Coverage Report

Created: 2025-11-16 06:18

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/proc/self/cwd/libfaad/ps_dec.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: ps_dec.c,v 1.16 2009/01/26 22:32:31 menno Exp $
29
**/
30
31
#include "common.h"
32
33
#ifdef PS_DEC
34
35
#include <stdlib.h>
36
#include <stdio.h>
37
#include "ps_dec.h"
38
#include "ps_tables.h"
39
40
/* constants */
41
45.9M
#define NEGATE_IPD_MASK            (0x1000)
42
348k
#define DECAY_SLOPE                FRAC_CONST(0.05)
43
#define COEF_SQRT2                 COEF_CONST(1.4142135623731)
44
45
/* tables */
46
/* filters are mirrored in coef 6, second half left out */
47
static const real_t p8_13_20[7] =
48
{
49
    FRAC_CONST(0.00746082949812),
50
    FRAC_CONST(0.02270420949825),
51
    FRAC_CONST(0.04546865930473),
52
    FRAC_CONST(0.07266113929591),
53
    FRAC_CONST(0.09885108575264),
54
    FRAC_CONST(0.11793710567217),
55
    FRAC_CONST(0.125)
56
};
57
58
static const real_t p2_13_20[7] =
59
{
60
    FRAC_CONST(0.0),
61
    FRAC_CONST(0.01899487526049),
62
    FRAC_CONST(0.0),
63
    FRAC_CONST(-0.07293139167538),
64
    FRAC_CONST(0.0),
65
    FRAC_CONST(0.30596630545168),
66
    FRAC_CONST(0.5)
67
};
68
69
static const real_t p12_13_34[7] =
70
{
71
    FRAC_CONST(0.04081179924692),
72
    FRAC_CONST(0.03812810994926),
73
    FRAC_CONST(0.05144908135699),
74
    FRAC_CONST(0.06399831151592),
75
    FRAC_CONST(0.07428313801106),
76
    FRAC_CONST(0.08100347892914),
77
    FRAC_CONST(0.08333333333333)
78
};
79
80
static const real_t p8_13_34[7] =
81
{
82
    FRAC_CONST(0.01565675600122),
83
    FRAC_CONST(0.03752716391991),
84
    FRAC_CONST(0.05417891378782),
85
    FRAC_CONST(0.08417044116767),
86
    FRAC_CONST(0.10307344158036),
87
    FRAC_CONST(0.12222452249753),
88
    FRAC_CONST(0.125)
89
};
90
91
static const real_t p4_13_34[7] =
92
{
93
    FRAC_CONST(-0.05908211155639),
94
    FRAC_CONST(-0.04871498374946),
95
    FRAC_CONST(0.0),
96
    FRAC_CONST(0.07778723915851),
97
    FRAC_CONST(0.16486303567403),
98
    FRAC_CONST(0.23279856662996),
99
    FRAC_CONST(0.25)
100
};
101
102
#ifdef PARAM_32KHZ
103
static const uint8_t delay_length_d[2][NO_ALLPASS_LINKS] = {
104
    { 1, 2, 3 } /* d_24kHz */,
105
    { 3, 4, 5 } /* d_48kHz */
106
};
107
#else
108
static const uint8_t delay_length_d[NO_ALLPASS_LINKS] = {
109
    3, 4, 5 /* d_48kHz */
110
};
111
#endif
112
static const real_t filter_a[NO_ALLPASS_LINKS] = { /* a(m) = exp(-d_48kHz(m)/7) */
113
    FRAC_CONST(0.65143905753106),
114
    FRAC_CONST(0.56471812200776),
115
    FRAC_CONST(0.48954165955695)
116
};
117
118
static const uint8_t group_border20[10+12 + 1] =
119
{
120
    6, 7, 0, 1, 2, 3, /* 6 subqmf subbands */
121
    9, 8,             /* 2 subqmf subbands */
122
    10, 11,           /* 2 subqmf subbands */
123
    3, 4, 5, 6, 7, 8, 9, 11, 14, 18, 23, 35, 64
124
};
125
126
static const uint8_t group_border34[32+18 + 1] =
127
{
128
     0,  1,  2,  3,  4,  5,  6,  7,  8,  9,  10, 11, /* 12 subqmf subbands */
129
     12, 13, 14, 15, 16, 17, 18, 19,                 /*  8 subqmf subbands */
130
     20, 21, 22, 23,                                 /*  4 subqmf subbands */
131
     24, 25, 26, 27,                                 /*  4 subqmf subbands */
132
     28, 29, 30, 31,                                 /*  4 subqmf subbands */
133
     32-27, 33-27, 34-27, 35-27, 36-27, 37-27, 38-27, 40-27, 42-27, 44-27, 46-27, 48-27, 51-27, 54-27, 57-27, 60-27, 64-27, 68-27, 91-27
134
};
135
136
static const uint16_t map_group2bk20[10+12] =
137
{
138
    (NEGATE_IPD_MASK | 1), (NEGATE_IPD_MASK | 0),
139
    0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19
140
};
141
142
static const uint16_t map_group2bk34[32+18] =
143
{
144
    0,  1,  2,  3,  4,  5,  6,  6,  7, (NEGATE_IPD_MASK | 2), (NEGATE_IPD_MASK | 1), (NEGATE_IPD_MASK | 0),
145
    10, 10, 4,  5,  6,  7,  8,  9,
146
    10, 11, 12, 9,
147
    14, 11, 12, 13,
148
    14, 15, 16, 13,
149
    16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33
150
};
151
152
/* type definitions */
153
typedef struct
154
{
155
    uint8_t frame_len;
156
    uint8_t resolution20[3];
157
    uint8_t resolution34[5];
158
159
    qmf_t *work;
160
    qmf_t **buffer;
161
    qmf_t **temp;
162
} hyb_info;
163
164
/* static function declarations */
165
static void ps_data_decode(ps_info *ps);
166
static hyb_info *hybrid_init(uint8_t numTimeSlotsRate);
167
static void channel_filter2(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
168
                            qmf_t *buffer, qmf_t **X_hybrid);
169
static void INLINE DCT3_4_unscaled(real_t *y, real_t *x);
170
static void channel_filter8(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
171
                            qmf_t *buffer, qmf_t **X_hybrid);
172
static void hybrid_analysis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
173
                            uint8_t use34, uint8_t numTimeSlotsRate);
174
static void hybrid_synthesis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
175
                             uint8_t use34, uint8_t numTimeSlotsRate);
176
static int8_t delta_clip(int8_t i, int8_t min, int8_t max);
177
static void delta_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
178
                         uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
179
                         int8_t min_index, int8_t max_index);
180
static void delta_modulo_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
181
                                uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
182
                                int8_t and_modulo);
183
static void map20indexto34(int8_t *index, uint8_t bins);
184
#ifdef PS_LOW_POWER
185
static void map34indexto20(int8_t *index, uint8_t bins);
186
#endif
187
static void ps_data_decode(ps_info *ps);
188
static void ps_decorrelate(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
189
                           qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32]);
190
static void ps_mix_phase(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
191
                         qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32]);
192
193
/*  */
194
195
196
static hyb_info *hybrid_init(uint8_t numTimeSlotsRate)
197
28.4k
{
198
28.4k
    uint8_t i;
199
200
28.4k
    hyb_info *hyb = (hyb_info*)faad_malloc(sizeof(hyb_info));
201
202
28.4k
    hyb->resolution34[0] = 12;
203
28.4k
    hyb->resolution34[1] = 8;
204
28.4k
    hyb->resolution34[2] = 4;
205
28.4k
    hyb->resolution34[3] = 4;
206
28.4k
    hyb->resolution34[4] = 4;
207
208
28.4k
    hyb->resolution20[0] = 8;
209
28.4k
    hyb->resolution20[1] = 2;
210
28.4k
    hyb->resolution20[2] = 2;
211
212
28.4k
    hyb->frame_len = numTimeSlotsRate;
213
214
28.4k
    hyb->work = (qmf_t*)faad_malloc((hyb->frame_len+12) * sizeof(qmf_t));
215
28.4k
    memset(hyb->work, 0, (hyb->frame_len+12) * sizeof(qmf_t));
216
217
28.4k
    hyb->buffer = (qmf_t**)faad_malloc(5 * sizeof(qmf_t*));
218
170k
    for (i = 0; i < 5; i++)
219
142k
    {
220
142k
        hyb->buffer[i] = (qmf_t*)faad_malloc(hyb->frame_len * sizeof(qmf_t));
221
142k
        memset(hyb->buffer[i], 0, hyb->frame_len * sizeof(qmf_t));
222
142k
    }
223
224
28.4k
    hyb->temp = (qmf_t**)faad_malloc(hyb->frame_len * sizeof(qmf_t*));
225
927k
    for (i = 0; i < hyb->frame_len; i++)
226
898k
    {
227
898k
        hyb->temp[i] = (qmf_t*)faad_malloc(12 /*max*/ * sizeof(qmf_t));
228
898k
    }
229
230
28.4k
    return hyb;
231
28.4k
}
232
233
static void hybrid_free(hyb_info *hyb)
234
28.4k
{
235
28.4k
    uint8_t i;
236
237
28.4k
  if (!hyb) return;
238
239
28.4k
    if (hyb->work)
240
28.4k
        faad_free(hyb->work);
241
242
170k
    for (i = 0; i < 5; i++)
243
142k
    {
244
142k
        if (hyb->buffer[i])
245
142k
            faad_free(hyb->buffer[i]);
246
142k
    }
247
28.4k
    if (hyb->buffer)
248
28.4k
        faad_free(hyb->buffer);
249
250
927k
    for (i = 0; i < hyb->frame_len; i++)
251
898k
    {
252
898k
        if (hyb->temp[i])
253
898k
            faad_free(hyb->temp[i]);
254
898k
    }
255
28.4k
    if (hyb->temp)
256
28.4k
        faad_free(hyb->temp);
257
258
28.4k
    faad_free(hyb);
259
28.4k
}
260
261
/* real filter, size 2 */
262
static void channel_filter2(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
263
                            qmf_t *buffer, qmf_t **X_hybrid)
264
48.1k
{
265
48.1k
    uint8_t i;
266
48.1k
    (void)hyb;  /* TODO: remove parameter? */
267
268
1.55M
    for (i = 0; i < frame_len; i++)
269
1.51M
    {
270
1.51M
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
1.51M
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
1.51M
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
1.51M
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
1.51M
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
1.51M
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
1.51M
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
1.51M
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
1.51M
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
1.51M
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
1.51M
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
1.51M
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
1.51M
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
1.51M
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
1.51M
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
1.51M
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
1.51M
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
1.51M
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
1.51M
    }
293
48.1k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
24.0k
{
265
24.0k
    uint8_t i;
266
24.0k
    (void)hyb;  /* TODO: remove parameter? */
267
268
779k
    for (i = 0; i < frame_len; i++)
269
755k
    {
270
755k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
755k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
755k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
755k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
755k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
755k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
755k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
755k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
755k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
755k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
755k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
755k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
755k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
755k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
755k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
755k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
755k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
755k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
755k
    }
293
24.0k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
24.0k
{
265
24.0k
    uint8_t i;
266
24.0k
    (void)hyb;  /* TODO: remove parameter? */
267
268
779k
    for (i = 0; i < frame_len; i++)
269
755k
    {
270
755k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
755k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
755k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
755k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
755k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
755k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
755k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
755k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
755k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
755k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
755k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
755k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
755k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
755k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
755k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
755k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
755k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
755k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
755k
    }
293
24.0k
}
294
295
/* complex filter, size 4 */
296
static void channel_filter4(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
297
                            qmf_t *buffer, qmf_t **X_hybrid)
298
18.9k
{
299
18.9k
    uint8_t i;
300
18.9k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
18.9k
    (void)hyb;  /* TODO: remove parameter? */
302
303
601k
    for (i = 0; i < frame_len; i++)
304
582k
    {
305
582k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
582k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
582k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
582k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
582k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
582k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
582k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
582k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
582k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
582k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
582k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
582k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
582k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
582k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
582k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
582k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
582k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
582k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
582k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
582k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
582k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
582k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
582k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
582k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
582k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
582k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
582k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
582k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
582k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
582k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
582k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
582k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
582k
    }
349
18.9k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
7.37k
{
299
7.37k
    uint8_t i;
300
7.37k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
7.37k
    (void)hyb;  /* TODO: remove parameter? */
302
303
235k
    for (i = 0; i < frame_len; i++)
304
227k
    {
305
227k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
227k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
227k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
227k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
227k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
227k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
227k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
227k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
227k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
227k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
227k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
227k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
227k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
227k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
227k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
227k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
227k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
227k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
227k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
227k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
227k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
227k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
227k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
227k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
227k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
227k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
227k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
227k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
227k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
227k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
227k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
227k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
227k
    }
349
7.37k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
11.5k
{
299
11.5k
    uint8_t i;
300
11.5k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
11.5k
    (void)hyb;  /* TODO: remove parameter? */
302
303
366k
    for (i = 0; i < frame_len; i++)
304
354k
    {
305
354k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
354k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
354k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
354k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
354k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
354k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
354k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
354k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
354k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
354k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
354k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
354k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
354k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
354k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
354k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
354k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
354k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
354k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
354k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
354k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
354k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
354k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
354k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
354k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
354k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
354k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
354k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
354k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
354k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
354k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
354k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
354k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
354k
    }
349
11.5k
}
350
351
static void INLINE DCT3_4_unscaled(real_t *y, real_t *x)
352
2.28M
{
353
2.28M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
2.28M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
2.28M
    f1 = x[0] - f0;
357
2.28M
    f2 = x[0] + f0;
358
2.28M
    f3 = x[1] + x[3];
359
2.28M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
2.28M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
2.28M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
2.28M
    f7 = f4 + f5;
363
2.28M
    f8 = f6 - f5;
364
2.28M
    y[3] = f2 - f8;
365
2.28M
    y[0] = f2 + f8;
366
2.28M
    y[2] = f1 - f7;
367
2.28M
    y[1] = f1 + f7;
368
2.28M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
951k
{
353
951k
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
951k
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
951k
    f1 = x[0] - f0;
357
951k
    f2 = x[0] + f0;
358
951k
    f3 = x[1] + x[3];
359
951k
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
951k
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
951k
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
951k
    f7 = f4 + f5;
363
951k
    f8 = f6 - f5;
364
951k
    y[3] = f2 - f8;
365
951k
    y[0] = f2 + f8;
366
951k
    y[2] = f1 - f7;
367
951k
    y[1] = f1 + f7;
368
951k
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.33M
{
353
1.33M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.33M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.33M
    f1 = x[0] - f0;
357
1.33M
    f2 = x[0] + f0;
358
1.33M
    f3 = x[1] + x[3];
359
1.33M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.33M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.33M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.33M
    f7 = f4 + f5;
363
1.33M
    f8 = f6 - f5;
364
1.33M
    y[3] = f2 - f8;
365
1.33M
    y[0] = f2 + f8;
366
1.33M
    y[2] = f1 - f7;
367
1.33M
    y[1] = f1 + f7;
368
1.33M
}
369
370
/* complex filter, size 8 */
371
static void channel_filter8(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
372
                            qmf_t *buffer, qmf_t **X_hybrid)
373
36.7k
{
374
36.7k
    uint8_t i, n;
375
36.7k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
36.7k
    real_t x[4];
377
36.7k
    (void)hyb;  /* TODO: remove parameter? */
378
379
1.18M
    for (i = 0; i < frame_len; i++)
380
1.14M
    {
381
1.14M
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
1.14M
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
1.14M
        input_re1[2] = -MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i]))) + MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
384
1.14M
        input_re1[3] = -MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i]))) + MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
385
386
1.14M
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
1.14M
        input_im1[1] = MUL_F(filter[0],(QMF_IM(buffer[12+i]) - QMF_IM(buffer[0+i]))) + MUL_F(filter[4],(QMF_IM(buffer[8+i]) - QMF_IM(buffer[4+i])));
388
1.14M
        input_im1[2] = MUL_F(filter[1],(QMF_IM(buffer[11+i]) - QMF_IM(buffer[1+i]))) + MUL_F(filter[3],(QMF_IM(buffer[9+i]) - QMF_IM(buffer[3+i])));
389
1.14M
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
5.71M
        for (n = 0; n < 4; n++)
392
4.57M
        {
393
4.57M
            x[n] = input_re1[n] - input_im1[3-n];
394
4.57M
        }
395
1.14M
        DCT3_4_unscaled(x, x);
396
1.14M
        QMF_RE(X_hybrid[i][7]) = x[0];
397
1.14M
        QMF_RE(X_hybrid[i][5]) = x[2];
398
1.14M
        QMF_RE(X_hybrid[i][3]) = x[3];
399
1.14M
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
5.71M
        for (n = 0; n < 4; n++)
402
4.57M
        {
403
4.57M
            x[n] = input_re1[n] + input_im1[3-n];
404
4.57M
        }
405
1.14M
        DCT3_4_unscaled(x, x);
406
1.14M
        QMF_RE(X_hybrid[i][6]) = x[1];
407
1.14M
        QMF_RE(X_hybrid[i][4]) = x[3];
408
1.14M
        QMF_RE(X_hybrid[i][2]) = x[2];
409
1.14M
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
1.14M
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
1.14M
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
1.14M
        input_im2[2] = -MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i]))) + MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
414
1.14M
        input_im2[3] = -MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i]))) + MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
415
416
1.14M
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
1.14M
        input_re2[1] = MUL_F(filter[0],(QMF_RE(buffer[12+i]) - QMF_RE(buffer[0+i]))) + MUL_F(filter[4],(QMF_RE(buffer[8+i]) - QMF_RE(buffer[4+i])));
418
1.14M
        input_re2[2] = MUL_F(filter[1],(QMF_RE(buffer[11+i]) - QMF_RE(buffer[1+i]))) + MUL_F(filter[3],(QMF_RE(buffer[9+i]) - QMF_RE(buffer[3+i])));
419
1.14M
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
5.71M
        for (n = 0; n < 4; n++)
422
4.57M
        {
423
4.57M
            x[n] = input_im2[n] + input_re2[3-n];
424
4.57M
        }
425
1.14M
        DCT3_4_unscaled(x, x);
426
1.14M
        QMF_IM(X_hybrid[i][7]) = x[0];
427
1.14M
        QMF_IM(X_hybrid[i][5]) = x[2];
428
1.14M
        QMF_IM(X_hybrid[i][3]) = x[3];
429
1.14M
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
5.71M
        for (n = 0; n < 4; n++)
432
4.57M
        {
433
4.57M
            x[n] = input_im2[n] - input_re2[3-n];
434
4.57M
        }
435
1.14M
        DCT3_4_unscaled(x, x);
436
1.14M
        QMF_IM(X_hybrid[i][6]) = x[1];
437
1.14M
        QMF_IM(X_hybrid[i][4]) = x[3];
438
1.14M
        QMF_IM(X_hybrid[i][2]) = x[2];
439
1.14M
        QMF_IM(X_hybrid[i][0]) = x[0];
440
1.14M
    }
441
36.7k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
18.3k
{
374
18.3k
    uint8_t i, n;
375
18.3k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
18.3k
    real_t x[4];
377
18.3k
    (void)hyb;  /* TODO: remove parameter? */
378
379
590k
    for (i = 0; i < frame_len; i++)
380
571k
    {
381
571k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
571k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
571k
        input_re1[2] = -MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i]))) + MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
384
571k
        input_re1[3] = -MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i]))) + MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
385
386
571k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
571k
        input_im1[1] = MUL_F(filter[0],(QMF_IM(buffer[12+i]) - QMF_IM(buffer[0+i]))) + MUL_F(filter[4],(QMF_IM(buffer[8+i]) - QMF_IM(buffer[4+i])));
388
571k
        input_im1[2] = MUL_F(filter[1],(QMF_IM(buffer[11+i]) - QMF_IM(buffer[1+i]))) + MUL_F(filter[3],(QMF_IM(buffer[9+i]) - QMF_IM(buffer[3+i])));
389
571k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
2.85M
        for (n = 0; n < 4; n++)
392
2.28M
        {
393
2.28M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.28M
        }
395
571k
        DCT3_4_unscaled(x, x);
396
571k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
571k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
571k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
571k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
2.85M
        for (n = 0; n < 4; n++)
402
2.28M
        {
403
2.28M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.28M
        }
405
571k
        DCT3_4_unscaled(x, x);
406
571k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
571k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
571k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
571k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
571k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
571k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
571k
        input_im2[2] = -MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i]))) + MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
414
571k
        input_im2[3] = -MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i]))) + MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
415
416
571k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
571k
        input_re2[1] = MUL_F(filter[0],(QMF_RE(buffer[12+i]) - QMF_RE(buffer[0+i]))) + MUL_F(filter[4],(QMF_RE(buffer[8+i]) - QMF_RE(buffer[4+i])));
418
571k
        input_re2[2] = MUL_F(filter[1],(QMF_RE(buffer[11+i]) - QMF_RE(buffer[1+i]))) + MUL_F(filter[3],(QMF_RE(buffer[9+i]) - QMF_RE(buffer[3+i])));
419
571k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
2.85M
        for (n = 0; n < 4; n++)
422
2.28M
        {
423
2.28M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.28M
        }
425
571k
        DCT3_4_unscaled(x, x);
426
571k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
571k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
571k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
571k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
2.85M
        for (n = 0; n < 4; n++)
432
2.28M
        {
433
2.28M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.28M
        }
435
571k
        DCT3_4_unscaled(x, x);
436
571k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
571k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
571k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
571k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
571k
    }
441
18.3k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
18.3k
{
374
18.3k
    uint8_t i, n;
375
18.3k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
18.3k
    real_t x[4];
377
18.3k
    (void)hyb;  /* TODO: remove parameter? */
378
379
590k
    for (i = 0; i < frame_len; i++)
380
571k
    {
381
571k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
571k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
571k
        input_re1[2] = -MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i]))) + MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
384
571k
        input_re1[3] = -MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i]))) + MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
385
386
571k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
571k
        input_im1[1] = MUL_F(filter[0],(QMF_IM(buffer[12+i]) - QMF_IM(buffer[0+i]))) + MUL_F(filter[4],(QMF_IM(buffer[8+i]) - QMF_IM(buffer[4+i])));
388
571k
        input_im1[2] = MUL_F(filter[1],(QMF_IM(buffer[11+i]) - QMF_IM(buffer[1+i]))) + MUL_F(filter[3],(QMF_IM(buffer[9+i]) - QMF_IM(buffer[3+i])));
389
571k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
2.85M
        for (n = 0; n < 4; n++)
392
2.28M
        {
393
2.28M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.28M
        }
395
571k
        DCT3_4_unscaled(x, x);
396
571k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
571k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
571k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
571k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
2.85M
        for (n = 0; n < 4; n++)
402
2.28M
        {
403
2.28M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.28M
        }
405
571k
        DCT3_4_unscaled(x, x);
406
571k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
571k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
571k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
571k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
571k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
571k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
571k
        input_im2[2] = -MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i]))) + MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
414
571k
        input_im2[3] = -MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i]))) + MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
415
416
571k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
571k
        input_re2[1] = MUL_F(filter[0],(QMF_RE(buffer[12+i]) - QMF_RE(buffer[0+i]))) + MUL_F(filter[4],(QMF_RE(buffer[8+i]) - QMF_RE(buffer[4+i])));
418
571k
        input_re2[2] = MUL_F(filter[1],(QMF_RE(buffer[11+i]) - QMF_RE(buffer[1+i]))) + MUL_F(filter[3],(QMF_RE(buffer[9+i]) - QMF_RE(buffer[3+i])));
419
571k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
2.85M
        for (n = 0; n < 4; n++)
422
2.28M
        {
423
2.28M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.28M
        }
425
571k
        DCT3_4_unscaled(x, x);
426
571k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
571k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
571k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
571k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
2.85M
        for (n = 0; n < 4; n++)
432
2.28M
        {
433
2.28M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.28M
        }
435
571k
        DCT3_4_unscaled(x, x);
436
571k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
571k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
571k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
571k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
571k
    }
441
18.3k
}
442
443
static void INLINE DCT3_6_unscaled(real_t *y, real_t *x)
444
777k
{
445
777k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
777k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
777k
    f1 = x[0] + f0;
449
777k
    f2 = x[0] - f0;
450
777k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
777k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
777k
    f5 = f4 - x[4];
453
777k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
777k
    f7 = f6 - f3;
455
777k
    y[0] = f1 + f6 + f4;
456
777k
    y[1] = f2 + f3 - x[4];
457
777k
    y[2] = f7 + f2 - f5;
458
777k
    y[3] = f1 - f7 - f5;
459
777k
    y[4] = f1 - f3 - x[4];
460
777k
    y[5] = f2 - f6 + f4;
461
777k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
303k
{
445
303k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
303k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
303k
    f1 = x[0] + f0;
449
303k
    f2 = x[0] - f0;
450
303k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
303k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
303k
    f5 = f4 - x[4];
453
303k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
303k
    f7 = f6 - f3;
455
303k
    y[0] = f1 + f6 + f4;
456
303k
    y[1] = f2 + f3 - x[4];
457
303k
    y[2] = f7 + f2 - f5;
458
303k
    y[3] = f1 - f7 - f5;
459
303k
    y[4] = f1 - f3 - x[4];
460
303k
    y[5] = f2 - f6 + f4;
461
303k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
473k
{
445
473k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
473k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
473k
    f1 = x[0] + f0;
449
473k
    f2 = x[0] - f0;
450
473k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
473k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
473k
    f5 = f4 - x[4];
453
473k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
473k
    f7 = f6 - f3;
455
473k
    y[0] = f1 + f6 + f4;
456
473k
    y[1] = f2 + f3 - x[4];
457
473k
    y[2] = f7 + f2 - f5;
458
473k
    y[3] = f1 - f7 - f5;
459
473k
    y[4] = f1 - f3 - x[4];
460
473k
    y[5] = f2 - f6 + f4;
461
473k
}
462
463
/* complex filter, size 12 */
464
static void channel_filter12(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
465
                             qmf_t *buffer, qmf_t **X_hybrid)
466
12.6k
{
467
12.6k
    uint8_t i, n;
468
12.6k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
12.6k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
12.6k
    (void)hyb;  /* TODO: remove parameter? */
471
472
401k
    for (i = 0; i < frame_len; i++)
473
388k
    {
474
2.72M
        for (n = 0; n < 6; n++)
475
2.33M
        {
476
2.33M
            if (n == 0)
477
388k
            {
478
388k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
388k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.94M
            } else {
481
1.94M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.94M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.94M
            }
484
2.33M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
2.33M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
2.33M
        }
487
488
388k
        DCT3_6_unscaled(out_re1, input_re1);
489
388k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
388k
        DCT3_6_unscaled(out_im1, input_im1);
492
388k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
1.55M
        for (n = 0; n < 6; n += 2)
495
1.16M
        {
496
1.16M
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
1.16M
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
1.16M
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
1.16M
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
1.16M
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
1.16M
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
1.16M
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
1.16M
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
1.16M
        }
506
388k
    }
507
12.6k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
6.31k
{
467
6.31k
    uint8_t i, n;
468
6.31k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
6.31k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
6.31k
    (void)hyb;  /* TODO: remove parameter? */
471
472
200k
    for (i = 0; i < frame_len; i++)
473
194k
    {
474
1.36M
        for (n = 0; n < 6; n++)
475
1.16M
        {
476
1.16M
            if (n == 0)
477
194k
            {
478
194k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
194k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
971k
            } else {
481
971k
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
971k
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
971k
            }
484
1.16M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.16M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.16M
        }
487
488
194k
        DCT3_6_unscaled(out_re1, input_re1);
489
194k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
194k
        DCT3_6_unscaled(out_im1, input_im1);
492
194k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
777k
        for (n = 0; n < 6; n += 2)
495
582k
        {
496
582k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
582k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
582k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
582k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
582k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
582k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
582k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
582k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
582k
        }
506
194k
    }
507
6.31k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
6.31k
{
467
6.31k
    uint8_t i, n;
468
6.31k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
6.31k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
6.31k
    (void)hyb;  /* TODO: remove parameter? */
471
472
200k
    for (i = 0; i < frame_len; i++)
473
194k
    {
474
1.36M
        for (n = 0; n < 6; n++)
475
1.16M
        {
476
1.16M
            if (n == 0)
477
194k
            {
478
194k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
194k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
971k
            } else {
481
971k
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
971k
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
971k
            }
484
1.16M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.16M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.16M
        }
487
488
194k
        DCT3_6_unscaled(out_re1, input_re1);
489
194k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
194k
        DCT3_6_unscaled(out_im1, input_im1);
492
194k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
777k
        for (n = 0; n < 6; n += 2)
495
582k
        {
496
582k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
582k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
582k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
582k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
582k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
582k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
582k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
582k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
582k
        }
506
194k
    }
507
6.31k
}
508
509
/* Hybrid analysis: further split up QMF subbands
510
 * to improve frequency resolution
511
 */
512
static void hybrid_analysis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
513
                            uint8_t use34, uint8_t numTimeSlotsRate)
514
18.3k
{
515
18.3k
    uint8_t k, n, band;
516
18.3k
    uint8_t offset = 0;
517
18.3k
    uint8_t qmf_bands = (use34) ? 5 : 3;
518
18.3k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
519
520
86.0k
    for (band = 0; band < qmf_bands; band++)
521
67.7k
    {
522
        /* build working buffer */
523
67.7k
        memcpy(hyb->work, hyb->buffer[band], 12 * sizeof(qmf_t));
524
525
        /* add new samples */
526
2.17M
        for (n = 0; n < hyb->frame_len; n++)
527
2.10M
        {
528
2.10M
            QMF_RE(hyb->work[12 + n]) = QMF_RE(X[n + 6 /*delay*/][band]);
529
2.10M
            QMF_IM(hyb->work[12 + n]) = QMF_IM(X[n + 6 /*delay*/][band]);
530
2.10M
        }
531
532
        /* store samples */
533
67.7k
        memcpy(hyb->buffer[band], hyb->work + hyb->frame_len, 12 * sizeof(qmf_t));
534
535
536
67.7k
        switch(resolution[band])
537
67.7k
        {
538
24.0k
        case 2:
539
            /* Type B real filter, Q[p] = 2 */
540
24.0k
            channel_filter2(hyb, hyb->frame_len, p2_13_20, hyb->work, hyb->temp);
541
24.0k
            break;
542
18.9k
        case 4:
543
            /* Type A complex filter, Q[p] = 4 */
544
18.9k
            channel_filter4(hyb, hyb->frame_len, p4_13_34, hyb->work, hyb->temp);
545
18.9k
            break;
546
18.3k
        case 8:
547
            /* Type A complex filter, Q[p] = 8 */
548
18.3k
            channel_filter8(hyb, hyb->frame_len, (use34) ? p8_13_34 : p8_13_20,
549
18.3k
                hyb->work, hyb->temp);
550
18.3k
            break;
551
6.31k
        case 12:
552
            /* Type A complex filter, Q[p] = 12 */
553
6.31k
            channel_filter12(hyb, hyb->frame_len, p12_13_34, hyb->work, hyb->temp);
554
6.31k
            break;
555
67.7k
        }
556
557
2.17M
        for (n = 0; n < hyb->frame_len; n++)
558
2.10M
        {
559
12.8M
            for (k = 0; k < resolution[band]; k++)
560
10.7M
            {
561
10.7M
                QMF_RE(X_hybrid[n][offset + k]) = QMF_RE(hyb->temp[n][k]);
562
10.7M
                QMF_IM(X_hybrid[n][offset + k]) = QMF_IM(hyb->temp[n][k]);
563
10.7M
            }
564
2.10M
        }
565
67.7k
        offset += resolution[band];
566
67.7k
    }
567
568
    /* group hybrid channels */
569
18.3k
    if (!use34)
570
12.0k
    {
571
389k
        for (n = 0; n < numTimeSlotsRate; n++)
572
377k
        {
573
377k
            QMF_RE(X_hybrid[n][3]) += QMF_RE(X_hybrid[n][4]);
574
377k
            QMF_IM(X_hybrid[n][3]) += QMF_IM(X_hybrid[n][4]);
575
377k
            QMF_RE(X_hybrid[n][4]) = 0;
576
377k
            QMF_IM(X_hybrid[n][4]) = 0;
577
578
377k
            QMF_RE(X_hybrid[n][2]) += QMF_RE(X_hybrid[n][5]);
579
377k
            QMF_IM(X_hybrid[n][2]) += QMF_IM(X_hybrid[n][5]);
580
377k
            QMF_RE(X_hybrid[n][5]) = 0;
581
377k
            QMF_IM(X_hybrid[n][5]) = 0;
582
377k
        }
583
12.0k
    }
584
18.3k
}
585
586
static void hybrid_synthesis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
587
                             uint8_t use34, uint8_t numTimeSlotsRate)
588
36.7k
{
589
36.7k
    uint8_t k, n, band;
590
36.7k
    uint8_t offset = 0;
591
36.7k
    uint8_t qmf_bands = (use34) ? 5 : 3;
592
36.7k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
593
36.7k
    (void)numTimeSlotsRate;  /* TODO: remove parameter? */
594
595
172k
    for(band = 0; band < qmf_bands; band++)
596
135k
    {
597
4.34M
        for (n = 0; n < hyb->frame_len; n++)
598
4.20M
        {
599
4.20M
            QMF_RE(X[n][band]) = 0;
600
4.20M
            QMF_IM(X[n][band]) = 0;
601
602
25.7M
            for (k = 0; k < resolution[band]; k++)
603
21.4M
            {
604
21.4M
                QMF_RE(X[n][band]) += QMF_RE(X_hybrid[n][offset + k]);
605
21.4M
                QMF_IM(X[n][band]) += QMF_IM(X_hybrid[n][offset + k]);
606
21.4M
            }
607
4.20M
        }
608
135k
        offset += resolution[band];
609
135k
    }
610
36.7k
}
611
612
/* limits the value i to the range [min,max] */
613
static int8_t delta_clip(int8_t i, int8_t min, int8_t max)
614
454k
{
615
454k
    if (i < min)
616
61.2k
        return min;
617
393k
    else if (i > max)
618
6.46k
        return max;
619
386k
    else
620
386k
        return i;
621
454k
}
622
623
//int iid = 0;
624
625
/* delta decode array */
626
static void delta_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
627
                         uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
628
                         int8_t min_index, int8_t max_index)
629
69.3k
{
630
69.3k
    int8_t i;
631
632
69.3k
    if (enable == 1)
633
35.1k
    {
634
35.1k
        if (dt_flag == 0)
635
21.7k
        {
636
            /* delta coded in frequency direction */
637
21.7k
            index[0] = 0 + index[0];
638
21.7k
            index[0] = delta_clip(index[0], min_index, max_index);
639
640
289k
            for (i = 1; i < nr_par; i++)
641
267k
            {
642
267k
                index[i] = index[i-1] + index[i];
643
267k
                index[i] = delta_clip(index[i], min_index, max_index);
644
267k
            }
645
21.7k
        } else {
646
            /* delta coded in time direction */
647
178k
            for (i = 0; i < nr_par; i++)
648
165k
            {
649
                //int8_t tmp2;
650
                //int8_t tmp = index[i];
651
652
                //printf("%d %d\n", index_prev[i*stride], index[i]);
653
                //printf("%d\n", index[i]);
654
655
165k
                index[i] = index_prev[i*stride] + index[i];
656
                //tmp2 = index[i];
657
165k
                index[i] = delta_clip(index[i], min_index, max_index);
658
659
                //if (iid)
660
                //{
661
                //    if (index[i] == 7)
662
                //    {
663
                //        printf("%d %d %d\n", index_prev[i*stride], tmp, tmp2);
664
                //    }
665
                //}
666
165k
            }
667
13.3k
        }
668
35.1k
    } else {
669
        /* set indices to zero */
670
51.2k
        for (i = 0; i < nr_par; i++)
671
17.0k
        {
672
17.0k
            index[i] = 0;
673
17.0k
        }
674
34.1k
    }
675
676
    /* coarse */
677
69.3k
    if (stride == 2)
678
45.9k
    {
679
284k
        for (i = (nr_par<<1)-1; i > 0; i--)
680
238k
        {
681
238k
            index[i] = index[i>>1];
682
238k
        }
683
45.9k
    }
684
69.3k
}
685
686
/* delta modulo decode array */
687
/* in: log2 value of the modulo value to allow using AND instead of MOD */
688
static void delta_modulo_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
689
                                uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
690
                                int8_t and_modulo)
691
69.3k
{
692
69.3k
    int8_t i;
693
694
69.3k
    if (enable == 1)
695
24.1k
    {
696
24.1k
        if (dt_flag == 0)
697
15.8k
        {
698
            /* delta coded in frequency direction */
699
15.8k
            index[0] = 0 + index[0];
700
15.8k
            index[0] &= and_modulo;
701
702
54.6k
            for (i = 1; i < nr_par; i++)
703
38.8k
            {
704
38.8k
                index[i] = index[i-1] + index[i];
705
38.8k
                index[i] &= and_modulo;
706
38.8k
            }
707
15.8k
        } else {
708
            /* delta coded in time direction */
709
23.4k
            for (i = 0; i < nr_par; i++)
710
15.0k
            {
711
15.0k
                index[i] = index_prev[i*stride] + index[i];
712
15.0k
                index[i] &= and_modulo;
713
15.0k
            }
714
8.35k
        }
715
45.1k
    } else {
716
        /* set indices to zero */
717
157k
        for (i = 0; i < nr_par; i++)
718
112k
        {
719
112k
            index[i] = 0;
720
112k
        }
721
45.1k
    }
722
723
    /* coarse */
724
69.3k
    if (stride == 2)
725
0
    {
726
0
        index[0] = 0;
727
0
        for (i = (nr_par<<1)-1; i > 0; i--)
728
0
        {
729
0
            index[i] = index[i>>1];
730
0
        }
731
0
    }
732
69.3k
}
733
734
#ifdef PS_LOW_POWER
735
static void map34indexto20(int8_t *index, uint8_t bins)
736
{
737
    index[0] = (2*index[0]+index[1])/3;
738
    index[1] = (index[1]+2*index[2])/3;
739
    index[2] = (2*index[3]+index[4])/3;
740
    index[3] = (index[4]+2*index[5])/3;
741
    index[4] = (index[6]+index[7])/2;
742
    index[5] = (index[8]+index[9])/2;
743
    index[6] = index[10];
744
    index[7] = index[11];
745
    index[8] = (index[12]+index[13])/2;
746
    index[9] = (index[14]+index[15])/2;
747
    index[10] = index[16];
748
749
    if (bins == 34)
750
    {
751
        index[11] = index[17];
752
        index[12] = index[18];
753
        index[13] = index[19];
754
        index[14] = (index[20]+index[21])/2;
755
        index[15] = (index[22]+index[23])/2;
756
        index[16] = (index[24]+index[25])/2;
757
        index[17] = (index[26]+index[27])/2;
758
        index[18] = (index[28]+index[29]+index[30]+index[31])/4;
759
        index[19] = (index[32]+index[33])/2;
760
    }
761
}
762
#endif
763
764
static void map20indexto34(int8_t *index, uint8_t bins)
765
28.1k
{
766
28.1k
    index[0] = index[0];
767
28.1k
    index[1] = (index[0] + index[1])/2;
768
28.1k
    index[2] = index[1];
769
28.1k
    index[3] = index[2];
770
28.1k
    index[4] = (index[2] + index[3])/2;
771
28.1k
    index[5] = index[3];
772
28.1k
    index[6] = index[4];
773
28.1k
    index[7] = index[4];
774
28.1k
    index[8] = index[5];
775
28.1k
    index[9] = index[5];
776
28.1k
    index[10] = index[6];
777
28.1k
    index[11] = index[7];
778
28.1k
    index[12] = index[8];
779
28.1k
    index[13] = index[8];
780
28.1k
    index[14] = index[9];
781
28.1k
    index[15] = index[9];
782
28.1k
    index[16] = index[10];
783
784
28.1k
    if (bins == 34)
785
12.2k
    {
786
12.2k
        index[17] = index[11];
787
12.2k
        index[18] = index[12];
788
12.2k
        index[19] = index[13];
789
12.2k
        index[20] = index[14];
790
12.2k
        index[21] = index[14];
791
12.2k
        index[22] = index[15];
792
12.2k
        index[23] = index[15];
793
12.2k
        index[24] = index[16];
794
12.2k
        index[25] = index[16];
795
12.2k
        index[26] = index[17];
796
12.2k
        index[27] = index[17];
797
12.2k
        index[28] = index[18];
798
12.2k
        index[29] = index[18];
799
12.2k
        index[30] = index[18];
800
12.2k
        index[31] = index[18];
801
12.2k
        index[32] = index[19];
802
12.2k
        index[33] = index[19];
803
12.2k
    }
804
28.1k
}
805
806
/* parse the bitstream data decoded in ps_data() */
807
static void ps_data_decode(ps_info *ps)
808
18.3k
{
809
18.3k
    uint8_t env, bin;
810
811
    /* ps data not available, use data from previous frame */
812
18.3k
    if (ps->ps_data_available == 0)
813
4.29k
    {
814
4.29k
        ps->num_env = 0;
815
4.29k
    }
816
817
53.0k
    for (env = 0; env < ps->num_env; env++)
818
34.6k
    {
819
34.6k
        int8_t *iid_index_prev;
820
34.6k
        int8_t *icc_index_prev;
821
34.6k
        int8_t *ipd_index_prev;
822
34.6k
        int8_t *opd_index_prev;
823
824
34.6k
        int8_t num_iid_steps = (ps->iid_mode < 3) ? 7 : 15 /*fine quant*/;
825
826
34.6k
        if (env == 0)
827
10.3k
        {
828
            /* take last envelope from previous frame */
829
10.3k
            iid_index_prev = ps->iid_index_prev;
830
10.3k
            icc_index_prev = ps->icc_index_prev;
831
10.3k
            ipd_index_prev = ps->ipd_index_prev;
832
10.3k
            opd_index_prev = ps->opd_index_prev;
833
24.3k
        } else {
834
            /* take index values from previous envelope */
835
24.3k
            iid_index_prev = ps->iid_index[env - 1];
836
24.3k
            icc_index_prev = ps->icc_index[env - 1];
837
24.3k
            ipd_index_prev = ps->ipd_index[env - 1];
838
24.3k
            opd_index_prev = ps->opd_index[env - 1];
839
24.3k
        }
840
841
//        iid = 1;
842
        /* delta decode iid parameters */
843
34.6k
        delta_decode(ps->enable_iid, ps->iid_index[env], iid_index_prev,
844
34.6k
            ps->iid_dt[env], ps->nr_iid_par,
845
34.6k
            (ps->iid_mode == 0 || ps->iid_mode == 3) ? 2 : 1,
846
34.6k
            -num_iid_steps, num_iid_steps);
847
//        iid = 0;
848
849
        /* delta decode icc parameters */
850
34.6k
        delta_decode(ps->enable_icc, ps->icc_index[env], icc_index_prev,
851
34.6k
            ps->icc_dt[env], ps->nr_icc_par,
852
34.6k
            (ps->icc_mode == 0 || ps->icc_mode == 3) ? 2 : 1,
853
34.6k
            0, 7);
854
855
        /* delta modulo decode ipd parameters */
856
34.6k
        delta_modulo_decode(ps->enable_ipdopd, ps->ipd_index[env], ipd_index_prev,
857
34.6k
            ps->ipd_dt[env], ps->nr_ipdopd_par, 1, 7);
858
859
        /* delta modulo decode opd parameters */
860
34.6k
        delta_modulo_decode(ps->enable_ipdopd, ps->opd_index[env], opd_index_prev,
861
34.6k
            ps->opd_dt[env], ps->nr_ipdopd_par, 1, 7);
862
34.6k
    }
863
864
    /* handle error case */
865
18.3k
    if (ps->num_env == 0)
866
8.05k
    {
867
        /* force to 1 */
868
8.05k
        ps->num_env = 1;
869
870
8.05k
        if (ps->enable_iid)
871
5.50k
        {
872
192k
            for (bin = 0; bin < 34; bin++)
873
187k
                ps->iid_index[0][bin] = ps->iid_index_prev[bin];
874
5.50k
        } else {
875
88.9k
            for (bin = 0; bin < 34; bin++)
876
86.4k
                ps->iid_index[0][bin] = 0;
877
2.54k
        }
878
879
8.05k
        if (ps->enable_icc)
880
3.61k
        {
881
126k
            for (bin = 0; bin < 34; bin++)
882
122k
                ps->icc_index[0][bin] = ps->icc_index_prev[bin];
883
4.43k
        } else {
884
155k
            for (bin = 0; bin < 34; bin++)
885
150k
                ps->icc_index[0][bin] = 0;
886
4.43k
        }
887
888
8.05k
        if (ps->enable_ipdopd)
889
1.00k
        {
890
18.0k
            for (bin = 0; bin < 17; bin++)
891
17.0k
            {
892
17.0k
                ps->ipd_index[0][bin] = ps->ipd_index_prev[bin];
893
17.0k
                ps->opd_index[0][bin] = ps->opd_index_prev[bin];
894
17.0k
            }
895
7.04k
        } else {
896
126k
            for (bin = 0; bin < 17; bin++)
897
119k
            {
898
119k
                ps->ipd_index[0][bin] = 0;
899
119k
                ps->opd_index[0][bin] = 0;
900
119k
            }
901
7.04k
        }
902
8.05k
    }
903
904
    /* update previous indices */
905
642k
    for (bin = 0; bin < 34; bin++)
906
624k
        ps->iid_index_prev[bin] = ps->iid_index[ps->num_env-1][bin];
907
642k
    for (bin = 0; bin < 34; bin++)
908
624k
        ps->icc_index_prev[bin] = ps->icc_index[ps->num_env-1][bin];
909
330k
    for (bin = 0; bin < 17; bin++)
910
312k
    {
911
312k
        ps->ipd_index_prev[bin] = ps->ipd_index[ps->num_env-1][bin];
912
312k
        ps->opd_index_prev[bin] = ps->opd_index[ps->num_env-1][bin];
913
312k
    }
914
915
18.3k
    ps->ps_data_available = 0;
916
917
18.3k
    if (ps->frame_class == 0)
918
10.3k
    {
919
10.3k
        ps->border_position[0] = 0;
920
19.8k
        for (env = 1; env < ps->num_env; env++)
921
9.51k
        {
922
9.51k
            ps->border_position[env] = (env * ps->numTimeSlotsRate) / ps->num_env;
923
9.51k
        }
924
10.3k
        ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
925
10.3k
    } else {
926
7.99k
        ps->border_position[0] = 0;
927
928
7.99k
        if (ps->border_position[ps->num_env] < ps->numTimeSlotsRate)
929
5.89k
        {
930
206k
            for (bin = 0; bin < 34; bin++)
931
200k
            {
932
200k
                ps->iid_index[ps->num_env][bin] = ps->iid_index[ps->num_env-1][bin];
933
200k
                ps->icc_index[ps->num_env][bin] = ps->icc_index[ps->num_env-1][bin];
934
200k
            }
935
106k
            for (bin = 0; bin < 17; bin++)
936
100k
            {
937
100k
                ps->ipd_index[ps->num_env][bin] = ps->ipd_index[ps->num_env-1][bin];
938
100k
                ps->opd_index[ps->num_env][bin] = ps->opd_index[ps->num_env-1][bin];
939
100k
            }
940
5.89k
            ps->num_env++;
941
5.89k
            ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
942
5.89k
        }
943
944
28.7k
        for (env = 1; env < ps->num_env; env++)
945
20.7k
        {
946
20.7k
            int8_t thr = ps->numTimeSlotsRate - (ps->num_env - env);
947
948
20.7k
            if (ps->border_position[env] > thr)
949
4.98k
            {
950
4.98k
                ps->border_position[env] = thr;
951
15.7k
            } else {
952
15.7k
                thr = ps->border_position[env-1]+1;
953
15.7k
                if (ps->border_position[env] < thr)
954
8.18k
                {
955
8.18k
                    ps->border_position[env] = thr;
956
8.18k
                }
957
15.7k
            }
958
20.7k
        }
959
7.99k
    }
960
961
    /* make sure that the indices of all parameters can be mapped
962
     * to the same hybrid synthesis filterbank
963
     */
964
#ifdef PS_LOW_POWER
965
    for (env = 0; env < ps->num_env; env++)
966
    {
967
        if (ps->iid_mode == 2 || ps->iid_mode == 5)
968
            map34indexto20(ps->iid_index[env], 34);
969
        if (ps->icc_mode == 2 || ps->icc_mode == 5)
970
            map34indexto20(ps->icc_index[env], 34);
971
972
        /* disable ipd/opd */
973
        for (bin = 0; bin < 17; bin++)
974
        {
975
            ps->aaIpdIndex[env][bin] = 0;
976
            ps->aaOpdIndex[env][bin] = 0;
977
        }
978
    }
979
#else
980
18.3k
    if (ps->use34hybrid_bands)
981
6.31k
    {
982
18.8k
        for (env = 0; env < ps->num_env; env++)
983
12.5k
        {
984
12.5k
            if (ps->iid_mode != 2 && ps->iid_mode != 5)
985
7.97k
                map20indexto34(ps->iid_index[env], 34);
986
12.5k
            if (ps->icc_mode != 2 && ps->icc_mode != 5)
987
4.26k
                map20indexto34(ps->icc_index[env], 34);
988
12.5k
            if (ps->ipd_mode != 2 && ps->ipd_mode != 5)
989
7.97k
            {
990
7.97k
                map20indexto34(ps->ipd_index[env], 17);
991
7.97k
                map20indexto34(ps->opd_index[env], 17);
992
7.97k
            }
993
12.5k
        }
994
6.31k
    }
995
18.3k
#endif
996
997
#if 0
998
    for (env = 0; env < ps->num_env; env++)
999
    {
1000
        printf("iid[env:%d]:", env);
1001
        for (bin = 0; bin < 34; bin++)
1002
        {
1003
            printf(" %d", ps->iid_index[env][bin]);
1004
        }
1005
        printf("\n");
1006
    }
1007
    for (env = 0; env < ps->num_env; env++)
1008
    {
1009
        printf("icc[env:%d]:", env);
1010
        for (bin = 0; bin < 34; bin++)
1011
        {
1012
            printf(" %d", ps->icc_index[env][bin]);
1013
        }
1014
        printf("\n");
1015
    }
1016
    for (env = 0; env < ps->num_env; env++)
1017
    {
1018
        printf("ipd[env:%d]:", env);
1019
        for (bin = 0; bin < 17; bin++)
1020
        {
1021
            printf(" %d", ps->ipd_index[env][bin]);
1022
        }
1023
        printf("\n");
1024
    }
1025
    for (env = 0; env < ps->num_env; env++)
1026
    {
1027
        printf("opd[env:%d]:", env);
1028
        for (bin = 0; bin < 17; bin++)
1029
        {
1030
            printf(" %d", ps->opd_index[env][bin]);
1031
        }
1032
        printf("\n");
1033
    }
1034
    printf("\n");
1035
#endif
1036
18.3k
}
1037
1038
/* decorrelate the mono signal using an allpass filter */
1039
static void ps_decorrelate(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
1040
                           qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32])
1041
18.3k
{
1042
18.3k
    uint8_t gr, n, bk;
1043
18.3k
    uint8_t temp_delay = 0;
1044
18.3k
    uint8_t sb, maxsb;
1045
18.3k
    const complex_t *Phi_Fract_SubQmf;
1046
18.3k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
18.3k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
18.3k
    real_t P[32][34];
1049
18.3k
    real_t G_TransientRatio[32][34] = {{0}};
1050
18.3k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
18.3k
    if (ps->use34hybrid_bands)
1055
6.31k
    {
1056
6.31k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
12.0k
    } else{
1058
12.0k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
12.0k
    }
1060
1061
    /* clear the energy values */
1062
605k
    for (n = 0; n < 32; n++)
1063
587k
    {
1064
20.5M
        for (bk = 0; bk < 34; bk++)
1065
19.9M
        {
1066
19.9M
            P[n][bk] = 0;
1067
19.9M
        }
1068
587k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
599k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
580k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
580k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
580k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
2.01M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
1.42M
        {
1081
46.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
44.6M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
44.6M
                if (gr < ps->num_hybrid_groups)
1089
10.0M
                {
1090
10.0M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
10.0M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
34.6M
                } else {
1093
34.6M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
34.6M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
34.6M
                }
1096
1097
                /* accumulate energy */
1098
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
18.4M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
18.4M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
26.1M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
44.6M
            }
1109
1.42M
        }
1110
580k
    }
1111
1112
#if 0
1113
    for (n = 0; n < 32; n++)
1114
    {
1115
        for (bk = 0; bk < 34; bk++)
1116
        {
1117
#ifdef FIXED_POINT
1118
            printf("%d %d: %d\n", n, bk, P[n][bk] /*/(float)REAL_PRECISION*/);
1119
#else
1120
            printf("%d %d: %f\n", n, bk, P[n][bk]/1024.0);
1121
#endif
1122
        }
1123
    }
1124
#endif
1125
1126
    /* calculate transient reduction ratio for each parameter band b(k) */
1127
473k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
455k
    {
1129
14.6M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
14.2M
        {
1131
14.2M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
14.2M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
14.2M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
145k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
14.2M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
14.2M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
14.2M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
14.2M
            nrg = ps->P_prev[bk];
1144
14.2M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
14.2M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
14.2M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
14.0M
            {
1150
14.0M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
14.0M
            } else {
1152
134k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
134k
            }
1154
14.2M
        }
1155
455k
    }
1156
1157
#if 0
1158
    for (n = 0; n < 32; n++)
1159
    {
1160
        for (bk = 0; bk < 34; bk++)
1161
        {
1162
#ifdef FIXED_POINT
1163
            printf("%d %d: %f\n", n, bk, G_TransientRatio[n][bk]/(float)REAL_PRECISION);
1164
#else
1165
            printf("%d %d: %f\n", n, bk, G_TransientRatio[n][bk]);
1166
#endif
1167
        }
1168
    }
1169
#endif
1170
1171
    /* apply stereo decorrelation filter to the signal */
1172
599k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
580k
    {
1174
580k
        if (gr < ps->num_hybrid_groups)
1175
322k
            maxsb = ps->group_border[gr] + 1;
1176
258k
        else
1177
258k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
2.01M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
1.42M
        {
1182
1.42M
            real_t g_DecaySlope;
1183
1.42M
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
1.42M
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
340k
            {
1188
340k
                g_DecaySlope = FRAC_CONST(1.0);
1189
1.08M
            } else {
1190
1.08M
                int8_t decay = ps->decay_cutoff - sb;
1191
1.08M
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
740k
                {
1193
740k
                    g_DecaySlope = 0;
1194
740k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
348k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
348k
                }
1198
1.08M
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
5.71M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
4.28M
            {
1203
4.28M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
4.28M
            }
1205
1206
1207
            /* set delay indices */
1208
1.42M
            temp_delay = ps->saved_delay;
1209
5.71M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
4.28M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
46.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
44.6M
            {
1214
44.6M
                complex_t tmp, tmp0, R0;
1215
44.6M
                uint8_t m;
1216
1217
44.6M
                if (gr < ps->num_hybrid_groups)
1218
10.0M
                {
1219
                    /* hybrid filterbank input */
1220
10.0M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
10.0M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
34.6M
                } else {
1223
                    /* QMF filterbank input */
1224
34.6M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
34.6M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
34.6M
                }
1227
1228
44.6M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
23.5M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
23.5M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
23.5M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
23.5M
                    RE(R0) = RE(tmp);
1236
23.5M
                    IM(R0) = IM(tmp);
1237
23.5M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
23.5M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
23.5M
                } else {
1240
                    /* allpass filter */
1241
21.1M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
21.1M
                    if (gr < ps->num_hybrid_groups)
1245
10.0M
                    {
1246
                        /* select data from the hybrid subbands */
1247
10.0M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
10.0M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
10.0M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
10.0M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
10.0M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
10.0M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
11.0M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
11.0M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
11.0M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
11.0M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
11.0M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
11.0M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
11.0M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
11.0M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
21.1M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
21.1M
                    RE(R0) = RE(tmp);
1271
21.1M
                    IM(R0) = IM(tmp);
1272
84.4M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
63.3M
                    {
1274
63.3M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
63.3M
                        if (gr < ps->num_hybrid_groups)
1278
30.0M
                        {
1279
                            /* select data from the hybrid subbands */
1280
30.0M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
30.0M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
30.0M
                            if (ps->use34hybrid_bands)
1284
18.6M
                            {
1285
18.6M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
18.6M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
18.6M
                            } else {
1288
11.3M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
11.3M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
11.3M
                            }
1291
33.2M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
33.2M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
33.2M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
33.2M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
33.2M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
33.2M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
63.3M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
63.3M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
63.3M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
63.3M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
63.3M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
63.3M
                        if (gr < ps->num_hybrid_groups)
1314
30.0M
                        {
1315
30.0M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
30.0M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
33.2M
                        } else {
1318
33.2M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
33.2M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
33.2M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
63.3M
                        RE(R0) = RE(tmp);
1324
63.3M
                        IM(R0) = IM(tmp);
1325
63.3M
                    }
1326
21.1M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
44.6M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
44.6M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
44.6M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
44.6M
                if (gr < ps->num_hybrid_groups)
1336
10.0M
                {
1337
                    /* hybrid */
1338
10.0M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
10.0M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
34.6M
                } else {
1341
                    /* QMF */
1342
34.6M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
34.6M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
34.6M
                }
1345
1346
                /* Update delay buffer index */
1347
44.6M
                if (++temp_delay >= 2)
1348
22.2M
                {
1349
22.2M
                    temp_delay = 0;
1350
22.2M
                }
1351
1352
                /* update delay indices */
1353
44.6M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
23.5M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
23.5M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
17.0M
                    {
1358
17.0M
                        ps->delay_buf_index_delay[sb] = 0;
1359
17.0M
                    }
1360
23.5M
                }
1361
1362
178M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
133M
                {
1364
133M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
34.2M
                    {
1366
34.2M
                        temp_delay_ser[m] = 0;
1367
34.2M
                    }
1368
133M
                }
1369
44.6M
            }
1370
1.42M
        }
1371
580k
    }
1372
1373
    /* update delay indices */
1374
18.3k
    ps->saved_delay = temp_delay;
1375
73.4k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
55.0k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
18.3k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
7.61k
{
1042
7.61k
    uint8_t gr, n, bk;
1043
7.61k
    uint8_t temp_delay = 0;
1044
7.61k
    uint8_t sb, maxsb;
1045
7.61k
    const complex_t *Phi_Fract_SubQmf;
1046
7.61k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
7.61k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
7.61k
    real_t P[32][34];
1049
7.61k
    real_t G_TransientRatio[32][34] = {{0}};
1050
7.61k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
7.61k
    if (ps->use34hybrid_bands)
1055
2.45k
    {
1056
2.45k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
5.15k
    } else{
1058
5.15k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
5.15k
    }
1060
1061
    /* clear the energy values */
1062
251k
    for (n = 0; n < 32; n++)
1063
243k
    {
1064
8.52M
        for (bk = 0; bk < 34; bk++)
1065
8.28M
        {
1066
8.28M
            P[n][bk] = 0;
1067
8.28M
        }
1068
243k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
243k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
236k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
236k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
236k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
825k
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
589k
        {
1081
19.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
18.4M
            {
1083
18.4M
#ifdef FIXED_POINT
1084
18.4M
                uint32_t in_re, in_im;
1085
18.4M
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
18.4M
                if (gr < ps->num_hybrid_groups)
1089
4.05M
                {
1090
4.05M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
4.05M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
14.3M
                } else {
1093
14.3M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
14.3M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
14.3M
                }
1096
1097
                /* accumulate energy */
1098
18.4M
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
18.4M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
18.4M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
18.4M
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
18.4M
            }
1109
589k
        }
1110
236k
    }
1111
1112
#if 0
1113
    for (n = 0; n < 32; n++)
1114
    {
1115
        for (bk = 0; bk < 34; bk++)
1116
        {
1117
#ifdef FIXED_POINT
1118
            printf("%d %d: %d\n", n, bk, P[n][bk] /*/(float)REAL_PRECISION*/);
1119
#else
1120
            printf("%d %d: %f\n", n, bk, P[n][bk]/1024.0);
1121
#endif
1122
        }
1123
    }
1124
#endif
1125
1126
    /* calculate transient reduction ratio for each parameter band b(k) */
1127
194k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
186k
    {
1129
6.01M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
5.83M
        {
1131
5.83M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
5.83M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
5.83M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
15.2k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
5.83M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
5.83M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
5.83M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
5.83M
            nrg = ps->P_prev[bk];
1144
5.83M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
5.83M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
5.83M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
5.82M
            {
1150
5.82M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
5.82M
            } else {
1152
8.09k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
8.09k
            }
1154
5.83M
        }
1155
186k
    }
1156
1157
#if 0
1158
    for (n = 0; n < 32; n++)
1159
    {
1160
        for (bk = 0; bk < 34; bk++)
1161
        {
1162
#ifdef FIXED_POINT
1163
            printf("%d %d: %f\n", n, bk, G_TransientRatio[n][bk]/(float)REAL_PRECISION);
1164
#else
1165
            printf("%d %d: %f\n", n, bk, G_TransientRatio[n][bk]);
1166
#endif
1167
        }
1168
    }
1169
#endif
1170
1171
    /* apply stereo decorrelation filter to the signal */
1172
243k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
236k
    {
1174
236k
        if (gr < ps->num_hybrid_groups)
1175
130k
            maxsb = ps->group_border[gr] + 1;
1176
106k
        else
1177
106k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
825k
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
589k
        {
1182
589k
            real_t g_DecaySlope;
1183
589k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
589k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
137k
            {
1188
137k
                g_DecaySlope = FRAC_CONST(1.0);
1189
451k
            } else {
1190
451k
                int8_t decay = ps->decay_cutoff - sb;
1191
451k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
307k
                {
1193
307k
                    g_DecaySlope = 0;
1194
307k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
144k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
144k
                }
1198
451k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
2.35M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
1.76M
            {
1203
1.76M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
1.76M
            }
1205
1206
1207
            /* set delay indices */
1208
589k
            temp_delay = ps->saved_delay;
1209
2.35M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
1.76M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
19.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
18.4M
            {
1214
18.4M
                complex_t tmp, tmp0, R0;
1215
18.4M
                uint8_t m;
1216
1217
18.4M
                if (gr < ps->num_hybrid_groups)
1218
4.05M
                {
1219
                    /* hybrid filterbank input */
1220
4.05M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
4.05M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
14.3M
                } else {
1223
                    /* QMF filterbank input */
1224
14.3M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
14.3M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
14.3M
                }
1227
1228
18.4M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
9.77M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
9.77M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
9.77M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
9.77M
                    RE(R0) = RE(tmp);
1236
9.77M
                    IM(R0) = IM(tmp);
1237
9.77M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
9.77M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
9.77M
                } else {
1240
                    /* allpass filter */
1241
8.67M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
8.67M
                    if (gr < ps->num_hybrid_groups)
1245
4.05M
                    {
1246
                        /* select data from the hybrid subbands */
1247
4.05M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
4.05M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
4.05M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
4.05M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
4.05M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
4.05M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
4.61M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
4.61M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
4.61M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
4.61M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
4.61M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
4.61M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
4.61M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
4.61M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
8.67M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
8.67M
                    RE(R0) = RE(tmp);
1271
8.67M
                    IM(R0) = IM(tmp);
1272
34.6M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
26.0M
                    {
1274
26.0M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
26.0M
                        if (gr < ps->num_hybrid_groups)
1278
12.1M
                        {
1279
                            /* select data from the hybrid subbands */
1280
12.1M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
12.1M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
12.1M
                            if (ps->use34hybrid_bands)
1284
7.30M
                            {
1285
7.30M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
7.30M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
7.30M
                            } else {
1288
4.86M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
4.86M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
4.86M
                            }
1291
13.8M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
13.8M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
13.8M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
13.8M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
13.8M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
13.8M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
26.0M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
26.0M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
26.0M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
26.0M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
26.0M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
26.0M
                        if (gr < ps->num_hybrid_groups)
1314
12.1M
                        {
1315
12.1M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
12.1M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
13.8M
                        } else {
1318
13.8M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
13.8M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
13.8M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
26.0M
                        RE(R0) = RE(tmp);
1324
26.0M
                        IM(R0) = IM(tmp);
1325
26.0M
                    }
1326
8.67M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
18.4M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
18.4M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
18.4M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
18.4M
                if (gr < ps->num_hybrid_groups)
1336
4.05M
                {
1337
                    /* hybrid */
1338
4.05M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
4.05M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
14.3M
                } else {
1341
                    /* QMF */
1342
14.3M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
14.3M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
14.3M
                }
1345
1346
                /* Update delay buffer index */
1347
18.4M
                if (++temp_delay >= 2)
1348
9.20M
                {
1349
9.20M
                    temp_delay = 0;
1350
9.20M
                }
1351
1352
                /* update delay indices */
1353
18.4M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
9.77M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
9.77M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
7.09M
                    {
1358
7.09M
                        ps->delay_buf_index_delay[sb] = 0;
1359
7.09M
                    }
1360
9.77M
                }
1361
1362
73.7M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
55.3M
                {
1364
55.3M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
14.0M
                    {
1366
14.0M
                        temp_delay_ser[m] = 0;
1367
14.0M
                    }
1368
55.3M
                }
1369
18.4M
            }
1370
589k
        }
1371
236k
    }
1372
1373
    /* update delay indices */
1374
7.61k
    ps->saved_delay = temp_delay;
1375
30.4k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
22.8k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
7.61k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
10.7k
{
1042
10.7k
    uint8_t gr, n, bk;
1043
10.7k
    uint8_t temp_delay = 0;
1044
10.7k
    uint8_t sb, maxsb;
1045
10.7k
    const complex_t *Phi_Fract_SubQmf;
1046
10.7k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
10.7k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
10.7k
    real_t P[32][34];
1049
10.7k
    real_t G_TransientRatio[32][34] = {{0}};
1050
10.7k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
10.7k
    if (ps->use34hybrid_bands)
1055
3.85k
    {
1056
3.85k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
6.89k
    } else{
1058
6.89k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
6.89k
    }
1060
1061
    /* clear the energy values */
1062
354k
    for (n = 0; n < 32; n++)
1063
343k
    {
1064
12.0M
        for (bk = 0; bk < 34; bk++)
1065
11.6M
        {
1066
11.6M
            P[n][bk] = 0;
1067
11.6M
        }
1068
343k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
355k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
344k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
344k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
344k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
1.18M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
840k
        {
1081
27.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
26.1M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
26.1M
                if (gr < ps->num_hybrid_groups)
1089
5.96M
                {
1090
5.96M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
5.96M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
20.2M
                } else {
1093
20.2M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
20.2M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
20.2M
                }
1096
1097
                /* accumulate energy */
1098
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
26.1M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
26.1M
#endif
1108
26.1M
            }
1109
840k
        }
1110
344k
    }
1111
1112
#if 0
1113
    for (n = 0; n < 32; n++)
1114
    {
1115
        for (bk = 0; bk < 34; bk++)
1116
        {
1117
#ifdef FIXED_POINT
1118
            printf("%d %d: %d\n", n, bk, P[n][bk] /*/(float)REAL_PRECISION*/);
1119
#else
1120
            printf("%d %d: %f\n", n, bk, P[n][bk]/1024.0);
1121
#endif
1122
        }
1123
    }
1124
#endif
1125
1126
    /* calculate transient reduction ratio for each parameter band b(k) */
1127
279k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
268k
    {
1129
8.63M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
8.36M
        {
1131
8.36M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
8.36M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
8.36M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
130k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
8.36M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
8.36M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
8.36M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
8.36M
            nrg = ps->P_prev[bk];
1144
8.36M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
8.36M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
8.36M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
8.24M
            {
1150
8.24M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
8.24M
            } else {
1152
126k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
126k
            }
1154
8.36M
        }
1155
268k
    }
1156
1157
#if 0
1158
    for (n = 0; n < 32; n++)
1159
    {
1160
        for (bk = 0; bk < 34; bk++)
1161
        {
1162
#ifdef FIXED_POINT
1163
            printf("%d %d: %f\n", n, bk, G_TransientRatio[n][bk]/(float)REAL_PRECISION);
1164
#else
1165
            printf("%d %d: %f\n", n, bk, G_TransientRatio[n][bk]);
1166
#endif
1167
        }
1168
    }
1169
#endif
1170
1171
    /* apply stereo decorrelation filter to the signal */
1172
355k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
344k
    {
1174
344k
        if (gr < ps->num_hybrid_groups)
1175
192k
            maxsb = ps->group_border[gr] + 1;
1176
152k
        else
1177
152k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
1.18M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
840k
        {
1182
840k
            real_t g_DecaySlope;
1183
840k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
840k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
203k
            {
1188
203k
                g_DecaySlope = FRAC_CONST(1.0);
1189
637k
            } else {
1190
637k
                int8_t decay = ps->decay_cutoff - sb;
1191
637k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
432k
                {
1193
432k
                    g_DecaySlope = 0;
1194
432k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
204k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
204k
                }
1198
637k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
3.36M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.52M
            {
1203
2.52M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.52M
            }
1205
1206
1207
            /* set delay indices */
1208
840k
            temp_delay = ps->saved_delay;
1209
3.36M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.52M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
27.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
26.1M
            {
1214
26.1M
                complex_t tmp, tmp0, R0;
1215
26.1M
                uint8_t m;
1216
1217
26.1M
                if (gr < ps->num_hybrid_groups)
1218
5.96M
                {
1219
                    /* hybrid filterbank input */
1220
5.96M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
5.96M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
20.2M
                } else {
1223
                    /* QMF filterbank input */
1224
20.2M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
20.2M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
20.2M
                }
1227
1228
26.1M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
13.7M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
13.7M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
13.7M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
13.7M
                    RE(R0) = RE(tmp);
1236
13.7M
                    IM(R0) = IM(tmp);
1237
13.7M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
13.7M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
13.7M
                } else {
1240
                    /* allpass filter */
1241
12.4M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
12.4M
                    if (gr < ps->num_hybrid_groups)
1245
5.96M
                    {
1246
                        /* select data from the hybrid subbands */
1247
5.96M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
5.96M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
5.96M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
5.96M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
5.96M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
5.96M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
6.47M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
6.47M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
6.47M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
6.47M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
6.47M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
6.47M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
6.47M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
6.47M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
12.4M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
12.4M
                    RE(R0) = RE(tmp);
1271
12.4M
                    IM(R0) = IM(tmp);
1272
49.7M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
37.3M
                    {
1274
37.3M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
37.3M
                        if (gr < ps->num_hybrid_groups)
1278
17.8M
                        {
1279
                            /* select data from the hybrid subbands */
1280
17.8M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
17.8M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
17.8M
                            if (ps->use34hybrid_bands)
1284
11.3M
                            {
1285
11.3M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
11.3M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
11.3M
                            } else {
1288
6.50M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
6.50M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
6.50M
                            }
1291
19.4M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
19.4M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
19.4M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
19.4M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
19.4M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
19.4M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
37.3M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
37.3M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
37.3M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
37.3M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
37.3M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
37.3M
                        if (gr < ps->num_hybrid_groups)
1314
17.8M
                        {
1315
17.8M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
17.8M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
19.4M
                        } else {
1318
19.4M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
19.4M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
19.4M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
37.3M
                        RE(R0) = RE(tmp);
1324
37.3M
                        IM(R0) = IM(tmp);
1325
37.3M
                    }
1326
12.4M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
26.1M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
26.1M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
26.1M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
26.1M
                if (gr < ps->num_hybrid_groups)
1336
5.96M
                {
1337
                    /* hybrid */
1338
5.96M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
5.96M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
20.2M
                } else {
1341
                    /* QMF */
1342
20.2M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
20.2M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
20.2M
                }
1345
1346
                /* Update delay buffer index */
1347
26.1M
                if (++temp_delay >= 2)
1348
13.0M
                {
1349
13.0M
                    temp_delay = 0;
1350
13.0M
                }
1351
1352
                /* update delay indices */
1353
26.1M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
13.7M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
13.7M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
9.98M
                    {
1358
9.98M
                        ps->delay_buf_index_delay[sb] = 0;
1359
9.98M
                    }
1360
13.7M
                }
1361
1362
104M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
78.5M
                {
1364
78.5M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
20.1M
                    {
1366
20.1M
                        temp_delay_ser[m] = 0;
1367
20.1M
                    }
1368
78.5M
                }
1369
26.1M
            }
1370
840k
        }
1371
344k
    }
1372
1373
    /* update delay indices */
1374
10.7k
    ps->saved_delay = temp_delay;
1375
42.9k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
32.2k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
10.7k
}
1378
1379
#if 0
1380
#ifdef FIXED_POINT
1381
#define step(shift) \
1382
    if ((0x40000000l >> shift) + root <= value)       \
1383
    {                                                 \
1384
        value -= (0x40000000l >> shift) + root;       \
1385
        root = (root >> 1) | (0x40000000l >> shift);  \
1386
    } else {                                          \
1387
        root = root >> 1;                             \
1388
    }
1389
1390
/* fixed point square root approximation */
1391
static real_t ps_sqrt(real_t value)
1392
{
1393
    real_t root = 0;
1394
1395
    step( 0); step( 2); step( 4); step( 6);
1396
    step( 8); step(10); step(12); step(14);
1397
    step(16); step(18); step(20); step(22);
1398
    step(24); step(26); step(28); step(30);
1399
1400
    if (root < value)
1401
        ++root;
1402
1403
    root <<= (REAL_BITS/2);
1404
1405
    return root;
1406
}
1407
#else
1408
#define ps_sqrt(A) sqrt(A)
1409
#endif
1410
#endif
1411
1412
static const real_t ipdopd_cos_tab[] = {
1413
    FRAC_CONST(1.000000000000000),
1414
    FRAC_CONST(0.707106781186548),
1415
    FRAC_CONST(0.000000000000000),
1416
    FRAC_CONST(-0.707106781186547),
1417
    FRAC_CONST(-1.000000000000000),
1418
    FRAC_CONST(-0.707106781186548),
1419
    FRAC_CONST(-0.000000000000000),
1420
    FRAC_CONST(0.707106781186547),
1421
    FRAC_CONST(1.000000000000000)
1422
};
1423
1424
static const real_t ipdopd_sin_tab[] = {
1425
    FRAC_CONST(0.000000000000000),
1426
    FRAC_CONST(0.707106781186547),
1427
    FRAC_CONST(1.000000000000000),
1428
    FRAC_CONST(0.707106781186548),
1429
    FRAC_CONST(0.000000000000000),
1430
    FRAC_CONST(-0.707106781186547),
1431
    FRAC_CONST(-1.000000000000000),
1432
    FRAC_CONST(-0.707106781186548),
1433
    FRAC_CONST(-0.000000000000000)
1434
};
1435
1436
static real_t magnitude_c(complex_t c)
1437
392k
{
1438
#ifdef FIXED_POINT
1439
443k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
#define ALPHA FRAC_CONST(0.948059448969)
1441
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
221k
    real_t abs_inphase = ps_abs(RE(c));
1444
221k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
221k
    if (abs_inphase > abs_quadrature) {
1447
188k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
188k
    } else {
1449
33.6k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
33.6k
    }
1451
#else
1452
170k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
392k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
221k
{
1438
221k
#ifdef FIXED_POINT
1439
221k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
221k
#define ALPHA FRAC_CONST(0.948059448969)
1441
221k
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
221k
    real_t abs_inphase = ps_abs(RE(c));
1444
221k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
221k
    if (abs_inphase > abs_quadrature) {
1447
188k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
188k
    } else {
1449
33.6k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
33.6k
    }
1451
#else
1452
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
221k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
170k
{
1438
#ifdef FIXED_POINT
1439
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
#define ALPHA FRAC_CONST(0.948059448969)
1441
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
    real_t abs_inphase = ps_abs(RE(c));
1444
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
    if (abs_inphase > abs_quadrature) {
1447
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
    } else {
1449
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
    }
1451
#else
1452
170k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
170k
#endif
1454
170k
}
1455
1456
static void ps_mix_phase(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
1457
                         qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32])
1458
18.3k
{
1459
18.3k
    uint8_t n;
1460
18.3k
    uint8_t gr;
1461
18.3k
    uint8_t bk = 0;
1462
18.3k
    uint8_t sb, maxsb;
1463
18.3k
    uint8_t env;
1464
18.3k
    uint8_t nr_ipdopd_par;
1465
18.3k
    complex_t h11, h12, h21, h22;  // COEF
1466
18.3k
    complex_t H11, H12, H21, H22;  // COEF
1467
18.3k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
18.3k
    complex_t tempLeft, tempRight; // FRAC
1469
18.3k
    complex_t phaseLeft, phaseRight; // FRAC
1470
18.3k
    real_t L;
1471
18.3k
    const real_t *sf_iid;
1472
18.3k
    uint8_t no_iid_steps;
1473
1474
18.3k
    if (ps->iid_mode >= 3)
1475
7.44k
    {
1476
7.44k
        no_iid_steps = 15;
1477
7.44k
        sf_iid = sf_iid_fine;
1478
10.9k
    } else {
1479
10.9k
        no_iid_steps = 7;
1480
10.9k
        sf_iid = sf_iid_normal;
1481
10.9k
    }
1482
1483
18.3k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
11.4k
    {
1485
11.4k
        nr_ipdopd_par = 11; /* resolution */
1486
11.4k
    } else {
1487
6.91k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
6.91k
    }
1489
1490
599k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
580k
    {
1492
580k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
580k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
2.00M
        for (env = 0; env < ps->num_env; env++)
1498
1.41M
        {
1499
1.41M
            uint8_t abs_iid = (uint8_t)abs(ps->iid_index[env][bk]);
1500
            /* index range is supposed to be -7...7 or -15...15 depending on iid_mode
1501
                (Table 8.24, ISO/IEC 14496-3:2005).
1502
                if it is outside these boundaries, this is most likely an error. sanitize
1503
                it and try to process further. */
1504
1.41M
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
340
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
340
                    -no_iid_steps);
1507
340
                ps->iid_index[env][bk] = -no_iid_steps;
1508
340
                abs_iid = no_iid_steps;
1509
1.41M
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
209
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
209
                    no_iid_steps);
1512
209
                ps->iid_index[env][bk] = no_iid_steps;
1513
209
                abs_iid = no_iid_steps;
1514
209
            }
1515
1.41M
            if (ps->icc_index[env][bk] < 0) {
1516
333
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
333
                ps->icc_index[env][bk] = 0;
1518
1.41M
            } else if (ps->icc_index[env][bk] > 7) {
1519
0
                fprintf(stderr, "Warning: invalid icc_index: %d > 7\n", ps->icc_index[env][bk]);
1520
0
                ps->icc_index[env][bk] = 7;
1521
0
            }
1522
1523
1.41M
            if (ps->icc_mode < 3)
1524
833k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
833k
                real_t c_1, c_2;  // COEF
1527
833k
                real_t cosa, sina;  // COEF
1528
833k
                real_t cosb, sinb;  // COEF
1529
833k
                real_t ab1, ab2;  // COEF
1530
833k
                real_t ab3, ab4;  // COEF
1531
1532
                /*
1533
                c_1 = sqrt(2.0 / (1.0 + pow(10.0, quant_iid[no_iid_steps + iid_index] / 10.0)));
1534
                c_2 = sqrt(2.0 / (1.0 + pow(10.0, quant_iid[no_iid_steps - iid_index] / 10.0)));
1535
                alpha = 0.5 * acos(quant_rho[icc_index]);
1536
                beta = alpha * ( c_1 - c_2 ) / sqrt(2.0);
1537
                */
1538
1539
                //printf("%d\n", ps->iid_index[env][bk]);
1540
1541
                /* calculate the scalefactors c_1 and c_2 from the intensity differences */
1542
833k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
833k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
833k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
833k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
833k
                if (ps->iid_mode >= 3)
1550
291k
                {
1551
291k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
291k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
541k
                } else {
1554
541k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
541k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
541k
                }
1557
1558
833k
                ab1 = MUL_C(cosb, cosa);
1559
833k
                ab2 = MUL_C(sinb, sina);
1560
833k
                ab3 = MUL_C(sinb, cosa);
1561
833k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
833k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
833k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
833k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
833k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
833k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
586k
                real_t sina, cosa;  // COEF
1571
586k
                real_t cosg, sing;  // COEF
1572
1573
                /*
1574
                real_t c, rho, mu, alpha, gamma;
1575
                uint8_t i;
1576
1577
                i = ps->iid_index[env][bk];
1578
                c = (real_t)pow(10.0, ((i)?(((i>0)?1:-1)*quant_iid[((i>0)?i:-i)-1]):0.)/20.0);
1579
                rho = quant_rho[ps->icc_index[env][bk]];
1580
1581
                if (rho == 0.0f && c == 1.)
1582
                {
1583
                    alpha = (real_t)M_PI/4.0f;
1584
                    rho = 0.05f;
1585
                } else {
1586
                    if (rho <= 0.05f)
1587
                    {
1588
                        rho = 0.05f;
1589
                    }
1590
                    alpha = 0.5f*(real_t)atan( (2.0f*c*rho) / (c*c-1.0f) );
1591
1592
                    if (alpha < 0.)
1593
                    {
1594
                        alpha += (real_t)M_PI/2.0f;
1595
                    }
1596
                    if (rho < 0.)
1597
                    {
1598
                        alpha += (real_t)M_PI;
1599
                    }
1600
                }
1601
                mu = c+1.0f/c;
1602
                mu = 1+(4.0f*rho*rho-4.0f)/(mu*mu);
1603
                gamma = (real_t)atan(sqrt((1.0f-sqrt(mu))/(1.0f+sqrt(mu))));
1604
                */
1605
1606
586k
                if (ps->iid_mode >= 3)
1607
361k
                {
1608
361k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
361k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
361k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
361k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
361k
                } else {
1613
224k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
224k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
224k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
224k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
224k
                }
1618
1619
586k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
586k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
586k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
586k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
586k
            }
1624
1.41M
            IM(h11) = IM(h12) = IM(h21) = IM(h22) = 0;
1625
1626
            /* calculate phase rotation parameters H_xy */
1627
            /* note that the imaginary part of these parameters are only calculated when
1628
               IPD and OPD are enabled
1629
             */
1630
1.41M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
196k
            {
1632
196k
                int8_t i;
1633
196k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
196k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
#ifdef FIXED_POINT
1640
                /* divide by 4*2, shift right 3 bits;
1641
                   extra halving to avoid overflows; it is ok, because result is normalized */
1642
110k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
110k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
110k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
110k
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
85.2k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
85.2k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
85.2k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
85.2k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
#endif
1652
1653
                /* save current value */
1654
196k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
196k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
196k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
196k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
110k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
110k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
110k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
110k
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
85.2k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
85.2k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
85.2k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
85.2k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
#endif
1672
1673
                /* ringbuffer index */
1674
196k
                if (i == 0)
1675
99.0k
                {
1676
99.0k
                    i = 2;
1677
99.0k
                }
1678
196k
                i--;
1679
1680
                /* get value before previous */
1681
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
110k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
110k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
110k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
110k
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
85.2k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
85.2k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
85.2k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
85.2k
                IM(tempRight) += MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1692
#endif
1693
1694
#if 0 /* original code */
1695
                ipd = (float)atan2(IM(tempLeft), RE(tempLeft));
1696
                opd = (float)atan2(IM(tempRight), RE(tempRight));
1697
1698
                /* phase rotation */
1699
                RE(phaseLeft) = (float)cos(opd);
1700
                IM(phaseLeft) = (float)sin(opd);
1701
                opd -= ipd;
1702
                RE(phaseRight) = (float)cos(opd);
1703
                IM(phaseRight) = (float)sin(opd);
1704
#else
1705
1706
                // x = IM(tempLeft)
1707
                // y = RE(tempLeft)
1708
                // p = IM(tempRight)
1709
                // q = RE(tempRight)
1710
                // cos(atan2(x,y)) = y/sqrt((x*x) + (y*y))
1711
                // sin(atan2(x,y)) = x/sqrt((x*x) + (y*y))
1712
                // cos(atan2(x,y)-atan2(p,q)) = (y*q + x*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1713
                // sin(atan2(x,y)-atan2(p,q)) = (x*q - y*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1714
1715
196k
                xy = magnitude_c(tempRight);
1716
196k
                pq = magnitude_c(tempLeft);
1717
1718
196k
                if (xy != 0)
1719
196k
                {
1720
196k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
196k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
196k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
196k
                xypq = MUL_F(xy, pq);
1728
1729
196k
                if (xypq != 0)
1730
196k
                {
1731
196k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
196k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
196k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
196k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
196k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
196k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
196k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
196k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
196k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
196k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
196k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
196k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
196k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
196k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
196k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
1.41M
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
1.41M
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
1.41M
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
1.41M
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
1.41M
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
1.41M
            RE(H11) = RE(ps->h11_prev[gr]);
1766
1.41M
            RE(H12) = RE(ps->h12_prev[gr]);
1767
1.41M
            RE(H21) = RE(ps->h21_prev[gr]);
1768
1.41M
            RE(H22) = RE(ps->h22_prev[gr]);
1769
1.41M
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
1.41M
            RE(ps->h11_prev[gr]) = RE(h11);
1772
1.41M
            RE(ps->h12_prev[gr]) = RE(h12);
1773
1.41M
            RE(ps->h21_prev[gr]) = RE(h21);
1774
1.41M
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
1.41M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
196k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
196k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
196k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
196k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
196k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
196k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
196k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
196k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
196k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
196k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
28.6k
                {
1792
28.6k
                    IM(deltaH11) = -IM(deltaH11);
1793
28.6k
                    IM(deltaH12) = -IM(deltaH12);
1794
28.6k
                    IM(deltaH21) = -IM(deltaH21);
1795
28.6k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
28.6k
                    IM(H11) = -IM(H11);
1798
28.6k
                    IM(H12) = -IM(H12);
1799
28.6k
                    IM(H21) = -IM(H21);
1800
28.6k
                    IM(H22) = -IM(H22);
1801
28.6k
                }
1802
1803
196k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
196k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
196k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
196k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
196k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
19.4M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
18.0M
            {
1812
                /* addition finalises the interpolation over every n */
1813
18.0M
                RE(H11) += RE(deltaH11);
1814
18.0M
                RE(H12) += RE(deltaH12);
1815
18.0M
                RE(H21) += RE(deltaH21);
1816
18.0M
                RE(H22) += RE(deltaH22);
1817
18.0M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
1.93M
                {
1819
1.93M
                    IM(H11) += IM(deltaH11);
1820
1.93M
                    IM(H12) += IM(deltaH12);
1821
1.93M
                    IM(H21) += IM(deltaH21);
1822
1.93M
                    IM(H22) += IM(deltaH22);
1823
1.93M
                }
1824
1825
                /* channel is an alias to the subband */
1826
62.7M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
44.6M
                {
1828
44.6M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
44.6M
                    if (gr < ps->num_hybrid_groups)
1832
10.0M
                    {
1833
10.0M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
10.0M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
10.0M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
10.0M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
34.6M
                    } else {
1838
34.6M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
34.6M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
34.6M
                        RE(inRight) = RE(X_right[n][sb]);
1841
34.6M
                        IM(inRight) = IM(X_right[n][sb]);
1842
34.6M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
44.6M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
44.6M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
44.6M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
44.6M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
44.6M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.93M
                    {
1855
                        /* apply rotation */
1856
1.93M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.93M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.93M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.93M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.93M
                    }
1861
1862
                    /* store final samples */
1863
44.6M
                    if (gr < ps->num_hybrid_groups)
1864
10.0M
                    {
1865
10.0M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
10.0M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
10.0M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
10.0M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
34.6M
                    } else {
1870
34.6M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
34.6M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
34.6M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
34.6M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
34.6M
                    }
1875
44.6M
                }
1876
18.0M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
1.41M
            ps->phase_hist++;
1880
1.41M
            if (ps->phase_hist == 2)
1881
709k
            {
1882
709k
                ps->phase_hist = 0;
1883
709k
            }
1884
1.41M
        }
1885
580k
    }
1886
18.3k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
7.61k
{
1459
7.61k
    uint8_t n;
1460
7.61k
    uint8_t gr;
1461
7.61k
    uint8_t bk = 0;
1462
7.61k
    uint8_t sb, maxsb;
1463
7.61k
    uint8_t env;
1464
7.61k
    uint8_t nr_ipdopd_par;
1465
7.61k
    complex_t h11, h12, h21, h22;  // COEF
1466
7.61k
    complex_t H11, H12, H21, H22;  // COEF
1467
7.61k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
7.61k
    complex_t tempLeft, tempRight; // FRAC
1469
7.61k
    complex_t phaseLeft, phaseRight; // FRAC
1470
7.61k
    real_t L;
1471
7.61k
    const real_t *sf_iid;
1472
7.61k
    uint8_t no_iid_steps;
1473
1474
7.61k
    if (ps->iid_mode >= 3)
1475
2.64k
    {
1476
2.64k
        no_iid_steps = 15;
1477
2.64k
        sf_iid = sf_iid_fine;
1478
4.97k
    } else {
1479
4.97k
        no_iid_steps = 7;
1480
4.97k
        sf_iid = sf_iid_normal;
1481
4.97k
    }
1482
1483
7.61k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
5.01k
    {
1485
5.01k
        nr_ipdopd_par = 11; /* resolution */
1486
5.01k
    } else {
1487
2.60k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
2.60k
    }
1489
1490
243k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
236k
    {
1492
236k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
236k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
857k
        for (env = 0; env < ps->num_env; env++)
1498
621k
        {
1499
621k
            uint8_t abs_iid = (uint8_t)abs(ps->iid_index[env][bk]);
1500
            /* index range is supposed to be -7...7 or -15...15 depending on iid_mode
1501
                (Table 8.24, ISO/IEC 14496-3:2005).
1502
                if it is outside these boundaries, this is most likely an error. sanitize
1503
                it and try to process further. */
1504
621k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
111
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
111
                    -no_iid_steps);
1507
111
                ps->iid_index[env][bk] = -no_iid_steps;
1508
111
                abs_iid = no_iid_steps;
1509
621k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
42
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
42
                    no_iid_steps);
1512
42
                ps->iid_index[env][bk] = no_iid_steps;
1513
42
                abs_iid = no_iid_steps;
1514
42
            }
1515
621k
            if (ps->icc_index[env][bk] < 0) {
1516
80
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
80
                ps->icc_index[env][bk] = 0;
1518
621k
            } else if (ps->icc_index[env][bk] > 7) {
1519
0
                fprintf(stderr, "Warning: invalid icc_index: %d > 7\n", ps->icc_index[env][bk]);
1520
0
                ps->icc_index[env][bk] = 7;
1521
0
            }
1522
1523
621k
            if (ps->icc_mode < 3)
1524
319k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
319k
                real_t c_1, c_2;  // COEF
1527
319k
                real_t cosa, sina;  // COEF
1528
319k
                real_t cosb, sinb;  // COEF
1529
319k
                real_t ab1, ab2;  // COEF
1530
319k
                real_t ab3, ab4;  // COEF
1531
1532
                /*
1533
                c_1 = sqrt(2.0 / (1.0 + pow(10.0, quant_iid[no_iid_steps + iid_index] / 10.0)));
1534
                c_2 = sqrt(2.0 / (1.0 + pow(10.0, quant_iid[no_iid_steps - iid_index] / 10.0)));
1535
                alpha = 0.5 * acos(quant_rho[icc_index]);
1536
                beta = alpha * ( c_1 - c_2 ) / sqrt(2.0);
1537
                */
1538
1539
                //printf("%d\n", ps->iid_index[env][bk]);
1540
1541
                /* calculate the scalefactors c_1 and c_2 from the intensity differences */
1542
319k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
319k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
319k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
319k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
319k
                if (ps->iid_mode >= 3)
1550
38.0k
                {
1551
38.0k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
38.0k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
281k
                } else {
1554
281k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
281k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
281k
                }
1557
1558
319k
                ab1 = MUL_C(cosb, cosa);
1559
319k
                ab2 = MUL_C(sinb, sina);
1560
319k
                ab3 = MUL_C(sinb, cosa);
1561
319k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
319k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
319k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
319k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
319k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
319k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
302k
                real_t sina, cosa;  // COEF
1571
302k
                real_t cosg, sing;  // COEF
1572
1573
                /*
1574
                real_t c, rho, mu, alpha, gamma;
1575
                uint8_t i;
1576
1577
                i = ps->iid_index[env][bk];
1578
                c = (real_t)pow(10.0, ((i)?(((i>0)?1:-1)*quant_iid[((i>0)?i:-i)-1]):0.)/20.0);
1579
                rho = quant_rho[ps->icc_index[env][bk]];
1580
1581
                if (rho == 0.0f && c == 1.)
1582
                {
1583
                    alpha = (real_t)M_PI/4.0f;
1584
                    rho = 0.05f;
1585
                } else {
1586
                    if (rho <= 0.05f)
1587
                    {
1588
                        rho = 0.05f;
1589
                    }
1590
                    alpha = 0.5f*(real_t)atan( (2.0f*c*rho) / (c*c-1.0f) );
1591
1592
                    if (alpha < 0.)
1593
                    {
1594
                        alpha += (real_t)M_PI/2.0f;
1595
                    }
1596
                    if (rho < 0.)
1597
                    {
1598
                        alpha += (real_t)M_PI;
1599
                    }
1600
                }
1601
                mu = c+1.0f/c;
1602
                mu = 1+(4.0f*rho*rho-4.0f)/(mu*mu);
1603
                gamma = (real_t)atan(sqrt((1.0f-sqrt(mu))/(1.0f+sqrt(mu))));
1604
                */
1605
1606
302k
                if (ps->iid_mode >= 3)
1607
213k
                {
1608
213k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
213k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
213k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
213k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
213k
                } else {
1613
88.6k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
88.6k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
88.6k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
88.6k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
88.6k
                }
1618
1619
302k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
302k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
302k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
302k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
302k
            }
1624
621k
            IM(h11) = IM(h12) = IM(h21) = IM(h22) = 0;
1625
1626
            /* calculate phase rotation parameters H_xy */
1627
            /* note that the imaginary part of these parameters are only calculated when
1628
               IPD and OPD are enabled
1629
             */
1630
621k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
110k
            {
1632
110k
                int8_t i;
1633
110k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
110k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
110k
#ifdef FIXED_POINT
1640
                /* divide by 4*2, shift right 3 bits;
1641
                   extra halving to avoid overflows; it is ok, because result is normalized */
1642
110k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
110k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
110k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
110k
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
#endif
1652
1653
                /* save current value */
1654
110k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
110k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
110k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
110k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
110k
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
110k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
110k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
110k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
110k
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
#endif
1672
1673
                /* ringbuffer index */
1674
110k
                if (i == 0)
1675
55.9k
                {
1676
55.9k
                    i = 2;
1677
55.9k
                }
1678
110k
                i--;
1679
1680
                /* get value before previous */
1681
110k
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
110k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
110k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
110k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
110k
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
                IM(tempRight) += MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1692
#endif
1693
1694
#if 0 /* original code */
1695
                ipd = (float)atan2(IM(tempLeft), RE(tempLeft));
1696
                opd = (float)atan2(IM(tempRight), RE(tempRight));
1697
1698
                /* phase rotation */
1699
                RE(phaseLeft) = (float)cos(opd);
1700
                IM(phaseLeft) = (float)sin(opd);
1701
                opd -= ipd;
1702
                RE(phaseRight) = (float)cos(opd);
1703
                IM(phaseRight) = (float)sin(opd);
1704
#else
1705
1706
                // x = IM(tempLeft)
1707
                // y = RE(tempLeft)
1708
                // p = IM(tempRight)
1709
                // q = RE(tempRight)
1710
                // cos(atan2(x,y)) = y/sqrt((x*x) + (y*y))
1711
                // sin(atan2(x,y)) = x/sqrt((x*x) + (y*y))
1712
                // cos(atan2(x,y)-atan2(p,q)) = (y*q + x*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1713
                // sin(atan2(x,y)-atan2(p,q)) = (x*q - y*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1714
1715
110k
                xy = magnitude_c(tempRight);
1716
110k
                pq = magnitude_c(tempLeft);
1717
1718
110k
                if (xy != 0)
1719
110k
                {
1720
110k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
110k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
110k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
110k
                xypq = MUL_F(xy, pq);
1728
1729
110k
                if (xypq != 0)
1730
110k
                {
1731
110k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
110k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
110k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
110k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
110k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
110k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
110k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
110k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
110k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
110k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
110k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
110k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
110k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
110k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
110k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
621k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
621k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
621k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
621k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
621k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
621k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
621k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
621k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
621k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
621k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
621k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
621k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
621k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
621k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
621k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
110k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
110k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
110k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
110k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
110k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
110k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
110k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
110k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
110k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
110k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
16.2k
                {
1792
16.2k
                    IM(deltaH11) = -IM(deltaH11);
1793
16.2k
                    IM(deltaH12) = -IM(deltaH12);
1794
16.2k
                    IM(deltaH21) = -IM(deltaH21);
1795
16.2k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
16.2k
                    IM(H11) = -IM(H11);
1798
16.2k
                    IM(H12) = -IM(H12);
1799
16.2k
                    IM(H21) = -IM(H21);
1800
16.2k
                    IM(H22) = -IM(H22);
1801
16.2k
                }
1802
1803
110k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
110k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
110k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
110k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
110k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
7.99M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
7.37M
            {
1812
                /* addition finalises the interpolation over every n */
1813
7.37M
                RE(H11) += RE(deltaH11);
1814
7.37M
                RE(H12) += RE(deltaH12);
1815
7.37M
                RE(H21) += RE(deltaH21);
1816
7.37M
                RE(H22) += RE(deltaH22);
1817
7.37M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
1.10M
                {
1819
1.10M
                    IM(H11) += IM(deltaH11);
1820
1.10M
                    IM(H12) += IM(deltaH12);
1821
1.10M
                    IM(H21) += IM(deltaH21);
1822
1.10M
                    IM(H22) += IM(deltaH22);
1823
1.10M
                }
1824
1825
                /* channel is an alias to the subband */
1826
25.8M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
18.4M
                {
1828
18.4M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
18.4M
                    if (gr < ps->num_hybrid_groups)
1832
4.05M
                    {
1833
4.05M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
4.05M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
4.05M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
4.05M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
14.3M
                    } else {
1838
14.3M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
14.3M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
14.3M
                        RE(inRight) = RE(X_right[n][sb]);
1841
14.3M
                        IM(inRight) = IM(X_right[n][sb]);
1842
14.3M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
18.4M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
18.4M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
18.4M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
18.4M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
18.4M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.10M
                    {
1855
                        /* apply rotation */
1856
1.10M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.10M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.10M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.10M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.10M
                    }
1861
1862
                    /* store final samples */
1863
18.4M
                    if (gr < ps->num_hybrid_groups)
1864
4.05M
                    {
1865
4.05M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
4.05M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
4.05M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
4.05M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
14.3M
                    } else {
1870
14.3M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
14.3M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
14.3M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
14.3M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
14.3M
                    }
1875
18.4M
                }
1876
7.37M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
621k
            ps->phase_hist++;
1880
621k
            if (ps->phase_hist == 2)
1881
310k
            {
1882
310k
                ps->phase_hist = 0;
1883
310k
            }
1884
621k
        }
1885
236k
    }
1886
7.61k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
10.7k
{
1459
10.7k
    uint8_t n;
1460
10.7k
    uint8_t gr;
1461
10.7k
    uint8_t bk = 0;
1462
10.7k
    uint8_t sb, maxsb;
1463
10.7k
    uint8_t env;
1464
10.7k
    uint8_t nr_ipdopd_par;
1465
10.7k
    complex_t h11, h12, h21, h22;  // COEF
1466
10.7k
    complex_t H11, H12, H21, H22;  // COEF
1467
10.7k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
10.7k
    complex_t tempLeft, tempRight; // FRAC
1469
10.7k
    complex_t phaseLeft, phaseRight; // FRAC
1470
10.7k
    real_t L;
1471
10.7k
    const real_t *sf_iid;
1472
10.7k
    uint8_t no_iid_steps;
1473
1474
10.7k
    if (ps->iid_mode >= 3)
1475
4.79k
    {
1476
4.79k
        no_iid_steps = 15;
1477
4.79k
        sf_iid = sf_iid_fine;
1478
5.94k
    } else {
1479
5.94k
        no_iid_steps = 7;
1480
5.94k
        sf_iid = sf_iid_normal;
1481
5.94k
    }
1482
1483
10.7k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
6.42k
    {
1485
6.42k
        nr_ipdopd_par = 11; /* resolution */
1486
6.42k
    } else {
1487
4.31k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
4.31k
    }
1489
1490
355k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
344k
    {
1492
344k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
344k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.14M
        for (env = 0; env < ps->num_env; env++)
1498
797k
        {
1499
797k
            uint8_t abs_iid = (uint8_t)abs(ps->iid_index[env][bk]);
1500
            /* index range is supposed to be -7...7 or -15...15 depending on iid_mode
1501
                (Table 8.24, ISO/IEC 14496-3:2005).
1502
                if it is outside these boundaries, this is most likely an error. sanitize
1503
                it and try to process further. */
1504
797k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
229
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
229
                    -no_iid_steps);
1507
229
                ps->iid_index[env][bk] = -no_iid_steps;
1508
229
                abs_iid = no_iid_steps;
1509
797k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
167
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
167
                    no_iid_steps);
1512
167
                ps->iid_index[env][bk] = no_iid_steps;
1513
167
                abs_iid = no_iid_steps;
1514
167
            }
1515
797k
            if (ps->icc_index[env][bk] < 0) {
1516
253
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
253
                ps->icc_index[env][bk] = 0;
1518
797k
            } else if (ps->icc_index[env][bk] > 7) {
1519
0
                fprintf(stderr, "Warning: invalid icc_index: %d > 7\n", ps->icc_index[env][bk]);
1520
0
                ps->icc_index[env][bk] = 7;
1521
0
            }
1522
1523
797k
            if (ps->icc_mode < 3)
1524
513k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
513k
                real_t c_1, c_2;  // COEF
1527
513k
                real_t cosa, sina;  // COEF
1528
513k
                real_t cosb, sinb;  // COEF
1529
513k
                real_t ab1, ab2;  // COEF
1530
513k
                real_t ab3, ab4;  // COEF
1531
1532
                /*
1533
                c_1 = sqrt(2.0 / (1.0 + pow(10.0, quant_iid[no_iid_steps + iid_index] / 10.0)));
1534
                c_2 = sqrt(2.0 / (1.0 + pow(10.0, quant_iid[no_iid_steps - iid_index] / 10.0)));
1535
                alpha = 0.5 * acos(quant_rho[icc_index]);
1536
                beta = alpha * ( c_1 - c_2 ) / sqrt(2.0);
1537
                */
1538
1539
                //printf("%d\n", ps->iid_index[env][bk]);
1540
1541
                /* calculate the scalefactors c_1 and c_2 from the intensity differences */
1542
513k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
513k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
513k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
513k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
513k
                if (ps->iid_mode >= 3)
1550
253k
                {
1551
253k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
253k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
260k
                } else {
1554
260k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
260k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
260k
                }
1557
1558
513k
                ab1 = MUL_C(cosb, cosa);
1559
513k
                ab2 = MUL_C(sinb, sina);
1560
513k
                ab3 = MUL_C(sinb, cosa);
1561
513k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
513k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
513k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
513k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
513k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
513k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
283k
                real_t sina, cosa;  // COEF
1571
283k
                real_t cosg, sing;  // COEF
1572
1573
                /*
1574
                real_t c, rho, mu, alpha, gamma;
1575
                uint8_t i;
1576
1577
                i = ps->iid_index[env][bk];
1578
                c = (real_t)pow(10.0, ((i)?(((i>0)?1:-1)*quant_iid[((i>0)?i:-i)-1]):0.)/20.0);
1579
                rho = quant_rho[ps->icc_index[env][bk]];
1580
1581
                if (rho == 0.0f && c == 1.)
1582
                {
1583
                    alpha = (real_t)M_PI/4.0f;
1584
                    rho = 0.05f;
1585
                } else {
1586
                    if (rho <= 0.05f)
1587
                    {
1588
                        rho = 0.05f;
1589
                    }
1590
                    alpha = 0.5f*(real_t)atan( (2.0f*c*rho) / (c*c-1.0f) );
1591
1592
                    if (alpha < 0.)
1593
                    {
1594
                        alpha += (real_t)M_PI/2.0f;
1595
                    }
1596
                    if (rho < 0.)
1597
                    {
1598
                        alpha += (real_t)M_PI;
1599
                    }
1600
                }
1601
                mu = c+1.0f/c;
1602
                mu = 1+(4.0f*rho*rho-4.0f)/(mu*mu);
1603
                gamma = (real_t)atan(sqrt((1.0f-sqrt(mu))/(1.0f+sqrt(mu))));
1604
                */
1605
1606
283k
                if (ps->iid_mode >= 3)
1607
148k
                {
1608
148k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
148k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
148k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
148k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
148k
                } else {
1613
135k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
135k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
135k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
135k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
135k
                }
1618
1619
283k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
283k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
283k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
283k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
283k
            }
1624
797k
            IM(h11) = IM(h12) = IM(h21) = IM(h22) = 0;
1625
1626
            /* calculate phase rotation parameters H_xy */
1627
            /* note that the imaginary part of these parameters are only calculated when
1628
               IPD and OPD are enabled
1629
             */
1630
797k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
85.2k
            {
1632
85.2k
                int8_t i;
1633
85.2k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
85.2k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
#ifdef FIXED_POINT
1640
                /* divide by 4*2, shift right 3 bits;
1641
                   extra halving to avoid overflows; it is ok, because result is normalized */
1642
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
85.2k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
85.2k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
85.2k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
85.2k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
85.2k
#endif
1652
1653
                /* save current value */
1654
85.2k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
85.2k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
85.2k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
85.2k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
85.2k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
85.2k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
85.2k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
85.2k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
85.2k
#endif
1672
1673
                /* ringbuffer index */
1674
85.2k
                if (i == 0)
1675
43.0k
                {
1676
43.0k
                    i = 2;
1677
43.0k
                }
1678
85.2k
                i--;
1679
1680
                /* get value before previous */
1681
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
85.2k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
85.2k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
85.2k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
85.2k
                IM(tempRight) += MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1692
85.2k
#endif
1693
1694
#if 0 /* original code */
1695
                ipd = (float)atan2(IM(tempLeft), RE(tempLeft));
1696
                opd = (float)atan2(IM(tempRight), RE(tempRight));
1697
1698
                /* phase rotation */
1699
                RE(phaseLeft) = (float)cos(opd);
1700
                IM(phaseLeft) = (float)sin(opd);
1701
                opd -= ipd;
1702
                RE(phaseRight) = (float)cos(opd);
1703
                IM(phaseRight) = (float)sin(opd);
1704
#else
1705
1706
                // x = IM(tempLeft)
1707
                // y = RE(tempLeft)
1708
                // p = IM(tempRight)
1709
                // q = RE(tempRight)
1710
                // cos(atan2(x,y)) = y/sqrt((x*x) + (y*y))
1711
                // sin(atan2(x,y)) = x/sqrt((x*x) + (y*y))
1712
                // cos(atan2(x,y)-atan2(p,q)) = (y*q + x*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1713
                // sin(atan2(x,y)-atan2(p,q)) = (x*q - y*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1714
1715
85.2k
                xy = magnitude_c(tempRight);
1716
85.2k
                pq = magnitude_c(tempLeft);
1717
1718
85.2k
                if (xy != 0)
1719
85.2k
                {
1720
85.2k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
85.2k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
85.2k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
85.2k
                xypq = MUL_F(xy, pq);
1728
1729
85.2k
                if (xypq != 0)
1730
85.2k
                {
1731
85.2k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
85.2k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
85.2k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
85.2k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
85.2k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
85.2k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
85.2k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
85.2k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
85.2k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
85.2k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
85.2k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
85.2k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
85.2k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
85.2k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
85.2k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
797k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
797k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
797k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
797k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
797k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
797k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
797k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
797k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
797k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
797k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
797k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
797k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
797k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
797k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
797k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
85.2k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
85.2k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
85.2k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
85.2k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
85.2k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
85.2k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
85.2k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
85.2k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
85.2k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
85.2k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
12.4k
                {
1792
12.4k
                    IM(deltaH11) = -IM(deltaH11);
1793
12.4k
                    IM(deltaH12) = -IM(deltaH12);
1794
12.4k
                    IM(deltaH21) = -IM(deltaH21);
1795
12.4k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
12.4k
                    IM(H11) = -IM(H11);
1798
12.4k
                    IM(H12) = -IM(H12);
1799
12.4k
                    IM(H21) = -IM(H21);
1800
12.4k
                    IM(H22) = -IM(H22);
1801
12.4k
                }
1802
1803
85.2k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
85.2k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
85.2k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
85.2k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
85.2k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
11.4M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
10.7M
            {
1812
                /* addition finalises the interpolation over every n */
1813
10.7M
                RE(H11) += RE(deltaH11);
1814
10.7M
                RE(H12) += RE(deltaH12);
1815
10.7M
                RE(H21) += RE(deltaH21);
1816
10.7M
                RE(H22) += RE(deltaH22);
1817
10.7M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
827k
                {
1819
827k
                    IM(H11) += IM(deltaH11);
1820
827k
                    IM(H12) += IM(deltaH12);
1821
827k
                    IM(H21) += IM(deltaH21);
1822
827k
                    IM(H22) += IM(deltaH22);
1823
827k
                }
1824
1825
                /* channel is an alias to the subband */
1826
36.8M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
26.1M
                {
1828
26.1M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
26.1M
                    if (gr < ps->num_hybrid_groups)
1832
5.96M
                    {
1833
5.96M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
5.96M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
5.96M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
5.96M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
20.2M
                    } else {
1838
20.2M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
20.2M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
20.2M
                        RE(inRight) = RE(X_right[n][sb]);
1841
20.2M
                        IM(inRight) = IM(X_right[n][sb]);
1842
20.2M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
26.1M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
26.1M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
26.1M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
26.1M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
26.1M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
831k
                    {
1855
                        /* apply rotation */
1856
831k
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
831k
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
831k
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
831k
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
831k
                    }
1861
1862
                    /* store final samples */
1863
26.1M
                    if (gr < ps->num_hybrid_groups)
1864
5.96M
                    {
1865
5.96M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
5.96M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
5.96M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
5.96M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
20.2M
                    } else {
1870
20.2M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
20.2M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
20.2M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
20.2M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
20.2M
                    }
1875
26.1M
                }
1876
10.7M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
797k
            ps->phase_hist++;
1880
797k
            if (ps->phase_hist == 2)
1881
398k
            {
1882
398k
                ps->phase_hist = 0;
1883
398k
            }
1884
797k
        }
1885
344k
    }
1886
10.7k
}
1887
1888
void ps_free(ps_info *ps)
1889
28.4k
{
1890
    /* free hybrid filterbank structures */
1891
28.4k
    hybrid_free(ps->hyb);
1892
1893
28.4k
    faad_free(ps);
1894
28.4k
}
1895
1896
ps_info *ps_init(uint8_t sr_index, uint8_t numTimeSlotsRate)
1897
28.4k
{
1898
28.4k
    uint8_t i;
1899
28.4k
    uint8_t short_delay_band;
1900
1901
28.4k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
28.4k
    memset(ps, 0, sizeof(ps_info));
1903
1904
28.4k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
28.4k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
28.4k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
28.4k
    ps->saved_delay = 0;
1911
1912
1.84M
    for (i = 0; i < 64; i++)
1913
1.81M
    {
1914
1.81M
        ps->delay_buf_index_delay[i] = 0;
1915
1.81M
    }
1916
1917
113k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
85.2k
    {
1919
85.2k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
85.2k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
85.2k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
85.2k
#endif
1932
85.2k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
28.4k
    short_delay_band = 35;
1950
28.4k
    ps->nr_allpass_bands = 22;
1951
28.4k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
28.4k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
28.4k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
1.02M
    for (i = 0; i < short_delay_band; i++)
1957
995k
    {
1958
995k
        ps->delay_D[i] = 14;
1959
995k
    }
1960
852k
    for (i = short_delay_band; i < 64; i++)
1961
824k
    {
1962
824k
        ps->delay_D[i] = 1;
1963
824k
    }
1964
1965
    /* mixing and phase */
1966
1.44M
    for (i = 0; i < 50; i++)
1967
1.42M
    {
1968
1.42M
        RE(ps->h11_prev[i]) = 1;
1969
1.42M
        IM(ps->h11_prev[i]) = 1;
1970
1.42M
        RE(ps->h12_prev[i]) = 1;
1971
1.42M
        IM(ps->h12_prev[i]) = 1;
1972
1.42M
    }
1973
1974
28.4k
    ps->phase_hist = 0;
1975
1976
597k
    for (i = 0; i < 20; i++)
1977
568k
    {
1978
568k
        RE(ps->ipd_prev[i][0]) = 0;
1979
568k
        IM(ps->ipd_prev[i][0]) = 0;
1980
568k
        RE(ps->ipd_prev[i][1]) = 0;
1981
568k
        IM(ps->ipd_prev[i][1]) = 0;
1982
568k
        RE(ps->opd_prev[i][0]) = 0;
1983
568k
        IM(ps->opd_prev[i][0]) = 0;
1984
568k
        RE(ps->opd_prev[i][1]) = 0;
1985
568k
        IM(ps->opd_prev[i][1]) = 0;
1986
568k
    }
1987
1988
28.4k
    return ps;
1989
28.4k
}
ps_init
Line
Count
Source
1897
11.4k
{
1898
11.4k
    uint8_t i;
1899
11.4k
    uint8_t short_delay_band;
1900
1901
11.4k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
11.4k
    memset(ps, 0, sizeof(ps_info));
1903
1904
11.4k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
11.4k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
11.4k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
11.4k
    ps->saved_delay = 0;
1911
1912
747k
    for (i = 0; i < 64; i++)
1913
735k
    {
1914
735k
        ps->delay_buf_index_delay[i] = 0;
1915
735k
    }
1916
1917
45.9k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
34.4k
    {
1919
34.4k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
34.4k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
34.4k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
34.4k
#endif
1932
34.4k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
11.4k
    short_delay_band = 35;
1950
11.4k
    ps->nr_allpass_bands = 22;
1951
11.4k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
11.4k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
11.4k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
413k
    for (i = 0; i < short_delay_band; i++)
1957
402k
    {
1958
402k
        ps->delay_D[i] = 14;
1959
402k
    }
1960
344k
    for (i = short_delay_band; i < 64; i++)
1961
333k
    {
1962
333k
        ps->delay_D[i] = 1;
1963
333k
    }
1964
1965
    /* mixing and phase */
1966
586k
    for (i = 0; i < 50; i++)
1967
574k
    {
1968
574k
        RE(ps->h11_prev[i]) = 1;
1969
574k
        IM(ps->h11_prev[i]) = 1;
1970
574k
        RE(ps->h12_prev[i]) = 1;
1971
574k
        IM(ps->h12_prev[i]) = 1;
1972
574k
    }
1973
1974
11.4k
    ps->phase_hist = 0;
1975
1976
241k
    for (i = 0; i < 20; i++)
1977
229k
    {
1978
229k
        RE(ps->ipd_prev[i][0]) = 0;
1979
229k
        IM(ps->ipd_prev[i][0]) = 0;
1980
229k
        RE(ps->ipd_prev[i][1]) = 0;
1981
229k
        IM(ps->ipd_prev[i][1]) = 0;
1982
229k
        RE(ps->opd_prev[i][0]) = 0;
1983
229k
        IM(ps->opd_prev[i][0]) = 0;
1984
229k
        RE(ps->opd_prev[i][1]) = 0;
1985
229k
        IM(ps->opd_prev[i][1]) = 0;
1986
229k
    }
1987
1988
11.4k
    return ps;
1989
11.4k
}
ps_init
Line
Count
Source
1897
16.9k
{
1898
16.9k
    uint8_t i;
1899
16.9k
    uint8_t short_delay_band;
1900
1901
16.9k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
16.9k
    memset(ps, 0, sizeof(ps_info));
1903
1904
16.9k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
16.9k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
16.9k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
16.9k
    ps->saved_delay = 0;
1911
1912
1.10M
    for (i = 0; i < 64; i++)
1913
1.08M
    {
1914
1.08M
        ps->delay_buf_index_delay[i] = 0;
1915
1.08M
    }
1916
1917
67.7k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
50.8k
    {
1919
50.8k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
50.8k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
50.8k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
50.8k
#endif
1932
50.8k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
16.9k
    short_delay_band = 35;
1950
16.9k
    ps->nr_allpass_bands = 22;
1951
16.9k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
16.9k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
16.9k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
609k
    for (i = 0; i < short_delay_band; i++)
1957
592k
    {
1958
592k
        ps->delay_D[i] = 14;
1959
592k
    }
1960
508k
    for (i = short_delay_band; i < 64; i++)
1961
491k
    {
1962
491k
        ps->delay_D[i] = 1;
1963
491k
    }
1964
1965
    /* mixing and phase */
1966
863k
    for (i = 0; i < 50; i++)
1967
846k
    {
1968
846k
        RE(ps->h11_prev[i]) = 1;
1969
846k
        IM(ps->h11_prev[i]) = 1;
1970
846k
        RE(ps->h12_prev[i]) = 1;
1971
846k
        IM(ps->h12_prev[i]) = 1;
1972
846k
    }
1973
1974
16.9k
    ps->phase_hist = 0;
1975
1976
355k
    for (i = 0; i < 20; i++)
1977
338k
    {
1978
338k
        RE(ps->ipd_prev[i][0]) = 0;
1979
338k
        IM(ps->ipd_prev[i][0]) = 0;
1980
338k
        RE(ps->ipd_prev[i][1]) = 0;
1981
338k
        IM(ps->ipd_prev[i][1]) = 0;
1982
338k
        RE(ps->opd_prev[i][0]) = 0;
1983
338k
        IM(ps->opd_prev[i][0]) = 0;
1984
338k
        RE(ps->opd_prev[i][1]) = 0;
1985
338k
        IM(ps->opd_prev[i][1]) = 0;
1986
338k
    }
1987
1988
16.9k
    return ps;
1989
16.9k
}
1990
1991
/* main Parametric Stereo decoding function */
1992
uint8_t ps_decode(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64])
1993
18.3k
{
1994
18.3k
    qmf_t X_hybrid_left[32][32] = {{{0}}};
1995
18.3k
    qmf_t X_hybrid_right[32][32] = {{{0}}};
1996
1997
    /* delta decoding of the bitstream data */
1998
18.3k
    ps_data_decode(ps);
1999
2000
    /* set up some parameters depending on filterbank type */
2001
18.3k
    if (ps->use34hybrid_bands)
2002
6.31k
    {
2003
6.31k
        ps->group_border = (uint8_t*)group_border34;
2004
6.31k
        ps->map_group2bk = (uint16_t*)map_group2bk34;
2005
6.31k
        ps->num_groups = 32+18;
2006
6.31k
        ps->num_hybrid_groups = 32;
2007
6.31k
        ps->nr_par_bands = 34;
2008
6.31k
        ps->decay_cutoff = 5;
2009
12.0k
    } else {
2010
12.0k
        ps->group_border = (uint8_t*)group_border20;
2011
12.0k
        ps->map_group2bk = (uint16_t*)map_group2bk20;
2012
12.0k
        ps->num_groups = 10+12;
2013
12.0k
        ps->num_hybrid_groups = 10;
2014
12.0k
        ps->nr_par_bands = 20;
2015
12.0k
        ps->decay_cutoff = 3;
2016
12.0k
    }
2017
2018
    /* Perform further analysis on the lowest subbands to get a higher
2019
     * frequency resolution
2020
     */
2021
18.3k
    hybrid_analysis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2022
18.3k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2023
2024
    /* decorrelate mono signal */
2025
18.3k
    ps_decorrelate(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2026
2027
    /* apply mixing and phase parameters */
2028
18.3k
    ps_mix_phase(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2029
2030
    /* hybrid synthesis, to rebuild the SBR QMF matrices */
2031
18.3k
    hybrid_synthesis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2032
18.3k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2033
2034
18.3k
    hybrid_synthesis((hyb_info*)ps->hyb, X_right, X_hybrid_right,
2035
18.3k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2036
2037
18.3k
    return 0;
2038
18.3k
}
2039
2040
#endif