Home Information Classes Download Usage Mail List Requirements Links FAQ Tutorial
Jezar at Dreampoint's FreeVerb, implemented in STK. More...
#include <FreeVerb.h>
Public Member Functions | |
FreeVerb () | |
FreeVerb Constructor. | |
~FreeVerb () | |
Destructor. | |
void | setEffectMix (StkFloat mix) |
Set the effect mix [0 = mostly dry, 1 = mostly wet]. | |
void | setRoomSize (StkFloat value) |
Set the room size (comb filter feedback gain) parameter [0,1]. | |
StkFloat | getRoomSize (void) |
Get the room size (comb filter feedback gain) parameter. | |
void | setDamping (StkFloat value) |
Set the damping parameter [0=low damping, 1=higher damping]. | |
StkFloat | getDamping (void) |
Get the damping parameter. | |
void | setWidth (StkFloat value) |
Set the width (left-right mixing) parameter [0,1]. | |
StkFloat | getWidth (void) |
Get the width (left-right mixing) parameter. | |
void | setMode (bool isFrozen) |
Set the mode [frozen = 1, unfrozen = 0]. | |
StkFloat | getMode (void) |
Get the current freeze mode [frozen = 1, unfrozen = 0]. | |
void | clear (void) |
Clears delay lines, etc. | |
StkFloat | lastOut (unsigned int channel=0) |
Return the specified channel value of the last computed stereo frame. | |
StkFloat | tick (StkFloat inputL, StkFloat inputR=0.0, unsigned int channel=0) |
Input one or two samples to the effect and return the specified channel value of the computed stereo frame. | |
StkFrames & | tick (StkFrames &frames, unsigned int channel=0) |
Take two channels of the StkFrames object as inputs to the effect and replace with stereo outputs. | |
StkFrames & | tick (StkFrames &iFrames, StkFrames &oFrames, unsigned int iChannel=0, unsigned int oChannel=0) |
Take one or two channels of the iFrames object as inputs to the effect and write stereo outputs to the oFrames object. | |
Public Member Functions inherited from stk::Effect | |
Effect (void) | |
Class constructor. | |
unsigned int | channelsOut (void) const |
Return the number of output channels for the class. | |
const StkFrames & | lastFrame (void) const |
Return an StkFrames reference to the last output sample frame. | |
virtual void | clear ()=0 |
Reset and clear all internal state. | |
virtual void | setEffectMix (StkFloat mix) |
Set the mixture of input and "effected" levels in the output (0.0 = input only, 1.0 = effect only). | |
Public Member Functions inherited from stk::Stk | |
void | ignoreSampleRateChange (bool ignore=true) |
A function to enable/disable the automatic updating of class data when the STK sample rate changes. | |
Protected Member Functions | |
void | update (void) |
Update interdependent parameters. | |
Protected Member Functions inherited from stk::Stk | |
Stk (void) | |
Default constructor. | |
virtual | ~Stk (void) |
Class destructor. | |
virtual void | sampleRateChanged (StkFloat newRate, StkFloat oldRate) |
This function should be implemented in subclasses that depend on the sample rate. | |
void | addSampleRateAlert (Stk *ptr) |
Add class pointer to list for sample rate change notification. | |
void | removeSampleRateAlert (Stk *ptr) |
Remove class pointer from list for sample rate change notification. | |
void | handleError (StkError::Type type) const |
Internal function for error reporting that assumes message in oStream_ variable. | |
Additional Inherited Members | |
Static Public Member Functions inherited from stk::Stk | |
static StkFloat | sampleRate (void) |
Static method that returns the current STK sample rate. | |
static void | setSampleRate (StkFloat rate) |
Static method that sets the STK sample rate. | |
static void | clear_alertList () |
Static method that frees memory from alertList_. | |
static std::string | rawwavePath (void) |
Static method that returns the current rawwave path. | |
static void | setRawwavePath (std::string path) |
Static method that sets the STK rawwave path. | |
static void | swap16 (unsigned char *ptr) |
Static method that byte-swaps a 16-bit data type. | |
static void | swap32 (unsigned char *ptr) |
Static method that byte-swaps a 32-bit data type. | |
static void | swap64 (unsigned char *ptr) |
Static method that byte-swaps a 64-bit data type. | |
static void | sleep (unsigned long milliseconds) |
Static cross-platform method to sleep for a number of milliseconds. | |
static bool | inRange (StkFloat value, StkFloat min, StkFloat max) |
Static method to check whether a value is within a specified range. | |
static void | handleError (const char *message, StkError::Type type) |
Static function for error reporting and handling using c-strings. | |
static void | handleError (std::string message, StkError::Type type) |
Static function for error reporting and handling using c++ strings. | |
static void | showWarnings (bool status) |
Toggle display of WARNING and STATUS messages. | |
static void | printErrors (bool status) |
Toggle display of error messages before throwing exceptions. | |
Static Public Attributes inherited from stk::Stk | |
static const StkFormat | STK_SINT8 |
static const StkFormat | STK_SINT16 |
static const StkFormat | STK_SINT24 |
static const StkFormat | STK_SINT32 |
static const StkFormat | STK_FLOAT32 |
static const StkFormat | STK_FLOAT64 |
Jezar at Dreampoint's FreeVerb, implemented in STK.
Freeverb is a free and open-source Schroeder reverberator originally implemented in C++. The parameters of the reverberation model are exceptionally well tuned. FreeVerb uses 8 lowpass-feedback-comb-filters in parallel, followed by 4 Schroeder allpass filters in series. The input signal can be either mono or stereo, and the output signal is stereo. The delay lengths are optimized for a sample rate of 44100 Hz.
Ported to STK by Gregory Burlet, 2012.
stk::FreeVerb::FreeVerb | ( | ) |
|
inline |
Return the specified channel value of the last computed stereo frame.
Use the lastFrame() function to get both values of the last computed stereo frame. The channel
argument must be 0 or 1 (the first channel is specified by 0). However, range checking is only performed if STK_DEBUG is defined during compilation, in which case an out-of-range value will trigger an StkError exception.
|
inline |
Input one or two samples to the effect and return the specified channel
value of the computed stereo frame.
Use the lastFrame() function to get both values of the computed stereo output frame. The channel
argument must be 0 or 1 (the first channel is specified by 0). However, range checking is only performed if STK_DEBUG is defined during compilation, in which case an out-of-range value will trigger an StkError exception.
Take two channels of the StkFrames object as inputs to the effect and replace with stereo outputs.
The StkFrames argument reference is returned. The stereo inputs are taken from (and written back to) the StkFrames argument starting at the specified channel
. Therefore, the channel
argument must be less than ( channels() - 1 ) of the StkFrames argument (the first channel is specified by 0). However, range checking is only performed if STK_DEBUG is defined during compilation, in which case an out-of-range value will trigger an StkError exception.
StkFrames & stk::FreeVerb::tick | ( | StkFrames & | iFrames, |
StkFrames & | oFrames, | ||
unsigned int | iChannel = 0 , |
||
unsigned int | oChannel = 0 |
||
) |
Take one or two channels of the iFrames
object as inputs to the effect and write stereo outputs to the oFrames
object.
The iFrames
object reference is returned. The iChannel
argument must be less than the number of channels in the iFrames
argument (the first channel is specified by 0). If more than one channel of data exists in iFrames
starting from iChannel
, stereo data is input to the effect. The oChannel
argument must be less than ( channels() - 1 ) of the oFrames
argument. However, range checking is only performed if STK_DEBUG is defined during compilation, in which case an out-of-range value will trigger an StkError exception.
The Synthesis ToolKit in C++ (STK) |
©1995--2023 Perry R. Cook and Gary P. Scavone. All Rights Reserved. |