X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Faudio_filter.h;h=86fdce590cf0a5dc6eddba42ad8566779c332c73;hp=fb7b7b92ccb64283d7bc01235b35d486f0c5422b;hb=fa4da415f1788bed17eefd05ba8d49b8ad847613;hpb=a69d242f3f00207d6ea7320e6723775f4b0dbfb3 diff --git a/src/lib/audio_filter.h b/src/lib/audio_filter.h index fb7b7b92c..86fdce590 100644 --- a/src/lib/audio_filter.h +++ b/src/lib/audio_filter.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -21,11 +21,15 @@ #ifndef DCPOMATIC_AUDIO_FILTER_H #define DCPOMATIC_AUDIO_FILTER_H -#include + +#include +#include + class AudioBuffers; struct audio_filter_impulse_input_test; + /** An audio filter which can take AudioBuffers and apply some filtering operation, * returning filtered samples */ @@ -33,7 +37,6 @@ class AudioFilter { public: explicit AudioFilter (float transition_bandwidth) - : _ir (0) { _M = 4 / transition_bandwidth; if (_M % 2) { @@ -41,9 +44,9 @@ public: } } - virtual ~AudioFilter (); + virtual ~AudioFilter () {} - boost::shared_ptr run (boost::shared_ptr in); + std::shared_ptr run (std::shared_ptr in); void flush (); @@ -51,13 +54,14 @@ protected: friend struct audio_filter_impulse_kernel_test; friend struct audio_filter_impulse_input_test; - float* sinc_blackman (float cutoff, bool invert) const; + std::vector sinc_blackman (float cutoff, bool invert) const; - float* _ir; + std::vector _ir; int _M; - boost::shared_ptr _tail; + std::shared_ptr _tail; }; + class LowPassAudioFilter : public AudioFilter { public: @@ -68,6 +72,7 @@ public: LowPassAudioFilter (float transition_bandwidth, float cutoff); }; + class HighPassAudioFilter : public AudioFilter { public: @@ -78,6 +83,7 @@ public: HighPassAudioFilter (float transition_bandwidth, float cutoff); }; + class BandPassAudioFilter : public AudioFilter { public: @@ -89,4 +95,5 @@ public: BandPassAudioFilter (float transition_bandwidth, float lower, float higher); }; + #endif