33 lines
710 B
C++
33 lines
710 B
C++
#pragma once
|
|
#include "Effect.h"
|
|
|
|
class Filter: public Effect
|
|
{
|
|
|
|
|
|
protected:
|
|
struct Normals {
|
|
float V;
|
|
float K;
|
|
};
|
|
|
|
float m_freq; // cutoff frequency
|
|
float m_q; // filter quantity (resonance)
|
|
float m_order; // filter order (peakGain)
|
|
/* todo: filter adsr */
|
|
float m_norm;
|
|
float m_a0, m_a1, m_a2, m_b1, m_b2;
|
|
float m_z1, m_z2;
|
|
Normals calculate_normals();
|
|
virtual void calculate_coefficients(){};
|
|
public:
|
|
Filter(/* args */);
|
|
~Filter();
|
|
void Trigger() override;
|
|
void Release() override;
|
|
float Process(float in);
|
|
void Process(std::vector<float>& samples) override;
|
|
void SetParameters(float freq, float res, float q);
|
|
};
|
|
|