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