Coverage Report

Created: 2025-07-18 06:36

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