wedding-immortalist
npx skills add https://github.com/curiositech/some_claude_skills --skill wedding-immortalist
Agent 安装分布
Skill 文档
Wedding Immortalist
Transform wedding photos and video into an eternal, immersive 3D experience. Create living memories that let couples and guests relive the magic forever.
When to Use This Skill
Use for:
- Processing thousands of wedding photos into 3DGS scenes
- Creating theatre-mode experiences where ceremony/reception moments play in-place
- Building face-clustered guest rosters with best-photo selection
- Matching design aesthetics to wedding themes (disco, rustic, beach, modern, queer celebrations)
- AI-curated photo selection per guest with aesthetic scoring
NOT for:
- General photo editing â use native-app-designer
- Non-wedding 3DGS â use drone-inspection-specialist
- Event planning â not a wedding planner
- Video editing without 3D reconstruction
Core Pipeline
âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
â WEDDING IMMORTALIST PIPELINE â
âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ¤
â â
â 1. INGEST 2. RECONSTRUCT 3. CLUSTER â
â ââ Photos (1000s) ââ COLMAP SfM ââ Face detect â
â ââ Video (hours) ââ 3DGS training ââ Embeddings â
â ââ Audio/speeches ââ Scene merge ââ Identity link â
â â
â 4. CURATE 5. DESIGN 6. PRESENT â
â ââ Aesthetic score ââ Theme extract ââ Web viewer â
â ââ Per-person best ââ Color palette ââ Theatre mode â
â ââ Moment detect ââ Typography ââ Guest roster â
â â
âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
Theme-Adaptive Design
Theme Detection & Matching
Every wedding has a unique aesthetic. Extract and honor it:
| Theme Type | Color Palette | Typography | UI Elements |
|---|---|---|---|
| 70s Disco | Gold, orange, burnt sienna, deep purple | Groovy script, bold sans | Mirror balls, starbursts, warm gradients |
| Rustic/Barn | Earth tones, sage, cream, wood | Serif, hand-lettered | Burlap textures, wildflower accents |
| Beach/Coastal | Ocean blues, sand, coral, seafoam | Light sans, script | Shell motifs, wave patterns |
| Modern Minimal | Black, white, metallics | Clean geometric sans | Sharp lines, negative space |
| Queer Joy | Rainbow spectrums, bold colors | Expressive, varied | Pride elements, celebration maximalism |
| Cultural Fusion | Per tradition | Traditional + modern | Cultural motifs, heritage patterns |
Extracting Theme from Photos
# Theme extraction signals
THEME_SIGNALS = {
'color_palette': 'Dominant colors from venue, florals, attire',
'lighting_mood': 'Warm/cool, natural/dramatic, string lights/chandeliers',
'decor_elements': 'Rustic/modern/vintage/eclectic',
'attire_style': 'Traditional/non-traditional, formal/casual',
'cultural_markers': 'Religious symbols, cultural traditions',
'era_aesthetic': '70s disco, 20s gatsby, etc.'
}
3D Gaussian Splatting Pipeline
Photo/Video Ingestion
Optimal Input Strategy:
âââ Video: Extract 2-3 fps (80% overlap minimum)
âââ Photos: Include ALL photographer shots
âââ Phone photos: Guest uploads (georeferenced bonus)
âââ Coverage: Ceremony + reception + all spaces
Quality Thresholds:
âââ Minimum images per space: 50-100
âââ Overlap requirement: 60-80%
âââ Blur rejection: Laplacian variance < 100 = skip
âââ Exposure: Reject severe over/underexposure
COLMAP Structure from Motion
# Feature extraction
colmap feature_extractor \
--database_path database.db \
--image_path images/ \
--ImageReader.single_camera 0 \
--SiftExtraction.max_image_size 3200
# Exhaustive matching for comprehensive coverage
colmap exhaustive_matcher \
--database_path database.db \
--SiftMatching.guided_matching 1
# Sparse reconstruction
colmap mapper \
--database_path database.db \
--image_path images/ \
--output_path sparse/
# Dense reconstruction (optional, for mesh)
colmap image_undistorter ...
colmap patch_match_stereo ...
3DGS Training
# Wedding-optimized 3DGS settings
WEDDING_3DGS_CONFIG = {
'iterations': 50_000, # High quality for permanent archive
'densify_from_iter': 500,
'densify_until_iter': 15_000,
'densification_interval': 100,
'opacity_reset_interval': 3000,
'sh_degree': 3, # Full spherical harmonics for lighting
'percent_dense': 0.01,
'densify_grad_threshold': 0.0002,
}
# Multi-space merge strategy
SPACES = ['ceremony', 'cocktail_hour', 'reception', 'photo_booth', 'dance_floor']
# Train each separately, then create unified navigation
Face Clustering System
Pipeline
ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
â FACE CLUSTERING PIPELINE â
ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ¤
â 1. Detection (RetinaFace/MTCNN) â
â ââ All faces in all photos â
â 2. Alignment (5-point landmark) â
â ââ Standardize for embedding â
â 3. Embedding (ArcFace/AdaFace) â
â ââ 512-dim identity vector per face â
â 4. Clustering (HDBSCAN) â
â ââ Group by identity, handle edge cases â
â 5. Identity Linking â
â ââ Match to couple, wedding party, family, guests â
â 6. Best Photo Selection â
â ââ Aesthetic scoring per cluster â
ââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ
Clustering Parameters
CLUSTERING_CONFIG = {
'min_cluster_size': 3, # At least 3 photos to form identity
'min_samples': 2,
'metric': 'cosine',
'cluster_selection_epsilon': 0.3,
'cluster_selection_method': 'eom',
}
# Identity priority for naming
IDENTITY_PRIORITY = [
'couple_1', 'couple_2', # The married couple
'wedding_party', # Bridesmaids, groomspeople
'parents', # Parents of the couple
'grandparents',
'siblings',
'extended_family',
'friends',
'vendors', # Photographer, DJ, etc.
]
Identity Linking Workflow
- Couple identification: User tags couple in 2-3 photos
- Wedding party: User identifies key people
- Auto-propagation: Embeddings match across all photos
- Guest matching: Optional guest list import for name assignment
- Manual corrections: UI for fixing mismatches
Aesthetic Scoring
Per-Photo Quality Metrics
AESTHETIC_FEATURES = {
# Technical quality
'sharpness': 'Laplacian variance, MTF analysis',
'exposure': 'Histogram analysis, dynamic range',
'noise': 'High-ISO detection, grain analysis',
# Composition
'rule_of_thirds': 'Subject placement scoring',
'symmetry': 'For venue/group shots',
'framing': 'Negative space, balance',
# Face-specific
'expression': 'Smile detection, eye openness',
'blink_detection': 'Eyes closed penalty',
'gaze_direction': 'Looking at camera vs. candid',
'face_occlusion': 'Nothing blocking the face',
'face_lighting': 'Even illumination, no harsh shadows',
# Emotional
'genuine_smile': 'Duchenne marker detection',
'moment_quality': 'Laughter, tears, embraces',
}
Best Photo Selection Per Person
def select_best_photos(cluster_photos, n=5):
"""Select top N photos for a person across all their appearances."""
scores = []
for photo in cluster_photos:
score = (
0.25 * technical_quality(photo) +
0.25 * composition_score(photo) +
0.30 * expression_quality(photo) +
0.20 * context_diversity(photo, scores) # Avoid all similar shots
)
scores.append((photo, score))
# Select top N with diversity constraint
return diverse_top_n(scores, n, diversity_threshold=0.7)
Theatre Mode
Moment Detection & Playback
KEY MOMENTS (auto-detected + user-tagged):
âââ Ceremony
â âââ Processional
â âââ Vows exchange
â âââ Ring ceremony
â âââ First kiss
â âââ Recessional
âââ Reception
â âââ Grand entrance
â âââ First dance
â âââ Parent dances
â âââ Toasts/speeches
â âââ Cake cutting
â âââ Bouquet/garter
âââ Party
â âââ Dance floor highlights
â âââ Exit/sendoff
âââ Candids
âââ Emotional moments (tears, laughter)
âââ Spontaneous joy
In-Scene Video Projection
Theatre Mode Rendering:
1. User navigates 3DGS scene freely
2. Approaches "moment marker" (glowing orb/frame)
3. Video/slideshow plays IN the 3D space
âââ On walls where projector was
âââ Floating frames in dance floor area
âââ Photo booth backdrop location
4. Spatial audio for speeches/music
5. User can pause, scrub, exit to continue exploring
Web Viewer Architecture
// Wedding Immortalist Viewer Components
const VIEWER_FEATURES = {
// 3DGS Navigation
gaussianSplatting: {
renderer: 'three-gaussian-splat',
navigation: 'orbit + first-person',
qualityLevels: ['preview', 'standard', 'maximum'],
},
// Theatre Mode
theatreMode: {
momentMarkers: true,
videoInScene: true,
spatialAudio: true,
transitionEffects: 'theme-matched',
},
// Guest Roster
guestRoster: {
faceGrid: 'clustered by identity',
photoGallery: 'per-person best shots',
searchByName: true,
shareableLinks: 'per-guest galleries',
},
// Theme
theming: {
colorPalette: 'extracted from wedding',
typography: 'theme-matched',
uiElements: 'aesthetic-consistent',
},
};
Anti-Patterns
“All Frames, All the Time”
Wrong: Extracting every video frame for 3DGS. Why: Redundant data, 10x slower processing, no quality improvement. Right: 2-3 fps extraction with motion-based keyframe selection.
“One Giant Scene”
Wrong: Training single 3DGS for entire venue. Why: Memory explosion, quality degradation, impossible on consumer hardware. Right: Train per-space, create unified navigation with seamless transitions.
“Default Clustering Threshold”
Wrong: Using default HDBSCAN settings. Why: Wedding photos have varying lighting, makeup, anglesâneed tuning. Right: Tune per-wedding based on photo count and quality variance.
“Ignoring Theme”
Wrong: Generic white/gray viewer UI for disco wedding. Why: Destroys the personality and joy of the event. Right: Extract and honor the couple’s aesthetic choices.
“Photographer Only”
Wrong: Using only professional photos. Why: Misses candid moments, guest perspectives, coverage gaps. Right: Merge professional + guest photos for complete coverage.
Guest Experience Features
Shareable Guest Galleries
Per-Guest Experience:
âââ Personalized link: yourwedding.com/guests/aunt-martha
âââ Their best photos (AI-curated)
âââ Photos with the couple
âââ Group photos they appear in
âââ Download options (full-res)
âââ "Add to my memories" for their own archives
Collaborative Enhancement
Guest Contribution Portal:
âââ Upload their own photos
âââ Tag themselves in unidentified clusters
âââ Correct misidentifications
âââ Add names to unknown guests
âââ Submit video moments they captured
Output Deliverables
wedding-immortalist-output/
âââ 3dgs-scenes/
â âââ ceremony/
â âââ cocktail/
â âââ reception/
â âââ unified-navigation.json
âââ guest-roster/
â âââ face-clusters/
â âââ identity-mapping.json
â âââ per-person-galleries/
âââ theatre-mode/
â âââ moment-markers.json
â âââ video-segments/
â âââ spatial-audio/
âââ web-viewer/
â âââ index.html
â âââ theme-config.json
â âââ assets/
âââ exports/
âââ full-resolution-photos/
âââ guest-gallery-zips/
âââ video-compilations/
Integration Points
- drone-inspection-specialist: 3DGS techniques, COLMAP pipeline
- collage-layout-expert: Photo arrangement, aesthetic composition
- color-theory-palette-harmony-expert: Theme color extraction
- clip-aware-embeddings: Photo-text matching for search
- photo-composition-critic: Aesthetic quality scoring
Core Philosophy: A wedding happens once. The memories should live forever. This skill transforms ephemeral moments into an eternal, explorable experience that honors the couple’s unique celebrationâwhether it’s a disco dance party, a rustic barn gathering, or two grooms celebrating their love with chosen family.