0
1
mirror of https://github.com/radio95-rnt/fm95.git synced 2026-02-27 11:33:54 +01:00
Files
fm95/filter/bs412.h
2025-12-30 22:06:59 +01:00

32 lines
662 B
C

#pragma once
#ifdef DEBUG
#define BS412_DEBUG
#endif
#include <math.h>
#include <string.h>
#include <stdint.h>
#ifdef BS412_DEBUG
#include "../lib/debug.h"
#endif
typedef struct
{
uint32_t mpx_deviation;
uint32_t sample_rate;
uint32_t sample_counter;
float target;
float attack;
float release;
float max;
float gain;
double avg_power;
double alpha;
} BS412Compressor;
float dbr_to_deviation(float dbr);
float deviation_to_dbr(float deviation);
void init_bs412(BS412Compressor *mpx, uint32_t mpx_deviation, float target_power, float attack, float release, float max, uint32_t sample_rate);
float bs412_compress(BS412Compressor *mpx, float average);