1*ec779b8eSAndroid Build Coastguard Worker /* 2*ec779b8eSAndroid Build Coastguard Worker * Copyright (C) 2007 The Android Open Source Project 3*ec779b8eSAndroid Build Coastguard Worker * 4*ec779b8eSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*ec779b8eSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*ec779b8eSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*ec779b8eSAndroid Build Coastguard Worker * 8*ec779b8eSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*ec779b8eSAndroid Build Coastguard Worker * 10*ec779b8eSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*ec779b8eSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*ec779b8eSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*ec779b8eSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*ec779b8eSAndroid Build Coastguard Worker * limitations under the License. 15*ec779b8eSAndroid Build Coastguard Worker */ 16*ec779b8eSAndroid Build Coastguard Worker 17*ec779b8eSAndroid Build Coastguard Worker #ifndef ANDROID_AUDIO_RESAMPLER_SINC_H 18*ec779b8eSAndroid Build Coastguard Worker #define ANDROID_AUDIO_RESAMPLER_SINC_H 19*ec779b8eSAndroid Build Coastguard Worker 20*ec779b8eSAndroid Build Coastguard Worker #include <stdint.h> 21*ec779b8eSAndroid Build Coastguard Worker #include <sys/types.h> 22*ec779b8eSAndroid Build Coastguard Worker #include <android/log.h> 23*ec779b8eSAndroid Build Coastguard Worker 24*ec779b8eSAndroid Build Coastguard Worker #include <media/AudioResampler.h> 25*ec779b8eSAndroid Build Coastguard Worker 26*ec779b8eSAndroid Build Coastguard Worker namespace android { 27*ec779b8eSAndroid Build Coastguard Worker 28*ec779b8eSAndroid Build Coastguard Worker 29*ec779b8eSAndroid Build Coastguard Worker typedef const int32_t * (*readCoefficientsFn)(bool upDownSample); 30*ec779b8eSAndroid Build Coastguard Worker typedef int32_t (*readResampleFirNumCoeffFn)(); 31*ec779b8eSAndroid Build Coastguard Worker typedef int32_t (*readResampleFirLerpIntBitsFn)(); 32*ec779b8eSAndroid Build Coastguard Worker 33*ec779b8eSAndroid Build Coastguard Worker // ---------------------------------------------------------------------------- 34*ec779b8eSAndroid Build Coastguard Worker 35*ec779b8eSAndroid Build Coastguard Worker class AudioResamplerSinc : public AudioResampler { 36*ec779b8eSAndroid Build Coastguard Worker public: 37*ec779b8eSAndroid Build Coastguard Worker AudioResamplerSinc(int inChannelCount, int32_t sampleRate, 38*ec779b8eSAndroid Build Coastguard Worker src_quality quality = HIGH_QUALITY); 39*ec779b8eSAndroid Build Coastguard Worker 40*ec779b8eSAndroid Build Coastguard Worker virtual ~AudioResamplerSinc(); 41*ec779b8eSAndroid Build Coastguard Worker 42*ec779b8eSAndroid Build Coastguard Worker virtual size_t resample(int32_t* out, size_t outFrameCount, 43*ec779b8eSAndroid Build Coastguard Worker AudioBufferProvider* provider); 44*ec779b8eSAndroid Build Coastguard Worker private: 45*ec779b8eSAndroid Build Coastguard Worker void init(); 46*ec779b8eSAndroid Build Coastguard Worker 47*ec779b8eSAndroid Build Coastguard Worker virtual void setVolume(float left, float right); 48*ec779b8eSAndroid Build Coastguard Worker 49*ec779b8eSAndroid Build Coastguard Worker template<int CHANNELS> 50*ec779b8eSAndroid Build Coastguard Worker size_t resample(int32_t* out, size_t outFrameCount, 51*ec779b8eSAndroid Build Coastguard Worker AudioBufferProvider* provider); 52*ec779b8eSAndroid Build Coastguard Worker 53*ec779b8eSAndroid Build Coastguard Worker template<int CHANNELS> 54*ec779b8eSAndroid Build Coastguard Worker inline void filterCoefficient( 55*ec779b8eSAndroid Build Coastguard Worker int32_t* out, uint32_t phase, const int16_t *samples, uint32_t vRL); 56*ec779b8eSAndroid Build Coastguard Worker 57*ec779b8eSAndroid Build Coastguard Worker template<int CHANNELS> 58*ec779b8eSAndroid Build Coastguard Worker inline void interpolate( 59*ec779b8eSAndroid Build Coastguard Worker int32_t& l, int32_t& r, 60*ec779b8eSAndroid Build Coastguard Worker const int32_t* coefs, size_t offset, 61*ec779b8eSAndroid Build Coastguard Worker int32_t lerp, const int16_t* samples); 62*ec779b8eSAndroid Build Coastguard Worker 63*ec779b8eSAndroid Build Coastguard Worker template<int CHANNELS> 64*ec779b8eSAndroid Build Coastguard Worker inline void read(int16_t*& impulse, uint32_t& phaseFraction, 65*ec779b8eSAndroid Build Coastguard Worker const int16_t* in, size_t inputIndex); 66*ec779b8eSAndroid Build Coastguard Worker 67*ec779b8eSAndroid Build Coastguard Worker int16_t *mState; 68*ec779b8eSAndroid Build Coastguard Worker int16_t *mImpulse; 69*ec779b8eSAndroid Build Coastguard Worker int16_t *mRingFull; 70*ec779b8eSAndroid Build Coastguard Worker int32_t mVolumeSIMD[2]; 71*ec779b8eSAndroid Build Coastguard Worker 72*ec779b8eSAndroid Build Coastguard Worker const int32_t * mFirCoefs; 73*ec779b8eSAndroid Build Coastguard Worker static const uint32_t mFirCoefsDown[]; 74*ec779b8eSAndroid Build Coastguard Worker static const uint32_t mFirCoefsUp[]; 75*ec779b8eSAndroid Build Coastguard Worker 76*ec779b8eSAndroid Build Coastguard Worker // ---------------------------------------------------------------------------- 77*ec779b8eSAndroid Build Coastguard Worker static const int32_t RESAMPLE_FIR_NUM_COEF = 8; 78*ec779b8eSAndroid Build Coastguard Worker static const int32_t RESAMPLE_FIR_LERP_INT_BITS = 7; 79*ec779b8eSAndroid Build Coastguard Worker 80*ec779b8eSAndroid Build Coastguard Worker struct Constants { 81*ec779b8eSAndroid Build Coastguard Worker int coefsBits; 82*ec779b8eSAndroid Build Coastguard Worker int cShift; 83*ec779b8eSAndroid Build Coastguard Worker uint32_t cMask; 84*ec779b8eSAndroid Build Coastguard Worker int pShift; 85*ec779b8eSAndroid Build Coastguard Worker uint32_t pMask; 86*ec779b8eSAndroid Build Coastguard Worker // number of zero-crossing on each side 87*ec779b8eSAndroid Build Coastguard Worker unsigned int halfNumCoefs; 88*ec779b8eSAndroid Build Coastguard Worker }; 89*ec779b8eSAndroid Build Coastguard Worker 90*ec779b8eSAndroid Build Coastguard Worker static Constants highQualityConstants; 91*ec779b8eSAndroid Build Coastguard Worker static Constants veryHighQualityConstants; 92*ec779b8eSAndroid Build Coastguard Worker const Constants *mConstants; // points to appropriate set of coefficient parameters 93*ec779b8eSAndroid Build Coastguard Worker 94*ec779b8eSAndroid Build Coastguard Worker static void init_routine(); 95*ec779b8eSAndroid Build Coastguard Worker }; 96*ec779b8eSAndroid Build Coastguard Worker 97*ec779b8eSAndroid Build Coastguard Worker // ---------------------------------------------------------------------------- 98*ec779b8eSAndroid Build Coastguard Worker } // namespace android 99*ec779b8eSAndroid Build Coastguard Worker 100*ec779b8eSAndroid Build Coastguard Worker #endif /*ANDROID_AUDIO_RESAMPLER_SINC_H*/ 101