Coverage Report

Created: 2025-12-14 06:24

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
50.0M
#define NEGATE_IPD_MASK            (0x1000)
42
378k
#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
30.8k
{
198
30.8k
    uint8_t i;
199
200
30.8k
    hyb_info *hyb = (hyb_info*)faad_malloc(sizeof(hyb_info));
201
202
30.8k
    hyb->resolution34[0] = 12;
203
30.8k
    hyb->resolution34[1] = 8;
204
30.8k
    hyb->resolution34[2] = 4;
205
30.8k
    hyb->resolution34[3] = 4;
206
30.8k
    hyb->resolution34[4] = 4;
207
208
30.8k
    hyb->resolution20[0] = 8;
209
30.8k
    hyb->resolution20[1] = 2;
210
30.8k
    hyb->resolution20[2] = 2;
211
212
30.8k
    hyb->frame_len = numTimeSlotsRate;
213
214
30.8k
    hyb->work = (qmf_t*)faad_malloc((hyb->frame_len+12) * sizeof(qmf_t));
215
30.8k
    memset(hyb->work, 0, (hyb->frame_len+12) * sizeof(qmf_t));
216
217
30.8k
    hyb->buffer = (qmf_t**)faad_malloc(5 * sizeof(qmf_t*));
218
184k
    for (i = 0; i < 5; i++)
219
154k
    {
220
154k
        hyb->buffer[i] = (qmf_t*)faad_malloc(hyb->frame_len * sizeof(qmf_t));
221
154k
        memset(hyb->buffer[i], 0, hyb->frame_len * sizeof(qmf_t));
222
154k
    }
223
224
30.8k
    hyb->temp = (qmf_t**)faad_malloc(hyb->frame_len * sizeof(qmf_t*));
225
1.00M
    for (i = 0; i < hyb->frame_len; i++)
226
974k
    {
227
974k
        hyb->temp[i] = (qmf_t*)faad_malloc(12 /*max*/ * sizeof(qmf_t));
228
974k
    }
229
230
30.8k
    return hyb;
231
30.8k
}
232
233
static void hybrid_free(hyb_info *hyb)
234
30.8k
{
235
30.8k
    uint8_t i;
236
237
30.8k
  if (!hyb) return;
238
239
30.8k
    if (hyb->work)
240
30.8k
        faad_free(hyb->work);
241
242
184k
    for (i = 0; i < 5; i++)
243
154k
    {
244
154k
        if (hyb->buffer[i])
245
154k
            faad_free(hyb->buffer[i]);
246
154k
    }
247
30.8k
    if (hyb->buffer)
248
30.8k
        faad_free(hyb->buffer);
249
250
1.00M
    for (i = 0; i < hyb->frame_len; i++)
251
974k
    {
252
974k
        if (hyb->temp[i])
253
974k
            faad_free(hyb->temp[i]);
254
974k
    }
255
30.8k
    if (hyb->temp)
256
30.8k
        faad_free(hyb->temp);
257
258
30.8k
    faad_free(hyb);
259
30.8k
}
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
52.4k
{
265
52.4k
    uint8_t i;
266
52.4k
    (void)hyb;  /* TODO: remove parameter? */
267
268
1.69M
    for (i = 0; i < frame_len; i++)
269
1.64M
    {
270
1.64M
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
1.64M
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
1.64M
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
1.64M
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
1.64M
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
1.64M
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
1.64M
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
1.64M
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
1.64M
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
1.64M
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
1.64M
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
1.64M
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
1.64M
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
1.64M
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
1.64M
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
1.64M
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
1.64M
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
1.64M
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
1.64M
    }
293
52.4k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
26.2k
{
265
26.2k
    uint8_t i;
266
26.2k
    (void)hyb;  /* TODO: remove parameter? */
267
268
848k
    for (i = 0; i < frame_len; i++)
269
822k
    {
270
822k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
822k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
822k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
822k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
822k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
822k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
822k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
822k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
822k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
822k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
822k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
822k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
822k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
822k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
822k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
822k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
822k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
822k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
822k
    }
293
26.2k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
26.2k
{
265
26.2k
    uint8_t i;
266
26.2k
    (void)hyb;  /* TODO: remove parameter? */
267
268
848k
    for (i = 0; i < frame_len; i++)
269
822k
    {
270
822k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
822k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
822k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
822k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
822k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
822k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
822k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
822k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
822k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
822k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
822k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
822k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
822k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
822k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
822k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
822k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
822k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
822k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
822k
    }
293
26.2k
}
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
20.4k
{
299
20.4k
    uint8_t i;
300
20.4k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
20.4k
    (void)hyb;  /* TODO: remove parameter? */
302
303
652k
    for (i = 0; i < frame_len; i++)
304
632k
    {
305
632k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
632k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
632k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
632k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
632k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
632k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
632k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
632k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
632k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
632k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
632k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
632k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
632k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
632k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
632k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
632k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
632k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
632k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
632k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
632k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
632k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
632k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
632k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
632k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
632k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
632k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
632k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
632k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
632k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
632k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
632k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
632k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
632k
    }
349
20.4k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
8.73k
{
299
8.73k
    uint8_t i;
300
8.73k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
8.73k
    (void)hyb;  /* TODO: remove parameter? */
302
303
278k
    for (i = 0; i < frame_len; i++)
304
269k
    {
305
269k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
269k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
269k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
269k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
269k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
269k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
269k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
269k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
269k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
269k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
269k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
269k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
269k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
269k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
269k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
269k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
269k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
269k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
269k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
269k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
269k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
269k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
269k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
269k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
269k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
269k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
269k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
269k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
269k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
269k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
269k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
269k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
269k
    }
349
8.73k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
11.7k
{
299
11.7k
    uint8_t i;
300
11.7k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
11.7k
    (void)hyb;  /* TODO: remove parameter? */
302
303
374k
    for (i = 0; i < frame_len; i++)
304
362k
    {
305
362k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
362k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
362k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
362k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
362k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
362k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
362k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
362k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
362k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
362k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
362k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
362k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
362k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
362k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
362k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
362k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
362k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
362k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
362k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
362k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
362k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
362k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
362k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
362k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
362k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
362k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
362k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
362k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
362k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
362k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
362k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
362k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
362k
    }
349
11.7k
}
350
351
static void INLINE DCT3_4_unscaled(real_t *y, real_t *x)
352
2.48M
{
353
2.48M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
2.48M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
2.48M
    f1 = x[0] - f0;
357
2.48M
    f2 = x[0] + f0;
358
2.48M
    f3 = x[1] + x[3];
359
2.48M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
2.48M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
2.48M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
2.48M
    f7 = f4 + f5;
363
2.48M
    f8 = f6 - f5;
364
2.48M
    y[3] = f2 - f8;
365
2.48M
    y[0] = f2 + f8;
366
2.48M
    y[2] = f1 - f7;
367
2.48M
    y[1] = f1 + f7;
368
2.48M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.15M
{
353
1.15M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.15M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.15M
    f1 = x[0] - f0;
357
1.15M
    f2 = x[0] + f0;
358
1.15M
    f3 = x[1] + x[3];
359
1.15M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.15M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.15M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.15M
    f7 = f4 + f5;
363
1.15M
    f8 = f6 - f5;
364
1.15M
    y[3] = f2 - f8;
365
1.15M
    y[0] = f2 + f8;
366
1.15M
    y[2] = f1 - f7;
367
1.15M
    y[1] = f1 + f7;
368
1.15M
}
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
39.8k
{
374
39.8k
    uint8_t i, n;
375
39.8k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
39.8k
    real_t x[4];
377
39.8k
    (void)hyb;  /* TODO: remove parameter? */
378
379
1.28M
    for (i = 0; i < frame_len; i++)
380
1.24M
    {
381
1.24M
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
1.24M
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
1.24M
        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.24M
        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.24M
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
1.24M
        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.24M
        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.24M
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
6.22M
        for (n = 0; n < 4; n++)
392
4.97M
        {
393
4.97M
            x[n] = input_re1[n] - input_im1[3-n];
394
4.97M
        }
395
1.24M
        DCT3_4_unscaled(x, x);
396
1.24M
        QMF_RE(X_hybrid[i][7]) = x[0];
397
1.24M
        QMF_RE(X_hybrid[i][5]) = x[2];
398
1.24M
        QMF_RE(X_hybrid[i][3]) = x[3];
399
1.24M
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
6.22M
        for (n = 0; n < 4; n++)
402
4.97M
        {
403
4.97M
            x[n] = input_re1[n] + input_im1[3-n];
404
4.97M
        }
405
1.24M
        DCT3_4_unscaled(x, x);
406
1.24M
        QMF_RE(X_hybrid[i][6]) = x[1];
407
1.24M
        QMF_RE(X_hybrid[i][4]) = x[3];
408
1.24M
        QMF_RE(X_hybrid[i][2]) = x[2];
409
1.24M
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
1.24M
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
1.24M
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
1.24M
        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.24M
        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.24M
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
1.24M
        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.24M
        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.24M
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
6.22M
        for (n = 0; n < 4; n++)
422
4.97M
        {
423
4.97M
            x[n] = input_im2[n] + input_re2[3-n];
424
4.97M
        }
425
1.24M
        DCT3_4_unscaled(x, x);
426
1.24M
        QMF_IM(X_hybrid[i][7]) = x[0];
427
1.24M
        QMF_IM(X_hybrid[i][5]) = x[2];
428
1.24M
        QMF_IM(X_hybrid[i][3]) = x[3];
429
1.24M
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
6.22M
        for (n = 0; n < 4; n++)
432
4.97M
        {
433
4.97M
            x[n] = input_im2[n] - input_re2[3-n];
434
4.97M
        }
435
1.24M
        DCT3_4_unscaled(x, x);
436
1.24M
        QMF_IM(X_hybrid[i][6]) = x[1];
437
1.24M
        QMF_IM(X_hybrid[i][4]) = x[3];
438
1.24M
        QMF_IM(X_hybrid[i][2]) = x[2];
439
1.24M
        QMF_IM(X_hybrid[i][0]) = x[0];
440
1.24M
    }
441
39.8k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
19.9k
{
374
19.9k
    uint8_t i, n;
375
19.9k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
19.9k
    real_t x[4];
377
19.9k
    (void)hyb;  /* TODO: remove parameter? */
378
379
642k
    for (i = 0; i < frame_len; i++)
380
622k
    {
381
622k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
622k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
622k
        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
622k
        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
622k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
622k
        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
622k
        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
622k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.11M
        for (n = 0; n < 4; n++)
392
2.48M
        {
393
2.48M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.48M
        }
395
622k
        DCT3_4_unscaled(x, x);
396
622k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
622k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
622k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
622k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.11M
        for (n = 0; n < 4; n++)
402
2.48M
        {
403
2.48M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.48M
        }
405
622k
        DCT3_4_unscaled(x, x);
406
622k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
622k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
622k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
622k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
622k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
622k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
622k
        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
622k
        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
622k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
622k
        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
622k
        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
622k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.11M
        for (n = 0; n < 4; n++)
422
2.48M
        {
423
2.48M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.48M
        }
425
622k
        DCT3_4_unscaled(x, x);
426
622k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
622k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
622k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
622k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.11M
        for (n = 0; n < 4; n++)
432
2.48M
        {
433
2.48M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.48M
        }
435
622k
        DCT3_4_unscaled(x, x);
436
622k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
622k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
622k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
622k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
622k
    }
441
19.9k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
19.9k
{
374
19.9k
    uint8_t i, n;
375
19.9k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
19.9k
    real_t x[4];
377
19.9k
    (void)hyb;  /* TODO: remove parameter? */
378
379
642k
    for (i = 0; i < frame_len; i++)
380
622k
    {
381
622k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
622k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
622k
        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
622k
        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
622k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
622k
        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
622k
        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
622k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.11M
        for (n = 0; n < 4; n++)
392
2.48M
        {
393
2.48M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.48M
        }
395
622k
        DCT3_4_unscaled(x, x);
396
622k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
622k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
622k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
622k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.11M
        for (n = 0; n < 4; n++)
402
2.48M
        {
403
2.48M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.48M
        }
405
622k
        DCT3_4_unscaled(x, x);
406
622k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
622k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
622k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
622k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
622k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
622k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
622k
        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
622k
        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
622k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
622k
        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
622k
        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
622k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.11M
        for (n = 0; n < 4; n++)
422
2.48M
        {
423
2.48M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.48M
        }
425
622k
        DCT3_4_unscaled(x, x);
426
622k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
622k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
622k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
622k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.11M
        for (n = 0; n < 4; n++)
432
2.48M
        {
433
2.48M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.48M
        }
435
622k
        DCT3_4_unscaled(x, x);
436
622k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
622k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
622k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
622k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
622k
    }
441
19.9k
}
442
443
static void INLINE DCT3_6_unscaled(real_t *y, real_t *x)
444
843k
{
445
843k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
843k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
843k
    f1 = x[0] + f0;
449
843k
    f2 = x[0] - f0;
450
843k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
843k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
843k
    f5 = f4 - x[4];
453
843k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
843k
    f7 = f6 - f3;
455
843k
    y[0] = f1 + f6 + f4;
456
843k
    y[1] = f2 + f3 - x[4];
457
843k
    y[2] = f7 + f2 - f5;
458
843k
    y[3] = f1 - f7 - f5;
459
843k
    y[4] = f1 - f3 - x[4];
460
843k
    y[5] = f2 - f6 + f4;
461
843k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
359k
{
445
359k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
359k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
359k
    f1 = x[0] + f0;
449
359k
    f2 = x[0] - f0;
450
359k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
359k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
359k
    f5 = f4 - x[4];
453
359k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
359k
    f7 = f6 - f3;
455
359k
    y[0] = f1 + f6 + f4;
456
359k
    y[1] = f2 + f3 - x[4];
457
359k
    y[2] = f7 + f2 - f5;
458
359k
    y[3] = f1 - f7 - f5;
459
359k
    y[4] = f1 - f3 - x[4];
460
359k
    y[5] = f2 - f6 + f4;
461
359k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
483k
{
445
483k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
483k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
483k
    f1 = x[0] + f0;
449
483k
    f2 = x[0] - f0;
450
483k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
483k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
483k
    f5 = f4 - x[4];
453
483k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
483k
    f7 = f6 - f3;
455
483k
    y[0] = f1 + f6 + f4;
456
483k
    y[1] = f2 + f3 - x[4];
457
483k
    y[2] = f7 + f2 - f5;
458
483k
    y[3] = f1 - f7 - f5;
459
483k
    y[4] = f1 - f3 - x[4];
460
483k
    y[5] = f2 - f6 + f4;
461
483k
}
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
13.6k
{
467
13.6k
    uint8_t i, n;
468
13.6k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
13.6k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
13.6k
    (void)hyb;  /* TODO: remove parameter? */
471
472
435k
    for (i = 0; i < frame_len; i++)
473
421k
    {
474
2.95M
        for (n = 0; n < 6; n++)
475
2.52M
        {
476
2.52M
            if (n == 0)
477
421k
            {
478
421k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
421k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
2.10M
            } else {
481
2.10M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
2.10M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
2.10M
            }
484
2.52M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
2.52M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
2.52M
        }
487
488
421k
        DCT3_6_unscaled(out_re1, input_re1);
489
421k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
421k
        DCT3_6_unscaled(out_im1, input_im1);
492
421k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
1.68M
        for (n = 0; n < 6; n += 2)
495
1.26M
        {
496
1.26M
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
1.26M
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
1.26M
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
1.26M
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
1.26M
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
1.26M
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
1.26M
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
1.26M
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
1.26M
        }
506
421k
    }
507
13.6k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
6.83k
{
467
6.83k
    uint8_t i, n;
468
6.83k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
6.83k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
6.83k
    (void)hyb;  /* TODO: remove parameter? */
471
472
217k
    for (i = 0; i < frame_len; i++)
473
210k
    {
474
1.47M
        for (n = 0; n < 6; n++)
475
1.26M
        {
476
1.26M
            if (n == 0)
477
210k
            {
478
210k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
210k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.05M
            } else {
481
1.05M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.05M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.05M
            }
484
1.26M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.26M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.26M
        }
487
488
210k
        DCT3_6_unscaled(out_re1, input_re1);
489
210k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
210k
        DCT3_6_unscaled(out_im1, input_im1);
492
210k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
843k
        for (n = 0; n < 6; n += 2)
495
632k
        {
496
632k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
632k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
632k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
632k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
632k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
632k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
632k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
632k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
632k
        }
506
210k
    }
507
6.83k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
6.83k
{
467
6.83k
    uint8_t i, n;
468
6.83k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
6.83k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
6.83k
    (void)hyb;  /* TODO: remove parameter? */
471
472
217k
    for (i = 0; i < frame_len; i++)
473
210k
    {
474
1.47M
        for (n = 0; n < 6; n++)
475
1.26M
        {
476
1.26M
            if (n == 0)
477
210k
            {
478
210k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
210k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.05M
            } else {
481
1.05M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.05M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.05M
            }
484
1.26M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.26M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.26M
        }
487
488
210k
        DCT3_6_unscaled(out_re1, input_re1);
489
210k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
210k
        DCT3_6_unscaled(out_im1, input_im1);
492
210k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
843k
        for (n = 0; n < 6; n += 2)
495
632k
        {
496
632k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
632k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
632k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
632k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
632k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
632k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
632k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
632k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
632k
        }
506
210k
    }
507
6.83k
}
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
19.9k
{
515
19.9k
    uint8_t k, n, band;
516
19.9k
    uint8_t offset = 0;
517
19.9k
    uint8_t qmf_bands = (use34) ? 5 : 3;
518
19.9k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
519
520
93.4k
    for (band = 0; band < qmf_bands; band++)
521
73.4k
    {
522
        /* build working buffer */
523
73.4k
        memcpy(hyb->work, hyb->buffer[band], 12 * sizeof(qmf_t));
524
525
        /* add new samples */
526
2.36M
        for (n = 0; n < hyb->frame_len; n++)
527
2.28M
        {
528
2.28M
            QMF_RE(hyb->work[12 + n]) = QMF_RE(X[n + 6 /*delay*/][band]);
529
2.28M
            QMF_IM(hyb->work[12 + n]) = QMF_IM(X[n + 6 /*delay*/][band]);
530
2.28M
        }
531
532
        /* store samples */
533
73.4k
        memcpy(hyb->buffer[band], hyb->work + hyb->frame_len, 12 * sizeof(qmf_t));
534
535
536
73.4k
        switch(resolution[band])
537
73.4k
        {
538
26.2k
        case 2:
539
            /* Type B real filter, Q[p] = 2 */
540
26.2k
            channel_filter2(hyb, hyb->frame_len, p2_13_20, hyb->work, hyb->temp);
541
26.2k
            break;
542
20.4k
        case 4:
543
            /* Type A complex filter, Q[p] = 4 */
544
20.4k
            channel_filter4(hyb, hyb->frame_len, p4_13_34, hyb->work, hyb->temp);
545
20.4k
            break;
546
19.9k
        case 8:
547
            /* Type A complex filter, Q[p] = 8 */
548
19.9k
            channel_filter8(hyb, hyb->frame_len, (use34) ? p8_13_34 : p8_13_20,
549
19.9k
                hyb->work, hyb->temp);
550
19.9k
            break;
551
6.83k
        case 12:
552
            /* Type A complex filter, Q[p] = 12 */
553
6.83k
            channel_filter12(hyb, hyb->frame_len, p12_13_34, hyb->work, hyb->temp);
554
6.83k
            break;
555
73.4k
        }
556
557
2.36M
        for (n = 0; n < hyb->frame_len; n++)
558
2.28M
        {
559
13.9M
            for (k = 0; k < resolution[band]; k++)
560
11.6M
            {
561
11.6M
                QMF_RE(X_hybrid[n][offset + k]) = QMF_RE(hyb->temp[n][k]);
562
11.6M
                QMF_IM(X_hybrid[n][offset + k]) = QMF_IM(hyb->temp[n][k]);
563
11.6M
            }
564
2.28M
        }
565
73.4k
        offset += resolution[band];
566
73.4k
    }
567
568
    /* group hybrid channels */
569
19.9k
    if (!use34)
570
13.1k
    {
571
424k
        for (n = 0; n < numTimeSlotsRate; n++)
572
411k
        {
573
411k
            QMF_RE(X_hybrid[n][3]) += QMF_RE(X_hybrid[n][4]);
574
411k
            QMF_IM(X_hybrid[n][3]) += QMF_IM(X_hybrid[n][4]);
575
411k
            QMF_RE(X_hybrid[n][4]) = 0;
576
411k
            QMF_IM(X_hybrid[n][4]) = 0;
577
578
411k
            QMF_RE(X_hybrid[n][2]) += QMF_RE(X_hybrid[n][5]);
579
411k
            QMF_IM(X_hybrid[n][2]) += QMF_IM(X_hybrid[n][5]);
580
411k
            QMF_RE(X_hybrid[n][5]) = 0;
581
411k
            QMF_IM(X_hybrid[n][5]) = 0;
582
411k
        }
583
13.1k
    }
584
19.9k
}
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
39.8k
{
589
39.8k
    uint8_t k, n, band;
590
39.8k
    uint8_t offset = 0;
591
39.8k
    uint8_t qmf_bands = (use34) ? 5 : 3;
592
39.8k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
593
39.8k
    (void)numTimeSlotsRate;  /* TODO: remove parameter? */
594
595
186k
    for(band = 0; band < qmf_bands; band++)
596
146k
    {
597
4.72M
        for (n = 0; n < hyb->frame_len; n++)
598
4.57M
        {
599
4.57M
            QMF_RE(X[n][band]) = 0;
600
4.57M
            QMF_IM(X[n][band]) = 0;
601
602
27.9M
            for (k = 0; k < resolution[band]; k++)
603
23.3M
            {
604
23.3M
                QMF_RE(X[n][band]) += QMF_RE(X_hybrid[n][offset + k]);
605
23.3M
                QMF_IM(X[n][band]) += QMF_IM(X_hybrid[n][offset + k]);
606
23.3M
            }
607
4.57M
        }
608
146k
        offset += resolution[band];
609
146k
    }
610
39.8k
}
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
457k
{
615
457k
    if (i < min)
616
57.4k
        return min;
617
399k
    else if (i > max)
618
5.86k
        return max;
619
393k
    else
620
393k
        return i;
621
457k
}
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
71.6k
{
630
71.6k
    int8_t i;
631
632
71.6k
    if (enable == 1)
633
35.8k
    {
634
35.8k
        if (dt_flag == 0)
635
21.6k
        {
636
            /* delta coded in frequency direction */
637
21.6k
            index[0] = 0 + index[0];
638
21.6k
            index[0] = delta_clip(index[0], min_index, max_index);
639
640
295k
            for (i = 1; i < nr_par; i++)
641
273k
            {
642
273k
                index[i] = index[i-1] + index[i];
643
273k
                index[i] = delta_clip(index[i], min_index, max_index);
644
273k
            }
645
21.6k
        } else {
646
            /* delta coded in time direction */
647
176k
            for (i = 0; i < nr_par; i++)
648
161k
            {
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
161k
                index[i] = index_prev[i*stride] + index[i];
656
                //tmp2 = index[i];
657
161k
                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
161k
            }
667
14.2k
        }
668
35.8k
    } else {
669
        /* set indices to zero */
670
59.9k
        for (i = 0; i < nr_par; i++)
671
24.2k
        {
672
24.2k
            index[i] = 0;
673
24.2k
        }
674
35.7k
    }
675
676
    /* coarse */
677
71.6k
    if (stride == 2)
678
47.8k
    {
679
303k
        for (i = (nr_par<<1)-1; i > 0; i--)
680
255k
        {
681
255k
            index[i] = index[i>>1];
682
255k
        }
683
47.8k
    }
684
71.6k
}
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
71.6k
{
692
71.6k
    int8_t i;
693
694
71.6k
    if (enable == 1)
695
24.3k
    {
696
24.3k
        if (dt_flag == 0)
697
14.6k
        {
698
            /* delta coded in frequency direction */
699
14.6k
            index[0] = 0 + index[0];
700
14.6k
            index[0] &= and_modulo;
701
702
57.5k
            for (i = 1; i < nr_par; i++)
703
42.9k
            {
704
42.9k
                index[i] = index[i-1] + index[i];
705
42.9k
                index[i] &= and_modulo;
706
42.9k
            }
707
14.6k
        } else {
708
            /* delta coded in time direction */
709
32.5k
            for (i = 0; i < nr_par; i++)
710
22.8k
            {
711
22.8k
                index[i] = index_prev[i*stride] + index[i];
712
22.8k
                index[i] &= and_modulo;
713
22.8k
            }
714
9.68k
        }
715
47.3k
    } else {
716
        /* set indices to zero */
717
169k
        for (i = 0; i < nr_par; i++)
718
122k
        {
719
122k
            index[i] = 0;
720
122k
        }
721
47.3k
    }
722
723
    /* coarse */
724
71.6k
    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
71.6k
}
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
26.2k
{
766
26.2k
    index[0] = index[0];
767
26.2k
    index[1] = (index[0] + index[1])/2;
768
26.2k
    index[2] = index[1];
769
26.2k
    index[3] = index[2];
770
26.2k
    index[4] = (index[2] + index[3])/2;
771
26.2k
    index[5] = index[3];
772
26.2k
    index[6] = index[4];
773
26.2k
    index[7] = index[4];
774
26.2k
    index[8] = index[5];
775
26.2k
    index[9] = index[5];
776
26.2k
    index[10] = index[6];
777
26.2k
    index[11] = index[7];
778
26.2k
    index[12] = index[8];
779
26.2k
    index[13] = index[8];
780
26.2k
    index[14] = index[9];
781
26.2k
    index[15] = index[9];
782
26.2k
    index[16] = index[10];
783
784
26.2k
    if (bins == 34)
785
12.1k
    {
786
12.1k
        index[17] = index[11];
787
12.1k
        index[18] = index[12];
788
12.1k
        index[19] = index[13];
789
12.1k
        index[20] = index[14];
790
12.1k
        index[21] = index[14];
791
12.1k
        index[22] = index[15];
792
12.1k
        index[23] = index[15];
793
12.1k
        index[24] = index[16];
794
12.1k
        index[25] = index[16];
795
12.1k
        index[26] = index[17];
796
12.1k
        index[27] = index[17];
797
12.1k
        index[28] = index[18];
798
12.1k
        index[29] = index[18];
799
12.1k
        index[30] = index[18];
800
12.1k
        index[31] = index[18];
801
12.1k
        index[32] = index[19];
802
12.1k
        index[33] = index[19];
803
12.1k
    }
804
26.2k
}
805
806
/* parse the bitstream data decoded in ps_data() */
807
static void ps_data_decode(ps_info *ps)
808
19.9k
{
809
19.9k
    uint8_t env, bin;
810
811
    /* ps data not available, use data from previous frame */
812
19.9k
    if (ps->ps_data_available == 0)
813
4.98k
    {
814
4.98k
        ps->num_env = 0;
815
4.98k
    }
816
817
55.7k
    for (env = 0; env < ps->num_env; env++)
818
35.8k
    {
819
35.8k
        int8_t *iid_index_prev;
820
35.8k
        int8_t *icc_index_prev;
821
35.8k
        int8_t *ipd_index_prev;
822
35.8k
        int8_t *opd_index_prev;
823
824
35.8k
        int8_t num_iid_steps = (ps->iid_mode < 3) ? 7 : 15 /*fine quant*/;
825
826
35.8k
        if (env == 0)
827
10.7k
        {
828
            /* take last envelope from previous frame */
829
10.7k
            iid_index_prev = ps->iid_index_prev;
830
10.7k
            icc_index_prev = ps->icc_index_prev;
831
10.7k
            ipd_index_prev = ps->ipd_index_prev;
832
10.7k
            opd_index_prev = ps->opd_index_prev;
833
25.0k
        } else {
834
            /* take index values from previous envelope */
835
25.0k
            iid_index_prev = ps->iid_index[env - 1];
836
25.0k
            icc_index_prev = ps->icc_index[env - 1];
837
25.0k
            ipd_index_prev = ps->ipd_index[env - 1];
838
25.0k
            opd_index_prev = ps->opd_index[env - 1];
839
25.0k
        }
840
841
//        iid = 1;
842
        /* delta decode iid parameters */
843
35.8k
        delta_decode(ps->enable_iid, ps->iid_index[env], iid_index_prev,
844
35.8k
            ps->iid_dt[env], ps->nr_iid_par,
845
35.8k
            (ps->iid_mode == 0 || ps->iid_mode == 3) ? 2 : 1,
846
35.8k
            -num_iid_steps, num_iid_steps);
847
//        iid = 0;
848
849
        /* delta decode icc parameters */
850
35.8k
        delta_decode(ps->enable_icc, ps->icc_index[env], icc_index_prev,
851
35.8k
            ps->icc_dt[env], ps->nr_icc_par,
852
35.8k
            (ps->icc_mode == 0 || ps->icc_mode == 3) ? 2 : 1,
853
35.8k
            0, 7);
854
855
        /* delta modulo decode ipd parameters */
856
35.8k
        delta_modulo_decode(ps->enable_ipdopd, ps->ipd_index[env], ipd_index_prev,
857
35.8k
            ps->ipd_dt[env], ps->nr_ipdopd_par, 1, 7);
858
859
        /* delta modulo decode opd parameters */
860
35.8k
        delta_modulo_decode(ps->enable_ipdopd, ps->opd_index[env], opd_index_prev,
861
35.8k
            ps->opd_dt[env], ps->nr_ipdopd_par, 1, 7);
862
35.8k
    }
863
864
    /* handle error case */
865
19.9k
    if (ps->num_env == 0)
866
9.16k
    {
867
        /* force to 1 */
868
9.16k
        ps->num_env = 1;
869
870
9.16k
        if (ps->enable_iid)
871
6.36k
        {
872
222k
            for (bin = 0; bin < 34; bin++)
873
216k
                ps->iid_index[0][bin] = ps->iid_index_prev[bin];
874
6.36k
        } else {
875
98.2k
            for (bin = 0; bin < 34; bin++)
876
95.4k
                ps->iid_index[0][bin] = 0;
877
2.80k
        }
878
879
9.16k
        if (ps->enable_icc)
880
4.12k
        {
881
144k
            for (bin = 0; bin < 34; bin++)
882
140k
                ps->icc_index[0][bin] = ps->icc_index_prev[bin];
883
5.04k
        } else {
884
176k
            for (bin = 0; bin < 34; bin++)
885
171k
                ps->icc_index[0][bin] = 0;
886
5.04k
        }
887
888
9.16k
        if (ps->enable_ipdopd)
889
1.10k
        {
890
19.9k
            for (bin = 0; bin < 17; bin++)
891
18.8k
            {
892
18.8k
                ps->ipd_index[0][bin] = ps->ipd_index_prev[bin];
893
18.8k
                ps->opd_index[0][bin] = ps->opd_index_prev[bin];
894
18.8k
            }
895
8.05k
        } else {
896
145k
            for (bin = 0; bin < 17; bin++)
897
137k
            {
898
137k
                ps->ipd_index[0][bin] = 0;
899
137k
                ps->opd_index[0][bin] = 0;
900
137k
            }
901
8.05k
        }
902
9.16k
    }
903
904
    /* update previous indices */
905
697k
    for (bin = 0; bin < 34; bin++)
906
677k
        ps->iid_index_prev[bin] = ps->iid_index[ps->num_env-1][bin];
907
697k
    for (bin = 0; bin < 34; bin++)
908
677k
        ps->icc_index_prev[bin] = ps->icc_index[ps->num_env-1][bin];
909
358k
    for (bin = 0; bin < 17; bin++)
910
338k
    {
911
338k
        ps->ipd_index_prev[bin] = ps->ipd_index[ps->num_env-1][bin];
912
338k
        ps->opd_index_prev[bin] = ps->opd_index[ps->num_env-1][bin];
913
338k
    }
914
915
19.9k
    ps->ps_data_available = 0;
916
917
19.9k
    if (ps->frame_class == 0)
918
11.7k
    {
919
11.7k
        ps->border_position[0] = 0;
920
21.6k
        for (env = 1; env < ps->num_env; env++)
921
9.94k
        {
922
9.94k
            ps->border_position[env] = (env * ps->numTimeSlotsRate) / ps->num_env;
923
9.94k
        }
924
11.7k
        ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
925
11.7k
    } else {
926
8.22k
        ps->border_position[0] = 0;
927
928
8.22k
        if (ps->border_position[ps->num_env] < ps->numTimeSlotsRate)
929
6.04k
        {
930
211k
            for (bin = 0; bin < 34; bin++)
931
205k
            {
932
205k
                ps->iid_index[ps->num_env][bin] = ps->iid_index[ps->num_env-1][bin];
933
205k
                ps->icc_index[ps->num_env][bin] = ps->icc_index[ps->num_env-1][bin];
934
205k
            }
935
108k
            for (bin = 0; bin < 17; bin++)
936
102k
            {
937
102k
                ps->ipd_index[ps->num_env][bin] = ps->ipd_index[ps->num_env-1][bin];
938
102k
                ps->opd_index[ps->num_env][bin] = ps->opd_index[ps->num_env-1][bin];
939
102k
            }
940
6.04k
            ps->num_env++;
941
6.04k
            ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
942
6.04k
        }
943
944
29.3k
        for (env = 1; env < ps->num_env; env++)
945
21.1k
        {
946
21.1k
            int8_t thr = ps->numTimeSlotsRate - (ps->num_env - env);
947
948
21.1k
            if (ps->border_position[env] > thr)
949
4.90k
            {
950
4.90k
                ps->border_position[env] = thr;
951
16.2k
            } else {
952
16.2k
                thr = ps->border_position[env-1]+1;
953
16.2k
                if (ps->border_position[env] < thr)
954
8.41k
                {
955
8.41k
                    ps->border_position[env] = thr;
956
8.41k
                }
957
16.2k
            }
958
21.1k
        }
959
8.22k
    }
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
19.9k
    if (ps->use34hybrid_bands)
981
6.83k
    {
982
19.8k
        for (env = 0; env < ps->num_env; env++)
983
12.9k
        {
984
12.9k
            if (ps->iid_mode != 2 && ps->iid_mode != 5)
985
7.05k
                map20indexto34(ps->iid_index[env], 34);
986
12.9k
            if (ps->icc_mode != 2 && ps->icc_mode != 5)
987
5.12k
                map20indexto34(ps->icc_index[env], 34);
988
12.9k
            if (ps->ipd_mode != 2 && ps->ipd_mode != 5)
989
7.05k
            {
990
7.05k
                map20indexto34(ps->ipd_index[env], 17);
991
7.05k
                map20indexto34(ps->opd_index[env], 17);
992
7.05k
            }
993
12.9k
        }
994
6.83k
    }
995
19.9k
#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
19.9k
}
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
19.9k
{
1042
19.9k
    uint8_t gr, n, bk;
1043
19.9k
    uint8_t temp_delay = 0;
1044
19.9k
    uint8_t sb, maxsb;
1045
19.9k
    const complex_t *Phi_Fract_SubQmf;
1046
19.9k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
19.9k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
19.9k
    real_t P[32][34];
1049
19.9k
    real_t G_TransientRatio[32][34] = {{0}};
1050
19.9k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
19.9k
    if (ps->use34hybrid_bands)
1055
6.83k
    {
1056
6.83k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
13.1k
    } else{
1058
13.1k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
13.1k
    }
1060
1061
    /* clear the energy values */
1062
657k
    for (n = 0; n < 32; n++)
1063
638k
    {
1064
22.3M
        for (bk = 0; bk < 34; bk++)
1065
21.6M
        {
1066
21.6M
            P[n][bk] = 0;
1067
21.6M
        }
1068
638k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
649k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
629k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
629k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
629k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
2.18M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
1.55M
        {
1081
50.1M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
48.5M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
48.5M
                if (gr < ps->num_hybrid_groups)
1089
10.8M
                {
1090
10.8M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
10.8M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
37.6M
                } else {
1093
37.6M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
37.6M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
37.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
22.3M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
22.3M
                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.2M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
48.5M
            }
1109
1.55M
        }
1110
629k
    }
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
514k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
494k
    {
1129
15.9M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
15.4M
        {
1131
15.4M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
15.4M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
15.4M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
170k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
15.4M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
15.4M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
15.4M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
15.4M
            nrg = ps->P_prev[bk];
1144
15.4M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
15.4M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
15.4M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
15.2M
            {
1150
15.2M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
15.2M
            } else {
1152
154k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
154k
            }
1154
15.4M
        }
1155
494k
    }
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
649k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
629k
    {
1174
629k
        if (gr < ps->num_hybrid_groups)
1175
349k
            maxsb = ps->group_border[gr] + 1;
1176
280k
        else
1177
280k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
2.18M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
1.55M
        {
1182
1.55M
            real_t g_DecaySlope;
1183
1.55M
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
1.55M
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
369k
            {
1188
369k
                g_DecaySlope = FRAC_CONST(1.0);
1189
1.18M
            } else {
1190
1.18M
                int8_t decay = ps->decay_cutoff - sb;
1191
1.18M
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
803k
                {
1193
803k
                    g_DecaySlope = 0;
1194
803k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
378k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
378k
                }
1198
1.18M
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
6.20M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
4.65M
            {
1203
4.65M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
4.65M
            }
1205
1206
1207
            /* set delay indices */
1208
1.55M
            temp_delay = ps->saved_delay;
1209
6.20M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
4.65M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
50.1M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
48.5M
            {
1214
48.5M
                complex_t tmp, tmp0, R0;
1215
48.5M
                uint8_t m;
1216
1217
48.5M
                if (gr < ps->num_hybrid_groups)
1218
10.8M
                {
1219
                    /* hybrid filterbank input */
1220
10.8M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
10.8M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
37.6M
                } else {
1223
                    /* QMF filterbank input */
1224
37.6M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
37.6M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
37.6M
                }
1227
1228
48.5M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
25.5M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
25.5M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
25.5M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
25.5M
                    RE(R0) = RE(tmp);
1236
25.5M
                    IM(R0) = IM(tmp);
1237
25.5M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
25.5M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
25.5M
                } else {
1240
                    /* allpass filter */
1241
22.9M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
22.9M
                    if (gr < ps->num_hybrid_groups)
1245
10.8M
                    {
1246
                        /* select data from the hybrid subbands */
1247
10.8M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
10.8M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
10.8M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
10.8M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
10.8M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
10.8M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
12.0M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
12.0M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
12.0M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
12.0M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
12.0M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
12.0M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
12.0M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
12.0M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
22.9M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
22.9M
                    RE(R0) = RE(tmp);
1271
22.9M
                    IM(R0) = IM(tmp);
1272
91.8M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
68.8M
                    {
1274
68.8M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
68.8M
                        if (gr < ps->num_hybrid_groups)
1278
32.6M
                        {
1279
                            /* select data from the hybrid subbands */
1280
32.6M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
32.6M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
32.6M
                            if (ps->use34hybrid_bands)
1284
20.2M
                            {
1285
20.2M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
20.2M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
20.2M
                            } else {
1288
12.3M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
12.3M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
12.3M
                            }
1291
36.1M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
36.1M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
36.1M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
36.1M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
36.1M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
36.1M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
68.8M
                        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
68.8M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
68.8M
                        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
68.8M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
68.8M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
68.8M
                        if (gr < ps->num_hybrid_groups)
1314
32.6M
                        {
1315
32.6M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
32.6M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
36.1M
                        } else {
1318
36.1M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
36.1M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
36.1M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
68.8M
                        RE(R0) = RE(tmp);
1324
68.8M
                        IM(R0) = IM(tmp);
1325
68.8M
                    }
1326
22.9M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
48.5M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
48.5M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
48.5M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
48.5M
                if (gr < ps->num_hybrid_groups)
1336
10.8M
                {
1337
                    /* hybrid */
1338
10.8M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
10.8M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
37.6M
                } else {
1341
                    /* QMF */
1342
37.6M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
37.6M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
37.6M
                }
1345
1346
                /* Update delay buffer index */
1347
48.5M
                if (++temp_delay >= 2)
1348
24.2M
                {
1349
24.2M
                    temp_delay = 0;
1350
24.2M
                }
1351
1352
                /* update delay indices */
1353
48.5M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
25.5M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
25.5M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
18.5M
                    {
1358
18.5M
                        ps->delay_buf_index_delay[sb] = 0;
1359
18.5M
                    }
1360
25.5M
                }
1361
1362
194M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
145M
                {
1364
145M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
37.2M
                    {
1366
37.2M
                        temp_delay_ser[m] = 0;
1367
37.2M
                    }
1368
145M
                }
1369
48.5M
            }
1370
1.55M
        }
1371
629k
    }
1372
1373
    /* update delay indices */
1374
19.9k
    ps->saved_delay = temp_delay;
1375
79.7k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
59.8k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
19.9k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
9.22k
{
1042
9.22k
    uint8_t gr, n, bk;
1043
9.22k
    uint8_t temp_delay = 0;
1044
9.22k
    uint8_t sb, maxsb;
1045
9.22k
    const complex_t *Phi_Fract_SubQmf;
1046
9.22k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
9.22k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
9.22k
    real_t P[32][34];
1049
9.22k
    real_t G_TransientRatio[32][34] = {{0}};
1050
9.22k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
9.22k
    if (ps->use34hybrid_bands)
1055
2.91k
    {
1056
2.91k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
6.30k
    } else{
1058
6.30k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
6.30k
    }
1060
1061
    /* clear the energy values */
1062
304k
    for (n = 0; n < 32; n++)
1063
295k
    {
1064
10.3M
        for (bk = 0; bk < 34; bk++)
1065
10.0M
        {
1066
10.0M
            P[n][bk] = 0;
1067
10.0M
        }
1068
295k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
293k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
284k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
284k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
284k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
997k
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
712k
        {
1081
23.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
22.3M
            {
1083
22.3M
#ifdef FIXED_POINT
1084
22.3M
                uint32_t in_re, in_im;
1085
22.3M
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
22.3M
                if (gr < ps->num_hybrid_groups)
1089
4.86M
                {
1090
4.86M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
4.86M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
17.4M
                } else {
1093
17.4M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
17.4M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
17.4M
                }
1096
1097
                /* accumulate energy */
1098
22.3M
#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
22.3M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
22.3M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
22.3M
                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
22.3M
            }
1109
712k
        }
1110
284k
    }
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
234k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
225k
    {
1129
7.26M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
7.03M
        {
1131
7.03M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
7.03M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
7.03M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
25.7k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
7.03M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
7.03M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
7.03M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
7.03M
            nrg = ps->P_prev[bk];
1144
7.03M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
7.03M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
7.03M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
7.02M
            {
1150
7.02M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
7.02M
            } else {
1152
14.5k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
14.5k
            }
1154
7.03M
        }
1155
225k
    }
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
293k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
284k
    {
1174
284k
        if (gr < ps->num_hybrid_groups)
1175
156k
            maxsb = ps->group_border[gr] + 1;
1176
128k
        else
1177
128k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
997k
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
712k
        {
1182
712k
            real_t g_DecaySlope;
1183
712k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
712k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
165k
            {
1188
165k
                g_DecaySlope = FRAC_CONST(1.0);
1189
547k
            } else {
1190
547k
                int8_t decay = ps->decay_cutoff - sb;
1191
547k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
372k
                {
1193
372k
                    g_DecaySlope = 0;
1194
372k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
175k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
175k
                }
1198
547k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
2.85M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.13M
            {
1203
2.13M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.13M
            }
1205
1206
1207
            /* set delay indices */
1208
712k
            temp_delay = ps->saved_delay;
1209
2.85M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.13M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
23.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
22.3M
            {
1214
22.3M
                complex_t tmp, tmp0, R0;
1215
22.3M
                uint8_t m;
1216
1217
22.3M
                if (gr < ps->num_hybrid_groups)
1218
4.86M
                {
1219
                    /* hybrid filterbank input */
1220
4.86M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
4.86M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
17.4M
                } else {
1223
                    /* QMF filterbank input */
1224
17.4M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
17.4M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
17.4M
                }
1227
1228
22.3M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
11.8M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
11.8M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
11.8M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
11.8M
                    RE(R0) = RE(tmp);
1236
11.8M
                    IM(R0) = IM(tmp);
1237
11.8M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
11.8M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
11.8M
                } else {
1240
                    /* allpass filter */
1241
10.4M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
10.4M
                    if (gr < ps->num_hybrid_groups)
1245
4.86M
                    {
1246
                        /* select data from the hybrid subbands */
1247
4.86M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
4.86M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
4.86M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
4.86M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
4.86M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
4.86M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
5.59M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
5.59M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
5.59M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
5.59M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
5.59M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
5.59M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
5.59M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
5.59M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
10.4M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
10.4M
                    RE(R0) = RE(tmp);
1271
10.4M
                    IM(R0) = IM(tmp);
1272
41.8M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
31.3M
                    {
1274
31.3M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
31.3M
                        if (gr < ps->num_hybrid_groups)
1278
14.6M
                        {
1279
                            /* select data from the hybrid subbands */
1280
14.6M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
14.6M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
14.6M
                            if (ps->use34hybrid_bands)
1284
8.64M
                            {
1285
8.64M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
8.64M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
8.64M
                            } else {
1288
5.96M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
5.96M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
5.96M
                            }
1291
16.7M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
16.7M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
16.7M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
16.7M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
16.7M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
16.7M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
31.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
31.3M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
31.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
31.3M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
31.3M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
31.3M
                        if (gr < ps->num_hybrid_groups)
1314
14.6M
                        {
1315
14.6M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
14.6M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
16.7M
                        } else {
1318
16.7M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
16.7M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
16.7M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
31.3M
                        RE(R0) = RE(tmp);
1324
31.3M
                        IM(R0) = IM(tmp);
1325
31.3M
                    }
1326
10.4M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
22.3M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
22.3M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
22.3M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
22.3M
                if (gr < ps->num_hybrid_groups)
1336
4.86M
                {
1337
                    /* hybrid */
1338
4.86M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
4.86M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
17.4M
                } else {
1341
                    /* QMF */
1342
17.4M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
17.4M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
17.4M
                }
1345
1346
                /* Update delay buffer index */
1347
22.3M
                if (++temp_delay >= 2)
1348
11.1M
                {
1349
11.1M
                    temp_delay = 0;
1350
11.1M
                }
1351
1352
                /* update delay indices */
1353
22.3M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
11.8M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
11.8M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
8.59M
                    {
1358
8.59M
                        ps->delay_buf_index_delay[sb] = 0;
1359
8.59M
                    }
1360
11.8M
                }
1361
1362
89.2M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
66.9M
                {
1364
66.9M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
17.0M
                    {
1366
17.0M
                        temp_delay_ser[m] = 0;
1367
17.0M
                    }
1368
66.9M
                }
1369
22.3M
            }
1370
712k
        }
1371
284k
    }
1372
1373
    /* update delay indices */
1374
9.22k
    ps->saved_delay = temp_delay;
1375
36.8k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
27.6k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
9.22k
}
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.92k
    {
1056
3.92k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
6.79k
    } else{
1058
6.79k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
6.79k
    }
1060
1061
    /* clear the energy values */
1062
353k
    for (n = 0; n < 32; n++)
1063
342k
    {
1064
12.0M
        for (bk = 0; bk < 34; bk++)
1065
11.6M
        {
1066
11.6M
            P[n][bk] = 0;
1067
11.6M
        }
1068
342k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
356k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
345k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
345k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
345k
        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
839k
        {
1081
27.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
26.2M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
26.2M
                if (gr < ps->num_hybrid_groups)
1089
6.01M
                {
1090
6.01M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
6.01M
                    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.2M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
26.2M
#endif
1108
26.2M
            }
1109
839k
        }
1110
345k
    }
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
269k
    {
1129
8.67M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
8.40M
        {
1131
8.40M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
8.40M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
8.40M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
144k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
8.40M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
8.40M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
8.40M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
8.40M
            nrg = ps->P_prev[bk];
1144
8.40M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
8.40M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
8.40M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
8.26M
            {
1150
8.26M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
8.26M
            } else {
1152
140k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
140k
            }
1154
8.40M
        }
1155
269k
    }
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
356k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
345k
    {
1174
345k
        if (gr < ps->num_hybrid_groups)
1175
193k
            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
839k
        {
1182
839k
            real_t g_DecaySlope;
1183
839k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
839k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
204k
            {
1188
204k
                g_DecaySlope = FRAC_CONST(1.0);
1189
635k
            } else {
1190
635k
                int8_t decay = ps->decay_cutoff - sb;
1191
635k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
431k
                {
1193
431k
                    g_DecaySlope = 0;
1194
431k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
203k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
203k
                }
1198
635k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
3.35M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.51M
            {
1203
2.51M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.51M
            }
1205
1206
1207
            /* set delay indices */
1208
839k
            temp_delay = ps->saved_delay;
1209
3.35M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.51M
                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.2M
            {
1214
26.2M
                complex_t tmp, tmp0, R0;
1215
26.2M
                uint8_t m;
1216
1217
26.2M
                if (gr < ps->num_hybrid_groups)
1218
6.01M
                {
1219
                    /* hybrid filterbank input */
1220
6.01M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
6.01M
                    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.2M
                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
6.01M
                    {
1246
                        /* select data from the hybrid subbands */
1247
6.01M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
6.01M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
6.01M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
6.01M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
6.01M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
6.01M
                        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.9M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
37.4M
                    {
1274
37.4M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
37.4M
                        if (gr < ps->num_hybrid_groups)
1278
18.0M
                        {
1279
                            /* select data from the hybrid subbands */
1280
18.0M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
18.0M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
18.0M
                            if (ps->use34hybrid_bands)
1284
11.6M
                            {
1285
11.6M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
11.6M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
11.6M
                            } else {
1288
6.43M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
6.43M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
6.43M
                            }
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.4M
                        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.4M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
37.4M
                        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.4M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
37.4M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
37.4M
                        if (gr < ps->num_hybrid_groups)
1314
18.0M
                        {
1315
18.0M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
18.0M
                            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.4M
                        RE(R0) = RE(tmp);
1324
37.4M
                        IM(R0) = IM(tmp);
1325
37.4M
                    }
1326
12.4M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
26.2M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
26.2M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
26.2M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
26.2M
                if (gr < ps->num_hybrid_groups)
1336
6.01M
                {
1337
                    /* hybrid */
1338
6.01M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
6.01M
                    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.2M
                if (++temp_delay >= 2)
1348
13.1M
                {
1349
13.1M
                    temp_delay = 0;
1350
13.1M
                }
1351
1352
                /* update delay indices */
1353
26.2M
                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.99M
                    {
1358
9.99M
                        ps->delay_buf_index_delay[sb] = 0;
1359
9.99M
                    }
1360
13.7M
                }
1361
1362
105M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
78.7M
                {
1364
78.7M
                    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.7M
                }
1369
26.2M
            }
1370
839k
        }
1371
345k
    }
1372
1373
    /* update delay indices */
1374
10.7k
    ps->saved_delay = temp_delay;
1375
42.8k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
32.1k
        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
406k
{
1438
#ifdef FIXED_POINT
1439
457k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
#define ALPHA FRAC_CONST(0.948059448969)
1441
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
228k
    real_t abs_inphase = ps_abs(RE(c));
1444
228k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
228k
    if (abs_inphase > abs_quadrature) {
1447
193k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
193k
    } else {
1449
35.7k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
35.7k
    }
1451
#else
1452
177k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
406k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
228k
{
1438
228k
#ifdef FIXED_POINT
1439
228k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
228k
#define ALPHA FRAC_CONST(0.948059448969)
1441
228k
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
228k
    real_t abs_inphase = ps_abs(RE(c));
1444
228k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
228k
    if (abs_inphase > abs_quadrature) {
1447
193k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
193k
    } else {
1449
35.7k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
35.7k
    }
1451
#else
1452
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
228k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
177k
{
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
177k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
177k
#endif
1454
177k
}
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
19.9k
{
1459
19.9k
    uint8_t n;
1460
19.9k
    uint8_t gr;
1461
19.9k
    uint8_t bk = 0;
1462
19.9k
    uint8_t sb, maxsb;
1463
19.9k
    uint8_t env;
1464
19.9k
    uint8_t nr_ipdopd_par;
1465
19.9k
    complex_t h11, h12, h21, h22;  // COEF
1466
19.9k
    complex_t H11, H12, H21, H22;  // COEF
1467
19.9k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
19.9k
    complex_t tempLeft, tempRight; // FRAC
1469
19.9k
    complex_t phaseLeft, phaseRight; // FRAC
1470
19.9k
    real_t L;
1471
19.9k
    const real_t *sf_iid;
1472
19.9k
    uint8_t no_iid_steps;
1473
1474
19.9k
    if (ps->iid_mode >= 3)
1475
7.79k
    {
1476
7.79k
        no_iid_steps = 15;
1477
7.79k
        sf_iid = sf_iid_fine;
1478
12.1k
    } else {
1479
12.1k
        no_iid_steps = 7;
1480
12.1k
        sf_iid = sf_iid_normal;
1481
12.1k
    }
1482
1483
19.9k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
12.0k
    {
1485
12.0k
        nr_ipdopd_par = 11; /* resolution */
1486
12.0k
    } else {
1487
7.90k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
7.90k
    }
1489
1490
649k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
629k
    {
1492
629k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
629k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
2.11M
        for (env = 0; env < ps->num_env; env++)
1498
1.48M
        {
1499
1.48M
            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.48M
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
337
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
337
                    -no_iid_steps);
1507
337
                ps->iid_index[env][bk] = -no_iid_steps;
1508
337
                abs_iid = no_iid_steps;
1509
1.48M
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
237
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
237
                    no_iid_steps);
1512
237
                ps->iid_index[env][bk] = no_iid_steps;
1513
237
                abs_iid = no_iid_steps;
1514
237
            }
1515
1.48M
            if (ps->icc_index[env][bk] < 0) {
1516
653
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
653
                ps->icc_index[env][bk] = 0;
1518
1.48M
            } 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.48M
            if (ps->icc_mode < 3)
1524
882k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
882k
                real_t c_1, c_2;  // COEF
1527
882k
                real_t cosa, sina;  // COEF
1528
882k
                real_t cosb, sinb;  // COEF
1529
882k
                real_t ab1, ab2;  // COEF
1530
882k
                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
882k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
882k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
882k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
882k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
882k
                if (ps->iid_mode >= 3)
1550
276k
                {
1551
276k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
276k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
605k
                } else {
1554
605k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
605k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
605k
                }
1557
1558
882k
                ab1 = MUL_C(cosb, cosa);
1559
882k
                ab2 = MUL_C(sinb, sina);
1560
882k
                ab3 = MUL_C(sinb, cosa);
1561
882k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
882k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
882k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
882k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
882k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
882k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
603k
                real_t sina, cosa;  // COEF
1571
603k
                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
603k
                if (ps->iid_mode >= 3)
1607
387k
                {
1608
387k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
387k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
387k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
387k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
387k
                } else {
1613
216k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
216k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
216k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
216k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
216k
                }
1618
1619
603k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
603k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
603k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
603k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
603k
            }
1624
1.48M
            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.48M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
203k
            {
1632
203k
                int8_t i;
1633
203k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
203k
                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
114k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
114k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
114k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
114k
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
88.6k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
88.6k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
88.6k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
88.6k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
#endif
1652
1653
                /* save current value */
1654
203k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
203k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
203k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
203k
                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
114k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
114k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
114k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
114k
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
88.6k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
88.6k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
88.6k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
88.6k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
#endif
1672
1673
                /* ringbuffer index */
1674
203k
                if (i == 0)
1675
102k
                {
1676
102k
                    i = 2;
1677
102k
                }
1678
203k
                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
114k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
114k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
114k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
114k
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
88.6k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
88.6k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
88.6k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
88.6k
                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
203k
                xy = magnitude_c(tempRight);
1716
203k
                pq = magnitude_c(tempLeft);
1717
1718
203k
                if (xy != 0)
1719
203k
                {
1720
203k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
203k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
203k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
203k
                xypq = MUL_F(xy, pq);
1728
1729
203k
                if (xypq != 0)
1730
203k
                {
1731
203k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
203k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
203k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
203k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
203k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
203k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
203k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
203k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
203k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
203k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
203k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
203k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
203k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
203k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
203k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
1.48M
            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.48M
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
1.48M
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
1.48M
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
1.48M
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
1.48M
            RE(H11) = RE(ps->h11_prev[gr]);
1766
1.48M
            RE(H12) = RE(ps->h12_prev[gr]);
1767
1.48M
            RE(H21) = RE(ps->h21_prev[gr]);
1768
1.48M
            RE(H22) = RE(ps->h22_prev[gr]);
1769
1.48M
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
1.48M
            RE(ps->h11_prev[gr]) = RE(h11);
1772
1.48M
            RE(ps->h12_prev[gr]) = RE(h12);
1773
1.48M
            RE(ps->h21_prev[gr]) = RE(h21);
1774
1.48M
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
1.48M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
203k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
203k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
203k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
203k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
203k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
203k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
203k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
203k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
203k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
203k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
29.0k
                {
1792
29.0k
                    IM(deltaH11) = -IM(deltaH11);
1793
29.0k
                    IM(deltaH12) = -IM(deltaH12);
1794
29.0k
                    IM(deltaH21) = -IM(deltaH21);
1795
29.0k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
29.0k
                    IM(H11) = -IM(H11);
1798
29.0k
                    IM(H12) = -IM(H12);
1799
29.0k
                    IM(H21) = -IM(H21);
1800
29.0k
                    IM(H22) = -IM(H22);
1801
29.0k
                }
1802
1803
203k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
203k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
203k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
203k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
203k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
21.1M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
19.6M
            {
1812
                /* addition finalises the interpolation over every n */
1813
19.6M
                RE(H11) += RE(deltaH11);
1814
19.6M
                RE(H12) += RE(deltaH12);
1815
19.6M
                RE(H21) += RE(deltaH21);
1816
19.6M
                RE(H22) += RE(deltaH22);
1817
19.6M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
2.03M
                {
1819
2.03M
                    IM(H11) += IM(deltaH11);
1820
2.03M
                    IM(H12) += IM(deltaH12);
1821
2.03M
                    IM(H21) += IM(deltaH21);
1822
2.03M
                    IM(H22) += IM(deltaH22);
1823
2.03M
                }
1824
1825
                /* channel is an alias to the subband */
1826
68.1M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
48.5M
                {
1828
48.5M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
48.5M
                    if (gr < ps->num_hybrid_groups)
1832
10.8M
                    {
1833
10.8M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
10.8M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
10.8M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
10.8M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
37.6M
                    } else {
1838
37.6M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
37.6M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
37.6M
                        RE(inRight) = RE(X_right[n][sb]);
1841
37.6M
                        IM(inRight) = IM(X_right[n][sb]);
1842
37.6M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
48.5M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
48.5M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
48.5M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
48.5M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
48.5M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
2.04M
                    {
1855
                        /* apply rotation */
1856
2.04M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
2.04M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
2.04M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
2.04M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
2.04M
                    }
1861
1862
                    /* store final samples */
1863
48.5M
                    if (gr < ps->num_hybrid_groups)
1864
10.8M
                    {
1865
10.8M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
10.8M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
10.8M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
10.8M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
37.6M
                    } else {
1870
37.6M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
37.6M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
37.6M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
37.6M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
37.6M
                    }
1875
48.5M
                }
1876
19.6M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
1.48M
            ps->phase_hist++;
1880
1.48M
            if (ps->phase_hist == 2)
1881
742k
            {
1882
742k
                ps->phase_hist = 0;
1883
742k
            }
1884
1.48M
        }
1885
629k
    }
1886
19.9k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
9.22k
{
1459
9.22k
    uint8_t n;
1460
9.22k
    uint8_t gr;
1461
9.22k
    uint8_t bk = 0;
1462
9.22k
    uint8_t sb, maxsb;
1463
9.22k
    uint8_t env;
1464
9.22k
    uint8_t nr_ipdopd_par;
1465
9.22k
    complex_t h11, h12, h21, h22;  // COEF
1466
9.22k
    complex_t H11, H12, H21, H22;  // COEF
1467
9.22k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
9.22k
    complex_t tempLeft, tempRight; // FRAC
1469
9.22k
    complex_t phaseLeft, phaseRight; // FRAC
1470
9.22k
    real_t L;
1471
9.22k
    const real_t *sf_iid;
1472
9.22k
    uint8_t no_iid_steps;
1473
1474
9.22k
    if (ps->iid_mode >= 3)
1475
3.13k
    {
1476
3.13k
        no_iid_steps = 15;
1477
3.13k
        sf_iid = sf_iid_fine;
1478
6.09k
    } else {
1479
6.09k
        no_iid_steps = 7;
1480
6.09k
        sf_iid = sf_iid_normal;
1481
6.09k
    }
1482
1483
9.22k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
5.75k
    {
1485
5.75k
        nr_ipdopd_par = 11; /* resolution */
1486
5.75k
    } else {
1487
3.46k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
3.46k
    }
1489
1490
293k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
284k
    {
1492
284k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
284k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
989k
        for (env = 0; env < ps->num_env; env++)
1498
704k
        {
1499
704k
            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
704k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
99
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
99
                    -no_iid_steps);
1507
99
                ps->iid_index[env][bk] = -no_iid_steps;
1508
99
                abs_iid = no_iid_steps;
1509
704k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
72
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
72
                    no_iid_steps);
1512
72
                ps->iid_index[env][bk] = no_iid_steps;
1513
72
                abs_iid = no_iid_steps;
1514
72
            }
1515
704k
            if (ps->icc_index[env][bk] < 0) {
1516
100
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
100
                ps->icc_index[env][bk] = 0;
1518
704k
            } 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
704k
            if (ps->icc_mode < 3)
1524
383k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
383k
                real_t c_1, c_2;  // COEF
1527
383k
                real_t cosa, sina;  // COEF
1528
383k
                real_t cosb, sinb;  // COEF
1529
383k
                real_t ab1, ab2;  // COEF
1530
383k
                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
383k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
383k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
383k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
383k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
383k
                if (ps->iid_mode >= 3)
1550
55.9k
                {
1551
55.9k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
55.9k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
327k
                } else {
1554
327k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
327k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
327k
                }
1557
1558
383k
                ab1 = MUL_C(cosb, cosa);
1559
383k
                ab2 = MUL_C(sinb, sina);
1560
383k
                ab3 = MUL_C(sinb, cosa);
1561
383k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
383k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
383k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
383k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
383k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
383k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
321k
                real_t sina, cosa;  // COEF
1571
321k
                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
321k
                if (ps->iid_mode >= 3)
1607
217k
                {
1608
217k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
217k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
217k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
217k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
217k
                } else {
1613
104k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
104k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
104k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
104k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
104k
                }
1618
1619
321k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
321k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
321k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
321k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
321k
            }
1624
704k
            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
704k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
114k
            {
1632
114k
                int8_t i;
1633
114k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
114k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
114k
#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
114k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
114k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
114k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
114k
                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
114k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
114k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
114k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
114k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
114k
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
114k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
114k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
114k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
114k
                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
114k
                if (i == 0)
1675
57.8k
                {
1676
57.8k
                    i = 2;
1677
57.8k
                }
1678
114k
                i--;
1679
1680
                /* get value before previous */
1681
114k
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
114k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
114k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
114k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
114k
                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
114k
                xy = magnitude_c(tempRight);
1716
114k
                pq = magnitude_c(tempLeft);
1717
1718
114k
                if (xy != 0)
1719
114k
                {
1720
114k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
114k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
114k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
114k
                xypq = MUL_F(xy, pq);
1728
1729
114k
                if (xypq != 0)
1730
114k
                {
1731
114k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
114k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
114k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
114k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
114k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
114k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
114k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
114k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
114k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
114k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
114k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
114k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
114k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
114k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
114k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
704k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
704k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
704k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
704k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
704k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
704k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
704k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
704k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
704k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
704k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
704k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
704k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
704k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
704k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
704k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
114k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
114k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
114k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
114k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
114k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
114k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
114k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
114k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
114k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
114k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
16.4k
                {
1792
16.4k
                    IM(deltaH11) = -IM(deltaH11);
1793
16.4k
                    IM(deltaH12) = -IM(deltaH12);
1794
16.4k
                    IM(deltaH21) = -IM(deltaH21);
1795
16.4k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
16.4k
                    IM(H11) = -IM(H11);
1798
16.4k
                    IM(H12) = -IM(H12);
1799
16.4k
                    IM(H21) = -IM(H21);
1800
16.4k
                    IM(H22) = -IM(H22);
1801
16.4k
                }
1802
1803
114k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
114k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
114k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
114k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
114k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
9.57M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
8.87M
            {
1812
                /* addition finalises the interpolation over every n */
1813
8.87M
                RE(H11) += RE(deltaH11);
1814
8.87M
                RE(H12) += RE(deltaH12);
1815
8.87M
                RE(H21) += RE(deltaH21);
1816
8.87M
                RE(H22) += RE(deltaH22);
1817
8.87M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
1.14M
                {
1819
1.14M
                    IM(H11) += IM(deltaH11);
1820
1.14M
                    IM(H12) += IM(deltaH12);
1821
1.14M
                    IM(H21) += IM(deltaH21);
1822
1.14M
                    IM(H22) += IM(deltaH22);
1823
1.14M
                }
1824
1825
                /* channel is an alias to the subband */
1826
31.1M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
22.3M
                {
1828
22.3M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
22.3M
                    if (gr < ps->num_hybrid_groups)
1832
4.86M
                    {
1833
4.86M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
4.86M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
4.86M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
4.86M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
17.4M
                    } else {
1838
17.4M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
17.4M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
17.4M
                        RE(inRight) = RE(X_right[n][sb]);
1841
17.4M
                        IM(inRight) = IM(X_right[n][sb]);
1842
17.4M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
22.3M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
22.3M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
22.3M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
22.3M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
22.3M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.15M
                    {
1855
                        /* apply rotation */
1856
1.15M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.15M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.15M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.15M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.15M
                    }
1861
1862
                    /* store final samples */
1863
22.3M
                    if (gr < ps->num_hybrid_groups)
1864
4.86M
                    {
1865
4.86M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
4.86M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
4.86M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
4.86M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
17.4M
                    } else {
1870
17.4M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
17.4M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
17.4M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
17.4M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
17.4M
                    }
1875
22.3M
                }
1876
8.87M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
704k
            ps->phase_hist++;
1880
704k
            if (ps->phase_hist == 2)
1881
352k
            {
1882
352k
                ps->phase_hist = 0;
1883
352k
            }
1884
704k
        }
1885
284k
    }
1886
9.22k
}
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.66k
    {
1476
4.66k
        no_iid_steps = 15;
1477
4.66k
        sf_iid = sf_iid_fine;
1478
6.05k
    } else {
1479
6.05k
        no_iid_steps = 7;
1480
6.05k
        sf_iid = sf_iid_normal;
1481
6.05k
    }
1482
1483
10.7k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
6.27k
    {
1485
6.27k
        nr_ipdopd_par = 11; /* resolution */
1486
6.27k
    } else {
1487
4.44k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
4.44k
    }
1489
1490
356k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
345k
    {
1492
345k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
345k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.12M
        for (env = 0; env < ps->num_env; env++)
1498
781k
        {
1499
781k
            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
781k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
238
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
238
                    -no_iid_steps);
1507
238
                ps->iid_index[env][bk] = -no_iid_steps;
1508
238
                abs_iid = no_iid_steps;
1509
780k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
165
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
165
                    no_iid_steps);
1512
165
                ps->iid_index[env][bk] = no_iid_steps;
1513
165
                abs_iid = no_iid_steps;
1514
165
            }
1515
781k
            if (ps->icc_index[env][bk] < 0) {
1516
553
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
553
                ps->icc_index[env][bk] = 0;
1518
780k
            } 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
781k
            if (ps->icc_mode < 3)
1524
498k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
498k
                real_t c_1, c_2;  // COEF
1527
498k
                real_t cosa, sina;  // COEF
1528
498k
                real_t cosb, sinb;  // COEF
1529
498k
                real_t ab1, ab2;  // COEF
1530
498k
                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
498k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
498k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
498k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
498k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
498k
                if (ps->iid_mode >= 3)
1550
220k
                {
1551
220k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
220k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
278k
                } else {
1554
278k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
278k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
278k
                }
1557
1558
498k
                ab1 = MUL_C(cosb, cosa);
1559
498k
                ab2 = MUL_C(sinb, sina);
1560
498k
                ab3 = MUL_C(sinb, cosa);
1561
498k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
498k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
498k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
498k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
498k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
498k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
282k
                real_t sina, cosa;  // COEF
1571
282k
                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
282k
                if (ps->iid_mode >= 3)
1607
170k
                {
1608
170k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
170k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
170k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
170k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
170k
                } else {
1613
112k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
112k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
112k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
112k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
112k
                }
1618
1619
282k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
282k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
282k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
282k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
282k
            }
1624
781k
            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
781k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
88.6k
            {
1632
88.6k
                int8_t i;
1633
88.6k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
88.6k
                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
88.6k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
88.6k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
88.6k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
88.6k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
88.6k
#endif
1652
1653
                /* save current value */
1654
88.6k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
88.6k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
88.6k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
88.6k
                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
88.6k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
88.6k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
88.6k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
88.6k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
88.6k
#endif
1672
1673
                /* ringbuffer index */
1674
88.6k
                if (i == 0)
1675
44.7k
                {
1676
44.7k
                    i = 2;
1677
44.7k
                }
1678
88.6k
                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
88.6k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
88.6k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
88.6k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
88.6k
                IM(tempRight) += MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1692
88.6k
#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
88.6k
                xy = magnitude_c(tempRight);
1716
88.6k
                pq = magnitude_c(tempLeft);
1717
1718
88.6k
                if (xy != 0)
1719
88.6k
                {
1720
88.6k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
88.6k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
88.6k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
88.6k
                xypq = MUL_F(xy, pq);
1728
1729
88.6k
                if (xypq != 0)
1730
88.6k
                {
1731
88.6k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
88.6k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
88.6k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
88.6k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
88.6k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
88.6k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
88.6k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
88.6k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
88.6k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
88.6k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
88.6k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
88.6k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
88.6k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
88.6k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
88.6k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
781k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
781k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
781k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
781k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
781k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
781k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
781k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
781k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
781k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
781k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
781k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
781k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
781k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
781k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
781k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
88.6k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
88.6k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
88.6k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
88.6k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
88.6k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
88.6k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
88.6k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
88.6k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
88.6k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
88.6k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
12.5k
                {
1792
12.5k
                    IM(deltaH11) = -IM(deltaH11);
1793
12.5k
                    IM(deltaH12) = -IM(deltaH12);
1794
12.5k
                    IM(deltaH21) = -IM(deltaH21);
1795
12.5k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
12.5k
                    IM(H11) = -IM(H11);
1798
12.5k
                    IM(H12) = -IM(H12);
1799
12.5k
                    IM(H21) = -IM(H21);
1800
12.5k
                    IM(H22) = -IM(H22);
1801
12.5k
                }
1802
1803
88.6k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
88.6k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
88.6k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
88.6k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
88.6k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
11.5M
            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
887k
                {
1819
887k
                    IM(H11) += IM(deltaH11);
1820
887k
                    IM(H12) += IM(deltaH12);
1821
887k
                    IM(H21) += IM(deltaH21);
1822
887k
                    IM(H22) += IM(deltaH22);
1823
887k
                }
1824
1825
                /* channel is an alias to the subband */
1826
37.0M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
26.2M
                {
1828
26.2M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
26.2M
                    if (gr < ps->num_hybrid_groups)
1832
6.01M
                    {
1833
6.01M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
6.01M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
6.01M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
6.01M
                        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.2M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
26.2M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
26.2M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
26.2M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
26.2M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
892k
                    {
1855
                        /* apply rotation */
1856
892k
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
892k
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
892k
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
892k
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
892k
                    }
1861
1862
                    /* store final samples */
1863
26.2M
                    if (gr < ps->num_hybrid_groups)
1864
6.01M
                    {
1865
6.01M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
6.01M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
6.01M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
6.01M
                        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.2M
                }
1876
10.7M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
781k
            ps->phase_hist++;
1880
781k
            if (ps->phase_hist == 2)
1881
390k
            {
1882
390k
                ps->phase_hist = 0;
1883
390k
            }
1884
781k
        }
1885
345k
    }
1886
10.7k
}
1887
1888
void ps_free(ps_info *ps)
1889
30.8k
{
1890
    /* free hybrid filterbank structures */
1891
30.8k
    hybrid_free(ps->hyb);
1892
1893
30.8k
    faad_free(ps);
1894
30.8k
}
1895
1896
ps_info *ps_init(uint8_t sr_index, uint8_t numTimeSlotsRate)
1897
30.8k
{
1898
30.8k
    uint8_t i;
1899
30.8k
    uint8_t short_delay_band;
1900
1901
30.8k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
30.8k
    memset(ps, 0, sizeof(ps_info));
1903
1904
30.8k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
30.8k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
30.8k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
30.8k
    ps->saved_delay = 0;
1911
1912
2.00M
    for (i = 0; i < 64; i++)
1913
1.97M
    {
1914
1.97M
        ps->delay_buf_index_delay[i] = 0;
1915
1.97M
    }
1916
1917
123k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
92.4k
    {
1919
92.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
92.4k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
92.4k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
92.4k
#endif
1932
92.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
30.8k
    short_delay_band = 35;
1950
30.8k
    ps->nr_allpass_bands = 22;
1951
30.8k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
30.8k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
30.8k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
1.10M
    for (i = 0; i < short_delay_band; i++)
1957
1.07M
    {
1958
1.07M
        ps->delay_D[i] = 14;
1959
1.07M
    }
1960
924k
    for (i = short_delay_band; i < 64; i++)
1961
893k
    {
1962
893k
        ps->delay_D[i] = 1;
1963
893k
    }
1964
1965
    /* mixing and phase */
1966
1.57M
    for (i = 0; i < 50; i++)
1967
1.54M
    {
1968
1.54M
        RE(ps->h11_prev[i]) = 1;
1969
1.54M
        IM(ps->h11_prev[i]) = 1;
1970
1.54M
        RE(ps->h12_prev[i]) = 1;
1971
1.54M
        IM(ps->h12_prev[i]) = 1;
1972
1.54M
    }
1973
1974
30.8k
    ps->phase_hist = 0;
1975
1976
646k
    for (i = 0; i < 20; i++)
1977
616k
    {
1978
616k
        RE(ps->ipd_prev[i][0]) = 0;
1979
616k
        IM(ps->ipd_prev[i][0]) = 0;
1980
616k
        RE(ps->ipd_prev[i][1]) = 0;
1981
616k
        IM(ps->ipd_prev[i][1]) = 0;
1982
616k
        RE(ps->opd_prev[i][0]) = 0;
1983
616k
        IM(ps->opd_prev[i][0]) = 0;
1984
616k
        RE(ps->opd_prev[i][1]) = 0;
1985
616k
        IM(ps->opd_prev[i][1]) = 0;
1986
616k
    }
1987
1988
30.8k
    return ps;
1989
30.8k
}
ps_init
Line
Count
Source
1897
14.3k
{
1898
14.3k
    uint8_t i;
1899
14.3k
    uint8_t short_delay_band;
1900
1901
14.3k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
14.3k
    memset(ps, 0, sizeof(ps_info));
1903
1904
14.3k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
14.3k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
14.3k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
14.3k
    ps->saved_delay = 0;
1911
1912
930k
    for (i = 0; i < 64; i++)
1913
916k
    {
1914
916k
        ps->delay_buf_index_delay[i] = 0;
1915
916k
    }
1916
1917
57.2k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
42.9k
    {
1919
42.9k
        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
42.9k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
42.9k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
42.9k
#endif
1932
42.9k
    }
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
14.3k
    short_delay_band = 35;
1950
14.3k
    ps->nr_allpass_bands = 22;
1951
14.3k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
14.3k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
14.3k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
515k
    for (i = 0; i < short_delay_band; i++)
1957
501k
    {
1958
501k
        ps->delay_D[i] = 14;
1959
501k
    }
1960
429k
    for (i = short_delay_band; i < 64; i++)
1961
415k
    {
1962
415k
        ps->delay_D[i] = 1;
1963
415k
    }
1964
1965
    /* mixing and phase */
1966
730k
    for (i = 0; i < 50; i++)
1967
715k
    {
1968
715k
        RE(ps->h11_prev[i]) = 1;
1969
715k
        IM(ps->h11_prev[i]) = 1;
1970
715k
        RE(ps->h12_prev[i]) = 1;
1971
715k
        IM(ps->h12_prev[i]) = 1;
1972
715k
    }
1973
1974
14.3k
    ps->phase_hist = 0;
1975
1976
300k
    for (i = 0; i < 20; i++)
1977
286k
    {
1978
286k
        RE(ps->ipd_prev[i][0]) = 0;
1979
286k
        IM(ps->ipd_prev[i][0]) = 0;
1980
286k
        RE(ps->ipd_prev[i][1]) = 0;
1981
286k
        IM(ps->ipd_prev[i][1]) = 0;
1982
286k
        RE(ps->opd_prev[i][0]) = 0;
1983
286k
        IM(ps->opd_prev[i][0]) = 0;
1984
286k
        RE(ps->opd_prev[i][1]) = 0;
1985
286k
        IM(ps->opd_prev[i][1]) = 0;
1986
286k
    }
1987
1988
14.3k
    return ps;
1989
14.3k
}
ps_init
Line
Count
Source
1897
16.4k
{
1898
16.4k
    uint8_t i;
1899
16.4k
    uint8_t short_delay_band;
1900
1901
16.4k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
16.4k
    memset(ps, 0, sizeof(ps_info));
1903
1904
16.4k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
16.4k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
16.4k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
16.4k
    ps->saved_delay = 0;
1911
1912
1.07M
    for (i = 0; i < 64; i++)
1913
1.05M
    {
1914
1.05M
        ps->delay_buf_index_delay[i] = 0;
1915
1.05M
    }
1916
1917
65.9k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
49.4k
    {
1919
49.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
49.4k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
49.4k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
49.4k
#endif
1932
49.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
16.4k
    short_delay_band = 35;
1950
16.4k
    ps->nr_allpass_bands = 22;
1951
16.4k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
16.4k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
16.4k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
593k
    for (i = 0; i < short_delay_band; i++)
1957
576k
    {
1958
576k
        ps->delay_D[i] = 14;
1959
576k
    }
1960
494k
    for (i = short_delay_band; i < 64; i++)
1961
478k
    {
1962
478k
        ps->delay_D[i] = 1;
1963
478k
    }
1964
1965
    /* mixing and phase */
1966
840k
    for (i = 0; i < 50; i++)
1967
824k
    {
1968
824k
        RE(ps->h11_prev[i]) = 1;
1969
824k
        IM(ps->h11_prev[i]) = 1;
1970
824k
        RE(ps->h12_prev[i]) = 1;
1971
824k
        IM(ps->h12_prev[i]) = 1;
1972
824k
    }
1973
1974
16.4k
    ps->phase_hist = 0;
1975
1976
346k
    for (i = 0; i < 20; i++)
1977
329k
    {
1978
329k
        RE(ps->ipd_prev[i][0]) = 0;
1979
329k
        IM(ps->ipd_prev[i][0]) = 0;
1980
329k
        RE(ps->ipd_prev[i][1]) = 0;
1981
329k
        IM(ps->ipd_prev[i][1]) = 0;
1982
329k
        RE(ps->opd_prev[i][0]) = 0;
1983
329k
        IM(ps->opd_prev[i][0]) = 0;
1984
329k
        RE(ps->opd_prev[i][1]) = 0;
1985
329k
        IM(ps->opd_prev[i][1]) = 0;
1986
329k
    }
1987
1988
16.4k
    return ps;
1989
16.4k
}
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
19.9k
{
1994
19.9k
    qmf_t X_hybrid_left[32][32] = {{{0}}};
1995
19.9k
    qmf_t X_hybrid_right[32][32] = {{{0}}};
1996
1997
    /* delta decoding of the bitstream data */
1998
19.9k
    ps_data_decode(ps);
1999
2000
    /* set up some parameters depending on filterbank type */
2001
19.9k
    if (ps->use34hybrid_bands)
2002
6.83k
    {
2003
6.83k
        ps->group_border = (uint8_t*)group_border34;
2004
6.83k
        ps->map_group2bk = (uint16_t*)map_group2bk34;
2005
6.83k
        ps->num_groups = 32+18;
2006
6.83k
        ps->num_hybrid_groups = 32;
2007
6.83k
        ps->nr_par_bands = 34;
2008
6.83k
        ps->decay_cutoff = 5;
2009
13.1k
    } else {
2010
13.1k
        ps->group_border = (uint8_t*)group_border20;
2011
13.1k
        ps->map_group2bk = (uint16_t*)map_group2bk20;
2012
13.1k
        ps->num_groups = 10+12;
2013
13.1k
        ps->num_hybrid_groups = 10;
2014
13.1k
        ps->nr_par_bands = 20;
2015
13.1k
        ps->decay_cutoff = 3;
2016
13.1k
    }
2017
2018
    /* Perform further analysis on the lowest subbands to get a higher
2019
     * frequency resolution
2020
     */
2021
19.9k
    hybrid_analysis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2022
19.9k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2023
2024
    /* decorrelate mono signal */
2025
19.9k
    ps_decorrelate(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2026
2027
    /* apply mixing and phase parameters */
2028
19.9k
    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
19.9k
    hybrid_synthesis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2032
19.9k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2033
2034
19.9k
    hybrid_synthesis((hyb_info*)ps->hyb, X_right, X_hybrid_right,
2035
19.9k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2036
2037
19.9k
    return 0;
2038
19.9k
}
2039
2040
#endif