0
1
mirror of https://github.com/radio95-rnt/fm95.git synced 2026-02-26 19:23:51 +01:00
Files
fm95/filter/bs412.h
2026-02-19 17:32:29 +01:00

37 lines
811 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_gain;
float gain;
double avg_power;
float alpha;
uint8_t can_compress : 1;
uint8_t second_counter;
float last_output;
float avg_deviation;
float modulation_power;
} BS412Compressor;
// float dbr_to_deviation(float dbr);
float deviation_to_dbr(float deviation);
void init_bs412(BS412Compressor *comp, uint32_t mpx_deviation, float target_power, float attack, float release, float max_gain, uint32_t sample_rate);
float bs412_compress(BS412Compressor *comp, float audio, float sample_mpx);