I chose to compare PhotoPrism, LibrePhotos, and Damselfly, because they seemed like the strongest freely available candidates for a large library of photographs.
I am mostly interested in face clustering (DBSCAN) and other "AI" capabilities like auto-categorization. Import speed is not as important to me as "playback" speed. I don't mind if it takes a few days but once everything is indexed and processed then it should be fast to explore everything.
The dataset that I used for this comparison was under 22GiB but over 750,000 images. Mostly AVIF files but some PNG and some JPEG.
All three were pretty easy to get started. I liked that damselfly automatically started scanning. But I don't like that it starts a bunch of folder watchers (inotify, etc) and there doesn't seem to be an option to disable that.
So far, I have the most to complain about PhotoPrism:
I disliked that PhotoPrism creates a sidecar YAML file for each image--though it does save this in the PhotoPrism Storage folder rather than mucking up your Originals folder--so I know it could be worse! However, this can be disabled with PHOTOPRISM_SIDECAR_YAML="false"
. But it is enabled by default!
It also seems weird that PHOTOPRISM_DISABLE_CHOWN is enabled by default, or even an option at all. LibrePhotos is more sane in this regard where there are a couple chmod commands in the LibrePhotos documentation that you can run if it is a problem.
Enabling WAL mode for the PhotoPrism SQLite DB sped up the import process a bit but it did seem to be the slowest of the three. However, they do recommend to use MariaDB for larger collections so I will delete everything and rescan with that for a more fair evaluation of playback performance.
However, PhotoPrism's documentation is a lot more well-written than LibrePhotos--both in terms of detail and terseness. And Damselfly doesn't even have a proper documentation site... nothing wrong with a bunch of markdown files but what exists is pretty sparse. So PhotoPrism is definitely winning on the documentation front!
The only other complaint that I have at this point is that LibrePhotos requires docker-compose--although the happy path is well-trod and things just work. If anything, infrastructure seems the most robust for LibrePhotos because more of the moving parts seem to be separated cleanly (by HTTP). So my complaint here is really just a complaint against YAML: 127.0.0.1:3000:80 is not the same as "127.0.0.1:3000:80".
Immich's setup is very similar to LibrePhotos. The documentation is at the same quality level as PhotoPrism. I think it wins this round. But there is one caveat that makes Immich setup different from the other three: Immich wants to copy all photos that it imports so you might need to follow the External Library guide. If you use SELinux then you might need to use :ro,z
so that all the other microservice containers can read the images--I'm not 100% sure. Using :ro
on its own wasn't working for me but maybe :ro,Z
would also work.
PhotoPrism makes 8 JPEG thumbnails with different crop/aspect ratio: center, left, right, fit, etc. This can add up but mostly in terms of file counts.
LibrePhotos generates 3 WebP thumbnails for each original: big, square, and square_small. In theory, these should be smaller in file size; however, the thumbnail size was about 3x the size of my original photos: 58 GiB in my case.
LibrePhotos also dumps all the photos into the same folder which is a big no-no. To contrast, PhotoPrism puts the thumbnails in three nested folders based on the first three chars of the hash used for the filename of the thumbnail. Damselfly retains the path of the original photos relative to the /pictures
folder.
Damselfly generates, or at least saves, only one thumbnail per photo, as JPEG. Damselfly has the smallest cache so I would say that it won this round!
Immich generates two thumbnails but it is very configurable. Still, it takes up more space than Damselfly.
PhotoPrism automatic object detection labeling is not very good but better than nothing. PhotoPrism face clustering is great but face detection is terrible.
LibrePhotos has much better face detection! It found 10x as many faces than PhotoPrism. It also has a really neat Face Clusters scatter plot. But LibrePhotos didn't use EXIF or file modified date when indexing the photos :/ And it didn't seem to have object detection.
Damselfly has more advanced filtering options like the ability to see photos that don't have faces, portrait or landscape orientation, etc. The LibrePhotos interface is a bit cleaner but Damselfly has more core functionality.
Immich is definitely the most similar to Google Photos. Very polished. All of the core functionality is there, but no over technical features like word clouds or scatter plots. No lists of all objects detected. But you can search--and the object detection is very good. Better than PhotoPrism by quite a bit.
Right now, I'd recommend Immich and Damselfly. It would be nice if Immich could add a few more corpus exploration features, similar to LibrePhotos.