2011-08-20 14:40:44 +00:00
|
|
|
#ifdef NALL_DSP_INTERNAL_HPP
|
|
|
|
|
2011-09-23 11:13:57 +00:00
|
|
|
struct ResampleCubic : Resampler {
|
|
|
|
inline void setFrequency();
|
|
|
|
inline void clear();
|
|
|
|
inline void sample();
|
2013-05-02 11:25:45 +00:00
|
|
|
ResampleCubic(DSP& dsp) : Resampler(dsp) {}
|
2011-09-23 11:13:57 +00:00
|
|
|
|
|
|
|
real fraction;
|
|
|
|
real step;
|
|
|
|
};
|
|
|
|
|
|
|
|
void ResampleCubic::setFrequency() {
|
|
|
|
fraction = 0.0;
|
|
|
|
step = dsp.settings.frequency / frequency;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ResampleCubic::clear() {
|
|
|
|
fraction = 0.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ResampleCubic::sample() {
|
|
|
|
while(fraction <= 1.0) {
|
|
|
|
real channel[dsp.settings.channels];
|
2011-08-20 14:40:44 +00:00
|
|
|
|
2011-09-23 11:13:57 +00:00
|
|
|
for(unsigned n = 0; n < dsp.settings.channels; n++) {
|
|
|
|
real a = dsp.buffer.read(n, -3);
|
|
|
|
real b = dsp.buffer.read(n, -2);
|
|
|
|
real c = dsp.buffer.read(n, -1);
|
|
|
|
real d = dsp.buffer.read(n, -0);
|
2011-08-20 14:40:44 +00:00
|
|
|
|
2011-09-23 11:13:57 +00:00
|
|
|
real mu = fraction;
|
2011-08-20 14:40:44 +00:00
|
|
|
|
2011-09-23 11:13:57 +00:00
|
|
|
real A = d - c - a + b;
|
|
|
|
real B = a - b - A;
|
|
|
|
real C = c - a;
|
|
|
|
real D = b;
|
2011-08-20 14:40:44 +00:00
|
|
|
|
|
|
|
channel[n] = A * (mu * 3) + B * (mu * 2) + C * mu + D;
|
|
|
|
}
|
|
|
|
|
2011-09-23 11:13:57 +00:00
|
|
|
dsp.write(channel);
|
|
|
|
fraction += step;
|
2011-08-20 14:40:44 +00:00
|
|
|
}
|
|
|
|
|
2011-09-23 11:13:57 +00:00
|
|
|
dsp.buffer.rdoffset++;
|
|
|
|
fraction -= 1.0;
|
2011-08-20 14:40:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|