Coverage Report

Created: 2025-09-17 07:02

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libxaac/encoder/ixheaace_tns_init.c
Line
Count
Source
1
/******************************************************************************
2
 *                                                                            *
3
 * Copyright (C) 2023 The Android Open Source Project
4
 *
5
 * Licensed under the Apache License, Version 2.0 (the "License");
6
 * you may not use this file except in compliance with the License.
7
 * You may obtain a copy of the License at:
8
 *
9
 * http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 *
17
 *****************************************************************************
18
 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19
 */
20
21
#include <math.h>
22
#include <stdlib.h>
23
24
#include "ixheaac_type_def.h"
25
#include "ixheaac_constants.h"
26
#include "ixheaace_aac_constants.h"
27
#include "ixheaac_error_standards.h"
28
#include "ixheaac_basic_ops32.h"
29
#include "ixheaac_basic_ops16.h"
30
#include "ixheaac_basic_ops40.h"
31
#include "ixheaac_basic_ops.h"
32
33
#include "ixheaace_common_rom.h"
34
#include "ixheaace_psy_const.h"
35
#include "ixheaace_tns.h"
36
#include "ixheaace_tns_params.h"
37
#include "ixheaace_rom.h"
38
#include "ixheaace_bitbuffer.h"
39
#include "ixheaace_psy_configuration.h"
40
#include "ixheaace_tns_func.h"
41
#include "ixheaace_common_utils.h"
42
43
static WORD32 ia_enhaacplus_enc_freq_to_band_with_rounding(WORD32 freq, WORD32 fs,
44
                                                           WORD32 num_bands,
45
57.2k
                                                           const WORD32 *ptr_band_start_offset) {
46
57.2k
  WORD32 line_num, band;
47
48
57.2k
  line_num = (freq * ptr_band_start_offset[num_bands] * 4 / fs + 1) / 2;
49
50
  /* freq > fs/2 */
51
57.2k
  if (line_num >= ptr_band_start_offset[num_bands]) {
52
9.89k
    return num_bands;
53
9.89k
  }
54
55
  /* find band the line number lies in */
56
  /* bandStartOffset[] */
57
637k
  for (band = 0; band < num_bands; band++) {
58
637k
    if (ptr_band_start_offset[band + 1] > line_num) break;
59
637k
  }
60
61
  /* round to nearest band border */
62
47.3k
  if (line_num - ptr_band_start_offset[band] > ptr_band_start_offset[band + 1] - line_num) {
63
13.0k
    band++;
64
13.0k
  }
65
66
47.3k
  return band;
67
57.2k
}
68
69
static VOID ia_enhaacplus_enc_calc_gauss_window(FLOAT32 *ptr_win, const WORD16 win_size,
70
                                                const WORD32 sampling_rate,
71
                                                const WORD16 block_type,
72
11.4k
                                                const FLOAT32 time_resolution) {
73
11.4k
  WORD16 i;
74
75
11.4k
  FLOAT32 accu_gauss_exp;
76
11.4k
  accu_gauss_exp = (sampling_rate * time_resolution) * PI_BY_1000;
77
78
11.4k
  if (block_type != SHORT_WINDOW) {
79
7.00k
    accu_gauss_exp = (FLOAT32)(accu_gauss_exp / FRAME_LEN_1024);
80
7.00k
  } else {
81
4.45k
    accu_gauss_exp = (FLOAT32)(accu_gauss_exp / FRAME_LEN_SHORT_128);
82
4.45k
  }
83
84
11.4k
  accu_gauss_exp = -(accu_gauss_exp * 0.5f * accu_gauss_exp);
85
86
129k
  for (i = 0; i < win_size; i++) {
87
117k
    ptr_win[i] = (FLOAT32)exp(accu_gauss_exp * (i + 0.5) * (i + 0.5));
88
117k
  }
89
11.4k
}
90
91
IA_ERRORCODE
92
ia_enhaacplus_enc_init_tns_configuration(WORD32 bit_rate, WORD32 sample_rate, WORD32 channels,
93
                                         ixheaace_temporal_noise_shaping_config *pstr_tns_config,
94
                                         ixheaace_psy_configuration_long *pstr_psy_config,
95
                                         WORD32 active,
96
                                         ixheaace_temporal_noise_shaping_tables *pstr_tns_tab,
97
                                         WORD32 frame_length, WORD32 aot)
98
99
7.00k
{
100
7.00k
  IA_ERRORCODE error;
101
7.00k
  pstr_tns_config->max_order = TEMPORAL_NOISE_SHAPING_MAX_ORDER;
102
7.00k
  pstr_tns_config->tns_start_freq = TEMPORAL_NOISE_SHAPING_START_FREQ;
103
7.00k
  pstr_tns_config->coef_res = TEMPORAL_NOISE_SHAPING_COEF_RES;
104
105
7.00k
  error = ia_enhaacplus_enc_get_tns_param(&pstr_tns_config->conf_tab, bit_rate / channels,
106
7.00k
                                          channels, LONG_WINDOW, pstr_tns_tab->tns_info_tab,
107
7.00k
                                          sizeof(pstr_tns_tab->tns_info_tab));
108
109
7.00k
  if (error != IA_NO_ERROR) {
110
0
    return error;
111
0
  }
112
113
7.00k
  ia_enhaacplus_enc_calc_gauss_window(pstr_tns_config->acf_window_float,
114
7.00k
                                      (const WORD16)(pstr_tns_config->max_order + 1), sample_rate,
115
7.00k
                                      LONG_WINDOW, pstr_tns_config->conf_tab.tns_time_resolution
116
117
7.00k
  );
118
119
7.00k
  ia_enhaacplus_enc_get_tns_max_bands(
120
7.00k
      sample_rate, LONG_WINDOW, &pstr_tns_config->tns_max_sfb, pstr_tns_tab->tns_max_bands_table,
121
7.00k
      sizeof(pstr_tns_tab->tns_max_bands_table), aot, frame_length);
122
123
7.00k
  pstr_tns_config->tns_active = 1;
124
125
7.00k
  if (active == 0) {
126
2.92k
    pstr_tns_config->tns_active = 0;
127
2.92k
  }
128
129
  /*now calc band and line borders */
130
7.00k
  pstr_tns_config->tns_stop_band = MIN(pstr_psy_config->sfb_cnt, pstr_tns_config->tns_max_sfb);
131
132
7.00k
  pstr_tns_config->tns_stop_line = pstr_psy_config->sfb_offsets[pstr_tns_config->tns_stop_band];
133
134
7.00k
  pstr_tns_config->tns_start_band = ia_enhaacplus_enc_freq_to_band_with_rounding(
135
7.00k
      pstr_tns_config->tns_start_freq, sample_rate, pstr_psy_config->sfb_cnt,
136
7.00k
      pstr_psy_config->sfb_offsets);
137
138
7.00k
  pstr_tns_config->tns_modify_begin_cb = ia_enhaacplus_enc_freq_to_band_with_rounding(
139
7.00k
      TEMPORAL_NOISE_SHAPING_MODIFY_BEGIN, sample_rate, pstr_psy_config->sfb_cnt,
140
7.00k
      pstr_psy_config->sfb_offsets);
141
142
7.00k
  pstr_tns_config->tns_ratio_patch_lowest_cb = ia_enhaacplus_enc_freq_to_band_with_rounding(
143
7.00k
      RATIO_PATCH_LOWER_BORDER, sample_rate, pstr_psy_config->sfb_cnt,
144
7.00k
      pstr_psy_config->sfb_offsets);
145
146
7.00k
  pstr_tns_config->tns_start_line = pstr_psy_config->sfb_offsets[pstr_tns_config->tns_start_band];
147
148
7.00k
  pstr_tns_config->lpc_stop_band = ia_enhaacplus_enc_freq_to_band_with_rounding(
149
7.00k
      pstr_tns_config->conf_tab.lpc_stop_freq, sample_rate, pstr_psy_config->sfb_cnt,
150
7.00k
      pstr_psy_config->sfb_offsets);
151
152
7.00k
  pstr_tns_config->lpc_stop_band =
153
7.00k
      MIN(pstr_tns_config->lpc_stop_band, pstr_psy_config->sfb_active);
154
155
7.00k
  pstr_tns_config->lpc_stop_line = pstr_psy_config->sfb_offsets[pstr_tns_config->lpc_stop_band];
156
7.00k
  pstr_tns_config->lpc_start_band = ia_enhaacplus_enc_freq_to_band_with_rounding(
157
7.00k
      pstr_tns_config->conf_tab.lpc_start_freq, sample_rate, pstr_psy_config->sfb_cnt,
158
7.00k
      pstr_psy_config->sfb_offsets);
159
160
7.00k
  pstr_tns_config->lpc_start_line = pstr_psy_config->sfb_offsets[pstr_tns_config->lpc_start_band];
161
7.00k
  pstr_tns_config->threshold = pstr_tns_config->conf_tab.thresh_on;
162
163
7.00k
  return IA_NO_ERROR;
164
7.00k
}
165
166
IA_ERRORCODE ia_enhaacplus_enc_init_tns_configuration_short(
167
    WORD32 bit_rate, WORD32 sample_rate, WORD32 channels,
168
    ixheaace_temporal_noise_shaping_config *pstr_tns_config,
169
    ixheaace_psy_configuration_short *pstr_psy_config, WORD32 active,
170
4.45k
    ixheaace_temporal_noise_shaping_tables *pstr_tns_tab, WORD32 frame_length, WORD32 aot) {
171
4.45k
  IA_ERRORCODE error = IA_NO_ERROR;
172
4.45k
  pstr_tns_config->max_order = TEMPORAL_NOISE_SHAPING_MAX_ORDER_SHORT;
173
4.45k
  pstr_tns_config->tns_start_freq = TEMPORAL_NOISE_SHAPING_START_FREQ_SHORT;
174
4.45k
  pstr_tns_config->coef_res = TEMPORAL_NOISE_SHAPING_COEF_RES_SHORT;
175
176
4.45k
  error = ia_enhaacplus_enc_get_tns_param(&pstr_tns_config->conf_tab, bit_rate / channels,
177
4.45k
                                          channels, SHORT_WINDOW, pstr_tns_tab->tns_info_tab,
178
4.45k
                                          sizeof(pstr_tns_tab->tns_info_tab));
179
4.45k
  if (error != IA_NO_ERROR) {
180
0
    return error;
181
0
  }
182
4.45k
  ia_enhaacplus_enc_calc_gauss_window(
183
4.45k
      pstr_tns_config->acf_window_float, (const WORD16)(pstr_tns_config->max_order + 1),
184
4.45k
      sample_rate, SHORT_WINDOW, pstr_tns_config->conf_tab.tns_time_resolution);
185
186
4.45k
  ia_enhaacplus_enc_get_tns_max_bands(
187
4.45k
      sample_rate, SHORT_WINDOW, &pstr_tns_config->tns_max_sfb, pstr_tns_tab->tns_max_bands_table,
188
4.45k
      sizeof(pstr_tns_tab->tns_max_bands_table), aot, frame_length);
189
190
4.45k
  pstr_tns_config->tns_active = 1;
191
192
4.45k
  if (active == 0) {
193
1.78k
    pstr_tns_config->tns_active = 0;
194
1.78k
  }
195
196
  /*now calc band and line borders */
197
198
4.45k
  pstr_tns_config->tns_stop_band = MIN(pstr_psy_config->sfb_cnt, pstr_tns_config->tns_max_sfb);
199
200
4.45k
  pstr_tns_config->tns_stop_line = pstr_psy_config->sfb_offsets[pstr_tns_config->tns_stop_band];
201
202
4.45k
  pstr_tns_config->tns_start_band = ia_enhaacplus_enc_freq_to_band_with_rounding(
203
4.45k
      pstr_tns_config->tns_start_freq, sample_rate, pstr_psy_config->sfb_cnt,
204
4.45k
      pstr_psy_config->sfb_offsets);
205
206
4.45k
  pstr_tns_config->tns_modify_begin_cb = ia_enhaacplus_enc_freq_to_band_with_rounding(
207
4.45k
      TEMPORAL_NOISE_SHAPING_MODIFY_BEGIN, sample_rate, pstr_psy_config->sfb_cnt,
208
4.45k
      pstr_psy_config->sfb_offsets);
209
210
4.45k
  pstr_tns_config->tns_ratio_patch_lowest_cb = ia_enhaacplus_enc_freq_to_band_with_rounding(
211
4.45k
      RATIO_PATCH_LOWER_BORDER, sample_rate, pstr_psy_config->sfb_cnt,
212
4.45k
      pstr_psy_config->sfb_offsets);
213
214
4.45k
  pstr_tns_config->tns_start_line = pstr_psy_config->sfb_offsets[pstr_tns_config->tns_start_band];
215
216
4.45k
  pstr_tns_config->lpc_stop_band = ia_enhaacplus_enc_freq_to_band_with_rounding(
217
4.45k
      pstr_tns_config->conf_tab.lpc_stop_freq, sample_rate, pstr_psy_config->sfb_cnt,
218
4.45k
      pstr_psy_config->sfb_offsets);
219
220
4.45k
  pstr_tns_config->lpc_stop_band =
221
4.45k
      MIN(pstr_tns_config->lpc_stop_band, pstr_psy_config->sfb_active);
222
223
4.45k
  pstr_tns_config->lpc_stop_line = pstr_psy_config->sfb_offsets[pstr_tns_config->lpc_stop_band];
224
225
4.45k
  pstr_tns_config->lpc_start_band = ia_enhaacplus_enc_freq_to_band_with_rounding(
226
4.45k
      pstr_tns_config->conf_tab.lpc_start_freq, sample_rate, pstr_psy_config->sfb_cnt,
227
4.45k
      pstr_psy_config->sfb_offsets);
228
229
4.45k
  pstr_tns_config->lpc_start_line = pstr_psy_config->sfb_offsets[pstr_tns_config->lpc_start_band];
230
4.45k
  pstr_tns_config->threshold = pstr_tns_config->conf_tab.thresh_on;
231
232
4.45k
  return IA_NO_ERROR;
233
4.45k
}
234
235
const WORD32 ia_enhaacplus_enc_m_log2_table[INT_BITS] = {
236
    0x00000000, 0x4ae00d00, 0x2934f080, 0x15c01a3f, 0x0b31fb80, 0x05aeb4e0, 0x02dcf2d0,
237
    0x016fe50c, 0x00b84e23, 0x005c3e10, 0x002e24ca, 0x001713d6, 0x000b8a47, 0x0005c53b,
238
    0x0002e2a3, 0x00017153, 0x0000b8aa, 0x00005c55, 0x00002e2b, 0x00001715, 0x00000b8b,
239
    0x000005c5, 0x000002e3, 0x00000171, 0x000000b9, 0x0000005c, 0x0000002e, 0x00000017,
240
    0x0000000c, 0x00000006, 0x00000003, 0x00000001};