blob: 16efc9a8318f96389e02f72eaf0c650d094bfb4b (
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
55
56
57
58
59
60
61
|
#ifndef __Acceleration_H
#define __Acceleration_H
#include <cstdint>
// Required typa alias for VTS processing funcs.
using VstInt32 = int32_t;
class Acceleration {
public:
Acceleration(double rate);
void connect_port(uint32_t port, void * data);
void run(uint32_t num_samples);
static constexpr const char * URI = "https://www.airwindows.com/acceleration";
private:
void processReplacing(float **in, float **out, VstInt32 samples);
void processDoubleReplacing(double **in, double **out, VstInt32 samples);
double getSampleRate();
double rate;
const float * limit;
const float * drywet;
const float * in[2];
float * out[2];
// Temp values used by the processing code
double A; // Value of limit when processing called
double B; // Value of dry/wet when processing called
// To keep state between runs
double ataLastOutL;
double s1L;
double s2L;
double s3L;
double o1L;
double o2L;
double o3L;
double m1L;
double m2L;
double desL;
double ataLastOutR;
double s1R;
double s2R;
double s3R;
double o1R;
double o2R;
double o3R;
double m1R;
double m2R;
double desR;
long double fpNShapeL;
long double fpNShapeR;
};
#endif
|