diff options
| author | St33v <github@f3rr3t.com> | 2026-06-10 19:10:38 +1000 |
|---|---|---|
| committer | St33v <github@f3rr3t.com> | 2026-06-10 19:10:38 +1000 |
| commit | e433a99ceddf7168d23377ffc8d585fc80ba8fb2 (patch) | |
| tree | 32f7ff056e404ae1d4563125c169bd4c535992aa /index.html | |
| parent | 59e7c485be1e9be62f0b4cdb7d1130701c1e3c46 (diff) | |
Add synoptic-morph: 30-day rolling morph timelapse
synopticMorph.sh: rolling-cache implementation. On each run:
1. Pick the last WINDOW_DAYS*4 charts from the archive.
2. For each adjacent pair, fill any missing pair-morph (cached at
/mnt/enclave/synoptic/pairs/<chartA>__<chartB>/p_NNNN.png).
3. Evict pair dirs whose slug isn't in the current window.
4. Symlink frames into a temp seq dir with LINGER on each source
chart and DWELL on the latest, fade-in 1s and fade-out 2s.
5. Encode to /srv/www/pestrel/morph.mp4 with ffmpeg/h264.
Bootstrap: ~50 min CPU on first run (119 pair morphs at ~25s each).
Steady state: ~1 min/cycle (1 new pair + concat + encode).
synoptic-morph.service: oneshot, TimeoutStartSec=2h to cover the
bootstrap, Nice=10 + IOSchedulingClass=idle so it doesn't fight
the system for CPU/disk.
synoptic.service gains OnSuccess=synoptic-morph.service so the
chain fires automatically after each successful chart fetch.
morph.html: points at /morph.mp4 now. index.html: "Three-day
history" button renamed to "Monthly history", URL /morph.html.
setup.sh: installs the new unit + script, provisions
/mnt/enclave/synoptic/{pairs,out} when the enclave mount is present.
.gitignore: drop .claude/ (transient harness state).
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
Diffstat (limited to 'index.html')
| -rw-r--r-- | index.html | 9 |
1 files changed, 6 insertions, 3 deletions
@@ -8,18 +8,21 @@ body { margin: 0; background: #000; display: flex; justify-content: center; align-items: center; height: 100vh; } img { max-width: 100%; max-height: 100vh; } a.nav-button { - position: fixed; left: 0; top: 16.6%; + position: fixed; left: 0; color: #aaa; background: rgba(0,0,0,0.7); padding: 0.45em 0.9em; border: 1px solid #444; border-left: none; border-radius: 0 0.3em 0.3em 0; text-decoration: none; font-family: sans-serif; font-size: 0.95em; } - a.nav-button:hover { color: #fff; border-color: #888; } + a.nav-button.radars { top: 60%; } + a.nav-button.history { top: 75%; } + a.nav-button:hover { color: #fff; border-color: #888; } </style> </head> <body> <img src="/synopticLatest.png" alt="Latest synoptic"> - <a class="nav-button" href="https://radar.pestrel.com/">Radars</a> + <a class="nav-button radars" href="https://radar.pestrel.com/">Radars</a> + <a class="nav-button history" href="/morph.html">Monthly history</a> </body> </html> |
