// Copyright 2013 Olivier Gillet. // // Author: Olivier Gillet (ol.gillet@gmail.com) // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. // // See http://creativecommons.org/licenses/MIT/ for more information. // // ----------------------------------------------------------------------------- // // 808-style HH. #include "peaks/drums/high_hat.h" #include #include "stmlib/utils/dsp.h" #include "stmlib/utils/random.h" #include "peaks/resources.h" namespace peaks { using namespace stmlib; void HighHat::Init() { noise_.Init(); noise_.set_frequency(105 << 7); // 8kHz noise_.set_resonance(24000); noise_.set_mode(SVF_MODE_BP); vca_coloration_.Init(); vca_coloration_.set_frequency(110 << 7); // 13kHz vca_coloration_.set_resonance(0); vca_coloration_.set_mode(SVF_MODE_HP); vca_envelope_.Init(); vca_envelope_.set_delay(0); vca_envelope_.set_decay(4093); } int16_t HighHat::ProcessSingleSample(uint8_t control) { if (control & CONTROL_GATE_RISING) { vca_envelope_.Trigger(32768 * 15); } phase_[0] += 48318382; phase_[1] += 71582788; phase_[2] += 37044092; phase_[3] += 54313440; phase_[4] += 66214079; phase_[5] += 93952409; int16_t noise = 0; noise += phase_[0] >> 31; noise += phase_[1] >> 31; noise += phase_[2] >> 31; noise += phase_[3] >> 31; noise += phase_[4] >> 31; noise += phase_[5] >> 31; noise <<= 12; // Run the SVF at the double of the original sample rate for stability. int32_t filtered_noise = 0; filtered_noise += noise_.Process(noise); filtered_noise += noise_.Process(noise); // The 808-style VCA amplifies only the positive section of the signal. if (filtered_noise < 0) { filtered_noise = 0; } else if (filtered_noise > 32767) { filtered_noise = 32767; } int32_t envelope = vca_envelope_.Process() >> 4; int32_t vca_noise = envelope * filtered_noise >> 14; CLIP(vca_noise); int32_t hh = 0; hh += vca_coloration_.Process(vca_noise); hh += vca_coloration_.Process(vca_noise); hh <<= 1; CLIP(hh); return hh; } } // namespace peaks