X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Faudio_filter.h;h=86fdce590cf0a5dc6eddba42ad8566779c332c73;hb=0771af91ad52ed2e25ab89410eb6e783b50f7329;hp=912e8c210d3ad9b9129df6f308108ba6b2069a56;hpb=2610abb85fc82056c51c540d7a3d8f691dfe3403;p=dcpomatic.git diff --git a/src/lib/audio_filter.h b/src/lib/audio_filter.h index 912e8c210..86fdce590 100644 --- a/src/lib/audio_filter.h +++ b/src/lib/audio_filter.h @@ -1,35 +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) { @@ -37,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 (); @@ -47,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: @@ -64,6 +72,7 @@ public: LowPassAudioFilter (float transition_bandwidth, float cutoff); }; + class HighPassAudioFilter : public AudioFilter { public: @@ -74,6 +83,7 @@ public: HighPassAudioFilter (float transition_bandwidth, float cutoff); }; + class BandPassAudioFilter : public AudioFilter { public: @@ -85,4 +95,5 @@ public: BandPassAudioFilter (float transition_bandwidth, float lower, float higher); }; + #endif