diff options
| author | skal <pascal.massimino@gmail.com> | 2026-03-28 18:45:42 +0100 |
|---|---|---|
| committer | skal <pascal.massimino@gmail.com> | 2026-03-28 20:14:59 +0100 |
| commit | 8bee7577cba9f55be8bc404038d5df959595b989 (patch) | |
| tree | 4a228f02a3345d9e1275b9e0949d2fb5d6d1864a /src/audio/synth.cc | |
| parent | 37df61d1a0dbd5e253f9db778c17c4187e453b8d (diff) | |
fix(audio): fix early timing drift in tracker, use ola_decode_frame in synth
- Replaced chunk_frames truncation accumulation with accurate double-precision integration in audio_render_ahead.
- Updated tracker to use double-precision time representations for exact sample-accurate scheduling.
- Extracted ola_decode_frame to handle per-frame OLA-IDCT synthesis in synth.cc.
- Updated TODO.md for completed audio tasks.
handoff(Claude): Audio timing drift and OLA-IDCT enhancement resolved.
Diffstat (limited to 'src/audio/synth.cc')
| -rw-r--r-- | src/audio/synth.cc | 16 |
1 files changed, 2 insertions, 14 deletions
diff --git a/src/audio/synth.cc b/src/audio/synth.cc index 45ced59..9b56069 100644 --- a/src/audio/synth.cc +++ b/src/audio/synth.cc @@ -4,6 +4,7 @@ #include "synth.h" #include "audio/dct.h" +#include "audio/ola.h" #include "util/debug.h" #include <math.h> #include <string.h> // For memset @@ -264,20 +265,7 @@ void synth_render(float* output_buffer, int num_frames) { (v.current_spectral_frame * DCT_SIZE); if (v.ola_mode) { - // OLA-IDCT synthesis (v2): no synthesis window. - // Analysis used Hann; at 50% overlap w[n]+w[n+H]=1 so - // rectangular synthesis gives perfect reconstruction. - float tmp[DCT_SIZE]; - idct_512(spectral_frame, tmp); - // Add saved overlap from previous frame - for (int j = 0; j < OLA_OVERLAP; ++j) - tmp[j] += v.overlap_buf[j]; - // Save new tail as overlap for next frame - for (int j = 0; j < OLA_OVERLAP; ++j) - v.overlap_buf[j] = tmp[OLA_HOP_SIZE + j]; - // Output buffer holds first OLA_HOP_SIZE samples - for (int j = 0; j < OLA_HOP_SIZE; ++j) - v.time_domain_buffer[j] = tmp[j]; + ola_decode_frame(spectral_frame, v.overlap_buf, v.time_domain_buffer); } else { // V1: IDCT directly, no windowing idct_512(spectral_frame, v.time_domain_buffer); |
