Coverage Report

Created: 2025-11-16 06:18

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
65.8k
{
84
#ifndef FIXED_POINT
85
    uint16_t i;
86
    real_t energy = 0.0;
87
    (void)sub;
88
89
32.1k
    scale_factor = min(max(scale_factor, -120), 120);
90
91
328k
    for (i = 0; i < size; i++)
92
295k
    {
93
295k
        real_t tmp = (real_t)(int32_t)ne_rng(__r1, __r2);
94
295k
        spec[i] = tmp;
95
295k
        energy += tmp*tmp;
96
295k
    }
97
98
32.1k
    if (energy > 0)
99
14.6k
    {
100
14.6k
        real_t scale = (real_t)1.0/(real_t)sqrt(energy);
101
14.6k
        scale *= (real_t)pow(2.0, 0.25 * scale_factor);
102
310k
        for (i = 0; i < size; i++)
103
295k
        {
104
295k
            spec[i] *= scale;
105
295k
        }
106
14.6k
    }
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
33.7k
    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
33.7k
    mask = (1 << (REAL_BITS + exp)) - 1;
124
125
    idx = size;
126
33.7k
    scale = COEF_CONST(1);
127
    // At most 2 iterations.
128
38.3k
    while (idx >= 16)
129
4.61k
    {
130
4.61k
        idx >>= 2;
131
4.61k
        scale >>= 1;
132
4.61k
    }
133
33.7k
    scale = MUL_C(scale, mean_energy_table[idx]);
134
33.7k
    if (frac)
135
6.41k
        scale = MUL_C(scale, pow2_table[frac]);
136
    // scale is less than 4.0 now.
137
138
344k
    for (i = 0; i < size; i++)
139
310k
    {
140
310k
        real_t tmp = (int32_t)ne_rng(__r1, __r2);
141
310k
        if (tmp < 0)
142
157k
            tmp = -(tmp & mask);
143
152k
        else
144
152k
            tmp = (tmp & mask);
145
310k
        spec[i] = MUL_C(tmp, scale);
146
310k
    }
147
#endif
148
65.8k
}
pns.c:gen_rand_vector
Line
Count
Source
83
33.7k
{
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
33.7k
    uint16_t i;
109
33.7k
    real_t scale;
110
33.7k
    int32_t exp, frac;
111
33.7k
    int32_t idx, mask;
112
113
    /* IMDCT pre-scaling */
114
33.7k
    scale_factor -= 4 * sub;
115
116
    // 52 stands for 2**13 == 8192 factor; larger factor causes overflows later (in cfft).
117
33.7k
    scale_factor = min(max(scale_factor, -(REAL_BITS * 4)), 52);
118
119
33.7k
    exp = scale_factor >> 2;
120
33.7k
    frac = scale_factor & 3;
121
122
    /* 29 <= REAL_BITS + exp <= 0 */
123
33.7k
    mask = (1 << (REAL_BITS + exp)) - 1;
124
125
33.7k
    idx = size;
126
33.7k
    scale = COEF_CONST(1);
127
    // At most 2 iterations.
128
38.3k
    while (idx >= 16)
129
4.61k
    {
130
4.61k
        idx >>= 2;
131
4.61k
        scale >>= 1;
132
4.61k
    }
133
33.7k
    scale = MUL_C(scale, mean_energy_table[idx]);
134
33.7k
    if (frac)
135
6.41k
        scale = MUL_C(scale, pow2_table[frac]);
136
    // scale is less than 4.0 now.
137
138
344k
    for (i = 0; i < size; i++)
139
310k
    {
140
310k
        real_t tmp = (int32_t)ne_rng(__r1, __r2);
141
310k
        if (tmp < 0)
142
157k
            tmp = -(tmp & mask);
143
152k
        else
144
152k
            tmp = (tmp & mask);
145
310k
        spec[i] = MUL_C(tmp, scale);
146
310k
    }
147
33.7k
#endif
148
33.7k
}
pns.c:gen_rand_vector
Line
Count
Source
83
32.1k
{
84
32.1k
#ifndef FIXED_POINT
85
32.1k
    uint16_t i;
86
32.1k
    real_t energy = 0.0;
87
32.1k
    (void)sub;
88
89
32.1k
    scale_factor = min(max(scale_factor, -120), 120);
90
91
328k
    for (i = 0; i < size; i++)
92
295k
    {
93
295k
        real_t tmp = (real_t)(int32_t)ne_rng(__r1, __r2);
94
295k
        spec[i] = tmp;
95
295k
        energy += tmp*tmp;
96
295k
    }
97
98
32.1k
    if (energy > 0)
99
14.6k
    {
100
14.6k
        real_t scale = (real_t)1.0/(real_t)sqrt(energy);
101
14.6k
        scale *= (real_t)pow(2.0, 0.25 * scale_factor);
102
310k
        for (i = 0; i < size; i++)
103
295k
        {
104
295k
            spec[i] *= scale;
105
295k
        }
106
14.6k
    }
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
32.1k
}
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
448k
{
155
448k
    uint8_t g, sfb, b;
156
448k
    uint16_t begin, end;
157
158
448k
    uint8_t group = 0;
159
448k
    uint16_t nshort = frame_len >> 3;
160
161
448k
    uint8_t sub = 0;
162
163
#ifdef FIXED_POINT
164
    /* IMDCT scaling */
165
153k
    if (object_type == LD)
166
824
    {
167
824
        sub = 9 /*9*/;
168
152k
    } else {
169
152k
        if (ics_left->window_sequence == EIGHT_SHORT_SEQUENCE)
170
17.0k
            sub = 7 /*7*/;
171
135k
        else
172
135k
            sub = 10 /*10*/;
173
152k
    }
174
#else
175
    (void)object_type;
176
#endif
177
178
1.17M
    for (g = 0; g < ics_left->num_window_groups; g++)
179
723k
    {
180
        /* Do perceptual noise substitution decoding */
181
1.51M
        for (b = 0; b < ics_left->window_group_length[g]; b++)
182
788k
        {
183
788k
            uint16_t base = group * nshort;
184
1.18M
            for (sfb = 0; sfb < ics_left->max_sfb; sfb++)
185
400k
            {
186
400k
                uint32_t r1_dep = 0, r2_dep = 0;
187
188
400k
                if (is_noise(ics_left, g, sfb))
189
46.5k
                {
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
46.5k
                    begin = min(base + ics_left->swb_offset[sfb], ics_left->swb_offset_max);
207
46.5k
                    end = min(base + ics_left->swb_offset[sfb+1], ics_left->swb_offset_max);
208
209
46.5k
                    r1_dep = *__r1;
210
46.5k
                    r2_dep = *__r2;
211
212
                    /* Generate random vector */
213
46.5k
                    gen_rand_vector(&spec_left[begin],
214
46.5k
                        ics_left->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
215
46.5k
                }
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
400k
                if ((ics_right != NULL)
231
135k
                    && is_noise(ics_right, g, sfb))
232
19.2k
                {
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
19.2k
                    if (channel_pair && is_noise(ics_left, g, sfb) &&
244
8.82k
                        (((ics_left->ms_mask_present == 1) &&
245
8.28k
                        (ics_left->ms_used[g][sfb])) ||
246
4.27k
                        (ics_left->ms_mask_present == 2)))
247
5.09k
                    {
248
                        /*uint16_t c;*/
249
250
5.09k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
251
5.09k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
252
253
                        /* Generate random vector dependent on left channel*/
254
5.09k
                        gen_rand_vector(&spec_right[begin],
255
5.09k
                            ics_right->scale_factors[g][sfb], end - begin, sub, &r1_dep, &r2_dep);
256
257
14.1k
                    } else /*if (ics_left->ms_mask_present == 0)*/ {
258
14.1k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
259
14.1k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
260
261
                        /* Generate random vector */
262
14.1k
                        gen_rand_vector(&spec_right[begin],
263
14.1k
                            ics_right->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
264
14.1k
                    }
265
19.2k
                }
266
400k
            } /* sfb */
267
788k
            group++;
268
788k
        } /* b */
269
723k
    } /* g */
270
448k
}
pns_decode
Line
Count
Source
154
153k
{
155
153k
    uint8_t g, sfb, b;
156
153k
    uint16_t begin, end;
157
158
153k
    uint8_t group = 0;
159
153k
    uint16_t nshort = frame_len >> 3;
160
161
153k
    uint8_t sub = 0;
162
163
153k
#ifdef FIXED_POINT
164
    /* IMDCT scaling */
165
153k
    if (object_type == LD)
166
824
    {
167
824
        sub = 9 /*9*/;
168
152k
    } else {
169
152k
        if (ics_left->window_sequence == EIGHT_SHORT_SEQUENCE)
170
17.0k
            sub = 7 /*7*/;
171
135k
        else
172
135k
            sub = 10 /*10*/;
173
152k
    }
174
#else
175
    (void)object_type;
176
#endif
177
178
406k
    for (g = 0; g < ics_left->num_window_groups; g++)
179
252k
    {
180
        /* Do perceptual noise substitution decoding */
181
525k
        for (b = 0; b < ics_left->window_group_length[g]; b++)
182
273k
        {
183
273k
            uint16_t base = group * nshort;
184
463k
            for (sfb = 0; sfb < ics_left->max_sfb; sfb++)
185
190k
            {
186
190k
                uint32_t r1_dep = 0, r2_dep = 0;
187
188
190k
                if (is_noise(ics_left, g, sfb))
189
22.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
22.3k
                    begin = min(base + ics_left->swb_offset[sfb], ics_left->swb_offset_max);
207
22.3k
                    end = min(base + ics_left->swb_offset[sfb+1], ics_left->swb_offset_max);
208
209
22.3k
                    r1_dep = *__r1;
210
22.3k
                    r2_dep = *__r2;
211
212
                    /* Generate random vector */
213
22.3k
                    gen_rand_vector(&spec_left[begin],
214
22.3k
                        ics_left->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
215
22.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
190k
                if ((ics_right != NULL)
231
75.2k
                    && is_noise(ics_right, g, sfb))
232
11.3k
                {
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
11.3k
                    if (channel_pair && is_noise(ics_left, g, sfb) &&
244
3.13k
                        (((ics_left->ms_mask_present == 1) &&
245
2.87k
                        (ics_left->ms_used[g][sfb])) ||
246
1.96k
                        (ics_left->ms_mask_present == 2)))
247
1.44k
                    {
248
                        /*uint16_t c;*/
249
250
1.44k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
251
1.44k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
252
253
                        /* Generate random vector dependent on left channel*/
254
1.44k
                        gen_rand_vector(&spec_right[begin],
255
1.44k
                            ics_right->scale_factors[g][sfb], end - begin, sub, &r1_dep, &r2_dep);
256
257
9.89k
                    } else /*if (ics_left->ms_mask_present == 0)*/ {
258
9.89k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
259
9.89k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
260
261
                        /* Generate random vector */
262
9.89k
                        gen_rand_vector(&spec_right[begin],
263
9.89k
                            ics_right->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
264
9.89k
                    }
265
11.3k
                }
266
190k
            } /* sfb */
267
273k
            group++;
268
273k
        } /* b */
269
252k
    } /* g */
270
153k
}
pns_decode
Line
Count
Source
154
294k
{
155
294k
    uint8_t g, sfb, b;
156
294k
    uint16_t begin, end;
157
158
294k
    uint8_t group = 0;
159
294k
    uint16_t nshort = frame_len >> 3;
160
161
294k
    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
294k
    (void)object_type;
176
294k
#endif
177
178
765k
    for (g = 0; g < ics_left->num_window_groups; g++)
179
470k
    {
180
        /* Do perceptual noise substitution decoding */
181
986k
        for (b = 0; b < ics_left->window_group_length[g]; b++)
182
515k
        {
183
515k
            uint16_t base = group * nshort;
184
725k
            for (sfb = 0; sfb < ics_left->max_sfb; sfb++)
185
209k
            {
186
209k
                uint32_t r1_dep = 0, r2_dep = 0;
187
188
209k
                if (is_noise(ics_left, g, sfb))
189
24.2k
                {
190
24.2k
#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
24.2k
                    ics_left->ltp.long_used[sfb] = 0;
197
24.2k
                    ics_left->ltp2.long_used[sfb] = 0;
198
24.2k
#endif
199
200
24.2k
#ifdef MAIN_DEC
201
                    /* For scalefactor bands coded using PNS the corresponding
202
                       predictors are switched to "off".
203
                    */
204
24.2k
                    ics_left->pred.prediction_used[sfb] = 0;
205
24.2k
#endif
206
24.2k
                    begin = min(base + ics_left->swb_offset[sfb], ics_left->swb_offset_max);
207
24.2k
                    end = min(base + ics_left->swb_offset[sfb+1], ics_left->swb_offset_max);
208
209
24.2k
                    r1_dep = *__r1;
210
24.2k
                    r2_dep = *__r2;
211
212
                    /* Generate random vector */
213
24.2k
                    gen_rand_vector(&spec_left[begin],
214
24.2k
                        ics_left->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
215
24.2k
                }
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
209k
                if ((ics_right != NULL)
231
59.7k
                    && is_noise(ics_right, g, sfb))
232
7.94k
                {
233
7.94k
#ifdef LTP_DEC
234
                    /* See comment above. */
235
7.94k
                    ics_right->ltp.long_used[sfb] = 0;
236
7.94k
                    ics_right->ltp2.long_used[sfb] = 0;
237
7.94k
#endif
238
7.94k
#ifdef MAIN_DEC
239
                    /* See comment above. */
240
7.94k
                    ics_right->pred.prediction_used[sfb] = 0;
241
7.94k
#endif
242
243
7.94k
                    if (channel_pair && is_noise(ics_left, g, sfb) &&
244
5.69k
                        (((ics_left->ms_mask_present == 1) &&
245
5.41k
                        (ics_left->ms_used[g][sfb])) ||
246
2.31k
                        (ics_left->ms_mask_present == 2)))
247
3.65k
                    {
248
                        /*uint16_t c;*/
249
250
3.65k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
251
3.65k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
252
253
                        /* Generate random vector dependent on left channel*/
254
3.65k
                        gen_rand_vector(&spec_right[begin],
255
3.65k
                            ics_right->scale_factors[g][sfb], end - begin, sub, &r1_dep, &r2_dep);
256
257
4.29k
                    } else /*if (ics_left->ms_mask_present == 0)*/ {
258
4.29k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
259
4.29k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
260
261
                        /* Generate random vector */
262
4.29k
                        gen_rand_vector(&spec_right[begin],
263
4.29k
                            ics_right->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
264
4.29k
                    }
265
7.94k
                }
266
209k
            } /* sfb */
267
515k
            group++;
268
515k
        } /* b */
269
470k
    } /* g */
270
294k
}