0
1
mirror of https://github.com/radio95-rnt/fm95.git synced 2026-02-27 03:23:54 +01:00
Files
fm95/lib/filters.h
2025-03-25 17:03:28 +01:00

28 lines
638 B
C

#pragma once
#include <string.h>
#include <stdlib.h>
#include <math.h>
#include "constants.h"
#include "oscillator.h"
#define FILTER_LEN 51
typedef struct
{
float alpha;
float prev_sample;
} ResistorCapacitor;
void init_preemphasis(ResistorCapacitor *filter, float tau, float sample_rate);
float apply_preemphasis(ResistorCapacitor *filter, float sample);
float hard_clip(float sample, float threshold);
typedef struct filters
{
float filter[FILTER_LEN];
int filter_idx;
} FIRFilter;
void init_bpf(FIRFilter *bpf, float start, float end);
void init_lpf(FIRFilter *lpf, float freq);
float fir_filter(FIRFilter *fir, float sample);