xref: /aosp_15_r20/external/libxaac/encoder/ixheaace_fft.h (revision 15dc779a375ca8b5125643b829a8aa4b70d7f451)
1*15dc779aSAndroid Build Coastguard Worker /******************************************************************************
2*15dc779aSAndroid Build Coastguard Worker  *                                                                            *
3*15dc779aSAndroid Build Coastguard Worker  * Copyright (C) 2023 The Android Open Source Project
4*15dc779aSAndroid Build Coastguard Worker  *
5*15dc779aSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
6*15dc779aSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
7*15dc779aSAndroid Build Coastguard Worker  * You may obtain a copy of the License at:
8*15dc779aSAndroid Build Coastguard Worker  *
9*15dc779aSAndroid Build Coastguard Worker  * http://www.apache.org/licenses/LICENSE-2.0
10*15dc779aSAndroid Build Coastguard Worker  *
11*15dc779aSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
12*15dc779aSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
13*15dc779aSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*15dc779aSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
15*15dc779aSAndroid Build Coastguard Worker  * limitations under the License.
16*15dc779aSAndroid Build Coastguard Worker  *
17*15dc779aSAndroid Build Coastguard Worker  *****************************************************************************
18*15dc779aSAndroid Build Coastguard Worker  * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*15dc779aSAndroid Build Coastguard Worker  */
20*15dc779aSAndroid Build Coastguard Worker 
21*15dc779aSAndroid Build Coastguard Worker #pragma once
22*15dc779aSAndroid Build Coastguard Worker #ifndef PI
23*15dc779aSAndroid Build Coastguard Worker #define PI (3.141592653589795)
24*15dc779aSAndroid Build Coastguard Worker #endif
25*15dc779aSAndroid Build Coastguard Worker 
26*15dc779aSAndroid Build Coastguard Worker #define LS_TRANS_128 448  //((long_frame_len - FRAME_LEN_SHORT_128) / 2)
27*15dc779aSAndroid Build Coastguard Worker #define LS_TRANS_120 420
28*15dc779aSAndroid Build Coastguard Worker 
29*15dc779aSAndroid Build Coastguard Worker #define DIG_REV(i, m, j)                                      \
30*15dc779aSAndroid Build Coastguard Worker   do {                                                        \
31*15dc779aSAndroid Build Coastguard Worker     unsigned _ = (i);                                         \
32*15dc779aSAndroid Build Coastguard Worker     _ = ((_ & 0x33333333) << 2) | ((_ & ~0x33333333) >> 2);   \
33*15dc779aSAndroid Build Coastguard Worker     _ = ((_ & 0x0F0F0F0F) << 4) | ((_ & ~0x0F0F0F0F) >> 4);   \
34*15dc779aSAndroid Build Coastguard Worker     _ = ((_ & 0x00FF00FF) << 8) | ((_ & ~0x00FF00FF) >> 8);   \
35*15dc779aSAndroid Build Coastguard Worker     _ = ((_ & 0x0000FFFF) << 16) | ((_ & ~0x0000FFFF) >> 16); \
36*15dc779aSAndroid Build Coastguard Worker     (j) = _ >> (m);                                           \
37*15dc779aSAndroid Build Coastguard Worker   } while (0)
38*15dc779aSAndroid Build Coastguard Worker 
39*15dc779aSAndroid Build Coastguard Worker #define DIG_REV_NEW(i, m, j)                                \
40*15dc779aSAndroid Build Coastguard Worker   do {                                                      \
41*15dc779aSAndroid Build Coastguard Worker     unsigned _ = (i);                                       \
42*15dc779aSAndroid Build Coastguard Worker     _ = ((_ & 0x33333333) << 2) | ((_ & ~0x33333333) >> 2); \
43*15dc779aSAndroid Build Coastguard Worker     _ = ((_ & 0x0F0F0F0F) << 4) | ((_ & ~0x0F0F0F0F) >> 4); \
44*15dc779aSAndroid Build Coastguard Worker     _ = ((_ & 0x00FF00FF) << 8) | ((_ & ~0x00FF00FF) >> 8); \
45*15dc779aSAndroid Build Coastguard Worker     (j) = _ >> (m);                                         \
46*15dc779aSAndroid Build Coastguard Worker   } while (0)
47*15dc779aSAndroid Build Coastguard Worker 
48*15dc779aSAndroid Build Coastguard Worker typedef struct {
49*15dc779aSAndroid Build Coastguard Worker   FLOAT32 p_fft_p2_y[2048];
50*15dc779aSAndroid Build Coastguard Worker   FLOAT32 p_fft_p3_data_3[800];
51*15dc779aSAndroid Build Coastguard Worker   FLOAT32 p_fft_p3_y[2048];
52*15dc779aSAndroid Build Coastguard Worker } ixheaace_scratch_mem;
53*15dc779aSAndroid Build Coastguard Worker 
54*15dc779aSAndroid Build Coastguard Worker VOID ia_enhaacplus_enc_complex_fft(FLOAT32 *ptr_data, WORD32 len,
55*15dc779aSAndroid Build Coastguard Worker                                    ixheaace_scratch_mem *pstr_scratch);
56*15dc779aSAndroid Build Coastguard Worker 
57*15dc779aSAndroid Build Coastguard Worker VOID ia_eaacp_enc_pre_twiddle_aac(FLOAT32 *ptr_x, FLOAT32 *ptr_data, WORD32 n,
58*15dc779aSAndroid Build Coastguard Worker                                   const FLOAT32 *ptr_cos_array);
59*15dc779aSAndroid Build Coastguard Worker 
60*15dc779aSAndroid Build Coastguard Worker VOID ia_enhaacplus_enc_post_twiddle(FLOAT32 *ptr_out, FLOAT32 *ptr_x,
61*15dc779aSAndroid Build Coastguard Worker                                     const FLOAT32 *ptr_cos_sin_tbl, WORD m);
62*15dc779aSAndroid Build Coastguard Worker 
63*15dc779aSAndroid Build Coastguard Worker VOID ia_aac_ld_enc_mdct_480(FLOAT32 *ptr_inp, FLOAT32 *ptr_scratch, WORD32 mdct_flag,
64*15dc779aSAndroid Build Coastguard Worker                             ixheaace_mdct_tables *pstr_mdct_tables);
65*15dc779aSAndroid Build Coastguard Worker 
66*15dc779aSAndroid Build Coastguard Worker VOID ia_enhaacplus_enc_complex_fft_p2(FLOAT32 *ptr_x, WORD32 nlength,
67*15dc779aSAndroid Build Coastguard Worker                                       FLOAT32 *ptr_scratch_fft_p2_y);
68*15dc779aSAndroid Build Coastguard Worker 
69*15dc779aSAndroid Build Coastguard Worker VOID ixheaace_transform_real_lc_ld(FLOAT32 *ptr_mdct_delay_buffer, const FLOAT32 *ptr_time_signal,
70*15dc779aSAndroid Build Coastguard Worker                                    WORD32 ch_increment, FLOAT32 *ptr_real_out, WORD32 block_type,
71*15dc779aSAndroid Build Coastguard Worker                                    WORD32 frame_len, WORD8 *ptr_scratch);
72*15dc779aSAndroid Build Coastguard Worker 
73*15dc779aSAndroid Build Coastguard Worker VOID ia_enhaacplus_enc_transform_real_eld(FLOAT32 *ptr_mdct_delay_buffer,
74*15dc779aSAndroid Build Coastguard Worker                                           const FLOAT32 *ptr_time_signal, WORD32 ch_increment,
75*15dc779aSAndroid Build Coastguard Worker                                           FLOAT32 *ptr_real_out, WORD8 *ptr_shared_buffer5,
76*15dc779aSAndroid Build Coastguard Worker                                           WORD32 frame_len);
77*15dc779aSAndroid Build Coastguard Worker 
78*15dc779aSAndroid Build Coastguard Worker VOID ia_enhaacplus_enc_transform_real(FLOAT32 *ptr_mdct_delay_buffer,
79*15dc779aSAndroid Build Coastguard Worker                                       const FLOAT32 *ptr_time_signal, WORD32 ch_increment,
80*15dc779aSAndroid Build Coastguard Worker                                       FLOAT32 *ptr_real_out, ixheaace_mdct_tables *pstr_mdct_tab,
81*15dc779aSAndroid Build Coastguard Worker                                       FLOAT32 *ptr_shared_buffer1, WORD8 *ptr_shared_buffer5,
82*15dc779aSAndroid Build Coastguard Worker                                       WORD32 long_frame_len);