forked from copych/AcidBox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfx_filtercrusher.h
98 lines (72 loc) · 2.54 KB
/
fx_filtercrusher.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#pragma once
#ifndef FXFCR_H
#define FXFCR_H
/*
this file includes some simple effects
- dual filter
- bit crusher
Author: Marcel Licence
*/
/*
#define WAVEFORM_BIT 10UL
#define WAVEFORM_CNT (1<<WAVEFORM_BIT)
#define WAVEFORM_MSK ((1<<WAVEFORM_BIT)-1)
#define WAVEFORM_I(i) ((i) >> (32 - WAVEFORM_BIT)) & WAVEFORM_MSK
*/
class FxFilterCrusher {
public:
FxFilterCrusher() {}
void Init (float samplerate) {
Init();
}
void Init( void ) {
/* for ( int i = 0; i < WAVEFORM_CNT; i++ ) {
float val = (float)sin(i * 2.0f * PI / WAVEFORM_CNT);
sine[i] = val;
}
*/
mainFilterL_LP.filterCoeff = &filterGlobalC_LP;
mainFilterR_LP.filterCoeff = &filterGlobalC_LP;
mainFilterL_HP.filterCoeff = &filterGlobalC_HP;
mainFilterR_HP.filterCoeff = &filterGlobalC_HP;
};
inline float Process (float sample) {
Process(&sample, &sample);
return sample;
}
void Process( float* left, float* right );
void SetCutoff( float value ) ;
void SetResonance( float value ) ;
void SetBitCrusher( float value ) ;
private:
struct filterCoeffT {
float aNorm[2] = {0.0f, 0.0f};
float bNorm[3] = {1.0f, 0.0f, 0.0f};
};
struct filterProcT {
struct filterCoeffT *filterCoeff;
float w[2];
};
struct filterCoeffT filterGlobalC_LP, filterGlobalC_HP;
struct filterProcT mainFilterL_LP, mainFilterR_LP, mainFilterL_HP, mainFilterR_HP;
// float sine[WAVEFORM_CNT];
float highpassC = 0.0f;
float lowpassC = 1.0f;
float filtReso = 1.0f;
float div_2_reso = 0.5f;
float cutoff_hp_slow = 0.0f;
float cutoff_lp_slow = 1.0f;
uint8_t effect_prescaler = 0;
float bitCrusher = 1.0f;
float div_bitCrusher = 1.0f;
// calculate coefficients of the 2nd order IIR filter
inline void Filter_CalculateTP(float c, float one_div_2_reso, struct filterCoeffT *const filterC );
inline void Filter_CalculateHP(float c, float one_div_2_reso, struct filterCoeffT *const filterC );
inline void Filter_Process( float *const signal, struct filterProcT *const filterP ) {
const float out = filterP->filterCoeff->bNorm[0] * (*signal) + filterP->w[0];
filterP->w[0] = filterP->filterCoeff->bNorm[1] * (*signal) - filterP->filterCoeff->aNorm[0] * out + filterP->w[1];
filterP->w[1] = filterP->filterCoeff->bNorm[2] * (*signal) - filterP->filterCoeff->aNorm[1] * out;
*signal = out;
};
};
#endif