Custom TensorFlow Models¶
As an alternative to the built-in model, PhotoPrism lets you configure custom more powerful TensorFlow models for image classification.1
Step 1: Mount model folder¶
In your compose.yaml file add a volume mount for a model folder.
compose.yaml
services:
  photoprism:
    ...
    volumes:
      - "./models/modelname:/opt/photoprism/assets/models/modelname"
      ...
Step 2: Download model and labels.txt¶
Download a suitable TensorFlow model and the labels.txt to your configured model folder.
It should now contain the following:
- saved_model.pb
- a variables/ subfolder with variables.index and variables.data-*
- labels.txt
PhotoPrism supports TensorFlow 2 image classification models in the SavedModel format.
Example Models¶
In our tests, the Vision Transformer model achieved the best accuracy. Inception V3 was faster and may better suited to low-power devices it produced more labels and had a higher error rate; it still outperformed the built-in NASNet model.
Step 3: Configure PhotoPrism¶
Now, create a new config/vision.yml file or edit the existing file in the storage folder of your PhotoPrism instance, following the example below. Its absolute path from inside the container is /photoprism/storage/config/vision.yml:
vision.yml
Models:
- Type: labels
  Name: modelname
  Resolution: 224
  TensorFlow:
    Output:
      Logits: true
- Type: nsfw
  Default: true
- Type: face
  Default: true
Thresholds:
  Confidence: 10
The config file must be named vision.yml, not vision.yaml, as otherwise it won't be found and will have no effect.
Step 4: Restart PhotoPrism¶
Run the following commands to restart photoprism and apply the new settings:
docker compose stop photoprism
docker compose up -d
On indexing the configured model will now be used to generate labels. Alternatively you can run the photoprism vision run CLI command to generate labels. 
Labels produced by TensorFlow models always have the source "image"; customizing the label source is not supported yet.
- 
Available to all users with the next stable version, see our release notes for details. ↩