tmp
[blender.git] / extern / audaspace / include / fx / HighpassCalculator.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 HighpassCalculator.h
21  * @ingroup fx
22  * The HighpassCalculator class.
23  */
24
25 #include "fx/IDynamicIIRFilterCalculator.h"
26
27 AUD_NAMESPACE_BEGIN
28
29 /**
30  * The HighpassCalculator class calculates high pass filter coefficients for a
31  * dynamic DynamicIIRFilter.
32  */
33 class AUD_LOCAL HighpassCalculator : public IDynamicIIRFilterCalculator
34 {
35 private:
36         /**
37          * The cutoff frequency.
38          */
39         const float m_frequency;
40
41         /**
42          * The Q factor.
43          */
44         const float m_Q;
45
46         // delete copy constructor and operator=
47         HighpassCalculator(const HighpassCalculator&) = delete;
48         HighpassCalculator& operator=(const HighpassCalculator&) = delete;
49
50 public:
51         /**
52          * Creates a HighpassCalculator object.
53          * @param frequency The cutoff frequency.
54          * @param Q The Q factor of the filter. If unsure, use 1.0 as default.
55          */
56         HighpassCalculator(float frequency, float Q);
57
58         virtual void recalculateCoefficients(SampleRate rate, std::vector<float> &b, std::vector<float> &a);
59 };
60
61 AUD_NAMESPACE_END