airwindows/plugins/MacVST/kCyberCity/source/kCyberCityProc.cpp
Christopher Johnson 6c583d8a64 kCyberCity
2026-05-16 20:25:14 -04:00

1132 lines
44 KiB
C++
Executable file

/* ========================================
* kCyberCity - kCyberCity.h
* Copyright (c) airwindows, Airwindows uses the MIT license
* ======================================== */
#ifndef __kCyberCity_H
#include "kCyberCity.h"
#endif
void kCyberCity::processReplacing(float **inputs, float **outputs, VstInt32 sampleFrames)
{
float* in1 = inputs[0];
float* in2 = inputs[1];
float* out1 = outputs[0];
float* out2 = outputs[1];
double overallscale = 1.0;
overallscale /= 44100.0;
overallscale *= getSampleRate();
int slewsing = floor(overallscale*2.0);
if (slewsing < 2) slewsing = 2; if (slewsing > 32) slewsing = 32;
double reg6n = (1.0-pow(1.0-A,3.0))*0.0013425;
double regenMax = 0.0013425;
double derez = 1.0;
derez = fmin(fmax(derez/overallscale,0.0005),1.0);
int bezFraction = (int)(1.0/derez);
double bezTrim = (double)bezFraction/(bezFraction+1.0);
derez = 1.0 / bezFraction;
bezTrim = 1.0-(derez*bezTrim);
int start = (int)(B * 27.0);
double wet = C;
while (--sampleFrames >= 0)
{
double inputSampleL = *in1;
double inputSampleR = *in2;
if (fabs(inputSampleL)<1.18e-23) inputSampleL = fpdL * 1.18e-17;
if (fabs(inputSampleR)<1.18e-23) inputSampleR = fpdR * 1.18e-17;
double drySampleL = inputSampleL;
double drySampleR = inputSampleR;
bez[bez_cycle] += derez;
bez[bez_SampL] += (inputSampleL * derez);
bez[bez_SampR] += (inputSampleR * derez);
if (bez[bez_cycle] > 1.0) { //hit the end point and we do a reverb sample
bez[bez_cycle] = 0.0;
double earlyFloor = fabs(inputSampleL) + fabs(inputSampleR);
switch(earlyZero){
case 0:
earlyFloor = earlyFloor + fabs(a3AL[c3AL]) + fabs(a3AR[c3AR]);
if (ld3A != early[start+3] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3A+2; x++) {a3AL[x] = 0.0; a3AR[x] = 0.0;}
ld3A = early[start+3];
} break;
case 1:
earlyFloor = earlyFloor + fabs(a3BL[c3BL]) + fabs(a3BR[c3BR]);
if (ld3B != early[start+7] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3B+2; x++) {a3BL[x] = 0.0; a3BR[x] = 0.0;}
ld3B = early[start+7];
} break;
case 2:
earlyFloor = earlyFloor + fabs(a3CL[c3CL]) + fabs(a3CR[c3CR]);
if (ld3C != early[start+8] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3C+2; x++) {a3CL[x] = 0.0; a3CR[x] = 0.0;}
ld3C = early[start+8];
} break;
case 3:
earlyFloor = earlyFloor + fabs(a3DL[c3DL]) + fabs(a3DR[c3DR]);
if (ld3D != early[start+2] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3D+2; x++) {a3DL[x] = 0.0; a3DR[x] = 0.0;}
ld3D = early[start+2];
} break;
case 4:
earlyFloor = earlyFloor + fabs(a3EL[c3EL]) + fabs(a3ER[c3ER]);
if (ld3E != early[start+4] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3E+2; x++) {a3EL[x] = 0.0; a3ER[x] = 0.0;}
ld3E = early[start+4];
} break;
case 5:
earlyFloor = earlyFloor + fabs(a3FL[c3FL]) + fabs(a3FR[c3FR]);
if (ld3F != early[start+6] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3F+2; x++) {a3FL[x] = 0.0; a3FR[x] = 0.0;}
ld3F = early[start+6];
} break;
case 6:
earlyFloor = earlyFloor + fabs(a3GL[c3GL]) + fabs(a3GR[c3GR]);
if (ld3G != early[start] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3G+2; x++) {a3GL[x] = 0.0; a3GR[x] = 0.0;}
ld3G = early[start];
} break;
case 7:
earlyFloor = earlyFloor + fabs(a3HL[c3HL]) + fabs(a3HR[c3HR]);
if (ld3H != early[start+1] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3H+2; x++) {a3HL[x] = 0.0; a3HR[x] = 0.0;}
ld3H = early[start+1];
} break;
case 8:
earlyFloor = earlyFloor + fabs(a3IL[c3IL]) + fabs(a3IR[c3IR]);
if (ld3I != early[start+5] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3I+2; x++) {a3IL[x] = 0.0; a3IR[x] = 0.0;}
ld3I = early[start+5];
} break;
}
earlyZero++; if (earlyZero > 8) earlyZero = 0;
inputSampleL = (bez[bez_SampL]);
inputSampleR = (bez[bez_SampR]);
a3AL[c3AL] = inputSampleL;
a3BL[c3BL] = inputSampleL;
a3CL[c3CL] = inputSampleL;
a3CR[c3CR] = inputSampleR;
a3FR[c3FR] = inputSampleR;
a3IR[c3IR] = inputSampleR;
c3AL++; if (c3AL > ld3A) c3AL = 0;
c3BL++; if (c3BL > ld3B) c3BL = 0;
c3CL++; if (c3CL > ld3C) c3CL = 0;
c3CR++; if (c3CR > ld3C) c3CR = 0;
c3FR++; if (c3FR > ld3F) c3FR = 0;
c3IR++; if (c3IR > ld3I) c3IR = 0;
double hA = a3AL[c3AL-((c3AL > ld3A)?c3AL+1:0)];
double hB = a3BL[c3BL-((c3BL > ld3B)?c3BL+1:0)];
double hC = a3CL[c3CL-((c3CL > ld3C)?c3CL+1:0)];
double hD = a3CR[c3CR-((c3CR > ld3C)?c3CR+1:0)];
double hE = a3FR[c3FR-((c3FR > ld3F)?c3FR+1:0)];
double hF = a3IR[c3IR-((c3IR > ld3I)?c3IR+1:0)];
a3DL[c3DL] = (((hB + hC) * -2.0) + hA);
a3EL[c3EL] = (((hA + hC) * -2.0) + hB);
a3FL[c3FL] = (((hA + hB) * -2.0) + hC);
a3BR[c3BR] = (((hE + hF) * -2.0) + hD);
a3ER[c3ER] = (((hD + hF) * -2.0) + hE);
a3HR[c3HR] = (((hD + hE) * -2.0) + hF);
c3DL++; if (c3DL > ld3D) c3DL = 0;
c3EL++; if (c3EL > ld3E) c3EL = 0;
c3FL++; if (c3FL > ld3F) c3FL = 0;
c3BR++; if (c3BR > ld3B) c3BR = 0;
c3ER++; if (c3ER > ld3E) c3ER = 0;
c3HR++; if (c3HR > ld3H) c3HR = 0;
hA = a3DL[c3DL-((c3DL > ld3D)?c3DL+1:0)];
hB = a3EL[c3EL-((c3EL > ld3E)?c3EL+1:0)];
hC = a3FL[c3FL-((c3FL > ld3F)?c3FL+1:0)];
hD = a3BR[c3BR-((c3BR > ld3B)?c3BR+1:0)];
hE = a3ER[c3ER-((c3ER > ld3E)?c3ER+1:0)];
hF = a3HR[c3HR-((c3HR > ld3H)?c3HR+1:0)];
a3GL[c3GL] = (((hB + hC) * -2.0) + hA);
a3HL[c3HL] = (((hA + hC) * -2.0) + hB);
a3IL[c3IL] = (((hA + hB) * -2.0) + hC);
a3AR[c3AR] = (((hE + hF) * -2.0) + hD);
a3DR[c3DR] = (((hD + hF) * -2.0) + hE);
a3GR[c3GR] = (((hD + hE) * -2.0) + hF);
c3GL++; if (c3GL > ld3G) c3GL = 0;
c3HL++; if (c3HL > ld3H) c3HL = 0;
c3IL++; if (c3IL > ld3I) c3IL = 0;
c3AR++; if (c3AR > ld3A) c3AR = 0;
c3DR++; if (c3DR > ld3D) c3DR = 0;
c3GR++; if (c3GR > ld3G) c3GR = 0;
hA = a3GL[c3GL-((c3GL > ld3G)?c3GL+1:0)];
hB = a3HL[c3HL-((c3HL > ld3H)?c3HL+1:0)];
hC = a3IL[c3IL-((c3IL > ld3I)?c3IL+1:0)];
hD = a3AR[c3AR-((c3AR > ld3A)?c3AR+1:0)];
hE = a3DR[c3DR-((c3DR > ld3D)?c3DR+1:0)];
hF = a3GR[c3GR-((c3GR > ld3G)?c3GR+1:0)];
double earlyReflectionL = (((hB + hC) * -2.0) + hA)*-0.0625;
double earlyReflectionR = (((hE + hF) * -2.0) + hD)*-0.0625;
double applyNonlin = 1.0-fmin(fmax(fabs(inputSampleL),fabs(inputSampleR)),1.0);
applyNonlin = 1.0-(applyNonlin*applyNonlin*applyNonlin);
inputSampleL -= earlyReflectionL;
inputSampleR -= earlyReflectionR;
roomTimerL++;
if (roomTimerL > 19) {
roomTimerL = 0;
if (roomNoiseL > 0.0) roomNoiseL -= fabs((fpdL / (double)UINT32_MAX)-0.5)*0.08625;
else roomNoiseL += fabs((fpdL / (double)UINT32_MAX)-0.5)*0.08625;
} else roomNoiseL += ((fpdL / (double)UINT32_MAX)-0.5)*0.08625;
//roomNoiseL governs the added 'room tone' noise. 0.125 gives you not an overwhelming
//volume of it, less will be quieter. The 13 is part of VoiceOfTheStarship, and
//larger allows more subs into the noise: it'll determine the apparent room scale,
//with subs content implying a HUGE space, no lows implying a small space.
roomTimerR++;
if (roomTimerR > 7) {
roomTimerR = 0;
if (roomNoiseR > fmin(reg6n+(applyNonlin*0.00058),regenMax)) roomNoiseR -= fabs((fpdR / (double)UINT32_MAX)-0.5)*0.000021;
else roomNoiseR += fabs((fpdR / (double)UINT32_MAX)-0.5)*0.000021;
} else roomNoiseR += ((fpdR / (double)UINT32_MAX)-0.5)*0.000021;
//roomNoiseR governs the activity of the air in this space. Consider it in terms of
//winds at MPH: the RoomTimer number is (int)sqrt(wind MPH) which governs the intensity
//of gusts and fluctuations (avoid hurricane force inside realistic rooms)
//and the scaling of roomNoiseR (as added to reg6n) is sqrt(wind MPH)*0.00002
//but check against pure tones, don't let it dirty them up too much!
a6AL[c6AL] = inputSampleL + ((f6BL+roomNoiseL) * roomNoiseR);
a6BL[c6BL] = inputSampleL + (f6CL * roomNoiseR);
a6CL[c6CL] = inputSampleL + (f6DL * roomNoiseR);
a6DL[c6DL] = inputSampleL + (f6EL * roomNoiseR);
a6EL[c6EL] = inputSampleL + (f6FL * roomNoiseR);
a6FL[c6FL] = inputSampleL + (f6AL * roomNoiseR);
a6FR[c6FR] = inputSampleR + ((f6LR+roomNoiseL) * roomNoiseR);
a6LR[c6LR] = inputSampleR + (f6RR * roomNoiseR);
a6RR[c6RR] = inputSampleR + (f6XR * roomNoiseR);
a6XR[c6XR] = inputSampleR + (f6ZER * roomNoiseR);
a6ZER[c6ZER] = inputSampleR + (f6ZKR * roomNoiseR);
a6ZKR[c6ZKR] = inputSampleR + (f6FR * roomNoiseR);
//left verb
c6AL++; if (c6AL > d6A) c6AL = 0;
c6BL++; if (c6BL > d6B) c6BL = 0;
c6CL++; if (c6CL > d6C) c6CL = 0;
c6DL++; if (c6DL > d6D) c6DL = 0;
c6EL++; if (c6EL > d6E) c6EL = 0;
c6FL++; if (c6FL > d6F) c6FL = 0;
hA = a6AL[c6AL-((c6AL > d6A)?d6A+1:0)];
hB = a6BL[c6BL-((c6BL > d6B)?d6B+1:0)];
hC = a6CL[c6CL-((c6CL > d6C)?d6C+1:0)];
hD = a6DL[c6DL-((c6DL > d6D)?d6D+1:0)];
hE = a6EL[c6EL-((c6EL > d6E)?d6E+1:0)];
hF = a6FL[c6FL-((c6FL > d6F)?d6F+1:0)];
a6GL[c6GL] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6HL[c6HL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6IL[c6IL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6JL[c6JL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6KL[c6KL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6LL[c6LL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6GL++; if (c6GL > d6G) c6GL = 0;
c6HL++; if (c6HL > d6H) c6HL = 0;
c6IL++; if (c6IL > d6I) c6IL = 0;
c6JL++; if (c6JL > d6J) c6JL = 0;
c6KL++; if (c6KL > d6K) c6KL = 0;
c6LL++; if (c6LL > d6L) c6LL = 0;
hA = a6GL[c6GL-((c6GL > d6G)?d6G+1:0)];
hB = a6HL[c6HL-((c6HL > d6H)?d6H+1:0)];
hC = a6IL[c6IL-((c6IL > d6I)?d6I+1:0)];
hD = a6JL[c6JL-((c6JL > d6J)?d6J+1:0)];
hE = a6KL[c6KL-((c6KL > d6K)?d6K+1:0)];
hF = a6LL[c6LL-((c6LL > d6L)?d6L+1:0)];
a6ML[c6ML] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6NL[c6NL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6OL[c6OL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6PL[c6PL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6QL[c6QL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6RL[c6RL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6ML++; if (c6ML > d6M) c6ML = 0;
c6NL++; if (c6NL > d6N) c6NL = 0;
c6OL++; if (c6OL > d6O) c6OL = 0;
c6PL++; if (c6PL > d6P) c6PL = 0;
c6QL++; if (c6QL > d6Q) c6QL = 0;
c6RL++; if (c6RL > d6R) c6RL = 0;
hA = a6ML[c6ML-((c6ML > d6M)?d6M+1:0)];
hB = a6NL[c6NL-((c6NL > d6N)?d6N+1:0)];
hC = a6OL[c6OL-((c6OL > d6O)?d6O+1:0)];
hD = a6PL[c6PL-((c6PL > d6P)?d6P+1:0)];
hE = a6QL[c6QL-((c6QL > d6Q)?d6Q+1:0)];
hF = a6RL[c6RL-((c6RL > d6R)?d6R+1:0)];
a6SL[c6SL] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6TL[c6TL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6UL[c6UL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6VL[c6VL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6WL[c6WL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6XL[c6XL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6SL++; if (c6SL > d6S) c6SL = 0;
c6TL++; if (c6TL > d6T) c6TL = 0;
c6UL++; if (c6UL > d6U) c6UL = 0;
c6VL++; if (c6VL > d6V) c6VL = 0;
c6WL++; if (c6WL > d6W) c6WL = 0;
c6XL++; if (c6XL > d6X) c6XL = 0;
hA = a6SL[c6SL-((c6SL > d6S)?d6S+1:0)];
hB = a6TL[c6TL-((c6TL > d6T)?d6T+1:0)];
hC = a6UL[c6UL-((c6UL > d6U)?d6U+1:0)];
hD = a6VL[c6VL-((c6VL > d6V)?d6V+1:0)];
hE = a6WL[c6WL-((c6WL > d6W)?d6W+1:0)];
hF = a6XL[c6XL-((c6XL > d6X)?d6X+1:0)];
a6YL[c6YL] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6ZAL[c6ZAL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6ZBL[c6ZBL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6ZCL[c6ZCL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZDL[c6ZDL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZEL[c6ZEL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6YL++; if (c6YL > d6Y) c6YL = 0;
c6ZAL++; if (c6ZAL > d6ZA) c6ZAL = 0;
c6ZBL++; if (c6ZBL > d6ZB) c6ZBL = 0;
c6ZCL++; if (c6ZCL > d6ZC) c6ZCL = 0;
c6ZDL++; if (c6ZDL > d6ZD) c6ZDL = 0;
c6ZEL++; if (c6ZEL > d6ZE) c6ZEL = 0;
hA = a6YL[c6YL-((c6YL > d6Y)?d6Y+1:0)];
hB = a6ZAL[c6ZAL-((c6ZAL > d6ZA)?d6ZA+1:0)];
hC = a6ZBL[c6ZBL-((c6ZBL > d6ZB)?d6ZB+1:0)];
hD = a6ZCL[c6ZCL-((c6ZCL > d6ZC)?d6ZC+1:0)];
hE = a6ZDL[c6ZDL-((c6ZDL > d6ZD)?d6ZD+1:0)];
hF = a6ZEL[c6ZEL-((c6ZEL > d6ZE)?d6ZE+1:0)];
a6ZFL[c6ZFL] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6ZGL[c6ZGL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6ZHL[c6ZHL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6ZIL[c6ZIL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZJL[c6ZJL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZKL[c6ZKL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6ZFL++; if (c6ZFL > d6ZF) c6ZFL = 0;
c6ZGL++; if (c6ZGL > d6ZG) c6ZGL = 0;
c6ZHL++; if (c6ZHL > d6ZH) c6ZHL = 0;
c6ZIL++; if (c6ZIL > d6ZI) c6ZIL = 0;
c6ZJL++; if (c6ZJL > d6ZJ) c6ZJL = 0;
c6ZKL++; if (c6ZKL > d6ZK) c6ZKL = 0;
hA = a6ZFL[c6ZFL-((c6ZFL > d6ZF)?d6ZF+1:0)];
hB = a6ZGL[c6ZGL-((c6ZGL > d6ZG)?d6ZG+1:0)];
hC = a6ZHL[c6ZHL-((c6ZHL > d6ZH)?d6ZH+1:0)];
hD = a6ZIL[c6ZIL-((c6ZIL > d6ZI)?d6ZI+1:0)];
hE = a6ZJL[c6ZJL-((c6ZJL > d6ZJ)?d6ZJ+1:0)];
hF = a6ZKL[c6ZKL-((c6ZKL > d6ZK)?d6ZK+1:0)];
f6FR = (((hA*2.0) - (hB + hC + hD + hE + hF))+avg6R)*0.5;
avg6R = ((hA*2.0) - (hB + hC + hD + hE + hF));
f6LR = ((hB*2.0) - (hA + hC + hD + hE + hF));
f6RR = ((hC*2.0) - (hA + hB + hD + hE + hF));
f6XR = ((hD*2.0) - (hA + hB + hC + hE + hF));
f6ZER = ((hE*2.0) - (hA + hB + hC + hD + hF));
f6ZKR = ((hF*2.0) - (hA + hB + hC + hD + hE));
inputSampleL = ((hA*2.0) - (hB + hC + hD + hE + hF))*0.001953125;
//right verb
c6FR++; if (c6FR > d6F) c6FR = 0;
c6LR++; if (c6LR > d6L) c6LR = 0;
c6RR++; if (c6RR > d6R) c6RR = 0;
c6XR++; if (c6XR > d6X) c6XR = 0;
c6ZER++; if (c6ZER > d6ZE) c6ZER = 0;
c6ZKR++; if (c6ZKR > d6ZK) c6ZKR = 0;
hA = a6FR[c6FR-((c6FR > d6F)?d6F+1:0)];
hB = a6LR[c6LR-((c6LR > d6L)?d6L+1:0)];
hC = a6RR[c6RR-((c6RR > d6R)?d6R+1:0)];
hD = a6XR[c6XR-((c6XR > d6X)?d6X+1:0)];
hE = a6ZER[c6ZER-((c6ZER > d6ZE)?d6ZE+1:0)];
hF = a6ZKR[c6ZKR-((c6ZKR > d6ZK)?d6ZK+1:0)];
a6ER[c6ER] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6KR[c6KR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6QR[c6QR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6WR[c6WR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZDR[c6ZDR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZJR[c6ZJR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6ER++; if (c6ER > d6E) c6ER = 0;
c6KR++; if (c6KR > d6K) c6KR = 0;
c6QR++; if (c6QR > d6Q) c6QR = 0;
c6WR++; if (c6WR > d6W) c6WR = 0;
c6ZDR++; if (c6ZDR > d6ZD) c6ZDR = 0;
c6ZJR++; if (c6ZJR > d6ZJ) c6ZJR = 0;
hA = a6ER[c6ER-((c6ER > d6E)?d6E+1:0)];
hB = a6KR[c6KR-((c6KR > d6K)?d6K+1:0)];
hC = a6QR[c6QR-((c6QR > d6Q)?d6Q+1:0)];
hD = a6WR[c6WR-((c6WR > d6W)?d6W+1:0)];
hE = a6ZDR[c6ZDR-((c6ZDR > d6ZD)?d6ZD+1:0)];
hF = a6ZJR[c6ZJR-((c6ZJR > d6ZJ)?d6ZJ+1:0)];
a6DR[c6DR] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6JR[c6JR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6PR[c6PR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6VR[c6VR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZCR[c6ZCR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZIR[c6ZIR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6DR++; if (c6DR > d6D) c6DR = 0;
c6JR++; if (c6JR > d6J) c6JR = 0;
c6PR++; if (c6PR > d6P) c6PR = 0;
c6VR++; if (c6VR > d6V) c6VR = 0;
c6ZCR++; if (c6ZCR > d6ZC) c6ZCR = 0;
c6ZIR++; if (c6ZIR > d6ZI) c6ZIR = 0;
hA = a6DR[c6DR-((c6DR > d6D)?d6D+1:0)];
hB = a6JR[c6JR-((c6JR > d6J)?d6J+1:0)];
hC = a6PR[c6PR-((c6PR > d6P)?d6P+1:0)];
hD = a6VR[c6VR-((c6VR > d6V)?d6V+1:0)];
hE = a6ZCR[c6ZCR-((c6ZCR > d6ZC)?d6ZC+1:0)];
hF = a6ZIR[c6ZIR-((c6ZIR > d6ZI)?d6ZI+1:0)];
a6CR[c6CR] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6IR[c6IR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6OR[c6OR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6UR[c6UR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZBR[c6ZBR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZHR[c6ZHR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6CR++; if (c6CR > d6C) c6CR = 0;
c6IR++; if (c6IR > d6I) c6IR = 0;
c6OR++; if (c6OR > d6O) c6OR = 0;
c6UR++; if (c6UR > d6U) c6UR = 0;
c6ZBR++; if (c6ZBR > d6ZB) c6ZBR = 0;
c6ZHR++; if (c6ZHR > d6ZH) c6ZHR = 0;
hA = a6CR[c6CR-((c6CR > d6C)?d6C+1:0)];
hB = a6IR[c6IR-((c6IR > d6I)?d6I+1:0)];
hC = a6OR[c6OR-((c6OR > d6O)?d6O+1:0)];
hD = a6UR[c6UR-((c6UR > d6U)?d6U+1:0)];
hE = a6ZBR[c6ZBR-((c6ZBR > d6ZB)?d6ZB+1:0)];
hF = a6ZHR[c6ZHR-((c6ZHR > d6ZH)?d6ZH+1:0)];
a6BR[c6BR] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6HR[c6HR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6NR[c6NR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6TR[c6TR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZAR[c6ZAR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZGR[c6ZGR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6BR++; if (c6BR > d6B) c6BR = 0;
c6HR++; if (c6HR > d6H) c6HR = 0;
c6NR++; if (c6NR > d6N) c6NR = 0;
c6TR++; if (c6TR > d6T) c6TR = 0;
c6ZBR++; if (c6ZBR > d6ZB) c6ZBR = 0;
c6ZGR++; if (c6ZGR > d6ZG) c6ZGR = 0;
hA = a6BR[c6BR-((c6BR > d6B)?d6B+1:0)];
hB = a6HR[c6HR-((c6HR > d6H)?d6H+1:0)];
hC = a6NR[c6NR-((c6NR > d6N)?d6N+1:0)];
hD = a6TR[c6TR-((c6TR > d6T)?d6T+1:0)];
hE = a6ZAR[c6ZAR-((c6ZAR > d6ZA)?d6ZA+1:0)];
hF = a6ZGR[c6ZGR-((c6ZGR > d6ZG)?d6ZG+1:0)];
a6AR[c6AR] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6GR[c6GR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6MR[c6MR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6SR[c6SR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6YR[c6YR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZFR[c6ZFR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6AR++; if (c6AR > d6A) c6AR = 0;
c6GR++; if (c6GR > d6G) c6GR = 0;
c6MR++; if (c6MR > d6M) c6MR = 0;
c6SR++; if (c6SR > d6S) c6SR = 0;
c6YR++; if (c6YR > d6Y) c6YR = 0;
c6ZFR++; if (c6ZFR > d6ZF) c6ZFR = 0;
hA = a6AR[c6AR-((c6AR > d6A)?d6A+1:0)];
hB = a6GR[c6GR-((c6GR > d6G)?d6G+1:0)];
hC = a6MR[c6MR-((c6MR > d6M)?d6M+1:0)];
hD = a6SR[c6SR-((c6SR > d6S)?d6S+1:0)];
hE = a6YR[c6YR-((c6YR > d6Y)?d6Y+1:0)];
hF = a6ZFR[c6ZFR-((c6ZFR > d6ZF)?d6ZF+1:0)];
f6AL = (((hA*2.0) - (hB + hC + hD + hE + hF))+avg6L)*0.5;
avg6L = ((hA*2.0) - (hB + hC + hD + hE + hF));
f6BL = ((hB*2.0) - (hA + hC + hD + hE + hF));
f6CL = ((hC*2.0) - (hA + hB + hD + hE + hF));
f6DL = ((hD*2.0) - (hA + hB + hC + hE + hF));
f6EL = ((hE*2.0) - (hA + hB + hC + hD + hF));
f6FL = ((hF*2.0) - (hA + hB + hC + hD + hE));
inputSampleR = ((hA*2.0) - (hB + hC + hD + hE + hF))*0.001953125;
inputSampleL += earlyReflectionL;
inputSampleR += earlyReflectionR;
bez[bez_CL] = bez[bez_BL];
bez[bez_BL] = bez[bez_AL];
bez[bez_AL] = inputSampleL;
bez[bez_SampL] = 0.0;
bez[bez_CR] = bez[bez_BR];
bez[bez_BR] = bez[bez_AR];
bez[bez_AR] = inputSampleR;
bez[bez_SampR] = 0.0;
}
double X = bez[bez_cycle]*bezTrim;
inputSampleL = (bez[bez_BL]+(bez[bez_CL]*(1.0-X)*(1.0-X))+(bez[bez_BL]*2.0*(1.0-X)*X)+(bez[bez_AL]*X*X))*-0.0625;
inputSampleR = (bez[bez_BR]+(bez[bez_CR]*(1.0-X)*(1.0-X))+(bez[bez_BR]*2.0*(1.0-X)*X)+(bez[bez_AR]*X*X))*-0.0625;
//begin TapeHack2
double darkSampleL = inputSampleL;
double darkSampleR = inputSampleR;
if (avgPos > 31) avgPos = 0;
if (slewsing > 31) {
avg32L[avgPos] = darkSampleL; avg32R[avgPos] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 32; x++) {darkSampleL += avg32L[x]; darkSampleR += avg32R[x];}
darkSampleL /= 32.0; darkSampleR /= 32.0;
} if (slewsing > 15) {
avg16L[avgPos%16] = darkSampleL; avg16R[avgPos%16] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 16; x++) {darkSampleL += avg16L[x]; darkSampleR += avg16R[x];}
darkSampleL /= 16.0; darkSampleR /= 16.0;
} if (slewsing > 7) {
avg8L[avgPos%8] = darkSampleL; avg8R[avgPos%8] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 8; x++) {darkSampleL += avg8L[x]; darkSampleR += avg8R[x];}
darkSampleL /= 8.0; darkSampleR /= 8.0;
} if (slewsing > 3) {
avg4L[avgPos%4] = darkSampleL; avg4R[avgPos%4] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 4; x++) {darkSampleL += avg4L[x]; darkSampleR += avg4R[x];}
darkSampleL /= 4.0; darkSampleR /= 4.0;
} if (slewsing > 1) {
avg2L[avgPos%2] = darkSampleL; avg2R[avgPos%2] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 2; x++) {darkSampleL += avg2L[x]; darkSampleR += avg2R[x];}
darkSampleL /= 2.0; darkSampleR /= 2.0;
} //only update avgPos after the post-distortion filter stage
double avgSlewL = fmin(fabs(lastDarkL-inputSampleL)*0.09384*overallscale,1.0);
avgSlewL = 1.0-(1.0-avgSlewL*1.0-avgSlewL);
inputSampleL = (inputSampleL*(1.0-avgSlewL)) + (darkSampleL*avgSlewL);
lastDarkL = darkSampleL;
double avgSlewR = fmin(fabs(lastDarkR-inputSampleR)*0.09384*overallscale,1.0);
avgSlewR = 1.0-(1.0-avgSlewR*1.0-avgSlewR);
inputSampleR = (inputSampleR*(1.0-avgSlewR)) + (darkSampleR*avgSlewR);
lastDarkR = darkSampleR;
inputSampleL = (inputSampleL * wet)+(drySampleL * (1.0-wet));
inputSampleR = (inputSampleR * wet)+(drySampleR * (1.0-wet));
//begin 32 bit stereo floating point dither
int expon; frexpf((float)inputSampleL, &expon);
fpdL ^= fpdL << 13; fpdL ^= fpdL >> 17; fpdL ^= fpdL << 5;
inputSampleL += ((double(fpdL)-uint32_t(0x7fffffff)) * 3.553e-44l * pow(2,expon+62));
frexpf((float)inputSampleR, &expon);
fpdR ^= fpdR << 13; fpdR ^= fpdR >> 17; fpdR ^= fpdR << 5;
if (fpdL-fpdR < 1073741824 || fpdR-fpdL < 1073741824) {
fpdR ^= fpdR << 13; fpdR ^= fpdR >> 17; fpdR ^= fpdR << 5;}
inputSampleR += ((double(fpdR)-uint32_t(0x7fffffff)) * 3.553e-44l * pow(2,expon+62));
//end 32 bit stereo floating point dither
*out1 = inputSampleL;
*out2 = inputSampleR;
in1++;
in2++;
out1++;
out2++;
}
}
void kCyberCity::processDoubleReplacing(double **inputs, double **outputs, VstInt32 sampleFrames)
{
double* in1 = inputs[0];
double* in2 = inputs[1];
double* out1 = outputs[0];
double* out2 = outputs[1];
double overallscale = 1.0;
overallscale /= 44100.0;
overallscale *= getSampleRate();
int slewsing = floor(overallscale*2.0);
if (slewsing < 2) slewsing = 2; if (slewsing > 32) slewsing = 32;
double reg6n = (1.0-pow(1.0-A,3.0))*0.0013425;
double regenMax = 0.0013425;
double derez = 1.0;
derez = fmin(fmax(derez/overallscale,0.0005),1.0);
int bezFraction = (int)(1.0/derez);
double bezTrim = (double)bezFraction/(bezFraction+1.0);
derez = 1.0 / bezFraction;
bezTrim = 1.0-(derez*bezTrim);
int start = (int)(B * 27.0);
double wet = C;
while (--sampleFrames >= 0)
{
double inputSampleL = *in1;
double inputSampleR = *in2;
if (fabs(inputSampleL)<1.18e-23) inputSampleL = fpdL * 1.18e-17;
if (fabs(inputSampleR)<1.18e-23) inputSampleR = fpdR * 1.18e-17;
double drySampleL = inputSampleL;
double drySampleR = inputSampleR;
bez[bez_cycle] += derez;
bez[bez_SampL] += (inputSampleL * derez);
bez[bez_SampR] += (inputSampleR * derez);
if (bez[bez_cycle] > 1.0) { //hit the end point and we do a reverb sample
bez[bez_cycle] = 0.0;
double earlyFloor = fabs(inputSampleL) + fabs(inputSampleR);
switch(earlyZero){
case 0:
earlyFloor = earlyFloor + fabs(a3AL[c3AL]) + fabs(a3AR[c3AR]);
if (ld3A != early[start+3] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3A+2; x++) {a3AL[x] = 0.0; a3AR[x] = 0.0;}
ld3A = early[start+3];
} break;
case 1:
earlyFloor = earlyFloor + fabs(a3BL[c3BL]) + fabs(a3BR[c3BR]);
if (ld3B != early[start+7] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3B+2; x++) {a3BL[x] = 0.0; a3BR[x] = 0.0;}
ld3B = early[start+7];
} break;
case 2:
earlyFloor = earlyFloor + fabs(a3CL[c3CL]) + fabs(a3CR[c3CR]);
if (ld3C != early[start+8] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3C+2; x++) {a3CL[x] = 0.0; a3CR[x] = 0.0;}
ld3C = early[start+8];
} break;
case 3:
earlyFloor = earlyFloor + fabs(a3DL[c3DL]) + fabs(a3DR[c3DR]);
if (ld3D != early[start+2] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3D+2; x++) {a3DL[x] = 0.0; a3DR[x] = 0.0;}
ld3D = early[start+2];
} break;
case 4:
earlyFloor = earlyFloor + fabs(a3EL[c3EL]) + fabs(a3ER[c3ER]);
if (ld3E != early[start+4] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3E+2; x++) {a3EL[x] = 0.0; a3ER[x] = 0.0;}
ld3E = early[start+4];
} break;
case 5:
earlyFloor = earlyFloor + fabs(a3FL[c3FL]) + fabs(a3FR[c3FR]);
if (ld3F != early[start+6] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3F+2; x++) {a3FL[x] = 0.0; a3FR[x] = 0.0;}
ld3F = early[start+6];
} break;
case 6:
earlyFloor = earlyFloor + fabs(a3GL[c3GL]) + fabs(a3GR[c3GR]);
if (ld3G != early[start] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3G+2; x++) {a3GL[x] = 0.0; a3GR[x] = 0.0;}
ld3G = early[start];
} break;
case 7:
earlyFloor = earlyFloor + fabs(a3HL[c3HL]) + fabs(a3HR[c3HR]);
if (ld3H != early[start+1] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3H+2; x++) {a3HL[x] = 0.0; a3HR[x] = 0.0;}
ld3H = early[start+1];
} break;
case 8:
earlyFloor = earlyFloor + fabs(a3IL[c3IL]) + fabs(a3IR[c3IR]);
if (ld3I != early[start+5] && earlyFloor < 0.06125)
{
for(int x = 0; x < d3I+2; x++) {a3IL[x] = 0.0; a3IR[x] = 0.0;}
ld3I = early[start+5];
} break;
}
earlyZero++; if (earlyZero > 8) earlyZero = 0;
inputSampleL = (bez[bez_SampL]);
inputSampleR = (bez[bez_SampR]);
a3AL[c3AL] = inputSampleL;
a3BL[c3BL] = inputSampleL;
a3CL[c3CL] = inputSampleL;
a3CR[c3CR] = inputSampleR;
a3FR[c3FR] = inputSampleR;
a3IR[c3IR] = inputSampleR;
c3AL++; if (c3AL > ld3A) c3AL = 0;
c3BL++; if (c3BL > ld3B) c3BL = 0;
c3CL++; if (c3CL > ld3C) c3CL = 0;
c3CR++; if (c3CR > ld3C) c3CR = 0;
c3FR++; if (c3FR > ld3F) c3FR = 0;
c3IR++; if (c3IR > ld3I) c3IR = 0;
double hA = a3AL[c3AL-((c3AL > ld3A)?c3AL+1:0)];
double hB = a3BL[c3BL-((c3BL > ld3B)?c3BL+1:0)];
double hC = a3CL[c3CL-((c3CL > ld3C)?c3CL+1:0)];
double hD = a3CR[c3CR-((c3CR > ld3C)?c3CR+1:0)];
double hE = a3FR[c3FR-((c3FR > ld3F)?c3FR+1:0)];
double hF = a3IR[c3IR-((c3IR > ld3I)?c3IR+1:0)];
a3DL[c3DL] = (((hB + hC) * -2.0) + hA);
a3EL[c3EL] = (((hA + hC) * -2.0) + hB);
a3FL[c3FL] = (((hA + hB) * -2.0) + hC);
a3BR[c3BR] = (((hE + hF) * -2.0) + hD);
a3ER[c3ER] = (((hD + hF) * -2.0) + hE);
a3HR[c3HR] = (((hD + hE) * -2.0) + hF);
c3DL++; if (c3DL > ld3D) c3DL = 0;
c3EL++; if (c3EL > ld3E) c3EL = 0;
c3FL++; if (c3FL > ld3F) c3FL = 0;
c3BR++; if (c3BR > ld3B) c3BR = 0;
c3ER++; if (c3ER > ld3E) c3ER = 0;
c3HR++; if (c3HR > ld3H) c3HR = 0;
hA = a3DL[c3DL-((c3DL > ld3D)?c3DL+1:0)];
hB = a3EL[c3EL-((c3EL > ld3E)?c3EL+1:0)];
hC = a3FL[c3FL-((c3FL > ld3F)?c3FL+1:0)];
hD = a3BR[c3BR-((c3BR > ld3B)?c3BR+1:0)];
hE = a3ER[c3ER-((c3ER > ld3E)?c3ER+1:0)];
hF = a3HR[c3HR-((c3HR > ld3H)?c3HR+1:0)];
a3GL[c3GL] = (((hB + hC) * -2.0) + hA);
a3HL[c3HL] = (((hA + hC) * -2.0) + hB);
a3IL[c3IL] = (((hA + hB) * -2.0) + hC);
a3AR[c3AR] = (((hE + hF) * -2.0) + hD);
a3DR[c3DR] = (((hD + hF) * -2.0) + hE);
a3GR[c3GR] = (((hD + hE) * -2.0) + hF);
c3GL++; if (c3GL > ld3G) c3GL = 0;
c3HL++; if (c3HL > ld3H) c3HL = 0;
c3IL++; if (c3IL > ld3I) c3IL = 0;
c3AR++; if (c3AR > ld3A) c3AR = 0;
c3DR++; if (c3DR > ld3D) c3DR = 0;
c3GR++; if (c3GR > ld3G) c3GR = 0;
hA = a3GL[c3GL-((c3GL > ld3G)?c3GL+1:0)];
hB = a3HL[c3HL-((c3HL > ld3H)?c3HL+1:0)];
hC = a3IL[c3IL-((c3IL > ld3I)?c3IL+1:0)];
hD = a3AR[c3AR-((c3AR > ld3A)?c3AR+1:0)];
hE = a3DR[c3DR-((c3DR > ld3D)?c3DR+1:0)];
hF = a3GR[c3GR-((c3GR > ld3G)?c3GR+1:0)];
double earlyReflectionL = (((hB + hC) * -2.0) + hA)*-0.0625;
double earlyReflectionR = (((hE + hF) * -2.0) + hD)*-0.0625;
double applyNonlin = 1.0-fmin(fmax(fabs(inputSampleL),fabs(inputSampleR)),1.0);
applyNonlin = 1.0-(applyNonlin*applyNonlin*applyNonlin);
inputSampleL -= earlyReflectionL;
inputSampleR -= earlyReflectionR;
roomTimerL++;
if (roomTimerL > 19) {
roomTimerL = 0;
if (roomNoiseL > 0.0) roomNoiseL -= fabs((fpdL / (double)UINT32_MAX)-0.5)*0.08625;
else roomNoiseL += fabs((fpdL / (double)UINT32_MAX)-0.5)*0.08625;
} else roomNoiseL += ((fpdL / (double)UINT32_MAX)-0.5)*0.08625;
//roomNoiseL governs the added 'room tone' noise. 0.125 gives you not an overwhelming
//volume of it, less will be quieter. The 13 is part of VoiceOfTheStarship, and
//larger allows more subs into the noise: it'll determine the apparent room scale,
//with subs content implying a HUGE space, no lows implying a small space.
roomTimerR++;
if (roomTimerR > 7) {
roomTimerR = 0;
if (roomNoiseR > fmin(reg6n+(applyNonlin*0.00058),regenMax)) roomNoiseR -= fabs((fpdR / (double)UINT32_MAX)-0.5)*0.000021;
else roomNoiseR += fabs((fpdR / (double)UINT32_MAX)-0.5)*0.000021;
} else roomNoiseR += ((fpdR / (double)UINT32_MAX)-0.5)*0.000021;
//roomNoiseR governs the activity of the air in this space. Consider it in terms of
//winds at MPH: the RoomTimer number is (int)sqrt(wind MPH) which governs the intensity
//of gusts and fluctuations (avoid hurricane force inside realistic rooms)
//and the scaling of roomNoiseR (as added to reg6n) is sqrt(wind MPH)*0.00002
//but check against pure tones, don't let it dirty them up too much!
a6AL[c6AL] = inputSampleL + ((f6BL+roomNoiseL) * roomNoiseR);
a6BL[c6BL] = inputSampleL + (f6CL * roomNoiseR);
a6CL[c6CL] = inputSampleL + (f6DL * roomNoiseR);
a6DL[c6DL] = inputSampleL + (f6EL * roomNoiseR);
a6EL[c6EL] = inputSampleL + (f6FL * roomNoiseR);
a6FL[c6FL] = inputSampleL + (f6AL * roomNoiseR);
a6FR[c6FR] = inputSampleR + ((f6LR+roomNoiseL) * roomNoiseR);
a6LR[c6LR] = inputSampleR + (f6RR * roomNoiseR);
a6RR[c6RR] = inputSampleR + (f6XR * roomNoiseR);
a6XR[c6XR] = inputSampleR + (f6ZER * roomNoiseR);
a6ZER[c6ZER] = inputSampleR + (f6ZKR * roomNoiseR);
a6ZKR[c6ZKR] = inputSampleR + (f6FR * roomNoiseR);
//left verb
c6AL++; if (c6AL > d6A) c6AL = 0;
c6BL++; if (c6BL > d6B) c6BL = 0;
c6CL++; if (c6CL > d6C) c6CL = 0;
c6DL++; if (c6DL > d6D) c6DL = 0;
c6EL++; if (c6EL > d6E) c6EL = 0;
c6FL++; if (c6FL > d6F) c6FL = 0;
hA = a6AL[c6AL-((c6AL > d6A)?d6A+1:0)];
hB = a6BL[c6BL-((c6BL > d6B)?d6B+1:0)];
hC = a6CL[c6CL-((c6CL > d6C)?d6C+1:0)];
hD = a6DL[c6DL-((c6DL > d6D)?d6D+1:0)];
hE = a6EL[c6EL-((c6EL > d6E)?d6E+1:0)];
hF = a6FL[c6FL-((c6FL > d6F)?d6F+1:0)];
a6GL[c6GL] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6HL[c6HL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6IL[c6IL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6JL[c6JL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6KL[c6KL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6LL[c6LL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6GL++; if (c6GL > d6G) c6GL = 0;
c6HL++; if (c6HL > d6H) c6HL = 0;
c6IL++; if (c6IL > d6I) c6IL = 0;
c6JL++; if (c6JL > d6J) c6JL = 0;
c6KL++; if (c6KL > d6K) c6KL = 0;
c6LL++; if (c6LL > d6L) c6LL = 0;
hA = a6GL[c6GL-((c6GL > d6G)?d6G+1:0)];
hB = a6HL[c6HL-((c6HL > d6H)?d6H+1:0)];
hC = a6IL[c6IL-((c6IL > d6I)?d6I+1:0)];
hD = a6JL[c6JL-((c6JL > d6J)?d6J+1:0)];
hE = a6KL[c6KL-((c6KL > d6K)?d6K+1:0)];
hF = a6LL[c6LL-((c6LL > d6L)?d6L+1:0)];
a6ML[c6ML] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6NL[c6NL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6OL[c6OL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6PL[c6PL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6QL[c6QL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6RL[c6RL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6ML++; if (c6ML > d6M) c6ML = 0;
c6NL++; if (c6NL > d6N) c6NL = 0;
c6OL++; if (c6OL > d6O) c6OL = 0;
c6PL++; if (c6PL > d6P) c6PL = 0;
c6QL++; if (c6QL > d6Q) c6QL = 0;
c6RL++; if (c6RL > d6R) c6RL = 0;
hA = a6ML[c6ML-((c6ML > d6M)?d6M+1:0)];
hB = a6NL[c6NL-((c6NL > d6N)?d6N+1:0)];
hC = a6OL[c6OL-((c6OL > d6O)?d6O+1:0)];
hD = a6PL[c6PL-((c6PL > d6P)?d6P+1:0)];
hE = a6QL[c6QL-((c6QL > d6Q)?d6Q+1:0)];
hF = a6RL[c6RL-((c6RL > d6R)?d6R+1:0)];
a6SL[c6SL] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6TL[c6TL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6UL[c6UL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6VL[c6VL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6WL[c6WL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6XL[c6XL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6SL++; if (c6SL > d6S) c6SL = 0;
c6TL++; if (c6TL > d6T) c6TL = 0;
c6UL++; if (c6UL > d6U) c6UL = 0;
c6VL++; if (c6VL > d6V) c6VL = 0;
c6WL++; if (c6WL > d6W) c6WL = 0;
c6XL++; if (c6XL > d6X) c6XL = 0;
hA = a6SL[c6SL-((c6SL > d6S)?d6S+1:0)];
hB = a6TL[c6TL-((c6TL > d6T)?d6T+1:0)];
hC = a6UL[c6UL-((c6UL > d6U)?d6U+1:0)];
hD = a6VL[c6VL-((c6VL > d6V)?d6V+1:0)];
hE = a6WL[c6WL-((c6WL > d6W)?d6W+1:0)];
hF = a6XL[c6XL-((c6XL > d6X)?d6X+1:0)];
a6YL[c6YL] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6ZAL[c6ZAL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6ZBL[c6ZBL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6ZCL[c6ZCL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZDL[c6ZDL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZEL[c6ZEL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6YL++; if (c6YL > d6Y) c6YL = 0;
c6ZAL++; if (c6ZAL > d6ZA) c6ZAL = 0;
c6ZBL++; if (c6ZBL > d6ZB) c6ZBL = 0;
c6ZCL++; if (c6ZCL > d6ZC) c6ZCL = 0;
c6ZDL++; if (c6ZDL > d6ZD) c6ZDL = 0;
c6ZEL++; if (c6ZEL > d6ZE) c6ZEL = 0;
hA = a6YL[c6YL-((c6YL > d6Y)?d6Y+1:0)];
hB = a6ZAL[c6ZAL-((c6ZAL > d6ZA)?d6ZA+1:0)];
hC = a6ZBL[c6ZBL-((c6ZBL > d6ZB)?d6ZB+1:0)];
hD = a6ZCL[c6ZCL-((c6ZCL > d6ZC)?d6ZC+1:0)];
hE = a6ZDL[c6ZDL-((c6ZDL > d6ZD)?d6ZD+1:0)];
hF = a6ZEL[c6ZEL-((c6ZEL > d6ZE)?d6ZE+1:0)];
a6ZFL[c6ZFL] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6ZGL[c6ZGL] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6ZHL[c6ZHL] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6ZIL[c6ZIL] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZJL[c6ZJL] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZKL[c6ZKL] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6ZFL++; if (c6ZFL > d6ZF) c6ZFL = 0;
c6ZGL++; if (c6ZGL > d6ZG) c6ZGL = 0;
c6ZHL++; if (c6ZHL > d6ZH) c6ZHL = 0;
c6ZIL++; if (c6ZIL > d6ZI) c6ZIL = 0;
c6ZJL++; if (c6ZJL > d6ZJ) c6ZJL = 0;
c6ZKL++; if (c6ZKL > d6ZK) c6ZKL = 0;
hA = a6ZFL[c6ZFL-((c6ZFL > d6ZF)?d6ZF+1:0)];
hB = a6ZGL[c6ZGL-((c6ZGL > d6ZG)?d6ZG+1:0)];
hC = a6ZHL[c6ZHL-((c6ZHL > d6ZH)?d6ZH+1:0)];
hD = a6ZIL[c6ZIL-((c6ZIL > d6ZI)?d6ZI+1:0)];
hE = a6ZJL[c6ZJL-((c6ZJL > d6ZJ)?d6ZJ+1:0)];
hF = a6ZKL[c6ZKL-((c6ZKL > d6ZK)?d6ZK+1:0)];
f6FR = (((hA*2.0) - (hB + hC + hD + hE + hF))+avg6R)*0.5;
avg6R = ((hA*2.0) - (hB + hC + hD + hE + hF));
f6LR = ((hB*2.0) - (hA + hC + hD + hE + hF));
f6RR = ((hC*2.0) - (hA + hB + hD + hE + hF));
f6XR = ((hD*2.0) - (hA + hB + hC + hE + hF));
f6ZER = ((hE*2.0) - (hA + hB + hC + hD + hF));
f6ZKR = ((hF*2.0) - (hA + hB + hC + hD + hE));
inputSampleL = ((hA*2.0) - (hB + hC + hD + hE + hF))*0.001953125;
//right verb
c6FR++; if (c6FR > d6F) c6FR = 0;
c6LR++; if (c6LR > d6L) c6LR = 0;
c6RR++; if (c6RR > d6R) c6RR = 0;
c6XR++; if (c6XR > d6X) c6XR = 0;
c6ZER++; if (c6ZER > d6ZE) c6ZER = 0;
c6ZKR++; if (c6ZKR > d6ZK) c6ZKR = 0;
hA = a6FR[c6FR-((c6FR > d6F)?d6F+1:0)];
hB = a6LR[c6LR-((c6LR > d6L)?d6L+1:0)];
hC = a6RR[c6RR-((c6RR > d6R)?d6R+1:0)];
hD = a6XR[c6XR-((c6XR > d6X)?d6X+1:0)];
hE = a6ZER[c6ZER-((c6ZER > d6ZE)?d6ZE+1:0)];
hF = a6ZKR[c6ZKR-((c6ZKR > d6ZK)?d6ZK+1:0)];
a6ER[c6ER] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6KR[c6KR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6QR[c6QR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6WR[c6WR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZDR[c6ZDR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZJR[c6ZJR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6ER++; if (c6ER > d6E) c6ER = 0;
c6KR++; if (c6KR > d6K) c6KR = 0;
c6QR++; if (c6QR > d6Q) c6QR = 0;
c6WR++; if (c6WR > d6W) c6WR = 0;
c6ZDR++; if (c6ZDR > d6ZD) c6ZDR = 0;
c6ZJR++; if (c6ZJR > d6ZJ) c6ZJR = 0;
hA = a6ER[c6ER-((c6ER > d6E)?d6E+1:0)];
hB = a6KR[c6KR-((c6KR > d6K)?d6K+1:0)];
hC = a6QR[c6QR-((c6QR > d6Q)?d6Q+1:0)];
hD = a6WR[c6WR-((c6WR > d6W)?d6W+1:0)];
hE = a6ZDR[c6ZDR-((c6ZDR > d6ZD)?d6ZD+1:0)];
hF = a6ZJR[c6ZJR-((c6ZJR > d6ZJ)?d6ZJ+1:0)];
a6DR[c6DR] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6JR[c6JR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6PR[c6PR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6VR[c6VR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZCR[c6ZCR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZIR[c6ZIR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6DR++; if (c6DR > d6D) c6DR = 0;
c6JR++; if (c6JR > d6J) c6JR = 0;
c6PR++; if (c6PR > d6P) c6PR = 0;
c6VR++; if (c6VR > d6V) c6VR = 0;
c6ZCR++; if (c6ZCR > d6ZC) c6ZCR = 0;
c6ZIR++; if (c6ZIR > d6ZI) c6ZIR = 0;
hA = a6DR[c6DR-((c6DR > d6D)?d6D+1:0)];
hB = a6JR[c6JR-((c6JR > d6J)?d6J+1:0)];
hC = a6PR[c6PR-((c6PR > d6P)?d6P+1:0)];
hD = a6VR[c6VR-((c6VR > d6V)?d6V+1:0)];
hE = a6ZCR[c6ZCR-((c6ZCR > d6ZC)?d6ZC+1:0)];
hF = a6ZIR[c6ZIR-((c6ZIR > d6ZI)?d6ZI+1:0)];
a6CR[c6CR] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6IR[c6IR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6OR[c6OR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6UR[c6UR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZBR[c6ZBR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZHR[c6ZHR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6CR++; if (c6CR > d6C) c6CR = 0;
c6IR++; if (c6IR > d6I) c6IR = 0;
c6OR++; if (c6OR > d6O) c6OR = 0;
c6UR++; if (c6UR > d6U) c6UR = 0;
c6ZBR++; if (c6ZBR > d6ZB) c6ZBR = 0;
c6ZHR++; if (c6ZHR > d6ZH) c6ZHR = 0;
hA = a6CR[c6CR-((c6CR > d6C)?d6C+1:0)];
hB = a6IR[c6IR-((c6IR > d6I)?d6I+1:0)];
hC = a6OR[c6OR-((c6OR > d6O)?d6O+1:0)];
hD = a6UR[c6UR-((c6UR > d6U)?d6U+1:0)];
hE = a6ZBR[c6ZBR-((c6ZBR > d6ZB)?d6ZB+1:0)];
hF = a6ZHR[c6ZHR-((c6ZHR > d6ZH)?d6ZH+1:0)];
a6BR[c6BR] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6HR[c6HR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6NR[c6NR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6TR[c6TR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6ZAR[c6ZAR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZGR[c6ZGR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6BR++; if (c6BR > d6B) c6BR = 0;
c6HR++; if (c6HR > d6H) c6HR = 0;
c6NR++; if (c6NR > d6N) c6NR = 0;
c6TR++; if (c6TR > d6T) c6TR = 0;
c6ZBR++; if (c6ZBR > d6ZB) c6ZBR = 0;
c6ZGR++; if (c6ZGR > d6ZG) c6ZGR = 0;
hA = a6BR[c6BR-((c6BR > d6B)?d6B+1:0)];
hB = a6HR[c6HR-((c6HR > d6H)?d6H+1:0)];
hC = a6NR[c6NR-((c6NR > d6N)?d6N+1:0)];
hD = a6TR[c6TR-((c6TR > d6T)?d6T+1:0)];
hE = a6ZAR[c6ZAR-((c6ZAR > d6ZA)?d6ZA+1:0)];
hF = a6ZGR[c6ZGR-((c6ZGR > d6ZG)?d6ZG+1:0)];
a6AR[c6AR] = ((hA*2.0) - (hB + hC + hD + hE + hF));
a6GR[c6GR] = ((hB*2.0) - (hA + hC + hD + hE + hF));
a6MR[c6MR] = ((hC*2.0) - (hA + hB + hD + hE + hF));
a6SR[c6SR] = ((hD*2.0) - (hA + hB + hC + hE + hF));
a6YR[c6YR] = ((hE*2.0) - (hA + hB + hC + hD + hF));
a6ZFR[c6ZFR] = ((hF*2.0) - (hA + hB + hC + hD + hE));
c6AR++; if (c6AR > d6A) c6AR = 0;
c6GR++; if (c6GR > d6G) c6GR = 0;
c6MR++; if (c6MR > d6M) c6MR = 0;
c6SR++; if (c6SR > d6S) c6SR = 0;
c6YR++; if (c6YR > d6Y) c6YR = 0;
c6ZFR++; if (c6ZFR > d6ZF) c6ZFR = 0;
hA = a6AR[c6AR-((c6AR > d6A)?d6A+1:0)];
hB = a6GR[c6GR-((c6GR > d6G)?d6G+1:0)];
hC = a6MR[c6MR-((c6MR > d6M)?d6M+1:0)];
hD = a6SR[c6SR-((c6SR > d6S)?d6S+1:0)];
hE = a6YR[c6YR-((c6YR > d6Y)?d6Y+1:0)];
hF = a6ZFR[c6ZFR-((c6ZFR > d6ZF)?d6ZF+1:0)];
f6AL = (((hA*2.0) - (hB + hC + hD + hE + hF))+avg6L)*0.5;
avg6L = ((hA*2.0) - (hB + hC + hD + hE + hF));
f6BL = ((hB*2.0) - (hA + hC + hD + hE + hF));
f6CL = ((hC*2.0) - (hA + hB + hD + hE + hF));
f6DL = ((hD*2.0) - (hA + hB + hC + hE + hF));
f6EL = ((hE*2.0) - (hA + hB + hC + hD + hF));
f6FL = ((hF*2.0) - (hA + hB + hC + hD + hE));
inputSampleR = ((hA*2.0) - (hB + hC + hD + hE + hF))*0.001953125;
inputSampleL += earlyReflectionL;
inputSampleR += earlyReflectionR;
bez[bez_CL] = bez[bez_BL];
bez[bez_BL] = bez[bez_AL];
bez[bez_AL] = inputSampleL;
bez[bez_SampL] = 0.0;
bez[bez_CR] = bez[bez_BR];
bez[bez_BR] = bez[bez_AR];
bez[bez_AR] = inputSampleR;
bez[bez_SampR] = 0.0;
}
double X = bez[bez_cycle]*bezTrim;
inputSampleL = (bez[bez_BL]+(bez[bez_CL]*(1.0-X)*(1.0-X))+(bez[bez_BL]*2.0*(1.0-X)*X)+(bez[bez_AL]*X*X))*-0.0625;
inputSampleR = (bez[bez_BR]+(bez[bez_CR]*(1.0-X)*(1.0-X))+(bez[bez_BR]*2.0*(1.0-X)*X)+(bez[bez_AR]*X*X))*-0.0625;
//begin TapeHack2
double darkSampleL = inputSampleL;
double darkSampleR = inputSampleR;
if (avgPos > 31) avgPos = 0;
if (slewsing > 31) {
avg32L[avgPos] = darkSampleL; avg32R[avgPos] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 32; x++) {darkSampleL += avg32L[x]; darkSampleR += avg32R[x];}
darkSampleL /= 32.0; darkSampleR /= 32.0;
} if (slewsing > 15) {
avg16L[avgPos%16] = darkSampleL; avg16R[avgPos%16] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 16; x++) {darkSampleL += avg16L[x]; darkSampleR += avg16R[x];}
darkSampleL /= 16.0; darkSampleR /= 16.0;
} if (slewsing > 7) {
avg8L[avgPos%8] = darkSampleL; avg8R[avgPos%8] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 8; x++) {darkSampleL += avg8L[x]; darkSampleR += avg8R[x];}
darkSampleL /= 8.0; darkSampleR /= 8.0;
} if (slewsing > 3) {
avg4L[avgPos%4] = darkSampleL; avg4R[avgPos%4] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 4; x++) {darkSampleL += avg4L[x]; darkSampleR += avg4R[x];}
darkSampleL /= 4.0; darkSampleR /= 4.0;
} if (slewsing > 1) {
avg2L[avgPos%2] = darkSampleL; avg2R[avgPos%2] = darkSampleR;
darkSampleL = 0.0; darkSampleR = 0.0;
for (int x = 0; x < 2; x++) {darkSampleL += avg2L[x]; darkSampleR += avg2R[x];}
darkSampleL /= 2.0; darkSampleR /= 2.0;
} //only update avgPos after the post-distortion filter stage
double avgSlewL = fmin(fabs(lastDarkL-inputSampleL)*0.09384*overallscale,1.0);
avgSlewL = 1.0-(1.0-avgSlewL*1.0-avgSlewL);
inputSampleL = (inputSampleL*(1.0-avgSlewL)) + (darkSampleL*avgSlewL);
lastDarkL = darkSampleL;
double avgSlewR = fmin(fabs(lastDarkR-inputSampleR)*0.09384*overallscale,1.0);
avgSlewR = 1.0-(1.0-avgSlewR*1.0-avgSlewR);
inputSampleR = (inputSampleR*(1.0-avgSlewR)) + (darkSampleR*avgSlewR);
lastDarkR = darkSampleR;
inputSampleL = (inputSampleL * wet)+(drySampleL * (1.0-wet));
inputSampleR = (inputSampleR * wet)+(drySampleR * (1.0-wet));
//begin 64 bit stereo floating point dither
//int expon; frexp((double)inputSampleL, &expon);
fpdL ^= fpdL << 13; fpdL ^= fpdL >> 17; fpdL ^= fpdL << 5;
//inputSampleL += ((double(fpdL)-uint32_t(0x7fffffff)) * 3.553e-44l * pow(2,expon+62));
//frexp((double)inputSampleR, &expon);
fpdR ^= fpdR << 13; fpdR ^= fpdR >> 17; fpdR ^= fpdR << 5;
if (fpdL-fpdR < 1073741824 || fpdR-fpdL < 1073741824) {
fpdR ^= fpdR << 13; fpdR ^= fpdR >> 17; fpdR ^= fpdR << 5;}
//inputSampleR += ((double(fpdR)-uint32_t(0x7fffffff)) * 3.553e-44l * pow(2,expon+62));
//end 64 bit stereo floating point dither
*out1 = inputSampleL;
*out2 = inputSampleR;
in1++;
in2++;
out1++;
out2++;
}
}