CUGL 3.0
Cornell University Game Library
|
#include <CUAlgorithmicReverb.h>
Public Member Functions | |
AlgorithmicReverb () | |
~AlgorithmicReverb () | |
virtual bool | init () override |
virtual bool | init (Uint8 channels, Uint32 rate) override |
bool | init (const std::shared_ptr< AudioNode > &input) |
virtual void | dispose () override |
bool | attach (const std::shared_ptr< AudioNode > &node) |
std::shared_ptr< AudioNode > | detach () |
std::shared_ptr< AudioNode > | getInput () |
void | clear () |
virtual void | setReadSize (Uint32 size) override |
virtual Uint32 | read (float *buffer, Uint32 frames) override |
void | setRoomSize (float value) |
float | getRoomSize () |
void | setDamp (float value) |
float | getDamp () |
void | setWet (float value) |
float | getWet () |
void | setDry (float value) |
float | getDry () |
void | setWidth (float value) |
float | getWidth () |
void | setTail (double duration) |
double | getTail () |
virtual bool | completed () override |
virtual bool | mark () override |
virtual bool | unmark () override |
virtual bool | reset () override |
virtual Sint64 | advance (Uint32 frames) override |
virtual Sint64 | getPosition () const override |
virtual Sint64 | setPosition (Uint32 position) override |
virtual double | getElapsed () const override |
virtual double | setElapsed (double time) override |
virtual double | getRemaining () const override |
virtual double | setRemaining (double time) override |
Public Member Functions inherited from cugl::audio::AudioNode | |
AudioNode () | |
virtual | ~AudioNode () |
virtual bool | init () |
virtual bool | init (Uint8 channels, Uint32 rate) |
virtual void | dispose () |
Uint8 | getChannels () const |
Uint32 | getRate () const |
float | getGain () |
virtual void | setGain (float gain) |
Uint32 | getReadSize () const |
virtual void | setReadSize (Uint32 size) |
const std::string | getClassName () const |
const std::string | getName () const |
void | setName (const std::string name) |
Sint32 | getTag () const |
void | setTag (Sint32 tag) |
virtual std::string | toString (bool verbose=false) const |
operator std::string () const | |
Callback | getCallback () |
void | setCallback (Callback callback) |
virtual bool | isPaused () |
virtual bool | pause () |
virtual bool | resume () |
virtual bool | completed () |
virtual Uint32 | read (float *buffer, Uint32 frames) |
virtual bool | mark () |
virtual bool | unmark () |
virtual bool | reset () |
virtual Sint64 | advance (Uint32 frames) |
virtual Sint64 | getPosition () const |
virtual Sint64 | setPosition (Uint32 position) |
virtual double | getElapsed () const |
virtual double | setElapsed (double time) |
virtual double | getRemaining () const |
virtual double | setRemaining (double time) |
Static Public Member Functions | |
static std::shared_ptr< AlgorithmicReverb > | alloc () |
static std::shared_ptr< AlgorithmicReverb > | alloc (Uint8 channels, Uint32 rate) |
static std::shared_ptr< AlgorithmicReverb > | alloc (const std::shared_ptr< AudioNode > &input) |
Protected Member Functions | |
void | initFilter () |
Protected Member Functions inherited from cugl::audio::AudioNode | |
void | notify (const std::shared_ptr< AudioNode > &node, Action action) |
Protected Attributes | |
std::shared_ptr< AudioNode > | _input |
std::mutex | _mutex |
std::atomic< float > | _ingain |
std::atomic< float > | _wet |
std::atomic< float > | _dry |
std::atomic< float > | _roomsize |
std::atomic< float > | _damp |
std::atomic< float > | _width |
std::atomic< bool > | _dirty |
ATK_AlgoReverb * | _reverb |
Sint64 | _outmark |
Uint64 | _fadeout |
bool | _outdone |
Protected Attributes inherited from cugl::audio::AudioNode | |
Uint8 | _channels |
Uint32 | _sampling |
bool | _booted |
std::atomic< float > | _ndgain |
std::atomic< bool > | _paused |
std::atomic< bool > | _polling |
Callback | _callback |
std::atomic< bool > | _calling |
Sint32 | _tag |
Uint32 | _readsize |
std::string | _localname |
std::string | _classname |
size_t | _hashOfName |
bool | _locked |
Additional Inherited Members | |
Public Types inherited from cugl::audio::AudioNode | |
enum | Action : int { COMPLETE = 0 , INTERRUPT = 1 , FADE_OUT = 2 , FADE_IN = 3 , FADE_DIP = 4 , LOOPBACK = 5 } |
typedef std::function< void(const std::shared_ptr< AudioNode > &node, Action type)> | Callback |
Static Public Attributes inherited from cugl::audio::AudioNode | |
static const Uint32 | DEFAULT_CHANNELS |
static const Uint32 | DEFAULT_SAMPLING |
This class provides an algorithmic implementation of audio reverb.
The implementation is modeled after the the open source Schroeder reverberator, Freeverb. It is tunable with several attributes, including wet/dry mix, damping, and room size. All of attributes except tail should be between 0 and 1. More information about the algorithm can be found at:
https://ccrma.stanford.edu/~jos/pasp/Freeverb.html
cugl::audio::AlgorithmicReverb::AlgorithmicReverb | ( | ) |
Creates a degenerate reverb node with no associated input.
The node has no settings and so will not provide any reverb.
NEVER USE A CONSTRUCTOR WITH NEW. If you want to allocate a graph node on the heap, use one of the static constructors instead.
|
inline |
Deletes this node, disposing of all resources.
|
overridevirtual |
Advances the stream by the given number of frames.
DELEGATED METHOD: This method delegates its call to the input node. It returns -1 if there is no input node or if this method is unsupported in that node
This method only advances the read position, it does not actually read data into a buffer. This method is generally not supported for nodes with real-time input like AudioInput
.
frames | The number of frames to advace |
Reimplemented from cugl::audio::AudioNode.
|
inlinestatic |
Returns a newly allocated reverb with the default stereo settings
The number of channels is two, for stereo output. The sample rate is the modern standard of 48000 HZ. Any input node must agree with these settings.
The reverb will be set with the default settings as defined by the public domain FreeVerb algorithm.
|
inlinestatic |
Returns a newly allocated reverb for the given input node.
This node acquires the channels and sample rate of the input. If input is nullptr, this method will fail.
The reverb will be set with the default settings as defined by the public domain FreeVerb algorithm.
input | The audio node to fade |
|
inlinestatic |
Returns a newly allocated reverb with the given number of channels and sample rate
These values determine the buffer the structure for all read
operations. In addition, they also detemine whether this node can serve as an input to other nodes in the audio graph.
The reverb will be set with the default settings as defined by the public domain FreeVerb algorithm.
channels | The number of audio channels |
rate | The sample rate (frequency) in HZ |
bool cugl::audio::AlgorithmicReverb::attach | ( | const std::shared_ptr< AudioNode > & | node | ) |
Attaches an audio node to this reverb node.
This method will fail if the channels of the audio node do not agree with this node.
node | The audio node to add reverb to |
void cugl::audio::AlgorithmicReverb::clear | ( | ) |
Clears all filters in the reverb subgraph.
|
overridevirtual |
Returns true if this audio node has no more data.
An audio node is typically completed if it return 0 (no frames read) on subsequent calls to read()
. However, for infinite-running audio threads, it is possible for this method to return true even when data can still be read; in that case the node is notifying that it should be shut down.
Reimplemented from cugl::audio::AudioNode.
std::shared_ptr< AudioNode > cugl::audio::AlgorithmicReverb::detach | ( | ) |
Detaches an audio node from this reverb node.
If the method succeeds, it returns the audio node that was removed.
|
overridevirtual |
Disposes any resources allocated for this player
The state of the node is reset to that of an uninitialized constructor. Unlike the destructor, this method allows the node to be reinitialized.
Reimplemented from cugl::audio::AudioNode.
float cugl::audio::AlgorithmicReverb::getDamp | ( | ) |
Returns the damping associated with each comb filter.
This value should be between 0 and 1 for best effects.
float cugl::audio::AlgorithmicReverb::getDry | ( | ) |
Returns the dryness scale for the reverb.
This should be a value between 0 and 1. A value of 0 will mean that only the wet mix (reverb) is played.
|
overridevirtual |
Returns the elapsed time in seconds.
DELEGATED METHOD: This method delegates its call to the input node. It returns -1 if there is no input node or if this method is unsupported in that node
In some nodes like AudioInput
, this method is only supported if mark()
is set. In that case, the times will be the number of seconds since the mark. Other nodes like AudioPlayer
measure from the start of the stream.
Reimplemented from cugl::audio::AudioNode.
|
inline |
Returns the input node of this reverb node.
|
overridevirtual |
Returns the current frame position of this audio node
DELEGATED METHOD: This method delegates its call to the input node. It returns -1 if there is no input node or if this method is unsupported in that node
In some nodes like AudioInput
, this method is only supported if mark()
is set. In that case, the position will be the number of frames since the mark. Other nodes like AudioPlayer
measure from the start of the stream.
Reimplemented from cugl::audio::AudioNode.
|
overridevirtual |
Returns the remaining time in seconds.
DELEGATED METHOD: This method delegates its call to the input node. It returns -1 if there is no input node or if this method is unsupported in that node
In some nodes like AudioInput
, this method is only supported if setRemaining()
has been called. In that case, the node will be marked as completed after the given number of seconds. This may or may not actually move the read head. For example, in AudioPlayer
it will skip to the end of the sample. However, in AudioInput
it will simply time out after the given time.
Reimplemented from cugl::audio::AudioNode.
float cugl::audio::AlgorithmicReverb::getRoomSize | ( | ) |
Returns the room size associated with each comb filter.
This value should be between 0 and 1 for best effects.
double cugl::audio::AlgorithmicReverb::getTail | ( | ) |
Returns the fade-out tail for this reverb node
A reverb node is technically complete when its input node is complete. But for long enough echoes, this can cause the echo to be cut off. Therefore, it makes sense to add a tail where the echo is allowed to persist a little bit longer. This echo will linearly fade to 0 over the tail duration.
If this value is 0 or less, there will be no tail. You should not add a tail if you want this sound to be looped with the echo.
float cugl::audio::AlgorithmicReverb::getWet | ( | ) |
Returns the wetness scale for the reverb.
This should be a value between 0 and 1. A value of 0 will mean that no reverb is applied.
float cugl::audio::AlgorithmicReverb::getWidth | ( | ) |
Returns the width between the stereo channels
|
overridevirtual |
Initializes the node with default stereo settings
The number of channels is two, for stereo output. The sample rate is the modern standard of 48000 HZ.
These values determine the buffer the structure for all read
operations. In addition, they also detemine whether this node can serve as an input to other nodes in the audio graph.
The reverb will be set with the default settings as defined by the public domain FreeVerb algorithm.
Reimplemented from cugl::audio::AudioNode.
bool cugl::audio::AlgorithmicReverb::init | ( | const std::shared_ptr< AudioNode > & | input | ) |
Initializes reverb for the given input node.
This node acquires the channels and sample rate of the input. If input is nullptr, this method will fail.
The reverb will be set with the default settings as defined by the public domain FreeVerb algorithm.
input | The audio node to fade |
|
overridevirtual |
Initializes the node with the given number of channels and sample rate
These values determine the buffer the structure for all read
operations. In addition, they also detemine whether this node can serve as an input to other nodes in the audio graph.
The reverb will be set with the default settings as defined by the public domain FreeVerb algorithm.
channels | The number of audio channels |
rate | The sample rate (frequency) in HZ |
Reimplemented from cugl::audio::AudioNode.
|
protected |
Initializes the reverb filter from the default settings.
|
overridevirtual |
Marks the current read position in the audio steam.
DELEGATED METHOD: This method delegates its call to the input node. It returns false if there is no input node or if this method is unsupported in that node
This method is typically used by reset()
to determine where to restore the read position. For some nodes (like AudioInput
), this method may start recording data to a buffer, which will continue until reset()
is called.
It is possible for reset()
to be supported even if this method is not.
Reimplemented from cugl::audio::AudioNode.
|
overridevirtual |
Reads up to the specified number of frames into the given buffer
AUDIO THREAD ONLY: Users should never access this method directly. The only exception is when the user needs to create a custom subclass of this AudioNode.
The buffer should have enough room to store frames * channels elements. The channels are interleaved into the output buffer.
This method will always forward the read position after reading. Reading again may return different data.
buffer | The read buffer to store the results |
frames | The maximum number of frames to read |
Reimplemented from cugl::audio::AudioNode.
|
overridevirtual |
Resets the read position to the marked position of the audio stream.
DELEGATED METHOD: This method delegates its call to the input node. It returns false if there is no input node or if this method is unsupported in that node
When no mark()
is set, the result of this method is node dependent. Some nodes (such as AudioPlayer
) will reset to the beginning of the stream, while others (like AudioInput
) only support a rest when a mark is set. Pay attention to the return value of this method to see if the call is successful.
Reimplemented from cugl::audio::AudioNode.
void cugl::audio::AlgorithmicReverb::setDamp | ( | float | value | ) |
Sets the damping associated with each comb filter.
This value should be between 0 and 1 for best effects.
value | the damping as a float. |
void cugl::audio::AlgorithmicReverb::setDry | ( | float | value | ) |
Sets the dryness scale for the reverb.
This should be a value between 0 and 1. A value of 0 will mean that only the wet mix (reverb) is played.
value | the amount of dry to mix as a float. |
|
overridevirtual |
Sets the read position to the elapsed time in seconds.
DELEGATED METHOD: This method delegates its call to the input node. It returns -1 if there is no input node or if this method is unsupported in that node
In some nodes like AudioInput
, this method is only supported if mark()
is set. In that case, the new time will be meaured from the mark. Other nodes like AudioPlayer
measure from the start of the stream.
time | The elapsed time in seconds. |
Reimplemented from cugl::audio::AudioNode.
|
overridevirtual |
Sets the current frame position of this audio node.
DELEGATED METHOD: This method delegates its call to the input node. It returns -1 if there is no input node or if this method is unsupported in that node
In some nodes like AudioInput
, this method is only supported if mark()
is set. In that case, the position will be the number of frames since the mark. Other nodes like AudioPlayer
measure from the start of the stream.
position | the current frame position of this audio node. |
Reimplemented from cugl::audio::AudioNode.
|
overridevirtual |
Sets the typical read size of this node.
Some audio nodes need an internal buffer for operations like mixing or resampling. In that case, it helps to know the requested read
size ahead of time. The capacity is the minimal required read amount of the AudioEngine
and corresponds to AudioEngine#getReadSize
.
It is not actually necessary to set this size. However for nodes with internal buffer, setting this value can optimize performance.
This method is not synchronized because it is assumed that this value will never change while the audio engine in running. The average user should never call this method explicitly. You should always call AudioEngine#setReadSize
instead.
size | The typical read size of this node. |
Reimplemented from cugl::audio::AudioNode.
|
overridevirtual |
Sets the remaining time in seconds.
DELEGATED METHOD: This method delegates its call to the input node. It returns -1 if there is no input node or if this method is unsupported in that node
If this method is supported, then the node will be marked as completed after the given number of seconds. This may or may not actually move the read head. For example, in AudioPlayer
it will skip to the end of the sample. However, in AudioInput
it will simply time out after the given time.
time | The remaining time in seconds. |
Reimplemented from cugl::audio::AudioNode.
void cugl::audio::AlgorithmicReverb::setRoomSize | ( | float | value | ) |
Sets the room size associated with each comb filter.
This value should be between 0 and 1 for best effects.
value | the room size as a float. |
void cugl::audio::AlgorithmicReverb::setTail | ( | double | duration | ) |
Sets the fade-out tail for this reverb node
A reverb node is technically complete when its input node is complete. But for long enough echoes, this can cause the echo to be cut off. Therefore, it makes sense to add a tail where the echo is allowed to persist a little bit longer. This echo will linearly fade to 0 over the tail duration.
If this value is 0 or less, there will be no tail. You should not add a tail if you want this sound to be looped with the echo.
duration | The fade-out tail in seconds |
void cugl::audio::AlgorithmicReverb::setWet | ( | float | value | ) |
Sets the wetness scale for the reverb.
This should be a value between 0 and 1. A value of 0 will mean that no reverb is applied.
value | the amount of wet to mix as a float. |
void cugl::audio::AlgorithmicReverb::setWidth | ( | float | value | ) |
Sets the width between the stereo channels
value | the distance between channels |
|
overridevirtual |
Clears the current marked position.
DELEGATED METHOD: This method delegates its call to the input node. It returns false if there is no input node or if this method is unsupported in that node
If the method mark()
started recording to a buffer (such as with AudioInput
), this method will stop recording and release the buffer. When the mark is cleared, reset()
may or may not work depending upon the specific node.
Reimplemented from cugl::audio::AudioNode.
|
protected |
Amount that the wet mix is damped
|
protected |
Whether the reverb settings have changed and need to be regenerated
|
protected |
Scales gain for the dry mix
|
protected |
The amount of fade-out remaining
|
protected |
internal gain for producing wet mix
|
protected |
The audio input node
|
protected |
This class needs a proper lock guard; too many race conditions
|
protected |
Whether we have completed this node due to a fadeout
|
protected |
The number of frames to fade-out; -1 if no active fade-out
|
protected |
The reverb filter from ATK
|
protected |
Sets the amount of feedback for the comb filters (wet tail length)
|
protected |
Scales gain for the wet mix (stereo)
|
protected |
distance between left and right channels