Turn your Immich photo library into video memory compilations with music and smart cuts
Project description
Immich Memories
Create beautiful yearly video compilations from your Immich photo library.
Immich Memories connects to your self-hosted Immich server, intelligently selects the best moments from your videos, and compiles them into shareable memory videos — perfect for year-end recaps or celebrating specific people in your life.
Full documentation: sam-dumont.github.io/immich-video-memory-generator
Reference Setup
graph LR
subgraph "Apple M2 Pro – 16GB RAM"
IM["Immich Memories<br/>Python + FFmpeg"]
LLM["omlx (mlx-vlm)<br/>Qwen2.5-VL local"]
end
subgraph "K8s Cluster (GPUs)"
ACE["ACE-Step 1.5<br/>T1000 8GB"]
MG["MusicGen API<br/>GTX 1070 8GB"]
end
subgraph "Synology NAS"
Immich["Immich v2.5.6<br/>Photos + Videos"]
end
IM -->|"API reads<br/>(download clips)"| Immich
IM -->|"Vision analysis<br/>(clip scoring)"| LLM
IM -->|"Background music<br/>(AI-generated)"| ACE
ACE -.->|"fallback"| MG
IM -->|"Upload back<br/>(optional)"| Immich
The LLM runs locally on the Mac via omlx (Apple Silicon MLX). Music generation runs on a K8s cluster with dedicated GPUs. Both are optional — the tool works without them, just without AI clip descriptions and generated music.
Docker (recommended for self-hosters)
# 1. Download the compose file
curl -O https://raw.githubusercontent.com/sam-dumont/immich-video-memory-generator/main/docker-compose.yml
# 2. Set your Immich connection
export IMMICH_URL="http://your-immich-server:2283"
export IMMICH_API_KEY="your-api-key"
# 3. Start
docker compose up -d
# 4. Open http://localhost:8080
Resource Requirements
| Phase | RAM | CPU | Time estimate |
|---|---|---|---|
| Idle (UI) | ~100MB | minimal | — |
| Analyzing clips | 2-4GB | 2+ cores | ~1 min per 10 clips |
| Encoding (1080p) | 4GB | 4 cores | ~2 min for 5 min video |
| Encoding (4K) | 6-8GB | 4+ cores | ~5 min for 5 min video |
Default Docker limits: 4GB RAM, 4 CPUs. This is not a NAS app — video analysis and encoding need real compute. Best run on a machine with 8GB+ RAM.
Developed and tested on: Apple M2 Pro, 16GB RAM, macOS. Not yet tested on other hardware. If you run it on Linux/x86, Synology, Unraid, or Raspberry Pi — please report your experience.
Supported Immich Versions
Developed and tested against Immich v2.5.6. Should work with v1.100+ (uses the /api/ endpoint prefix), but no guarantees for older versions.
Optional: LLM for smart clip analysis
For AI-powered content analysis (identifies what's happening in each clip), point to any OpenAI-compatible vision model:
# In ~/.immich-memories/config.yaml
advanced:
llm:
provider: "openai-compatible"
base_url: "http://your-llm-server:8080/v1"
model: "qwen2.5-vl"
Quick Install
# One-liner (no clone needed)
uvx immich-memories --help
# Or clone and install
git clone https://github.com/sam-dumont/immich-video-memory-generator.git
cd immich-video-memory-generator
uv sync
Quick Start
# 1. Configure
mkdir -p ~/.immich-memories
cat > ~/.immich-memories/config.yaml << EOF
immich:
url: "https://photos.example.com"
api_key: "your-api-key-here"
EOF
# 2. Launch the UI
immich-memories ui
# Opens at http://localhost:8080
# 3. Or use the CLI
immich-memories generate --year 2024 --person "John" --output ~/Videos/john_2024.mp4
Key Features
- Immich Integration — Direct REST API connection with face recognition support
- Smart Clip Selection — Scene detection, interest scoring, duplicate filtering
- Face-Aware Cropping — Keeps faces centered when converting aspect ratios
- Hardware Acceleration — NVIDIA NVENC, Apple VideoToolbox, Intel QSV, AMD VAAPI
- AI Music Generation — ACE-Step or MusicGen with automatic mood detection
- Audio Ducking — Music lowers automatically during speech
- Web UI + CLI — 4-step wizard or headless automation
- Docker & Kubernetes — Containerized deployment with GPU support
Documentation
See the full documentation for:
- Installation options (uv, pip, Docker, Kubernetes, Terraform)
- UI Walkthrough
- CLI Reference
- Configuration
- Hardware Acceleration
- AI Music
- Guides
Development
make dev # Install all dependencies
make check # Run all checks (lint, format, typecheck, tests)
make ci # Full CI pipeline
make help # Show all available targets
See CONTRIBUTING.md for guidelines.
Built with AI
This entire codebase was written with AI (Claude) as an experiment in building complex software cleanly with AI assistance. 1,100+ tests, strict quality gates, the works. See DISCLAIMER.md for the full story.
License
MIT License — see LICENSE for details.
Made with ❤️ for the Immich community
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file immich_memories-0.16.0.tar.gz.
File metadata
- Download URL: immich_memories-0.16.0.tar.gz
- Upload date:
- Size: 912.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b8928d448ea40cda3a325ed34943e5ee5538048d68fd71a2206ca553f43ef73c
|
|
| MD5 |
5a3fa1a328178d045b5a8e0cd4ca5421
|
|
| BLAKE2b-256 |
a96daa27c5477ee139211873fa75195b52c231a85f7f19f2ad16bef2765cdebf
|
Provenance
The following attestation bundles were made for immich_memories-0.16.0.tar.gz:
Publisher:
release.yml on sam-dumont/immich-video-memory-generator
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
immich_memories-0.16.0.tar.gz -
Subject digest:
b8928d448ea40cda3a325ed34943e5ee5538048d68fd71a2206ca553f43ef73c - Sigstore transparency entry: 1143417276
- Sigstore integration time:
-
Permalink:
sam-dumont/immich-video-memory-generator@4c1b2b8c96a1ed812f8b7888d73a1e9c706da79c -
Branch / Tag:
refs/heads/main - Owner: https://github.com/sam-dumont
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@4c1b2b8c96a1ed812f8b7888d73a1e9c706da79c -
Trigger Event:
push
-
Statement type:
File details
Details for the file immich_memories-0.16.0-py3-none-any.whl.
File metadata
- Download URL: immich_memories-0.16.0-py3-none-any.whl
- Upload date:
- Size: 543.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7211ce42deacab7d4c784f6a58fae1094b95d3ed0b6d3ca8972b1e486bf1c9df
|
|
| MD5 |
56ff629bd2669eec3b276fae935f0181
|
|
| BLAKE2b-256 |
74e58c0f80f13ef10106180a347f03c49f2b437d524409d7b0d0458c2ce78087
|
Provenance
The following attestation bundles were made for immich_memories-0.16.0-py3-none-any.whl:
Publisher:
release.yml on sam-dumont/immich-video-memory-generator
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
immich_memories-0.16.0-py3-none-any.whl -
Subject digest:
7211ce42deacab7d4c784f6a58fae1094b95d3ed0b6d3ca8972b1e486bf1c9df - Sigstore transparency entry: 1143417346
- Sigstore integration time:
-
Permalink:
sam-dumont/immich-video-memory-generator@4c1b2b8c96a1ed812f8b7888d73a1e9c706da79c -
Branch / Tag:
refs/heads/main - Owner: https://github.com/sam-dumont
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@4c1b2b8c96a1ed812f8b7888d73a1e9c706da79c -
Trigger Event:
push
-
Statement type: