blob: 22b1167b9ce0b84f2b0b18cb4a9a6bbc316d6edf (
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
|
#include "Compresaturator.h"
#include <iostream>
#include <lv2wrapper.h>
Compresaturator::Compresaturator(double rate)
: LV2Plugin(rate)
{
}
void Compresaturator::activate()
{
A = 0.5; //-12 to +12 dB
B = 0.5; //0 to 100%
C = 0.5; //50 to 5000 samples, default 500
D = 1.0;
E = 1.0;
for(int count = 0; count < 10990; count++) {dL[count] = 0.0; dR[count] = 0.0;}
dCount = 0;
lastWidthL = 500;
padFactorL = 0;
lastWidthR = 500;
padFactorR = 0;
fpd = 17;
//this is reset: values being initialized only once. Startup values, whatever they are.
}
void Compresaturator::run(uint32_t num_samples)
{
A = *params[0];
B = *params[1];
C = *params[2];
D = *params[3];
E = *params[4];
processReplacing(const_cast<float **>(in), out, num_samples);
}
//
// Include the processing code from the VST version.
//
#include <cmath>
#include "../../../LinuxVST/src/Compresaturator/CompresaturatorProc.cpp"
// Create the LV2Wrapper and register the plugin
LV2Wrapper<Compresaturator> plugin;
|