|
HART
0.2.0
High level Audio Regression and Testing
|
Signal defined by a user-provided function. More...
#include <hart_signal_function.hpp>
Public Member Functions | |
| SignalFunction (std::function< void(AudioBuffer< SampleType > &)> signalFunction, const std::string &label={}, Loop loop=Loop::yes) | |
| Constructs a signal from a user-defined function. | |
| void | renderNextBlock (AudioBuffer< SampleType > &output) override |
| Renders next block audio for the signal. | |
| void | prepare (double sampleRateHz, size_t numOutputChannels, size_t) override |
| Prepare the signal for rendering. | |
| void | reset () override |
| Resets the Signal to initial state. | |
| void | represent (std::ostream &stream) const override |
| Makes a text representation of this Signal for test failure outputs. | |
Public Member Functions inherited from Signal< SampleType, SignalFunction< SampleType > > | |
| SignalFunction< SampleType > & | followedBy (DerivedDSP &&dsp) & |
| Adds a DSP effect to the end of signal's DSP chain. | |
| SignalFunction< SampleType > && | followedBy (DerivedDSP &&dsp) && |
| Adds a DSP effect to the end of signal's DSP chain. | |
| SignalFunction< SampleType > & | followedBy (std::unique_ptr< DSPBase< SampleType > > dsp) & |
| Adds a DSP effect to the end of signal's DSP chain. | |
| SignalFunction< SampleType > && | followedBy (std::unique_ptr< DSPBase< SampleType > > dsp) && |
| Adds a DSP effect to the end of signal's DSP chain. | |
| std::unique_ptr< SignalBase< SampleType > > | copy () const override |
| Returns a smart pointer with a copy of this object. | |
| std::unique_ptr< SignalBase< SampleType > > | move () override |
| Returns a smart pointer with a moved instance of this object. | |
| SignalFunction< SampleType > & | skipTo (double startTimestampSeconds) & |
| Skips the signal to a specific timestamp. | |
| SignalFunction< SampleType > && | skipTo (double startTimestampSeconds) && |
| Skips the signal to a specific timestamp. | |
| SignalFunction< SampleType > | operator- () const |
| Returns a copy of this signal, but with flipped phase. | |
| SignalFunction< SampleType > | operator~ () const |
| Returns a copy of this signal, but with flipped phase. | |
Public Member Functions inherited from SignalBase< SampleType > | |
| SignalBase ()=default | |
| Default constructor. | |
| SignalBase (const SignalBase &other) | |
| Copies other signal. | |
| SignalBase (SignalBase &&other) noexcept | |
| Moves from other signal. | |
| virtual | ~SignalBase ()=default |
| Destructor. | |
| SignalBase & | operator= (const SignalBase &other) |
| Copies from other signal. | |
| SignalBase & | operator= (SignalBase &&other) noexcept |
| Moves from other signal. | |
| virtual bool | supportsNumChannels (size_t) const |
| Tells the host whether this Signal is capable of generating audio for a certain amount of channels. | |
| virtual bool | supportsSampleRate (double) const |
| Tells whether this Signal supports given sample rate. | |
| void | prepareWithDSPChain (double sampleRateHz, size_t numOutputChannels, size_t maxBlockSizeFrames) |
| Prepares the signal and all attached effects in the DSP chain for rendering. | |
| void | renderNextBlockWithDSPChain (AudioBuffer< SampleType > &output) |
| Renders next block audio for the signal and all the effects in the DSP chain. | |
| virtual void | resetWithDSPChain () |
| Resets to Signal and all the effects attached to its DSP chain to initial state. | |
| size_t | getDSPChainSize () const |
| Returns the size of the DSP chain attached to the Signal. | |
| DSPBase< SampleType > * | getDSP (int index=-1) const |
| Access a specific element in the DSP chain. | |
| std::unique_ptr< DSPBase< SampleType > > | popDSP (int index=-1) |
| Extract a specific element in the DSP chain by removing it. | |
Additional Inherited Members | |
Protected Member Functions inherited from SignalBase< SampleType > | |
| void | setNumChannels (size_t numChannels) |
| size_t | getNumChannels () |
Protected Attributes inherited from SignalBase< SampleType > | |
| size_t | m_numChannels = 1 |
| double | m_startTimestampSeconds = 0.0 |
| std::vector< std::unique_ptr< DSPBase< SampleType > > > | m_dspChain |
Related Symbols inherited from Signal< SampleType, SignalFunction< SampleType > > | |
| MixedSignal< SampleType > | operator- (const Signal< SampleType, DerivedSignalTypeLHS > &lhs, const Signal< SampleType, DerivedSignalTypeRHS > &rhs) |
| Subtracts one signal from another, resulting in a new mixed signal. | |
| MixedSignal< SampleType > | operator+ (const Signal< SampleType, DerivedSignalTypeLHS > &lhs, const Signal< SampleType, DerivedSignalTypeRHS > &rhs) |
| Adds one signal to another, resulting in a new mixed signal. | |
| std::ostream & | operator<< (std::ostream &stream, const SignalBase< SampleType > &signal) |
| Prints readable text representation of the Signal object into the I/O stream. | |
| auto | operator>> (SignalFunction< SampleType > &signal, DerivedDSP &&dsp) -> decltype(signal.followedBy(std::forward< DerivedDSP >(dsp))) |
| Adds a DSP effect to the end of signal's DSP chain by transfering it. | |
| auto | operator>> (SignalFunction< SampleType > &&signal, DerivedDSP &&dsp) -> decltype(std::move(signal).followedBy(std::forward< DerivedDSP >(dsp))) |
| Adds a DSP effect to the end of signal's DSP chain by transfering it. | |
Signal defined by a user-provided function.
This Signal allows defining input signals using a lambda or function object, instead of creating a dedicated Signal subclass.
The provided function is called during prepare() and is expected to fill an initially empty AudioBuffer with audio data. This buffer is then used as a source and streamed block-by-block during processing.
The generated buffer can either:
SignalFunction can be suitable for:
| hart::NullPointerError | if signalFunction is empty |
| hart::ChannelLayoutError | if the function changes buffer's channel count |
| hart::SampleRateError | if the function changes buffer's sample rate |
| hart::SizeError | if the function does not allocate any frames |
Definition at line 59 of file hart_signal_function.hpp.
|
inline |
Constructs a signal from a user-defined function.
The provided function is guaranteed to be called with an empty AudioBuffer, i.e. AudioBuffer::getNumFrames() will return zero. The function must allocate and fill the buffer with audio data. The provided buffer is guaranteed to contain valid metadata on required number of channels (see AudioBuffer::getNumChannels()) and sample rate (see AudioBuffer::getSampleRateHz()).
The buffer is owned internally and reused during processing.
| signalFunction | A callable with signature: void (AudioBuffer<SampleType>&) |
For the provided buffer, the function must:
| label | A human-readable description of the signal, used in logs and failure reports. Can be empty. |
| loop | If set to Loop::yes, the generated buffer will repeat continuously. If set to Loop::no, the signal will output silence (zeros) after the buffer is exhausted. |
Definition at line 89 of file hart_signal_function.hpp.
|
inlineoverridevirtual |
Renders next block audio for the signal.
Depending on circumstances, this callback will either be called once to generate an entire piece of audio from start to finish, or called repeatedly, one block at a time. This method is guaranteed to be called strictly after prepare(), or not called at all. Number of channels and max block size are guaranteed to be in line with the ones set by prepare() callback. Assume sample rate to always be equal to the one received in the last prepare() callback. All audio blocks except the last one are guaranteed to be equal to maxBlockSizeFrames set in prepare() callback.
| output | Output audio block |
Implements SignalBase< SampleType >.
Definition at line 96 of file hart_signal_function.hpp.
|
inlineoverridevirtual |
Prepare the signal for rendering.
This method is guaranteed to be called after supportsNumChannels() and supportsSampleRate(), but before renderNextBlock(). It is guaranteed that numChannels obeys supportsNumChannels() preferences, same with sampleRateHz and supportsSampleRate(). It is guaranteed that all subsequent renderNextBlock() calls will be in line with the arguments received in this callback.
| sampleRateHz | sample rate at which the audio should be generated |
| numOutputChannels | Number of output channels to be filled |
| maxBlockSizeFrames | Maximum block size in frames (samples) |
Implements SignalBase< SampleType >.
Definition at line 154 of file hart_signal_function.hpp.
|
inlineoverridevirtual |
Resets the Signal to initial state.
Ideally should be implemented in a way that audio produced after resetting is identical to audio produced after instantiation
Implements SignalBase< SampleType >.
Definition at line 187 of file hart_signal_function.hpp.
|
inlineoverridevirtual |
Makes a text representation of this Signal for test failure outputs.
It is strongly encouraged to follow python's repr() conventions for returned text - basically, put something like "MyClass(value1, value2)" (with no quotes) into the stream whenever possible, or "<Readable info in angled brackets>" otherwise. Also, use built-in stream manipulators like dbPrecision wherever applicable. Use HART_DEFINE_GENERIC_REPRESENT() to get a basic implementation for this method.
| [out] | stream | Output stream to write to |
Implements SignalBase< SampleType >.
Definition at line 192 of file hart_signal_function.hpp.