Audaspace 1.5.0
A high level audio library.
Loading...
Searching...
No Matches
IIRFilterReader.h
Go to the documentation of this file.
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
26
27#include <vector>
28
30
35{
36private:
40 std::vector<float> m_a;
41
45 std::vector<float> m_b;
46
47 // delete copy constructor and operator=
48 IIRFilterReader(const IIRFilterReader&) = delete;
49 IIRFilterReader& operator=(const IIRFilterReader&) = delete;
50
51public:
58 IIRFilterReader(std::shared_ptr<IReader> reader, const std::vector<float>& b, const std::vector<float>& a);
59
60 virtual sample_t filter();
61
67 void setCoefficients(const std::vector<float>& b, const std::vector<float>& a);
68};
69
#define AUD_NAMESPACE_END
Closes the audaspace namespace aud.
Definition Audaspace.h:119
float sample_t
Sample type.(float samples)
Definition Audaspace.h:126
#define AUD_NAMESPACE_BEGIN
Opens the audaspace namespace aud.
Definition Audaspace.h:116
#define AUD_API
Used for exporting symbols in the shared library.
Definition Audaspace.h:93
The BaseIIRFilterReader class.
This class is a base class for infinite impulse response filters.
Definition BaseIIRFilterReader.h:33
This class is for infinite impulse response filters with simple coefficients.
Definition IIRFilterReader.h:35
IIRFilterReader(std::shared_ptr< IReader > reader, const std::vector< float > &b, const std::vector< float > &a)
Creates a new IIR filter reader.
void setCoefficients(const std::vector< float > &b, const std::vector< float > &a)
Sets new filter coefficients.
virtual sample_t filter()
Runs the filtering function.