Mercurial > hg > beaglert
view examples/10-Instruments/airharp/Junction.cpp @ 464:8fcfbfb32aa0 prerelease
Examples reorder with subdirectories. Added header to each project. Moved Doxygen to bottom of render.cpp.
author | Robert Jack <robert.h.jack@gmail.com> |
---|---|
date | Mon, 20 Jun 2016 16:20:38 +0100 |
parents | |
children |
line wrap: on
line source
/* * * Excitation Junction for two waveguides * * Christian Heinrichs 04/2015 * */ #include "Junction.h" #include "../include/Utilities.h" Junction::Junction() { setFrequency(440); _dt = 1.0/44100.0; // initialize variables for(int i=0;i<WG_BUFFER_SIZE;i++) { _buffer_l[i] = 0; _buffer_r[i] = 0; } _excitation = 0; _lastPlectrumDisplacement = 0; _readPtr = 0; } void Junction::update(float excitation, float left, float right) { // 1. advance delay buffer read pointer if(++_readPtr>=WG_BUFFER_SIZE) _readPtr=0; // 2. add excitation sample into buffer _buffer_l[(_readPtr+_delay_l+WG_BUFFER_SIZE)%WG_BUFFER_SIZE] = excitation; _buffer_r[(_readPtr+_delay_r+WG_BUFFER_SIZE)%WG_BUFFER_SIZE] = excitation; // 3. feed right input to left output and vice versa _buffer_l[_readPtr] += right; _buffer_r[_readPtr] += left; // 4. store excitation value for later use _excitation = excitation; } float Junction::getOutput(int direction) { if(direction = 0) return _buffer_l[_readPtr]; else return _buffer_r[_readPtr]; } float Junction::getExcitationDisplacement() { // string displacement and excitation force // use delayed value to account for excitation position float in = _buffer_l[(_readPtr+_delay_l+WG_BUFFER_SIZE)%WG_BUFFER_SIZE] + _excitation; // integrate total force float out = 0.00001 * in + 0.99999 * _lastPlectrumDisplacement; // store variable for next iteration _lastPlectrumDisplacement = out; // multiply by delta time return out * _dt; } void Junction::setPluckPosition(float pluckPos){ pluckPos = constrain(pluckPos,0,1); _delay_l = pluckPos * _periodInSamples; _delay_r = (1-pluckPos) * _periodInSamples; } void Junction::setPeriod(float period) { _periodInMilliseconds = period; } void Junction::setFrequency(float frequency) { _periodInMilliseconds = 1000.0/frequency; _periodInSamples = (int)(_periodInMilliseconds * 44.1); }