ScummVM API documentation
LinearResampler.h
1 /* Copyright (C) 2015-2022 Sergey V. Mikayev
2  *
3  * This program is free software: you can redistribute it and/or modify
4  * it under the terms of the GNU Lesser General Public License as published by
5  * the Free Software Foundation, either version 2.1 of the License, or
6  * (at your option) any later version.
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11  * GNU Lesser General Public License for more details.
12  *
13  * You should have received a copy of the GNU Lesser General Public License
14  * along with this program. If not, see <http://www.gnu.org/licenses/>.
15  */
16 
17 #ifndef SRCTOOLS_LINEAR_RESAMPLER_H
18 #define SRCTOOLS_LINEAR_RESAMPLER_H
19 
20 #include "ResamplerStage.h"
21 
22 namespace SRCTools {
23 
24 static const unsigned int LINEAR_RESAMPER_CHANNEL_COUNT = 2;
25 
27 public:
28  LinearResampler(double sourceSampleRate, double targetSampleRate);
29  ~LinearResampler() {}
30 
31  unsigned int estimateInLength(const unsigned int outLength) const;
32  void process(const FloatSample *&inSamples, unsigned int &inLength, FloatSample *&outSamples, unsigned int &outLength);
33 
34 private:
35  const double inputToOutputRatio;
36  double position;
37  FloatSample lastInputSamples[LINEAR_RESAMPER_CHANNEL_COUNT];
38 };
39 
40 } // namespace SRCTools
41 
42 #endif // SRCTOOLS_LINEAR_RESAMPLER_H
unsigned int estimateInLength(const unsigned int outLength) const
void process(const FloatSample *&inSamples, unsigned int &inLength, FloatSample *&outSamples, unsigned int &outLength)
Definition: ResamplerStage.h:25
Definition: FIRResampler.h:22
Definition: LinearResampler.h:26