blob: edf15fdc3339fcb9ea6f8e6338cab4e574821143 (
plain) (
blame)
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
|
#ifndef __Hermepass_H
#define __Hermepass_H
#include <lv2plugin.h>
class Hermepass : public LV2Plugin<2> {
public:
Hermepass(double rate);
void activate();
void run(uint32_t num_samples);
static constexpr const char * URI = "https://www.airwindows.com/hermepass";
private:
/*
* These are the original DSP functions from the VST plugin.
* They need to be called from the LV2 plugins `run` function.
*/
void processReplacing(float **in, float **out, VstInt32 samples);
void processDoubleReplacing(double **in, double **out, VstInt32 samples);
/*
* Members needed by the processing functions.
*/
long double fpNShapeL;
long double fpNShapeR;
//default stuff
double iirAL;
double iirBL; //first stage is the flipping one, for lowest slope. It is always engaged, and is the highest one
double iirCL; //we introduce the second pole at the same frequency, to become a pseudo-Capacitor behavior
double iirDL;
double iirEL;
double iirFL; //our slope control will have a pow() on it so that the high orders are way to the right side
double iirGL;
double iirHL; //seven poles max, and the final pole is always at 20hz directly.
double iirAR;
double iirBR; //first stage is the flipping one, for lowest slope. It is always engaged, and is the highest one
double iirCR; //we introduce the second pole at the same frequency, to become a pseudo-Capacitor behavior
double iirDR;
double iirER;
double iirFR; //our slope control will have a pow() on it so that the high orders are way to the right side
double iirGR;
double iirHR; //seven poles max, and the final pole is always at 20hz directly.
bool fpFlip;
float A;
float B;
};
#endif
|