X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Faudio_filter.h;h=86fdce590cf0a5dc6eddba42ad8566779c332c73;hb=640e30afec63fe0ceab064c1082450a77c75f9d3;hp=b7a675e6b85fa3472f9e6d9ffd2aaaed42fb6975;hpb=e07926b8b0d3d93c2b670aea4b49230170a3532b;p=dcpomatic.git diff --git a/src/lib/audio_filter.h b/src/lib/audio_filter.h index b7a675e6b..86fdce590 100644 --- a/src/lib/audio_filter.h +++ b/src/lib/audio_filter.h @@ -1,38 +1,42 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2021 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ #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 */ class AudioFilter { public: - AudioFilter (float transition_bandwidth) - : _ir (0) + explicit AudioFilter (float transition_bandwidth) { _M = 4 / transition_bandwidth; if (_M % 2) { @@ -40,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 (); @@ -50,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: @@ -67,6 +72,7 @@ public: LowPassAudioFilter (float transition_bandwidth, float cutoff); }; + class HighPassAudioFilter : public AudioFilter { public: @@ -77,6 +83,7 @@ public: HighPassAudioFilter (float transition_bandwidth, float cutoff); }; + class BandPassAudioFilter : public AudioFilter { public: @@ -88,4 +95,5 @@ public: BandPassAudioFilter (float transition_bandwidth, float lower, float higher); }; + #endif