8#include "signals/hart_signal.hpp"
17template<
typename SampleType>
22 SineWave (
double frequencyHz = (SampleType) 1000,
double phaseRadians = (SampleType) 0):
23 m_frequencyHz (frequencyHz),
24 m_initialPhaseRadians (phaseRadians),
25 m_phaseRadians (phaseRadians)
35 void prepare (
double sampleRateHz, size_t , size_t )
override
37 m_sampleRateHz = sampleRateHz;
42 const double phaseIncrement =
hart::twoPi * m_frequencyHz / m_sampleRateHz;
44 for (size_t frame = 0; frame < output.getNumFrames(); ++frame)
46 SampleType value =
static_cast<SampleType> (std::sin (m_phaseRadians));
48 for (size_t channel = 0; channel < output.getNumChannels(); ++channel)
49 output[channel][frame] = value;
51 m_phaseRadians += phaseIncrement;
58 m_phaseRadians = m_initialPhaseRadians;
61 void represent (std::ostream& stream)
const override
63 stream <<
"SineWave ("
71 const double m_frequencyHz;
72 const double m_initialPhaseRadians;
73 double m_phaseRadians;
74 double m_sampleRateHz;
78 while (m_phaseRadians < 0)
82 m_phaseRadians = std::fmod (m_phaseRadians,
hart::twoPi);
Produces a sine wave at fixed frequency.
void renderNextBlock(AudioBuffer< SampleType > &output) override
Renders next block audio for the signal.
SineWave(double frequencyHz=(SampleType) 1000, double phaseRadians=(SampleType) 0)
void represent(std::ostream &stream) const override
Makes a text representation of this Signal for test failure outputs.
bool supportsNumChannels(size_t) const override
Tells the host whether this Signal is capable of generating audio for a certain amount of cchannels.
void prepare(double sampleRateHz, size_t, size_t) override
Prepare the signal for rendering.
void reset() override
Resets the Signal to initial state.
std::ostream & radPrecision(std::ostream &stream)
Sets number of decimal places for values in radians.
std::ostream & hzPrecision(std::ostream &stream)
Sets number of decimal places for values in hertz.
#define HART_SIGNAL_DEFINE_COPY_AND_MOVE(ClassName)
Defines hart::Signal::copy() and hart::Signal::move() methods.
constexpr double twoPi
2 * pi
#define HART_THROW(ExceptionType, message)
#define HART_SIGNAL_DECLARE_ALIASES_FOR(ClassName)