From 922733a04f0b800ca1529805f8d70c378312481b Mon Sep 17 00:00:00 2001 From: GithubActions BaconPaul Bot Date: Sun, 17 Sep 2023 20:55:41 +0000 Subject: [PATCH] Update to Latest Airwin --- libs/airwindows | 2 +- res/awpdoc/ResEQ2.txt | 21 + src/ModuleAdd.h | 332 +++---- src/autogen_airwin/CMakeLists.txt | 4 + src/autogen_airwin/CrickBass.cpp | 187 ++++ src/autogen_airwin/CrickBass.h | 145 +++ src/autogen_airwin/CrickBassProc.cpp | 1280 ++++++++++++++++++++++++++ src/autogen_airwin/ResEQ2.cpp | 127 +++ src/autogen_airwin/ResEQ2.h | 74 ++ src/autogen_airwin/ResEQ2Proc.cpp | 196 ++++ 10 files changed, 2203 insertions(+), 165 deletions(-) create mode 100644 res/awpdoc/ResEQ2.txt create mode 100644 src/autogen_airwin/CrickBass.cpp create mode 100644 src/autogen_airwin/CrickBass.h create mode 100644 src/autogen_airwin/CrickBassProc.cpp create mode 100644 src/autogen_airwin/ResEQ2.cpp create mode 100644 src/autogen_airwin/ResEQ2.h create mode 100644 src/autogen_airwin/ResEQ2Proc.cpp diff --git a/libs/airwindows b/libs/airwindows index bbd64f1..1d65cc8 160000 --- a/libs/airwindows +++ b/libs/airwindows @@ -1 +1 @@ -Subproject commit bbd64f1b33ad7f2e170a3d5a87a3fc340216cf35 +Subproject commit 1d65cc8ec3ac9cb5032f77efc03ba62a8bf4ce7f diff --git a/res/awpdoc/ResEQ2.txt b/res/awpdoc/ResEQ2.txt new file mode 100644 index 0000000..2e026af --- /dev/null +++ b/res/awpdoc/ResEQ2.txt @@ -0,0 +1,21 @@ +# ResEQ2 is a single, sharp, sonorous mid peak. + +This is another 'piece of an upcoming great plugin'. In order to do an MCI console properly I had to do a good mid peak. + +And we're talking 'way better than just a sharp biquad filter' mid peak. I needed clarity and character beyond what regular digital EQ cookbooks could cook up. + +ResEQ2 continues on the work I started in the original ResEQ, where I observed that Manley EQ impulses for sharp resonances seemed to be like a sine-like ring, except the onset did NOT seem to be at the same frequency: seemed to start faster, even double the frequency. I made a whole plugin, ResEQ, giving it my best shot for generating multiple resonant 'rings' and combining them, to produce a convolution impulse that was the sum of multiple analog-like resoances. It still exists: it's way before I routinely worked at 96k, and it's got a lot of quirks, but it does get a distinct sound. + +I returned to those deep, murky waters when trying to come up with a sweepable mid peak like certain classic analog consoles. + +ResEQ2 is the result. It's the opposite of what you'll normally find in great classic analog consoles. A lot of the classics really had quite limited analog EQ: detailed parametric sculpting came in with SSL, and to some extent API before that. In the olden days, things were a lot simpler (and you gained something sonically from this simplicity). + +But there were a few special cases, and so you had MCI's sweepable mid, that could only boost. Not cut. It just gave you a sort of ring, wherever you wanted it. Not the most flexible circuit… but a hitmaker. + +This is because, contrary to modern practice, there's huge power in being able to single out a midrange, upper-mid, or treble frequency, and sort of just open up the top of it so it can get effortlessly loud. Instead of just blasting everything, you find one presence peak on your track that really lets it speak, and you just give that a boost. More peak energy, more clarity exactly where it's most useful, and it's almost never in the same place for different instruments or vocalists, so the combined sound of the mix cuts through on dozens of sonorities at once, and everything is powerful and clear. + +It's the mids equivalent of Airwindows Weight for bass, and it works incredibly well (even if you do it with biquads or EQ-design cookbooks). And I don't have the analog-Console projects finished yet… but you can have this part of it now. + +Use the 'ow argh way too extreme' settings like 1.0, where everything kind of turns into an audio laser, to dial in exactly what spot opens up an instrument or voice for maximum passion and sonority. Then, dial it back to around 0.5 and begin increasing it, seeing at what point you've got too much of a good thing. ResEQ2 is great at being a subtle light-bringer and giving clarity to a track. It's also a full-on energy weapon that can be set to 'way too much', so use it however you please. The resonance increases as you turn it up, so feel free to dial it back if it gets ringy. Probably not a good plugin for mixing live sound unless you like dial-a-feedback :) hope you enjoy ResEQ2! + + diff --git a/src/ModuleAdd.h b/src/ModuleAdd.h index ec5954d..481d8fe 100644 --- a/src/ModuleAdd.h +++ b/src/ModuleAdd.h @@ -13,7 +13,7 @@ int Air_unused = AirwinRegistry::registerAirwindow({"Air", "Brightness", 59, "Ai #include "autogen_airwin/Air2.h" int Air2_unused = AirwinRegistry::registerAirwindow({"Air2", "Brightness", 58, "Air2 is a different bright EQ with silk tone and high sample rate support.", airwin2rack::Air2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Apicolypse.h" -int Apicolypse_unused = AirwinRegistry::registerAirwindow({"Apicolypse", "Tone Color", 305, "Apicolypse is a re-release of my old API-style color adder, exacly as it was.", airwin2rack::Apicolypse::kNumParameters, []() { return std::make_unique(0); }}); +int Apicolypse_unused = AirwinRegistry::registerAirwindow({"Apicolypse", "Tone Color", 306, "Apicolypse is a re-release of my old API-style color adder, exacly as it was.", airwin2rack::Apicolypse::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/AtmosphereBuss.h" int AtmosphereBuss_unused = AirwinRegistry::registerAirwindow({"AtmosphereBuss", "Consoles", 107, "AtmosphereBuss is Console5 processing with powerful new acoustic distance effects.", airwin2rack::AtmosphereBuss::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/AtmosphereChannel.h" @@ -21,13 +21,13 @@ int AtmosphereChannel_unused = AirwinRegistry::registerAirwindow({"AtmosphereCha #include "autogen_airwin/Aura.h" int Aura_unused = AirwinRegistry::registerAirwindow({"Aura", "Effects", 180, "Aura is a new kind of resonant lowpass EQ.", airwin2rack::Aura::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/AutoPan.h" -int AutoPan_unused = AirwinRegistry::registerAirwindow({"AutoPan", "Stereo", 277, "AutoPan is for getting some organic stereo movement into your mix.", airwin2rack::AutoPan::kNumParameters, []() { return std::make_unique(0); }}); +int AutoPan_unused = AirwinRegistry::registerAirwindow({"AutoPan", "Stereo", 278, "AutoPan is for getting some organic stereo movement into your mix.", airwin2rack::AutoPan::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/AverMatrix.h" -int AverMatrix_unused = AirwinRegistry::registerAirwindow({"AverMatrix", "Filter", 204, "AverMatrix turns averaging into a full-featured EQ.", airwin2rack::AverMatrix::kNumParameters, []() { return std::make_unique(0); }}); +int AverMatrix_unused = AirwinRegistry::registerAirwindow({"AverMatrix", "Filter", 205, "AverMatrix turns averaging into a full-featured EQ.", airwin2rack::AverMatrix::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Average.h" -int Average_unused = AirwinRegistry::registerAirwindow({"Average", "Filter", 205, "Average is a distinctive sort of lowpass filter.", airwin2rack::Average::kNumParameters, []() { return std::make_unique(0); }}); +int Average_unused = AirwinRegistry::registerAirwindow({"Average", "Filter", 206, "Average is a distinctive sort of lowpass filter.", airwin2rack::Average::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Balanced.h" -int Balanced_unused = AirwinRegistry::registerAirwindow({"Balanced", "Utility", 338, "Balanced lets you run an XLR input into a stereo input, sum it to mono, and use it.", airwin2rack::Balanced::kNumParameters, []() { return std::make_unique(0); }}); +int Balanced_unused = AirwinRegistry::registerAirwindow({"Balanced", "Utility", 339, "Balanced lets you run an XLR input into a stereo input, sum it to mono, and use it.", airwin2rack::Balanced::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/BassAmp.h" int BassAmp_unused = AirwinRegistry::registerAirwindow({"BassAmp", "Amp Sims", 32, "BassAmp is an old plugin with new tweaks, that gives some bass guitar tones.", airwin2rack::BassAmp::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/BassDrive.h" @@ -35,7 +35,7 @@ int BassDrive_unused = AirwinRegistry::registerAirwindow({"BassDrive", "Amp Sims #include "autogen_airwin/BassKit.h" int BassKit_unused = AirwinRegistry::registerAirwindow({"BassKit", "Bass", 35, "BassKit is centered bass reinforcement with subs fill. Clean and controllable.", airwin2rack::BassKit::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Baxandall.h" -int Baxandall_unused = AirwinRegistry::registerAirwindow({"Baxandall", "Filter", 207, "Baxandall is a killer general-purpose EQ.", airwin2rack::Baxandall::kNumParameters, []() { return std::make_unique(0); }}); +int Baxandall_unused = AirwinRegistry::registerAirwindow({"Baxandall", "Filter", 208, "Baxandall is a killer general-purpose EQ.", airwin2rack::Baxandall::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Baxandall2.h" int Baxandall2_unused = AirwinRegistry::registerAirwindow({"Baxandall2", "Filter", 194, "Baxandall2 is Baxandall, extended and made more powerful.", airwin2rack::Baxandall2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Beam.h" @@ -55,13 +55,13 @@ int BiquadPlus_unused = AirwinRegistry::registerAirwindow({"BiquadPlus", "Biquad #include "autogen_airwin/BiquadTriple.h" int BiquadTriple_unused = AirwinRegistry::registerAirwindow({"BiquadTriple", "Biquads", 45, "BiquadTriple is a handy Airwindows cascaded biquad filter: steeper roll-off before resonance.", airwin2rack::BiquadTriple::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/BitGlitter.h" -int BitGlitter_unused = AirwinRegistry::registerAirwindow({"BitGlitter", "Lo-Fi", 226, "BitGlitter is an old-sampler style digital lo-fi plugin.", airwin2rack::BitGlitter::kNumParameters, []() { return std::make_unique(0); }}); +int BitGlitter_unused = AirwinRegistry::registerAirwindow({"BitGlitter", "Lo-Fi", 227, "BitGlitter is an old-sampler style digital lo-fi plugin.", airwin2rack::BitGlitter::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/BitShiftGain.h" -int BitShiftGain_unused = AirwinRegistry::registerAirwindow({"BitShiftGain", "Utility", 322, "BitShiftGain is the ‘One Weird Trick’ perfect boost/pad, but in 6db increments ONLY.", airwin2rack::BitShiftGain::kNumParameters, []() { return std::make_unique(0); }}); +int BitShiftGain_unused = AirwinRegistry::registerAirwindow({"BitShiftGain", "Utility", 323, "BitShiftGain is the ‘One Weird Trick’ perfect boost/pad, but in 6db increments ONLY.", airwin2rack::BitShiftGain::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/BitShiftPan.h" -int BitShiftPan_unused = AirwinRegistry::registerAirwindow({"BitShiftPan", "Utility", 321, "BitShiftPan gives you a gain and a pan control that are ONLY done using bit shifts.", airwin2rack::BitShiftPan::kNumParameters, []() { return std::make_unique(0); }}); +int BitShiftPan_unused = AirwinRegistry::registerAirwindow({"BitShiftPan", "Utility", 322, "BitShiftPan gives you a gain and a pan control that are ONLY done using bit shifts.", airwin2rack::BitShiftPan::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Bite.h" -int Bite_unused = AirwinRegistry::registerAirwindow({"Bite", "Lo-Fi", 231, "Bite is an unusual edge-maker.", airwin2rack::Bite::kNumParameters, []() { return std::make_unique(0); }}); +int Bite_unused = AirwinRegistry::registerAirwindow({"Bite", "Lo-Fi", 232, "Bite is an unusual edge-maker.", airwin2rack::Bite::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/BlockParty.h" int BlockParty_unused = AirwinRegistry::registerAirwindow({"BlockParty", "Dynamics", 158, "BlockParty is like a moderately saturated analog limiter.", airwin2rack::BlockParty::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/BrassRider.h" @@ -75,7 +75,7 @@ int BrightAmbience3_unused = AirwinRegistry::registerAirwindow({"BrightAmbience3 #include "autogen_airwin/BuildATPDF.h" int BuildATPDF_unused = AirwinRegistry::registerAirwindow({"BuildATPDF", "Dithers", 137, "BuildATPDF is a dither-making toolkit.", airwin2rack::BuildATPDF::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/BussColors4.h" -int BussColors4_unused = AirwinRegistry::registerAirwindow({"BussColors4", "Tone Color", 303, "BussColors4 is the Airwindows console emulations, now working up to 192K correctly.", airwin2rack::BussColors4::kNumParameters, []() { return std::make_unique(0); }}); +int BussColors4_unused = AirwinRegistry::registerAirwindow({"BussColors4", "Tone Color", 304, "BussColors4 is the Airwindows console emulations, now working up to 192K correctly.", airwin2rack::BussColors4::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ButterComp.h" int ButterComp_unused = AirwinRegistry::registerAirwindow({"ButterComp", "Dynamics", 163, "ButterComp is my softest, smoothest compressor.", airwin2rack::ButterComp::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ButterComp2.h" @@ -87,49 +87,49 @@ int C5RawChannel_unused = AirwinRegistry::registerAirwindow({"C5RawChannel", "Co #include "autogen_airwin/CStrip.h" int CStrip_unused = AirwinRegistry::registerAirwindow({"CStrip", "Unclassified", -1, "CStrip is an Airwindows channel strip.", airwin2rack::CStrip::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/CStrip2.h" -int CStrip2_unused = AirwinRegistry::registerAirwindow({"CStrip2", "Filter", 198, "CStrip2 refines and optimizes CStrip, by request!", airwin2rack::CStrip2::kNumParameters, []() { return std::make_unique(0); }}); +int CStrip2_unused = AirwinRegistry::registerAirwindow({"CStrip2", "Filter", 199, "CStrip2 refines and optimizes CStrip, by request!", airwin2rack::CStrip2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Cabs.h" int Cabs_unused = AirwinRegistry::registerAirwindow({"Cabs", "Amp Sims", 30, "Cabs is an Airwindows guitar speaker cabinet simulator.", airwin2rack::Cabs::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Calibre.h" -int Calibre_unused = AirwinRegistry::registerAirwindow({"Calibre", "Tone Color", 308, "Calibre is a re-release of another old Character plugin.", airwin2rack::Calibre::kNumParameters, []() { return std::make_unique(0); }}); +int Calibre_unused = AirwinRegistry::registerAirwindow({"Calibre", "Tone Color", 309, "Calibre is a re-release of another old Character plugin.", airwin2rack::Calibre::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Capacitor.h" -int Capacitor_unused = AirwinRegistry::registerAirwindow({"Capacitor", "Filter", 210, "Capacitor is a lowpass/highpass filter of a new type.", airwin2rack::Capacitor::kNumParameters, []() { return std::make_unique(0); }}); +int Capacitor_unused = AirwinRegistry::registerAirwindow({"Capacitor", "Filter", 211, "Capacitor is a lowpass/highpass filter of a new type.", airwin2rack::Capacitor::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Capacitor2.h" int Capacitor2_unused = AirwinRegistry::registerAirwindow({"Capacitor2", "Filter", 195, "Capacitor2 is Capacitor with extra analog modeling and mojo.", airwin2rack::Capacitor2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Chamber.h" -int Chamber_unused = AirwinRegistry::registerAirwindow({"Chamber", "Reverb", 251, "Chamber is a feedforward reverb based on the golden ratio.", airwin2rack::Chamber::kNumParameters, []() { return std::make_unique(0); }}); +int Chamber_unused = AirwinRegistry::registerAirwindow({"Chamber", "Reverb", 252, "Chamber is a feedforward reverb based on the golden ratio.", airwin2rack::Chamber::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Chamber2.h" -int Chamber2_unused = AirwinRegistry::registerAirwindow({"Chamber2", "Reverb", 250, "Chamber2 is a feedforward reverb, a blur delay, and a glitch topping!", airwin2rack::Chamber2::kNumParameters, []() { return std::make_unique(0); }}); +int Chamber2_unused = AirwinRegistry::registerAirwindow({"Chamber2", "Reverb", 251, "Chamber2 is a feedforward reverb, a blur delay, and a glitch topping!", airwin2rack::Chamber2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Channel4.h" -int Channel4_unused = AirwinRegistry::registerAirwindow({"Channel4", "Tone Color", 317, "Channel4 is a tone coloring plugin that gives more of an analog feel.", airwin2rack::Channel4::kNumParameters, []() { return std::make_unique(0); }}); +int Channel4_unused = AirwinRegistry::registerAirwindow({"Channel4", "Tone Color", 318, "Channel4 is a tone coloring plugin that gives more of an analog feel.", airwin2rack::Channel4::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Channel5.h" -int Channel5_unused = AirwinRegistry::registerAirwindow({"Channel5", "Tone Color", 316, "Channel5 is Channel for 2018, with new subtleties.", airwin2rack::Channel5::kNumParameters, []() { return std::make_unique(0); }}); +int Channel5_unused = AirwinRegistry::registerAirwindow({"Channel5", "Tone Color", 317, "Channel5 is Channel for 2018, with new subtleties.", airwin2rack::Channel5::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Channel6.h" -int Channel6_unused = AirwinRegistry::registerAirwindow({"Channel6", "Tone Color", 315, "Channel6 uses the Spiral algorithm.", airwin2rack::Channel6::kNumParameters, []() { return std::make_unique(0); }}); +int Channel6_unused = AirwinRegistry::registerAirwindow({"Channel6", "Tone Color", 316, "Channel6 uses the Spiral algorithm.", airwin2rack::Channel6::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Channel7.h" -int Channel7_unused = AirwinRegistry::registerAirwindow({"Channel7", "Tone Color", 314, "Channel7 improves slew clipping and lets you blend Channel 6 and 5.", airwin2rack::Channel7::kNumParameters, []() { return std::make_unique(0); }}); +int Channel7_unused = AirwinRegistry::registerAirwindow({"Channel7", "Tone Color", 315, "Channel7 improves slew clipping and lets you blend Channel 6 and 5.", airwin2rack::Channel7::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Channel8.h" -int Channel8_unused = AirwinRegistry::registerAirwindow({"Channel8", "Tone Color", 313, "Channel8 is Channel7 with updates from Capacitor2 and Slew3. More and better of what Channel is.", airwin2rack::Channel8::kNumParameters, []() { return std::make_unique(0); }}); +int Channel8_unused = AirwinRegistry::registerAirwindow({"Channel8", "Tone Color", 314, "Channel8 is Channel7 with updates from Capacitor2 and Slew3. More and better of what Channel is.", airwin2rack::Channel8::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Channel9.h" -int Channel9_unused = AirwinRegistry::registerAirwindow({"Channel9", "Tone Color", 304, "Channel9 is Channel8 with ultrasonic filtering, and new Teac and Mackie 'low end' settings.", airwin2rack::Channel9::kNumParameters, []() { return std::make_unique(0); }}); +int Channel9_unused = AirwinRegistry::registerAirwindow({"Channel9", "Tone Color", 305, "Channel9 is Channel8 with ultrasonic filtering, and new Teac and Mackie 'low end' settings.", airwin2rack::Channel9::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Chorus.h" int Chorus_unused = AirwinRegistry::registerAirwindow({"Chorus", "Ambience", 21, "Chorus is a mono chorus, also works as a vibrato.", airwin2rack::Chorus::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ChorusEnsemble.h" int ChorusEnsemble_unused = AirwinRegistry::registerAirwindow({"ChorusEnsemble", "Ambience", 22, "ChorusEnsemble is a more complex, multi-tap mono chorus.", airwin2rack::ChorusEnsemble::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ChromeOxide.h" -int ChromeOxide_unused = AirwinRegistry::registerAirwindow({"ChromeOxide", "Lo-Fi", 228, "ChromeOxide is an alternate path to vibey old tape sonics.", airwin2rack::ChromeOxide::kNumParameters, []() { return std::make_unique(0); }}); +int ChromeOxide_unused = AirwinRegistry::registerAirwindow({"ChromeOxide", "Lo-Fi", 229, "ChromeOxide is an alternate path to vibey old tape sonics.", airwin2rack::ChromeOxide::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Cider.h" -int Cider_unused = AirwinRegistry::registerAirwindow({"Cider", "Tone Color", 309, "Cider is a re-release of another old Character plugin.", airwin2rack::Cider::kNumParameters, []() { return std::make_unique(0); }}); +int Cider_unused = AirwinRegistry::registerAirwindow({"Cider", "Tone Color", 310, "Cider is a re-release of another old Character plugin.", airwin2rack::Cider::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ClipOnly2.h" int ClipOnly2_unused = AirwinRegistry::registerAirwindow({"ClipOnly2", "Clipping", 69, "ClipOnly2 suppresses the brightness of digital clipping without affecting unclipped samples, at any sample rate.", airwin2rack::ClipOnly2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ClipSoftly.h" int ClipSoftly_unused = AirwinRegistry::registerAirwindow({"ClipSoftly", "Clipping", 70, "ClipSoftly is ClipOnly2 but as a softclipper: a very handy building block.", airwin2rack::ClipSoftly::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Coils.h" -int Coils_unused = AirwinRegistry::registerAirwindow({"Coils", "Subtlety", 292, "Coils models the types of distortion you'll find in transformers.", airwin2rack::Coils::kNumParameters, []() { return std::make_unique(0); }}); +int Coils_unused = AirwinRegistry::registerAirwindow({"Coils", "Subtlety", 293, "Coils models the types of distortion you'll find in transformers.", airwin2rack::Coils::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Coils2.h" -int Coils2_unused = AirwinRegistry::registerAirwindow({"Coils2", "Subtlety", 287, "Coils2 is a transformer overdrive emulator.", airwin2rack::Coils2::kNumParameters, []() { return std::make_unique(0); }}); +int Coils2_unused = AirwinRegistry::registerAirwindow({"Coils2", "Subtlety", 288, "Coils2 is a transformer overdrive emulator.", airwin2rack::Coils2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Cojones.h" -int Cojones_unused = AirwinRegistry::registerAirwindow({"Cojones", "Lo-Fi", 229, "Cojones is a new kind of distorty.", airwin2rack::Cojones::kNumParameters, []() { return std::make_unique(0); }}); +int Cojones_unused = AirwinRegistry::registerAirwindow({"Cojones", "Lo-Fi", 230, "Cojones is a new kind of distorty.", airwin2rack::Cojones::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Compresaturator.h" int Compresaturator_unused = AirwinRegistry::registerAirwindow({"Compresaturator", "Dynamics", 161, "Compresaturator fades between compressing and soft clipping.", airwin2rack::Compresaturator::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Console0Buss.h" @@ -181,17 +181,19 @@ int Console8SubIn_unused = AirwinRegistry::registerAirwindow({"Console8SubIn", " #include "autogen_airwin/Console8SubOut.h" int Console8SubOut_unused = AirwinRegistry::registerAirwindow({"Console8SubOut", "Consoles", 85, "Console8SubOut moves to a channel/submix/buss topology and adds analog simulation.", airwin2rack::Console8SubOut::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Creature.h" -int Creature_unused = AirwinRegistry::registerAirwindow({"Creature", "Saturation", 258, "Creature is a soft slew saturator, a new class of noisechanger.", airwin2rack::Creature::kNumParameters, []() { return std::make_unique(0); }}); +int Creature_unused = AirwinRegistry::registerAirwindow({"Creature", "Saturation", 259, "Creature is a soft slew saturator, a new class of noisechanger.", airwin2rack::Creature::kNumParameters, []() { return std::make_unique(0); }}); +#include "autogen_airwin/CrickBass.h" +int CrickBass_unused = AirwinRegistry::registerAirwindow({"CrickBass", "Unclassified", -1, "", airwin2rack::CrickBass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/CrunchyGrooveWear.h" -int CrunchyGrooveWear_unused = AirwinRegistry::registerAirwindow({"CrunchyGrooveWear", "Lo-Fi", 222, "CrunchyGrooveWear is a version of GrooveWear for more edge and distortion.", airwin2rack::CrunchyGrooveWear::kNumParameters, []() { return std::make_unique(0); }}); +int CrunchyGrooveWear_unused = AirwinRegistry::registerAirwindow({"CrunchyGrooveWear", "Lo-Fi", 223, "CrunchyGrooveWear is a version of GrooveWear for more edge and distortion.", airwin2rack::CrunchyGrooveWear::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Crystal.h" -int Crystal_unused = AirwinRegistry::registerAirwindow({"Crystal", "Tone Color", 310, "Crystal is a tone shaper and buss soft-clipper.", airwin2rack::Crystal::kNumParameters, []() { return std::make_unique(0); }}); +int Crystal_unused = AirwinRegistry::registerAirwindow({"Crystal", "Tone Color", 311, "Crystal is a tone shaper and buss soft-clipper.", airwin2rack::Crystal::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/DCVoltage.h" -int DCVoltage_unused = AirwinRegistry::registerAirwindow({"DCVoltage", "Utility", 331, "DCVoltage is literally a DC control voltage, in a plugin.", airwin2rack::DCVoltage::kNumParameters, []() { return std::make_unique(0); }}); +int DCVoltage_unused = AirwinRegistry::registerAirwindow({"DCVoltage", "Utility", 332, "DCVoltage is literally a DC control voltage, in a plugin.", airwin2rack::DCVoltage::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Dark.h" int Dark_unused = AirwinRegistry::registerAirwindow({"Dark", "Dithers", 124, "Dark is a wordlength reducer that gives your music a blacker backdrop.", airwin2rack::Dark::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/DarkNoise.h" -int DarkNoise_unused = AirwinRegistry::registerAirwindow({"DarkNoise", "Noise", 238, "DarkNoise is an alternative method for producing bassier noise directly. Sound design stuff.", airwin2rack::DarkNoise::kNumParameters, []() { return std::make_unique(0); }}); +int DarkNoise_unused = AirwinRegistry::registerAirwindow({"DarkNoise", "Noise", 239, "DarkNoise is an alternative method for producing bassier noise directly. Sound design stuff.", airwin2rack::DarkNoise::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/DeBess.h" int DeBess_unused = AirwinRegistry::registerAirwindow({"DeBess", "Brightness", 48, "DeBess is an improved DeEss, with perfect rejection of non-ess audio.", airwin2rack::DeBess::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/DeEss.h" @@ -199,27 +201,27 @@ int DeEss_unused = AirwinRegistry::registerAirwindow({"DeEss", "Brightness", 52, #include "autogen_airwin/DeHiss.h" int DeHiss_unused = AirwinRegistry::registerAirwindow({"DeHiss", "Brightness", 62, "DeHiss tries to suppress background hiss, like a hiss gate.", airwin2rack::DeHiss::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/DeRez.h" -int DeRez_unused = AirwinRegistry::registerAirwindow({"DeRez", "Lo-Fi", 227, "DeRez is an analog-style bit and sample rate crusher with continuous adjustments.", airwin2rack::DeRez::kNumParameters, []() { return std::make_unique(0); }}); +int DeRez_unused = AirwinRegistry::registerAirwindow({"DeRez", "Lo-Fi", 228, "DeRez is an analog-style bit and sample rate crusher with continuous adjustments.", airwin2rack::DeRez::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/DeRez2.h" -int DeRez2_unused = AirwinRegistry::registerAirwindow({"DeRez2", "Lo-Fi", 225, "DeRez2 brings more authentic retro-digital hardware tones.", airwin2rack::DeRez2::kNumParameters, []() { return std::make_unique(0); }}); +int DeRez2_unused = AirwinRegistry::registerAirwindow({"DeRez2", "Lo-Fi", 226, "DeRez2 brings more authentic retro-digital hardware tones.", airwin2rack::DeRez2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Deckwrecka.h" -int Deckwrecka_unused = AirwinRegistry::registerAirwindow({"Deckwrecka", "Lo-Fi", 232, "Deckwrecka fattens and dirties up beats.", airwin2rack::Deckwrecka::kNumParameters, []() { return std::make_unique(0); }}); +int Deckwrecka_unused = AirwinRegistry::registerAirwindow({"Deckwrecka", "Lo-Fi", 233, "Deckwrecka fattens and dirties up beats.", airwin2rack::Deckwrecka::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Density.h" int Density_unused = AirwinRegistry::registerAirwindow({"Density", "Distortion", 118, "Density is a Swiss Army Knife of saturation/antisaturation.", airwin2rack::Density::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Density2.h" int Density2_unused = AirwinRegistry::registerAirwindow({"Density2", "Distortion", 117, "Density2 is a different color for Density, some old code I had that people wanted.", airwin2rack::Density2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Desk.h" -int Desk_unused = AirwinRegistry::registerAirwindow({"Desk", "Subtlety", 293, "Desk is classic Airwindows subtle analog modeling.", airwin2rack::Desk::kNumParameters, []() { return std::make_unique(0); }}); +int Desk_unused = AirwinRegistry::registerAirwindow({"Desk", "Subtlety", 294, "Desk is classic Airwindows subtle analog modeling.", airwin2rack::Desk::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Desk4.h" -int Desk4_unused = AirwinRegistry::registerAirwindow({"Desk4", "Saturation", 270, "Desk4 is distinctive analog coloration (a tuneable version of the control-less Desk plugins)", airwin2rack::Desk4::kNumParameters, []() { return std::make_unique(0); }}); +int Desk4_unused = AirwinRegistry::registerAirwindow({"Desk4", "Saturation", 271, "Desk4 is distinctive analog coloration (a tuneable version of the control-less Desk plugins)", airwin2rack::Desk4::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/DigitalBlack.h" int DigitalBlack_unused = AirwinRegistry::registerAirwindow({"DigitalBlack", "Dynamics", 151, "DigitalBlack is a quick, staccato gate.", airwin2rack::DigitalBlack::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Dirt.h" int Dirt_unused = AirwinRegistry::registerAirwindow({"Dirt", "Distortion", 115, "Dirt is a soft-clip distortion in the spirit of Edge.", airwin2rack::Dirt::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Distance.h" -int Distance_unused = AirwinRegistry::registerAirwindow({"Distance", "Filter", 217, "Distance is a sound design or reverb far-away-izer.", airwin2rack::Distance::kNumParameters, []() { return std::make_unique(0); }}); +int Distance_unused = AirwinRegistry::registerAirwindow({"Distance", "Filter", 218, "Distance is a sound design or reverb far-away-izer.", airwin2rack::Distance::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Distance2.h" -int Distance2_unused = AirwinRegistry::registerAirwindow({"Distance2", "Filter", 216, "Distance2 is a versatile space shaper for creating depth.", airwin2rack::Distance2::kNumParameters, []() { return std::make_unique(0); }}); +int Distance2_unused = AirwinRegistry::registerAirwindow({"Distance2", "Filter", 217, "Distance2 is a versatile space shaper for creating depth.", airwin2rack::Distance2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Distortion.h" int Distortion_unused = AirwinRegistry::registerAirwindow({"Distortion", "Distortion", 113, "Distortion is a slightly dark analog-style distortion with several presets, like Focus.", airwin2rack::Distortion::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/DitherFloat.h" @@ -245,21 +247,21 @@ int DubSub_unused = AirwinRegistry::registerAirwindow({"DubSub", "Bass", 37, "Du #include "autogen_airwin/Dubly.h" int Dubly_unused = AirwinRegistry::registerAirwindow({"Dubly", "Effects", 176, "Dubly is a retro vibe and atmosphere maker.", airwin2rack::Dubly::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/DustBunny.h" -int DustBunny_unused = AirwinRegistry::registerAirwindow({"DustBunny", "Lo-Fi", 233, "DustBunny is unpredictable distorty noise, like dust wedged under your turntable needle.", airwin2rack::DustBunny::kNumParameters, []() { return std::make_unique(0); }}); +int DustBunny_unused = AirwinRegistry::registerAirwindow({"DustBunny", "Lo-Fi", 234, "DustBunny is unpredictable distorty noise, like dust wedged under your turntable needle.", airwin2rack::DustBunny::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Dynamics.h" int Dynamics_unused = AirwinRegistry::registerAirwindow({"Dynamics", "Dynamics", 149, "Dynamics is a combination compressor gate.", airwin2rack::Dynamics::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Dyno.h" -int Dyno_unused = AirwinRegistry::registerAirwindow({"Dyno", "Saturation", 267, "Dyno is a lot like Mojo, but for intensity instead of loudness.", airwin2rack::Dyno::kNumParameters, []() { return std::make_unique(0); }}); +int Dyno_unused = AirwinRegistry::registerAirwindow({"Dyno", "Saturation", 268, "Dyno is a lot like Mojo, but for intensity instead of loudness.", airwin2rack::Dyno::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/EQ.h" -int EQ_unused = AirwinRegistry::registerAirwindow({"EQ", "Filter", 209, "EQ is just the EQ parts of CStrip.", airwin2rack::EQ::kNumParameters, []() { return std::make_unique(0); }}); +int EQ_unused = AirwinRegistry::registerAirwindow({"EQ", "Filter", 210, "EQ is just the EQ parts of CStrip.", airwin2rack::EQ::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/EdIsDim.h" -int EdIsDim_unused = AirwinRegistry::registerAirwindow({"EdIsDim", "Utility", 332, "EdIsDim is mid/side conversion utility plugins.", airwin2rack::EdIsDim::kNumParameters, []() { return std::make_unique(0); }}); +int EdIsDim_unused = AirwinRegistry::registerAirwindow({"EdIsDim", "Utility", 333, "EdIsDim is mid/side conversion utility plugins.", airwin2rack::EdIsDim::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Edge.h" int Edge_unused = AirwinRegistry::registerAirwindow({"Edge", "Distortion", 114, "Edge is a seven-stage distortion with Hypersonic filtering and tone shaping controls.", airwin2rack::Edge::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Elation.h" -int Elation_unused = AirwinRegistry::registerAirwindow({"Elation", "Tone Color", 307, "Elation is a re-release of another old Character plugin.", airwin2rack::Elation::kNumParameters, []() { return std::make_unique(0); }}); +int Elation_unused = AirwinRegistry::registerAirwindow({"Elation", "Tone Color", 308, "Elation is a re-release of another old Character plugin.", airwin2rack::Elation::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ElectroHat.h" -int ElectroHat_unused = AirwinRegistry::registerAirwindow({"ElectroHat", "Noise", 239, "ElectroHat is a hi-hat tone generator that uses the original sound as a control voltage.", airwin2rack::ElectroHat::kNumParameters, []() { return std::make_unique(0); }}); +int ElectroHat_unused = AirwinRegistry::registerAirwindow({"ElectroHat", "Noise", 240, "ElectroHat is a hi-hat tone generator that uses the original sound as a control voltage.", airwin2rack::ElectroHat::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Energy.h" int Energy_unused = AirwinRegistry::registerAirwindow({"Energy", "Effects", 187, "Energy is electrifying fixed-frequency treble boosts.", airwin2rack::Energy::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Energy2.h" @@ -271,7 +273,7 @@ int EveryConsole_unused = AirwinRegistry::registerAirwindow({"EveryConsole", "Co #include "autogen_airwin/EverySlew.h" int EverySlew_unused = AirwinRegistry::registerAirwindow({"EverySlew", "Brightness", 54, "EverySlew is a wide variety of unique sound processing tools.", airwin2rack::EverySlew::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/EveryTrim.h" -int EveryTrim_unused = AirwinRegistry::registerAirwindow({"EveryTrim", "Utility", 325, "EveryTrim is Left/Right, Mid/Side, and Master in one plugin.", airwin2rack::EveryTrim::kNumParameters, []() { return std::make_unique(0); }}); +int EveryTrim_unused = AirwinRegistry::registerAirwindow({"EveryTrim", "Utility", 326, "EveryTrim is Left/Right, Mid/Side, and Master in one plugin.", airwin2rack::EveryTrim::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Exciter.h" int Exciter_unused = AirwinRegistry::registerAirwindow({"Exciter", "Effects", 185, "Exciter is an Aural Exciter plugin that can be both subtle and extreme.", airwin2rack::Exciter::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Facet.h" @@ -281,23 +283,23 @@ int FathomFive_unused = AirwinRegistry::registerAirwindow({"FathomFive", "Bass", #include "autogen_airwin/FireAmp.h" int FireAmp_unused = AirwinRegistry::registerAirwindow({"FireAmp", "Amp Sims", 25, "FireAmp is a bright, loud, tubey amp sim for leads and dirt guitar.", airwin2rack::FireAmp::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Flipity.h" -int Flipity_unused = AirwinRegistry::registerAirwindow({"Flipity", "Utility", 339, "Flipity is a channel phase flipper/swapper utility.", airwin2rack::Flipity::kNumParameters, []() { return std::make_unique(0); }}); +int Flipity_unused = AirwinRegistry::registerAirwindow({"Flipity", "Utility", 340, "Flipity is a channel phase flipper/swapper utility.", airwin2rack::Flipity::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Floor.h" int Floor_unused = AirwinRegistry::registerAirwindow({"Floor", "Bass", 38, "Floor is fake bottom octave for fun and profit!", airwin2rack::Floor::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Flutter.h" -int Flutter_unused = AirwinRegistry::registerAirwindow({"Flutter", "Lo-Fi", 221, "Flutter is the most recent Airwindows flutter, standalone.", airwin2rack::Flutter::kNumParameters, []() { return std::make_unique(0); }}); +int Flutter_unused = AirwinRegistry::registerAirwindow({"Flutter", "Lo-Fi", 222, "Flutter is the most recent Airwindows flutter, standalone.", airwin2rack::Flutter::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Focus.h" -int Focus_unused = AirwinRegistry::registerAirwindow({"Focus", "Saturation", 265, "Focus brings out clarity by distorting. Aggressive, subtle, flexible.", airwin2rack::Focus::kNumParameters, []() { return std::make_unique(0); }}); +int Focus_unused = AirwinRegistry::registerAirwindow({"Focus", "Saturation", 266, "Focus brings out clarity by distorting. Aggressive, subtle, flexible.", airwin2rack::Focus::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Fracture.h" int Fracture_unused = AirwinRegistry::registerAirwindow({"Fracture", "Effects", 189, "Fracture is a frequency multiplier/waveshaper with a soft disruption to the sound.", airwin2rack::Fracture::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Fracture2.h" int Fracture2_unused = AirwinRegistry::registerAirwindow({"Fracture2", "Effects", 175, "Fracture2 is a wavefolder that allows more extreme disruption.", airwin2rack::Fracture2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/FromTape.h" -int FromTape_unused = AirwinRegistry::registerAirwindow({"FromTape", "Tape", 297, "FromTape is a minimalist, cleaner analog tape emulation.", airwin2rack::FromTape::kNumParameters, []() { return std::make_unique(0); }}); +int FromTape_unused = AirwinRegistry::registerAirwindow({"FromTape", "Tape", 298, "FromTape is a minimalist, cleaner analog tape emulation.", airwin2rack::FromTape::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Galactic.h" -int Galactic_unused = AirwinRegistry::registerAirwindow({"Galactic", "Reverb", 248, "Galactic is a super-reverb designed specially for pads and space ambient.", airwin2rack::Galactic::kNumParameters, []() { return std::make_unique(0); }}); +int Galactic_unused = AirwinRegistry::registerAirwindow({"Galactic", "Reverb", 249, "Galactic is a super-reverb designed specially for pads and space ambient.", airwin2rack::Galactic::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Galactic2.h" -int Galactic2_unused = AirwinRegistry::registerAirwindow({"Galactic2", "Reverb", 247, "Galactic2 is a super-reverb REdesigned specially for pads and space ambient.", airwin2rack::Galactic2::kNumParameters, []() { return std::make_unique(0); }}); +int Galactic2_unused = AirwinRegistry::registerAirwindow({"Galactic2", "Reverb", 248, "Galactic2 is a super-reverb REdesigned specially for pads and space ambient.", airwin2rack::Galactic2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/GalacticVibe.h" int GalacticVibe_unused = AirwinRegistry::registerAirwindow({"GalacticVibe", "Effects", 174, "GalacticVibe is the stereo vibrato from the original Galactic reverb.", airwin2rack::GalacticVibe::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Gatelope.h" @@ -307,19 +309,19 @@ int GlitchShifter_unused = AirwinRegistry::registerAirwindow({"GlitchShifter", " #include "autogen_airwin/GoldenSlew.h" int GoldenSlew_unused = AirwinRegistry::registerAirwindow({"GoldenSlew", "Brightness", 49, "GoldenSlew is a multistage slew clipper based on the Golden Ratio.", airwin2rack::GoldenSlew::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Golem.h" -int Golem_unused = AirwinRegistry::registerAirwindow({"Golem", "Utility", 330, "Golem lets you blend a stereo track of two mics on an amp.", airwin2rack::Golem::kNumParameters, []() { return std::make_unique(0); }}); +int Golem_unused = AirwinRegistry::registerAirwindow({"Golem", "Utility", 331, "Golem lets you blend a stereo track of two mics on an amp.", airwin2rack::Golem::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/GrindAmp.h" int GrindAmp_unused = AirwinRegistry::registerAirwindow({"GrindAmp", "Amp Sims", 24, "GrindAmp is a heavier amp sim for many purposes.", airwin2rack::GrindAmp::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Gringer.h" int Gringer_unused = AirwinRegistry::registerAirwindow({"Gringer", "Effects", 184, "Gringer is a full-wave rectifier plugin, like a Green Ringer guitar effect.", airwin2rack::Gringer::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/GrooveWear.h" -int GrooveWear_unused = AirwinRegistry::registerAirwindow({"GrooveWear", "Lo-Fi", 223, "GrooveWear is for scrubbing highs off mechanically like a stylus would.", airwin2rack::GrooveWear::kNumParameters, []() { return std::make_unique(0); }}); +int GrooveWear_unused = AirwinRegistry::registerAirwindow({"GrooveWear", "Lo-Fi", 224, "GrooveWear is for scrubbing highs off mechanically like a stylus would.", airwin2rack::GrooveWear::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/GuitarConditioner.h" int GuitarConditioner_unused = AirwinRegistry::registerAirwindow({"GuitarConditioner", "Effects", 179, "GuitarConditioner is like a Tube Screamer voicing without the squishiness and indistinctness.", airwin2rack::GuitarConditioner::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/HardVacuum.h" int HardVacuum_unused = AirwinRegistry::registerAirwindow({"HardVacuum", "Distortion", 121, "HardVacuum is tube style saturation effects.", airwin2rack::HardVacuum::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/HermeTrim.h" -int HermeTrim_unused = AirwinRegistry::registerAirwindow({"HermeTrim", "Utility", 326, "HermeTrim is Very Fine Adjustments, otherwise just like EveryTrim.", airwin2rack::HermeTrim::kNumParameters, []() { return std::make_unique(0); }}); +int HermeTrim_unused = AirwinRegistry::registerAirwindow({"HermeTrim", "Utility", 327, "HermeTrim is Very Fine Adjustments, otherwise just like EveryTrim.", airwin2rack::HermeTrim::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Hermepass.h" int Hermepass_unused = AirwinRegistry::registerAirwindow({"Hermepass", "Bass", 34, "Hermepass is a mastering highpass to set by ear only.", airwin2rack::Hermepass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/HighGlossDither.h" @@ -327,51 +329,51 @@ int HighGlossDither_unused = AirwinRegistry::registerAirwindow({"HighGlossDither #include "autogen_airwin/HighImpact.h" int HighImpact_unused = AirwinRegistry::registerAirwindow({"HighImpact", "Distortion", 122, "HighImpact is distorted grit and punch without fatness.", airwin2rack::HighImpact::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Highpass.h" -int Highpass_unused = AirwinRegistry::registerAirwindow({"Highpass", "Filter", 219, "Highpass is a time warp, for retro midrangey sounds.", airwin2rack::Highpass::kNumParameters, []() { return std::make_unique(0); }}); +int Highpass_unused = AirwinRegistry::registerAirwindow({"Highpass", "Filter", 220, "Highpass is a time warp, for retro midrangey sounds.", airwin2rack::Highpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Highpass2.h" -int Highpass2_unused = AirwinRegistry::registerAirwindow({"Highpass2", "Filter", 215, "Highpass2 is an unusual-sounding variable-slope highpass filter.", airwin2rack::Highpass2::kNumParameters, []() { return std::make_unique(0); }}); +int Highpass2_unused = AirwinRegistry::registerAirwindow({"Highpass2", "Filter", 216, "Highpass2 is an unusual-sounding variable-slope highpass filter.", airwin2rack::Highpass2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Holt.h" -int Holt_unused = AirwinRegistry::registerAirwindow({"Holt", "Filter", 202, "Holt is a synth-like resonant lowpass filter focussed on bass frequencies.", airwin2rack::Holt::kNumParameters, []() { return std::make_unique(0); }}); +int Holt_unused = AirwinRegistry::registerAirwindow({"Holt", "Filter", 203, "Holt is a synth-like resonant lowpass filter focussed on bass frequencies.", airwin2rack::Holt::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Holt2.h" -int Holt2_unused = AirwinRegistry::registerAirwindow({"Holt2", "Filter", 201, "Holt2 is a bass-cab-like resonant lowpass filter.", airwin2rack::Holt2::kNumParameters, []() { return std::make_unique(0); }}); +int Holt2_unused = AirwinRegistry::registerAirwindow({"Holt2", "Filter", 202, "Holt2 is a bass-cab-like resonant lowpass filter.", airwin2rack::Holt2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Hombre.h" int Hombre_unused = AirwinRegistry::registerAirwindow({"Hombre", "Ambience", 16, "Hombre is atmosphere and texture (through very short delays).", airwin2rack::Hombre::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Huge.h" -int Huge_unused = AirwinRegistry::registerAirwindow({"Huge", "Saturation", 259, "Huge is a dirty, dirty loudenator.", airwin2rack::Huge::kNumParameters, []() { return std::make_unique(0); }}); +int Huge_unused = AirwinRegistry::registerAirwindow({"Huge", "Saturation", 260, "Huge is a dirty, dirty loudenator.", airwin2rack::Huge::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Hull.h" -int Hull_unused = AirwinRegistry::registerAirwindow({"Hull", "Filter", 208, "Hull is an alternate form of highpass/lowpass filter.", airwin2rack::Hull::kNumParameters, []() { return std::make_unique(0); }}); +int Hull_unused = AirwinRegistry::registerAirwindow({"Hull", "Filter", 209, "Hull is an alternate form of highpass/lowpass filter.", airwin2rack::Hull::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Hype.h" -int Hype_unused = AirwinRegistry::registerAirwindow({"Hype", "Subtlety", 281, "Hype is a treble softening experiment gone strangely awry :)", airwin2rack::Hype::kNumParameters, []() { return std::make_unique(0); }}); +int Hype_unused = AirwinRegistry::registerAirwindow({"Hype", "Subtlety", 282, "Hype is a treble softening experiment gone strangely awry :)", airwin2rack::Hype::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/HypersonX.h" int HypersonX_unused = AirwinRegistry::registerAirwindow({"HypersonX", "Brightness", 64, "HypersonX is like UltrasonX but with seven stages instead of five.", airwin2rack::HypersonX::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Hypersonic.h" int Hypersonic_unused = AirwinRegistry::registerAirwindow({"Hypersonic", "Brightness", 63, "Hypersonic is Ultrasonic, but steeper and higher cutoff.", airwin2rack::Hypersonic::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Infinity.h" -int Infinity_unused = AirwinRegistry::registerAirwindow({"Infinity", "Reverb", 254, "Infinity is a MatrixVerb specifically designed to sustain and layer sounds forever.", airwin2rack::Infinity::kNumParameters, []() { return std::make_unique(0); }}); +int Infinity_unused = AirwinRegistry::registerAirwindow({"Infinity", "Reverb", 255, "Infinity is a MatrixVerb specifically designed to sustain and layer sounds forever.", airwin2rack::Infinity::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Infinity2.h" -int Infinity2_unused = AirwinRegistry::registerAirwindow({"Infinity2", "Reverb", 252, "Infinity2 expands Infinity with more tone shaping and a much-requested kill-switch!", airwin2rack::Infinity2::kNumParameters, []() { return std::make_unique(0); }}); +int Infinity2_unused = AirwinRegistry::registerAirwindow({"Infinity2", "Reverb", 253, "Infinity2 expands Infinity with more tone shaping and a much-requested kill-switch!", airwin2rack::Infinity2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Inflamer.h" -int Inflamer_unused = AirwinRegistry::registerAirwindow({"Inflamer", "Subtlety", 283, "Inflamer is an Airwindowsized take on the waveshapers in Oxford Inflator.", airwin2rack::Inflamer::kNumParameters, []() { return std::make_unique(0); }}); +int Inflamer_unused = AirwinRegistry::registerAirwindow({"Inflamer", "Subtlety", 284, "Inflamer is an Airwindowsized take on the waveshapers in Oxford Inflator.", airwin2rack::Inflamer::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Infrasonic.h" int Infrasonic_unused = AirwinRegistry::registerAirwindow({"Infrasonic", "Bass", 39, "Infrasonic is a very steep subsonic filter, built like Ultrasonic.", airwin2rack::Infrasonic::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Interstage.h" -int Interstage_unused = AirwinRegistry::registerAirwindow({"Interstage", "Subtlety", 288, "Interstage is a subtle and sophisticated analogifier.", airwin2rack::Interstage::kNumParameters, []() { return std::make_unique(0); }}); +int Interstage_unused = AirwinRegistry::registerAirwindow({"Interstage", "Subtlety", 289, "Interstage is a subtle and sophisticated analogifier.", airwin2rack::Interstage::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/IronOxide5.h" -int IronOxide5_unused = AirwinRegistry::registerAirwindow({"IronOxide5", "Tape", 300, "IronOxide5 is the old school, heavily colored Airwindows tape emulation.", airwin2rack::IronOxide5::kNumParameters, []() { return std::make_unique(0); }}); +int IronOxide5_unused = AirwinRegistry::registerAirwindow({"IronOxide5", "Tape", 301, "IronOxide5 is the old school, heavily colored Airwindows tape emulation.", airwin2rack::IronOxide5::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/IronOxideClassic.h" -int IronOxideClassic_unused = AirwinRegistry::registerAirwindow({"IronOxideClassic", "Tape", 302, "IronOxideClassic is the purer, simpler, early form of Iron Oxide before all the features.", airwin2rack::IronOxideClassic::kNumParameters, []() { return std::make_unique(0); }}); +int IronOxideClassic_unused = AirwinRegistry::registerAirwindow({"IronOxideClassic", "Tape", 303, "IronOxideClassic is the purer, simpler, early form of Iron Oxide before all the features.", airwin2rack::IronOxideClassic::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/IronOxideClassic2.h" -int IronOxideClassic2_unused = AirwinRegistry::registerAirwindow({"IronOxideClassic2", "Tape", 299, "IronOxideClassic2 is my bandpassy tape sim, updated for high sample rate and aliasing control.", airwin2rack::IronOxideClassic2::kNumParameters, []() { return std::make_unique(0); }}); +int IronOxideClassic2_unused = AirwinRegistry::registerAirwindow({"IronOxideClassic2", "Tape", 300, "IronOxideClassic2 is my bandpassy tape sim, updated for high sample rate and aliasing control.", airwin2rack::IronOxideClassic2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Isolator.h" -int Isolator_unused = AirwinRegistry::registerAirwindow({"Isolator", "Filter", 211, "Isolator is a steep highpass or lowpass filter, like you might find in a speaker crossover.", airwin2rack::Isolator::kNumParameters, []() { return std::make_unique(0); }}); +int Isolator_unused = AirwinRegistry::registerAirwindow({"Isolator", "Filter", 212, "Isolator is a steep highpass or lowpass filter, like you might find in a speaker crossover.", airwin2rack::Isolator::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Isolator2.h" -int Isolator2_unused = AirwinRegistry::registerAirwindow({"Isolator2", "Filter", 200, "Isolator2 is Isolator, but with control smoothing and a new resonance booster.", airwin2rack::Isolator2::kNumParameters, []() { return std::make_unique(0); }}); +int Isolator2_unused = AirwinRegistry::registerAirwindow({"Isolator2", "Filter", 201, "Isolator2 is Isolator, but with control smoothing and a new resonance booster.", airwin2rack::Isolator2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/LRFlipTimer.h" -int LRFlipTimer_unused = AirwinRegistry::registerAirwindow({"LRFlipTimer", "Stereo", 278, "LRFlipTimer is a utility that swaps Left with Right every few (1-10) minutes.", airwin2rack::LRFlipTimer::kNumParameters, []() { return std::make_unique(0); }}); +int LRFlipTimer_unused = AirwinRegistry::registerAirwindow({"LRFlipTimer", "Stereo", 279, "LRFlipTimer is a utility that swaps Left with Right every few (1-10) minutes.", airwin2rack::LRFlipTimer::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/LeadAmp.h" int LeadAmp_unused = AirwinRegistry::registerAirwindow({"LeadAmp", "Amp Sims", 26, "LeadAmp is an amp sim with a clear, penetrating, vocal tone.", airwin2rack::LeadAmp::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/LeftoMono.h" -int LeftoMono_unused = AirwinRegistry::registerAirwindow({"LeftoMono", "Utility", 337, "LeftoMono copies one channel to both, losslessly.", airwin2rack::LeftoMono::kNumParameters, []() { return std::make_unique(0); }}); +int LeftoMono_unused = AirwinRegistry::registerAirwindow({"LeftoMono", "Utility", 338, "LeftoMono copies one channel to both, losslessly.", airwin2rack::LeftoMono::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/LilAmp.h" int LilAmp_unused = AirwinRegistry::registerAirwindow({"LilAmp", "Amp Sims", 27, "LilAmp is a tiny amp sim, like a little bitty practice amp without that much gain.", airwin2rack::LilAmp::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Logical4.h" @@ -379,53 +381,53 @@ int Logical4_unused = AirwinRegistry::registerAirwindow({"Logical4", "Dynamics", #include "autogen_airwin/Loud.h" int Loud_unused = AirwinRegistry::registerAirwindow({"Loud", "Distortion", 120, "Loud is distortion and demolition of air molecules, modeled.", airwin2rack::Loud::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Lowpass.h" -int Lowpass_unused = AirwinRegistry::registerAirwindow({"Lowpass", "Filter", 218, "Lowpass deepens the tone, leaves a gloss and textural modifications.", airwin2rack::Lowpass::kNumParameters, []() { return std::make_unique(0); }}); +int Lowpass_unused = AirwinRegistry::registerAirwindow({"Lowpass", "Filter", 219, "Lowpass deepens the tone, leaves a gloss and textural modifications.", airwin2rack::Lowpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Lowpass2.h" -int Lowpass2_unused = AirwinRegistry::registerAirwindow({"Lowpass2", "Filter", 214, "Lowpass2 is an unusual-sounding variable-slope lowpass filter.", airwin2rack::Lowpass2::kNumParameters, []() { return std::make_unique(0); }}); +int Lowpass2_unused = AirwinRegistry::registerAirwindow({"Lowpass2", "Filter", 215, "Lowpass2 is an unusual-sounding variable-slope lowpass filter.", airwin2rack::Lowpass2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Luxor.h" -int Luxor_unused = AirwinRegistry::registerAirwindow({"Luxor", "Tone Color", 312, "Luxor is a re-release of another old Character plugin.", airwin2rack::Luxor::kNumParameters, []() { return std::make_unique(0); }}); +int Luxor_unused = AirwinRegistry::registerAirwindow({"Luxor", "Tone Color", 313, "Luxor is a re-release of another old Character plugin.", airwin2rack::Luxor::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/MV.h" int MV_unused = AirwinRegistry::registerAirwindow({"MV", "Ambience", 8, "MV is a dual-mono reverb based on BitShiftGain and the old Midiverbs.", airwin2rack::MV::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/MV2.h" int MV2_unused = AirwinRegistry::registerAirwindow({"MV2", "Ambience", 7, "MV2 is a dual-mono reverb based on BitShiftGain and the old Midiverbs, adapted to high sample rates.", airwin2rack::MV2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/MackEQ.h" -int MackEQ_unused = AirwinRegistry::registerAirwindow({"MackEQ", "Filter", 206, "MackEQ is the Mackie distortion but with treble and bass controls added.", airwin2rack::MackEQ::kNumParameters, []() { return std::make_unique(0); }}); +int MackEQ_unused = AirwinRegistry::registerAirwindow({"MackEQ", "Filter", 207, "MackEQ is the Mackie distortion but with treble and bass controls added.", airwin2rack::MackEQ::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Mackity.h" int Mackity_unused = AirwinRegistry::registerAirwindow({"Mackity", "Distortion", 116, "Mackity is an emulation of the input stage of a vintage Mackie 1202!", airwin2rack::Mackity::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/MatrixVerb.h" -int MatrixVerb_unused = AirwinRegistry::registerAirwindow({"MatrixVerb", "Reverb", 255, "MatrixVerb is a wildly adjustable, strangely colorful reverb for deep and flexible spaces.", airwin2rack::MatrixVerb::kNumParameters, []() { return std::make_unique(0); }}); +int MatrixVerb_unused = AirwinRegistry::registerAirwindow({"MatrixVerb", "Reverb", 256, "MatrixVerb is a wildly adjustable, strangely colorful reverb for deep and flexible spaces.", airwin2rack::MatrixVerb::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Melt.h" int Melt_unused = AirwinRegistry::registerAirwindow({"Melt", "Ambience", 6, "Melt is a wobbly chorusy weird diffuse effect.", airwin2rack::Melt::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/MidAmp.h" int MidAmp_unused = AirwinRegistry::registerAirwindow({"MidAmp", "Amp Sims", 28, "MidAmp is a clean amp sim meant to work like a loud Twin or something of that nature.", airwin2rack::MidAmp::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/MidSide.h" -int MidSide_unused = AirwinRegistry::registerAirwindow({"MidSide", "Utility", 333, "MidSide is the other side of the EdIsDim mid/side conversion utility plugin.", airwin2rack::MidSide::kNumParameters, []() { return std::make_unique(0); }}); +int MidSide_unused = AirwinRegistry::registerAirwindow({"MidSide", "Utility", 334, "MidSide is the other side of the EdIsDim mid/side conversion utility plugin.", airwin2rack::MidSide::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/MoNoam.h" -int MoNoam_unused = AirwinRegistry::registerAirwindow({"MoNoam", "Utility", 340, "MoNoam gives you variations on mono, mid, and side in different channels.", airwin2rack::MoNoam::kNumParameters, []() { return std::make_unique(0); }}); +int MoNoam_unused = AirwinRegistry::registerAirwindow({"MoNoam", "Utility", 341, "MoNoam gives you variations on mono, mid, and side in different channels.", airwin2rack::MoNoam::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Mojo.h" -int Mojo_unused = AirwinRegistry::registerAirwindow({"Mojo", "Saturation", 266, "Mojo is a biggenator that also works as a loudenator.", airwin2rack::Mojo::kNumParameters, []() { return std::make_unique(0); }}); +int Mojo_unused = AirwinRegistry::registerAirwindow({"Mojo", "Saturation", 267, "Mojo is a biggenator that also works as a loudenator.", airwin2rack::Mojo::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Monitoring.h" -int Monitoring_unused = AirwinRegistry::registerAirwindow({"Monitoring", "Utility", 320, "Monitoring is your one-stop shop for final 2-buss work!", airwin2rack::Monitoring::kNumParameters, []() { return std::make_unique(0); }}); +int Monitoring_unused = AirwinRegistry::registerAirwindow({"Monitoring", "Utility", 321, "Monitoring is your one-stop shop for final 2-buss work!", airwin2rack::Monitoring::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Monitoring2.h" -int Monitoring2_unused = AirwinRegistry::registerAirwindow({"Monitoring2", "Utility", 319, "Monitoring2 is Monitoring, but with Dark as the wordlength reducer.", airwin2rack::Monitoring2::kNumParameters, []() { return std::make_unique(0); }}); +int Monitoring2_unused = AirwinRegistry::registerAirwindow({"Monitoring2", "Utility", 320, "Monitoring2 is Monitoring, but with Dark as the wordlength reducer.", airwin2rack::Monitoring2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Monitoring3.h" -int Monitoring3_unused = AirwinRegistry::registerAirwindow({"Monitoring3", "Utility", 318, "Monitoring3 is Monitoring, but with Ten Nines into Dark as the wordlength reducer.", airwin2rack::Monitoring3::kNumParameters, []() { return std::make_unique(0); }}); +int Monitoring3_unused = AirwinRegistry::registerAirwindow({"Monitoring3", "Utility", 319, "Monitoring3 is Monitoring, but with Ten Nines into Dark as the wordlength reducer.", airwin2rack::Monitoring3::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/MultiBandDistortion.h" int MultiBandDistortion_unused = AirwinRegistry::registerAirwindow({"MultiBandDistortion", "Distortion", 123, "MultiBandDistortion is an old weird gnarly sound wrecker :)", airwin2rack::MultiBandDistortion::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/NCSeventeen.h" -int NCSeventeen_unused = AirwinRegistry::registerAirwindow({"NCSeventeen", "Saturation", 260, "NCSeventeen is Dirty Loud!", airwin2rack::NCSeventeen::kNumParameters, []() { return std::make_unique(0); }}); +int NCSeventeen_unused = AirwinRegistry::registerAirwindow({"NCSeventeen", "Saturation", 261, "NCSeventeen is Dirty Loud!", airwin2rack::NCSeventeen::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/NaturalizeDither.h" int NaturalizeDither_unused = AirwinRegistry::registerAirwindow({"NaturalizeDither", "Dithers", 144, "NaturalizeDither is deterministic dither that uses Benford Realness calculations for each sample.", airwin2rack::NaturalizeDither::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Neverland.h" -int Neverland_unused = AirwinRegistry::registerAirwindow({"Neverland", "Tone Color", 306, "Neverland is a re-release of my old Neve-style color adder, exacly as it was.", airwin2rack::Neverland::kNumParameters, []() { return std::make_unique(0); }}); +int Neverland_unused = AirwinRegistry::registerAirwindow({"Neverland", "Tone Color", 307, "Neverland is a re-release of my old Neve-style color adder, exacly as it was.", airwin2rack::Neverland::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Nikola.h" int Nikola_unused = AirwinRegistry::registerAirwindow({"Nikola", "Effects", 193, "Nikola is an Audio Tesla Coil plugin! Note: audio tesla coils don't sound nice.", airwin2rack::Nikola::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/NodeDither.h" int NodeDither_unused = AirwinRegistry::registerAirwindow({"NodeDither", "Dithers", 138, "NodeDither is adjusta-TPDF-dither, like a dither flanger. Can do Paul and Tape settings.", airwin2rack::NodeDither::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Noise.h" -int Noise_unused = AirwinRegistry::registerAirwindow({"Noise", "Noise", 234, "Noise is the Airwindows deep noise oscillator, as a sound reinforcer.", airwin2rack::Noise::kNumParameters, []() { return std::make_unique(0); }}); +int Noise_unused = AirwinRegistry::registerAirwindow({"Noise", "Noise", 235, "Noise is the Airwindows deep noise oscillator, as a sound reinforcer.", airwin2rack::Noise::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/NonlinearSpace.h" -int NonlinearSpace_unused = AirwinRegistry::registerAirwindow({"NonlinearSpace", "Reverb", 253, "NonlinearSpace is a flexible reverb plugin.", airwin2rack::NonlinearSpace::kNumParameters, []() { return std::make_unique(0); }}); +int NonlinearSpace_unused = AirwinRegistry::registerAirwindow({"NonlinearSpace", "Reverb", 254, "NonlinearSpace is a flexible reverb plugin.", airwin2rack::NonlinearSpace::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/NotJustAnotherCD.h" int NotJustAnotherCD_unused = AirwinRegistry::registerAirwindow({"NotJustAnotherCD", "Dithers", 130, "NotJustAnotherCD is a next-gen wordlength reducers for 16 bit with DeRez.", airwin2rack::NotJustAnotherCD::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/NotJustAnotherDither.h" @@ -447,11 +449,11 @@ int PaulDither_unused = AirwinRegistry::registerAirwindow({"PaulDither", "Dither #include "autogen_airwin/PaulWide.h" int PaulWide_unused = AirwinRegistry::registerAirwindow({"PaulWide", "Dithers", 125, "PaulWide is a highpassed TPDF wide dither. (quieter, airier AND wider)", airwin2rack::PaulWide::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PeaksOnly.h" -int PeaksOnly_unused = AirwinRegistry::registerAirwindow({"PeaksOnly", "Utility", 329, "PeaksOnly is a transformative mix check tool.", airwin2rack::PeaksOnly::kNumParameters, []() { return std::make_unique(0); }}); +int PeaksOnly_unused = AirwinRegistry::registerAirwindow({"PeaksOnly", "Utility", 330, "PeaksOnly is a transformative mix check tool.", airwin2rack::PeaksOnly::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Pear.h" int Pear_unused = AirwinRegistry::registerAirwindow({"Pear", "Filter", 196, "Pear is the testbed for a new filter, implemented as a highpass/lowpass shelf.", airwin2rack::Pear::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PhaseNudge.h" -int PhaseNudge_unused = AirwinRegistry::registerAirwindow({"PhaseNudge", "Subtlety", 289, "PhaseNudge is a phase rotator/allpass filter.", airwin2rack::PhaseNudge::kNumParameters, []() { return std::make_unique(0); }}); +int PhaseNudge_unused = AirwinRegistry::registerAirwindow({"PhaseNudge", "Subtlety", 290, "PhaseNudge is a phase rotator/allpass filter.", airwin2rack::PhaseNudge::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PitchDelay.h" int PitchDelay_unused = AirwinRegistry::registerAirwindow({"PitchDelay", "Ambience", 2, "PitchDelay is TapeDelay2 but with pitch shift instead of flutter.", airwin2rack::PitchDelay::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PitchNasty.h" @@ -459,11 +461,11 @@ int PitchNasty_unused = AirwinRegistry::registerAirwindow({"PitchNasty", "Effect #include "autogen_airwin/PlatinumSlew.h" int PlatinumSlew_unused = AirwinRegistry::registerAirwindow({"PlatinumSlew", "Brightness", 47, "PlatinumSlew is the best easy-to-use slew clipper.", airwin2rack::PlatinumSlew::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PocketVerbs.h" -int PocketVerbs_unused = AirwinRegistry::registerAirwindow({"PocketVerbs", "Reverb", 256, "PocketVerbs is my popular old special effects reverbs plugin!", airwin2rack::PocketVerbs::kNumParameters, []() { return std::make_unique(0); }}); +int PocketVerbs_unused = AirwinRegistry::registerAirwindow({"PocketVerbs", "Reverb", 257, "PocketVerbs is my popular old special effects reverbs plugin!", airwin2rack::PocketVerbs::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Pockey.h" -int Pockey_unused = AirwinRegistry::registerAirwindow({"Pockey", "Lo-Fi", 224, "Pockey is 12 bit (and under) lo-fi hiphop in a plugin.", airwin2rack::Pockey::kNumParameters, []() { return std::make_unique(0); }}); +int Pockey_unused = AirwinRegistry::registerAirwindow({"Pockey", "Lo-Fi", 225, "Pockey is 12 bit (and under) lo-fi hiphop in a plugin.", airwin2rack::Pockey::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Pockey2.h" -int Pockey2_unused = AirwinRegistry::registerAirwindow({"Pockey2", "Lo-Fi", 220, "Pockey2 is more efficient, more intense lo-fi hiphop in a plugin.", airwin2rack::Pockey2::kNumParameters, []() { return std::make_unique(0); }}); +int Pockey2_unused = AirwinRegistry::registerAirwindow({"Pockey2", "Lo-Fi", 221, "Pockey2 is more efficient, more intense lo-fi hiphop in a plugin.", airwin2rack::Pockey2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Podcast.h" int Podcast_unused = AirwinRegistry::registerAirwindow({"Podcast", "Dynamics", 168, "Podcast is a simpler pile of curve-style compressors with hard clipping.", airwin2rack::Podcast::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PodcastDeluxe.h" @@ -479,7 +481,7 @@ int PowerSag_unused = AirwinRegistry::registerAirwindow({"PowerSag", "Effects", #include "autogen_airwin/PowerSag2.h" int PowerSag2_unused = AirwinRegistry::registerAirwindow({"PowerSag2", "Effects", 190, "PowerSag2 is my improved circuit-starve plugin, now with inverse effect!", airwin2rack::PowerSag2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Precious.h" -int Precious_unused = AirwinRegistry::registerAirwindow({"Precious", "Tone Color", 311, "Precious is a re-release of another old Character plugin.", airwin2rack::Precious::kNumParameters, []() { return std::make_unique(0); }}); +int Precious_unused = AirwinRegistry::registerAirwindow({"Precious", "Tone Color", 312, "Precious is a re-release of another old Character plugin.", airwin2rack::Precious::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Preponderant.h" int Preponderant_unused = AirwinRegistry::registerAirwindow({"Preponderant", "Effects", 192, "Preponderant is Airwindows Anti-Soothe, a strange tone intensifier and balancer.", airwin2rack::Preponderant::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Pressure4.h" @@ -501,19 +503,19 @@ int PurestConsoleBuss_unused = AirwinRegistry::registerAirwindow({"PurestConsole #include "autogen_airwin/PurestConsoleChannel.h" int PurestConsoleChannel_unused = AirwinRegistry::registerAirwindow({"PurestConsoleChannel", "Consoles", 97, "PurestConsoleChannel is the most free from coloration Console system.", airwin2rack::PurestConsoleChannel::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PurestDrive.h" -int PurestDrive_unused = AirwinRegistry::registerAirwindow({"PurestDrive", "Saturation", 264, "PurestDrive is the magic saturation plugin of subtlety and French House tone.", airwin2rack::PurestDrive::kNumParameters, []() { return std::make_unique(0); }}); +int PurestDrive_unused = AirwinRegistry::registerAirwindow({"PurestDrive", "Saturation", 265, "PurestDrive is the magic saturation plugin of subtlety and French House tone.", airwin2rack::PurestDrive::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PurestEcho.h" int PurestEcho_unused = AirwinRegistry::registerAirwindow({"PurestEcho", "Ambience", 12, "PurestEcho is optimized Airwindows echo with exactly four evenly spaced taps on tap.", airwin2rack::PurestEcho::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PurestFade.h" -int PurestFade_unused = AirwinRegistry::registerAirwindow({"PurestFade", "Utility", 324, "PurestFade is just like PurestGain, but for LONG fades.", airwin2rack::PurestFade::kNumParameters, []() { return std::make_unique(0); }}); +int PurestFade_unused = AirwinRegistry::registerAirwindow({"PurestFade", "Utility", 325, "PurestFade is just like PurestGain, but for LONG fades.", airwin2rack::PurestFade::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PurestGain.h" -int PurestGain_unused = AirwinRegistry::registerAirwindow({"PurestGain", "Utility", 323, "PurestGain is a high-res noise shaped gain, with smoothed fader.", airwin2rack::PurestGain::kNumParameters, []() { return std::make_unique(0); }}); +int PurestGain_unused = AirwinRegistry::registerAirwindow({"PurestGain", "Utility", 324, "PurestGain is a high-res noise shaped gain, with smoothed fader.", airwin2rack::PurestGain::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PurestSquish.h" int PurestSquish_unused = AirwinRegistry::registerAirwindow({"PurestSquish", "Dynamics", 170, "PurestSquish is an open-sounding compressor with bass bloom.", airwin2rack::PurestSquish::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PurestWarm.h" -int PurestWarm_unused = AirwinRegistry::registerAirwindow({"PurestWarm", "Subtlety", 286, "PurestWarm is a subtle tone shaper and warmth adder.", airwin2rack::PurestWarm::kNumParameters, []() { return std::make_unique(0); }}); +int PurestWarm_unused = AirwinRegistry::registerAirwindow({"PurestWarm", "Subtlety", 287, "PurestWarm is a subtle tone shaper and warmth adder.", airwin2rack::PurestWarm::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/PurestWarm2.h" -int PurestWarm2_unused = AirwinRegistry::registerAirwindow({"PurestWarm2", "Subtlety", 285, "PurestWarm2 adds dual dry/wet controls for each side of the waveform.", airwin2rack::PurestWarm2::kNumParameters, []() { return std::make_unique(0); }}); +int PurestWarm2_unused = AirwinRegistry::registerAirwindow({"PurestWarm2", "Subtlety", 286, "PurestWarm2 adds dual dry/wet controls for each side of the waveform.", airwin2rack::PurestWarm2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Pyewacket.h" int Pyewacket_unused = AirwinRegistry::registerAirwindow({"Pyewacket", "Dynamics", 157, "Pyewacket is an old school compressor for high definition transients. Adds no fatness, just energy.", airwin2rack::Pyewacket::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/RawGlitters.h" @@ -523,27 +525,29 @@ int RawTimbers_unused = AirwinRegistry::registerAirwindow({"RawTimbers", "Dither #include "autogen_airwin/Recurve.h" int Recurve_unused = AirwinRegistry::registerAirwindow({"Recurve", "Dynamics", 156, "Recurve is a special buss compressor with no threshold point.", airwin2rack::Recurve::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Remap.h" -int Remap_unused = AirwinRegistry::registerAirwindow({"Remap", "Subtlety", 290, "Remap puts the guts back into overloudenated audio!", airwin2rack::Remap::kNumParameters, []() { return std::make_unique(0); }}); +int Remap_unused = AirwinRegistry::registerAirwindow({"Remap", "Subtlety", 291, "Remap puts the guts back into overloudenated audio!", airwin2rack::Remap::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ResEQ.h" -int ResEQ_unused = AirwinRegistry::registerAirwindow({"ResEQ", "Filter", 213, "ResEQ is a bank of mostly midrange resonances.", airwin2rack::ResEQ::kNumParameters, []() { return std::make_unique(0); }}); +int ResEQ_unused = AirwinRegistry::registerAirwindow({"ResEQ", "Filter", 214, "ResEQ is a bank of mostly midrange resonances.", airwin2rack::ResEQ::kNumParameters, []() { return std::make_unique(0); }}); +#include "autogen_airwin/ResEQ2.h" +int ResEQ2_unused = AirwinRegistry::registerAirwindow({"ResEQ2", "Filter", 197, "ResEQ2 is a single, sharp, sonorous mid peak.", airwin2rack::ResEQ2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Reverb.h" -int Reverb_unused = AirwinRegistry::registerAirwindow({"Reverb", "Reverb", 257, "Reverb is simplified and tuned MatrixVerb, adjusting everything for each optimum verb size.", airwin2rack::Reverb::kNumParameters, []() { return std::make_unique(0); }}); +int Reverb_unused = AirwinRegistry::registerAirwindow({"Reverb", "Reverb", 258, "Reverb is simplified and tuned MatrixVerb, adjusting everything for each optimum verb size.", airwin2rack::Reverb::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Righteous4.h" -int Righteous4_unused = AirwinRegistry::registerAirwindow({"Righteous4", "Saturation", 271, "Righteous4 is a final output stage for targeting dynamic range.", airwin2rack::Righteous4::kNumParameters, []() { return std::make_unique(0); }}); +int Righteous4_unused = AirwinRegistry::registerAirwindow({"Righteous4", "Saturation", 272, "Righteous4 is a final output stage for targeting dynamic range.", airwin2rack::Righteous4::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/RightoMono.h" -int RightoMono_unused = AirwinRegistry::registerAirwindow({"RightoMono", "Utility", 336, "RightoMono copies one channel to both, losslessly.", airwin2rack::RightoMono::kNumParameters, []() { return std::make_unique(0); }}); +int RightoMono_unused = AirwinRegistry::registerAirwindow({"RightoMono", "Utility", 337, "RightoMono copies one channel to both, losslessly.", airwin2rack::RightoMono::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/SampleDelay.h" int SampleDelay_unused = AirwinRegistry::registerAirwindow({"SampleDelay", "Ambience", 3, "SampleDelay is three delays combined: millisecond, sample and subsample.", airwin2rack::SampleDelay::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Shape.h" -int Shape_unused = AirwinRegistry::registerAirwindow({"Shape", "Subtlety", 282, "Shape is an asymmetrical waveshaper for peak manipulating.", airwin2rack::Shape::kNumParameters, []() { return std::make_unique(0); }}); +int Shape_unused = AirwinRegistry::registerAirwindow({"Shape", "Subtlety", 283, "Shape is an asymmetrical waveshaper for peak manipulating.", airwin2rack::Shape::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/SideDull.h" -int SideDull_unused = AirwinRegistry::registerAirwindow({"SideDull", "Stereo", 280, "SideDull is like Sidepass, but a lowpass on the side channel. Treble-centerer.", airwin2rack::SideDull::kNumParameters, []() { return std::make_unique(0); }}); +int SideDull_unused = AirwinRegistry::registerAirwindow({"SideDull", "Stereo", 281, "SideDull is like Sidepass, but a lowpass on the side channel. Treble-centerer.", airwin2rack::SideDull::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Sidepass.h" -int Sidepass_unused = AirwinRegistry::registerAirwindow({"Sidepass", "Stereo", 279, "Sidepass is a simple utility plugin, a highpass on the side channel. Mono-maker.", airwin2rack::Sidepass::kNumParameters, []() { return std::make_unique(0); }}); +int Sidepass_unused = AirwinRegistry::registerAirwindow({"Sidepass", "Stereo", 280, "Sidepass is a simple utility plugin, a highpass on the side channel. Mono-maker.", airwin2rack::Sidepass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Silhouette.h" -int Silhouette_unused = AirwinRegistry::registerAirwindow({"Silhouette", "Noise", 240, "Silhouette replaces the sound with raw noise sculpted to match its dynamics.", airwin2rack::Silhouette::kNumParameters, []() { return std::make_unique(0); }}); +int Silhouette_unused = AirwinRegistry::registerAirwindow({"Silhouette", "Noise", 241, "Silhouette replaces the sound with raw noise sculpted to match its dynamics.", airwin2rack::Silhouette::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/SingleEndedTriode.h" -int SingleEndedTriode_unused = AirwinRegistry::registerAirwindow({"SingleEndedTriode", "Subtlety", 291, "SingleEndedTriode is unusual analog modeling effects.", airwin2rack::SingleEndedTriode::kNumParameters, []() { return std::make_unique(0); }}); +int SingleEndedTriode_unused = AirwinRegistry::registerAirwindow({"SingleEndedTriode", "Subtlety", 292, "SingleEndedTriode is unusual analog modeling effects.", airwin2rack::SingleEndedTriode::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Slew.h" int Slew_unused = AirwinRegistry::registerAirwindow({"Slew", "Brightness", 57, "Slew is a slew clipper, which darkens treble in an unusual way.", airwin2rack::Slew::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Slew2.h" @@ -551,7 +555,7 @@ int Slew2_unused = AirwinRegistry::registerAirwindow({"Slew2", "Brightness", 56, #include "autogen_airwin/Slew3.h" int Slew3_unused = AirwinRegistry::registerAirwindow({"Slew3", "Brightness", 55, "Slew3 is a new approach to slew clipping meant for a more analog-like darkening effect.", airwin2rack::Slew3::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/SlewOnly.h" -int SlewOnly_unused = AirwinRegistry::registerAirwindow({"SlewOnly", "Utility", 327, "SlewOnly is a mix check plugin that shows you only the extreme highs.", airwin2rack::SlewOnly::kNumParameters, []() { return std::make_unique(0); }}); +int SlewOnly_unused = AirwinRegistry::registerAirwindow({"SlewOnly", "Utility", 328, "SlewOnly is a mix check plugin that shows you only the extreme highs.", airwin2rack::SlewOnly::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/SlewSonic.h" int SlewSonic_unused = AirwinRegistry::registerAirwindow({"SlewSonic", "Brightness", 50, "SlewSonic combines SlewOnly with ultrasonic filtering to solo brightness.", airwin2rack::SlewSonic::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Smooth.h" @@ -561,13 +565,13 @@ int SoftGate_unused = AirwinRegistry::registerAirwindow({"SoftGate", "Dynamics", #include "autogen_airwin/SpatializeDither.h" int SpatializeDither_unused = AirwinRegistry::registerAirwindow({"SpatializeDither", "Dithers", 133, "SpatializeDither is a high-performance clarity and accuracy dither.", airwin2rack::SpatializeDither::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Spiral.h" -int Spiral_unused = AirwinRegistry::registerAirwindow({"Spiral", "Saturation", 268, "Spiral is the new best smoothest distortion algorithm.", airwin2rack::Spiral::kNumParameters, []() { return std::make_unique(0); }}); +int Spiral_unused = AirwinRegistry::registerAirwindow({"Spiral", "Saturation", 269, "Spiral is the new best smoothest distortion algorithm.", airwin2rack::Spiral::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Spiral2.h" -int Spiral2_unused = AirwinRegistry::registerAirwindow({"Spiral2", "Saturation", 263, "Spiral2 is Spiral with controls including Presence.", airwin2rack::Spiral2::kNumParameters, []() { return std::make_unique(0); }}); +int Spiral2_unused = AirwinRegistry::registerAirwindow({"Spiral2", "Saturation", 264, "Spiral2 is Spiral with controls including Presence.", airwin2rack::Spiral2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Srsly.h" -int Srsly_unused = AirwinRegistry::registerAirwindow({"Srsly", "Stereo", 272, "Srsly is a psychoacoustic stereo processor.", airwin2rack::Srsly::kNumParameters, []() { return std::make_unique(0); }}); +int Srsly_unused = AirwinRegistry::registerAirwindow({"Srsly", "Stereo", 273, "Srsly is a psychoacoustic stereo processor.", airwin2rack::Srsly::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Srsly2.h" -int Srsly2_unused = AirwinRegistry::registerAirwindow({"Srsly2", "Stereo", 273, "Srsly2 is a revisit of Srsly, to make the stereo widening more extreme.", airwin2rack::Srsly2::kNumParameters, []() { return std::make_unique(0); }}); +int Srsly2_unused = AirwinRegistry::registerAirwindow({"Srsly2", "Stereo", 274, "Srsly2 is a revisit of Srsly, to make the stereo widening more extreme.", airwin2rack::Srsly2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/StarChild.h" int StarChild_unused = AirwinRegistry::registerAirwindow({"StarChild", "Ambience", 15, "StarChild is a weird digital ambience/echo plugin.", airwin2rack::StarChild::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/StarChild2.h" @@ -579,19 +583,19 @@ int StereoDoubler_unused = AirwinRegistry::registerAirwindow({"StereoDoubler", " #include "autogen_airwin/StereoEnsemble.h" int StereoEnsemble_unused = AirwinRegistry::registerAirwindow({"StereoEnsemble", "Ambience", 19, "StereoEnsemble is a sort of hyperchorus blast from the past.", airwin2rack::StereoEnsemble::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/StereoFX.h" -int StereoFX_unused = AirwinRegistry::registerAirwindow({"StereoFX", "Stereo", 275, "StereoFX is an aggressive stereo widener.", airwin2rack::StereoFX::kNumParameters, []() { return std::make_unique(0); }}); +int StereoFX_unused = AirwinRegistry::registerAirwindow({"StereoFX", "Stereo", 276, "StereoFX is an aggressive stereo widener.", airwin2rack::StereoFX::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/StudioTan.h" int StudioTan_unused = AirwinRegistry::registerAirwindow({"StudioTan", "Dithers", 139, "StudioTan is all the 'non-dither' dithers, up to date and convenient.", airwin2rack::StudioTan::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/SubTight.h" -int SubTight_unused = AirwinRegistry::registerAirwindow({"SubTight", "Filter", 197, "SubTight uses a variation on the Creature algorithm to tighten sub-lows.", airwin2rack::SubTight::kNumParameters, []() { return std::make_unique(0); }}); +int SubTight_unused = AirwinRegistry::registerAirwindow({"SubTight", "Filter", 198, "SubTight uses a variation on the Creature algorithm to tighten sub-lows.", airwin2rack::SubTight::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/SubsOnly.h" -int SubsOnly_unused = AirwinRegistry::registerAirwindow({"SubsOnly", "Utility", 328, "SubsOnly is a mix check plugin that shows you only the extreme lows.", airwin2rack::SubsOnly::kNumParameters, []() { return std::make_unique(0); }}); +int SubsOnly_unused = AirwinRegistry::registerAirwindow({"SubsOnly", "Utility", 329, "SubsOnly is a mix check plugin that shows you only the extreme lows.", airwin2rack::SubsOnly::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Surge.h" int Surge_unused = AirwinRegistry::registerAirwindow({"Surge", "Dynamics", 172, "Surge is a compressor for accentuating beats and pulses.", airwin2rack::Surge::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/SurgeTide.h" int SurgeTide_unused = AirwinRegistry::registerAirwindow({"SurgeTide", "Dynamics", 173, "SurgeTide is a surge and flow dynamics plugin.", airwin2rack::SurgeTide::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Sweeten.h" -int Sweeten_unused = AirwinRegistry::registerAirwindow({"Sweeten", "Subtlety", 284, "Sweeten is where you can find super-clean second harmonic.", airwin2rack::Sweeten::kNumParameters, []() { return std::make_unique(0); }}); +int Sweeten_unused = AirwinRegistry::registerAirwindow({"Sweeten", "Subtlety", 285, "Sweeten is where you can find super-clean second harmonic.", airwin2rack::Sweeten::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Swell.h" int Swell_unused = AirwinRegistry::registerAirwindow({"Swell", "Dynamics", 169, "Swell is Dial-an-attack, like sidechaining.", airwin2rack::Swell::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/TPDFDither.h" @@ -599,7 +603,7 @@ int TPDFDither_unused = AirwinRegistry::registerAirwindow({"TPDFDither", "Dither #include "autogen_airwin/TPDFWide.h" int TPDFWide_unused = AirwinRegistry::registerAirwindow({"TPDFWide", "Dithers", 127, "TPDFWide is still TPDF dither but better and wider. With 16/24 bit output and a DeRez control.", airwin2rack::TPDFWide::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Tape.h" -int Tape_unused = AirwinRegistry::registerAirwindow({"Tape", "Tape", 298, "Tape is simplified, all-purpose tape mojo: my personal jam.", airwin2rack::Tape::kNumParameters, []() { return std::make_unique(0); }}); +int Tape_unused = AirwinRegistry::registerAirwindow({"Tape", "Tape", 299, "Tape is simplified, all-purpose tape mojo: my personal jam.", airwin2rack::Tape::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/TapeDelay.h" int TapeDelay_unused = AirwinRegistry::registerAirwindow({"TapeDelay", "Ambience", 13, "TapeDelay is an old school tape echo with pitch swerve effects.", airwin2rack::TapeDelay::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/TapeDelay2.h" @@ -607,25 +611,25 @@ int TapeDelay2_unused = AirwinRegistry::registerAirwindow({"TapeDelay2", "Ambien #include "autogen_airwin/TapeDither.h" int TapeDither_unused = AirwinRegistry::registerAirwindow({"TapeDither", "Dithers", 132, "TapeDither is TPDF dither with noise like reel-to-reel tape.", airwin2rack::TapeDither::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/TapeDust.h" -int TapeDust_unused = AirwinRegistry::registerAirwindow({"TapeDust", "Noise", 241, "TapeDust is just a special treble-erode noise, a ‘slew noise’ plugin.", airwin2rack::TapeDust::kNumParameters, []() { return std::make_unique(0); }}); +int TapeDust_unused = AirwinRegistry::registerAirwindow({"TapeDust", "Noise", 242, "TapeDust is just a special treble-erode noise, a ‘slew noise’ plugin.", airwin2rack::TapeDust::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/TapeFat.h" -int TapeFat_unused = AirwinRegistry::registerAirwindow({"TapeFat", "Filter", 212, "TapeFat is the tone control from TapeDelay.", airwin2rack::TapeFat::kNumParameters, []() { return std::make_unique(0); }}); +int TapeFat_unused = AirwinRegistry::registerAirwindow({"TapeFat", "Filter", 213, "TapeFat is the tone control from TapeDelay.", airwin2rack::TapeFat::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Texturize.h" -int Texturize_unused = AirwinRegistry::registerAirwindow({"Texturize", "Noise", 235, "Texturize is a hidden-noise plugin for adding sonic texture to things.", airwin2rack::Texturize::kNumParameters, []() { return std::make_unique(0); }}); +int Texturize_unused = AirwinRegistry::registerAirwindow({"Texturize", "Noise", 236, "Texturize is a hidden-noise plugin for adding sonic texture to things.", airwin2rack::Texturize::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/TexturizeMS.h" -int TexturizeMS_unused = AirwinRegistry::registerAirwindow({"TexturizeMS", "Noise", 236, "TexturizeMS is a hidden-noise plugin for adding mid-side sonic texture to things.", airwin2rack::TexturizeMS::kNumParameters, []() { return std::make_unique(0); }}); +int TexturizeMS_unused = AirwinRegistry::registerAirwindow({"TexturizeMS", "Noise", 237, "TexturizeMS is a hidden-noise plugin for adding mid-side sonic texture to things.", airwin2rack::TexturizeMS::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Thunder.h" int Thunder_unused = AirwinRegistry::registerAirwindow({"Thunder", "Dynamics", 160, "Thunder is a compressor that retains or exaggerates subsonic bass when you push it.", airwin2rack::Thunder::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ToTape5.h" -int ToTape5_unused = AirwinRegistry::registerAirwindow({"ToTape5", "Tape", 301, "ToTape5 is Airwindows analog tape emulation.", airwin2rack::ToTape5::kNumParameters, []() { return std::make_unique(0); }}); +int ToTape5_unused = AirwinRegistry::registerAirwindow({"ToTape5", "Tape", 302, "ToTape5 is Airwindows analog tape emulation.", airwin2rack::ToTape5::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ToTape6.h" -int ToTape6_unused = AirwinRegistry::registerAirwindow({"ToTape6", "Tape", 296, "ToTape6 is Airwindows tape emulation for 2020!", airwin2rack::ToTape6::kNumParameters, []() { return std::make_unique(0); }}); +int ToTape6_unused = AirwinRegistry::registerAirwindow({"ToTape6", "Tape", 297, "ToTape6 is Airwindows tape emulation for 2020!", airwin2rack::ToTape6::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ToVinyl4.h" -int ToVinyl4_unused = AirwinRegistry::registerAirwindow({"ToVinyl4", "Stereo", 276, "ToVinyl4 is a vinyl-mastering simulator bringing several vinyl-type colors.", airwin2rack::ToVinyl4::kNumParameters, []() { return std::make_unique(0); }}); +int ToVinyl4_unused = AirwinRegistry::registerAirwindow({"ToVinyl4", "Stereo", 277, "ToVinyl4 is a vinyl-mastering simulator bringing several vinyl-type colors.", airwin2rack::ToVinyl4::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ToneSlant.h" -int ToneSlant_unused = AirwinRegistry::registerAirwindow({"ToneSlant", "Filter", 203, "ToneSlant is a super-transparent ‘tilt EQ’ with very low Q.", airwin2rack::ToneSlant::kNumParameters, []() { return std::make_unique(0); }}); +int ToneSlant_unused = AirwinRegistry::registerAirwindow({"ToneSlant", "Filter", 204, "ToneSlant is a super-transparent ‘tilt EQ’ with very low Q.", airwin2rack::ToneSlant::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/TransDesk.h" -int TransDesk_unused = AirwinRegistry::registerAirwindow({"TransDesk", "Subtlety", 294, "TransDesk is more of a transistory, rock desk analog modeling.", airwin2rack::TransDesk::kNumParameters, []() { return std::make_unique(0); }}); +int TransDesk_unused = AirwinRegistry::registerAirwindow({"TransDesk", "Subtlety", 295, "TransDesk is more of a transistory, rock desk analog modeling.", airwin2rack::TransDesk::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/TremoSquare.h" int TremoSquare_unused = AirwinRegistry::registerAirwindow({"TremoSquare", "Effects", 181, "TremoSquare is a squarewave tremolo effect that only switches on zero crossings.", airwin2rack::TremoSquare::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Tremolo.h" @@ -633,11 +637,11 @@ int Tremolo_unused = AirwinRegistry::registerAirwindow({"Tremolo", "Effects", 18 #include "autogen_airwin/TripleSpread.h" int TripleSpread_unused = AirwinRegistry::registerAirwindow({"TripleSpread", "Ambience", 5, "TripleSpread is a stereo tripler with extra wideness and GlitchShifter processing.", airwin2rack::TripleSpread::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Tube.h" -int Tube_unused = AirwinRegistry::registerAirwindow({"Tube", "Saturation", 262, "Tube is a tube style SoundBetterIzer using a new algorithm for analog modeling!", airwin2rack::Tube::kNumParameters, []() { return std::make_unique(0); }}); +int Tube_unused = AirwinRegistry::registerAirwindow({"Tube", "Saturation", 263, "Tube is a tube style SoundBetterIzer using a new algorithm for analog modeling!", airwin2rack::Tube::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Tube2.h" -int Tube2_unused = AirwinRegistry::registerAirwindow({"Tube2", "Saturation", 261, "Tube2 extends Tube, with more sophisticated processing and input trim.", airwin2rack::Tube2::kNumParameters, []() { return std::make_unique(0); }}); +int Tube2_unused = AirwinRegistry::registerAirwindow({"Tube2", "Saturation", 262, "Tube2 extends Tube, with more sophisticated processing and input trim.", airwin2rack::Tube2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/TubeDesk.h" -int TubeDesk_unused = AirwinRegistry::registerAirwindow({"TubeDesk", "Subtlety", 295, "TubeDesk is a tube recording console type tone coloring.", airwin2rack::TubeDesk::kNumParameters, []() { return std::make_unique(0); }}); +int TubeDesk_unused = AirwinRegistry::registerAirwindow({"TubeDesk", "Subtlety", 296, "TubeDesk is a tube recording console type tone coloring.", airwin2rack::TubeDesk::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/UltrasonX.h" int UltrasonX_unused = AirwinRegistry::registerAirwindow({"UltrasonX", "Brightness", 68, "UltrasonX is a method for rolling your own Console-type systems with total control over your ultrasonic filtering.", airwin2rack::UltrasonX::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Ultrasonic.h" @@ -647,77 +651,77 @@ int UltrasonicLite_unused = AirwinRegistry::registerAirwindow({"UltrasonicLite", #include "autogen_airwin/UltrasonicMed.h" int UltrasonicMed_unused = AirwinRegistry::registerAirwindow({"UltrasonicMed", "Brightness", 67, "UltrasonicMed is two stages of supersonic filter, for using inside digital mixes.", airwin2rack::UltrasonicMed::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/UnBox.h" -int UnBox_unused = AirwinRegistry::registerAirwindow({"UnBox", "Saturation", 269, "UnBox is a distortion where only the harmonics that don't alias are allowed to distort.", airwin2rack::UnBox::kNumParameters, []() { return std::make_unique(0); }}); +int UnBox_unused = AirwinRegistry::registerAirwindow({"UnBox", "Saturation", 270, "UnBox is a distortion where only the harmonics that don't alias are allowed to distort.", airwin2rack::UnBox::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/VariMu.h" int VariMu_unused = AirwinRegistry::registerAirwindow({"VariMu", "Dynamics", 153, "VariMu is a more organic variation on Pressure (a compressor)", airwin2rack::VariMu::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Verbity.h" -int Verbity_unused = AirwinRegistry::registerAirwindow({"Verbity", "Reverb", 249, "Verbity is a dual-mono reverb, which uses feedforward reverb topology.", airwin2rack::Verbity::kNumParameters, []() { return std::make_unique(0); }}); +int Verbity_unused = AirwinRegistry::registerAirwindow({"Verbity", "Reverb", 250, "Verbity is a dual-mono reverb, which uses feedforward reverb topology.", airwin2rack::Verbity::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Verbity2.h" -int Verbity2_unused = AirwinRegistry::registerAirwindow({"Verbity2", "Reverb", 246, "Verbity2 adds stereo crossmodulation and expands Verbity's feedforward reverb topology.", airwin2rack::Verbity2::kNumParameters, []() { return std::make_unique(0); }}); +int Verbity2_unused = AirwinRegistry::registerAirwindow({"Verbity2", "Reverb", 247, "Verbity2 adds stereo crossmodulation and expands Verbity's feedforward reverb topology.", airwin2rack::Verbity2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Vibrato.h" -int Vibrato_unused = AirwinRegistry::registerAirwindow({"Vibrato", "Lo-Fi", 230, "Vibrato lets you vibrato, chorus, flange, and make odd FM noises.", airwin2rack::Vibrato::kNumParameters, []() { return std::make_unique(0); }}); +int Vibrato_unused = AirwinRegistry::registerAirwindow({"Vibrato", "Lo-Fi", 231, "Vibrato lets you vibrato, chorus, flange, and make odd FM noises.", airwin2rack::Vibrato::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/VinylDither.h" int VinylDither_unused = AirwinRegistry::registerAirwindow({"VinylDither", "Dithers", 134, "VinylDither is a high-performance dither that converts digital noise to ‘groove noise’.", airwin2rack::VinylDither::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/VoiceOfTheStarship.h" -int VoiceOfTheStarship_unused = AirwinRegistry::registerAirwindow({"VoiceOfTheStarship", "Noise", 237, "VoiceOfTheStarship is a deep noise tone source.", airwin2rack::VoiceOfTheStarship::kNumParameters, []() { return std::make_unique(0); }}); +int VoiceOfTheStarship_unused = AirwinRegistry::registerAirwindow({"VoiceOfTheStarship", "Noise", 238, "VoiceOfTheStarship is a deep noise tone source.", airwin2rack::VoiceOfTheStarship::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/VoiceTrick.h" -int VoiceTrick_unused = AirwinRegistry::registerAirwindow({"VoiceTrick", "Utility", 341, "VoiceTrick lets you record vocals while monitoring over speakers.", airwin2rack::VoiceTrick::kNumParameters, []() { return std::make_unique(0); }}); +int VoiceTrick_unused = AirwinRegistry::registerAirwindow({"VoiceTrick", "Utility", 342, "VoiceTrick lets you record vocals while monitoring over speakers.", airwin2rack::VoiceTrick::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Weight.h" -int Weight_unused = AirwinRegistry::registerAirwindow({"Weight", "Filter", 199, "Weight is a very accurate sub-bass boost based on Holt.", airwin2rack::Weight::kNumParameters, []() { return std::make_unique(0); }}); +int Weight_unused = AirwinRegistry::registerAirwindow({"Weight", "Filter", 200, "Weight is a very accurate sub-bass boost based on Holt.", airwin2rack::Weight::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/Wider.h" -int Wider_unused = AirwinRegistry::registerAirwindow({"Wider", "Stereo", 274, "Wider is Airwindows stereo space shaping.", airwin2rack::Wider::kNumParameters, []() { return std::make_unique(0); }}); +int Wider_unused = AirwinRegistry::registerAirwindow({"Wider", "Stereo", 275, "Wider is Airwindows stereo space shaping.", airwin2rack::Wider::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/XBandpass.h" -int XBandpass_unused = AirwinRegistry::registerAirwindow({"XBandpass", "XYZ Filters", 356, "XBandpass is a distorted digital EQ, inspired by retro sampler DSP.", airwin2rack::XBandpass::kNumParameters, []() { return std::make_unique(0); }}); +int XBandpass_unused = AirwinRegistry::registerAirwindow({"XBandpass", "XYZ Filters", 357, "XBandpass is a distorted digital EQ, inspired by retro sampler DSP.", airwin2rack::XBandpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/XHighpass.h" -int XHighpass_unused = AirwinRegistry::registerAirwindow({"XHighpass", "XYZ Filters", 357, "XHighpass is a distorted digital EQ, inspired by retro sampler DSP.", airwin2rack::XHighpass::kNumParameters, []() { return std::make_unique(0); }}); +int XHighpass_unused = AirwinRegistry::registerAirwindow({"XHighpass", "XYZ Filters", 358, "XHighpass is a distorted digital EQ, inspired by retro sampler DSP.", airwin2rack::XHighpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/XLowpass.h" -int XLowpass_unused = AirwinRegistry::registerAirwindow({"XLowpass", "XYZ Filters", 358, "XLowpass is a distorted digital EQ, inspired by retro sampler DSP.", airwin2rack::XLowpass::kNumParameters, []() { return std::make_unique(0); }}); +int XLowpass_unused = AirwinRegistry::registerAirwindow({"XLowpass", "XYZ Filters", 359, "XLowpass is a distorted digital EQ, inspired by retro sampler DSP.", airwin2rack::XLowpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/XNotch.h" -int XNotch_unused = AirwinRegistry::registerAirwindow({"XNotch", "XYZ Filters", 359, "XNotch is a distorted digital EQ, not as glitchy as the others.", airwin2rack::XNotch::kNumParameters, []() { return std::make_unique(0); }}); +int XNotch_unused = AirwinRegistry::registerAirwindow({"XNotch", "XYZ Filters", 360, "XNotch is a distorted digital EQ, not as glitchy as the others.", airwin2rack::XNotch::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/XRegion.h" -int XRegion_unused = AirwinRegistry::registerAirwindow({"XRegion", "XYZ Filters", 360, "XRegion is distorted staggered bandpasses, for extreme soundmangling.", airwin2rack::XRegion::kNumParameters, []() { return std::make_unique(0); }}); +int XRegion_unused = AirwinRegistry::registerAirwindow({"XRegion", "XYZ Filters", 361, "XRegion is distorted staggered bandpasses, for extreme soundmangling.", airwin2rack::XRegion::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/YBandpass.h" -int YBandpass_unused = AirwinRegistry::registerAirwindow({"YBandpass", "XYZ Filters", 352, "YBandpass is soft and smooth to nasty, edgy texture-varying filtering.", airwin2rack::YBandpass::kNumParameters, []() { return std::make_unique(0); }}); +int YBandpass_unused = AirwinRegistry::registerAirwindow({"YBandpass", "XYZ Filters", 353, "YBandpass is soft and smooth to nasty, edgy texture-varying filtering.", airwin2rack::YBandpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/YHighpass.h" -int YHighpass_unused = AirwinRegistry::registerAirwindow({"YHighpass", "XYZ Filters", 353, "YHighpass is soft and smooth to nasty, edgy texture-varying filtering.", airwin2rack::YHighpass::kNumParameters, []() { return std::make_unique(0); }}); +int YHighpass_unused = AirwinRegistry::registerAirwindow({"YHighpass", "XYZ Filters", 354, "YHighpass is soft and smooth to nasty, edgy texture-varying filtering.", airwin2rack::YHighpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/YLowpass.h" -int YLowpass_unused = AirwinRegistry::registerAirwindow({"YLowpass", "XYZ Filters", 354, "YLowpass is soft and smooth to nasty, edgy texture-varying filtering.", airwin2rack::YLowpass::kNumParameters, []() { return std::make_unique(0); }}); +int YLowpass_unused = AirwinRegistry::registerAirwindow({"YLowpass", "XYZ Filters", 355, "YLowpass is soft and smooth to nasty, edgy texture-varying filtering.", airwin2rack::YLowpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/YNotch.h" -int YNotch_unused = AirwinRegistry::registerAirwindow({"YNotch", "XYZ Filters", 355, "YNotch is soft and smooth to nasty, edgy texture-varying filtering.", airwin2rack::YNotch::kNumParameters, []() { return std::make_unique(0); }}); +int YNotch_unused = AirwinRegistry::registerAirwindow({"YNotch", "XYZ Filters", 356, "YNotch is soft and smooth to nasty, edgy texture-varying filtering.", airwin2rack::YNotch::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZBandpass.h" -int ZBandpass_unused = AirwinRegistry::registerAirwindow({"ZBandpass", "XYZ Filters", 347, "ZBandpass is a bandpass made to sound and act like the Emu e6400 Ultra bandpass.", airwin2rack::ZBandpass::kNumParameters, []() { return std::make_unique(0); }}); +int ZBandpass_unused = AirwinRegistry::registerAirwindow({"ZBandpass", "XYZ Filters", 348, "ZBandpass is a bandpass made to sound and act like the Emu e6400 Ultra bandpass.", airwin2rack::ZBandpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZBandpass2.h" -int ZBandpass2_unused = AirwinRegistry::registerAirwindow({"ZBandpass2", "XYZ Filters", 342, "ZBandpass2 acts more like the Emu e6400 Ultra bandpass in motion, with control smoothing.", airwin2rack::ZBandpass2::kNumParameters, []() { return std::make_unique(0); }}); +int ZBandpass2_unused = AirwinRegistry::registerAirwindow({"ZBandpass2", "XYZ Filters", 343, "ZBandpass2 acts more like the Emu e6400 Ultra bandpass in motion, with control smoothing.", airwin2rack::ZBandpass2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZHighpass.h" -int ZHighpass_unused = AirwinRegistry::registerAirwindow({"ZHighpass", "XYZ Filters", 348, "ZHighpass is a highpass made to sound and act like the Emu e6400 Ultra highpass.", airwin2rack::ZHighpass::kNumParameters, []() { return std::make_unique(0); }}); +int ZHighpass_unused = AirwinRegistry::registerAirwindow({"ZHighpass", "XYZ Filters", 349, "ZHighpass is a highpass made to sound and act like the Emu e6400 Ultra highpass.", airwin2rack::ZHighpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZHighpass2.h" -int ZHighpass2_unused = AirwinRegistry::registerAirwindow({"ZHighpass2", "XYZ Filters", 343, "ZHighpass2 acts more like the Emu e6400 Ultra highpass in motion, with control smoothing.", airwin2rack::ZHighpass2::kNumParameters, []() { return std::make_unique(0); }}); +int ZHighpass2_unused = AirwinRegistry::registerAirwindow({"ZHighpass2", "XYZ Filters", 344, "ZHighpass2 acts more like the Emu e6400 Ultra highpass in motion, with control smoothing.", airwin2rack::ZHighpass2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZLowpass.h" -int ZLowpass_unused = AirwinRegistry::registerAirwindow({"ZLowpass", "XYZ Filters", 349, "ZLowpass is a lowpass made to sound and act like the Emu e6400 Ultra lowpass.", airwin2rack::ZLowpass::kNumParameters, []() { return std::make_unique(0); }}); +int ZLowpass_unused = AirwinRegistry::registerAirwindow({"ZLowpass", "XYZ Filters", 350, "ZLowpass is a lowpass made to sound and act like the Emu e6400 Ultra lowpass.", airwin2rack::ZLowpass::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZLowpass2.h" -int ZLowpass2_unused = AirwinRegistry::registerAirwindow({"ZLowpass2", "XYZ Filters", 344, "ZLowpass2 acts more like the Emu e6400 Ultra lowpass in motion, with control smoothing.", airwin2rack::ZLowpass2::kNumParameters, []() { return std::make_unique(0); }}); +int ZLowpass2_unused = AirwinRegistry::registerAirwindow({"ZLowpass2", "XYZ Filters", 345, "ZLowpass2 acts more like the Emu e6400 Ultra lowpass in motion, with control smoothing.", airwin2rack::ZLowpass2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZNotch.h" -int ZNotch_unused = AirwinRegistry::registerAirwindow({"ZNotch", "XYZ Filters", 350, "ZNotch is a notch filter made to sound and act like the Emu e6400 Phaser.", airwin2rack::ZNotch::kNumParameters, []() { return std::make_unique(0); }}); +int ZNotch_unused = AirwinRegistry::registerAirwindow({"ZNotch", "XYZ Filters", 351, "ZNotch is a notch filter made to sound and act like the Emu e6400 Phaser.", airwin2rack::ZNotch::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZNotch2.h" -int ZNotch2_unused = AirwinRegistry::registerAirwindow({"ZNotch2", "XYZ Filters", 345, "ZNotch2 acts more like the Emu e6400 Ultra phaser in motion, with control smoothing.", airwin2rack::ZNotch2::kNumParameters, []() { return std::make_unique(0); }}); +int ZNotch2_unused = AirwinRegistry::registerAirwindow({"ZNotch2", "XYZ Filters", 346, "ZNotch2 acts more like the Emu e6400 Ultra phaser in motion, with control smoothing.", airwin2rack::ZNotch2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZRegion.h" -int ZRegion_unused = AirwinRegistry::registerAirwindow({"ZRegion", "XYZ Filters", 351, "ZRegion is an Emu e6400 style Airwindows Region filter.", airwin2rack::ZRegion::kNumParameters, []() { return std::make_unique(0); }}); +int ZRegion_unused = AirwinRegistry::registerAirwindow({"ZRegion", "XYZ Filters", 352, "ZRegion is an Emu e6400 style Airwindows Region filter.", airwin2rack::ZRegion::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/ZRegion2.h" -int ZRegion2_unused = AirwinRegistry::registerAirwindow({"ZRegion2", "XYZ Filters", 346, "ZRegion2 is an Emu e6400 style Airwindows Region filter, with control smoothing.", airwin2rack::ZRegion2::kNumParameters, []() { return std::make_unique(0); }}); +int ZRegion2_unused = AirwinRegistry::registerAirwindow({"ZRegion2", "XYZ Filters", 347, "ZRegion2 is an Emu e6400 style Airwindows Region filter, with control smoothing.", airwin2rack::ZRegion2::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/curve.h" int curve_unused = AirwinRegistry::registerAirwindow({"curve", "Dynamics", 155, "curve is the simplest, purest form of Recurve with no extra boosts.", airwin2rack::curve::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/kChamberAR.h" int kChamberAR_unused = AirwinRegistry::registerAirwindow({"kChamberAR", "Ambience", 10, "kChamberAR is a take on tape echo into chamber echo.", airwin2rack::kChamberAR::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/kPlateA.h" -int kPlateA_unused = AirwinRegistry::registerAirwindow({"kPlateA", "Reverb", 244, "kPlateA is a plate reverb, not unlike its namesake atop Abbey Road.", airwin2rack::kPlateA::kNumParameters, []() { return std::make_unique(0); }}); +int kPlateA_unused = AirwinRegistry::registerAirwindow({"kPlateA", "Reverb", 245, "kPlateA is a plate reverb, not unlike its namesake atop Abbey Road.", airwin2rack::kPlateA::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/kPlateB.h" -int kPlateB_unused = AirwinRegistry::registerAirwindow({"kPlateB", "Reverb", 243, "kPlateB is a plate reverb, not unlike its namesake atop Abbey Road.", airwin2rack::kPlateB::kNumParameters, []() { return std::make_unique(0); }}); +int kPlateB_unused = AirwinRegistry::registerAirwindow({"kPlateB", "Reverb", 244, "kPlateB is a plate reverb, not unlike its namesake atop Abbey Road.", airwin2rack::kPlateB::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/kPlateC.h" -int kPlateC_unused = AirwinRegistry::registerAirwindow({"kPlateC", "Reverb", 245, "kPlateC is a plate reverb, not unlike its namesake atop Abbey Road.", airwin2rack::kPlateC::kNumParameters, []() { return std::make_unique(0); }}); +int kPlateC_unused = AirwinRegistry::registerAirwindow({"kPlateC", "Reverb", 246, "kPlateC is a plate reverb, not unlike its namesake atop Abbey Road.", airwin2rack::kPlateC::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/kPlateD.h" -int kPlateD_unused = AirwinRegistry::registerAirwindow({"kPlateD", "Reverb", 242, "kPlateD is a plate reverb, not unlike its namesake atop Abbey Road.", airwin2rack::kPlateD::kNumParameters, []() { return std::make_unique(0); }}); +int kPlateD_unused = AirwinRegistry::registerAirwindow({"kPlateD", "Reverb", 243, "kPlateD is a plate reverb, not unlike its namesake atop Abbey Road.", airwin2rack::kPlateD::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/uLawDecode.h" -int uLawDecode_unused = AirwinRegistry::registerAirwindow({"uLawDecode", "Utility", 335, "uLawDecode is a Console-like encode/decode pair, but much more extreme.", airwin2rack::uLawDecode::kNumParameters, []() { return std::make_unique(0); }}); +int uLawDecode_unused = AirwinRegistry::registerAirwindow({"uLawDecode", "Utility", 336, "uLawDecode is a Console-like encode/decode pair, but much more extreme.", airwin2rack::uLawDecode::kNumParameters, []() { return std::make_unique(0); }}); #include "autogen_airwin/uLawEncode.h" -int uLawEncode_unused = AirwinRegistry::registerAirwindow({"uLawEncode", "Utility", 334, "uLawEncode is a Console-like encode/decode pair, but much more extreme.", airwin2rack::uLawEncode::kNumParameters, []() { return std::make_unique(0); }}); +int uLawEncode_unused = AirwinRegistry::registerAirwindow({"uLawEncode", "Utility", 335, "uLawEncode is a Console-like encode/decode pair, but much more extreme.", airwin2rack::uLawEncode::kNumParameters, []() { return std::make_unique(0); }}); int unusedComplete = AirwinRegistry::completeRegistry(); diff --git a/src/autogen_airwin/CMakeLists.txt b/src/autogen_airwin/CMakeLists.txt index f58ac2c..ee21784 100644 --- a/src/autogen_airwin/CMakeLists.txt +++ b/src/autogen_airwin/CMakeLists.txt @@ -183,6 +183,8 @@ set(AIRWIN_SOURCES src/autogen_airwin/Console8SubOutProc.cpp src/autogen_airwin/Creature.cpp src/autogen_airwin/CreatureProc.cpp + src/autogen_airwin/CrickBass.cpp + src/autogen_airwin/CrickBassProc.cpp src/autogen_airwin/CrunchyGrooveWear.cpp src/autogen_airwin/CrunchyGrooveWearProc.cpp src/autogen_airwin/Crystal.cpp @@ -527,6 +529,8 @@ set(AIRWIN_SOURCES src/autogen_airwin/RemapProc.cpp src/autogen_airwin/ResEQ.cpp src/autogen_airwin/ResEQProc.cpp + src/autogen_airwin/ResEQ2.cpp + src/autogen_airwin/ResEQ2Proc.cpp src/autogen_airwin/Reverb.cpp src/autogen_airwin/ReverbProc.cpp src/autogen_airwin/Righteous4.cpp diff --git a/src/autogen_airwin/CrickBass.cpp b/src/autogen_airwin/CrickBass.cpp new file mode 100644 index 0000000..5e297e6 --- /dev/null +++ b/src/autogen_airwin/CrickBass.cpp @@ -0,0 +1,187 @@ +/* ======================================== + * CrickBass - CrickBass.h + * Copyright (c) airwindows, Airwindows uses the MIT license + * ======================================== */ + +#ifndef __CrickBass_H +#include "CrickBass.h" +#endif +namespace airwin2rack::CrickBass { + +AudioEffect* createEffectInstance(audioMasterCallback audioMaster) {return new CrickBass(audioMaster);} + +CrickBass::CrickBass(audioMasterCallback audioMaster) : + AudioEffectX(audioMaster, kNumPrograms, kNumParameters) +{ + A = 0.5; + B = 0.5; + + lastASampleL = 0.0; + lastSlewL = 0.0; + iirSampleAL = 0.0; + iirSampleBL = 0.0; + iirSampleCL = 0.0; + iirSampleDL = 0.0; + iirSampleEL = 0.0; + iirSampleFL = 0.0; + iirSampleGL = 0.0; + iirSampleHL = 0.0; + iirSampleIL = 0.0; + iirSampleJL = 0.0; + + lastASampleR = 0.0; + lastSlewR = 0.0; + iirSampleAR = 0.0; + iirSampleBR = 0.0; + iirSampleCR = 0.0; + iirSampleDR = 0.0; + iirSampleER = 0.0; + OddAR = 0.0; + OddBR = 0.0; + OddCR = 0.0; + OddDR = 0.0; + OddER = 0.0; + EvenAR = 0.0; + EvenBR = 0.0; + EvenCR = 0.0; + EvenDR = 0.0; + EvenER = 0.0; + + for (int fcount = 0; fcount < 257; fcount++) { + OddL[fcount] = 0.0; + EvenL[fcount] = 0.0; + } + + count = 0; + flip = false; //amp + + for(int fcount = 0; fcount < 90; fcount++) { + bL[fcount] = 0; + bR[fcount] = 0; + } + smoothCabAL = 0.0; smoothCabBL = 0.0; lastCabSampleL = 0.0; //cab + smoothCabAR = 0.0; smoothCabBR = 0.0; lastCabSampleR = 0.0; //cab + + for (int fcount = 0; fcount < 9; fcount++) { + lastRefL[fcount] = 0.0; + lastRefR[fcount] = 0.0; + } + cycle = 0; //undersampling + + for (int x = 0; x < fix_total; x++) { + fixA[x] = 0.0; + fixB[x] = 0.0; + fixC[x] = 0.0; + fixD[x] = 0.0; + fixE[x] = 0.0; + fixF[x] = 0.0; + } //filtering + + lastSampleR = 0.0; + wasPosClipR = false; + wasNegClipR = false; + for (int x = 0; x < 16; x++) intermediateR[x] = 0.0; + + fpdL = 1.0; while (fpdL < 16386) fpdL = rand()*UINT32_MAX; + fpdR = 1.0; while (fpdR < 16386) fpdR = rand()*UINT32_MAX; + //this is reset: values being initialized only once. Startup values, whatever they are. + + _canDo.insert("plugAsChannelInsert"); // plug-in can be used as a channel insert effect. + _canDo.insert("plugAsSend"); // plug-in can be used as a send effect. + _canDo.insert("x2in2out"); + setNumInputs(kNumInputs); + setNumOutputs(kNumOutputs); + setUniqueID(kUniqueId); + canProcessReplacing(); // supports output replacing + canDoubleReplacing(); // supports double precision processing + programsAreChunks(true); + vst_strncpy (_programName, "Default", kVstMaxProgNameLen); // default program name +} + +CrickBass::~CrickBass() {} +VstInt32 CrickBass::getVendorVersion () {return 1000;} +void CrickBass::setProgramName(char *name) {vst_strncpy (_programName, name, kVstMaxProgNameLen);} +void CrickBass::getProgramName(char *name) {vst_strncpy (name, _programName, kVstMaxProgNameLen);} +//airwindows likes to ignore this stuff. Make your own programs, and make a different plugin rather than +//trying to do versioning and preventing people from using older versions. Maybe they like the old one! + +static float pinParameter(float data) +{ + if (data < 0.0f) return 0.0f; + if (data > 1.0f) return 1.0f; + return data; +} + +void CrickBass::setParameter(VstInt32 index, float value) { + switch (index) { + case kParamA: A = value; break; + case kParamB: B = value; break; + default: break; // unknown parameter, shouldn't happen! + } +} + +float CrickBass::getParameter(VstInt32 index) { + switch (index) { + case kParamA: return A; break; + case kParamB: return B; break; + default: break; // unknown parameter, shouldn't happen! + } return 0.0; //we only need to update the relevant name, this is simple to manage +} + +void CrickBass::getParameterName(VstInt32 index, char *text) { + switch (index) { + case kParamA: vst_strncpy (text, "Drive", kVstMaxParamStrLen); break; + case kParamB: vst_strncpy (text, "Tone", kVstMaxParamStrLen); break; + default: break; // unknown parameter, shouldn't happen! + } //this is our labels for displaying in the VST host +} + +void CrickBass::getParameterDisplay(VstInt32 index, char *text) { + switch (index) { + case kParamA: float2string (A, text, kVstMaxParamStrLen); break; + case kParamB: float2string (B, text, kVstMaxParamStrLen); break; + default: break; // unknown parameter, shouldn't happen! + } //this displays the values and handles 'popups' where it's discrete choices +} + +void CrickBass::getParameterLabel(VstInt32 index, char *text) { + switch (index) { + case kParamA: vst_strncpy (text, "", kVstMaxParamStrLen); break; + case kParamB: vst_strncpy (text, "", kVstMaxParamStrLen); break; + default: break; // unknown parameter, shouldn't happen! + } +} + +VstInt32 CrickBass::canDo(char *text) +{ return (_canDo.find(text) == _canDo.end()) ? -1: 1; } // 1 = yes, -1 = no, 0 = don't know + +bool CrickBass::getEffectName(char* name) { + vst_strncpy(name, "CrickBass", kVstMaxProductStrLen); return true; +} + +VstPlugCategory CrickBass::getPlugCategory() {return kPlugCategEffect;} + +bool CrickBass::getProductString(char* text) { + vst_strncpy (text, "airwindows CrickBass", kVstMaxProductStrLen); return true; +} + +bool CrickBass::getVendorString(char* text) { + vst_strncpy (text, "airwindows", kVstMaxVendorStrLen); return true; +} +bool CrickBass::parameterTextToValue(VstInt32 index, const char *text, float &value) { + switch(index) { + case kParamA: { auto b = string2float(text, value); return b; break; } + case kParamB: { auto b = string2float(text, value); return b; break; } + + } + return false; +} +bool CrickBass::canConvertParameterTextToValue(VstInt32 index) { + switch(index) { + case kParamA: return true; + case kParamB: return true; + + } + return false; +} +} // end namespace diff --git a/src/autogen_airwin/CrickBass.h b/src/autogen_airwin/CrickBass.h new file mode 100644 index 0000000..d725456 --- /dev/null +++ b/src/autogen_airwin/CrickBass.h @@ -0,0 +1,145 @@ +/* ======================================== + * CrickBass - CrickBass.h + * Created 8/12/11 by SPIAdmin + * Copyright (c) Airwindows, Airwindows uses the MIT license + * ======================================== */ + +#ifndef __CrickBass_CrickBass_H +#define __CrickBass_CrickBass_H + +#ifndef __audioeffect__ +#include "../airwin2rackbase.h" +#endif + +#include +#include +#include + +namespace airwin2rack::CrickBass { +enum { + kParamA = 0, + kParamB = 1, + kNumParameters = 2 +}; // + +const int kNumPrograms = 0; +const int kNumInputs = 2; +const int kNumOutputs = 2; +const unsigned long kUniqueId = 'crik'; //Change this to what the AU identity is! + +class CrickBass : + public AudioEffectX +{ +public: + CrickBass(audioMasterCallback audioMaster); + ~CrickBass(); + virtual bool getEffectName(char* name); // The plug-in name + virtual VstPlugCategory getPlugCategory(); // The general category for the plug-in + virtual bool getProductString(char* text); // This is a unique plug-in string provided by Steinberg + virtual bool getVendorString(char* text); // Vendor info + virtual VstInt32 getVendorVersion(); // Version number + virtual void processReplacing (float** inputs, float** outputs, VstInt32 sampleFrames); + virtual void processDoubleReplacing (double** inputs, double** outputs, VstInt32 sampleFrames); + virtual void getProgramName(char *name); // read the name from the host + virtual void setProgramName(char *name); // changes the name of the preset displayed in the host + virtual float getParameter(VstInt32 index); // get the parameter value at the specified index + virtual void setParameter(VstInt32 index, float value); // set the parameter at index to value + virtual void getParameterLabel(VstInt32 index, char *text); // label for the parameter (eg dB) + virtual void getParameterName(VstInt32 index, char *text); // name of the parameter + virtual void getParameterDisplay(VstInt32 index, char *text); // text description of the current value + // Added by the perl as inverses + virtual bool parameterTextToValue(VstInt32 index, const char *text, float &value); + virtual bool canConvertParameterTextToValue(VstInt32 index); + virtual VstInt32 canDo(char *text); +private: + char _programName[kVstMaxProgNameLen + 1]; + std::set< std::string > _canDo; + + uint32_t fpdL; + uint32_t fpdR; + //default stuff + + double lastASampleL; + double lastSlewL; + double iirSampleAL; + double iirSampleBL; + double iirSampleCL; + double iirSampleDL; + double iirSampleEL; + double iirSampleFL; + double iirSampleGL; + double iirSampleHL; + double iirSampleIL; + double iirSampleJL; + double OddL[257]; + double EvenL[257]; //amp + + double bL[90]; + double lastCabSampleL; + double smoothCabAL; + double smoothCabBL; //cab + + + double lastASampleR; + double lastSlewR; + double iirSampleAR; + double iirSampleBR; + double iirSampleCR; + double iirSampleDR; + double iirSampleER; + double OddAR; + double OddBR; + double OddCR; + double OddDR; + double OddER; + double EvenAR; + double EvenBR; + double EvenCR; + double EvenDR; + double EvenER; + + double bR[90]; + double lastCabSampleR; + double smoothCabAR; + double smoothCabBR; //cab + + + double lastRefL[10]; + double lastRefR[10]; + int cycle; //undersampling + + bool flip; + int count; //amp + + enum { + fix_freq, + fix_reso, + fix_a0, + fix_a1, + fix_a2, + fix_b1, + fix_b2, + fix_sL1, + fix_sL2, + fix_sR1, + fix_sR2, + fix_total + }; //fixed frequency biquad filter for ultrasonics, stereo + double fixA[fix_total]; + double fixB[fix_total]; + double fixC[fix_total]; + double fixD[fix_total]; + double fixE[fix_total]; + double fixF[fix_total]; //filtering + + double lastSampleR; + double intermediateR[16]; + bool wasPosClipR; + bool wasNegClipR; //ClipOnly2 + + float A; + float B; +}; + +#endif +} // end namespace diff --git a/src/autogen_airwin/CrickBassProc.cpp b/src/autogen_airwin/CrickBassProc.cpp new file mode 100644 index 0000000..e5143e3 --- /dev/null +++ b/src/autogen_airwin/CrickBassProc.cpp @@ -0,0 +1,1280 @@ +/* ======================================== + * CrickBass - CrickBass.h + * Copyright (c) airwindows, Airwindows uses the MIT license + * ======================================== */ + +#ifndef __CrickBass_H +#include "CrickBass.h" +#endif +namespace airwin2rack::CrickBass { + +void CrickBass::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 cycleEnd = floor(overallscale); + if (cycleEnd < 1) cycleEnd = 1; + if (cycleEnd > 4) cycleEnd = 4; + //this is going to be 2 for 88.1 or 96k, 3 for silly people, 4 for 176 or 192k + if (cycle > cycleEnd-1) cycle = cycleEnd-1; //sanity check + + double inputlevelL = pow(A+0.5,2); + double inputlevelH = inputlevelL*4.0; + double basstrimH = (B*0.6)+0.2; + double basstrimL = basstrimH*0.618; + + double EQL = (basstrimL/getSampleRate())*22050.0; + double EQH = (basstrimH/getSampleRate())*22050.0; + double BEQ = (0.0625/getSampleRate())*22050.0; + + int diagonal = (int)(0.000861678*getSampleRate()); + if (diagonal > 127) diagonal = 127; + int side = (int)(diagonal/1.4142135623730951); + int down = (side + diagonal)/2; + //now we've got down, side and diagonal as offsets and we also use three successive samples upfront + double skewlevel = pow(basstrimH,2); + + double cutoff = (15000.0+(basstrimH*10000.0))/getSampleRate(); + if (cutoff > 0.49) cutoff = 0.49; //don't crash if run at 44.1k + if (cutoff < 0.001) cutoff = 0.001; //or if cutoff's too low + + fixF[fix_freq] = fixE[fix_freq] = fixD[fix_freq] = fixC[fix_freq] = fixB[fix_freq] = fixA[fix_freq] = cutoff; + + fixA[fix_reso] = 4.46570214; + fixB[fix_reso] = 1.51387132; + fixC[fix_reso] = 0.93979296; + fixD[fix_reso] = 0.70710678; + fixE[fix_reso] = 0.52972649; + fixF[fix_reso] = 0.50316379; + + double K = tan(M_PI * fixA[fix_freq]); //lowpass + double norm = 1.0 / (1.0 + K / fixA[fix_reso] + K * K); + fixA[fix_a0] = K * K * norm; + fixA[fix_a1] = 2.0 * fixA[fix_a0]; + fixA[fix_a2] = fixA[fix_a0]; + fixA[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixA[fix_b2] = (1.0 - K / fixA[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixB[fix_freq]); + norm = 1.0 / (1.0 + K / fixB[fix_reso] + K * K); + fixB[fix_a0] = K * K * norm; + fixB[fix_a1] = 2.0 * fixB[fix_a0]; + fixB[fix_a2] = fixB[fix_a0]; + fixB[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixB[fix_b2] = (1.0 - K / fixB[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixC[fix_freq]); + norm = 1.0 / (1.0 + K / fixC[fix_reso] + K * K); + fixC[fix_a0] = K * K * norm; + fixC[fix_a1] = 2.0 * fixC[fix_a0]; + fixC[fix_a2] = fixC[fix_a0]; + fixC[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixC[fix_b2] = (1.0 - K / fixC[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixD[fix_freq]); + norm = 1.0 / (1.0 + K / fixD[fix_reso] + K * K); + fixD[fix_a0] = K * K * norm; + fixD[fix_a1] = 2.0 * fixD[fix_a0]; + fixD[fix_a2] = fixD[fix_a0]; + fixD[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixD[fix_b2] = (1.0 - K / fixD[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixE[fix_freq]); + norm = 1.0 / (1.0 + K / fixE[fix_reso] + K * K); + fixE[fix_a0] = K * K * norm; + fixE[fix_a1] = 2.0 * fixE[fix_a0]; + fixE[fix_a2] = fixE[fix_a0]; + fixE[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixE[fix_b2] = (1.0 - K / fixE[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixF[fix_freq]); + norm = 1.0 / (1.0 + K / fixF[fix_reso] + K * K); + fixF[fix_a0] = K * K * norm; + fixF[fix_a1] = 2.0 * fixF[fix_a0]; + fixF[fix_a2] = fixF[fix_a0]; + fixF[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixF[fix_b2] = (1.0 - K / fixF[fix_reso] + K * K) * norm; + + 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 outSample = (inputSampleL * fixA[fix_a0]) + fixA[fix_sL1]; + fixA[fix_sL1] = (inputSampleL * fixA[fix_a1]) - (outSample * fixA[fix_b1]) + fixA[fix_sL2]; + fixA[fix_sL2] = (inputSampleL * fixA[fix_a2]) - (outSample * fixA[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixA[fix_a0]) + fixA[fix_sR1]; + fixA[fix_sR1] = (inputSampleR * fixA[fix_a1]) - (outSample * fixA[fix_b1]) + fixA[fix_sR2]; + fixA[fix_sR2] = (inputSampleR * fixA[fix_a2]) - (outSample * fixA[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 1 + + double skewL = (inputSampleL - lastASampleL); + lastASampleL = inputSampleL; + //skew will be direction/angle + double bridgerectifier = fabs(skewL); + if (bridgerectifier > 3.1415926) bridgerectifier = 3.1415926; + //for skew we want it to go to zero effect again, so we use full range of the sine + bridgerectifier = sin(bridgerectifier); + if (skewL > 0) skewL = bridgerectifier; + else skewL = -bridgerectifier; + //skew is now sined and clamped and then re-amplified again + skewL *= inputSampleL; + skewL = (skewL+(skewL*basstrimL))/2.0; + inputSampleL *= basstrimL; + double basscut = basstrimL; + + double skewR = (inputSampleR - lastASampleR); + lastASampleR = inputSampleR; + //skew will be direction/angle + bridgerectifier = fabs(skewR); + if (bridgerectifier > 3.1415926) bridgerectifier = 3.1415926; + //for skew we want it to go to zero effect again, so we use full range of the sine + bridgerectifier = sin(bridgerectifier); + if (skewR > 0.0) skewR = bridgerectifier; + else skewR = -bridgerectifier; + //skew is now sined and clamped and then re-amplified again + skewR *= inputSampleR; + skewR *= skewlevel; + inputSampleR *= basstrimH; + inputSampleR *= inputlevelH; + double offsetR = (1.0 - EQH) + (fabs(inputSampleR)*EQH); + if (offsetR < 0.0) offsetR = 0.0; + if (offsetR > 1.0) offsetR = 1.0; + iirSampleAR = (iirSampleAR * (1.0 - (offsetR * EQH))) + (inputSampleR * (offsetR * EQH)); + inputSampleR = inputSampleR - iirSampleAR; + //highpass + bridgerectifier = fabs(inputSampleR) + skewR; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewR; + if (inputSampleR > 0) inputSampleR = (inputSampleR*(-0.57079633+skewR))+(bridgerectifier*(1.57079633+skewR)); + else inputSampleR = (inputSampleR*(-0.57079633+skewR))-(bridgerectifier*(1.57079633+skewR)); + //overdrive + iirSampleCR = (iirSampleCR * (1.0 - (offsetR * EQH))) + (inputSampleR * (offsetR * EQH)); + inputSampleR = iirSampleCR; + //lowpass. Use offset from before gain stage + //finished first gain stage + + outSample = (inputSampleL * fixB[fix_a0]) + fixB[fix_sL1]; + fixB[fix_sL1] = (inputSampleL * fixB[fix_a1]) - (outSample * fixB[fix_b1]) + fixB[fix_sL2]; + fixB[fix_sL2] = (inputSampleL * fixB[fix_a2]) - (outSample * fixB[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixB[fix_a0]) + fixB[fix_sR1]; + fixB[fix_sR1] = (inputSampleR * fixB[fix_a1]) - (outSample * fixB[fix_b1]) + fixB[fix_sR2]; + fixB[fix_sR2] = (inputSampleR * fixB[fix_a2]) - (outSample * fixB[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 2 + + inputSampleL *= inputlevelL; + double offsetL = (1.0 - EQL) + (fabs(inputSampleL)*EQL); + if (offsetL < 0.0) offsetL = 0.0; + if (offsetL > 1.0) offsetL = 1.0; + iirSampleAL = (iirSampleAL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = inputSampleL - (iirSampleAL*basscut); + //highpass + bridgerectifier = fabs(inputSampleL) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleL > 0.0) inputSampleL = (inputSampleL*(-0.57079633+skewL))+(bridgerectifier*(1.57079633+skewL)); + else inputSampleL = (inputSampleL*(-0.57079633+skewL))-(bridgerectifier*(1.57079633+skewL)); + //overdrive + iirSampleBL = (iirSampleBL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = inputSampleL - (iirSampleBL*basscut); + //highpass. Use offset from before gain stage + //finished first gain stage + + inputSampleR *= inputlevelH; + offsetR = (1.0 + offsetR) / 2.0; + iirSampleBR = (iirSampleBR * (1.0 - (offsetR * EQH))) + (inputSampleR * (offsetR * EQH)); + inputSampleR = inputSampleR - iirSampleBR; + //highpass + bridgerectifier = fabs(inputSampleR) + skewR; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewR; + if (inputSampleR > 0.0) inputSampleR = (inputSampleR*(-0.57079633+skewR))+(bridgerectifier*(1.57079633+skewR)); + else inputSampleR = (inputSampleR*(-0.57079633+skewR))-(bridgerectifier*(1.57079633+skewR)); + //overdrive + iirSampleDR = (iirSampleDR * (1.0 - (offsetR * EQH))) + (inputSampleR * (offsetR * EQH)); + inputSampleR = iirSampleDR; + //lowpass. Use offset from before gain stage + if (flip) + { + OddDR = OddCR; OddCR = OddBR; OddBR = OddAR; OddAR = inputSampleR; + inputSampleR = (OddAR + OddBR + OddCR + OddDR) / 4.0; + } + else + { + EvenDR = EvenCR; EvenCR = EvenBR; EvenBR = EvenAR; EvenAR = inputSampleR; + inputSampleR = (EvenAR + EvenBR + EvenCR + EvenDR) / 4.0; + } + + outSample = (inputSampleL * fixC[fix_a0]) + fixC[fix_sL1]; + fixC[fix_sL1] = (inputSampleL * fixC[fix_a1]) - (outSample * fixC[fix_b1]) + fixC[fix_sL2]; + fixC[fix_sL2] = (inputSampleL * fixC[fix_a2]) - (outSample * fixC[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixC[fix_a0]) + fixC[fix_sR1]; + fixC[fix_sR1] = (inputSampleR * fixC[fix_a1]) - (outSample * fixC[fix_b1]) + fixC[fix_sR2]; + fixC[fix_sR2] = (inputSampleR * fixC[fix_a2]) - (outSample * fixC[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 3 + + inputSampleL *= inputlevelL; + skewL /= 2.0; + offsetL = (1.0 + offsetL) / 2.0; + bridgerectifier = fabs(inputSampleL) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleL > 0.0) inputSampleL = (inputSampleL*(-0.57079633+skewL))+(bridgerectifier*(1.57079633+skewL)); + else inputSampleL = (inputSampleL*(-0.57079633+skewL))-(bridgerectifier*(1.57079633+skewL)); + //overdrive + iirSampleCL = (iirSampleCL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = inputSampleL - (iirSampleCL*basscut); + //highpass. + iirSampleDL = (iirSampleDL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = iirSampleDL; + //lowpass. Use offset from before gain stage + + inputSampleR *= inputlevelH; + bridgerectifier = fabs(inputSampleR) + skewR; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleR > 0.0) inputSampleR = (inputSampleR*-0.57079633)+(bridgerectifier*1.57079633); + else inputSampleR = (inputSampleR*-0.57079633)-(bridgerectifier*1.57079633); + //output stage has less gain, no highpass, straight lowpass + iirSampleER = (iirSampleER * (1.0 - EQH)) + (inputSampleR * EQH); + inputSampleR = iirSampleER; + //lowpass. Use offset from before gain stage + + outSample = (inputSampleL * fixD[fix_a0]) + fixD[fix_sL1]; + fixD[fix_sL1] = (inputSampleL * fixD[fix_a1]) - (outSample * fixD[fix_b1]) + fixD[fix_sL2]; + fixD[fix_sL2] = (inputSampleL * fixD[fix_a2]) - (outSample * fixD[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixD[fix_a0]) + fixD[fix_sR1]; + fixD[fix_sR1] = (inputSampleR * fixD[fix_a1]) - (outSample * fixD[fix_b1]) + fixD[fix_sR2]; + fixD[fix_sR2] = (inputSampleR * fixD[fix_a2]) - (outSample * fixD[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 4 + + inputSampleL *= inputlevelL; + skewL /= 2.0; + offsetL = (1.0 + offsetL) / 2.0; + bridgerectifier = fabs(inputSampleL) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleL > 0.0) inputSampleL = (inputSampleL*(-0.57079633+skewL))+(bridgerectifier*(1.57079633+skewL)); + else inputSampleL = (inputSampleL*(-0.57079633+skewL))-(bridgerectifier*(1.57079633+skewL)); + //overdrive + iirSampleEL = (iirSampleEL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = inputSampleL - (iirSampleEL*basscut); + //we don't need to do basscut again, that was the last one + //highpass. + iirSampleFL = (iirSampleFL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = iirSampleFL; + //lowpass. Use offset from before gain stage + + inputSampleR = sin(inputSampleR); + + outSample = (inputSampleL * fixE[fix_a0]) + fixE[fix_sL1]; + fixE[fix_sL1] = (inputSampleL * fixE[fix_a1]) - (outSample * fixE[fix_b1]) + fixE[fix_sL2]; + fixE[fix_sL2] = (inputSampleL * fixE[fix_a2]) - (outSample * fixE[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixE[fix_a0]) + fixE[fix_sR1]; + fixE[fix_sR1] = (inputSampleR * fixE[fix_a1]) - (outSample * fixE[fix_b1]) + fixE[fix_sR2]; + fixE[fix_sR2] = (inputSampleR * fixE[fix_a2]) - (outSample * fixE[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 5 + + inputSampleL *= inputlevelL; + skewL /= 2.0; + offsetL= (1.0 + offsetL) / 2.0; + bridgerectifier = fabs(inputSampleL) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleL > 0.0) inputSampleL = (inputSampleL*(-0.57079633+skewL))+(bridgerectifier*(1.57079633+skewL)); + else inputSampleL = (inputSampleL*(-0.57079633+skewL))-(bridgerectifier*(1.57079633+skewL)); + //output stage has less gain, no highpass, straight lowpass + iirSampleGL = (iirSampleGL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = iirSampleGL; + //lowpass. Use offset from before gain stage + iirSampleHL = (iirSampleHL * (1.0 - (offsetL * BEQ))) + (inputSampleL * (offsetL * BEQ)); + //extra lowpass for 4*12" speakers + + if (count < 0 || count > 128) count = 128; + double resultBL = 0.0; + if (flip) + { + OddL[count+128] = OddL[count] = iirSampleHL; + resultBL = (OddL[count+down] + OddL[count+side] + OddL[count+diagonal]); + } else { + EvenL[count+128] = EvenL[count] = iirSampleHL; + resultBL = (EvenL[count+down] + EvenL[count+side] + EvenL[count+diagonal]); + } + count--; + + iirSampleIL = (iirSampleIL * (1.0 - (offsetL * BEQ))) + (resultBL * (offsetL * BEQ)); + inputSampleL += (iirSampleIL*0.0625); + //extra lowpass for 4*12" speakers + iirSampleJL = (iirSampleJL * (1.0 - (offsetL * BEQ))) + (inputSampleL * (offsetL * BEQ)); + inputSampleL += iirSampleJL; + inputSampleL = sin(inputSampleL); + + outSample = (inputSampleL * fixF[fix_a0]) + fixF[fix_sL1]; + fixF[fix_sL1] = (inputSampleL * fixF[fix_a1]) - (outSample * fixF[fix_b1]) + fixF[fix_sL2]; + fixF[fix_sL2] = (inputSampleL * fixF[fix_a2]) - (outSample * fixF[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixF[fix_a0]) + fixF[fix_sR1]; + fixF[fix_sR1] = (inputSampleR * fixF[fix_a1]) - (outSample * fixF[fix_b1]) + fixF[fix_sR2]; + fixF[fix_sR2] = (inputSampleR * fixF[fix_a2]) - (outSample * fixF[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 6 + + flip = !flip; + //amp + + cycle++; + if (cycle == cycleEnd) { + + double temp = (inputSampleL + smoothCabAL)/3.0; + smoothCabAL = inputSampleL; + inputSampleL = temp; + + bL[81] = bL[80]; bL[80] = bL[79]; + bL[79] = bL[78]; bL[78] = bL[77]; bL[77] = bL[76]; bL[76] = bL[75]; bL[75] = bL[74]; bL[74] = bL[73]; bL[73] = bL[72]; bL[72] = bL[71]; + bL[71] = bL[70]; bL[70] = bL[69]; bL[69] = bL[68]; bL[68] = bL[67]; bL[67] = bL[66]; bL[66] = bL[65]; bL[65] = bL[64]; bL[64] = bL[63]; + bL[63] = bL[62]; bL[62] = bL[61]; bL[61] = bL[60]; bL[60] = bL[59]; bL[59] = bL[58]; bL[58] = bL[57]; bL[57] = bL[56]; bL[56] = bL[55]; + bL[55] = bL[54]; bL[54] = bL[53]; bL[53] = bL[52]; bL[52] = bL[51]; bL[51] = bL[50]; bL[50] = bL[49]; bL[49] = bL[48]; bL[48] = bL[47]; + bL[47] = bL[46]; bL[46] = bL[45]; bL[45] = bL[44]; bL[44] = bL[43]; bL[43] = bL[42]; bL[42] = bL[41]; bL[41] = bL[40]; bL[40] = bL[39]; + bL[39] = bL[38]; bL[38] = bL[37]; bL[37] = bL[36]; bL[36] = bL[35]; bL[35] = bL[34]; bL[34] = bL[33]; bL[33] = bL[32]; bL[32] = bL[31]; + bL[31] = bL[30]; bL[30] = bL[29]; bL[29] = bL[28]; bL[28] = bL[27]; bL[27] = bL[26]; bL[26] = bL[25]; bL[25] = bL[24]; bL[24] = bL[23]; + bL[23] = bL[22]; bL[22] = bL[21]; bL[21] = bL[20]; bL[20] = bL[19]; bL[19] = bL[18]; bL[18] = bL[17]; bL[17] = bL[16]; bL[16] = bL[15]; + bL[15] = bL[14]; bL[14] = bL[13]; bL[13] = bL[12]; bL[12] = bL[11]; bL[11] = bL[10]; bL[10] = bL[9]; bL[9] = bL[8]; bL[8] = bL[7]; + bL[7] = bL[6]; bL[6] = bL[5]; bL[5] = bL[4]; bL[4] = bL[3]; bL[3] = bL[2]; bL[2] = bL[1]; bL[1] = bL[0]; bL[0] = inputSampleL; + + inputSampleL += (bL[1] * (1.35472031405494242 + (0.00220914099195157*fabs(bL[1])))); + inputSampleL += (bL[2] * (1.63534207755253003 - (0.11406232654509685*fabs(bL[2])))); + inputSampleL += (bL[3] * (1.82334575691525869 - (0.42647194712964054*fabs(bL[3])))); + inputSampleL += (bL[4] * (1.86156386235405868 - (0.76744187887586590*fabs(bL[4])))); + inputSampleL += (bL[5] * (1.67332739338852599 - (0.95161997324293013*fabs(bL[5])))); + inputSampleL += (bL[6] * (1.25054130794899021 - (0.98410433514572859*fabs(bL[6])))); + inputSampleL += (bL[7] * (0.70049121047281737 - (0.87375612110718992*fabs(bL[7])))); + inputSampleL += (bL[8] * (0.15291791448081560 - (0.61195266024519046*fabs(bL[8])))); + inputSampleL -= (bL[9] * (0.37301992914152693 + (0.16755422915252094*fabs(bL[9])))); + inputSampleL -= (bL[10] * (0.76568539228498433 - (0.28554435228965386*fabs(bL[10])))); + inputSampleL -= (bL[11] * (0.95726568749937369 - (0.61659719162806048*fabs(bL[11])))); + inputSampleL -= (bL[12] * (1.01273552193911032 - (0.81827288407943954*fabs(bL[12])))); + inputSampleL -= (bL[13] * (0.93920108117234447 - (0.80077111864205874*fabs(bL[13])))); + inputSampleL -= (bL[14] * (0.79831898832953974 - (0.65814750339694406*fabs(bL[14])))); + inputSampleL -= (bL[15] * (0.64200088100452313 - (0.46135833001232618*fabs(bL[15])))); + inputSampleL -= (bL[16] * (0.48807302802822128 - (0.15506178974799034*fabs(bL[16])))); + inputSampleL -= (bL[17] * (0.36545171501947982 + (0.16126103769376721*fabs(bL[17])))); + inputSampleL -= (bL[18] * (0.31469581455759105 + (0.32250870039053953*fabs(bL[18])))); + inputSampleL -= (bL[19] * (0.36893534817945800 + (0.25409418897237473*fabs(bL[19])))); + inputSampleL -= (bL[20] * (0.41092557722975687 + (0.13114730488878301*fabs(bL[20])))); + inputSampleL -= (bL[21] * (0.38584044480710594 + (0.06825323739722661*fabs(bL[21])))); + inputSampleL -= (bL[22] * (0.33378434007178670 + (0.04144255489164217*fabs(bL[22])))); + inputSampleL -= (bL[23] * (0.26144203061699706 + (0.06031313105098152*fabs(bL[23])))); + inputSampleL -= (bL[24] * (0.25818342000920502 + (0.03642289242586355*fabs(bL[24])))); + inputSampleL -= (bL[25] * (0.28096018498822661 + (0.00976973667327174*fabs(bL[25])))); + inputSampleL -= (bL[26] * (0.25845682019095384 + (0.02749015358080831*fabs(bL[26])))); + inputSampleL -= (bL[27] * (0.26655607865953096 - (0.00329839675455690*fabs(bL[27])))); + inputSampleL -= (bL[28] * (0.30590085026938518 - (0.07375043215328811*fabs(bL[28])))); + inputSampleL -= (bL[29] * (0.32875683916470899 - (0.12454134857516502*fabs(bL[29])))); + inputSampleL -= (bL[30] * (0.38166643180506560 - (0.19973911428609989*fabs(bL[30])))); + inputSampleL -= (bL[31] * (0.49068186937289598 - (0.34785166842136384*fabs(bL[31])))); + inputSampleL -= (bL[32] * (0.60274753867622777 - (0.48685038872711034*fabs(bL[32])))); + inputSampleL -= (bL[33] * (0.65944678627090636 - (0.49844657885975518*fabs(bL[33])))); + inputSampleL -= (bL[34] * (0.64488955808717285 - (0.40514406499806987*fabs(bL[34])))); + inputSampleL -= (bL[35] * (0.55818730353434354 - (0.28029870614987346*fabs(bL[35])))); + inputSampleL -= (bL[36] * (0.43110859113387556 - (0.15373504582939335*fabs(bL[36])))); + inputSampleL -= (bL[37] * (0.37726894966096269 - (0.11570983506028532*fabs(bL[37])))); + inputSampleL -= (bL[38] * (0.39953242355200935 - (0.17879231130484088*fabs(bL[38])))); + inputSampleL -= (bL[39] * (0.36726676379100875 - (0.22013553023983223*fabs(bL[39])))); + inputSampleL -= (bL[40] * (0.27187029469227386 - (0.18461171768478427*fabs(bL[40])))); + inputSampleL -= (bL[41] * (0.21109334552321635 - (0.14497481318083569*fabs(bL[41])))); + inputSampleL -= (bL[42] * (0.19808797405293213 - (0.14916579928186940*fabs(bL[42])))); + inputSampleL -= (bL[43] * (0.16287926785495671 - (0.15146098461120627*fabs(bL[43])))); + inputSampleL -= (bL[44] * (0.11086621477163359 - (0.13182973443924018*fabs(bL[44])))); + inputSampleL -= (bL[45] * (0.07531043236890560 - (0.08062172796472888*fabs(bL[45])))); + inputSampleL -= (bL[46] * (0.01747364473230771 + (0.02201865873632456*fabs(bL[46])))); + inputSampleL += (bL[47] * (0.03080279125662693 - (0.08721756240972101*fabs(bL[47])))); + inputSampleL += (bL[48] * (0.02354148659185142 - (0.06376361763053796*fabs(bL[48])))); + inputSampleL -= (bL[49] * (0.02835772372098715 + (0.00589978513642627*fabs(bL[49])))); + inputSampleL -= (bL[50] * (0.08983370744565244 - (0.02350960427706536*fabs(bL[50])))); + inputSampleL -= (bL[51] * (0.14148947620055380 - (0.03329826628693369*fabs(bL[51])))); + inputSampleL -= (bL[52] * (0.17576502674572581 - (0.06507546651241880*fabs(bL[52])))); + inputSampleL -= (bL[53] * (0.17168865666573860 - (0.07734801128437317*fabs(bL[53])))); + inputSampleL -= (bL[54] * (0.14107027738292105 - (0.03136459344220402*fabs(bL[54])))); + inputSampleL -= (bL[55] * (0.12287163395380074 + (0.01933408169185258*fabs(bL[55])))); + inputSampleL -= (bL[56] * (0.12276622398112971 + (0.01983508766241737*fabs(bL[56])))); + inputSampleL -= (bL[57] * (0.12349721440213673 - (0.01111031415304768*fabs(bL[57])))); + inputSampleL -= (bL[58] * (0.08649454142716655 + (0.02252815645513927*fabs(bL[58])))); + inputSampleL -= (bL[59] * (0.00953083685474757 + (0.13778878548343007*fabs(bL[59])))); + inputSampleL += (bL[60] * (0.06045983158868478 - (0.23966318224935096*fabs(bL[60])))); + inputSampleL += (bL[61] * (0.09053229817093242 - (0.27190119941572544*fabs(bL[61])))); + inputSampleL += (bL[62] * (0.08112662178843048 - (0.22456862606452327*fabs(bL[62])))); + inputSampleL += (bL[63] * (0.07503525686243730 - (0.14330154410548213*fabs(bL[63])))); + inputSampleL += (bL[64] * (0.07372595404399729 - (0.06185193766408734*fabs(bL[64])))); + inputSampleL += (bL[65] * (0.06073789200080433 + (0.01261857435786178*fabs(bL[65])))); + inputSampleL += (bL[66] * (0.04616712695742254 + (0.05851771967084609*fabs(bL[66])))); + inputSampleL += (bL[67] * (0.01036235510345900 + (0.08286534414423796*fabs(bL[67])))); + inputSampleL -= (bL[68] * (0.03708389413229191 - (0.06695282381039531*fabs(bL[68])))); + inputSampleL -= (bL[69] * (0.07092204876981217 - (0.01915829199112784*fabs(bL[69])))); + inputSampleL -= (bL[70] * (0.09443579589460312 + (0.01210082455316246*fabs(bL[70])))); + inputSampleL -= (bL[71] * (0.07824038577769601 + (0.06121988546065113*fabs(bL[71])))); + inputSampleL -= (bL[72] * (0.00854730633079399 + (0.14468518752295506*fabs(bL[72])))); + inputSampleL += (bL[73] * (0.06845589924191028 - (0.18902431382592944*fabs(bL[73])))); + inputSampleL += (bL[74] * (0.10351569998375465 - (0.13204443060279647*fabs(bL[74])))); + inputSampleL += (bL[75] * (0.10513368758532179 - (0.02993199294485649*fabs(bL[75])))); + inputSampleL += (bL[76] * (0.08896978950235003 + (0.04074499273825906*fabs(bL[76])))); + inputSampleL += (bL[77] * (0.03697537734050980 + (0.09217751130846838*fabs(bL[77])))); + inputSampleL -= (bL[78] * (0.04014322441280276 - (0.14062297149365666*fabs(bL[78])))); + inputSampleL -= (bL[79] * (0.10505934581398618 - (0.16988861157275814*fabs(bL[79])))); + inputSampleL -= (bL[80] * (0.13937661651676272 - (0.15083294570551492*fabs(bL[80])))); + inputSampleL -= (bL[81] * (0.13183458845108439 - (0.06657454442471208*fabs(bL[81])))); + + temp = (inputSampleL + smoothCabBL)/3.0; + smoothCabBL = inputSampleL; + inputSampleL = temp/4.0; + + temp = (inputSampleR + smoothCabAR)/3.0; + smoothCabAR = inputSampleR; + inputSampleR = temp; + + bR[82] = bR[81]; bR[81] = bR[80]; bR[80] = bR[79]; + bR[79] = bR[78]; bR[78] = bR[77]; bR[77] = bR[76]; bR[76] = bR[75]; bR[75] = bR[74]; bR[74] = bR[73]; bR[73] = bR[72]; bR[72] = bR[71]; + bR[71] = bR[70]; bR[70] = bR[69]; bR[69] = bR[68]; bR[68] = bR[67]; bR[67] = bR[66]; bR[66] = bR[65]; bR[65] = bR[64]; bR[64] = bR[63]; + bR[63] = bR[62]; bR[62] = bR[61]; bR[61] = bR[60]; bR[60] = bR[59]; bR[59] = bR[58]; bR[58] = bR[57]; bR[57] = bR[56]; bR[56] = bR[55]; + bR[55] = bR[54]; bR[54] = bR[53]; bR[53] = bR[52]; bR[52] = bR[51]; bR[51] = bR[50]; bR[50] = bR[49]; bR[49] = bR[48]; bR[48] = bR[47]; + bR[47] = bR[46]; bR[46] = bR[45]; bR[45] = bR[44]; bR[44] = bR[43]; bR[43] = bR[42]; bR[42] = bR[41]; bR[41] = bR[40]; bR[40] = bR[39]; + bR[39] = bR[38]; bR[38] = bR[37]; bR[37] = bR[36]; bR[36] = bR[35]; bR[35] = bR[34]; bR[34] = bR[33]; bR[33] = bR[32]; bR[32] = bR[31]; + bR[31] = bR[30]; bR[30] = bR[29]; bR[29] = bR[28]; bR[28] = bR[27]; bR[27] = bR[26]; bR[26] = bR[25]; bR[25] = bR[24]; bR[24] = bR[23]; + bR[23] = bR[22]; bR[22] = bR[21]; bR[21] = bR[20]; bR[20] = bR[19]; bR[19] = bR[18]; bR[18] = bR[17]; bR[17] = bR[16]; bR[16] = bR[15]; + bR[15] = bR[14]; bR[14] = bR[13]; bR[13] = bR[12]; bR[12] = bR[11]; bR[11] = bR[10]; bR[10] = bR[9]; bR[9] = bR[8]; bR[8] = bR[7]; + bR[7] = bR[6]; bR[6] = bR[5]; bR[5] = bR[4]; bR[4] = bR[3]; bR[3] = bR[2]; bR[2] = bR[1]; bR[1] = bR[0]; bR[0] = inputSampleR; + inputSampleR += (bR[1] * (1.42133070619855229 - (0.18270903813104500*fabs(bR[1])))); + inputSampleR += (bR[2] * (1.47209686171873821 - (0.27954009590498585*fabs(bR[2])))); + inputSampleR += (bR[3] * (1.34648011331265294 - (0.47178343556301960*fabs(bR[3])))); + inputSampleR += (bR[4] * (0.82133804036124580 - (0.41060189990353935*fabs(bR[4])))); + inputSampleR += (bR[5] * (0.21628057120466901 - (0.26062442734317454*fabs(bR[5])))); + inputSampleR -= (bR[6] * (0.30306716082877883 + (0.10067648425439185*fabs(bR[6])))); + inputSampleR -= (bR[7] * (0.69484313178531876 - (0.09655574841702286*fabs(bR[7])))); + inputSampleR -= (bR[8] * (0.88320822356980833 - (0.26501644327144314*fabs(bR[8])))); + inputSampleR -= (bR[9] * (0.81326147029423723 - (0.31115926837054075*fabs(bR[9])))); + inputSampleR -= (bR[10] * (0.56728759049069222 - (0.23304233545561287*fabs(bR[10])))); + inputSampleR -= (bR[11] * (0.33340326645198737 - (0.12361361388240180*fabs(bR[11])))); + inputSampleR -= (bR[12] * (0.20280263733605616 - (0.03531960962500105*fabs(bR[12])))); + inputSampleR -= (bR[13] * (0.15864533788751345 + (0.00355160825317868*fabs(bR[13])))); + inputSampleR -= (bR[14] * (0.12544767480555119 + (0.01979010423176500*fabs(bR[14])))); + inputSampleR -= (bR[15] * (0.06666788902658917 + (0.00188830739903378*fabs(bR[15])))); + inputSampleR += (bR[16] * (0.02977793355081072 + (0.02304216615605394*fabs(bR[16])))); + inputSampleR += (bR[17] * (0.12821526330916558 + (0.02636238376777800*fabs(bR[17])))); + inputSampleR += (bR[18] * (0.19933812710210136 - (0.02932657234709721*fabs(bR[18])))); + inputSampleR += (bR[19] * (0.18346460191225772 - (0.12859581955080629*fabs(bR[19])))); + inputSampleR -= (bR[20] * (0.00088697526755385 + (0.15855257539277415*fabs(bR[20])))); + inputSampleR -= (bR[21] * (0.28904286712096761 + (0.06226286786982616*fabs(bR[21])))); + inputSampleR -= (bR[22] * (0.49133546282552537 - (0.06512851581813534*fabs(bR[22])))); + inputSampleR -= (bR[23] * (0.52908013030763046 - (0.13606992188523465*fabs(bR[23])))); + inputSampleR -= (bR[24] * (0.45897241332311706 - (0.15527194946346906*fabs(bR[24])))); + inputSampleR -= (bR[25] * (0.35535938629924352 - (0.13634771941703441*fabs(bR[25])))); + inputSampleR -= (bR[26] * (0.26185269405237693 - (0.08736651482771546*fabs(bR[26])))); + inputSampleR -= (bR[27] * (0.19997351944186473 - (0.01714565029656306*fabs(bR[27])))); + inputSampleR -= (bR[28] * (0.18894054145105646 + (0.04557612705740050*fabs(bR[28])))); + inputSampleR -= (bR[29] * (0.24043993691153928 + (0.05267500387081067*fabs(bR[29])))); + inputSampleR -= (bR[30] * (0.29191852873822671 + (0.01922151122971644*fabs(bR[30])))); + inputSampleR -= (bR[31] * (0.29399783430587761 - (0.02238952856106585*fabs(bR[31])))); + inputSampleR -= (bR[32] * (0.26662219155294159 - (0.07760819463416335*fabs(bR[32])))); + inputSampleR -= (bR[33] * (0.20881206667122221 - (0.11930017354479640*fabs(bR[33])))); + inputSampleR -= (bR[34] * (0.12916658879944876 - (0.11798638949823513*fabs(bR[34])))); + inputSampleR -= (bR[35] * (0.07678815166012012 - (0.06826864734598684*fabs(bR[35])))); + inputSampleR -= (bR[36] * (0.08568505484529348 - (0.00510459741104792*fabs(bR[36])))); + inputSampleR -= (bR[37] * (0.13613615872486634 + (0.02288223583971244*fabs(bR[37])))); + inputSampleR -= (bR[38] * (0.17426657494209266 + (0.02723737220296440*fabs(bR[38])))); + inputSampleR -= (bR[39] * (0.17343619261009030 + (0.01412920547179825*fabs(bR[39])))); + inputSampleR -= (bR[40] * (0.14548368977428555 - (0.02640418940455951*fabs(bR[40])))); + inputSampleR -= (bR[41] * (0.10485295885802372 - (0.06334665781931498*fabs(bR[41])))); + inputSampleR -= (bR[42] * (0.06632268974717079 - (0.05960343688612868*fabs(bR[42])))); + inputSampleR -= (bR[43] * (0.06915692039882040 - (0.03541337869596061*fabs(bR[43])))); + inputSampleR -= (bR[44] * (0.11889611687783583 - (0.02250608307287119*fabs(bR[44])))); + inputSampleR -= (bR[45] * (0.14598456370320673 + (0.00280345943128246*fabs(bR[45])))); + inputSampleR -= (bR[46] * (0.12312084125613143 + (0.04947283933434576*fabs(bR[46])))); + inputSampleR -= (bR[47] * (0.11379940289994711 + (0.06590080966570636*fabs(bR[47])))); + inputSampleR -= (bR[48] * (0.12963290754003182 + (0.02597647654256477*fabs(bR[48])))); + inputSampleR -= (bR[49] * (0.12723837402978638 - (0.04942071966927938*fabs(bR[49])))); + inputSampleR -= (bR[50] * (0.09185015882996231 - (0.10420810015956679*fabs(bR[50])))); + inputSampleR -= (bR[51] * (0.04011592913036545 - (0.10234174227772008*fabs(bR[51])))); + inputSampleR += (bR[52] * (0.00992597785057113 + (0.05674042373836896*fabs(bR[52])))); + inputSampleR += (bR[53] * (0.04921452178306781 - (0.00222698867111080*fabs(bR[53])))); + inputSampleR += (bR[54] * (0.06096504883783566 - (0.04040426549982253*fabs(bR[54])))); + inputSampleR += (bR[55] * (0.04113530718724200 - (0.04190143593049960*fabs(bR[55])))); + inputSampleR += (bR[56] * (0.01292699017654650 - (0.01121994018532499*fabs(bR[56])))); + inputSampleR -= (bR[57] * (0.00437123132431870 - (0.02482497612289103*fabs(bR[57])))); + inputSampleR -= (bR[58] * (0.02090571264211918 - (0.03732746039260295*fabs(bR[58])))); + inputSampleR -= (bR[59] * (0.04749751678612051 - (0.02960060937328099*fabs(bR[59])))); + inputSampleR -= (bR[60] * (0.07675095194206227 - (0.02241927084099648*fabs(bR[60])))); + inputSampleR -= (bR[61] * (0.08879414028581609 - (0.01144281133042115*fabs(bR[61])))); + inputSampleR -= (bR[62] * (0.07378854974999530 + (0.02518742701599147*fabs(bR[62])))); + inputSampleR -= (bR[63] * (0.04677309194488959 + (0.08984657372223502*fabs(bR[63])))); + inputSampleR -= (bR[64] * (0.02911874044176449 + (0.14202665940555093*fabs(bR[64])))); + inputSampleR -= (bR[65] * (0.02103564720234969 + (0.14640411976171003*fabs(bR[65])))); + inputSampleR -= (bR[66] * (0.01940626429101940 + (0.10867274382865903*fabs(bR[66])))); + inputSampleR -= (bR[67] * (0.03965401793931531 + (0.04775225375522835*fabs(bR[67])))); + inputSampleR -= (bR[68] * (0.08102486457314527 - (0.03204447425666343*fabs(bR[68])))); + inputSampleR -= (bR[69] * (0.11794849372825778 - (0.12755667382696789*fabs(bR[69])))); + inputSampleR -= (bR[70] * (0.11946469076758266 - (0.20151394599125422*fabs(bR[70])))); + inputSampleR -= (bR[71] * (0.07404630324668053 - (0.21300634351769704*fabs(bR[71])))); + inputSampleR -= (bR[72] * (0.00477584437144086 - (0.16864707684978708*fabs(bR[72])))); + inputSampleR += (bR[73] * (0.05924822014377220 + (0.09394651445109450*fabs(bR[73])))); + inputSampleR += (bR[74] * (0.10060989907457370 + (0.00419196431884887*fabs(bR[74])))); + inputSampleR += (bR[75] * (0.10817907203844988 - (0.07459664480796091*fabs(bR[75])))); + inputSampleR += (bR[76] * (0.08701102204768002 - (0.11129477437630560*fabs(bR[76])))); + inputSampleR += (bR[77] * (0.05673785623180162 - (0.10638640242375266*fabs(bR[77])))); + inputSampleR += (bR[78] * (0.02944190197442081 - (0.08499792583420167*fabs(bR[78])))); + inputSampleR += (bR[79] * (0.01570145445652971 - (0.06190456843465320*fabs(bR[79])))); + inputSampleR += (bR[80] * (0.02770233032476748 - (0.04573713136865480*fabs(bR[80])))); + inputSampleR += (bR[81] * (0.05417160459175360 - (0.03965651064634598*fabs(bR[81])))); + inputSampleR += (bR[82] * (0.06080831637644498 - (0.02909500789113911*fabs(bR[82])))); + + temp = (inputSampleR + smoothCabBR)/3.0; + smoothCabBR = inputSampleR; + inputSampleR = temp/4.0; + + if (cycleEnd == 4) { + lastRefL[0] = lastRefL[4]; //start from previous last + lastRefL[2] = (lastRefL[0] + inputSampleL)/2; //half + lastRefL[1] = (lastRefL[0] + lastRefL[2])/2; //one quarter + lastRefL[3] = (lastRefL[2] + inputSampleL)/2; //three quarters + lastRefL[4] = inputSampleL; //full + lastRefR[0] = lastRefR[4]; //start from previous last + lastRefR[2] = (lastRefR[0] + inputSampleR)/2; //half + lastRefR[1] = (lastRefR[0] + lastRefR[2])/2; //one quarter + lastRefR[3] = (lastRefR[2] + inputSampleR)/2; //three quarters + lastRefR[4] = inputSampleR; //full + } + if (cycleEnd == 3) { + lastRefL[0] = lastRefL[3]; //start from previous last + lastRefL[2] = (lastRefL[0]+lastRefL[0]+inputSampleL)/3; //third + lastRefL[1] = (lastRefL[0]+inputSampleL+inputSampleL)/3; //two thirds + lastRefL[3] = inputSampleL; //full + lastRefR[0] = lastRefR[3]; //start from previous last + lastRefR[2] = (lastRefR[0]+lastRefR[0]+inputSampleR)/3; //third + lastRefR[1] = (lastRefR[0]+inputSampleR+inputSampleR)/3; //two thirds + lastRefR[3] = inputSampleR; //full + } + if (cycleEnd == 2) { + lastRefL[0] = lastRefL[2]; //start from previous last + lastRefL[1] = (lastRefL[0] + inputSampleL)/2; //half + lastRefL[2] = inputSampleL; //full + lastRefR[0] = lastRefR[2]; //start from previous last + lastRefR[1] = (lastRefR[0] + inputSampleR)/2; //half + lastRefR[2] = inputSampleR; //full + } + if (cycleEnd == 1) { + lastRefL[0] = inputSampleL; + lastRefR[0] = inputSampleR; + } + cycle = 0; //reset + inputSampleL = lastRefL[cycle]; + inputSampleR = lastRefR[cycle]; + } else { + inputSampleL = lastRefL[cycle]; + inputSampleR = lastRefR[cycle]; + //we are going through our references now + } + switch (cycleEnd) //multi-pole average using lastRef[] variables on BigAmp channel only + { + case 4: + lastRefL[8] = inputSampleL; inputSampleL = (inputSampleL+lastRefL[7])*0.5; + lastRefL[7] = lastRefL[8]; //continue, do not break + case 3: + lastRefL[8] = inputSampleL; inputSampleL = (inputSampleL+lastRefL[6])*0.5; + lastRefL[6] = lastRefL[8]; //continue, do not break + case 2: + lastRefL[8] = inputSampleL; inputSampleL = (inputSampleL+lastRefL[5])*0.5; + lastRefL[5] = lastRefL[8]; //continue, do not break + case 1: + break; //no further averaging + } + + inputSampleR = (inputSampleL*0.5)+(inputSampleR*0.5); + + if (inputSampleR > 4.0) inputSampleR = 4.0; if (inputSampleR < -4.0) inputSampleR = -4.0; + if (wasPosClipR == true) { //current will be over + if (inputSampleR0.9549925859) {wasPosClipR=true;inputSampleR=0.7058208+(lastSampleR*0.2609148);} + if (wasNegClipR == true) { //current will be -over + if (inputSampleR > lastSampleR) lastSampleR=-0.7058208+(inputSampleR*0.2609148); + else lastSampleR=-0.2491717+(lastSampleR*0.7390851); + } wasNegClipR = false; + if (inputSampleR<-0.9549925859) {wasNegClipR=true;inputSampleR=-0.7058208+(lastSampleR*0.2609148);} + intermediateR[cycleEnd] = inputSampleR; + inputSampleR = lastSampleR; //Latency is however many samples equals one 44.1k sample + for (int x = cycleEnd; x > 0; x--) intermediateR[x-1] = intermediateR[x]; + lastSampleR = intermediateR[0]; //run a little buffer to handle this + + inputSampleL = inputSampleR; + + //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)) * 5.5e-36l * pow(2,expon+62)); + frexpf((float)inputSampleR, &expon); + fpdR ^= fpdR << 13; fpdR ^= fpdR >> 17; fpdR ^= fpdR << 5; + inputSampleR += ((double(fpdR)-uint32_t(0x7fffffff)) * 5.5e-36l * pow(2,expon+62)); + //end 32 bit stereo floating point dither + + *out1 = inputSampleL; + *out2 = inputSampleR; + + in1++; + in2++; + out1++; + out2++; + } +} + +void CrickBass::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 cycleEnd = floor(overallscale); + if (cycleEnd < 1) cycleEnd = 1; + if (cycleEnd > 4) cycleEnd = 4; + //this is going to be 2 for 88.1 or 96k, 3 for silly people, 4 for 176 or 192k + if (cycle > cycleEnd-1) cycle = cycleEnd-1; //sanity check + + double inputlevelL = pow(A+0.5,2); + double inputlevelH = inputlevelL*4.0; + double basstrimH = (B*0.6)+0.2; + double basstrimL = basstrimH*0.618; + + double EQL = (basstrimL/getSampleRate())*22050.0; + double EQH = (basstrimH/getSampleRate())*22050.0; + double BEQ = (0.0625/getSampleRate())*22050.0; + + int diagonal = (int)(0.000861678*getSampleRate()); + if (diagonal > 127) diagonal = 127; + int side = (int)(diagonal/1.4142135623730951); + int down = (side + diagonal)/2; + //now we've got down, side and diagonal as offsets and we also use three successive samples upfront + double skewlevel = pow(basstrimH,2); + + double cutoff = (15000.0+(basstrimH*10000.0))/getSampleRate(); + if (cutoff > 0.49) cutoff = 0.49; //don't crash if run at 44.1k + if (cutoff < 0.001) cutoff = 0.001; //or if cutoff's too low + + fixF[fix_freq] = fixE[fix_freq] = fixD[fix_freq] = fixC[fix_freq] = fixB[fix_freq] = fixA[fix_freq] = cutoff; + + fixA[fix_reso] = 4.46570214; + fixB[fix_reso] = 1.51387132; + fixC[fix_reso] = 0.93979296; + fixD[fix_reso] = 0.70710678; + fixE[fix_reso] = 0.52972649; + fixF[fix_reso] = 0.50316379; + + double K = tan(M_PI * fixA[fix_freq]); //lowpass + double norm = 1.0 / (1.0 + K / fixA[fix_reso] + K * K); + fixA[fix_a0] = K * K * norm; + fixA[fix_a1] = 2.0 * fixA[fix_a0]; + fixA[fix_a2] = fixA[fix_a0]; + fixA[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixA[fix_b2] = (1.0 - K / fixA[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixB[fix_freq]); + norm = 1.0 / (1.0 + K / fixB[fix_reso] + K * K); + fixB[fix_a0] = K * K * norm; + fixB[fix_a1] = 2.0 * fixB[fix_a0]; + fixB[fix_a2] = fixB[fix_a0]; + fixB[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixB[fix_b2] = (1.0 - K / fixB[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixC[fix_freq]); + norm = 1.0 / (1.0 + K / fixC[fix_reso] + K * K); + fixC[fix_a0] = K * K * norm; + fixC[fix_a1] = 2.0 * fixC[fix_a0]; + fixC[fix_a2] = fixC[fix_a0]; + fixC[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixC[fix_b2] = (1.0 - K / fixC[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixD[fix_freq]); + norm = 1.0 / (1.0 + K / fixD[fix_reso] + K * K); + fixD[fix_a0] = K * K * norm; + fixD[fix_a1] = 2.0 * fixD[fix_a0]; + fixD[fix_a2] = fixD[fix_a0]; + fixD[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixD[fix_b2] = (1.0 - K / fixD[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixE[fix_freq]); + norm = 1.0 / (1.0 + K / fixE[fix_reso] + K * K); + fixE[fix_a0] = K * K * norm; + fixE[fix_a1] = 2.0 * fixE[fix_a0]; + fixE[fix_a2] = fixE[fix_a0]; + fixE[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixE[fix_b2] = (1.0 - K / fixE[fix_reso] + K * K) * norm; + + K = tan(M_PI * fixF[fix_freq]); + norm = 1.0 / (1.0 + K / fixF[fix_reso] + K * K); + fixF[fix_a0] = K * K * norm; + fixF[fix_a1] = 2.0 * fixF[fix_a0]; + fixF[fix_a2] = fixF[fix_a0]; + fixF[fix_b1] = 2.0 * (K * K - 1.0) * norm; + fixF[fix_b2] = (1.0 - K / fixF[fix_reso] + K * K) * norm; + + 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 outSample = (inputSampleL * fixA[fix_a0]) + fixA[fix_sL1]; + fixA[fix_sL1] = (inputSampleL * fixA[fix_a1]) - (outSample * fixA[fix_b1]) + fixA[fix_sL2]; + fixA[fix_sL2] = (inputSampleL * fixA[fix_a2]) - (outSample * fixA[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixA[fix_a0]) + fixA[fix_sR1]; + fixA[fix_sR1] = (inputSampleR * fixA[fix_a1]) - (outSample * fixA[fix_b1]) + fixA[fix_sR2]; + fixA[fix_sR2] = (inputSampleR * fixA[fix_a2]) - (outSample * fixA[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 1 + + double skewL = (inputSampleL - lastASampleL); + lastASampleL = inputSampleL; + //skew will be direction/angle + double bridgerectifier = fabs(skewL); + if (bridgerectifier > 3.1415926) bridgerectifier = 3.1415926; + //for skew we want it to go to zero effect again, so we use full range of the sine + bridgerectifier = sin(bridgerectifier); + if (skewL > 0) skewL = bridgerectifier; + else skewL = -bridgerectifier; + //skew is now sined and clamped and then re-amplified again + skewL *= inputSampleL; + skewL = (skewL+(skewL*basstrimL))/2.0; + inputSampleL *= basstrimL; + double basscut = basstrimL; + + double skewR = (inputSampleR - lastASampleR); + lastASampleR = inputSampleR; + //skew will be direction/angle + bridgerectifier = fabs(skewR); + if (bridgerectifier > 3.1415926) bridgerectifier = 3.1415926; + //for skew we want it to go to zero effect again, so we use full range of the sine + bridgerectifier = sin(bridgerectifier); + if (skewR > 0.0) skewR = bridgerectifier; + else skewR = -bridgerectifier; + //skew is now sined and clamped and then re-amplified again + skewR *= inputSampleR; + skewR *= skewlevel; + inputSampleR *= basstrimH; + inputSampleR *= inputlevelH; + double offsetR = (1.0 - EQH) + (fabs(inputSampleR)*EQH); + if (offsetR < 0.0) offsetR = 0.0; + if (offsetR > 1.0) offsetR = 1.0; + iirSampleAR = (iirSampleAR * (1.0 - (offsetR * EQH))) + (inputSampleR * (offsetR * EQH)); + inputSampleR = inputSampleR - iirSampleAR; + //highpass + bridgerectifier = fabs(inputSampleR) + skewR; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewR; + if (inputSampleR > 0) inputSampleR = (inputSampleR*(-0.57079633+skewR))+(bridgerectifier*(1.57079633+skewR)); + else inputSampleR = (inputSampleR*(-0.57079633+skewR))-(bridgerectifier*(1.57079633+skewR)); + //overdrive + iirSampleCR = (iirSampleCR * (1.0 - (offsetR * EQH))) + (inputSampleR * (offsetR * EQH)); + inputSampleR = iirSampleCR; + //lowpass. Use offset from before gain stage + //finished first gain stage + + outSample = (inputSampleL * fixB[fix_a0]) + fixB[fix_sL1]; + fixB[fix_sL1] = (inputSampleL * fixB[fix_a1]) - (outSample * fixB[fix_b1]) + fixB[fix_sL2]; + fixB[fix_sL2] = (inputSampleL * fixB[fix_a2]) - (outSample * fixB[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixB[fix_a0]) + fixB[fix_sR1]; + fixB[fix_sR1] = (inputSampleR * fixB[fix_a1]) - (outSample * fixB[fix_b1]) + fixB[fix_sR2]; + fixB[fix_sR2] = (inputSampleR * fixB[fix_a2]) - (outSample * fixB[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 2 + + inputSampleL *= inputlevelL; + double offsetL = (1.0 - EQL) + (fabs(inputSampleL)*EQL); + if (offsetL < 0.0) offsetL = 0.0; + if (offsetL > 1.0) offsetL = 1.0; + iirSampleAL = (iirSampleAL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = inputSampleL - (iirSampleAL*basscut); + //highpass + bridgerectifier = fabs(inputSampleL) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleL > 0.0) inputSampleL = (inputSampleL*(-0.57079633+skewL))+(bridgerectifier*(1.57079633+skewL)); + else inputSampleL = (inputSampleL*(-0.57079633+skewL))-(bridgerectifier*(1.57079633+skewL)); + //overdrive + iirSampleBL = (iirSampleBL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = inputSampleL - (iirSampleBL*basscut); + //highpass. Use offset from before gain stage + //finished first gain stage + + inputSampleR *= inputlevelH; + offsetR = (1.0 + offsetR) / 2.0; + iirSampleBR = (iirSampleBR * (1.0 - (offsetR * EQH))) + (inputSampleR * (offsetR * EQH)); + inputSampleR = inputSampleR - iirSampleBR; + //highpass + bridgerectifier = fabs(inputSampleR) + skewR; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewR; + if (inputSampleR > 0.0) inputSampleR = (inputSampleR*(-0.57079633+skewR))+(bridgerectifier*(1.57079633+skewR)); + else inputSampleR = (inputSampleR*(-0.57079633+skewR))-(bridgerectifier*(1.57079633+skewR)); + //overdrive + iirSampleDR = (iirSampleDR * (1.0 - (offsetR * EQH))) + (inputSampleR * (offsetR * EQH)); + inputSampleR = iirSampleDR; + //lowpass. Use offset from before gain stage + if (flip) + { + OddDR = OddCR; OddCR = OddBR; OddBR = OddAR; OddAR = inputSampleR; + inputSampleR = (OddAR + OddBR + OddCR + OddDR) / 4.0; + } + else + { + EvenDR = EvenCR; EvenCR = EvenBR; EvenBR = EvenAR; EvenAR = inputSampleR; + inputSampleR = (EvenAR + EvenBR + EvenCR + EvenDR) / 4.0; + } + + outSample = (inputSampleL * fixC[fix_a0]) + fixC[fix_sL1]; + fixC[fix_sL1] = (inputSampleL * fixC[fix_a1]) - (outSample * fixC[fix_b1]) + fixC[fix_sL2]; + fixC[fix_sL2] = (inputSampleL * fixC[fix_a2]) - (outSample * fixC[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixC[fix_a0]) + fixC[fix_sR1]; + fixC[fix_sR1] = (inputSampleR * fixC[fix_a1]) - (outSample * fixC[fix_b1]) + fixC[fix_sR2]; + fixC[fix_sR2] = (inputSampleR * fixC[fix_a2]) - (outSample * fixC[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 3 + + inputSampleL *= inputlevelL; + skewL /= 2.0; + offsetL = (1.0 + offsetL) / 2.0; + bridgerectifier = fabs(inputSampleL) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleL > 0.0) inputSampleL = (inputSampleL*(-0.57079633+skewL))+(bridgerectifier*(1.57079633+skewL)); + else inputSampleL = (inputSampleL*(-0.57079633+skewL))-(bridgerectifier*(1.57079633+skewL)); + //overdrive + iirSampleCL = (iirSampleCL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = inputSampleL - (iirSampleCL*basscut); + //highpass. + iirSampleDL = (iirSampleDL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = iirSampleDL; + //lowpass. Use offset from before gain stage + + inputSampleR *= inputlevelH; + bridgerectifier = fabs(inputSampleR) + skewR; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleR > 0.0) inputSampleR = (inputSampleR*-0.57079633)+(bridgerectifier*1.57079633); + else inputSampleR = (inputSampleR*-0.57079633)-(bridgerectifier*1.57079633); + //output stage has less gain, no highpass, straight lowpass + iirSampleER = (iirSampleER * (1.0 - EQH)) + (inputSampleR * EQH); + inputSampleR = iirSampleER; + //lowpass. Use offset from before gain stage + + outSample = (inputSampleL * fixD[fix_a0]) + fixD[fix_sL1]; + fixD[fix_sL1] = (inputSampleL * fixD[fix_a1]) - (outSample * fixD[fix_b1]) + fixD[fix_sL2]; + fixD[fix_sL2] = (inputSampleL * fixD[fix_a2]) - (outSample * fixD[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixD[fix_a0]) + fixD[fix_sR1]; + fixD[fix_sR1] = (inputSampleR * fixD[fix_a1]) - (outSample * fixD[fix_b1]) + fixD[fix_sR2]; + fixD[fix_sR2] = (inputSampleR * fixD[fix_a2]) - (outSample * fixD[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 4 + + inputSampleL *= inputlevelL; + skewL /= 2.0; + offsetL = (1.0 + offsetL) / 2.0; + bridgerectifier = fabs(inputSampleL) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = (sin(bridgerectifier) * 1.57079633) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleL > 0.0) inputSampleL = (inputSampleL*(-0.57079633+skewL))+(bridgerectifier*(1.57079633+skewL)); + else inputSampleL = (inputSampleL*(-0.57079633+skewL))-(bridgerectifier*(1.57079633+skewL)); + //overdrive + iirSampleEL = (iirSampleEL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = inputSampleL - (iirSampleEL*basscut); + //we don't need to do basscut again, that was the last one + //highpass. + iirSampleFL = (iirSampleFL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = iirSampleFL; + //lowpass. Use offset from before gain stage + + inputSampleR = sin(inputSampleR); + + outSample = (inputSampleL * fixE[fix_a0]) + fixE[fix_sL1]; + fixE[fix_sL1] = (inputSampleL * fixE[fix_a1]) - (outSample * fixE[fix_b1]) + fixE[fix_sL2]; + fixE[fix_sL2] = (inputSampleL * fixE[fix_a2]) - (outSample * fixE[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixE[fix_a0]) + fixE[fix_sR1]; + fixE[fix_sR1] = (inputSampleR * fixE[fix_a1]) - (outSample * fixE[fix_b1]) + fixE[fix_sR2]; + fixE[fix_sR2] = (inputSampleR * fixE[fix_a2]) - (outSample * fixE[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 5 + + inputSampleL *= inputlevelL; + skewL /= 2.0; + offsetL= (1.0 + offsetL) / 2.0; + bridgerectifier = fabs(inputSampleL) + skewL; + if (bridgerectifier > 1.57079633) bridgerectifier = 1.57079633; + bridgerectifier = sin(bridgerectifier) * 1.57079633; + if (inputSampleL > 0.0) inputSampleL = (inputSampleL*(-0.57079633+skewL))+(bridgerectifier*(1.57079633+skewL)); + else inputSampleL = (inputSampleL*(-0.57079633+skewL))-(bridgerectifier*(1.57079633+skewL)); + //output stage has less gain, no highpass, straight lowpass + iirSampleGL = (iirSampleGL * (1.0 - (offsetL * EQL))) + (inputSampleL * (offsetL * EQL)); + inputSampleL = iirSampleGL; + //lowpass. Use offset from before gain stage + iirSampleHL = (iirSampleHL * (1.0 - (offsetL * BEQ))) + (inputSampleL * (offsetL * BEQ)); + //extra lowpass for 4*12" speakers + + if (count < 0 || count > 128) count = 128; + double resultBL = 0.0; + if (flip) + { + OddL[count+128] = OddL[count] = iirSampleHL; + resultBL = (OddL[count+down] + OddL[count+side] + OddL[count+diagonal]); + } else { + EvenL[count+128] = EvenL[count] = iirSampleHL; + resultBL = (EvenL[count+down] + EvenL[count+side] + EvenL[count+diagonal]); + } + count--; + + iirSampleIL = (iirSampleIL * (1.0 - (offsetL * BEQ))) + (resultBL * (offsetL * BEQ)); + inputSampleL += (iirSampleIL*0.0625); + //extra lowpass for 4*12" speakers + iirSampleJL = (iirSampleJL * (1.0 - (offsetL * BEQ))) + (inputSampleL * (offsetL * BEQ)); + inputSampleL += iirSampleJL; + inputSampleL = sin(inputSampleL); + + outSample = (inputSampleL * fixF[fix_a0]) + fixF[fix_sL1]; + fixF[fix_sL1] = (inputSampleL * fixF[fix_a1]) - (outSample * fixF[fix_b1]) + fixF[fix_sL2]; + fixF[fix_sL2] = (inputSampleL * fixF[fix_a2]) - (outSample * fixF[fix_b2]); + inputSampleL = outSample; //fixed biquad filtering ultrasonics + outSample = (inputSampleR * fixF[fix_a0]) + fixF[fix_sR1]; + fixF[fix_sR1] = (inputSampleR * fixF[fix_a1]) - (outSample * fixF[fix_b1]) + fixF[fix_sR2]; + fixF[fix_sR2] = (inputSampleR * fixF[fix_a2]) - (outSample * fixF[fix_b2]); + inputSampleR = outSample; //fixed biquad filtering ultrasonics 6 + + flip = !flip; + //amp + + cycle++; + if (cycle == cycleEnd) { + + double temp = (inputSampleL + smoothCabAL)/3.0; + smoothCabAL = inputSampleL; + inputSampleL = temp; + + bL[81] = bL[80]; bL[80] = bL[79]; + bL[79] = bL[78]; bL[78] = bL[77]; bL[77] = bL[76]; bL[76] = bL[75]; bL[75] = bL[74]; bL[74] = bL[73]; bL[73] = bL[72]; bL[72] = bL[71]; + bL[71] = bL[70]; bL[70] = bL[69]; bL[69] = bL[68]; bL[68] = bL[67]; bL[67] = bL[66]; bL[66] = bL[65]; bL[65] = bL[64]; bL[64] = bL[63]; + bL[63] = bL[62]; bL[62] = bL[61]; bL[61] = bL[60]; bL[60] = bL[59]; bL[59] = bL[58]; bL[58] = bL[57]; bL[57] = bL[56]; bL[56] = bL[55]; + bL[55] = bL[54]; bL[54] = bL[53]; bL[53] = bL[52]; bL[52] = bL[51]; bL[51] = bL[50]; bL[50] = bL[49]; bL[49] = bL[48]; bL[48] = bL[47]; + bL[47] = bL[46]; bL[46] = bL[45]; bL[45] = bL[44]; bL[44] = bL[43]; bL[43] = bL[42]; bL[42] = bL[41]; bL[41] = bL[40]; bL[40] = bL[39]; + bL[39] = bL[38]; bL[38] = bL[37]; bL[37] = bL[36]; bL[36] = bL[35]; bL[35] = bL[34]; bL[34] = bL[33]; bL[33] = bL[32]; bL[32] = bL[31]; + bL[31] = bL[30]; bL[30] = bL[29]; bL[29] = bL[28]; bL[28] = bL[27]; bL[27] = bL[26]; bL[26] = bL[25]; bL[25] = bL[24]; bL[24] = bL[23]; + bL[23] = bL[22]; bL[22] = bL[21]; bL[21] = bL[20]; bL[20] = bL[19]; bL[19] = bL[18]; bL[18] = bL[17]; bL[17] = bL[16]; bL[16] = bL[15]; + bL[15] = bL[14]; bL[14] = bL[13]; bL[13] = bL[12]; bL[12] = bL[11]; bL[11] = bL[10]; bL[10] = bL[9]; bL[9] = bL[8]; bL[8] = bL[7]; + bL[7] = bL[6]; bL[6] = bL[5]; bL[5] = bL[4]; bL[4] = bL[3]; bL[3] = bL[2]; bL[2] = bL[1]; bL[1] = bL[0]; bL[0] = inputSampleL; + + inputSampleL += (bL[1] * (1.35472031405494242 + (0.00220914099195157*fabs(bL[1])))); + inputSampleL += (bL[2] * (1.63534207755253003 - (0.11406232654509685*fabs(bL[2])))); + inputSampleL += (bL[3] * (1.82334575691525869 - (0.42647194712964054*fabs(bL[3])))); + inputSampleL += (bL[4] * (1.86156386235405868 - (0.76744187887586590*fabs(bL[4])))); + inputSampleL += (bL[5] * (1.67332739338852599 - (0.95161997324293013*fabs(bL[5])))); + inputSampleL += (bL[6] * (1.25054130794899021 - (0.98410433514572859*fabs(bL[6])))); + inputSampleL += (bL[7] * (0.70049121047281737 - (0.87375612110718992*fabs(bL[7])))); + inputSampleL += (bL[8] * (0.15291791448081560 - (0.61195266024519046*fabs(bL[8])))); + inputSampleL -= (bL[9] * (0.37301992914152693 + (0.16755422915252094*fabs(bL[9])))); + inputSampleL -= (bL[10] * (0.76568539228498433 - (0.28554435228965386*fabs(bL[10])))); + inputSampleL -= (bL[11] * (0.95726568749937369 - (0.61659719162806048*fabs(bL[11])))); + inputSampleL -= (bL[12] * (1.01273552193911032 - (0.81827288407943954*fabs(bL[12])))); + inputSampleL -= (bL[13] * (0.93920108117234447 - (0.80077111864205874*fabs(bL[13])))); + inputSampleL -= (bL[14] * (0.79831898832953974 - (0.65814750339694406*fabs(bL[14])))); + inputSampleL -= (bL[15] * (0.64200088100452313 - (0.46135833001232618*fabs(bL[15])))); + inputSampleL -= (bL[16] * (0.48807302802822128 - (0.15506178974799034*fabs(bL[16])))); + inputSampleL -= (bL[17] * (0.36545171501947982 + (0.16126103769376721*fabs(bL[17])))); + inputSampleL -= (bL[18] * (0.31469581455759105 + (0.32250870039053953*fabs(bL[18])))); + inputSampleL -= (bL[19] * (0.36893534817945800 + (0.25409418897237473*fabs(bL[19])))); + inputSampleL -= (bL[20] * (0.41092557722975687 + (0.13114730488878301*fabs(bL[20])))); + inputSampleL -= (bL[21] * (0.38584044480710594 + (0.06825323739722661*fabs(bL[21])))); + inputSampleL -= (bL[22] * (0.33378434007178670 + (0.04144255489164217*fabs(bL[22])))); + inputSampleL -= (bL[23] * (0.26144203061699706 + (0.06031313105098152*fabs(bL[23])))); + inputSampleL -= (bL[24] * (0.25818342000920502 + (0.03642289242586355*fabs(bL[24])))); + inputSampleL -= (bL[25] * (0.28096018498822661 + (0.00976973667327174*fabs(bL[25])))); + inputSampleL -= (bL[26] * (0.25845682019095384 + (0.02749015358080831*fabs(bL[26])))); + inputSampleL -= (bL[27] * (0.26655607865953096 - (0.00329839675455690*fabs(bL[27])))); + inputSampleL -= (bL[28] * (0.30590085026938518 - (0.07375043215328811*fabs(bL[28])))); + inputSampleL -= (bL[29] * (0.32875683916470899 - (0.12454134857516502*fabs(bL[29])))); + inputSampleL -= (bL[30] * (0.38166643180506560 - (0.19973911428609989*fabs(bL[30])))); + inputSampleL -= (bL[31] * (0.49068186937289598 - (0.34785166842136384*fabs(bL[31])))); + inputSampleL -= (bL[32] * (0.60274753867622777 - (0.48685038872711034*fabs(bL[32])))); + inputSampleL -= (bL[33] * (0.65944678627090636 - (0.49844657885975518*fabs(bL[33])))); + inputSampleL -= (bL[34] * (0.64488955808717285 - (0.40514406499806987*fabs(bL[34])))); + inputSampleL -= (bL[35] * (0.55818730353434354 - (0.28029870614987346*fabs(bL[35])))); + inputSampleL -= (bL[36] * (0.43110859113387556 - (0.15373504582939335*fabs(bL[36])))); + inputSampleL -= (bL[37] * (0.37726894966096269 - (0.11570983506028532*fabs(bL[37])))); + inputSampleL -= (bL[38] * (0.39953242355200935 - (0.17879231130484088*fabs(bL[38])))); + inputSampleL -= (bL[39] * (0.36726676379100875 - (0.22013553023983223*fabs(bL[39])))); + inputSampleL -= (bL[40] * (0.27187029469227386 - (0.18461171768478427*fabs(bL[40])))); + inputSampleL -= (bL[41] * (0.21109334552321635 - (0.14497481318083569*fabs(bL[41])))); + inputSampleL -= (bL[42] * (0.19808797405293213 - (0.14916579928186940*fabs(bL[42])))); + inputSampleL -= (bL[43] * (0.16287926785495671 - (0.15146098461120627*fabs(bL[43])))); + inputSampleL -= (bL[44] * (0.11086621477163359 - (0.13182973443924018*fabs(bL[44])))); + inputSampleL -= (bL[45] * (0.07531043236890560 - (0.08062172796472888*fabs(bL[45])))); + inputSampleL -= (bL[46] * (0.01747364473230771 + (0.02201865873632456*fabs(bL[46])))); + inputSampleL += (bL[47] * (0.03080279125662693 - (0.08721756240972101*fabs(bL[47])))); + inputSampleL += (bL[48] * (0.02354148659185142 - (0.06376361763053796*fabs(bL[48])))); + inputSampleL -= (bL[49] * (0.02835772372098715 + (0.00589978513642627*fabs(bL[49])))); + inputSampleL -= (bL[50] * (0.08983370744565244 - (0.02350960427706536*fabs(bL[50])))); + inputSampleL -= (bL[51] * (0.14148947620055380 - (0.03329826628693369*fabs(bL[51])))); + inputSampleL -= (bL[52] * (0.17576502674572581 - (0.06507546651241880*fabs(bL[52])))); + inputSampleL -= (bL[53] * (0.17168865666573860 - (0.07734801128437317*fabs(bL[53])))); + inputSampleL -= (bL[54] * (0.14107027738292105 - (0.03136459344220402*fabs(bL[54])))); + inputSampleL -= (bL[55] * (0.12287163395380074 + (0.01933408169185258*fabs(bL[55])))); + inputSampleL -= (bL[56] * (0.12276622398112971 + (0.01983508766241737*fabs(bL[56])))); + inputSampleL -= (bL[57] * (0.12349721440213673 - (0.01111031415304768*fabs(bL[57])))); + inputSampleL -= (bL[58] * (0.08649454142716655 + (0.02252815645513927*fabs(bL[58])))); + inputSampleL -= (bL[59] * (0.00953083685474757 + (0.13778878548343007*fabs(bL[59])))); + inputSampleL += (bL[60] * (0.06045983158868478 - (0.23966318224935096*fabs(bL[60])))); + inputSampleL += (bL[61] * (0.09053229817093242 - (0.27190119941572544*fabs(bL[61])))); + inputSampleL += (bL[62] * (0.08112662178843048 - (0.22456862606452327*fabs(bL[62])))); + inputSampleL += (bL[63] * (0.07503525686243730 - (0.14330154410548213*fabs(bL[63])))); + inputSampleL += (bL[64] * (0.07372595404399729 - (0.06185193766408734*fabs(bL[64])))); + inputSampleL += (bL[65] * (0.06073789200080433 + (0.01261857435786178*fabs(bL[65])))); + inputSampleL += (bL[66] * (0.04616712695742254 + (0.05851771967084609*fabs(bL[66])))); + inputSampleL += (bL[67] * (0.01036235510345900 + (0.08286534414423796*fabs(bL[67])))); + inputSampleL -= (bL[68] * (0.03708389413229191 - (0.06695282381039531*fabs(bL[68])))); + inputSampleL -= (bL[69] * (0.07092204876981217 - (0.01915829199112784*fabs(bL[69])))); + inputSampleL -= (bL[70] * (0.09443579589460312 + (0.01210082455316246*fabs(bL[70])))); + inputSampleL -= (bL[71] * (0.07824038577769601 + (0.06121988546065113*fabs(bL[71])))); + inputSampleL -= (bL[72] * (0.00854730633079399 + (0.14468518752295506*fabs(bL[72])))); + inputSampleL += (bL[73] * (0.06845589924191028 - (0.18902431382592944*fabs(bL[73])))); + inputSampleL += (bL[74] * (0.10351569998375465 - (0.13204443060279647*fabs(bL[74])))); + inputSampleL += (bL[75] * (0.10513368758532179 - (0.02993199294485649*fabs(bL[75])))); + inputSampleL += (bL[76] * (0.08896978950235003 + (0.04074499273825906*fabs(bL[76])))); + inputSampleL += (bL[77] * (0.03697537734050980 + (0.09217751130846838*fabs(bL[77])))); + inputSampleL -= (bL[78] * (0.04014322441280276 - (0.14062297149365666*fabs(bL[78])))); + inputSampleL -= (bL[79] * (0.10505934581398618 - (0.16988861157275814*fabs(bL[79])))); + inputSampleL -= (bL[80] * (0.13937661651676272 - (0.15083294570551492*fabs(bL[80])))); + inputSampleL -= (bL[81] * (0.13183458845108439 - (0.06657454442471208*fabs(bL[81])))); + + temp = (inputSampleL + smoothCabBL)/3.0; + smoothCabBL = inputSampleL; + inputSampleL = temp/4.0; + + temp = (inputSampleR + smoothCabAR)/3.0; + smoothCabAR = inputSampleR; + inputSampleR = temp; + + bR[82] = bR[81]; bR[81] = bR[80]; bR[80] = bR[79]; + bR[79] = bR[78]; bR[78] = bR[77]; bR[77] = bR[76]; bR[76] = bR[75]; bR[75] = bR[74]; bR[74] = bR[73]; bR[73] = bR[72]; bR[72] = bR[71]; + bR[71] = bR[70]; bR[70] = bR[69]; bR[69] = bR[68]; bR[68] = bR[67]; bR[67] = bR[66]; bR[66] = bR[65]; bR[65] = bR[64]; bR[64] = bR[63]; + bR[63] = bR[62]; bR[62] = bR[61]; bR[61] = bR[60]; bR[60] = bR[59]; bR[59] = bR[58]; bR[58] = bR[57]; bR[57] = bR[56]; bR[56] = bR[55]; + bR[55] = bR[54]; bR[54] = bR[53]; bR[53] = bR[52]; bR[52] = bR[51]; bR[51] = bR[50]; bR[50] = bR[49]; bR[49] = bR[48]; bR[48] = bR[47]; + bR[47] = bR[46]; bR[46] = bR[45]; bR[45] = bR[44]; bR[44] = bR[43]; bR[43] = bR[42]; bR[42] = bR[41]; bR[41] = bR[40]; bR[40] = bR[39]; + bR[39] = bR[38]; bR[38] = bR[37]; bR[37] = bR[36]; bR[36] = bR[35]; bR[35] = bR[34]; bR[34] = bR[33]; bR[33] = bR[32]; bR[32] = bR[31]; + bR[31] = bR[30]; bR[30] = bR[29]; bR[29] = bR[28]; bR[28] = bR[27]; bR[27] = bR[26]; bR[26] = bR[25]; bR[25] = bR[24]; bR[24] = bR[23]; + bR[23] = bR[22]; bR[22] = bR[21]; bR[21] = bR[20]; bR[20] = bR[19]; bR[19] = bR[18]; bR[18] = bR[17]; bR[17] = bR[16]; bR[16] = bR[15]; + bR[15] = bR[14]; bR[14] = bR[13]; bR[13] = bR[12]; bR[12] = bR[11]; bR[11] = bR[10]; bR[10] = bR[9]; bR[9] = bR[8]; bR[8] = bR[7]; + bR[7] = bR[6]; bR[6] = bR[5]; bR[5] = bR[4]; bR[4] = bR[3]; bR[3] = bR[2]; bR[2] = bR[1]; bR[1] = bR[0]; bR[0] = inputSampleR; + inputSampleR += (bR[1] * (1.42133070619855229 - (0.18270903813104500*fabs(bR[1])))); + inputSampleR += (bR[2] * (1.47209686171873821 - (0.27954009590498585*fabs(bR[2])))); + inputSampleR += (bR[3] * (1.34648011331265294 - (0.47178343556301960*fabs(bR[3])))); + inputSampleR += (bR[4] * (0.82133804036124580 - (0.41060189990353935*fabs(bR[4])))); + inputSampleR += (bR[5] * (0.21628057120466901 - (0.26062442734317454*fabs(bR[5])))); + inputSampleR -= (bR[6] * (0.30306716082877883 + (0.10067648425439185*fabs(bR[6])))); + inputSampleR -= (bR[7] * (0.69484313178531876 - (0.09655574841702286*fabs(bR[7])))); + inputSampleR -= (bR[8] * (0.88320822356980833 - (0.26501644327144314*fabs(bR[8])))); + inputSampleR -= (bR[9] * (0.81326147029423723 - (0.31115926837054075*fabs(bR[9])))); + inputSampleR -= (bR[10] * (0.56728759049069222 - (0.23304233545561287*fabs(bR[10])))); + inputSampleR -= (bR[11] * (0.33340326645198737 - (0.12361361388240180*fabs(bR[11])))); + inputSampleR -= (bR[12] * (0.20280263733605616 - (0.03531960962500105*fabs(bR[12])))); + inputSampleR -= (bR[13] * (0.15864533788751345 + (0.00355160825317868*fabs(bR[13])))); + inputSampleR -= (bR[14] * (0.12544767480555119 + (0.01979010423176500*fabs(bR[14])))); + inputSampleR -= (bR[15] * (0.06666788902658917 + (0.00188830739903378*fabs(bR[15])))); + inputSampleR += (bR[16] * (0.02977793355081072 + (0.02304216615605394*fabs(bR[16])))); + inputSampleR += (bR[17] * (0.12821526330916558 + (0.02636238376777800*fabs(bR[17])))); + inputSampleR += (bR[18] * (0.19933812710210136 - (0.02932657234709721*fabs(bR[18])))); + inputSampleR += (bR[19] * (0.18346460191225772 - (0.12859581955080629*fabs(bR[19])))); + inputSampleR -= (bR[20] * (0.00088697526755385 + (0.15855257539277415*fabs(bR[20])))); + inputSampleR -= (bR[21] * (0.28904286712096761 + (0.06226286786982616*fabs(bR[21])))); + inputSampleR -= (bR[22] * (0.49133546282552537 - (0.06512851581813534*fabs(bR[22])))); + inputSampleR -= (bR[23] * (0.52908013030763046 - (0.13606992188523465*fabs(bR[23])))); + inputSampleR -= (bR[24] * (0.45897241332311706 - (0.15527194946346906*fabs(bR[24])))); + inputSampleR -= (bR[25] * (0.35535938629924352 - (0.13634771941703441*fabs(bR[25])))); + inputSampleR -= (bR[26] * (0.26185269405237693 - (0.08736651482771546*fabs(bR[26])))); + inputSampleR -= (bR[27] * (0.19997351944186473 - (0.01714565029656306*fabs(bR[27])))); + inputSampleR -= (bR[28] * (0.18894054145105646 + (0.04557612705740050*fabs(bR[28])))); + inputSampleR -= (bR[29] * (0.24043993691153928 + (0.05267500387081067*fabs(bR[29])))); + inputSampleR -= (bR[30] * (0.29191852873822671 + (0.01922151122971644*fabs(bR[30])))); + inputSampleR -= (bR[31] * (0.29399783430587761 - (0.02238952856106585*fabs(bR[31])))); + inputSampleR -= (bR[32] * (0.26662219155294159 - (0.07760819463416335*fabs(bR[32])))); + inputSampleR -= (bR[33] * (0.20881206667122221 - (0.11930017354479640*fabs(bR[33])))); + inputSampleR -= (bR[34] * (0.12916658879944876 - (0.11798638949823513*fabs(bR[34])))); + inputSampleR -= (bR[35] * (0.07678815166012012 - (0.06826864734598684*fabs(bR[35])))); + inputSampleR -= (bR[36] * (0.08568505484529348 - (0.00510459741104792*fabs(bR[36])))); + inputSampleR -= (bR[37] * (0.13613615872486634 + (0.02288223583971244*fabs(bR[37])))); + inputSampleR -= (bR[38] * (0.17426657494209266 + (0.02723737220296440*fabs(bR[38])))); + inputSampleR -= (bR[39] * (0.17343619261009030 + (0.01412920547179825*fabs(bR[39])))); + inputSampleR -= (bR[40] * (0.14548368977428555 - (0.02640418940455951*fabs(bR[40])))); + inputSampleR -= (bR[41] * (0.10485295885802372 - (0.06334665781931498*fabs(bR[41])))); + inputSampleR -= (bR[42] * (0.06632268974717079 - (0.05960343688612868*fabs(bR[42])))); + inputSampleR -= (bR[43] * (0.06915692039882040 - (0.03541337869596061*fabs(bR[43])))); + inputSampleR -= (bR[44] * (0.11889611687783583 - (0.02250608307287119*fabs(bR[44])))); + inputSampleR -= (bR[45] * (0.14598456370320673 + (0.00280345943128246*fabs(bR[45])))); + inputSampleR -= (bR[46] * (0.12312084125613143 + (0.04947283933434576*fabs(bR[46])))); + inputSampleR -= (bR[47] * (0.11379940289994711 + (0.06590080966570636*fabs(bR[47])))); + inputSampleR -= (bR[48] * (0.12963290754003182 + (0.02597647654256477*fabs(bR[48])))); + inputSampleR -= (bR[49] * (0.12723837402978638 - (0.04942071966927938*fabs(bR[49])))); + inputSampleR -= (bR[50] * (0.09185015882996231 - (0.10420810015956679*fabs(bR[50])))); + inputSampleR -= (bR[51] * (0.04011592913036545 - (0.10234174227772008*fabs(bR[51])))); + inputSampleR += (bR[52] * (0.00992597785057113 + (0.05674042373836896*fabs(bR[52])))); + inputSampleR += (bR[53] * (0.04921452178306781 - (0.00222698867111080*fabs(bR[53])))); + inputSampleR += (bR[54] * (0.06096504883783566 - (0.04040426549982253*fabs(bR[54])))); + inputSampleR += (bR[55] * (0.04113530718724200 - (0.04190143593049960*fabs(bR[55])))); + inputSampleR += (bR[56] * (0.01292699017654650 - (0.01121994018532499*fabs(bR[56])))); + inputSampleR -= (bR[57] * (0.00437123132431870 - (0.02482497612289103*fabs(bR[57])))); + inputSampleR -= (bR[58] * (0.02090571264211918 - (0.03732746039260295*fabs(bR[58])))); + inputSampleR -= (bR[59] * (0.04749751678612051 - (0.02960060937328099*fabs(bR[59])))); + inputSampleR -= (bR[60] * (0.07675095194206227 - (0.02241927084099648*fabs(bR[60])))); + inputSampleR -= (bR[61] * (0.08879414028581609 - (0.01144281133042115*fabs(bR[61])))); + inputSampleR -= (bR[62] * (0.07378854974999530 + (0.02518742701599147*fabs(bR[62])))); + inputSampleR -= (bR[63] * (0.04677309194488959 + (0.08984657372223502*fabs(bR[63])))); + inputSampleR -= (bR[64] * (0.02911874044176449 + (0.14202665940555093*fabs(bR[64])))); + inputSampleR -= (bR[65] * (0.02103564720234969 + (0.14640411976171003*fabs(bR[65])))); + inputSampleR -= (bR[66] * (0.01940626429101940 + (0.10867274382865903*fabs(bR[66])))); + inputSampleR -= (bR[67] * (0.03965401793931531 + (0.04775225375522835*fabs(bR[67])))); + inputSampleR -= (bR[68] * (0.08102486457314527 - (0.03204447425666343*fabs(bR[68])))); + inputSampleR -= (bR[69] * (0.11794849372825778 - (0.12755667382696789*fabs(bR[69])))); + inputSampleR -= (bR[70] * (0.11946469076758266 - (0.20151394599125422*fabs(bR[70])))); + inputSampleR -= (bR[71] * (0.07404630324668053 - (0.21300634351769704*fabs(bR[71])))); + inputSampleR -= (bR[72] * (0.00477584437144086 - (0.16864707684978708*fabs(bR[72])))); + inputSampleR += (bR[73] * (0.05924822014377220 + (0.09394651445109450*fabs(bR[73])))); + inputSampleR += (bR[74] * (0.10060989907457370 + (0.00419196431884887*fabs(bR[74])))); + inputSampleR += (bR[75] * (0.10817907203844988 - (0.07459664480796091*fabs(bR[75])))); + inputSampleR += (bR[76] * (0.08701102204768002 - (0.11129477437630560*fabs(bR[76])))); + inputSampleR += (bR[77] * (0.05673785623180162 - (0.10638640242375266*fabs(bR[77])))); + inputSampleR += (bR[78] * (0.02944190197442081 - (0.08499792583420167*fabs(bR[78])))); + inputSampleR += (bR[79] * (0.01570145445652971 - (0.06190456843465320*fabs(bR[79])))); + inputSampleR += (bR[80] * (0.02770233032476748 - (0.04573713136865480*fabs(bR[80])))); + inputSampleR += (bR[81] * (0.05417160459175360 - (0.03965651064634598*fabs(bR[81])))); + inputSampleR += (bR[82] * (0.06080831637644498 - (0.02909500789113911*fabs(bR[82])))); + + temp = (inputSampleR + smoothCabBR)/3.0; + smoothCabBR = inputSampleR; + inputSampleR = temp/4.0; + + if (cycleEnd == 4) { + lastRefL[0] = lastRefL[4]; //start from previous last + lastRefL[2] = (lastRefL[0] + inputSampleL)/2; //half + lastRefL[1] = (lastRefL[0] + lastRefL[2])/2; //one quarter + lastRefL[3] = (lastRefL[2] + inputSampleL)/2; //three quarters + lastRefL[4] = inputSampleL; //full + lastRefR[0] = lastRefR[4]; //start from previous last + lastRefR[2] = (lastRefR[0] + inputSampleR)/2; //half + lastRefR[1] = (lastRefR[0] + lastRefR[2])/2; //one quarter + lastRefR[3] = (lastRefR[2] + inputSampleR)/2; //three quarters + lastRefR[4] = inputSampleR; //full + } + if (cycleEnd == 3) { + lastRefL[0] = lastRefL[3]; //start from previous last + lastRefL[2] = (lastRefL[0]+lastRefL[0]+inputSampleL)/3; //third + lastRefL[1] = (lastRefL[0]+inputSampleL+inputSampleL)/3; //two thirds + lastRefL[3] = inputSampleL; //full + lastRefR[0] = lastRefR[3]; //start from previous last + lastRefR[2] = (lastRefR[0]+lastRefR[0]+inputSampleR)/3; //third + lastRefR[1] = (lastRefR[0]+inputSampleR+inputSampleR)/3; //two thirds + lastRefR[3] = inputSampleR; //full + } + if (cycleEnd == 2) { + lastRefL[0] = lastRefL[2]; //start from previous last + lastRefL[1] = (lastRefL[0] + inputSampleL)/2; //half + lastRefL[2] = inputSampleL; //full + lastRefR[0] = lastRefR[2]; //start from previous last + lastRefR[1] = (lastRefR[0] + inputSampleR)/2; //half + lastRefR[2] = inputSampleR; //full + } + if (cycleEnd == 1) { + lastRefL[0] = inputSampleL; + lastRefR[0] = inputSampleR; + } + cycle = 0; //reset + inputSampleL = lastRefL[cycle]; + inputSampleR = lastRefR[cycle]; + } else { + inputSampleL = lastRefL[cycle]; + inputSampleR = lastRefR[cycle]; + //we are going through our references now + } + switch (cycleEnd) //multi-pole average using lastRef[] variables on BigAmp channel only + { + case 4: + lastRefL[8] = inputSampleL; inputSampleL = (inputSampleL+lastRefL[7])*0.5; + lastRefL[7] = lastRefL[8]; //continue, do not break + case 3: + lastRefL[8] = inputSampleL; inputSampleL = (inputSampleL+lastRefL[6])*0.5; + lastRefL[6] = lastRefL[8]; //continue, do not break + case 2: + lastRefL[8] = inputSampleL; inputSampleL = (inputSampleL+lastRefL[5])*0.5; + lastRefL[5] = lastRefL[8]; //continue, do not break + case 1: + break; //no further averaging + } + + inputSampleR = (inputSampleL*0.5)+(inputSampleR*0.5); + + if (inputSampleR > 4.0) inputSampleR = 4.0; if (inputSampleR < -4.0) inputSampleR = -4.0; + if (wasPosClipR == true) { //current will be over + if (inputSampleR0.9549925859) {wasPosClipR=true;inputSampleR=0.7058208+(lastSampleR*0.2609148);} + if (wasNegClipR == true) { //current will be -over + if (inputSampleR > lastSampleR) lastSampleR=-0.7058208+(inputSampleR*0.2609148); + else lastSampleR=-0.2491717+(lastSampleR*0.7390851); + } wasNegClipR = false; + if (inputSampleR<-0.9549925859) {wasNegClipR=true;inputSampleR=-0.7058208+(lastSampleR*0.2609148);} + intermediateR[cycleEnd] = inputSampleR; + inputSampleR = lastSampleR; //Latency is however many samples equals one 44.1k sample + for (int x = cycleEnd; x > 0; x--) intermediateR[x-1] = intermediateR[x]; + lastSampleR = intermediateR[0]; //run a little buffer to handle this + + inputSampleL = inputSampleR; + + //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)) * 1.1e-44l * pow(2,expon+62)); + //frexp((double)inputSampleR, &expon); + fpdR ^= fpdR << 13; fpdR ^= fpdR >> 17; fpdR ^= fpdR << 5; + //inputSampleR += ((double(fpdR)-uint32_t(0x7fffffff)) * 1.1e-44l * pow(2,expon+62)); + //end 64 bit stereo floating point dither + + *out1 = inputSampleL; + *out2 = inputSampleR; + + in1++; + in2++; + out1++; + out2++; + } +} +} // end namespace diff --git a/src/autogen_airwin/ResEQ2.cpp b/src/autogen_airwin/ResEQ2.cpp new file mode 100644 index 0000000..e64fae2 --- /dev/null +++ b/src/autogen_airwin/ResEQ2.cpp @@ -0,0 +1,127 @@ +/* ======================================== + * ResEQ2 - ResEQ2.h + * Copyright (c) airwindows, Airwindows uses the MIT license + * ======================================== */ + +#ifndef __ResEQ2_H +#include "ResEQ2.h" +#endif +namespace airwin2rack::ResEQ2 { + +AudioEffect* createEffectInstance(audioMasterCallback audioMaster) {return new ResEQ2(audioMaster);} + +ResEQ2::ResEQ2(audioMasterCallback audioMaster) : + AudioEffectX(audioMaster, kNumPrograms, kNumParameters) +{ + A = 0.5; + B = 0.0; + + for(int count = 0; count < 2004; count++) {mpkL[count] = 0.0; mpkR[count] = 0.0;} + for(int count = 0; count < 65; count++) {f[count] = 0.0;} + prevfreqMPeak = -1; + prevamountMPeak = -1; + mpc = 1; + + fpdL = 1.0; while (fpdL < 16386) fpdL = rand()*UINT32_MAX; + fpdR = 1.0; while (fpdR < 16386) fpdR = rand()*UINT32_MAX; + //this is reset: values being initialized only once. Startup values, whatever they are. + + _canDo.insert("plugAsChannelInsert"); // plug-in can be used as a channel insert effect. + _canDo.insert("plugAsSend"); // plug-in can be used as a send effect. + _canDo.insert("x2in2out"); + setNumInputs(kNumInputs); + setNumOutputs(kNumOutputs); + setUniqueID(kUniqueId); + canProcessReplacing(); // supports output replacing + canDoubleReplacing(); // supports double precision processing + programsAreChunks(true); + vst_strncpy (_programName, "Default", kVstMaxProgNameLen); // default program name +} + +ResEQ2::~ResEQ2() {} +VstInt32 ResEQ2::getVendorVersion () {return 1000;} +void ResEQ2::setProgramName(char *name) {vst_strncpy (_programName, name, kVstMaxProgNameLen);} +void ResEQ2::getProgramName(char *name) {vst_strncpy (name, _programName, kVstMaxProgNameLen);} +//airwindows likes to ignore this stuff. Make your own programs, and make a different plugin rather than +//trying to do versioning and preventing people from using older versions. Maybe they like the old one! + +static float pinParameter(float data) +{ + if (data < 0.0f) return 0.0f; + if (data > 1.0f) return 1.0f; + return data; +} + +void ResEQ2::setParameter(VstInt32 index, float value) { + switch (index) { + case kParamA: A = value; break; + case kParamB: B = value; break; + default: break; // unknown parameter, shouldn't happen! + } +} + +float ResEQ2::getParameter(VstInt32 index) { + switch (index) { + case kParamA: return A; break; + case kParamB: return B; break; + default: break; // unknown parameter, shouldn't happen! + } return 0.0; //we only need to update the relevant name, this is simple to manage +} + +void ResEQ2::getParameterName(VstInt32 index, char *text) { + switch (index) { + case kParamA: vst_strncpy (text, "MSweep", kVstMaxParamStrLen); break; + case kParamB: vst_strncpy (text, "MBoost", kVstMaxParamStrLen); break; + default: break; // unknown parameter, shouldn't happen! + } //this is our labels for displaying in the VST host +} + +void ResEQ2::getParameterDisplay(VstInt32 index, char *text) { + switch (index) { + case kParamA: float2string (A, text, kVstMaxParamStrLen); break; + case kParamB: float2string (B, text, kVstMaxParamStrLen); break; + default: break; // unknown parameter, shouldn't happen! + } //this displays the values and handles 'popups' where it's discrete choices +} + +void ResEQ2::getParameterLabel(VstInt32 index, char *text) { + switch (index) { + case kParamA: vst_strncpy (text, "", kVstMaxParamStrLen); break; + case kParamB: vst_strncpy (text, "", kVstMaxParamStrLen); break; + default: break; // unknown parameter, shouldn't happen! + } +} + +VstInt32 ResEQ2::canDo(char *text) +{ return (_canDo.find(text) == _canDo.end()) ? -1: 1; } // 1 = yes, -1 = no, 0 = don't know + +bool ResEQ2::getEffectName(char* name) { + vst_strncpy(name, "ResEQ2", kVstMaxProductStrLen); return true; +} + +VstPlugCategory ResEQ2::getPlugCategory() {return kPlugCategEffect;} + +bool ResEQ2::getProductString(char* text) { + vst_strncpy (text, "airwindows ResEQ2", kVstMaxProductStrLen); return true; +} + +bool ResEQ2::getVendorString(char* text) { + vst_strncpy (text, "airwindows", kVstMaxVendorStrLen); return true; +} +bool ResEQ2::parameterTextToValue(VstInt32 index, const char *text, float &value) { + switch(index) { + case kParamA: { auto b = string2float(text, value); return b; break; } + case kParamB: { auto b = string2float(text, value); return b; break; } + + } + return false; +} +bool ResEQ2::canConvertParameterTextToValue(VstInt32 index) { + switch(index) { + case kParamA: return true; + case kParamB: return true; + + } + return false; +} +} // end namespace diff --git a/src/autogen_airwin/ResEQ2.h b/src/autogen_airwin/ResEQ2.h new file mode 100644 index 0000000..c30652f --- /dev/null +++ b/src/autogen_airwin/ResEQ2.h @@ -0,0 +1,74 @@ +/* ======================================== + * ResEQ2 - ResEQ2.h + * Created 8/12/11 by SPIAdmin + * Copyright (c) Airwindows, Airwindows uses the MIT license + * ======================================== */ + +#ifndef __ResEQ2_ResEQ2_H +#define __ResEQ2_ResEQ2_H + +#ifndef __audioeffect__ +#include "../airwin2rackbase.h" +#endif + +#include +#include +#include + +namespace airwin2rack::ResEQ2 { +enum { + kParamA = 0, + kParamB = 1, + kNumParameters = 2 +}; // + +const int kNumPrograms = 0; +const int kNumInputs = 2; +const int kNumOutputs = 2; +const unsigned long kUniqueId = 'resp'; //Change this to what the AU identity is! + +class ResEQ2 : + public AudioEffectX +{ +public: + ResEQ2(audioMasterCallback audioMaster); + ~ResEQ2(); + virtual bool getEffectName(char* name); // The plug-in name + virtual VstPlugCategory getPlugCategory(); // The general category for the plug-in + virtual bool getProductString(char* text); // This is a unique plug-in string provided by Steinberg + virtual bool getVendorString(char* text); // Vendor info + virtual VstInt32 getVendorVersion(); // Version number + virtual void processReplacing (float** inputs, float** outputs, VstInt32 sampleFrames); + virtual void processDoubleReplacing (double** inputs, double** outputs, VstInt32 sampleFrames); + virtual void getProgramName(char *name); // read the name from the host + virtual void setProgramName(char *name); // changes the name of the preset displayed in the host + virtual float getParameter(VstInt32 index); // get the parameter value at the specified index + virtual void setParameter(VstInt32 index, float value); // set the parameter at index to value + virtual void getParameterLabel(VstInt32 index, char *text); // label for the parameter (eg dB) + virtual void getParameterName(VstInt32 index, char *text); // name of the parameter + virtual void getParameterDisplay(VstInt32 index, char *text); // text description of the current value + // Added by the perl as inverses + virtual bool parameterTextToValue(VstInt32 index, const char *text, float &value); + virtual bool canConvertParameterTextToValue(VstInt32 index); + virtual VstInt32 canDo(char *text); +private: + char _programName[kVstMaxProgNameLen + 1]; + std::set< std::string > _canDo; + + double mpkL[2005]; + double mpkR[2005]; + double f[66]; + double prevfreqMPeak; + double prevamountMPeak; + int mpc; + + uint32_t fpdL; + uint32_t fpdR; + //default stuff + + float A; + float B; +}; + +#endif +} // end namespace diff --git a/src/autogen_airwin/ResEQ2Proc.cpp b/src/autogen_airwin/ResEQ2Proc.cpp new file mode 100644 index 0000000..6e20d93 --- /dev/null +++ b/src/autogen_airwin/ResEQ2Proc.cpp @@ -0,0 +1,196 @@ +/* ======================================== + * ResEQ2 - ResEQ2.h + * Copyright (c) airwindows, Airwindows uses the MIT license + * ======================================== */ + +#ifndef __ResEQ2_H +#include "ResEQ2.h" +#endif +namespace airwin2rack::ResEQ2 { + +void ResEQ2::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 cycleEnd = floor(overallscale); + if (cycleEnd < 1) cycleEnd = 1; + if (cycleEnd > 4) cycleEnd = 4; + //this is going to be 2 for 88.1 or 96k, 3 for silly people, 4 for 176 or 192k + + //begin ResEQ2 Mid Boost + double freqMPeak = pow(A+0.15,3); + double amountMPeak = pow(B,2); + int maxMPeak = (amountMPeak*63.0)+1; + if ((freqMPeak != prevfreqMPeak)||(amountMPeak != prevamountMPeak)) { + for (int x = 0; x < maxMPeak; x++) { + if (((double)x*freqMPeak) < M_PI_4) f[x] = sin(((double)x*freqMPeak)*4.0)*freqMPeak*sin(((double)(maxMPeak-x)/(double)maxMPeak)*M_PI_2); + else f[x] = cos((double)x*freqMPeak)*freqMPeak*sin(((double)(maxMPeak-x)/(double)maxMPeak)*M_PI_2); + } + prevfreqMPeak = freqMPeak; prevamountMPeak = amountMPeak; + }//end ResEQ2 Mid Boost + + 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; + + //begin ResEQ2 Mid Boost + mpc++; if (mpc < 1 || mpc > 2001) mpc = 1; + mpkL[mpc] = inputSampleL; + mpkR[mpc] = inputSampleR; + double midMPeakL = 0.0; + double midMPeakR = 0.0; + for (int x = 0; x < maxMPeak; x++) { + int y = x*cycleEnd; + switch (cycleEnd) + { + case 1: + midMPeakL += (mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x]); + midMPeakR += (mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x]); break; + case 2: + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.5); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.5); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.5); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.5); break; + case 3: + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); break; + case 4: + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); //break + } + } + inputSampleL = (midMPeakL*amountMPeak)+((1.5-amountMPeak>1.0)?inputSampleL:inputSampleL*(1.5-amountMPeak)); + inputSampleR = (midMPeakR*amountMPeak)+((1.5-amountMPeak>1.0)?inputSampleR:inputSampleR*(1.5-amountMPeak)); + //end ResEQ2 Mid Boost + + //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)) * 5.5e-36l * pow(2,expon+62)); + frexpf((float)inputSampleR, &expon); + fpdR ^= fpdR << 13; fpdR ^= fpdR >> 17; fpdR ^= fpdR << 5; + inputSampleR += ((double(fpdR)-uint32_t(0x7fffffff)) * 5.5e-36l * pow(2,expon+62)); + //end 32 bit stereo floating point dither + + *out1 = inputSampleL; + *out2 = inputSampleR; + + in1++; + in2++; + out1++; + out2++; + } +} + +void ResEQ2::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 cycleEnd = floor(overallscale); + if (cycleEnd < 1) cycleEnd = 1; + if (cycleEnd > 4) cycleEnd = 4; + //this is going to be 2 for 88.1 or 96k, 3 for silly people, 4 for 176 or 192k + + //begin ResEQ2 Mid Boost + double freqMPeak = pow(A+0.15,3); + double amountMPeak = pow(B,2); + int maxMPeak = (amountMPeak*63.0)+1; + if ((freqMPeak != prevfreqMPeak)||(amountMPeak != prevamountMPeak)) { + for (int x = 0; x < maxMPeak; x++) { + if (((double)x*freqMPeak) < M_PI_4) f[x] = sin(((double)x*freqMPeak)*4.0)*freqMPeak*sin(((double)(maxMPeak-x)/(double)maxMPeak)*M_PI_2); + else f[x] = cos((double)x*freqMPeak)*freqMPeak*sin(((double)(maxMPeak-x)/(double)maxMPeak)*M_PI_2); + } + prevfreqMPeak = freqMPeak; prevamountMPeak = amountMPeak; + }//end ResEQ2 Mid Boost + + 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; + + //begin ResEQ2 Mid Boost + mpc++; if (mpc < 1 || mpc > 2001) mpc = 1; + mpkL[mpc] = inputSampleL; + mpkR[mpc] = inputSampleR; + double midMPeakL = 0.0; + double midMPeakR = 0.0; + for (int x = 0; x < maxMPeak; x++) { + int y = x*cycleEnd; + switch (cycleEnd) + { + case 1: + midMPeakL += (mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x]); + midMPeakR += (mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x]); break; + case 2: + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.5); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.5); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.5); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.5); break; + case 3: + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.333); break; + case 4: + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); y--; + midMPeakL += ((mpkL[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); + midMPeakR += ((mpkR[(mpc-y)+((mpc-y < 1)?2001:0)] * f[x])*0.25); //break + } + } + inputSampleL = (midMPeakL*amountMPeak)+((1.5-amountMPeak>1.0)?inputSampleL:inputSampleL*(1.5-amountMPeak)); + inputSampleR = (midMPeakR*amountMPeak)+((1.5-amountMPeak>1.0)?inputSampleR:inputSampleR*(1.5-amountMPeak)); + //end ResEQ2 Mid Boost + + //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)) * 1.1e-44l * pow(2,expon+62)); + //frexp((double)inputSampleR, &expon); + fpdR ^= fpdR << 13; fpdR ^= fpdR >> 17; fpdR ^= fpdR << 5; + //inputSampleR += ((double(fpdR)-uint32_t(0x7fffffff)) * 1.1e-44l * pow(2,expon+62)); + //end 64 bit stereo floating point dither + + *out1 = inputSampleL; + *out2 = inputSampleR; + + in1++; + in2++; + out1++; + out2++; + } +} +} // end namespace