add averager

This commit is contained in:
2024-09-30 08:20:19 +02:00
parent 9485c74961
commit e5e156ce32
2 changed files with 43 additions and 2 deletions

View File

@@ -1,7 +1,8 @@
#pragma once #pragma once
#include "../clip/wavefolder.h"
#include "../util/averager.h"
#include "tx_envelope.h" #include "tx_envelope.h"
#include "tx_sineosc.h" #include "tx_sineosc.h"
#include "../clip/wavefolder.h"
namespace trnr { namespace trnr {
class tx_operator { class tx_operator {
@@ -9,19 +10,22 @@ public:
tx_operator() tx_operator()
: ratio {1} : ratio {1}
, amplitude {1.0f} , amplitude {1.0f}
, wavefolding_amt {1.0f}
{ {
} }
tx_envelope envelope; tx_envelope envelope;
tx_sineosc oscillator; tx_sineosc oscillator;
wavefolder wavefolding;
float ratio; float ratio;
float amplitude; float amplitude;
float wavefolding_amt;
float process_sample(const bool& gate, const bool& trigger, const float& frequency, const float& velocity, float process_sample(const bool& gate, const bool& trigger, const float& frequency, const float& velocity,
const float& pm = 0) const float& pm = 0)
{ {
float env = envelope.process_sample(gate, trigger); float env = envelope.process_sample(gate, trigger);
float avg = m_averager.process_sample(wavefolding_amt);
m_wavefolder.amount = avg;
// drifts and sounds better! // drifts and sounds better!
if (envelope.is_busy()) { if (envelope.is_busy()) {
@@ -38,5 +42,9 @@ public:
this->envelope.set_samplerate(samplerate); this->envelope.set_samplerate(samplerate);
this->oscillator.set_samplerate(samplerate); this->oscillator.set_samplerate(samplerate);
} }
private:
averager<float, 1000> m_averager;
wavefolder m_wavefolder;
}; };
} // namespace trnr } // namespace trnr

33
util/averager.h Normal file
View File

@@ -0,0 +1,33 @@
#pragma once
#include <array>
namespace trnr {
template <typename t_sample, unsigned int sample_size>
class averager {
public:
averager() { samples.fill(0); }
t_sample process_sample(t_sample& _sample)
{
t_sample sum = t_sample(0);
for (unsigned int i = 0; i < sample_size; i++) {
if (i < sample_size - 1) {
// shift to the left
samples[i] = samples[i + 1];
} else {
// put new sample last
samples[i] = _sample;
}
sum += samples[i];
}
return sum / sample_size;
}
private:
std::array<t_sample, sample_size> samples;
};
} // namespace trnr