mirror of
https://github.com/thestk/stk
synced 2026-01-11 20:11:52 +00:00
63 lines
1.5 KiB
C++
63 lines
1.5 KiB
C++
/*********************************************/
|
|
/* Bowed Bar model */
|
|
/* by Georg Essl, 1999 */
|
|
/* For details refer to: */
|
|
/* G.Essl, P.R.Cook: "Banded Waveguides: */
|
|
/* Towards Physical Modelling of Bar */
|
|
/* Percussion Instruments", ICMC'99 */
|
|
/*********************************************/
|
|
|
|
#if !defined(__BowedBar_h)
|
|
#define __BowedBar_h
|
|
|
|
#include "Instrmnt.h"
|
|
#include "DLineN.h"
|
|
#include "BowTabl.h"
|
|
#include "ADSR.h"
|
|
#include "BiQuad.h"
|
|
|
|
class BowedBar : public Instrmnt
|
|
{
|
|
protected:
|
|
BowTabl *bowTabl;
|
|
ADSR *adsr;
|
|
BiQuad *bandpass_;
|
|
|
|
MY_FLOAT maxVelocity;
|
|
MY_FLOAT modes[4];
|
|
DLineN delay[4];
|
|
float Zs[4][2];
|
|
MY_FLOAT coeffs[4][2];
|
|
float filtOut[4];
|
|
float filtIn[4];
|
|
MY_FLOAT filtGain[4];
|
|
MY_FLOAT freq;
|
|
int length;
|
|
MY_FLOAT R;
|
|
MY_FLOAT GAIN;
|
|
MY_FLOAT gains[4];
|
|
MY_FLOAT slope;
|
|
MY_FLOAT velinput;
|
|
MY_FLOAT integration_const_;
|
|
int trackVel;
|
|
MY_FLOAT bowvel, bowTarg, bowPos, lastBowPos;
|
|
int pluck_;
|
|
|
|
public:
|
|
BowedBar(MY_FLOAT lowestFreq=16);
|
|
~BowedBar();
|
|
void tuneBandPasses();
|
|
void clear();
|
|
void startBowing(MY_FLOAT amplitude,MY_FLOAT rate);
|
|
void stopBowing(MY_FLOAT rate);
|
|
void pluck(MY_FLOAT amp);
|
|
void setStrikePosition(MY_FLOAT position);
|
|
virtual void noteOn(MY_FLOAT freq, MY_FLOAT amp);
|
|
virtual void noteOff(MY_FLOAT amp);
|
|
virtual void setFreq(MY_FLOAT frequency);
|
|
virtual void controlChange(int number, MY_FLOAT value);
|
|
virtual MY_FLOAT tick();
|
|
};
|
|
|
|
#endif
|