X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Faudio_filter.h;h=922cc5fdb483fdec278721becf8f4528776600dd;hp=9fc69daadb23574158e6b298d7b0140a23071716;hb=2d4e8c5f69cc694625ad95dcee554499605f823b;hpb=5e4f001bf32e3cdf65efa34803d70e6c1c00c66b diff --git a/src/lib/audio_filter.h b/src/lib/audio_filter.h index 9fc69daad..922cc5fdb 100644 --- a/src/lib/audio_filter.h +++ b/src/lib/audio_filter.h @@ -1,33 +1,41 @@ /* - 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 . */ -#include -#include +#ifndef DCPOMATIC_AUDIO_FILTER_H +#define DCPOMATIC_AUDIO_FILTER_H + + +#include + class AudioBuffers; -class audio_filter_impulse_kernel_test; 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) + explicit AudioFilter (float transition_bandwidth) { _M = 4 / transition_bandwidth; if (_M % 2) { @@ -35,7 +43,9 @@ public: } } - boost::shared_ptr run (boost::shared_ptr in); + virtual ~AudioFilter (); + + std::shared_ptr run (std::shared_ptr in); void flush (); @@ -43,13 +53,14 @@ protected: friend struct audio_filter_impulse_kernel_test; friend struct audio_filter_impulse_input_test; - std::vector sinc_blackman (float cutoff, bool invert) const; + float* sinc_blackman (float cutoff, bool invert) const; - std::vector _ir; + float* _ir = nullptr; int _M; - boost::shared_ptr _tail; + std::shared_ptr _tail; }; + class LowPassAudioFilter : public AudioFilter { public: @@ -60,6 +71,7 @@ public: LowPassAudioFilter (float transition_bandwidth, float cutoff); }; + class HighPassAudioFilter : public AudioFilter { public: @@ -70,6 +82,7 @@ public: HighPassAudioFilter (float transition_bandwidth, float cutoff); }; + class BandPassAudioFilter : public AudioFilter { public: @@ -80,3 +93,6 @@ public: */ BandPassAudioFilter (float transition_bandwidth, float lower, float higher); }; + + +#endif