summaryrefslogtreecommitdiff
path: root/src/audio/synth.cc
diff options
context:
space:
mode:
authorskal <pascal.massimino@gmail.com>2026-03-28 18:45:42 +0100
committerskal <pascal.massimino@gmail.com>2026-03-28 20:14:59 +0100
commit8bee7577cba9f55be8bc404038d5df959595b989 (patch)
tree4a228f02a3345d9e1275b9e0949d2fb5d6d1864a /src/audio/synth.cc
parent37df61d1a0dbd5e253f9db778c17c4187e453b8d (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.cc16
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);