libsidplayfp 2.15.0
ZeroOrderResampler.h
1/*
2 * This file is part of libsidplayfp, a SID player engine.
3 *
4 * Copyright 2011-2013 Leandro Nini <drfiemost@users.sourceforge.net>
5 * Copyright 2007-2010 Antti Lankila
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20 */
21
22#ifndef ZEROORDER_RESAMPLER_H
23#define ZEROORDER_RESAMPLER_H
24
25#include "Resampler.h"
26
27#include "sidcxx11.h"
28
29namespace reSIDfp
30{
31
37class ZeroOrderResampler final : public Resampler
38{
39
40private:
42 int cachedSample;
43
45 const int cyclesPerSample;
46
47 int sampleOffset;
48
50 int outputValue;
51
52public:
53 ZeroOrderResampler(double clockFrequency, double samplingFrequency) :
54 cachedSample(0),
55 cyclesPerSample(static_cast<int>(clockFrequency / samplingFrequency * 1024.)),
56 sampleOffset(0),
57 outputValue(0) {}
58
59 bool input(int sample) override
60 {
61 bool ready = false;
62
63 if (sampleOffset < 1024)
64 {
65 outputValue = cachedSample + (sampleOffset * (sample - cachedSample) >> 10);
66 ready = true;
67 sampleOffset += cyclesPerSample;
68 }
69
70 sampleOffset -= 1024;
71
72 cachedSample = sample;
73
74 return ready;
75 }
76
77 int output() const override { return outputValue; }
78
79 void reset() override
80 {
81 sampleOffset = 0;
82 cachedSample = 0;
83 }
84};
85
86} // namespace reSIDfp
87
88#endif
Definition Resampler.h:40
Definition ZeroOrderResampler.h:38
bool input(int sample) override
Definition ZeroOrderResampler.h:59