Files
stk/include/Modal.h
Gary Scavone a6381b9d38 Version 4.2.0
2013-09-29 23:06:14 +02:00

103 lines
2.8 KiB
C++

/***************************************************/
/*! \class Modal
\brief STK resonance model instrument.
This class contains an excitation wavetable,
an envelope, an oscillator, and N resonances
(non-sweeping BiQuad filters), where N is set
during instantiation.
by Perry R. Cook and Gary P. Scavone, 1995 - 2004.
*/
/***************************************************/
#ifndef STK_MODAL_H
#define STK_MODAL_H
#include "Instrmnt.h"
#include "Envelope.h"
#include "WaveLoop.h"
#include "BiQuad.h"
#include "OnePole.h"
class Modal : public Instrmnt
{
public:
//! Class constructor, taking the desired number of modes to create.
/*!
An StkError will be thrown if the rawwave path is incorrectly set.
*/
Modal( unsigned int modes = 4 );
//! Class destructor.
virtual ~Modal();
//! Reset and clear all internal state.
void clear();
//! Set instrument parameters for a particular frequency.
virtual void setFrequency(StkFloat frequency);
//! Set the ratio and radius for a specified mode filter.
void setRatioAndRadius(unsigned int modeIndex, StkFloat ratio, StkFloat radius);
//! Set the master gain.
void setMasterGain(StkFloat aGain);
//! Set the direct gain.
void setDirectGain(StkFloat aGain);
//! Set the gain for a specified mode filter.
void setModeGain(unsigned int modeIndex, StkFloat gain);
//! Initiate a strike with the given amplitude (0.0 - 1.0).
virtual void strike(StkFloat amplitude);
//! Damp modes with a given decay factor (0.0 - 1.0).
void damp(StkFloat amplitude);
//! Start a note with the given frequency and amplitude.
void noteOn(StkFloat frequency, StkFloat amplitude);
//! Stop a note with the given amplitude (speed of decay).
void noteOff(StkFloat amplitude);
//! Compute one output sample.
virtual StkFloat tick();
//! Computer \e vectorSize outputs and return them in \e vector.
virtual StkFloat *tick(StkFloat *vector, unsigned int vectorSize);
//! Fill a channel of the StkFrames object with computed outputs.
/*!
The \c channel argument should be one or greater (the first
channel is specified by 1). An StkError will be thrown if the \c
channel argument is zero or it is greater than the number of
channels in the StkFrames object.
*/
virtual StkFrames& tick( StkFrames& frames, unsigned int channel = 1 );
//! Perform the control change specified by \e number and \e value (0.0 - 128.0).
virtual void controlChange(int number, StkFloat value) = 0;
protected:
Envelope envelope_;
WvIn *wave_;
BiQuad **filters_;
OnePole onepole_;
WaveLoop *vibrato_;
unsigned int nModes_;
std::vector<StkFloat> ratios_;
std::vector<StkFloat> radii_;
StkFloat vibratoGain_;
StkFloat masterGain_;
StkFloat directGain_;
StkFloat stickHardness_;
StkFloat strikePosition_;
StkFloat baseFrequency_;
};
#endif