mirror of
https://github.com/radio95-rnt/fm95.git
synced 2026-02-26 19:23:51 +01:00
also delay pilot
This commit is contained in:
@@ -1,4 +1,6 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
typedef struct delay_line_t {
|
typedef struct delay_line_t {
|
||||||
float *buffer;
|
float *buffer;
|
||||||
|
|||||||
@@ -7,7 +7,9 @@ void init_stereo_encoder(StereoEncoder* st, uint8_t multiplier, Oscillator* osc,
|
|||||||
st->pilot_volume = pilot_volume;
|
st->pilot_volume = pilot_volume;
|
||||||
st->audio_volume = audio_volume;
|
st->audio_volume = audio_volume;
|
||||||
#ifdef STEREO_SSB
|
#ifdef STEREO_SSB
|
||||||
|
init_delay_line(&st->delay_pilot, osc->sample_rate);
|
||||||
init_delay_line(&st->delay, osc->sample_rate);
|
init_delay_line(&st->delay, osc->sample_rate);
|
||||||
|
set_delay_line(&st->delay_pilot, STEREO_SSB*2+1);
|
||||||
set_delay_line(&st->delay, STEREO_SSB*2+1);
|
set_delay_line(&st->delay, STEREO_SSB*2+1);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@@ -30,6 +32,9 @@ float stereo_encode(StereoEncoder* st, uint8_t enabled, float left, float right,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
float signalx1 = get_oscillator_sin_multiplier_ni(st->osc, st->multiplier);
|
float signalx1 = get_oscillator_sin_multiplier_ni(st->osc, st->multiplier);
|
||||||
|
#ifdef STEREO_SSB
|
||||||
|
signalx1 = delay_line(&st->delay_pilot, signalx1);
|
||||||
|
#endif
|
||||||
float signalx2 = get_oscillator_sin_multiplier_ni(st->osc, st->multiplier * 2.0f);
|
float signalx2 = get_oscillator_sin_multiplier_ni(st->osc, st->multiplier * 2.0f);
|
||||||
|
|
||||||
#ifdef STEREO_SSB
|
#ifdef STEREO_SSB
|
||||||
@@ -42,4 +47,5 @@ float stereo_encode(StereoEncoder* st, uint8_t enabled, float left, float right,
|
|||||||
|
|
||||||
void exit_stereo_encoder(StereoEncoder* st) {
|
void exit_stereo_encoder(StereoEncoder* st) {
|
||||||
exit_delay_line(&st->delay);
|
exit_delay_line(&st->delay);
|
||||||
|
exit_delay_line(&st->delay_pilot);
|
||||||
}
|
}
|
||||||
@@ -14,7 +14,8 @@ typedef struct
|
|||||||
Oscillator* osc;
|
Oscillator* osc;
|
||||||
float audio_volume;
|
float audio_volume;
|
||||||
float pilot_volume;
|
float pilot_volume;
|
||||||
struct delay_line_t delay;
|
delay_line_t delay;
|
||||||
|
delay_line_t delay_pilot;
|
||||||
} StereoEncoder;
|
} StereoEncoder;
|
||||||
|
|
||||||
void init_stereo_encoder(StereoEncoder *st, uint8_t multiplier, Oscillator *osc, float audio_volume, float pilot_volume);
|
void init_stereo_encoder(StereoEncoder *st, uint8_t multiplier, Oscillator *osc, float audio_volume, float pilot_volume);
|
||||||
|
|||||||
@@ -145,7 +145,7 @@ void cleanup_runtime(FM95_Runtime* runtime, const FM95_Config config) {
|
|||||||
}
|
}
|
||||||
#ifdef STEREO_SSB
|
#ifdef STEREO_SSB
|
||||||
firhilbf_destroy(runtime->stereo_hilbert);
|
firhilbf_destroy(runtime->stereo_hilbert);
|
||||||
exit_stereo_encoder(runtime->stencode);
|
exit_stereo_encoder(&runtime->stencode);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user