tmp
[blender.git] / extern / audaspace / include / fx / ButterworthCalculator.h
1 /*******************************************************************************
2  * Copyright 2009-2016 Jörg Müller
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *   http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  ******************************************************************************/
16
17 #pragma once
18
19 /**
20  * @file ButterworthCalculator.h
21  * @ingroup fx
22  * The ButterworthCalculator class.
23  */
24
25 #include "fx/IDynamicIIRFilterCalculator.h"
26
27 AUD_NAMESPACE_BEGIN
28
29 /**
30  * The ButterworthCalculator class calculates fourth order Butterworth low pass
31  * filter coefficients for a dynamic DynamicIIRFilter.
32  */
33 class AUD_LOCAL ButterworthCalculator : public IDynamicIIRFilterCalculator
34 {
35 private:
36         /**
37          * The attack value in seconds.
38          */
39         const float m_frequency;
40
41         // delete copy constructor and operator=
42         ButterworthCalculator(const ButterworthCalculator&) = delete;
43         ButterworthCalculator& operator=(const ButterworthCalculator&) = delete;
44
45 public:
46         /**
47          * Creates a ButterworthCalculator object.
48          * @param frequency The cutoff frequency.
49          */
50         ButterworthCalculator(float frequency);
51
52         virtual void recalculateCoefficients(SampleRate rate, std::vector<float> &b, std::vector<float> &a);
53 };
54
55 AUD_NAMESPACE_END