Coverage Report

Created: 2026-03-20 06:59

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/proc/self/cwd/libfaad/pns.c
Line
Count
Source
1
/*
2
** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
3
** Copyright (C) 2003-2005 M. Bakker, Nero AG, http://www.nero.com
4
**
5
** This program is free software; you can redistribute it and/or modify
6
** it under the terms of the GNU General Public License as published by
7
** the Free Software Foundation; either version 2 of the License, or
8
** (at your option) any later version.
9
**
10
** This program is distributed in the hope that it will be useful,
11
** but WITHOUT ANY WARRANTY; without even the implied warranty of
12
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
** GNU General Public License for more details.
14
**
15
** You should have received a copy of the GNU General Public License
16
** along with this program; if not, write to the Free Software
17
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18
**
19
** Any non-GPL usage of this software or parts of this software is strictly
20
** forbidden.
21
**
22
** The "appropriate copyright message" mentioned in section 2c of the GPLv2
23
** must read: "Code from FAAD2 is copyright (c) Nero AG, www.nero.com"
24
**
25
** Commercial non-GPL licensing of this software is possible.
26
** For more info contact Nero AG through Mpeg4AAClicense@nero.com.
27
**
28
** $Id: pns.c,v 1.39 2010/06/04 20:47:56 menno Exp $
29
**/
30
31
#include "common.h"
32
#include "structs.h"
33
34
#include "pns.h"
35
36
37
/* static function declarations */
38
static void gen_rand_vector(real_t *spec, int16_t scale_factor, uint16_t size,
39
                            uint8_t sub,
40
                            /* RNG states */ uint32_t *__r1, uint32_t *__r2);
41
42
43
#ifdef FIXED_POINT
44
45
static real_t const pow2_table[] =
46
{
47
    COEF_CONST(1.0),
48
    COEF_CONST(1.18920711500272),
49
    COEF_CONST(1.41421356237310),
50
    COEF_CONST(1.68179283050743)
51
};
52
53
// mean_energy_table[x] == sqrt(3 / x)
54
static real_t const mean_energy_table[] =
55
{
56
    COEF_CONST(0.0),                // should not happen
57
    COEF_CONST(1.7320508075688772),
58
    COEF_CONST(1.224744871391589),
59
    COEF_CONST(1.0),                // sqrt(3/3)
60
    COEF_CONST(0.8660254037844386),
61
    COEF_CONST(0.7745966692414834),
62
    COEF_CONST(0.7071067811865476),
63
    COEF_CONST(0.6546536707079771),
64
    COEF_CONST(0.6123724356957945),
65
    COEF_CONST(0.5773502691896257),
66
    COEF_CONST(0.5477225575051661),
67
    COEF_CONST(0.5222329678670935),
68
    COEF_CONST(0.5),                // sqrt(3/12)
69
    COEF_CONST(0.4803844614152614),
70
    COEF_CONST(0.4629100498862757),
71
    COEF_CONST(0.4472135954999579),
72
};
73
#endif
74
75
/* The function gen_rand_vector(addr, size) generates a vector of length
76
   <size> with signed random values of average energy MEAN_NRG per random
77
   value. A suitable random number generator can be realized using one
78
   multiplication/accumulation per random value.
79
*/
80
static INLINE void gen_rand_vector(real_t *spec, int16_t scale_factor, uint16_t size,
81
                                   uint8_t sub,
82
                                   /* RNG states */ uint32_t *__r1, uint32_t *__r2)
83
117k
{
84
#ifndef FIXED_POINT
85
    uint16_t i;
86
    real_t energy = 0.0;
87
    (void)sub;
88
89
68.5k
    scale_factor = min(max(scale_factor, -120), 120);
90
91
405k
    for (i = 0; i < size; i++)
92
336k
    {
93
336k
        real_t tmp = (real_t)(int32_t)ne_rng(__r1, __r2);
94
336k
        spec[i] = tmp;
95
336k
        energy += tmp*tmp;
96
336k
    }
97
98
68.5k
    if (energy > 0)
99
20.8k
    {
100
20.8k
        real_t scale = (real_t)1.0/(real_t)sqrt(energy);
101
20.8k
        scale *= (real_t)pow(2.0, 0.25 * scale_factor);
102
357k
        for (i = 0; i < size; i++)
103
336k
        {
104
336k
            spec[i] *= scale;
105
336k
        }
106
20.8k
    }
107
#else
108
    uint16_t i;
109
    real_t scale;
110
    int32_t exp, frac;
111
    int32_t idx, mask;
112
113
    /* IMDCT pre-scaling */
114
    scale_factor -= 4 * sub;
115
116
    // 52 stands for 2**13 == 8192 factor; larger factor causes overflows later (in cfft).
117
49.0k
    scale_factor = min(max(scale_factor, -(REAL_BITS * 4)), 52);
118
119
    exp = scale_factor >> 2;
120
    frac = scale_factor & 3;
121
122
    /* 29 <= REAL_BITS + exp <= 0 */
123
49.0k
    mask = (1 << (REAL_BITS + exp)) - 1;
124
125
    idx = size;
126
49.0k
    scale = COEF_CONST(1);
127
    // At most 2 iterations.
128
57.2k
    while (idx >= 16)
129
8.22k
    {
130
8.22k
        idx >>= 2;
131
8.22k
        scale >>= 1;
132
8.22k
    }
133
49.0k
    scale = MUL_C(scale, mean_energy_table[idx]);
134
49.0k
    if (frac)
135
7.98k
        scale = MUL_C(scale, pow2_table[frac]);
136
    // scale is less than 4.0 now.
137
138
523k
    for (i = 0; i < size; i++)
139
474k
    {
140
474k
        real_t tmp = (int32_t)ne_rng(__r1, __r2);
141
474k
        if (tmp < 0)
142
240k
            tmp = -(tmp & mask);
143
234k
        else
144
234k
            tmp = (tmp & mask);
145
474k
        spec[i] = MUL_C(tmp, scale);
146
474k
    }
147
#endif
148
117k
}
pns.c:gen_rand_vector
Line
Count
Source
83
49.0k
{
84
#ifndef FIXED_POINT
85
    uint16_t i;
86
    real_t energy = 0.0;
87
    (void)sub;
88
89
    scale_factor = min(max(scale_factor, -120), 120);
90
91
    for (i = 0; i < size; i++)
92
    {
93
        real_t tmp = (real_t)(int32_t)ne_rng(__r1, __r2);
94
        spec[i] = tmp;
95
        energy += tmp*tmp;
96
    }
97
98
    if (energy > 0)
99
    {
100
        real_t scale = (real_t)1.0/(real_t)sqrt(energy);
101
        scale *= (real_t)pow(2.0, 0.25 * scale_factor);
102
        for (i = 0; i < size; i++)
103
        {
104
            spec[i] *= scale;
105
        }
106
    }
107
#else
108
49.0k
    uint16_t i;
109
49.0k
    real_t scale;
110
49.0k
    int32_t exp, frac;
111
49.0k
    int32_t idx, mask;
112
113
    /* IMDCT pre-scaling */
114
49.0k
    scale_factor -= 4 * sub;
115
116
    // 52 stands for 2**13 == 8192 factor; larger factor causes overflows later (in cfft).
117
49.0k
    scale_factor = min(max(scale_factor, -(REAL_BITS * 4)), 52);
118
119
49.0k
    exp = scale_factor >> 2;
120
49.0k
    frac = scale_factor & 3;
121
122
    /* 29 <= REAL_BITS + exp <= 0 */
123
49.0k
    mask = (1 << (REAL_BITS + exp)) - 1;
124
125
49.0k
    idx = size;
126
49.0k
    scale = COEF_CONST(1);
127
    // At most 2 iterations.
128
57.2k
    while (idx >= 16)
129
8.22k
    {
130
8.22k
        idx >>= 2;
131
8.22k
        scale >>= 1;
132
8.22k
    }
133
49.0k
    scale = MUL_C(scale, mean_energy_table[idx]);
134
49.0k
    if (frac)
135
7.98k
        scale = MUL_C(scale, pow2_table[frac]);
136
    // scale is less than 4.0 now.
137
138
523k
    for (i = 0; i < size; i++)
139
474k
    {
140
474k
        real_t tmp = (int32_t)ne_rng(__r1, __r2);
141
474k
        if (tmp < 0)
142
240k
            tmp = -(tmp & mask);
143
234k
        else
144
234k
            tmp = (tmp & mask);
145
474k
        spec[i] = MUL_C(tmp, scale);
146
474k
    }
147
49.0k
#endif
148
49.0k
}
pns.c:gen_rand_vector
Line
Count
Source
83
68.5k
{
84
68.5k
#ifndef FIXED_POINT
85
68.5k
    uint16_t i;
86
68.5k
    real_t energy = 0.0;
87
68.5k
    (void)sub;
88
89
68.5k
    scale_factor = min(max(scale_factor, -120), 120);
90
91
405k
    for (i = 0; i < size; i++)
92
336k
    {
93
336k
        real_t tmp = (real_t)(int32_t)ne_rng(__r1, __r2);
94
336k
        spec[i] = tmp;
95
336k
        energy += tmp*tmp;
96
336k
    }
97
98
68.5k
    if (energy > 0)
99
20.8k
    {
100
20.8k
        real_t scale = (real_t)1.0/(real_t)sqrt(energy);
101
20.8k
        scale *= (real_t)pow(2.0, 0.25 * scale_factor);
102
357k
        for (i = 0; i < size; i++)
103
336k
        {
104
336k
            spec[i] *= scale;
105
336k
        }
106
20.8k
    }
107
#else
108
    uint16_t i;
109
    real_t scale;
110
    int32_t exp, frac;
111
    int32_t idx, mask;
112
113
    /* IMDCT pre-scaling */
114
    scale_factor -= 4 * sub;
115
116
    // 52 stands for 2**13 == 8192 factor; larger factor causes overflows later (in cfft).
117
    scale_factor = min(max(scale_factor, -(REAL_BITS * 4)), 52);
118
119
    exp = scale_factor >> 2;
120
    frac = scale_factor & 3;
121
122
    /* 29 <= REAL_BITS + exp <= 0 */
123
    mask = (1 << (REAL_BITS + exp)) - 1;
124
125
    idx = size;
126
    scale = COEF_CONST(1);
127
    // At most 2 iterations.
128
    while (idx >= 16)
129
    {
130
        idx >>= 2;
131
        scale >>= 1;
132
    }
133
    scale = MUL_C(scale, mean_energy_table[idx]);
134
    if (frac)
135
        scale = MUL_C(scale, pow2_table[frac]);
136
    // scale is less than 4.0 now.
137
138
    for (i = 0; i < size; i++)
139
    {
140
        real_t tmp = (int32_t)ne_rng(__r1, __r2);
141
        if (tmp < 0)
142
            tmp = -(tmp & mask);
143
        else
144
            tmp = (tmp & mask);
145
        spec[i] = MUL_C(tmp, scale);
146
    }
147
#endif
148
68.5k
}
149
150
void pns_decode(ic_stream *ics_left, ic_stream *ics_right,
151
                real_t *spec_left, real_t *spec_right, uint16_t frame_len,
152
                uint8_t channel_pair, uint8_t object_type,
153
                /* RNG states */ uint32_t *__r1, uint32_t *__r2)
154
601k
{
155
601k
    uint8_t g, sfb, b;
156
601k
    uint16_t begin, end;
157
158
601k
    uint8_t group = 0;
159
601k
    uint16_t nshort = frame_len >> 3;
160
161
601k
    uint8_t sub = 0;
162
163
#ifdef FIXED_POINT
164
    /* IMDCT scaling */
165
250k
    if (object_type == LD)
166
1.34k
    {
167
1.34k
        sub = 9 /*9*/;
168
248k
    } else {
169
248k
        if (ics_left->window_sequence == EIGHT_SHORT_SEQUENCE)
170
23.7k
            sub = 7 /*7*/;
171
224k
        else
172
224k
            sub = 10 /*10*/;
173
248k
    }
174
#else
175
    (void)object_type;
176
#endif
177
178
1.52M
    for (g = 0; g < ics_left->num_window_groups; g++)
179
922k
    {
180
        /* Do perceptual noise substitution decoding */
181
1.92M
        for (b = 0; b < ics_left->window_group_length[g]; b++)
182
1.00M
        {
183
1.00M
            uint16_t base = group * nshort;
184
1.44M
            for (sfb = 0; sfb < ics_left->max_sfb; sfb++)
185
442k
            {
186
442k
                uint32_t r1_dep = 0, r2_dep = 0;
187
188
442k
                if (is_noise(ics_left, g, sfb))
189
78.0k
                {
190
#ifdef LTP_DEC
191
                    /* Simultaneous use of LTP and PNS is not prevented in the
192
                       syntax. If both LTP, and PNS are enabled on the same
193
                       scalefactor band, PNS takes precedence, and no prediction
194
                       is applied to this band.
195
                    */
196
                    ics_left->ltp.long_used[sfb] = 0;
197
                    ics_left->ltp2.long_used[sfb] = 0;
198
#endif
199
200
#ifdef MAIN_DEC
201
                    /* For scalefactor bands coded using PNS the corresponding
202
                       predictors are switched to "off".
203
                    */
204
                    ics_left->pred.prediction_used[sfb] = 0;
205
#endif
206
78.0k
                    begin = min(base + ics_left->swb_offset[sfb], ics_left->swb_offset_max);
207
78.0k
                    end = min(base + ics_left->swb_offset[sfb+1], ics_left->swb_offset_max);
208
209
78.0k
                    r1_dep = *__r1;
210
78.0k
                    r2_dep = *__r2;
211
212
                    /* Generate random vector */
213
78.0k
                    gen_rand_vector(&spec_left[begin],
214
78.0k
                        ics_left->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
215
78.0k
                }
216
217
/* From the spec:
218
   If the same scalefactor band and group is coded by perceptual noise
219
   substitution in both channels of a channel pair, the correlation of
220
   the noise signal can be controlled by means of the ms_used field: While
221
   the default noise generation process works independently for each channel
222
   (separate generation of random vectors), the same random vector is used
223
   for both channels if ms_used[] is set for a particular scalefactor band
224
   and group. In this case, no M/S stereo coding is carried out (because M/S
225
   stereo coding and noise substitution coding are mutually exclusive).
226
   If the same scalefactor band and group is coded by perceptual noise
227
   substitution in only one channel of a channel pair the setting of ms_used[]
228
   is not evaluated.
229
*/
230
442k
                if ((ics_right != NULL)
231
173k
                    && is_noise(ics_right, g, sfb))
232
39.5k
                {
233
#ifdef LTP_DEC
234
                    /* See comment above. */
235
                    ics_right->ltp.long_used[sfb] = 0;
236
                    ics_right->ltp2.long_used[sfb] = 0;
237
#endif
238
#ifdef MAIN_DEC
239
                    /* See comment above. */
240
                    ics_right->pred.prediction_used[sfb] = 0;
241
#endif
242
243
39.5k
                    if (channel_pair && is_noise(ics_left, g, sfb) &&
244
29.0k
                        (((ics_left->ms_mask_present == 1) &&
245
27.4k
                        (ics_left->ms_used[g][sfb])) ||
246
9.85k
                        (ics_left->ms_mask_present == 2)))
247
20.7k
                    {
248
                        /*uint16_t c;*/
249
250
20.7k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
251
20.7k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
252
253
                        /* Generate random vector dependent on left channel*/
254
20.7k
                        gen_rand_vector(&spec_right[begin],
255
20.7k
                            ics_right->scale_factors[g][sfb], end - begin, sub, &r1_dep, &r2_dep);
256
257
20.7k
                    } else /*if (ics_left->ms_mask_present == 0)*/ {
258
18.8k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
259
18.8k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
260
261
                        /* Generate random vector */
262
18.8k
                        gen_rand_vector(&spec_right[begin],
263
18.8k
                            ics_right->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
264
18.8k
                    }
265
39.5k
                }
266
442k
            } /* sfb */
267
1.00M
            group++;
268
1.00M
        } /* b */
269
922k
    } /* g */
270
601k
}
pns_decode
Line
Count
Source
154
250k
{
155
250k
    uint8_t g, sfb, b;
156
250k
    uint16_t begin, end;
157
158
250k
    uint8_t group = 0;
159
250k
    uint16_t nshort = frame_len >> 3;
160
161
250k
    uint8_t sub = 0;
162
163
250k
#ifdef FIXED_POINT
164
    /* IMDCT scaling */
165
250k
    if (object_type == LD)
166
1.34k
    {
167
1.34k
        sub = 9 /*9*/;
168
248k
    } else {
169
248k
        if (ics_left->window_sequence == EIGHT_SHORT_SEQUENCE)
170
23.7k
            sub = 7 /*7*/;
171
224k
        else
172
224k
            sub = 10 /*10*/;
173
248k
    }
174
#else
175
    (void)object_type;
176
#endif
177
178
638k
    for (g = 0; g < ics_left->num_window_groups; g++)
179
388k
    {
180
        /* Do perceptual noise substitution decoding */
181
804k
        for (b = 0; b < ics_left->window_group_length[g]; b++)
182
416k
        {
183
416k
            uint16_t base = group * nshort;
184
617k
            for (sfb = 0; sfb < ics_left->max_sfb; sfb++)
185
201k
            {
186
201k
                uint32_t r1_dep = 0, r2_dep = 0;
187
188
201k
                if (is_noise(ics_left, g, sfb))
189
35.3k
                {
190
#ifdef LTP_DEC
191
                    /* Simultaneous use of LTP and PNS is not prevented in the
192
                       syntax. If both LTP, and PNS are enabled on the same
193
                       scalefactor band, PNS takes precedence, and no prediction
194
                       is applied to this band.
195
                    */
196
                    ics_left->ltp.long_used[sfb] = 0;
197
                    ics_left->ltp2.long_used[sfb] = 0;
198
#endif
199
200
#ifdef MAIN_DEC
201
                    /* For scalefactor bands coded using PNS the corresponding
202
                       predictors are switched to "off".
203
                    */
204
                    ics_left->pred.prediction_used[sfb] = 0;
205
#endif
206
35.3k
                    begin = min(base + ics_left->swb_offset[sfb], ics_left->swb_offset_max);
207
35.3k
                    end = min(base + ics_left->swb_offset[sfb+1], ics_left->swb_offset_max);
208
209
35.3k
                    r1_dep = *__r1;
210
35.3k
                    r2_dep = *__r2;
211
212
                    /* Generate random vector */
213
35.3k
                    gen_rand_vector(&spec_left[begin],
214
35.3k
                        ics_left->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
215
35.3k
                }
216
217
/* From the spec:
218
   If the same scalefactor band and group is coded by perceptual noise
219
   substitution in both channels of a channel pair, the correlation of
220
   the noise signal can be controlled by means of the ms_used field: While
221
   the default noise generation process works independently for each channel
222
   (separate generation of random vectors), the same random vector is used
223
   for both channels if ms_used[] is set for a particular scalefactor band
224
   and group. In this case, no M/S stereo coding is carried out (because M/S
225
   stereo coding and noise substitution coding are mutually exclusive).
226
   If the same scalefactor band and group is coded by perceptual noise
227
   substitution in only one channel of a channel pair the setting of ms_used[]
228
   is not evaluated.
229
*/
230
201k
                if ((ics_right != NULL)
231
91.4k
                    && is_noise(ics_right, g, sfb))
232
13.6k
                {
233
#ifdef LTP_DEC
234
                    /* See comment above. */
235
                    ics_right->ltp.long_used[sfb] = 0;
236
                    ics_right->ltp2.long_used[sfb] = 0;
237
#endif
238
#ifdef MAIN_DEC
239
                    /* See comment above. */
240
                    ics_right->pred.prediction_used[sfb] = 0;
241
#endif
242
243
13.6k
                    if (channel_pair && is_noise(ics_left, g, sfb) &&
244
5.65k
                        (((ics_left->ms_mask_present == 1) &&
245
5.15k
                        (ics_left->ms_used[g][sfb])) ||
246
3.38k
                        (ics_left->ms_mask_present == 2)))
247
2.76k
                    {
248
                        /*uint16_t c;*/
249
250
2.76k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
251
2.76k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
252
253
                        /* Generate random vector dependent on left channel*/
254
2.76k
                        gen_rand_vector(&spec_right[begin],
255
2.76k
                            ics_right->scale_factors[g][sfb], end - begin, sub, &r1_dep, &r2_dep);
256
257
10.8k
                    } else /*if (ics_left->ms_mask_present == 0)*/ {
258
10.8k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
259
10.8k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
260
261
                        /* Generate random vector */
262
10.8k
                        gen_rand_vector(&spec_right[begin],
263
10.8k
                            ics_right->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
264
10.8k
                    }
265
13.6k
                }
266
201k
            } /* sfb */
267
416k
            group++;
268
416k
        } /* b */
269
388k
    } /* g */
270
250k
}
pns_decode
Line
Count
Source
154
350k
{
155
350k
    uint8_t g, sfb, b;
156
350k
    uint16_t begin, end;
157
158
350k
    uint8_t group = 0;
159
350k
    uint16_t nshort = frame_len >> 3;
160
161
350k
    uint8_t sub = 0;
162
163
#ifdef FIXED_POINT
164
    /* IMDCT scaling */
165
    if (object_type == LD)
166
    {
167
        sub = 9 /*9*/;
168
    } else {
169
        if (ics_left->window_sequence == EIGHT_SHORT_SEQUENCE)
170
            sub = 7 /*7*/;
171
        else
172
            sub = 10 /*10*/;
173
    }
174
#else
175
350k
    (void)object_type;
176
350k
#endif
177
178
885k
    for (g = 0; g < ics_left->num_window_groups; g++)
179
534k
    {
180
        /* Do perceptual noise substitution decoding */
181
1.11M
        for (b = 0; b < ics_left->window_group_length[g]; b++)
182
585k
        {
183
585k
            uint16_t base = group * nshort;
184
825k
            for (sfb = 0; sfb < ics_left->max_sfb; sfb++)
185
240k
            {
186
240k
                uint32_t r1_dep = 0, r2_dep = 0;
187
188
240k
                if (is_noise(ics_left, g, sfb))
189
42.6k
                {
190
42.6k
#ifdef LTP_DEC
191
                    /* Simultaneous use of LTP and PNS is not prevented in the
192
                       syntax. If both LTP, and PNS are enabled on the same
193
                       scalefactor band, PNS takes precedence, and no prediction
194
                       is applied to this band.
195
                    */
196
42.6k
                    ics_left->ltp.long_used[sfb] = 0;
197
42.6k
                    ics_left->ltp2.long_used[sfb] = 0;
198
42.6k
#endif
199
200
42.6k
#ifdef MAIN_DEC
201
                    /* For scalefactor bands coded using PNS the corresponding
202
                       predictors are switched to "off".
203
                    */
204
42.6k
                    ics_left->pred.prediction_used[sfb] = 0;
205
42.6k
#endif
206
42.6k
                    begin = min(base + ics_left->swb_offset[sfb], ics_left->swb_offset_max);
207
42.6k
                    end = min(base + ics_left->swb_offset[sfb+1], ics_left->swb_offset_max);
208
209
42.6k
                    r1_dep = *__r1;
210
42.6k
                    r2_dep = *__r2;
211
212
                    /* Generate random vector */
213
42.6k
                    gen_rand_vector(&spec_left[begin],
214
42.6k
                        ics_left->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
215
42.6k
                }
216
217
/* From the spec:
218
   If the same scalefactor band and group is coded by perceptual noise
219
   substitution in both channels of a channel pair, the correlation of
220
   the noise signal can be controlled by means of the ms_used field: While
221
   the default noise generation process works independently for each channel
222
   (separate generation of random vectors), the same random vector is used
223
   for both channels if ms_used[] is set for a particular scalefactor band
224
   and group. In this case, no M/S stereo coding is carried out (because M/S
225
   stereo coding and noise substitution coding are mutually exclusive).
226
   If the same scalefactor band and group is coded by perceptual noise
227
   substitution in only one channel of a channel pair the setting of ms_used[]
228
   is not evaluated.
229
*/
230
240k
                if ((ics_right != NULL)
231
81.8k
                    && is_noise(ics_right, g, sfb))
232
25.8k
                {
233
25.8k
#ifdef LTP_DEC
234
                    /* See comment above. */
235
25.8k
                    ics_right->ltp.long_used[sfb] = 0;
236
25.8k
                    ics_right->ltp2.long_used[sfb] = 0;
237
25.8k
#endif
238
25.8k
#ifdef MAIN_DEC
239
                    /* See comment above. */
240
25.8k
                    ics_right->pred.prediction_used[sfb] = 0;
241
25.8k
#endif
242
243
25.8k
                    if (channel_pair && is_noise(ics_left, g, sfb) &&
244
23.3k
                        (((ics_left->ms_mask_present == 1) &&
245
22.2k
                        (ics_left->ms_used[g][sfb])) ||
246
6.46k
                        (ics_left->ms_mask_present == 2)))
247
17.9k
                    {
248
                        /*uint16_t c;*/
249
250
17.9k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
251
17.9k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
252
253
                        /* Generate random vector dependent on left channel*/
254
17.9k
                        gen_rand_vector(&spec_right[begin],
255
17.9k
                            ics_right->scale_factors[g][sfb], end - begin, sub, &r1_dep, &r2_dep);
256
257
17.9k
                    } else /*if (ics_left->ms_mask_present == 0)*/ {
258
7.92k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
259
7.92k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
260
261
                        /* Generate random vector */
262
7.92k
                        gen_rand_vector(&spec_right[begin],
263
7.92k
                            ics_right->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
264
7.92k
                    }
265
25.8k
                }
266
240k
            } /* sfb */
267
585k
            group++;
268
585k
        } /* b */
269
534k
    } /* g */
270
350k
}