filter of sorts
This commit is contained in:
parent
bde0863a15
commit
357cbbac9a
@ -115,6 +115,8 @@ void Chassis::run(const float **, float **outputs, uint32_t frames, const MidiEv
|
|||||||
// flatten the left channel to use as temporary storage, since
|
// flatten the left channel to use as temporary storage, since
|
||||||
// the synth engine only generates a mono channel
|
// the synth engine only generates a mono channel
|
||||||
bzero(outputs[0], sizeof(float) * frames);
|
bzero(outputs[0], sizeof(float) * frames);
|
||||||
|
bzero(outputs[1], sizeof(float) * frames);
|
||||||
|
|
||||||
|
|
||||||
// get any of the last block's worth of MIDI out of the way
|
// get any of the last block's worth of MIDI out of the way
|
||||||
lastEvent = 0;
|
lastEvent = 0;
|
||||||
@ -157,6 +159,7 @@ void Chassis::run(const float **, float **outputs, uint32_t frames, const MidiEv
|
|||||||
s.voice[i].run(s, outputs[0] + framePos, sizeThisTime);
|
s.voice[i].run(s, outputs[0] + framePos, sizeThisTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
framePos += sizeThisTime;
|
framePos += sizeThisTime;
|
||||||
s.framesLeft -= sizeThisTime;
|
s.framesLeft -= sizeThisTime;
|
||||||
s.blockLeft -= sizeThisTime;
|
s.blockLeft -= sizeThisTime;
|
||||||
|
@ -146,7 +146,7 @@ void Chassis::initParameter(uint32_t index, Parameter ¶meter) {
|
|||||||
parameter.ranges.min = 0.0f;
|
parameter.ranges.min = 0.0f;
|
||||||
parameter.ranges.max = 127.0f;
|
parameter.ranges.max = 127.0f;
|
||||||
parameter.ranges.def = 0.0f;
|
parameter.ranges.def = 0.0f;
|
||||||
parameter.midiCC = 74;
|
parameter.midiCC = 71;
|
||||||
break;
|
break;
|
||||||
case paramVCFMode:
|
case paramVCFMode:
|
||||||
parameter.hints = kParameterIsAutomatable | kParameterIsBoolean;
|
parameter.hints = kParameterIsAutomatable | kParameterIsBoolean;
|
||||||
|
@ -41,9 +41,12 @@ void Voice::run(Synth &s, float *buffer, uint32_t samples) {
|
|||||||
// there's a resistor on the panel board to sprag the range
|
// there's a resistor on the panel board to sprag the range
|
||||||
float pw = s.ff4f / 32768.0f;
|
float pw = s.ff4f / 32768.0f;
|
||||||
|
|
||||||
float sqr = (s.patchRam.switch1 & 0x08) ? 0.175 : 0;
|
float fb, res = s.patchRam.vcfReso / 24.0f; // guess
|
||||||
float saw = (s.patchRam.switch1 & 0x10) ? 0.220 : 0;
|
float cut = s.patchRam.vcfFreq / 400.0f; // guess
|
||||||
float sub = (s.patchRam.sub / 127.0f) * 0.275;
|
|
||||||
|
float sqr = (s.patchRam.switch1 & 0x08) ? 0.63 : 0; //? 0.175 : 0;
|
||||||
|
float saw = (s.patchRam.switch1 & 0x10) ? 0.8 : 0; //? 0.220 : 0;
|
||||||
|
float sub = (s.patchRam.sub / 127.0f); // * 0.275;
|
||||||
|
|
||||||
float gain = 0.5 * powf(2, (s.patchRam.vca / 64.0f) - 1);
|
float gain = 0.5 * powf(2, (s.patchRam.vca / 64.0f) - 1);
|
||||||
|
|
||||||
@ -97,8 +100,29 @@ void Voice::run(Synth &s, float *buffer, uint32_t samples) {
|
|||||||
out = y;
|
out = y;
|
||||||
// widthDelay = pw;
|
// widthDelay = pw;
|
||||||
|
|
||||||
|
//out *= 0.5;
|
||||||
|
|
||||||
|
for (uint8_t ovs = 0; ovs < 4; ovs++) {
|
||||||
|
fb = b4;
|
||||||
|
// hard clip
|
||||||
|
if (fb > 1) fb = 1;
|
||||||
|
if (fb < -1) fb = -1;
|
||||||
|
|
||||||
|
fb = out - (fb * res);
|
||||||
|
b1 = ((fb - b1) * cut) + b1;
|
||||||
|
b2 = ((b1 - b2) * cut) + b2;
|
||||||
|
b3 = ((b2 - b3) * cut) + b3;
|
||||||
|
b4 = ((b3 - b4) * cut) + b4;
|
||||||
|
}
|
||||||
|
|
||||||
vr58c106 += ((vcaEnv - vr58c106) * 0.0075);
|
vr58c106 += ((vcaEnv - vr58c106) * 0.0075);
|
||||||
lastpw = pw;
|
lastpw = pw;
|
||||||
buffer[i] += (gain * out * vr58c106);
|
|
||||||
|
out = b4 * (0.275);
|
||||||
|
|
||||||
|
buffer[i] += (gain * b4 * vr58c106);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Voice::filter(Synth &s, float *buffer, uint32_t samples) {
|
||||||
|
}
|
@ -34,6 +34,8 @@ class Voice {
|
|||||||
void run(Synth &s, float *buffer, uint32_t samples);
|
void run(Synth &s, float *buffer, uint32_t samples);
|
||||||
void gate(Synth &s);
|
void gate(Synth &s);
|
||||||
void calcPitch(Synth &s);
|
void calcPitch(Synth &s);
|
||||||
|
void filter(Synth &s, float *buffer, uint32_t samples);
|
||||||
|
|
||||||
uint16_t ff71 = 0; // stores pitch + fraction
|
uint16_t ff71 = 0; // stores pitch + fraction
|
||||||
|
|
||||||
float omega;
|
float omega;
|
||||||
@ -64,6 +66,9 @@ class Voice {
|
|||||||
|
|
||||||
float lastpw = 0;
|
float lastpw = 0;
|
||||||
float vr58c106 = 0;
|
float vr58c106 = 0;
|
||||||
|
|
||||||
|
float b1, b2, b3, b4;
|
||||||
|
|
||||||
uint16_t attack_table[128] = {
|
uint16_t attack_table[128] = {
|
||||||
0x4000, 0x2000, 0x1000, 0x0aaa, 0x0800, 0x0666, 0x0555, 0x0492, 0x0400,
|
0x4000, 0x2000, 0x1000, 0x0aaa, 0x0800, 0x0666, 0x0555, 0x0492, 0x0400,
|
||||||
0x038e, 0x0333, 0x02e9, 0x02ab, 0x0276, 0x0249, 0x0222, 0x0200, 0x01e2,
|
0x038e, 0x0333, 0x02e9, 0x02ab, 0x0276, 0x0249, 0x0222, 0x0200, 0x01e2,
|
||||||
|
Loading…
Reference in New Issue
Block a user