Coverage Report

Created: 2026-02-14 07:13

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
93.3k
{
84
#ifndef FIXED_POINT
85
    uint16_t i;
86
    real_t energy = 0.0;
87
    (void)sub;
88
89
53.1k
    scale_factor = min(max(scale_factor, -120), 120);
90
91
320k
    for (i = 0; i < size; i++)
92
267k
    {
93
267k
        real_t tmp = (real_t)(int32_t)ne_rng(__r1, __r2);
94
267k
        spec[i] = tmp;
95
267k
        energy += tmp*tmp;
96
267k
    }
97
98
53.1k
    if (energy > 0)
99
17.0k
    {
100
17.0k
        real_t scale = (real_t)1.0/(real_t)sqrt(energy);
101
17.0k
        scale *= (real_t)pow(2.0, 0.25 * scale_factor);
102
284k
        for (i = 0; i < size; i++)
103
267k
        {
104
267k
            spec[i] *= scale;
105
267k
        }
106
17.0k
    }
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
40.2k
    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
40.2k
    mask = (1 << (REAL_BITS + exp)) - 1;
124
125
    idx = size;
126
40.2k
    scale = COEF_CONST(1);
127
    // At most 2 iterations.
128
47.1k
    while (idx >= 16)
129
6.96k
    {
130
6.96k
        idx >>= 2;
131
6.96k
        scale >>= 1;
132
6.96k
    }
133
40.2k
    scale = MUL_C(scale, mean_energy_table[idx]);
134
40.2k
    if (frac)
135
6.19k
        scale = MUL_C(scale, pow2_table[frac]);
136
    // scale is less than 4.0 now.
137
138
456k
    for (i = 0; i < size; i++)
139
416k
    {
140
416k
        real_t tmp = (int32_t)ne_rng(__r1, __r2);
141
416k
        if (tmp < 0)
142
210k
            tmp = -(tmp & mask);
143
205k
        else
144
205k
            tmp = (tmp & mask);
145
416k
        spec[i] = MUL_C(tmp, scale);
146
416k
    }
147
#endif
148
93.3k
}
pns.c:gen_rand_vector
Line
Count
Source
83
40.2k
{
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
40.2k
    uint16_t i;
109
40.2k
    real_t scale;
110
40.2k
    int32_t exp, frac;
111
40.2k
    int32_t idx, mask;
112
113
    /* IMDCT pre-scaling */
114
40.2k
    scale_factor -= 4 * sub;
115
116
    // 52 stands for 2**13 == 8192 factor; larger factor causes overflows later (in cfft).
117
40.2k
    scale_factor = min(max(scale_factor, -(REAL_BITS * 4)), 52);
118
119
40.2k
    exp = scale_factor >> 2;
120
40.2k
    frac = scale_factor & 3;
121
122
    /* 29 <= REAL_BITS + exp <= 0 */
123
40.2k
    mask = (1 << (REAL_BITS + exp)) - 1;
124
125
40.2k
    idx = size;
126
40.2k
    scale = COEF_CONST(1);
127
    // At most 2 iterations.
128
47.1k
    while (idx >= 16)
129
6.96k
    {
130
6.96k
        idx >>= 2;
131
6.96k
        scale >>= 1;
132
6.96k
    }
133
40.2k
    scale = MUL_C(scale, mean_energy_table[idx]);
134
40.2k
    if (frac)
135
6.19k
        scale = MUL_C(scale, pow2_table[frac]);
136
    // scale is less than 4.0 now.
137
138
456k
    for (i = 0; i < size; i++)
139
416k
    {
140
416k
        real_t tmp = (int32_t)ne_rng(__r1, __r2);
141
416k
        if (tmp < 0)
142
210k
            tmp = -(tmp & mask);
143
205k
        else
144
205k
            tmp = (tmp & mask);
145
416k
        spec[i] = MUL_C(tmp, scale);
146
416k
    }
147
40.2k
#endif
148
40.2k
}
pns.c:gen_rand_vector
Line
Count
Source
83
53.1k
{
84
53.1k
#ifndef FIXED_POINT
85
53.1k
    uint16_t i;
86
53.1k
    real_t energy = 0.0;
87
53.1k
    (void)sub;
88
89
53.1k
    scale_factor = min(max(scale_factor, -120), 120);
90
91
320k
    for (i = 0; i < size; i++)
92
267k
    {
93
267k
        real_t tmp = (real_t)(int32_t)ne_rng(__r1, __r2);
94
267k
        spec[i] = tmp;
95
267k
        energy += tmp*tmp;
96
267k
    }
97
98
53.1k
    if (energy > 0)
99
17.0k
    {
100
17.0k
        real_t scale = (real_t)1.0/(real_t)sqrt(energy);
101
17.0k
        scale *= (real_t)pow(2.0, 0.25 * scale_factor);
102
284k
        for (i = 0; i < size; i++)
103
267k
        {
104
267k
            spec[i] *= scale;
105
267k
        }
106
17.0k
    }
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
53.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
447k
{
155
447k
    uint8_t g, sfb, b;
156
447k
    uint16_t begin, end;
157
158
447k
    uint8_t group = 0;
159
447k
    uint16_t nshort = frame_len >> 3;
160
161
447k
    uint8_t sub = 0;
162
163
#ifdef FIXED_POINT
164
    /* IMDCT scaling */
165
178k
    if (object_type == LD)
166
953
    {
167
953
        sub = 9 /*9*/;
168
177k
    } else {
169
177k
        if (ics_left->window_sequence == EIGHT_SHORT_SEQUENCE)
170
17.5k
            sub = 7 /*7*/;
171
159k
        else
172
159k
            sub = 10 /*10*/;
173
177k
    }
174
#else
175
    (void)object_type;
176
#endif
177
178
1.15M
    for (g = 0; g < ics_left->num_window_groups; g++)
179
708k
    {
180
        /* Do perceptual noise substitution decoding */
181
1.48M
        for (b = 0; b < ics_left->window_group_length[g]; b++)
182
773k
        {
183
773k
            uint16_t base = group * nshort;
184
1.16M
            for (sfb = 0; sfb < ics_left->max_sfb; sfb++)
185
387k
            {
186
387k
                uint32_t r1_dep = 0, r2_dep = 0;
187
188
387k
                if (is_noise(ics_left, g, sfb))
189
64.1k
                {
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
64.1k
                    begin = min(base + ics_left->swb_offset[sfb], ics_left->swb_offset_max);
207
64.1k
                    end = min(base + ics_left->swb_offset[sfb+1], ics_left->swb_offset_max);
208
209
64.1k
                    r1_dep = *__r1;
210
64.1k
                    r2_dep = *__r2;
211
212
                    /* Generate random vector */
213
64.1k
                    gen_rand_vector(&spec_left[begin],
214
64.1k
                        ics_left->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
215
64.1k
                }
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
387k
                if ((ics_right != NULL)
231
137k
                    && is_noise(ics_right, g, sfb))
232
29.1k
                {
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
29.1k
                    if (channel_pair && is_noise(ics_left, g, sfb) &&
244
22.0k
                        (((ics_left->ms_mask_present == 1) &&
245
21.0k
                        (ics_left->ms_used[g][sfb])) ||
246
7.65k
                        (ics_left->ms_mask_present == 2)))
247
15.4k
                    {
248
                        /*uint16_t c;*/
249
250
15.4k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
251
15.4k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
252
253
                        /* Generate random vector dependent on left channel*/
254
15.4k
                        gen_rand_vector(&spec_right[begin],
255
15.4k
                            ics_right->scale_factors[g][sfb], end - begin, sub, &r1_dep, &r2_dep);
256
257
15.4k
                    } else /*if (ics_left->ms_mask_present == 0)*/ {
258
13.7k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
259
13.7k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
260
261
                        /* Generate random vector */
262
13.7k
                        gen_rand_vector(&spec_right[begin],
263
13.7k
                            ics_right->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
264
13.7k
                    }
265
29.1k
                }
266
387k
            } /* sfb */
267
773k
            group++;
268
773k
        } /* b */
269
708k
    } /* g */
270
447k
}
pns_decode
Line
Count
Source
154
178k
{
155
178k
    uint8_t g, sfb, b;
156
178k
    uint16_t begin, end;
157
158
178k
    uint8_t group = 0;
159
178k
    uint16_t nshort = frame_len >> 3;
160
161
178k
    uint8_t sub = 0;
162
163
178k
#ifdef FIXED_POINT
164
    /* IMDCT scaling */
165
178k
    if (object_type == LD)
166
953
    {
167
953
        sub = 9 /*9*/;
168
177k
    } else {
169
177k
        if (ics_left->window_sequence == EIGHT_SHORT_SEQUENCE)
170
17.5k
            sub = 7 /*7*/;
171
159k
        else
172
159k
            sub = 10 /*10*/;
173
177k
    }
174
#else
175
    (void)object_type;
176
#endif
177
178
458k
    for (g = 0; g < ics_left->num_window_groups; g++)
179
280k
    {
180
        /* Do perceptual noise substitution decoding */
181
581k
        for (b = 0; b < ics_left->window_group_length[g]; b++)
182
301k
        {
183
301k
            uint16_t base = group * nshort;
184
467k
            for (sfb = 0; sfb < ics_left->max_sfb; sfb++)
185
166k
            {
186
166k
                uint32_t r1_dep = 0, r2_dep = 0;
187
188
166k
                if (is_noise(ics_left, g, sfb))
189
29.6k
                {
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
29.6k
                    begin = min(base + ics_left->swb_offset[sfb], ics_left->swb_offset_max);
207
29.6k
                    end = min(base + ics_left->swb_offset[sfb+1], ics_left->swb_offset_max);
208
209
29.6k
                    r1_dep = *__r1;
210
29.6k
                    r2_dep = *__r2;
211
212
                    /* Generate random vector */
213
29.6k
                    gen_rand_vector(&spec_left[begin],
214
29.6k
                        ics_left->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
215
29.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
166k
                if ((ics_right != NULL)
231
70.4k
                    && is_noise(ics_right, g, sfb))
232
10.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
10.5k
                    if (channel_pair && is_noise(ics_left, g, sfb) &&
244
4.92k
                        (((ics_left->ms_mask_present == 1) &&
245
4.61k
                        (ics_left->ms_used[g][sfb])) ||
246
2.94k
                        (ics_left->ms_mask_present == 2)))
247
2.27k
                    {
248
                        /*uint16_t c;*/
249
250
2.27k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
251
2.27k
                        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.27k
                        gen_rand_vector(&spec_right[begin],
255
2.27k
                            ics_right->scale_factors[g][sfb], end - begin, sub, &r1_dep, &r2_dep);
256
257
8.30k
                    } else /*if (ics_left->ms_mask_present == 0)*/ {
258
8.30k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
259
8.30k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
260
261
                        /* Generate random vector */
262
8.30k
                        gen_rand_vector(&spec_right[begin],
263
8.30k
                            ics_right->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
264
8.30k
                    }
265
10.5k
                }
266
166k
            } /* sfb */
267
301k
            group++;
268
301k
        } /* b */
269
280k
    } /* g */
270
178k
}
pns_decode
Line
Count
Source
154
269k
{
155
269k
    uint8_t g, sfb, b;
156
269k
    uint16_t begin, end;
157
158
269k
    uint8_t group = 0;
159
269k
    uint16_t nshort = frame_len >> 3;
160
161
269k
    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
269k
    (void)object_type;
176
269k
#endif
177
178
698k
    for (g = 0; g < ics_left->num_window_groups; g++)
179
428k
    {
180
        /* Do perceptual noise substitution decoding */
181
900k
        for (b = 0; b < ics_left->window_group_length[g]; b++)
182
472k
        {
183
472k
            uint16_t base = group * nshort;
184
693k
            for (sfb = 0; sfb < ics_left->max_sfb; sfb++)
185
221k
            {
186
221k
                uint32_t r1_dep = 0, r2_dep = 0;
187
188
221k
                if (is_noise(ics_left, g, sfb))
189
34.5k
                {
190
34.5k
#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
34.5k
                    ics_left->ltp.long_used[sfb] = 0;
197
34.5k
                    ics_left->ltp2.long_used[sfb] = 0;
198
34.5k
#endif
199
200
34.5k
#ifdef MAIN_DEC
201
                    /* For scalefactor bands coded using PNS the corresponding
202
                       predictors are switched to "off".
203
                    */
204
34.5k
                    ics_left->pred.prediction_used[sfb] = 0;
205
34.5k
#endif
206
34.5k
                    begin = min(base + ics_left->swb_offset[sfb], ics_left->swb_offset_max);
207
34.5k
                    end = min(base + ics_left->swb_offset[sfb+1], ics_left->swb_offset_max);
208
209
34.5k
                    r1_dep = *__r1;
210
34.5k
                    r2_dep = *__r2;
211
212
                    /* Generate random vector */
213
34.5k
                    gen_rand_vector(&spec_left[begin],
214
34.5k
                        ics_left->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
215
34.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
221k
                if ((ics_right != NULL)
231
67.2k
                    && is_noise(ics_right, g, sfb))
232
18.5k
                {
233
18.5k
#ifdef LTP_DEC
234
                    /* See comment above. */
235
18.5k
                    ics_right->ltp.long_used[sfb] = 0;
236
18.5k
                    ics_right->ltp2.long_used[sfb] = 0;
237
18.5k
#endif
238
18.5k
#ifdef MAIN_DEC
239
                    /* See comment above. */
240
18.5k
                    ics_right->pred.prediction_used[sfb] = 0;
241
18.5k
#endif
242
243
18.5k
                    if (channel_pair && is_noise(ics_left, g, sfb) &&
244
17.1k
                        (((ics_left->ms_mask_present == 1) &&
245
16.3k
                        (ics_left->ms_used[g][sfb])) ||
246
4.70k
                        (ics_left->ms_mask_present == 2)))
247
13.1k
                    {
248
                        /*uint16_t c;*/
249
250
13.1k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
251
13.1k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
252
253
                        /* Generate random vector dependent on left channel*/
254
13.1k
                        gen_rand_vector(&spec_right[begin],
255
13.1k
                            ics_right->scale_factors[g][sfb], end - begin, sub, &r1_dep, &r2_dep);
256
257
13.1k
                    } else /*if (ics_left->ms_mask_present == 0)*/ {
258
5.46k
                        begin = min(base + ics_right->swb_offset[sfb], ics_right->swb_offset_max);
259
5.46k
                        end = min(base + ics_right->swb_offset[sfb+1], ics_right->swb_offset_max);
260
261
                        /* Generate random vector */
262
5.46k
                        gen_rand_vector(&spec_right[begin],
263
5.46k
                            ics_right->scale_factors[g][sfb], end - begin, sub, __r1, __r2);
264
5.46k
                    }
265
18.5k
                }
266
221k
            } /* sfb */
267
472k
            group++;
268
472k
        } /* b */
269
428k
    } /* g */
270
269k
}