-
-
Notifications
You must be signed in to change notification settings - Fork 3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
docs: Better Facial Recognition Clusters #14911
base: main
Are you sure you want to change the base?
Conversation
📖 Documentation deployed to pr-14911.preview.immich.app |
Would it make sense to apply some of this automatically on a rerun if the library has a large amount of assets? |
Not without deleting all previously assigned name data. |
mertalev wrote that maybe in the future there will be a refresh button that can prevent this. |
A generalization of this guide would be to use OPTICS instead of DBSCAN, which would basically cluster in order from the densest regions to the least dense. This guide is a valid alternative until something like that is implemented. |
Co-authored-by: Felix Bühler <[email protected]>
Once the reset jobs are complete, refine the recognition as follows: | ||
|
||
- **Step 1:** | ||
Return to **Minimum recognized faces** in Machine Learning Settings and lower the value to **8**. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
10 -> 8 might get the right result for your library, but I think it's too subtle to work as a general recommendation. Maybe 20 -> 10 -> 3?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
From a test I did, setting the value too high to start with causes many faces to not be recognized (because 20 faces per person is too many), which causes people who look similar to other person to merge (false positives).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
But this is going to vary by library, right? Some people will have large libraries where 10 vs 8 doesn't matter, some people will have burst photos, etc. You can adjust the text to recommend different numbers based on their library.
Set this to **0.5**. | ||
> This helps recognize more faces while avoiding false positives (non-faces). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Recommending a different detection score is out of scope for this guide. A lower score risks false positives that are difficult to deal with once they exist.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I can understand the reason you say this, I decided to point it out because in the test I did that once I obtained high-quality clusters even faces that are a little covered (and when the value is 0.6 they are not even recognized at all) manage to enter the high-quality cluster that is created and then there is no risk in faces that are not assigned to anyone.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It might not have caused an issue for your library, but I've seen it cause non-faces to come up for others and things get very messy. A guide that shows how to get higher quality results shouldn't suggest things that can often cause lower quality results.
|
||
Perform the following: | ||
|
||
1. **FACE DETECTION → Reset** |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just resetting facial recognition is enough without the detection score change. If you do change the detection score, then you should only queue face detection and let it queue faces for recognition automatically.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, in fact it should run the job automatically as you mentioned, it's a bit old guide I wrote, and if I'm not mistaken at the time there was a "bug" that didn't run this job automatically. (If this is no longer the case then I will remove this part)
## Outcome | ||
|
||
This method creates high-quality face clusters for core faces and ensures the model can reliably add new faces as they appear in your library. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This seems unnecessary.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍I will remove this part soon.
I haven't forgotten about this PR, I'm not at home right now so I'll edit it according to feedback when I can. |
I tried this guide on my library and the results were very promising, I thought I would make a guide that could help more people.
Maybe in the future it will be possible to make this process automatic 🤔
If it doesn't fit the documentation I will pass it on to Community Guides.
@mertalev I would like to know what you think about it and if you have any ideas for correction/improvement.