Coverage Report

Created: 2025-11-09 07:01

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libxaac/encoder/iusace_ms.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 "ixheaac_type_def.h"
22
#include "ixheaac_constants.h"
23
#include "iusace_cnst.h"
24
#include "iusace_bitbuffer.h"
25
#include "iusace_tns_usac.h"
26
#include "iusace_psy_mod.h"
27
#include "ixheaac_basic_ops32.h"
28
#include "ixheaac_basic_ops40.h"
29
#include "ixheaac_basic_ops.h"
30
31
VOID iusace_ms_apply(ia_psy_mod_data_struct *pstr_psy_data, FLOAT64 *ptr_spec_left,
32
                     FLOAT64 *ptr_spec_right, WORD32 *ms_select,
33
                     WORD32 ms_used[MAX_SHORT_WINDOWS][MAX_SFB_LONG], const WORD32 sfb_count,
34
                     const WORD32 sfb_per_group, const WORD32 max_sfb_per_grp,
35
171k
                     const WORD32 *ptr_sfb_offsets, WORD32 chn, FLOAT64 *ptr_ms_spec) {
36
171k
  FLOAT32 *ptr_sfb_enegry_left = pstr_psy_data[chn].ptr_sfb_energy_long;
37
171k
  FLOAT32 *ptr_sfb_energy_right = pstr_psy_data[chn + 1].ptr_sfb_energy_long;
38
171k
  const FLOAT32 *ptr_sfb_energy_mid = pstr_psy_data[chn].ptr_sfb_energy_long_ms;
39
171k
  const FLOAT32 *ptr_sfb_energy_side = pstr_psy_data[chn + 1].ptr_sfb_energy_long_ms;
40
171k
  FLOAT32 *ptr_sfb_thr_left = pstr_psy_data[chn].ptr_sfb_thr_long;
41
171k
  FLOAT32 *ptr_sfb_thr_right = pstr_psy_data[chn + 1].ptr_sfb_thr_long;
42
171k
  FLOAT32 *ptr_sfb_spread_energy_left = pstr_psy_data[chn].ptr_sfb_spreaded_energy_long;
43
171k
  FLOAT32 *ptr_sfb_spread_energy_right = pstr_psy_data[chn + 1].ptr_sfb_spreaded_energy_long;
44
171k
  WORD32 sfb, sfb_offsets, j;
45
171k
  WORD32 grp = 0;
46
171k
  WORD32 ms_counter = 0;
47
171k
  WORD32 lr_counter = 0;
48
49
171k
  *ms_select = 0;
50
51
496k
  for (sfb = 0; sfb < sfb_count; sfb += sfb_per_group, grp++) {
52
7.28M
    for (sfb_offsets = 0; sfb_offsets < max_sfb_per_grp; sfb_offsets++) {
53
6.96M
      FLOAT32 left_right, mid_side, min_thr;
54
6.96M
      WORD32 use_ms;
55
6.96M
      ms_used[grp][sfb_offsets] = 0;
56
57
6.96M
      min_thr = MIN(ptr_sfb_thr_left[sfb + sfb_offsets], ptr_sfb_thr_right[sfb + sfb_offsets]);
58
59
6.96M
      left_right =
60
6.96M
          (ptr_sfb_thr_left[sfb + sfb_offsets] /
61
6.96M
           MAX(ptr_sfb_enegry_left[sfb + sfb_offsets], ptr_sfb_thr_left[sfb + sfb_offsets])) *
62
6.96M
          (ptr_sfb_thr_right[sfb + sfb_offsets] /
63
6.96M
           max(ptr_sfb_energy_right[sfb + sfb_offsets], ptr_sfb_thr_right[sfb + sfb_offsets]));
64
65
6.96M
      mid_side = (min_thr / max(ptr_sfb_energy_mid[sfb + sfb_offsets], min_thr)) *
66
6.96M
                 (min_thr / max(ptr_sfb_energy_side[sfb + sfb_offsets], min_thr));
67
68
6.96M
      use_ms = (mid_side >= left_right);
69
70
6.96M
      if (use_ms) {
71
6.79M
        ms_used[grp][sfb_offsets] = 1;
72
73
134M
        for (j = ptr_sfb_offsets[sfb + sfb_offsets]; j < ptr_sfb_offsets[sfb + sfb_offsets + 1];
74
127M
             j++) {
75
127M
          if (ptr_ms_spec != NULL) {
76
72.1M
            ptr_spec_left[j] = ptr_ms_spec[j];
77
72.1M
            ptr_spec_right[j] = ptr_ms_spec[1024 + j];
78
72.1M
          } else {
79
55.5M
            FLOAT64 tmp = ptr_spec_left[j];
80
81
55.5M
            ptr_spec_left[j] = 0.5f * (ptr_spec_left[j] + ptr_spec_right[j]);
82
83
55.5M
            ptr_spec_right[j] = 0.5f * (tmp - ptr_spec_right[j]);
84
55.5M
          }
85
127M
        }
86
87
6.79M
        ptr_sfb_thr_left[sfb + sfb_offsets] = ptr_sfb_thr_right[sfb + sfb_offsets] = min_thr;
88
89
6.79M
        ptr_sfb_enegry_left[sfb + sfb_offsets] = ptr_sfb_energy_mid[sfb + sfb_offsets];
90
6.79M
        ptr_sfb_energy_right[sfb + sfb_offsets] = ptr_sfb_energy_side[sfb + sfb_offsets];
91
92
6.79M
        ptr_sfb_spread_energy_left[sfb + sfb_offsets] =
93
6.79M
            ptr_sfb_spread_energy_right[sfb + sfb_offsets] =
94
6.79M
                min(ptr_sfb_spread_energy_left[sfb + sfb_offsets],
95
6.79M
                    ptr_sfb_spread_energy_right[sfb + sfb_offsets]) *
96
6.79M
                0.5f;
97
98
6.79M
        ms_counter++;
99
6.79M
      } else {
100
170k
        ms_used[grp][sfb_offsets] = 0;
101
170k
        lr_counter++;
102
170k
      }
103
6.96M
    }
104
324k
  }
105
106
171k
  if (ms_counter == 0) {
107
9.69k
    *ms_select = 0;
108
161k
  } else {
109
161k
    if (lr_counter != 0) {
110
22.8k
      *ms_select = 1;
111
138k
    } else {
112
138k
      *ms_select = 2;
113
138k
    }
114
161k
  }
115
171k
  return;
116
171k
}
117
118
VOID iusace_calc_ms_band_energy(const FLOAT64 *ptr_spec_left, const FLOAT64 *ptr_spec_right,
119
                                const WORD32 *ptr_band_offset, const WORD32 num_bands,
120
743k
                                FLOAT32 *ptr_band_energy_mid, FLOAT32 *ptr_band_energy_side) {
121
743k
  WORD32 i, j;
122
123
743k
  j = 0;
124
15.1M
  for (i = 0; i < num_bands; i++) {
125
14.3M
    ptr_band_energy_mid[i] = 0.0f;
126
14.3M
    ptr_band_energy_side[i] = 0.0f;
127
128
221M
    while (j < ptr_band_offset[i + 1]) {
129
207M
      FLOAT32 specm, specs;
130
131
207M
      specm = (FLOAT32)(0.5f * (ptr_spec_left[j] + ptr_spec_right[j]));
132
207M
      specs = (FLOAT32)(0.5f * (ptr_spec_left[j] - ptr_spec_right[j]));
133
134
207M
      ptr_band_energy_mid[i] += specm * specm;
135
207M
      ptr_band_energy_side[i] += specs * specs;
136
137
207M
      j++;
138
207M
    }
139
14.3M
  }
140
141
743k
  return;
142
743k
}