xref: /aosp_15_r20/frameworks/av/media/libaudioprocessing/AudioResamplerSinc.h (revision ec779b8e0859a360c3d303172224686826e6e0e1)
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