15#ifndef R8B_CDSPHBDOWNSAMPLER_INCLUDED
16#define R8B_CDSPHBDOWNSAMPLER_INCLUDED
47 const bool IsThird,
const double PrevLatency )
49 static const CConvolveFn FltConvFn[ 14 ] = {
50 &CDSPHBDownsampler :: convolve1, &CDSPHBDownsampler :: convolve2,
51 &CDSPHBDownsampler :: convolve3, &CDSPHBDownsampler :: convolve4,
52 &CDSPHBDownsampler :: convolve5, &CDSPHBDownsampler :: convolve6,
53 &CDSPHBDownsampler :: convolve7, &CDSPHBDownsampler :: convolve8,
54 &CDSPHBDownsampler :: convolve9, &CDSPHBDownsampler :: convolve10,
55 &CDSPHBDownsampler :: convolve11, &CDSPHBDownsampler :: convolve12,
56 &CDSPHBDownsampler :: convolve13,
57 &CDSPHBDownsampler :: convolve14 };
65 CDSPHBUpsampler :: getHBFilterThird( ReqAtten, SteepIndex, fltp0,
70 CDSPHBUpsampler :: getHBFilter( ReqAtten, SteepIndex, fltp0, fltt,
77 memcpy( fltp, fltp0, fltt *
sizeof( fltp[ 0 ]));
79 convfn = FltConvFn[ fltt - 1 ];
85 BufRP2 = Buf2 + fll - 1;
87 LatencyFrac = PrevLatency * 0.5;
88 Latency = (int) LatencyFrac;
89 LatencyFrac -= Latency;
93 R8BCONSOLE(
"CDSPHBDownsampler: taps=%i third=%i att=%.1f io=1/2\n",
94 fltt, (
int) IsThird, att );
101 return( flo + (
int) (( Latency + LatencyFrac + ReqOutPos ) * 2.0 ));
111 return( LatencyFrac );
118 return(( MaxInLen + 1 ) >> 1 );
123 LatencyLeft = Latency;
129 memset( &Buf1[ ReadPos ], 0, ( BufLen - flb ) *
sizeof( Buf1[ 0 ]));
130 memset( &Buf2[ ReadPos ], 0, ( BufLen - flb ) *
sizeof( Buf2[ 0 ]));
133 virtual int process(
double* ip,
int l,
double*& op0 )
143 if( WritePos1 != WritePos2 )
148 double*
const wp2 = Buf2 + WritePos2;
151 if( WritePos2 < flo )
157 WritePos2 = WritePos1;
162 const int b1 =
min(( l + 1 ) >> 1,
163 min( BufLen - WritePos1, flb - BufLeft ));
165 const int b2 = b1 - ( b1 * 2 > l );
167 double* wp1 = Buf1 + WritePos1;
168 double* wp2 = Buf2 + WritePos1;
169 double*
const ipe = ip + b2 * 2;
186 const int ec = flo - WritePos1;
190 wp1 = Buf1 + WritePos1;
191 memcpy( wp1 + BufLen, wp1,
min( b1, ec ) *
sizeof( wp1[ 0 ]));
192 wp2 = Buf2 + WritePos1;
193 memcpy( wp2 + BufLen, wp2,
min( b2, ec ) *
sizeof( wp2[ 0 ]));
196 WritePos1 = ( WritePos1 + b1 ) & BufLenMask;
197 WritePos2 = ( WritePos2 + b2 ) & BufLenMask;
203 const int c = BufLeft - fl2;
207 double*
const opend = op + c;
208 ( *convfn )( op, opend, fltp, BufRP1, BufRP2, ReadPos );
211 ReadPos = ( ReadPos + c ) & BufLenMask;
216 int ol = (int) ( op - op0 );
218 if( LatencyLeft != 0 )
220 if( LatencyLeft >= ol )
235 static const int BufLenBits = 10;
241 static const int BufLen = 1 << BufLenBits;
244 static const int BufLenMask = BufLen - 1;
246 double Buf1[ BufLen + 27 ];
248 double Buf2[ BufLen + 27 ];
250 double FltBuf[ 14 + 2 ];
252 const double* BufRP1;
253 const double* BufRP2;
269 typedef void( *CConvolveFn )(
double* op,
double*
const opend,
270 const double*
const flt,
const double*
const rp01,
271 const double*
const rp02,
int rpos );
275#define R8BHBC1( fn ) \
276 static void fn( double* op, double* const opend, const double* const flt, \
277 const double* const rp01, const double* const rp02, int rpos ) \
279 while( op != opend ) \
281 const double* const rp1 = rp01 + rpos; \
282 const double* const rp = rp02 + rpos;
285 rpos = ( rpos + 1 ) & BufLenMask; \
290#include "CDSPHBDownsampler.inc"
Half-band upsampling class.
#define R8BASSERT(e)
Definition: r8bconf.h:27
#define R8BCONSOLE(...)
Definition: r8bconf.h:40
The "r8brain-free-src" library namespace.
Definition: CDSPBlockConvolver.h:21
T * alignptr(T *const ptr, const uintptr_t align)
Definition: r8bbase.h:279
T min(const T &v1, const T &v2)
Definition: r8bbase.h:1063
Half-band downsampler class.
Definition: CDSPHBDownsampler.h:30
virtual int getInLenBeforeOutPos(const int ReqOutPos) const
Definition: CDSPHBDownsampler.h:99
virtual int process(double *ip, int l, double *&op0)
Definition: CDSPHBDownsampler.h:133
CDSPHBDownsampler(const double ReqAtten, const int SteepIndex, const bool IsThird, const double PrevLatency)
Definition: CDSPHBDownsampler.h:46
virtual int getLatency() const
Definition: CDSPHBDownsampler.h:104
virtual void clear()
Definition: CDSPHBDownsampler.h:121
virtual int getMaxOutLen(const int MaxInLen) const
Definition: CDSPHBDownsampler.h:114
virtual double getLatencyFrac() const
Definition: CDSPHBDownsampler.h:109
The base virtual class for DSP processing algorithms.
Definition: CDSPProcessor.h:32