mirror of
https://github.com/DerKoun/bsnes-hd.git
synced 2025-04-02 10:52:49 -04:00
29 lines
430 B
C++
29 lines
430 B
C++
#pragma once
|
|
|
|
#include <nall/dsp/dsp.hpp>
|
|
|
|
//DC offset removal IIR filter
|
|
|
|
namespace nall::DSP::IIR {
|
|
|
|
struct DCRemoval {
|
|
inline auto reset() -> void;
|
|
inline auto process(double in) -> double; //normalized sample (-1.0 to +1.0)
|
|
|
|
private:
|
|
double x;
|
|
double y;
|
|
};
|
|
|
|
auto DCRemoval::reset() -> void {
|
|
x = 0.0;
|
|
y = 0.0;
|
|
}
|
|
|
|
auto DCRemoval::process(double in) -> double {
|
|
x = 0.999 * x + in - y;
|
|
y = in;
|
|
return x;
|
|
}
|
|
|
|
}
|