Audaspace:
[blender.git] / intern / audaspace / intern / AUD_JOSResampleReader.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * Copyright 2009-2011 Jörg Hermann Müller
5  *
6  * This file is part of AudaSpace.
7  *
8  * Audaspace is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * AudaSpace is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with Audaspace; if not, write to the Free Software Foundation,
20  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
21  *
22  * ***** END GPL LICENSE BLOCK *****
23  */
24
25 /** \file audaspace/intern/AUD_JOSResampleReader.h
26  *  \ingroup audaspaceintern
27  */
28
29
30 #ifndef __AUD_JOSRESAMPLEREADER_H__
31 #define __AUD_JOSRESAMPLEREADER_H__
32
33 #include "AUD_ResampleReader.h"
34 #include "AUD_Buffer.h"
35
36 /**
37  * This resampling reader uses Julius O. Smith's resampling algorithm.
38  */
39 class AUD_JOSResampleReader : public AUD_ResampleReader
40 {
41 private:
42         typedef void (AUD_JOSResampleReader::*AUD_resample_f)(double target_factor, int length, sample_t* buffer);
43
44         /**
45          * The half filter length.
46          */
47         static const int m_len;
48
49         /**
50          * The sample step size for the filter.
51          */
52         static const int m_L;
53
54         /**
55          * The filter coefficients.
56          */
57         static const float m_coeff[];
58
59         /**
60          * The reader channels.
61          */
62         AUD_Channels m_channels;
63
64         /**
65          * The sample position in the cache.
66          */
67         unsigned int m_n;
68
69         /**
70          * The subsample position in the cache.
71          */
72         double m_P;
73
74         /**
75          * The input data buffer.
76          */
77         AUD_Buffer m_buffer;
78
79         /**
80          * Double buffer for the sums.
81          */
82         AUD_Buffer m_sums;
83
84         /**
85          * How many samples in the cache are valid.
86          */
87         int m_cache_valid;
88
89         /**
90          * Resample function.
91          */
92         AUD_resample_f m_resample;
93
94         /**
95          * Last resampling factor.
96          */
97         double m_last_factor;
98
99         // hide copy constructor and operator=
100         AUD_JOSResampleReader(const AUD_JOSResampleReader&);
101         AUD_JOSResampleReader& operator=(const AUD_JOSResampleReader&);
102
103         /**
104          * Resets the resampler to its initial state.
105          */
106         void reset();
107
108         /**
109          * Updates the buffer to be as small as possible for the coming reading.
110          * \param size The size of samples to be read.
111          * \param factor The next resampling factor.
112          * \param samplesize The size of a sample.
113          */
114         void updateBuffer(int size, double factor, int samplesize);
115
116         void resample(double target_factor, int length, sample_t* buffer);
117         void resample_mono(double target_factor, int length, sample_t* buffer);
118         void resample_stereo(double target_factor, int length, sample_t* buffer);
119
120 public:
121         /**
122          * Creates a resampling reader.
123          * \param reader The reader to mix.
124          * \param specs The target specification.
125          */
126         AUD_JOSResampleReader(boost::shared_ptr<AUD_IReader> reader, AUD_Specs specs);
127
128         virtual void seek(int position);
129         virtual int getLength() const;
130         virtual int getPosition() const;
131         virtual AUD_Specs getSpecs() const;
132         virtual void read(int& length, bool& eos, sample_t* buffer);
133 };
134
135 #endif //__AUD_JOSRESAMPLEREADER_H__