psemek/libs/audio/source/wave/sawtooth.cpp

21 lines
443 B
C++

#include <psemek/audio/wave/sawtooth.hpp>
#include <psemek/audio/wave/generator.hpp>
#include <psemek/audio/detail/oscillator.hpp>
#include <psemek/log/log.hpp>
#include <cmath>
namespace psemek::audio
{
stream_ptr sawtooth_wave(float frequency)
{
auto func = [o = oscillator{frequency}]() mutable {
auto z = o.next();
return (2.f / math::pi) * (- std::atan2(z.real() + 1.f, z.imag()));
};
return make_generator(func);
}
}