Home Information Classes Download Usage Mail List Requirements Links FAQ Tutorial
STK non-interpolating delay line class. More...
#include <Delay.h>
Public Member Functions | |
Delay (unsigned long delay=0, unsigned long maxDelay=4095) | |
The default constructor creates a delay-line with maximum length of 4095 samples and zero delay. | |
~Delay () | |
Class destructor. | |
void | setMaximumDelay (unsigned long delay) |
Set the maximum delay-line length. | |
void | setDelay (unsigned long delay) |
Set the delay-line length. | |
unsigned long | getDelay (void) const |
Return the current delay-line length. | |
StkFloat | contentsAt (unsigned long tapDelay) |
Return the value at tapDelay samples from the delay-line input. | |
StkFloat | addTo (unsigned long tapDelay, StkFloat value) |
Sum the provided value into the delay line at tapDelay samples from the input. | |
StkFloat | lastOut (void) const |
Return the last computed output value. | |
StkFloat | nextOut (void) |
Return the value that will be output by the next call to tick(). | |
StkFloat | energy (void) const |
Calculate and return the signal energy in the delay-line. | |
StkFloat | tick (StkFloat input) |
Input one sample to the filter and return one output. | |
StkFrames & | tick (StkFrames &frames, unsigned int channel=0) |
Take a channel of the StkFrames object as inputs to the filter and replace with corresponding outputs. | |
StkFrames & | tick (StkFrames &iFrames, StkFrames &oFrames, unsigned int iChannel=0, unsigned int oChannel=0) |
Take a channel of the iFrames object as inputs to the filter and write outputs to the oFrames object. |
STK non-interpolating delay line class.
This class implements a non-interpolating digital delay-line. If the delay and maximum length are not specified during instantiation, a fixed maximum length of 4095 and a delay of zero is set.
A non-interpolating delay line is typically used in fixed delay-length applications, such as for reverberation.
by Perry R. Cook and Gary P. Scavone, 1995 - 2010.
stk::Delay::Delay | ( | unsigned long | delay = 0 , |
|
unsigned long | maxDelay = 4095 | |||
) |
The default constructor creates a delay-line with maximum length of 4095 samples and zero delay.
An StkError will be thrown if the delay parameter is less than zero, the maximum delay parameter is less than one, or the delay parameter is greater than the maxDelay value.
void stk::Delay::setMaximumDelay | ( | unsigned long | delay | ) |
Set the maximum delay-line length.
This method should generally only be used during initial setup of the delay line. If it is used between calls to the tick() function, without a call to clear(), a signal discontinuity will likely occur. If the current maximum length is greater than the new length, no change will be made.
void stk::Delay::setDelay | ( | unsigned long | delay | ) |
Set the delay-line length.
The valid range for delay is from 0 to the maximum delay-line length.
StkFloat stk::Delay::contentsAt | ( | unsigned long | tapDelay | ) |
Return the value at tapDelay samples from the delay-line input.
The tap point is determined modulo the delay-line length and is relative to the last input value (i.e., a tapDelay of zero returns the last input value).
StkFloat stk::Delay::addTo | ( | unsigned long | tapDelay, | |
StkFloat | value | |||
) |
Sum the provided value into the delay line at tapDelay samples from the input.
The new value is returned. The tap point is determined modulo the delay-line length and is relative to the last input value (i.e., a tapDelay of zero sums into the last input value).
StkFloat stk::Delay::nextOut | ( | void | ) | [inline] |
Return the value that will be output by the next call to tick().
This method is valid only for delay settings greater than zero!
Take a channel of the StkFrames object as inputs to the filter and replace with corresponding outputs.
The StkFrames argument reference is returned. The channel
argument must be less than the number of channels in 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.
Implements stk::Filter.
StkFrames & stk::Delay::tick | ( | StkFrames & | iFrames, | |
StkFrames & | oFrames, | |||
unsigned int | iChannel = 0 , |
|||
unsigned int | oChannel = 0 | |||
) | [inline] |
Take a channel of the iFrames
object as inputs to the filter and write outputs to the oFrames
object.
The iFrames
object reference is returned. Each channel argument must be less than the number of channels in the corresponding 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.
The Synthesis ToolKit in C++ (STK) |
©1995-2010 Perry R. Cook and Gary P. Scavone. All Rights Reserved. |