mirror of
https://github.com/airwindows/airwindows.git
synced 2026-06-30 06:02:07 -06:00
1132 lines
44 KiB
C++
Executable file
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++;
|
|
}
|
|
}
|