mirror of
https://github.com/radio95-rnt/fm95.git
synced 2026-02-26 19:23:51 +01:00
25 lines
659 B
C
25 lines
659 B
C
#pragma once
|
|
|
|
#include <math.h>
|
|
#include "../lib/constants.h"
|
|
|
|
typedef struct
|
|
{
|
|
float alpha;
|
|
float prev_sample;
|
|
float gain;
|
|
} ResistorCapacitor;
|
|
|
|
void init_preemphasis(ResistorCapacitor *filter, float tau, float sample_rate, float ref_freq);
|
|
float apply_preemphasis(ResistorCapacitor *filter, float sample);
|
|
|
|
typedef struct {
|
|
float a0, a1; // lowpass coeffs
|
|
float lp; // lowpass state
|
|
float low_gain; // gain for low frequencies
|
|
float high_gain; // gain for high frequencies
|
|
} TiltCorrectionFilter;
|
|
|
|
void tilt_init(TiltCorrectionFilter* f, float correction_strength, float sr);
|
|
float tilt(TiltCorrectionFilter *f, float in);
|