0
1
mirror of https://github.com/radio95-rnt/fm95.git synced 2026-02-26 19:23:51 +01:00
This commit is contained in:
2025-03-08 21:23:23 +01:00
parent 21b009f68b
commit 2b720500de
3 changed files with 3 additions and 43 deletions

View File

@@ -31,26 +31,6 @@ float apply_biquad(BiquadFilter* filter, float input) {
return out;
}
void init_upsampler(Upsampler* up, int ratio, float sample_rate) {
up->i = 0;
up->ratio = ratio;
init_lpf(&up->lpf, sample_rate*ratio, 0.70710678f, sample_rate);
}
float upsample(Upsampler* up, float sample) {
float output = 0.0f;
if (up->i == 0) {
output = sample;
}
output = apply_biquad(&up->lpf, output);
up->i++;
if(up->i >= up->ratio) up->i = 0;
return output;
}
float hard_clip(float sample, float threshold) {
if (sample > threshold) {

View File

@@ -23,15 +23,6 @@ typedef struct {
void init_lpf(BiquadFilter* filter, float cutoffFreq, float qFactor, float sampleRate);
float apply_biquad(BiquadFilter* filter, float input);
typedef struct
{
int i;
int ratio;
BiquadFilter lpf;
} Upsampler;
void init_upsampler(Upsampler* up, int ratio, float sample_rate);
float upsample(Upsampler *up, float sample);
float hard_clip(float sample, float threshold);
float voltage_db_to_voltage(float db);
float power_db_to_voltage(float db);