xref: /aosp_15_r20/external/libxaac/encoder/ixheaace_radix2_fft.c (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 #include <math.h>
22*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_type_def.h"
23*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_constants.h"
24*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_aac_constants.h"
25*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_psy_const.h"
26*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_tns.h"
27*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_tns_params.h"
28*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_rom.h"
29*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_common_rom.h"
30*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_bitbuffer.h"
31*15dc779aSAndroid Build Coastguard Worker 
ia_enhaacplus_enc_ps_fft(complex * out,LOOPINDEX N,WORD32 nob,ixheaace_common_tables * comm_tab_ptr)32*15dc779aSAndroid Build Coastguard Worker static VOID ia_enhaacplus_enc_ps_fft(complex *out, LOOPINDEX N, WORD32 nob,
33*15dc779aSAndroid Build Coastguard Worker                                      ixheaace_common_tables *comm_tab_ptr) {
34*15dc779aSAndroid Build Coastguard Worker   LOOPINDEX block_per_stage, stage_num, inner;
35*15dc779aSAndroid Build Coastguard Worker 
36*15dc779aSAndroid Build Coastguard Worker   WORD32 index_1, index_2, tab_modifier;
37*15dc779aSAndroid Build Coastguard Worker   WORD32 len, increment, i;
38*15dc779aSAndroid Build Coastguard Worker 
39*15dc779aSAndroid Build Coastguard Worker   FLOAT32 cos_val;
40*15dc779aSAndroid Build Coastguard Worker   FLOAT32 sin_val;
41*15dc779aSAndroid Build Coastguard Worker 
42*15dc779aSAndroid Build Coastguard Worker   WORD16 index1;
43*15dc779aSAndroid Build Coastguard Worker   FLOAT32 re_temp, re_temp2;
44*15dc779aSAndroid Build Coastguard Worker   FLOAT32 im_temp, im_temp2;
45*15dc779aSAndroid Build Coastguard Worker   FLOAT32 *out1_w32, *out2_w32;
46*15dc779aSAndroid Build Coastguard Worker 
47*15dc779aSAndroid Build Coastguard Worker   len = N >> 1;
48*15dc779aSAndroid Build Coastguard Worker   index_1 = 0;
49*15dc779aSAndroid Build Coastguard Worker 
50*15dc779aSAndroid Build Coastguard Worker   out1_w32 = (FLOAT32 *)&out[index_1];
51*15dc779aSAndroid Build Coastguard Worker   out2_w32 = (FLOAT32 *)&out[index_1 + 1];
52*15dc779aSAndroid Build Coastguard Worker 
53*15dc779aSAndroid Build Coastguard Worker   for (block_per_stage = len - 1; block_per_stage >= 0; block_per_stage--) {
54*15dc779aSAndroid Build Coastguard Worker     re_temp = out1_w32[0];
55*15dc779aSAndroid Build Coastguard Worker     im_temp = out1_w32[1];
56*15dc779aSAndroid Build Coastguard Worker 
57*15dc779aSAndroid Build Coastguard Worker     re_temp2 = out2_w32[0];
58*15dc779aSAndroid Build Coastguard Worker     im_temp2 = out2_w32[1];
59*15dc779aSAndroid Build Coastguard Worker 
60*15dc779aSAndroid Build Coastguard Worker     out1_w32[0] = re_temp + re_temp2;
61*15dc779aSAndroid Build Coastguard Worker     out1_w32[1] = im_temp + im_temp2;
62*15dc779aSAndroid Build Coastguard Worker 
63*15dc779aSAndroid Build Coastguard Worker     out2_w32[0] = re_temp - re_temp2;
64*15dc779aSAndroid Build Coastguard Worker     out2_w32[1] = im_temp - im_temp2;
65*15dc779aSAndroid Build Coastguard Worker 
66*15dc779aSAndroid Build Coastguard Worker     out1_w32 += 4;
67*15dc779aSAndroid Build Coastguard Worker     out2_w32 += 4;
68*15dc779aSAndroid Build Coastguard Worker   }
69*15dc779aSAndroid Build Coastguard Worker 
70*15dc779aSAndroid Build Coastguard Worker   if (nob == 3) {
71*15dc779aSAndroid Build Coastguard Worker     i = 2; /* used for dist calculation*/
72*15dc779aSAndroid Build Coastguard Worker     increment = 1;
73*15dc779aSAndroid Build Coastguard Worker     tab_modifier = 2;
74*15dc779aSAndroid Build Coastguard Worker     for (stage_num = 1; stage_num >= 0; stage_num--) {
75*15dc779aSAndroid Build Coastguard Worker       len = len >> 1;
76*15dc779aSAndroid Build Coastguard Worker       index_1 = 0;
77*15dc779aSAndroid Build Coastguard Worker       increment += 1;
78*15dc779aSAndroid Build Coastguard Worker 
79*15dc779aSAndroid Build Coastguard Worker       tab_modifier--;
80*15dc779aSAndroid Build Coastguard Worker 
81*15dc779aSAndroid Build Coastguard Worker       for (block_per_stage = len - 1; block_per_stage >= 0; block_per_stage--) {
82*15dc779aSAndroid Build Coastguard Worker         index_2 = index_1 + i;
83*15dc779aSAndroid Build Coastguard Worker 
84*15dc779aSAndroid Build Coastguard Worker         out1_w32 = (FLOAT32 *)&out[index_1];
85*15dc779aSAndroid Build Coastguard Worker         out2_w32 = (FLOAT32 *)&out[index_2];
86*15dc779aSAndroid Build Coastguard Worker 
87*15dc779aSAndroid Build Coastguard Worker         re_temp = out1_w32[0];
88*15dc779aSAndroid Build Coastguard Worker         im_temp = out1_w32[1];
89*15dc779aSAndroid Build Coastguard Worker 
90*15dc779aSAndroid Build Coastguard Worker         re_temp2 = out2_w32[0];
91*15dc779aSAndroid Build Coastguard Worker         im_temp2 = out2_w32[1];
92*15dc779aSAndroid Build Coastguard Worker 
93*15dc779aSAndroid Build Coastguard Worker         out1_w32[0] = re_temp + re_temp2;
94*15dc779aSAndroid Build Coastguard Worker         out1_w32[1] = im_temp + im_temp2;
95*15dc779aSAndroid Build Coastguard Worker 
96*15dc779aSAndroid Build Coastguard Worker         out2_w32[0] = re_temp - re_temp2;
97*15dc779aSAndroid Build Coastguard Worker         out2_w32[1] = im_temp - im_temp2;
98*15dc779aSAndroid Build Coastguard Worker 
99*15dc779aSAndroid Build Coastguard Worker         index1 = (WORD16)tab_modifier;
100*15dc779aSAndroid Build Coastguard Worker 
101*15dc779aSAndroid Build Coastguard Worker         out1_w32 += 2;
102*15dc779aSAndroid Build Coastguard Worker         out2_w32 += 2;
103*15dc779aSAndroid Build Coastguard Worker 
104*15dc779aSAndroid Build Coastguard Worker         for (inner = 0; inner < (2 * i - 2); inner += 2) {
105*15dc779aSAndroid Build Coastguard Worker           cos_val = comm_tab_ptr->cos_arr[index1];
106*15dc779aSAndroid Build Coastguard Worker           sin_val = comm_tab_ptr->sin_arr[index1];
107*15dc779aSAndroid Build Coastguard Worker 
108*15dc779aSAndroid Build Coastguard Worker           index1++;
109*15dc779aSAndroid Build Coastguard Worker 
110*15dc779aSAndroid Build Coastguard Worker           re_temp = (out2_w32[inner] * cos_val) + (out2_w32[inner + 1] * sin_val);
111*15dc779aSAndroid Build Coastguard Worker           im_temp = (out2_w32[inner + 1] * cos_val) - (out2_w32[inner] * sin_val);
112*15dc779aSAndroid Build Coastguard Worker 
113*15dc779aSAndroid Build Coastguard Worker           re_temp2 = out1_w32[inner];
114*15dc779aSAndroid Build Coastguard Worker           im_temp2 = out1_w32[inner + 1];
115*15dc779aSAndroid Build Coastguard Worker 
116*15dc779aSAndroid Build Coastguard Worker           out1_w32[inner] = re_temp2 + re_temp;
117*15dc779aSAndroid Build Coastguard Worker           out1_w32[inner + 1] = im_temp2 + im_temp;
118*15dc779aSAndroid Build Coastguard Worker 
119*15dc779aSAndroid Build Coastguard Worker           out2_w32[inner] = re_temp2 - re_temp;
120*15dc779aSAndroid Build Coastguard Worker           out2_w32[inner + 1] = im_temp2 - im_temp;
121*15dc779aSAndroid Build Coastguard Worker         }
122*15dc779aSAndroid Build Coastguard Worker 
123*15dc779aSAndroid Build Coastguard Worker         index_1 += (WORD32)pow(2, increment);
124*15dc779aSAndroid Build Coastguard Worker       }
125*15dc779aSAndroid Build Coastguard Worker       i <<= 1;
126*15dc779aSAndroid Build Coastguard Worker     }
127*15dc779aSAndroid Build Coastguard Worker   } else {
128*15dc779aSAndroid Build Coastguard Worker     out1_w32 = (FLOAT32 *)&out[0];
129*15dc779aSAndroid Build Coastguard Worker     out2_w32 = (FLOAT32 *)&out[2];
130*15dc779aSAndroid Build Coastguard Worker 
131*15dc779aSAndroid Build Coastguard Worker     re_temp = out1_w32[0];
132*15dc779aSAndroid Build Coastguard Worker     im_temp = out1_w32[1];
133*15dc779aSAndroid Build Coastguard Worker 
134*15dc779aSAndroid Build Coastguard Worker     re_temp2 = out2_w32[0];
135*15dc779aSAndroid Build Coastguard Worker     im_temp2 = out2_w32[1];
136*15dc779aSAndroid Build Coastguard Worker 
137*15dc779aSAndroid Build Coastguard Worker     out1_w32[0] = re_temp + re_temp2;
138*15dc779aSAndroid Build Coastguard Worker     out1_w32[1] = im_temp + im_temp2;
139*15dc779aSAndroid Build Coastguard Worker 
140*15dc779aSAndroid Build Coastguard Worker     out2_w32[0] = re_temp - re_temp2;
141*15dc779aSAndroid Build Coastguard Worker     out2_w32[1] = im_temp - im_temp2;
142*15dc779aSAndroid Build Coastguard Worker 
143*15dc779aSAndroid Build Coastguard Worker     out1_w32 += 2;
144*15dc779aSAndroid Build Coastguard Worker     out2_w32 += 2;
145*15dc779aSAndroid Build Coastguard Worker 
146*15dc779aSAndroid Build Coastguard Worker     sin_val = comm_tab_ptr->sin_arr[1];
147*15dc779aSAndroid Build Coastguard Worker 
148*15dc779aSAndroid Build Coastguard Worker     re_temp = out2_w32[1] * sin_val;
149*15dc779aSAndroid Build Coastguard Worker     im_temp = out2_w32[0] * sin_val;
150*15dc779aSAndroid Build Coastguard Worker 
151*15dc779aSAndroid Build Coastguard Worker     re_temp2 = out1_w32[0];
152*15dc779aSAndroid Build Coastguard Worker     im_temp2 = out1_w32[1];
153*15dc779aSAndroid Build Coastguard Worker 
154*15dc779aSAndroid Build Coastguard Worker     out1_w32[0] = re_temp2 + re_temp;
155*15dc779aSAndroid Build Coastguard Worker     out1_w32[1] = im_temp2 - im_temp;
156*15dc779aSAndroid Build Coastguard Worker 
157*15dc779aSAndroid Build Coastguard Worker     out2_w32[0] = re_temp2 - re_temp;
158*15dc779aSAndroid Build Coastguard Worker     out2_w32[1] = im_temp2 + im_temp;
159*15dc779aSAndroid Build Coastguard Worker   }
160*15dc779aSAndroid Build Coastguard Worker }
161*15dc779aSAndroid Build Coastguard Worker 
ia_enhaacplus_enc_fft(complex * out,WORD32 N,ixheaace_common_tables * pstr_common_tab)162*15dc779aSAndroid Build Coastguard Worker VOID ia_enhaacplus_enc_fft(complex *out, WORD32 N, ixheaace_common_tables *pstr_common_tab) {
163*15dc779aSAndroid Build Coastguard Worker   WORD32 nob;
164*15dc779aSAndroid Build Coastguard Worker   WORD32 len;
165*15dc779aSAndroid Build Coastguard Worker 
166*15dc779aSAndroid Build Coastguard Worker   /* time domain samples obtained with bit reversal*/
167*15dc779aSAndroid Build Coastguard Worker   len = N;
168*15dc779aSAndroid Build Coastguard Worker 
169*15dc779aSAndroid Build Coastguard Worker   if (len == 8) {
170*15dc779aSAndroid Build Coastguard Worker     nob = 3;
171*15dc779aSAndroid Build Coastguard Worker   } else {
172*15dc779aSAndroid Build Coastguard Worker     nob = 2;
173*15dc779aSAndroid Build Coastguard Worker   }
174*15dc779aSAndroid Build Coastguard Worker   ia_enhaacplus_enc_ps_fft(out, N, nob, pstr_common_tab);
175*15dc779aSAndroid Build Coastguard Worker }
176