-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathADSR.h
132 lines (115 loc) · 2.89 KB
/
ADSR.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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
#ifndef ADSR_h
#define ADSR_h
#include <Arduino.h>
class ADSR {
public:
ADSR();
ADSR(float sampleRate);
~ADSR(void);
float Process(void);
float GetOutput(void);
int GetState(void);
void SetADSR(uint8_t attack, uint8_t decay, uint8_t sustain, uint8_t release);
void Gate(int on);
void SetAttack(float attack);
void SetDecay(float decay);
void SetRelease(float release);
void SetSustain(float level);
float GetAttack(){return attack;}
float GetDecay(){return decay;}
float GetSustain(){return sustainLevel;}
float GetRelease(){return release;}
void Reset(void);
void SetAttackMidi(uint8_t attack);
void SetDecayMidi(uint8_t decay);
void SetSustainMidi(uint8_t sustain);
void SetReleaseMidi(uint8_t release);
uint8_t GetAttackMidi(){return midiAttack;}
uint8_t GetDecayMidi(){return midiDecay;}
uint8_t GetSustainMidi(){return midiSustain;}
uint8_t GetReleaseMidi(){return midiRelease;}
double GetAttackCoef(){return attackCoef;}
double GetDecayCoef(){return decayCoef;}
double GetReleaseCoef(){return releaseCoef;}
double GetReleaseBase(){return releaseBase;}
enum envState {
env_idle = 0,
env_attack,
env_decay,
env_sustain,
env_release
};
protected:
int state;
float output;
float attack;
float decay;
float release;
int32_t counter;
double attackCoef;
double decayCoef;
double releaseCoef;
double sustainLevel;
double attackBase;
double decayBase;
double releaseBase;
uint8_t midiAttack;
uint8_t midiDecay;
uint8_t midiSustain;
uint8_t midiRelease;
uint32_t sampleRate;
};
inline float ADSR::Process() {
switch (state) {
case env_idle:
output = 0.0;
break;
case env_attack:
output = output+attackBase + attackCoef;
if (output >= 1.0) {
output = 1.0; //http://www.earlevel.com/main/2013/06/01/envelope-generators/
state = env_decay;
}
break;
case env_decay:
output = output - decayCoef;
if (output <= sustainLevel || output <=0) {
output = sustainLevel;
state = env_sustain;
}
break;
case env_sustain:
output = sustainLevel;
break;
case env_release:
output = output - releaseCoef;
if (output <= 0.0) {
output = 0.0;
state = env_idle;
}
break;
}
return output;
}
inline void ADSR::Gate(int gate) {
if (gate)
{
output = 0.0;
state = env_attack;
}
else if (state != env_idle)
{
state = env_release;
}
}
inline int ADSR::GetState() {
return state;
}
inline void ADSR::Reset() {
state = env_idle;
output = 0.0;
}
inline float ADSR::GetOutput() {
return output;
}
#endif