Coverage Report

Created: 2025-12-31 06:11

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/proc/self/cwd/libfaad/ps_dec.c
Line
Count
Source
1
/*
2
** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
3
** Copyright (C) 2003-2005 M. Bakker, Nero AG, http://www.nero.com
4
**
5
** This program is free software; you can redistribute it and/or modify
6
** it under the terms of the GNU General Public License as published by
7
** the Free Software Foundation; either version 2 of the License, or
8
** (at your option) any later version.
9
**
10
** This program is distributed in the hope that it will be useful,
11
** but WITHOUT ANY WARRANTY; without even the implied warranty of
12
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
** GNU General Public License for more details.
14
**
15
** You should have received a copy of the GNU General Public License
16
** along with this program; if not, write to the Free Software
17
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18
**
19
** Any non-GPL usage of this software or parts of this software is strictly
20
** forbidden.
21
**
22
** The "appropriate copyright message" mentioned in section 2c of the GPLv2
23
** must read: "Code from FAAD2 is copyright (c) Nero AG, www.nero.com"
24
**
25
** Commercial non-GPL licensing of this software is possible.
26
** For more info contact Nero AG through Mpeg4AAClicense@nero.com.
27
**
28
** $Id: ps_dec.c,v 1.16 2009/01/26 22:32:31 menno Exp $
29
**/
30
31
#include "common.h"
32
33
#ifdef PS_DEC
34
35
#include <stdlib.h>
36
#include <stdio.h>
37
#include "ps_dec.h"
38
#include "ps_tables.h"
39
40
/* constants */
41
52.8M
#define NEGATE_IPD_MASK            (0x1000)
42
399k
#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
32.5k
{
198
32.5k
    uint8_t i;
199
200
32.5k
    hyb_info *hyb = (hyb_info*)faad_malloc(sizeof(hyb_info));
201
202
32.5k
    hyb->resolution34[0] = 12;
203
32.5k
    hyb->resolution34[1] = 8;
204
32.5k
    hyb->resolution34[2] = 4;
205
32.5k
    hyb->resolution34[3] = 4;
206
32.5k
    hyb->resolution34[4] = 4;
207
208
32.5k
    hyb->resolution20[0] = 8;
209
32.5k
    hyb->resolution20[1] = 2;
210
32.5k
    hyb->resolution20[2] = 2;
211
212
32.5k
    hyb->frame_len = numTimeSlotsRate;
213
214
32.5k
    hyb->work = (qmf_t*)faad_malloc((hyb->frame_len+12) * sizeof(qmf_t));
215
32.5k
    memset(hyb->work, 0, (hyb->frame_len+12) * sizeof(qmf_t));
216
217
32.5k
    hyb->buffer = (qmf_t**)faad_malloc(5 * sizeof(qmf_t*));
218
195k
    for (i = 0; i < 5; i++)
219
162k
    {
220
162k
        hyb->buffer[i] = (qmf_t*)faad_malloc(hyb->frame_len * sizeof(qmf_t));
221
162k
        memset(hyb->buffer[i], 0, hyb->frame_len * sizeof(qmf_t));
222
162k
    }
223
224
32.5k
    hyb->temp = (qmf_t**)faad_malloc(hyb->frame_len * sizeof(qmf_t*));
225
1.06M
    for (i = 0; i < hyb->frame_len; i++)
226
1.02M
    {
227
1.02M
        hyb->temp[i] = (qmf_t*)faad_malloc(12 /*max*/ * sizeof(qmf_t));
228
1.02M
    }
229
230
32.5k
    return hyb;
231
32.5k
}
232
233
static void hybrid_free(hyb_info *hyb)
234
32.5k
{
235
32.5k
    uint8_t i;
236
237
32.5k
  if (!hyb) return;
238
239
32.5k
    if (hyb->work)
240
32.5k
        faad_free(hyb->work);
241
242
195k
    for (i = 0; i < 5; i++)
243
162k
    {
244
162k
        if (hyb->buffer[i])
245
162k
            faad_free(hyb->buffer[i]);
246
162k
    }
247
32.5k
    if (hyb->buffer)
248
32.5k
        faad_free(hyb->buffer);
249
250
1.06M
    for (i = 0; i < hyb->frame_len; i++)
251
1.02M
    {
252
1.02M
        if (hyb->temp[i])
253
1.02M
            faad_free(hyb->temp[i]);
254
1.02M
    }
255
32.5k
    if (hyb->temp)
256
32.5k
        faad_free(hyb->temp);
257
258
32.5k
    faad_free(hyb);
259
32.5k
}
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
54.4k
{
265
54.4k
    uint8_t i;
266
54.4k
    (void)hyb;  /* TODO: remove parameter? */
267
268
1.76M
    for (i = 0; i < frame_len; i++)
269
1.71M
    {
270
1.71M
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
1.71M
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
1.71M
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
1.71M
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
1.71M
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
1.71M
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
1.71M
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
1.71M
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
1.71M
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
1.71M
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
1.71M
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
1.71M
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
1.71M
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
1.71M
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
1.71M
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
1.71M
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
1.71M
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
1.71M
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
1.71M
    }
293
54.4k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
27.2k
{
265
27.2k
    uint8_t i;
266
27.2k
    (void)hyb;  /* TODO: remove parameter? */
267
268
882k
    for (i = 0; i < frame_len; i++)
269
855k
    {
270
855k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
855k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
855k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
855k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
855k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
855k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
855k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
855k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
855k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
855k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
855k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
855k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
855k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
855k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
855k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
855k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
855k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
855k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
855k
    }
293
27.2k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
27.2k
{
265
27.2k
    uint8_t i;
266
27.2k
    (void)hyb;  /* TODO: remove parameter? */
267
268
882k
    for (i = 0; i < frame_len; i++)
269
855k
    {
270
855k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
855k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
855k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
855k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
855k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
855k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
855k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
855k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
855k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
855k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
855k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
855k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
855k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
855k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
855k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
855k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
855k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
855k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
855k
    }
293
27.2k
}
294
295
/* complex filter, size 4 */
296
static void channel_filter4(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
297
                            qmf_t *buffer, qmf_t **X_hybrid)
298
22.2k
{
299
22.2k
    uint8_t i;
300
22.2k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
22.2k
    (void)hyb;  /* TODO: remove parameter? */
302
303
708k
    for (i = 0; i < frame_len; i++)
304
686k
    {
305
686k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
686k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
686k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
686k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
686k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
686k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
686k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
686k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
686k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
686k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
686k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
686k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
686k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
686k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
686k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
686k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
686k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
686k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
686k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
686k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
686k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
686k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
686k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
686k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
686k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
686k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
686k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
686k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
686k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
686k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
686k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
686k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
686k
    }
349
22.2k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
9.65k
{
299
9.65k
    uint8_t i;
300
9.65k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
9.65k
    (void)hyb;  /* TODO: remove parameter? */
302
303
307k
    for (i = 0; i < frame_len; i++)
304
297k
    {
305
297k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
297k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
297k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
297k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
297k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
297k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
297k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
297k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
297k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
297k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
297k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
297k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
297k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
297k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
297k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
297k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
297k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
297k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
297k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
297k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
297k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
297k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
297k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
297k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
297k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
297k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
297k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
297k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
297k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
297k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
297k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
297k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
297k
    }
349
9.65k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
12.6k
{
299
12.6k
    uint8_t i;
300
12.6k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
12.6k
    (void)hyb;  /* TODO: remove parameter? */
302
303
401k
    for (i = 0; i < frame_len; i++)
304
388k
    {
305
388k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
388k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
388k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
388k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
388k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
388k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
388k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
388k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
388k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
388k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
388k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
388k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
388k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
388k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
388k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
388k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
388k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
388k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
388k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
388k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
388k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
388k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
388k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
388k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
388k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
388k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
388k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
388k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
388k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
388k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
388k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
388k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
388k
    }
349
12.6k
}
350
351
static void INLINE DCT3_4_unscaled(real_t *y, real_t *x)
352
2.62M
{
353
2.62M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
2.62M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
2.62M
    f1 = x[0] - f0;
357
2.62M
    f2 = x[0] + f0;
358
2.62M
    f3 = x[1] + x[3];
359
2.62M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
2.62M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
2.62M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
2.62M
    f7 = f4 + f5;
363
2.62M
    f8 = f6 - f5;
364
2.62M
    y[3] = f2 - f8;
365
2.62M
    y[0] = f2 + f8;
366
2.62M
    y[2] = f1 - f7;
367
2.62M
    y[1] = f1 + f7;
368
2.62M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.24M
{
353
1.24M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.24M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.24M
    f1 = x[0] - f0;
357
1.24M
    f2 = x[0] + f0;
358
1.24M
    f3 = x[1] + x[3];
359
1.24M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.24M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.24M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.24M
    f7 = f4 + f5;
363
1.24M
    f8 = f6 - f5;
364
1.24M
    y[3] = f2 - f8;
365
1.24M
    y[0] = f2 + f8;
366
1.24M
    y[2] = f1 - f7;
367
1.24M
    y[1] = f1 + f7;
368
1.24M
}
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
42.0k
{
374
42.0k
    uint8_t i, n;
375
42.0k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
42.0k
    real_t x[4];
377
42.0k
    (void)hyb;  /* TODO: remove parameter? */
378
379
1.35M
    for (i = 0; i < frame_len; i++)
380
1.31M
    {
381
1.31M
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
1.31M
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
1.31M
        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.31M
        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.31M
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
1.31M
        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.31M
        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.31M
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
6.56M
        for (n = 0; n < 4; n++)
392
5.25M
        {
393
5.25M
            x[n] = input_re1[n] - input_im1[3-n];
394
5.25M
        }
395
1.31M
        DCT3_4_unscaled(x, x);
396
1.31M
        QMF_RE(X_hybrid[i][7]) = x[0];
397
1.31M
        QMF_RE(X_hybrid[i][5]) = x[2];
398
1.31M
        QMF_RE(X_hybrid[i][3]) = x[3];
399
1.31M
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
6.56M
        for (n = 0; n < 4; n++)
402
5.25M
        {
403
5.25M
            x[n] = input_re1[n] + input_im1[3-n];
404
5.25M
        }
405
1.31M
        DCT3_4_unscaled(x, x);
406
1.31M
        QMF_RE(X_hybrid[i][6]) = x[1];
407
1.31M
        QMF_RE(X_hybrid[i][4]) = x[3];
408
1.31M
        QMF_RE(X_hybrid[i][2]) = x[2];
409
1.31M
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
1.31M
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
1.31M
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
1.31M
        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.31M
        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.31M
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
1.31M
        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.31M
        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.31M
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
6.56M
        for (n = 0; n < 4; n++)
422
5.25M
        {
423
5.25M
            x[n] = input_im2[n] + input_re2[3-n];
424
5.25M
        }
425
1.31M
        DCT3_4_unscaled(x, x);
426
1.31M
        QMF_IM(X_hybrid[i][7]) = x[0];
427
1.31M
        QMF_IM(X_hybrid[i][5]) = x[2];
428
1.31M
        QMF_IM(X_hybrid[i][3]) = x[3];
429
1.31M
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
6.56M
        for (n = 0; n < 4; n++)
432
5.25M
        {
433
5.25M
            x[n] = input_im2[n] - input_re2[3-n];
434
5.25M
        }
435
1.31M
        DCT3_4_unscaled(x, x);
436
1.31M
        QMF_IM(X_hybrid[i][6]) = x[1];
437
1.31M
        QMF_IM(X_hybrid[i][4]) = x[3];
438
1.31M
        QMF_IM(X_hybrid[i][2]) = x[2];
439
1.31M
        QMF_IM(X_hybrid[i][0]) = x[0];
440
1.31M
    }
441
42.0k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
21.0k
{
374
21.0k
    uint8_t i, n;
375
21.0k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
21.0k
    real_t x[4];
377
21.0k
    (void)hyb;  /* TODO: remove parameter? */
378
379
677k
    for (i = 0; i < frame_len; i++)
380
656k
    {
381
656k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
656k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
656k
        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
656k
        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
656k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
656k
        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
656k
        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
656k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.28M
        for (n = 0; n < 4; n++)
392
2.62M
        {
393
2.62M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.62M
        }
395
656k
        DCT3_4_unscaled(x, x);
396
656k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
656k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
656k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
656k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.28M
        for (n = 0; n < 4; n++)
402
2.62M
        {
403
2.62M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.62M
        }
405
656k
        DCT3_4_unscaled(x, x);
406
656k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
656k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
656k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
656k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
656k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
656k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
656k
        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
656k
        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
656k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
656k
        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
656k
        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
656k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.28M
        for (n = 0; n < 4; n++)
422
2.62M
        {
423
2.62M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.62M
        }
425
656k
        DCT3_4_unscaled(x, x);
426
656k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
656k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
656k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
656k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.28M
        for (n = 0; n < 4; n++)
432
2.62M
        {
433
2.62M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.62M
        }
435
656k
        DCT3_4_unscaled(x, x);
436
656k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
656k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
656k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
656k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
656k
    }
441
21.0k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
21.0k
{
374
21.0k
    uint8_t i, n;
375
21.0k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
21.0k
    real_t x[4];
377
21.0k
    (void)hyb;  /* TODO: remove parameter? */
378
379
677k
    for (i = 0; i < frame_len; i++)
380
656k
    {
381
656k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
656k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
656k
        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
656k
        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
656k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
656k
        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
656k
        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
656k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.28M
        for (n = 0; n < 4; n++)
392
2.62M
        {
393
2.62M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.62M
        }
395
656k
        DCT3_4_unscaled(x, x);
396
656k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
656k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
656k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
656k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.28M
        for (n = 0; n < 4; n++)
402
2.62M
        {
403
2.62M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.62M
        }
405
656k
        DCT3_4_unscaled(x, x);
406
656k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
656k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
656k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
656k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
656k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
656k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
656k
        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
656k
        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
656k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
656k
        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
656k
        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
656k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.28M
        for (n = 0; n < 4; n++)
422
2.62M
        {
423
2.62M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.62M
        }
425
656k
        DCT3_4_unscaled(x, x);
426
656k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
656k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
656k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
656k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.28M
        for (n = 0; n < 4; n++)
432
2.62M
        {
433
2.62M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.62M
        }
435
656k
        DCT3_4_unscaled(x, x);
436
656k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
656k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
656k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
656k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
656k
    }
441
21.0k
}
442
443
static void INLINE DCT3_6_unscaled(real_t *y, real_t *x)
444
915k
{
445
915k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
915k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
915k
    f1 = x[0] + f0;
449
915k
    f2 = x[0] - f0;
450
915k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
915k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
915k
    f5 = f4 - x[4];
453
915k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
915k
    f7 = f6 - f3;
455
915k
    y[0] = f1 + f6 + f4;
456
915k
    y[1] = f2 + f3 - x[4];
457
915k
    y[2] = f7 + f2 - f5;
458
915k
    y[3] = f1 - f7 - f5;
459
915k
    y[4] = f1 - f3 - x[4];
460
915k
    y[5] = f2 - f6 + f4;
461
915k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
397k
{
445
397k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
397k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
397k
    f1 = x[0] + f0;
449
397k
    f2 = x[0] - f0;
450
397k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
397k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
397k
    f5 = f4 - x[4];
453
397k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
397k
    f7 = f6 - f3;
455
397k
    y[0] = f1 + f6 + f4;
456
397k
    y[1] = f2 + f3 - x[4];
457
397k
    y[2] = f7 + f2 - f5;
458
397k
    y[3] = f1 - f7 - f5;
459
397k
    y[4] = f1 - f3 - x[4];
460
397k
    y[5] = f2 - f6 + f4;
461
397k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
518k
{
445
518k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
518k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
518k
    f1 = x[0] + f0;
449
518k
    f2 = x[0] - f0;
450
518k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
518k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
518k
    f5 = f4 - x[4];
453
518k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
518k
    f7 = f6 - f3;
455
518k
    y[0] = f1 + f6 + f4;
456
518k
    y[1] = f2 + f3 - x[4];
457
518k
    y[2] = f7 + f2 - f5;
458
518k
    y[3] = f1 - f7 - f5;
459
518k
    y[4] = f1 - f3 - x[4];
460
518k
    y[5] = f2 - f6 + f4;
461
518k
}
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
14.8k
{
467
14.8k
    uint8_t i, n;
468
14.8k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
14.8k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
14.8k
    (void)hyb;  /* TODO: remove parameter? */
471
472
472k
    for (i = 0; i < frame_len; i++)
473
457k
    {
474
3.20M
        for (n = 0; n < 6; n++)
475
2.74M
        {
476
2.74M
            if (n == 0)
477
457k
            {
478
457k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
457k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
2.28M
            } else {
481
2.28M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
2.28M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
2.28M
            }
484
2.74M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
2.74M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
2.74M
        }
487
488
457k
        DCT3_6_unscaled(out_re1, input_re1);
489
457k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
457k
        DCT3_6_unscaled(out_im1, input_im1);
492
457k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
1.83M
        for (n = 0; n < 6; n += 2)
495
1.37M
        {
496
1.37M
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
1.37M
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
1.37M
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
1.37M
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
1.37M
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
1.37M
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
1.37M
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
1.37M
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
1.37M
        }
506
457k
    }
507
14.8k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
7.42k
{
467
7.42k
    uint8_t i, n;
468
7.42k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
7.42k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
7.42k
    (void)hyb;  /* TODO: remove parameter? */
471
472
236k
    for (i = 0; i < frame_len; i++)
473
228k
    {
474
1.60M
        for (n = 0; n < 6; n++)
475
1.37M
        {
476
1.37M
            if (n == 0)
477
228k
            {
478
228k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
228k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.14M
            } else {
481
1.14M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.14M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.14M
            }
484
1.37M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.37M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.37M
        }
487
488
228k
        DCT3_6_unscaled(out_re1, input_re1);
489
228k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
228k
        DCT3_6_unscaled(out_im1, input_im1);
492
228k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
915k
        for (n = 0; n < 6; n += 2)
495
686k
        {
496
686k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
686k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
686k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
686k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
686k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
686k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
686k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
686k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
686k
        }
506
228k
    }
507
7.42k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
7.42k
{
467
7.42k
    uint8_t i, n;
468
7.42k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
7.42k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
7.42k
    (void)hyb;  /* TODO: remove parameter? */
471
472
236k
    for (i = 0; i < frame_len; i++)
473
228k
    {
474
1.60M
        for (n = 0; n < 6; n++)
475
1.37M
        {
476
1.37M
            if (n == 0)
477
228k
            {
478
228k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
228k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.14M
            } else {
481
1.14M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.14M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.14M
            }
484
1.37M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.37M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.37M
        }
487
488
228k
        DCT3_6_unscaled(out_re1, input_re1);
489
228k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
228k
        DCT3_6_unscaled(out_im1, input_im1);
492
228k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
915k
        for (n = 0; n < 6; n += 2)
495
686k
        {
496
686k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
686k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
686k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
686k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
686k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
686k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
686k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
686k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
686k
        }
506
228k
    }
507
7.42k
}
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
21.0k
{
515
21.0k
    uint8_t k, n, band;
516
21.0k
    uint8_t offset = 0;
517
21.0k
    uint8_t qmf_bands = (use34) ? 5 : 3;
518
21.0k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
519
520
98.9k
    for (band = 0; band < qmf_bands; band++)
521
77.9k
    {
522
        /* build working buffer */
523
77.9k
        memcpy(hyb->work, hyb->buffer[band], 12 * sizeof(qmf_t));
524
525
        /* add new samples */
526
2.50M
        for (n = 0; n < hyb->frame_len; n++)
527
2.42M
        {
528
2.42M
            QMF_RE(hyb->work[12 + n]) = QMF_RE(X[n + 6 /*delay*/][band]);
529
2.42M
            QMF_IM(hyb->work[12 + n]) = QMF_IM(X[n + 6 /*delay*/][band]);
530
2.42M
        }
531
532
        /* store samples */
533
77.9k
        memcpy(hyb->buffer[band], hyb->work + hyb->frame_len, 12 * sizeof(qmf_t));
534
535
536
77.9k
        switch(resolution[band])
537
77.9k
        {
538
27.2k
        case 2:
539
            /* Type B real filter, Q[p] = 2 */
540
27.2k
            channel_filter2(hyb, hyb->frame_len, p2_13_20, hyb->work, hyb->temp);
541
27.2k
            break;
542
22.2k
        case 4:
543
            /* Type A complex filter, Q[p] = 4 */
544
22.2k
            channel_filter4(hyb, hyb->frame_len, p4_13_34, hyb->work, hyb->temp);
545
22.2k
            break;
546
21.0k
        case 8:
547
            /* Type A complex filter, Q[p] = 8 */
548
21.0k
            channel_filter8(hyb, hyb->frame_len, (use34) ? p8_13_34 : p8_13_20,
549
21.0k
                hyb->work, hyb->temp);
550
21.0k
            break;
551
7.42k
        case 12:
552
            /* Type A complex filter, Q[p] = 12 */
553
7.42k
            channel_filter12(hyb, hyb->frame_len, p12_13_34, hyb->work, hyb->temp);
554
7.42k
            break;
555
77.9k
        }
556
557
2.50M
        for (n = 0; n < hyb->frame_len; n++)
558
2.42M
        {
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.42M
        }
565
77.9k
        offset += resolution[band];
566
77.9k
    }
567
568
    /* group hybrid channels */
569
21.0k
    if (!use34)
570
13.6k
    {
571
441k
        for (n = 0; n < numTimeSlotsRate; n++)
572
427k
        {
573
427k
            QMF_RE(X_hybrid[n][3]) += QMF_RE(X_hybrid[n][4]);
574
427k
            QMF_IM(X_hybrid[n][3]) += QMF_IM(X_hybrid[n][4]);
575
427k
            QMF_RE(X_hybrid[n][4]) = 0;
576
427k
            QMF_IM(X_hybrid[n][4]) = 0;
577
578
427k
            QMF_RE(X_hybrid[n][2]) += QMF_RE(X_hybrid[n][5]);
579
427k
            QMF_IM(X_hybrid[n][2]) += QMF_IM(X_hybrid[n][5]);
580
427k
            QMF_RE(X_hybrid[n][5]) = 0;
581
427k
            QMF_IM(X_hybrid[n][5]) = 0;
582
427k
        }
583
13.6k
    }
584
21.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
42.0k
{
589
42.0k
    uint8_t k, n, band;
590
42.0k
    uint8_t offset = 0;
591
42.0k
    uint8_t qmf_bands = (use34) ? 5 : 3;
592
42.0k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
593
42.0k
    (void)numTimeSlotsRate;  /* TODO: remove parameter? */
594
595
197k
    for(band = 0; band < qmf_bands; band++)
596
155k
    {
597
5.01M
        for (n = 0; n < hyb->frame_len; n++)
598
4.85M
        {
599
4.85M
            QMF_RE(X[n][band]) = 0;
600
4.85M
            QMF_IM(X[n][band]) = 0;
601
602
29.7M
            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.85M
        }
608
155k
        offset += resolution[band];
609
155k
    }
610
42.0k
}
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
458k
{
615
458k
    if (i < min)
616
58.1k
        return min;
617
400k
    else if (i > max)
618
5.88k
        return max;
619
394k
    else
620
394k
        return i;
621
458k
}
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
74.7k
{
630
74.7k
    int8_t i;
631
632
74.7k
    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
292k
            for (i = 1; i < nr_par; i++)
641
270k
            {
642
270k
                index[i] = index[i-1] + index[i];
643
270k
                index[i] = delta_clip(index[i], min_index, max_index);
644
270k
            }
645
21.9k
        } else {
646
            /* delta coded in time direction */
647
180k
            for (i = 0; i < nr_par; i++)
648
165k
            {
649
                //int8_t tmp2;
650
                //int8_t tmp = index[i];
651
652
                //printf("%d %d\n", index_prev[i*stride], index[i]);
653
                //printf("%d\n", index[i]);
654
655
165k
                index[i] = index_prev[i*stride] + index[i];
656
                //tmp2 = index[i];
657
165k
                index[i] = delta_clip(index[i], min_index, max_index);
658
659
                //if (iid)
660
                //{
661
                //    if (index[i] == 7)
662
                //    {
663
                //        printf("%d %d %d\n", index_prev[i*stride], tmp, tmp2);
664
                //    }
665
                //}
666
165k
            }
667
14.5k
        }
668
38.2k
    } else {
669
        /* set indices to zero */
670
68.1k
        for (i = 0; i < nr_par; i++)
671
29.9k
        {
672
29.9k
            index[i] = 0;
673
29.9k
        }
674
38.2k
    }
675
676
    /* coarse */
677
74.7k
    if (stride == 2)
678
51.7k
    {
679
336k
        for (i = (nr_par<<1)-1; i > 0; i--)
680
285k
        {
681
285k
            index[i] = index[i>>1];
682
285k
        }
683
51.7k
    }
684
74.7k
}
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
74.7k
{
692
74.7k
    int8_t i;
693
694
74.7k
    if (enable == 1)
695
25.7k
    {
696
25.7k
        if (dt_flag == 0)
697
15.8k
        {
698
            /* delta coded in frequency direction */
699
15.8k
            index[0] = 0 + index[0];
700
15.8k
            index[0] &= and_modulo;
701
702
62.0k
            for (i = 1; i < nr_par; i++)
703
46.2k
            {
704
46.2k
                index[i] = index[i-1] + index[i];
705
46.2k
                index[i] &= and_modulo;
706
46.2k
            }
707
15.8k
        } else {
708
            /* delta coded in time direction */
709
31.3k
            for (i = 0; i < nr_par; i++)
710
21.4k
            {
711
21.4k
                index[i] = index_prev[i*stride] + index[i];
712
21.4k
                index[i] &= and_modulo;
713
21.4k
            }
714
9.90k
        }
715
48.9k
    } else {
716
        /* set indices to zero */
717
179k
        for (i = 0; i < nr_par; i++)
718
130k
        {
719
130k
            index[i] = 0;
720
130k
        }
721
48.9k
    }
722
723
    /* coarse */
724
74.7k
    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
74.7k
}
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
25.3k
{
766
25.3k
    index[0] = index[0];
767
25.3k
    index[1] = (index[0] + index[1])/2;
768
25.3k
    index[2] = index[1];
769
25.3k
    index[3] = index[2];
770
25.3k
    index[4] = (index[2] + index[3])/2;
771
25.3k
    index[5] = index[3];
772
25.3k
    index[6] = index[4];
773
25.3k
    index[7] = index[4];
774
25.3k
    index[8] = index[5];
775
25.3k
    index[9] = index[5];
776
25.3k
    index[10] = index[6];
777
25.3k
    index[11] = index[7];
778
25.3k
    index[12] = index[8];
779
25.3k
    index[13] = index[8];
780
25.3k
    index[14] = index[9];
781
25.3k
    index[15] = index[9];
782
25.3k
    index[16] = index[10];
783
784
25.3k
    if (bins == 34)
785
12.1k
    {
786
12.1k
        index[17] = index[11];
787
12.1k
        index[18] = index[12];
788
12.1k
        index[19] = index[13];
789
12.1k
        index[20] = index[14];
790
12.1k
        index[21] = index[14];
791
12.1k
        index[22] = index[15];
792
12.1k
        index[23] = index[15];
793
12.1k
        index[24] = index[16];
794
12.1k
        index[25] = index[16];
795
12.1k
        index[26] = index[17];
796
12.1k
        index[27] = index[17];
797
12.1k
        index[28] = index[18];
798
12.1k
        index[29] = index[18];
799
12.1k
        index[30] = index[18];
800
12.1k
        index[31] = index[18];
801
12.1k
        index[32] = index[19];
802
12.1k
        index[33] = index[19];
803
12.1k
    }
804
25.3k
}
805
806
/* parse the bitstream data decoded in ps_data() */
807
static void ps_data_decode(ps_info *ps)
808
21.0k
{
809
21.0k
    uint8_t env, bin;
810
811
    /* ps data not available, use data from previous frame */
812
21.0k
    if (ps->ps_data_available == 0)
813
5.25k
    {
814
5.25k
        ps->num_env = 0;
815
5.25k
    }
816
817
58.4k
    for (env = 0; env < ps->num_env; env++)
818
37.3k
    {
819
37.3k
        int8_t *iid_index_prev;
820
37.3k
        int8_t *icc_index_prev;
821
37.3k
        int8_t *ipd_index_prev;
822
37.3k
        int8_t *opd_index_prev;
823
824
37.3k
        int8_t num_iid_steps = (ps->iid_mode < 3) ? 7 : 15 /*fine quant*/;
825
826
37.3k
        if (env == 0)
827
11.1k
        {
828
            /* take last envelope from previous frame */
829
11.1k
            iid_index_prev = ps->iid_index_prev;
830
11.1k
            icc_index_prev = ps->icc_index_prev;
831
11.1k
            ipd_index_prev = ps->ipd_index_prev;
832
11.1k
            opd_index_prev = ps->opd_index_prev;
833
26.1k
        } else {
834
            /* take index values from previous envelope */
835
26.1k
            iid_index_prev = ps->iid_index[env - 1];
836
26.1k
            icc_index_prev = ps->icc_index[env - 1];
837
26.1k
            ipd_index_prev = ps->ipd_index[env - 1];
838
26.1k
            opd_index_prev = ps->opd_index[env - 1];
839
26.1k
        }
840
841
//        iid = 1;
842
        /* delta decode iid parameters */
843
37.3k
        delta_decode(ps->enable_iid, ps->iid_index[env], iid_index_prev,
844
37.3k
            ps->iid_dt[env], ps->nr_iid_par,
845
37.3k
            (ps->iid_mode == 0 || ps->iid_mode == 3) ? 2 : 1,
846
37.3k
            -num_iid_steps, num_iid_steps);
847
//        iid = 0;
848
849
        /* delta decode icc parameters */
850
37.3k
        delta_decode(ps->enable_icc, ps->icc_index[env], icc_index_prev,
851
37.3k
            ps->icc_dt[env], ps->nr_icc_par,
852
37.3k
            (ps->icc_mode == 0 || ps->icc_mode == 3) ? 2 : 1,
853
37.3k
            0, 7);
854
855
        /* delta modulo decode ipd parameters */
856
37.3k
        delta_modulo_decode(ps->enable_ipdopd, ps->ipd_index[env], ipd_index_prev,
857
37.3k
            ps->ipd_dt[env], ps->nr_ipdopd_par, 1, 7);
858
859
        /* delta modulo decode opd parameters */
860
37.3k
        delta_modulo_decode(ps->enable_ipdopd, ps->opd_index[env], opd_index_prev,
861
37.3k
            ps->opd_dt[env], ps->nr_ipdopd_par, 1, 7);
862
37.3k
    }
863
864
    /* handle error case */
865
21.0k
    if (ps->num_env == 0)
866
9.83k
    {
867
        /* force to 1 */
868
9.83k
        ps->num_env = 1;
869
870
9.83k
        if (ps->enable_iid)
871
6.86k
        {
872
240k
            for (bin = 0; bin < 34; bin++)
873
233k
                ps->iid_index[0][bin] = ps->iid_index_prev[bin];
874
6.86k
        } else {
875
103k
            for (bin = 0; bin < 34; bin++)
876
100k
                ps->iid_index[0][bin] = 0;
877
2.97k
        }
878
879
9.83k
        if (ps->enable_icc)
880
4.82k
        {
881
169k
            for (bin = 0; bin < 34; bin++)
882
164k
                ps->icc_index[0][bin] = ps->icc_index_prev[bin];
883
5.00k
        } else {
884
175k
            for (bin = 0; bin < 34; bin++)
885
170k
                ps->icc_index[0][bin] = 0;
886
5.00k
        }
887
888
9.83k
        if (ps->enable_ipdopd)
889
1.23k
        {
890
22.3k
            for (bin = 0; bin < 17; bin++)
891
21.0k
            {
892
21.0k
                ps->ipd_index[0][bin] = ps->ipd_index_prev[bin];
893
21.0k
                ps->opd_index[0][bin] = ps->opd_index_prev[bin];
894
21.0k
            }
895
8.59k
        } else {
896
154k
            for (bin = 0; bin < 17; bin++)
897
146k
            {
898
146k
                ps->ipd_index[0][bin] = 0;
899
146k
                ps->opd_index[0][bin] = 0;
900
146k
            }
901
8.59k
        }
902
9.83k
    }
903
904
    /* update previous indices */
905
736k
    for (bin = 0; bin < 34; bin++)
906
715k
        ps->iid_index_prev[bin] = ps->iid_index[ps->num_env-1][bin];
907
736k
    for (bin = 0; bin < 34; bin++)
908
715k
        ps->icc_index_prev[bin] = ps->icc_index[ps->num_env-1][bin];
909
378k
    for (bin = 0; bin < 17; bin++)
910
357k
    {
911
357k
        ps->ipd_index_prev[bin] = ps->ipd_index[ps->num_env-1][bin];
912
357k
        ps->opd_index_prev[bin] = ps->opd_index[ps->num_env-1][bin];
913
357k
    }
914
915
21.0k
    ps->ps_data_available = 0;
916
917
21.0k
    if (ps->frame_class == 0)
918
12.6k
    {
919
12.6k
        ps->border_position[0] = 0;
920
23.5k
        for (env = 1; env < ps->num_env; env++)
921
10.9k
        {
922
10.9k
            ps->border_position[env] = (env * ps->numTimeSlotsRate) / ps->num_env;
923
10.9k
        }
924
12.6k
        ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
925
12.6k
    } else {
926
8.38k
        ps->border_position[0] = 0;
927
928
8.38k
        if (ps->border_position[ps->num_env] < ps->numTimeSlotsRate)
929
6.33k
        {
930
221k
            for (bin = 0; bin < 34; bin++)
931
215k
            {
932
215k
                ps->iid_index[ps->num_env][bin] = ps->iid_index[ps->num_env-1][bin];
933
215k
                ps->icc_index[ps->num_env][bin] = ps->icc_index[ps->num_env-1][bin];
934
215k
            }
935
114k
            for (bin = 0; bin < 17; bin++)
936
107k
            {
937
107k
                ps->ipd_index[ps->num_env][bin] = ps->ipd_index[ps->num_env-1][bin];
938
107k
                ps->opd_index[ps->num_env][bin] = ps->opd_index[ps->num_env-1][bin];
939
107k
            }
940
6.33k
            ps->num_env++;
941
6.33k
            ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
942
6.33k
        }
943
944
29.9k
        for (env = 1; env < ps->num_env; env++)
945
21.6k
        {
946
21.6k
            int8_t thr = ps->numTimeSlotsRate - (ps->num_env - env);
947
948
21.6k
            if (ps->border_position[env] > thr)
949
4.81k
            {
950
4.81k
                ps->border_position[env] = thr;
951
16.7k
            } else {
952
16.7k
                thr = ps->border_position[env-1]+1;
953
16.7k
                if (ps->border_position[env] < thr)
954
8.95k
                {
955
8.95k
                    ps->border_position[env] = thr;
956
8.95k
                }
957
16.7k
            }
958
21.6k
        }
959
8.38k
    }
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
21.0k
    if (ps->use34hybrid_bands)
981
7.42k
    {
982
20.4k
        for (env = 0; env < ps->num_env; env++)
983
13.0k
        {
984
13.0k
            if (ps->iid_mode != 2 && ps->iid_mode != 5)
985
6.60k
                map20indexto34(ps->iid_index[env], 34);
986
13.0k
            if (ps->icc_mode != 2 && ps->icc_mode != 5)
987
5.51k
                map20indexto34(ps->icc_index[env], 34);
988
13.0k
            if (ps->ipd_mode != 2 && ps->ipd_mode != 5)
989
6.60k
            {
990
6.60k
                map20indexto34(ps->ipd_index[env], 17);
991
6.60k
                map20indexto34(ps->opd_index[env], 17);
992
6.60k
            }
993
13.0k
        }
994
7.42k
    }
995
21.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
21.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
21.0k
{
1042
21.0k
    uint8_t gr, n, bk;
1043
21.0k
    uint8_t temp_delay = 0;
1044
21.0k
    uint8_t sb, maxsb;
1045
21.0k
    const complex_t *Phi_Fract_SubQmf;
1046
21.0k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
21.0k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
21.0k
    real_t P[32][34];
1049
21.0k
    real_t G_TransientRatio[32][34] = {{0}};
1050
21.0k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
21.0k
    if (ps->use34hybrid_bands)
1055
7.42k
    {
1056
7.42k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
13.6k
    } else{
1058
13.6k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
13.6k
    }
1060
1061
    /* clear the energy values */
1062
694k
    for (n = 0; n < 32; n++)
1063
672k
    {
1064
23.5M
        for (bk = 0; bk < 34; bk++)
1065
22.8M
        {
1066
22.8M
            P[n][bk] = 0;
1067
22.8M
        }
1068
672k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
691k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
670k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
670k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
670k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
2.31M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
1.64M
        {
1081
52.9M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
51.3M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
51.3M
                if (gr < ps->num_hybrid_groups)
1089
11.6M
                {
1090
11.6M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
11.6M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
39.7M
                } else {
1093
39.7M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
39.7M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
39.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
24.1M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
24.1M
                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
27.1M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
51.3M
            }
1109
1.64M
        }
1110
670k
    }
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
545k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
524k
    {
1129
16.9M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
16.3M
        {
1131
16.3M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
16.3M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
16.3M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
144k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
16.3M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
16.3M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
16.3M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
16.3M
            nrg = ps->P_prev[bk];
1144
16.3M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
16.3M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
16.3M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
16.2M
            {
1150
16.2M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
16.2M
            } else {
1152
134k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
134k
            }
1154
16.3M
        }
1155
524k
    }
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
691k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
670k
    {
1174
670k
        if (gr < ps->num_hybrid_groups)
1175
373k
            maxsb = ps->group_border[gr] + 1;
1176
296k
        else
1177
296k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
2.31M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
1.64M
        {
1182
1.64M
            real_t g_DecaySlope;
1183
1.64M
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
1.64M
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
394k
            {
1188
394k
                g_DecaySlope = FRAC_CONST(1.0);
1189
1.24M
            } else {
1190
1.24M
                int8_t decay = ps->decay_cutoff - sb;
1191
1.24M
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
847k
                {
1193
847k
                    g_DecaySlope = 0;
1194
847k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
399k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
399k
                }
1198
1.24M
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
6.56M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
4.92M
            {
1203
4.92M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
4.92M
            }
1205
1206
1207
            /* set delay indices */
1208
1.64M
            temp_delay = ps->saved_delay;
1209
6.56M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
4.92M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
52.9M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
51.3M
            {
1214
51.3M
                complex_t tmp, tmp0, R0;
1215
51.3M
                uint8_t m;
1216
1217
51.3M
                if (gr < ps->num_hybrid_groups)
1218
11.6M
                {
1219
                    /* hybrid filterbank input */
1220
11.6M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
11.6M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
39.7M
                } else {
1223
                    /* QMF filterbank input */
1224
39.7M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
39.7M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
39.7M
                }
1227
1228
51.3M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
26.9M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
26.9M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
26.9M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
26.9M
                    RE(R0) = RE(tmp);
1236
26.9M
                    IM(R0) = IM(tmp);
1237
26.9M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
26.9M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
26.9M
                } else {
1240
                    /* allpass filter */
1241
24.3M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
24.3M
                    if (gr < ps->num_hybrid_groups)
1245
11.6M
                    {
1246
                        /* select data from the hybrid subbands */
1247
11.6M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
11.6M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
11.6M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
11.6M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
11.6M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
11.6M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
12.7M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
12.7M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
12.7M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
12.7M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
12.7M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
12.7M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
12.7M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
12.7M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
24.3M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
24.3M
                    RE(R0) = RE(tmp);
1271
24.3M
                    IM(R0) = IM(tmp);
1272
97.3M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
73.0M
                    {
1274
73.0M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
73.0M
                        if (gr < ps->num_hybrid_groups)
1278
34.8M
                        {
1279
                            /* select data from the hybrid subbands */
1280
34.8M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
34.8M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
34.8M
                            if (ps->use34hybrid_bands)
1284
22.0M
                            {
1285
22.0M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
22.0M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
22.0M
                            } else {
1288
12.8M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
12.8M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
12.8M
                            }
1291
38.1M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
38.1M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
38.1M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
38.1M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
38.1M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
38.1M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
73.0M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
73.0M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
73.0M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
73.0M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
73.0M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
73.0M
                        if (gr < ps->num_hybrid_groups)
1314
34.8M
                        {
1315
34.8M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
34.8M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
38.1M
                        } else {
1318
38.1M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
38.1M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
38.1M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
73.0M
                        RE(R0) = RE(tmp);
1324
73.0M
                        IM(R0) = IM(tmp);
1325
73.0M
                    }
1326
24.3M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
51.3M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
51.3M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
51.3M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
51.3M
                if (gr < ps->num_hybrid_groups)
1336
11.6M
                {
1337
                    /* hybrid */
1338
11.6M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
11.6M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
39.7M
                } else {
1341
                    /* QMF */
1342
39.7M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
39.7M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
39.7M
                }
1345
1346
                /* Update delay buffer index */
1347
51.3M
                if (++temp_delay >= 2)
1348
25.6M
                {
1349
25.6M
                    temp_delay = 0;
1350
25.6M
                }
1351
1352
                /* update delay indices */
1353
51.3M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
26.9M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
26.9M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
19.5M
                    {
1358
19.5M
                        ps->delay_buf_index_delay[sb] = 0;
1359
19.5M
                    }
1360
26.9M
                }
1361
1362
205M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
153M
                {
1364
153M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
39.3M
                    {
1366
39.3M
                        temp_delay_ser[m] = 0;
1367
39.3M
                    }
1368
153M
                }
1369
51.3M
            }
1370
1.64M
        }
1371
670k
    }
1372
1373
    /* update delay indices */
1374
21.0k
    ps->saved_delay = temp_delay;
1375
84.1k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
63.0k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
21.0k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
9.98k
{
1042
9.98k
    uint8_t gr, n, bk;
1043
9.98k
    uint8_t temp_delay = 0;
1044
9.98k
    uint8_t sb, maxsb;
1045
9.98k
    const complex_t *Phi_Fract_SubQmf;
1046
9.98k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
9.98k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
9.98k
    real_t P[32][34];
1049
9.98k
    real_t G_TransientRatio[32][34] = {{0}};
1050
9.98k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
9.98k
    if (ps->use34hybrid_bands)
1055
3.21k
    {
1056
3.21k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
6.76k
    } else{
1058
6.76k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
6.76k
    }
1060
1061
    /* clear the energy values */
1062
329k
    for (n = 0; n < 32; n++)
1063
319k
    {
1064
11.1M
        for (bk = 0; bk < 34; bk++)
1065
10.8M
        {
1066
10.8M
            P[n][bk] = 0;
1067
10.8M
        }
1068
319k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
319k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
309k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
309k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
309k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
1.08M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
773k
        {
1081
24.9M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
24.1M
            {
1083
24.1M
#ifdef FIXED_POINT
1084
24.1M
                uint32_t in_re, in_im;
1085
24.1M
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
24.1M
                if (gr < ps->num_hybrid_groups)
1089
5.30M
                {
1090
5.30M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
5.30M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
18.8M
                } else {
1093
18.8M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
18.8M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
18.8M
                }
1096
1097
                /* accumulate energy */
1098
24.1M
#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
24.1M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
24.1M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
24.1M
                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
24.1M
            }
1109
773k
        }
1110
309k
    }
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
254k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
244k
    {
1129
7.88M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
7.63M
        {
1131
7.63M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
7.63M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
7.63M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
18.6k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
7.63M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
7.63M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
7.63M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
7.63M
            nrg = ps->P_prev[bk];
1144
7.63M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
7.63M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
7.63M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
7.62M
            {
1150
7.62M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
7.62M
            } else {
1152
11.1k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
11.1k
            }
1154
7.63M
        }
1155
244k
    }
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
319k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
309k
    {
1174
309k
        if (gr < ps->num_hybrid_groups)
1175
170k
            maxsb = ps->group_border[gr] + 1;
1176
139k
        else
1177
139k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
1.08M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
773k
        {
1182
773k
            real_t g_DecaySlope;
1183
773k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
773k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
180k
            {
1188
180k
                g_DecaySlope = FRAC_CONST(1.0);
1189
592k
            } else {
1190
592k
                int8_t decay = ps->decay_cutoff - sb;
1191
592k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
402k
                {
1193
402k
                    g_DecaySlope = 0;
1194
402k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
189k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
189k
                }
1198
592k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
3.09M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.31M
            {
1203
2.31M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.31M
            }
1205
1206
1207
            /* set delay indices */
1208
773k
            temp_delay = ps->saved_delay;
1209
3.09M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.31M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
24.9M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
24.1M
            {
1214
24.1M
                complex_t tmp, tmp0, R0;
1215
24.1M
                uint8_t m;
1216
1217
24.1M
                if (gr < ps->num_hybrid_groups)
1218
5.30M
                {
1219
                    /* hybrid filterbank input */
1220
5.30M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
5.30M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
18.8M
                } else {
1223
                    /* QMF filterbank input */
1224
18.8M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
18.8M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
18.8M
                }
1227
1228
24.1M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
12.8M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
12.8M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
12.8M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
12.8M
                    RE(R0) = RE(tmp);
1236
12.8M
                    IM(R0) = IM(tmp);
1237
12.8M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
12.8M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
12.8M
                } else {
1240
                    /* allpass filter */
1241
11.3M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
11.3M
                    if (gr < ps->num_hybrid_groups)
1245
5.30M
                    {
1246
                        /* select data from the hybrid subbands */
1247
5.30M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
5.30M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
5.30M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
5.30M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
5.30M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
5.30M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
6.04M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
6.04M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
6.04M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
6.04M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
6.04M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
6.04M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
6.04M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
6.04M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
11.3M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
11.3M
                    RE(R0) = RE(tmp);
1271
11.3M
                    IM(R0) = IM(tmp);
1272
45.4M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
34.0M
                    {
1274
34.0M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
34.0M
                        if (gr < ps->num_hybrid_groups)
1278
15.9M
                        {
1279
                            /* select data from the hybrid subbands */
1280
15.9M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
15.9M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
15.9M
                            if (ps->use34hybrid_bands)
1284
9.53M
                            {
1285
9.53M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
9.53M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
9.53M
                            } else {
1288
6.38M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
6.38M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
6.38M
                            }
1291
18.1M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
18.1M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
18.1M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
18.1M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
18.1M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
18.1M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
34.0M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
34.0M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
34.0M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
34.0M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
34.0M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
34.0M
                        if (gr < ps->num_hybrid_groups)
1314
15.9M
                        {
1315
15.9M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
15.9M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
18.1M
                        } else {
1318
18.1M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
18.1M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
18.1M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
34.0M
                        RE(R0) = RE(tmp);
1324
34.0M
                        IM(R0) = IM(tmp);
1325
34.0M
                    }
1326
11.3M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
24.1M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
24.1M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
24.1M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
24.1M
                if (gr < ps->num_hybrid_groups)
1336
5.30M
                {
1337
                    /* hybrid */
1338
5.30M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
5.30M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
18.8M
                } else {
1341
                    /* QMF */
1342
18.8M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
18.8M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
18.8M
                }
1345
1346
                /* Update delay buffer index */
1347
24.1M
                if (++temp_delay >= 2)
1348
12.0M
                {
1349
12.0M
                    temp_delay = 0;
1350
12.0M
                }
1351
1352
                /* update delay indices */
1353
24.1M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
12.8M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
12.8M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
9.29M
                    {
1358
9.29M
                        ps->delay_buf_index_delay[sb] = 0;
1359
9.29M
                    }
1360
12.8M
                }
1361
1362
96.6M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
72.4M
                {
1364
72.4M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
18.4M
                    {
1366
18.4M
                        temp_delay_ser[m] = 0;
1367
18.4M
                    }
1368
72.4M
                }
1369
24.1M
            }
1370
773k
        }
1371
309k
    }
1372
1373
    /* update delay indices */
1374
9.98k
    ps->saved_delay = temp_delay;
1375
39.9k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
29.9k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
9.98k
}
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.20k
    {
1056
4.20k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
6.84k
    } else{
1058
6.84k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
6.84k
    }
1060
1061
    /* clear the energy values */
1062
364k
    for (n = 0; n < 32; n++)
1063
353k
    {
1064
12.3M
        for (bk = 0; bk < 34; bk++)
1065
12.0M
        {
1066
12.0M
            P[n][bk] = 0;
1067
12.0M
        }
1068
353k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
371k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
360k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
360k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
360k
        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
868k
        {
1081
28.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
27.1M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
27.1M
                if (gr < ps->num_hybrid_groups)
1089
6.31M
                {
1090
6.31M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
6.31M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
20.8M
                } else {
1093
20.8M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
20.8M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
20.8M
                }
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
27.1M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
27.1M
#endif
1108
27.1M
            }
1109
868k
        }
1110
360k
    }
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
290k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
279k
    {
1129
9.02M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
8.74M
        {
1131
8.74M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
8.74M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
8.74M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
125k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
8.74M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
8.74M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
8.74M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
8.74M
            nrg = ps->P_prev[bk];
1144
8.74M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
8.74M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
8.74M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
8.61M
            {
1150
8.61M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
8.61M
            } else {
1152
123k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
123k
            }
1154
8.74M
        }
1155
279k
    }
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
371k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
360k
    {
1174
360k
        if (gr < ps->num_hybrid_groups)
1175
202k
            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
868k
        {
1182
868k
            real_t g_DecaySlope;
1183
868k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
868k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
214k
            {
1188
214k
                g_DecaySlope = FRAC_CONST(1.0);
1189
654k
            } else {
1190
654k
                int8_t decay = ps->decay_cutoff - sb;
1191
654k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
444k
                {
1193
444k
                    g_DecaySlope = 0;
1194
444k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
209k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
209k
                }
1198
654k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
3.47M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.60M
            {
1203
2.60M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.60M
            }
1205
1206
1207
            /* set delay indices */
1208
868k
            temp_delay = ps->saved_delay;
1209
3.47M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.60M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
28.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
27.1M
            {
1214
27.1M
                complex_t tmp, tmp0, R0;
1215
27.1M
                uint8_t m;
1216
1217
27.1M
                if (gr < ps->num_hybrid_groups)
1218
6.31M
                {
1219
                    /* hybrid filterbank input */
1220
6.31M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
6.31M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
20.8M
                } else {
1223
                    /* QMF filterbank input */
1224
20.8M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
20.8M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
20.8M
                }
1227
1228
27.1M
                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.9M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
12.9M
                    if (gr < ps->num_hybrid_groups)
1245
6.31M
                    {
1246
                        /* select data from the hybrid subbands */
1247
6.31M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
6.31M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
6.31M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
6.31M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
6.31M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
6.31M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
6.66M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
6.66M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
6.66M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
6.66M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
6.66M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
6.66M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
6.66M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
6.66M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
12.9M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
12.9M
                    RE(R0) = RE(tmp);
1271
12.9M
                    IM(R0) = IM(tmp);
1272
51.9M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
38.9M
                    {
1274
38.9M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
38.9M
                        if (gr < ps->num_hybrid_groups)
1278
18.9M
                        {
1279
                            /* select data from the hybrid subbands */
1280
18.9M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
18.9M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
18.9M
                            if (ps->use34hybrid_bands)
1284
12.4M
                            {
1285
12.4M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
12.4M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
12.4M
                            } 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.9M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
19.9M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
19.9M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
19.9M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
19.9M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
19.9M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
38.9M
                        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.9M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
38.9M
                        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.9M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
38.9M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
38.9M
                        if (gr < ps->num_hybrid_groups)
1314
18.9M
                        {
1315
18.9M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
18.9M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
19.9M
                        } else {
1318
19.9M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
19.9M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
19.9M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
38.9M
                        RE(R0) = RE(tmp);
1324
38.9M
                        IM(R0) = IM(tmp);
1325
38.9M
                    }
1326
12.9M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
27.1M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
27.1M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
27.1M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
27.1M
                if (gr < ps->num_hybrid_groups)
1336
6.31M
                {
1337
                    /* hybrid */
1338
6.31M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
6.31M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
20.8M
                } else {
1341
                    /* QMF */
1342
20.8M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
20.8M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
20.8M
                }
1345
1346
                /* Update delay buffer index */
1347
27.1M
                if (++temp_delay >= 2)
1348
13.5M
                {
1349
13.5M
                    temp_delay = 0;
1350
13.5M
                }
1351
1352
                /* update delay indices */
1353
27.1M
                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.3M
                    {
1358
10.3M
                        ps->delay_buf_index_delay[sb] = 0;
1359
10.3M
                    }
1360
14.1M
                }
1361
1362
108M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
81.5M
                {
1364
81.5M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
20.8M
                    {
1366
20.8M
                        temp_delay_ser[m] = 0;
1367
20.8M
                    }
1368
81.5M
                }
1369
27.1M
            }
1370
868k
        }
1371
360k
    }
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.1k
        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
433k
{
1438
#ifdef FIXED_POINT
1439
483k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
#define ALPHA FRAC_CONST(0.948059448969)
1441
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
241k
    real_t abs_inphase = ps_abs(RE(c));
1444
241k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
241k
    if (abs_inphase > abs_quadrature) {
1447
201k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
201k
    } else {
1449
39.6k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
39.6k
    }
1451
#else
1452
191k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
433k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
241k
{
1438
241k
#ifdef FIXED_POINT
1439
241k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
241k
#define ALPHA FRAC_CONST(0.948059448969)
1441
241k
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
241k
    real_t abs_inphase = ps_abs(RE(c));
1444
241k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
241k
    if (abs_inphase > abs_quadrature) {
1447
201k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
201k
    } else {
1449
39.6k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
39.6k
    }
1451
#else
1452
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
241k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
191k
{
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
191k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
191k
#endif
1454
191k
}
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
21.0k
{
1459
21.0k
    uint8_t n;
1460
21.0k
    uint8_t gr;
1461
21.0k
    uint8_t bk = 0;
1462
21.0k
    uint8_t sb, maxsb;
1463
21.0k
    uint8_t env;
1464
21.0k
    uint8_t nr_ipdopd_par;
1465
21.0k
    complex_t h11, h12, h21, h22;  // COEF
1466
21.0k
    complex_t H11, H12, H21, H22;  // COEF
1467
21.0k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
21.0k
    complex_t tempLeft, tempRight; // FRAC
1469
21.0k
    complex_t phaseLeft, phaseRight; // FRAC
1470
21.0k
    real_t L;
1471
21.0k
    const real_t *sf_iid;
1472
21.0k
    uint8_t no_iid_steps;
1473
1474
21.0k
    if (ps->iid_mode >= 3)
1475
8.37k
    {
1476
8.37k
        no_iid_steps = 15;
1477
8.37k
        sf_iid = sf_iid_fine;
1478
12.6k
    } else {
1479
12.6k
        no_iid_steps = 7;
1480
12.6k
        sf_iid = sf_iid_normal;
1481
12.6k
    }
1482
1483
21.0k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
12.5k
    {
1485
12.5k
        nr_ipdopd_par = 11; /* resolution */
1486
12.5k
    } else {
1487
8.47k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
8.47k
    }
1489
1490
691k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
670k
    {
1492
670k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
670k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
2.21M
        for (env = 0; env < ps->num_env; env++)
1498
1.54M
        {
1499
1.54M
            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.54M
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
378
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
378
                    -no_iid_steps);
1507
378
                ps->iid_index[env][bk] = -no_iid_steps;
1508
378
                abs_iid = no_iid_steps;
1509
1.54M
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
260
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
260
                    no_iid_steps);
1512
260
                ps->iid_index[env][bk] = no_iid_steps;
1513
260
                abs_iid = no_iid_steps;
1514
260
            }
1515
1.54M
            if (ps->icc_index[env][bk] < 0) {
1516
644
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
644
                ps->icc_index[env][bk] = 0;
1518
1.54M
            } 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.54M
            if (ps->icc_mode < 3)
1524
895k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
895k
                real_t c_1, c_2;  // COEF
1527
895k
                real_t cosa, sina;  // COEF
1528
895k
                real_t cosb, sinb;  // COEF
1529
895k
                real_t ab1, ab2;  // COEF
1530
895k
                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
895k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
895k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
895k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
895k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
895k
                if (ps->iid_mode >= 3)
1550
264k
                {
1551
264k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
264k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
630k
                } else {
1554
630k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
630k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
630k
                }
1557
1558
895k
                ab1 = MUL_C(cosb, cosa);
1559
895k
                ab2 = MUL_C(sinb, sina);
1560
895k
                ab3 = MUL_C(sinb, cosa);
1561
895k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
895k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
895k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
895k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
895k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
895k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
648k
                real_t sina, cosa;  // COEF
1571
648k
                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
648k
                if (ps->iid_mode >= 3)
1607
417k
                {
1608
417k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
417k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
417k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
417k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
417k
                } else {
1613
231k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
231k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
231k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
231k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
231k
                }
1618
1619
648k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
648k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
648k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
648k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
648k
            }
1624
1.54M
            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.54M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
216k
            {
1632
216k
                int8_t i;
1633
216k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
216k
                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
120k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
120k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
120k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
120k
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
95.7k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
95.7k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
95.7k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
95.7k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
#endif
1652
1653
                /* save current value */
1654
216k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
216k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
216k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
216k
                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
120k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
120k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
120k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
120k
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
95.7k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
95.7k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
95.7k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
95.7k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
#endif
1672
1673
                /* ringbuffer index */
1674
216k
                if (i == 0)
1675
109k
                {
1676
109k
                    i = 2;
1677
109k
                }
1678
216k
                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
120k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
120k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
120k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
120k
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
95.7k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
95.7k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
95.7k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
95.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
216k
                xy = magnitude_c(tempRight);
1716
216k
                pq = magnitude_c(tempLeft);
1717
1718
216k
                if (xy != 0)
1719
216k
                {
1720
216k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
216k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
216k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
216k
                xypq = MUL_F(xy, pq);
1728
1729
216k
                if (xypq != 0)
1730
216k
                {
1731
216k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
216k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
216k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
216k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
216k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
216k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
216k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
216k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
216k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
216k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
216k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
216k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
216k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
216k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
216k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
1.54M
            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.54M
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
1.54M
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
1.54M
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
1.54M
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
1.54M
            RE(H11) = RE(ps->h11_prev[gr]);
1766
1.54M
            RE(H12) = RE(ps->h12_prev[gr]);
1767
1.54M
            RE(H21) = RE(ps->h21_prev[gr]);
1768
1.54M
            RE(H22) = RE(ps->h22_prev[gr]);
1769
1.54M
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
1.54M
            RE(ps->h11_prev[gr]) = RE(h11);
1772
1.54M
            RE(ps->h12_prev[gr]) = RE(h12);
1773
1.54M
            RE(ps->h21_prev[gr]) = RE(h21);
1774
1.54M
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
1.54M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
216k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
216k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
216k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
216k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
216k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
216k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
216k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
216k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
216k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
216k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
31.2k
                {
1792
31.2k
                    IM(deltaH11) = -IM(deltaH11);
1793
31.2k
                    IM(deltaH12) = -IM(deltaH12);
1794
31.2k
                    IM(deltaH21) = -IM(deltaH21);
1795
31.2k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
31.2k
                    IM(H11) = -IM(H11);
1798
31.2k
                    IM(H12) = -IM(H12);
1799
31.2k
                    IM(H21) = -IM(H21);
1800
31.2k
                    IM(H22) = -IM(H22);
1801
31.2k
                }
1802
1803
216k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
216k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
216k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
216k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
216k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
22.4M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
20.9M
            {
1812
                /* addition finalises the interpolation over every n */
1813
20.9M
                RE(H11) += RE(deltaH11);
1814
20.9M
                RE(H12) += RE(deltaH12);
1815
20.9M
                RE(H21) += RE(deltaH21);
1816
20.9M
                RE(H22) += RE(deltaH22);
1817
20.9M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
2.17M
                {
1819
2.17M
                    IM(H11) += IM(deltaH11);
1820
2.17M
                    IM(H12) += IM(deltaH12);
1821
2.17M
                    IM(H21) += IM(deltaH21);
1822
2.17M
                    IM(H22) += IM(deltaH22);
1823
2.17M
                }
1824
1825
                /* channel is an alias to the subband */
1826
72.2M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
51.3M
                {
1828
51.3M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
51.3M
                    if (gr < ps->num_hybrid_groups)
1832
11.6M
                    {
1833
11.6M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
11.6M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
11.6M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
11.6M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
39.7M
                    } else {
1838
39.7M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
39.7M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
39.7M
                        RE(inRight) = RE(X_right[n][sb]);
1841
39.7M
                        IM(inRight) = IM(X_right[n][sb]);
1842
39.7M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
51.3M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
51.3M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
51.3M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
51.3M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
51.3M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
2.17M
                    {
1855
                        /* apply rotation */
1856
2.17M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
2.17M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
2.17M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
2.17M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
2.17M
                    }
1861
1862
                    /* store final samples */
1863
51.3M
                    if (gr < ps->num_hybrid_groups)
1864
11.6M
                    {
1865
11.6M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
11.6M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
11.6M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
11.6M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
39.7M
                    } else {
1870
39.7M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
39.7M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
39.7M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
39.7M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
39.7M
                    }
1875
51.3M
                }
1876
20.9M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
1.54M
            ps->phase_hist++;
1880
1.54M
            if (ps->phase_hist == 2)
1881
771k
            {
1882
771k
                ps->phase_hist = 0;
1883
771k
            }
1884
1.54M
        }
1885
670k
    }
1886
21.0k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
9.98k
{
1459
9.98k
    uint8_t n;
1460
9.98k
    uint8_t gr;
1461
9.98k
    uint8_t bk = 0;
1462
9.98k
    uint8_t sb, maxsb;
1463
9.98k
    uint8_t env;
1464
9.98k
    uint8_t nr_ipdopd_par;
1465
9.98k
    complex_t h11, h12, h21, h22;  // COEF
1466
9.98k
    complex_t H11, H12, H21, H22;  // COEF
1467
9.98k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
9.98k
    complex_t tempLeft, tempRight; // FRAC
1469
9.98k
    complex_t phaseLeft, phaseRight; // FRAC
1470
9.98k
    real_t L;
1471
9.98k
    const real_t *sf_iid;
1472
9.98k
    uint8_t no_iid_steps;
1473
1474
9.98k
    if (ps->iid_mode >= 3)
1475
3.72k
    {
1476
3.72k
        no_iid_steps = 15;
1477
3.72k
        sf_iid = sf_iid_fine;
1478
6.25k
    } else {
1479
6.25k
        no_iid_steps = 7;
1480
6.25k
        sf_iid = sf_iid_normal;
1481
6.25k
    }
1482
1483
9.98k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
6.15k
    {
1485
6.15k
        nr_ipdopd_par = 11; /* resolution */
1486
6.15k
    } else {
1487
3.82k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
3.82k
    }
1489
1490
319k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
309k
    {
1492
309k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
309k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.05M
        for (env = 0; env < ps->num_env; env++)
1498
744k
        {
1499
744k
            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
744k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
93
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
93
                    -no_iid_steps);
1507
93
                ps->iid_index[env][bk] = -no_iid_steps;
1508
93
                abs_iid = no_iid_steps;
1509
744k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
89
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
89
                    no_iid_steps);
1512
89
                ps->iid_index[env][bk] = no_iid_steps;
1513
89
                abs_iid = no_iid_steps;
1514
89
            }
1515
744k
            if (ps->icc_index[env][bk] < 0) {
1516
89
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
89
                ps->icc_index[env][bk] = 0;
1518
744k
            } 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
744k
            if (ps->icc_mode < 3)
1524
396k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
396k
                real_t c_1, c_2;  // COEF
1527
396k
                real_t cosa, sina;  // COEF
1528
396k
                real_t cosb, sinb;  // COEF
1529
396k
                real_t ab1, ab2;  // COEF
1530
396k
                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
396k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
396k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
396k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
396k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
396k
                if (ps->iid_mode >= 3)
1550
69.3k
                {
1551
69.3k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
69.3k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
327k
                } else {
1554
327k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
327k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
327k
                }
1557
1558
396k
                ab1 = MUL_C(cosb, cosa);
1559
396k
                ab2 = MUL_C(sinb, sina);
1560
396k
                ab3 = MUL_C(sinb, cosa);
1561
396k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
396k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
396k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
396k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
396k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
396k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
347k
                real_t sina, cosa;  // COEF
1571
347k
                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
347k
                if (ps->iid_mode >= 3)
1607
235k
                {
1608
235k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
235k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
235k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
235k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
235k
                } else {
1613
112k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
112k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
112k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
112k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
112k
                }
1618
1619
347k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
347k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
347k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
347k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
347k
            }
1624
744k
            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
744k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
120k
            {
1632
120k
                int8_t i;
1633
120k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
120k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
120k
#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
120k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
120k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
120k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
120k
                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
120k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
120k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
120k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
120k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
120k
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
120k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
120k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
120k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
120k
                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
120k
                if (i == 0)
1675
61.1k
                {
1676
61.1k
                    i = 2;
1677
61.1k
                }
1678
120k
                i--;
1679
1680
                /* get value before previous */
1681
120k
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
120k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
120k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
120k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
120k
                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
120k
                xy = magnitude_c(tempRight);
1716
120k
                pq = magnitude_c(tempLeft);
1717
1718
120k
                if (xy != 0)
1719
120k
                {
1720
120k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
120k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
120k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
120k
                xypq = MUL_F(xy, pq);
1728
1729
120k
                if (xypq != 0)
1730
120k
                {
1731
120k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
120k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
120k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
120k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
120k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
120k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
120k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
120k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
120k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
120k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
120k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
120k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
120k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
120k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
120k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
744k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
744k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
744k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
744k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
744k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
744k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
744k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
744k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
744k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
744k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
744k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
744k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
744k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
744k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
744k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
120k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
120k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
120k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
120k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
120k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
120k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
120k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
120k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
120k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
120k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
17.6k
                {
1792
17.6k
                    IM(deltaH11) = -IM(deltaH11);
1793
17.6k
                    IM(deltaH12) = -IM(deltaH12);
1794
17.6k
                    IM(deltaH21) = -IM(deltaH21);
1795
17.6k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
17.6k
                    IM(H11) = -IM(H11);
1798
17.6k
                    IM(H12) = -IM(H12);
1799
17.6k
                    IM(H21) = -IM(H21);
1800
17.6k
                    IM(H22) = -IM(H22);
1801
17.6k
                }
1802
1803
120k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
120k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
120k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
120k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
120k
            }
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.65M
            {
1812
                /* addition finalises the interpolation over every n */
1813
9.65M
                RE(H11) += RE(deltaH11);
1814
9.65M
                RE(H12) += RE(deltaH12);
1815
9.65M
                RE(H21) += RE(deltaH21);
1816
9.65M
                RE(H22) += RE(deltaH22);
1817
9.65M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
1.22M
                {
1819
1.22M
                    IM(H11) += IM(deltaH11);
1820
1.22M
                    IM(H12) += IM(deltaH12);
1821
1.22M
                    IM(H21) += IM(deltaH21);
1822
1.22M
                    IM(H22) += IM(deltaH22);
1823
1.22M
                }
1824
1825
                /* channel is an alias to the subband */
1826
33.8M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
24.1M
                {
1828
24.1M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
24.1M
                    if (gr < ps->num_hybrid_groups)
1832
5.30M
                    {
1833
5.30M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
5.30M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
5.30M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
5.30M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
18.8M
                    } else {
1838
18.8M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
18.8M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
18.8M
                        RE(inRight) = RE(X_right[n][sb]);
1841
18.8M
                        IM(inRight) = IM(X_right[n][sb]);
1842
18.8M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
24.1M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
24.1M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
24.1M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
24.1M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
24.1M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.22M
                    {
1855
                        /* apply rotation */
1856
1.22M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.22M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.22M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.22M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.22M
                    }
1861
1862
                    /* store final samples */
1863
24.1M
                    if (gr < ps->num_hybrid_groups)
1864
5.30M
                    {
1865
5.30M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
5.30M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
5.30M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
5.30M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
18.8M
                    } else {
1870
18.8M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
18.8M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
18.8M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
18.8M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
18.8M
                    }
1875
24.1M
                }
1876
9.65M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
744k
            ps->phase_hist++;
1880
744k
            if (ps->phase_hist == 2)
1881
372k
            {
1882
372k
                ps->phase_hist = 0;
1883
372k
            }
1884
744k
        }
1885
309k
    }
1886
9.98k
}
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.64k
    {
1476
4.64k
        no_iid_steps = 15;
1477
4.64k
        sf_iid = sf_iid_fine;
1478
6.40k
    } else {
1479
6.40k
        no_iid_steps = 7;
1480
6.40k
        sf_iid = sf_iid_normal;
1481
6.40k
    }
1482
1483
11.0k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
6.40k
    {
1485
6.40k
        nr_ipdopd_par = 11; /* resolution */
1486
6.40k
    } else {
1487
4.64k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
4.64k
    }
1489
1490
371k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
360k
    {
1492
360k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
360k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.15M
        for (env = 0; env < ps->num_env; env++)
1498
798k
        {
1499
798k
            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
798k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
285
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
285
                    -no_iid_steps);
1507
285
                ps->iid_index[env][bk] = -no_iid_steps;
1508
285
                abs_iid = no_iid_steps;
1509
798k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
171
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
171
                    no_iid_steps);
1512
171
                ps->iid_index[env][bk] = no_iid_steps;
1513
171
                abs_iid = no_iid_steps;
1514
171
            }
1515
798k
            if (ps->icc_index[env][bk] < 0) {
1516
555
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
555
                ps->icc_index[env][bk] = 0;
1518
798k
            } 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
798k
            if (ps->icc_mode < 3)
1524
498k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
498k
                real_t c_1, c_2;  // COEF
1527
498k
                real_t cosa, sina;  // COEF
1528
498k
                real_t cosb, sinb;  // COEF
1529
498k
                real_t ab1, ab2;  // COEF
1530
498k
                real_t ab3, ab4;  // COEF
1531
1532
                /*
1533
                c_1 = sqrt(2.0 / (1.0 + pow(10.0, quant_iid[no_iid_steps + iid_index] / 10.0)));
1534
                c_2 = sqrt(2.0 / (1.0 + pow(10.0, quant_iid[no_iid_steps - iid_index] / 10.0)));
1535
                alpha = 0.5 * acos(quant_rho[icc_index]);
1536
                beta = alpha * ( c_1 - c_2 ) / sqrt(2.0);
1537
                */
1538
1539
                //printf("%d\n", ps->iid_index[env][bk]);
1540
1541
                /* calculate the scalefactors c_1 and c_2 from the intensity differences */
1542
498k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
498k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
498k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
498k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
498k
                if (ps->iid_mode >= 3)
1550
195k
                {
1551
195k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
195k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
303k
                } else {
1554
303k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
303k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
303k
                }
1557
1558
498k
                ab1 = MUL_C(cosb, cosa);
1559
498k
                ab2 = MUL_C(sinb, sina);
1560
498k
                ab3 = MUL_C(sinb, cosa);
1561
498k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
498k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
498k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
498k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
498k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
498k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
300k
                real_t sina, cosa;  // COEF
1571
300k
                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
300k
                if (ps->iid_mode >= 3)
1607
181k
                {
1608
181k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
181k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
181k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
181k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
181k
                } else {
1613
118k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
118k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
118k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
118k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
118k
                }
1618
1619
300k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
300k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
300k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
300k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
300k
            }
1624
798k
            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
798k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
95.7k
            {
1632
95.7k
                int8_t i;
1633
95.7k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
95.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
95.7k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
95.7k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
95.7k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
95.7k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
95.7k
#endif
1652
1653
                /* save current value */
1654
95.7k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
95.7k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
95.7k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
95.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
95.7k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
95.7k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
95.7k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
95.7k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
95.7k
#endif
1672
1673
                /* ringbuffer index */
1674
95.7k
                if (i == 0)
1675
48.3k
                {
1676
48.3k
                    i = 2;
1677
48.3k
                }
1678
95.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
95.7k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
95.7k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
95.7k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
95.7k
                IM(tempRight) += MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1692
95.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
95.7k
                xy = magnitude_c(tempRight);
1716
95.7k
                pq = magnitude_c(tempLeft);
1717
1718
95.7k
                if (xy != 0)
1719
95.7k
                {
1720
95.7k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
95.7k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
95.7k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
95.7k
                xypq = MUL_F(xy, pq);
1728
1729
95.7k
                if (xypq != 0)
1730
95.7k
                {
1731
95.7k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
95.7k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
95.7k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
95.7k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
95.7k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
95.7k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
95.7k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
95.7k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
95.7k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
95.7k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
95.7k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
95.7k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
95.7k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
95.7k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
95.7k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
798k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
798k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
798k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
798k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
798k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
798k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
798k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
798k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
798k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
798k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
798k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
798k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
798k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
798k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
798k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
95.7k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
95.7k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
95.7k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
95.7k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
95.7k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
95.7k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
95.7k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
95.7k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
95.7k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
95.7k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
13.6k
                {
1792
13.6k
                    IM(deltaH11) = -IM(deltaH11);
1793
13.6k
                    IM(deltaH12) = -IM(deltaH12);
1794
13.6k
                    IM(deltaH21) = -IM(deltaH21);
1795
13.6k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
13.6k
                    IM(H11) = -IM(H11);
1798
13.6k
                    IM(H12) = -IM(H12);
1799
13.6k
                    IM(H21) = -IM(H21);
1800
13.6k
                    IM(H22) = -IM(H22);
1801
13.6k
                }
1802
1803
95.7k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
95.7k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
95.7k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
95.7k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
95.7k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
12.0M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
11.2M
            {
1812
                /* addition finalises the interpolation over every n */
1813
11.2M
                RE(H11) += RE(deltaH11);
1814
11.2M
                RE(H12) += RE(deltaH12);
1815
11.2M
                RE(H21) += RE(deltaH21);
1816
11.2M
                RE(H22) += RE(deltaH22);
1817
11.2M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
949k
                {
1819
949k
                    IM(H11) += IM(deltaH11);
1820
949k
                    IM(H12) += IM(deltaH12);
1821
949k
                    IM(H21) += IM(deltaH21);
1822
949k
                    IM(H22) += IM(deltaH22);
1823
949k
                }
1824
1825
                /* channel is an alias to the subband */
1826
38.4M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
27.1M
                {
1828
27.1M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
27.1M
                    if (gr < ps->num_hybrid_groups)
1832
6.31M
                    {
1833
6.31M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
6.31M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
6.31M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
6.31M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
20.8M
                    } else {
1838
20.8M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
20.8M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
20.8M
                        RE(inRight) = RE(X_right[n][sb]);
1841
20.8M
                        IM(inRight) = IM(X_right[n][sb]);
1842
20.8M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
27.1M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
27.1M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
27.1M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
27.1M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
27.1M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
953k
                    {
1855
                        /* apply rotation */
1856
953k
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
953k
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
953k
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
953k
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
953k
                    }
1861
1862
                    /* store final samples */
1863
27.1M
                    if (gr < ps->num_hybrid_groups)
1864
6.31M
                    {
1865
6.31M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
6.31M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
6.31M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
6.31M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
20.8M
                    } else {
1870
20.8M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
20.8M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
20.8M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
20.8M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
20.8M
                    }
1875
27.1M
                }
1876
11.2M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
798k
            ps->phase_hist++;
1880
798k
            if (ps->phase_hist == 2)
1881
399k
            {
1882
399k
                ps->phase_hist = 0;
1883
399k
            }
1884
798k
        }
1885
360k
    }
1886
11.0k
}
1887
1888
void ps_free(ps_info *ps)
1889
32.5k
{
1890
    /* free hybrid filterbank structures */
1891
32.5k
    hybrid_free(ps->hyb);
1892
1893
32.5k
    faad_free(ps);
1894
32.5k
}
1895
1896
ps_info *ps_init(uint8_t sr_index, uint8_t numTimeSlotsRate)
1897
32.5k
{
1898
32.5k
    uint8_t i;
1899
32.5k
    uint8_t short_delay_band;
1900
1901
32.5k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
32.5k
    memset(ps, 0, sizeof(ps_info));
1903
1904
32.5k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
32.5k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
32.5k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
32.5k
    ps->saved_delay = 0;
1911
1912
2.11M
    for (i = 0; i < 64; i++)
1913
2.08M
    {
1914
2.08M
        ps->delay_buf_index_delay[i] = 0;
1915
2.08M
    }
1916
1917
130k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
97.5k
    {
1919
97.5k
        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
97.5k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
97.5k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
97.5k
#endif
1932
97.5k
    }
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
32.5k
    short_delay_band = 35;
1950
32.5k
    ps->nr_allpass_bands = 22;
1951
32.5k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
32.5k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
32.5k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
1.17M
    for (i = 0; i < short_delay_band; i++)
1957
1.13M
    {
1958
1.13M
        ps->delay_D[i] = 14;
1959
1.13M
    }
1960
975k
    for (i = short_delay_band; i < 64; i++)
1961
942k
    {
1962
942k
        ps->delay_D[i] = 1;
1963
942k
    }
1964
1965
    /* mixing and phase */
1966
1.65M
    for (i = 0; i < 50; i++)
1967
1.62M
    {
1968
1.62M
        RE(ps->h11_prev[i]) = 1;
1969
1.62M
        IM(ps->h11_prev[i]) = 1;
1970
1.62M
        RE(ps->h12_prev[i]) = 1;
1971
1.62M
        IM(ps->h12_prev[i]) = 1;
1972
1.62M
    }
1973
1974
32.5k
    ps->phase_hist = 0;
1975
1976
682k
    for (i = 0; i < 20; i++)
1977
650k
    {
1978
650k
        RE(ps->ipd_prev[i][0]) = 0;
1979
650k
        IM(ps->ipd_prev[i][0]) = 0;
1980
650k
        RE(ps->ipd_prev[i][1]) = 0;
1981
650k
        IM(ps->ipd_prev[i][1]) = 0;
1982
650k
        RE(ps->opd_prev[i][0]) = 0;
1983
650k
        IM(ps->opd_prev[i][0]) = 0;
1984
650k
        RE(ps->opd_prev[i][1]) = 0;
1985
650k
        IM(ps->opd_prev[i][1]) = 0;
1986
650k
    }
1987
1988
32.5k
    return ps;
1989
32.5k
}
ps_init
Line
Count
Source
1897
14.7k
{
1898
14.7k
    uint8_t i;
1899
14.7k
    uint8_t short_delay_band;
1900
1901
14.7k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
14.7k
    memset(ps, 0, sizeof(ps_info));
1903
1904
14.7k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
14.7k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
14.7k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
14.7k
    ps->saved_delay = 0;
1911
1912
961k
    for (i = 0; i < 64; i++)
1913
946k
    {
1914
946k
        ps->delay_buf_index_delay[i] = 0;
1915
946k
    }
1916
1917
59.1k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
44.3k
    {
1919
44.3k
        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
44.3k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
44.3k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
44.3k
#endif
1932
44.3k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
14.7k
    short_delay_band = 35;
1950
14.7k
    ps->nr_allpass_bands = 22;
1951
14.7k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
14.7k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
14.7k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
532k
    for (i = 0; i < short_delay_band; i++)
1957
517k
    {
1958
517k
        ps->delay_D[i] = 14;
1959
517k
    }
1960
443k
    for (i = short_delay_band; i < 64; i++)
1961
428k
    {
1962
428k
        ps->delay_D[i] = 1;
1963
428k
    }
1964
1965
    /* mixing and phase */
1966
754k
    for (i = 0; i < 50; i++)
1967
739k
    {
1968
739k
        RE(ps->h11_prev[i]) = 1;
1969
739k
        IM(ps->h11_prev[i]) = 1;
1970
739k
        RE(ps->h12_prev[i]) = 1;
1971
739k
        IM(ps->h12_prev[i]) = 1;
1972
739k
    }
1973
1974
14.7k
    ps->phase_hist = 0;
1975
1976
310k
    for (i = 0; i < 20; i++)
1977
295k
    {
1978
295k
        RE(ps->ipd_prev[i][0]) = 0;
1979
295k
        IM(ps->ipd_prev[i][0]) = 0;
1980
295k
        RE(ps->ipd_prev[i][1]) = 0;
1981
295k
        IM(ps->ipd_prev[i][1]) = 0;
1982
295k
        RE(ps->opd_prev[i][0]) = 0;
1983
295k
        IM(ps->opd_prev[i][0]) = 0;
1984
295k
        RE(ps->opd_prev[i][1]) = 0;
1985
295k
        IM(ps->opd_prev[i][1]) = 0;
1986
295k
    }
1987
1988
14.7k
    return ps;
1989
14.7k
}
ps_init
Line
Count
Source
1897
17.7k
{
1898
17.7k
    uint8_t i;
1899
17.7k
    uint8_t short_delay_band;
1900
1901
17.7k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
17.7k
    memset(ps, 0, sizeof(ps_info));
1903
1904
17.7k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
17.7k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
17.7k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
17.7k
    ps->saved_delay = 0;
1911
1912
1.15M
    for (i = 0; i < 64; i++)
1913
1.13M
    {
1914
1.13M
        ps->delay_buf_index_delay[i] = 0;
1915
1.13M
    }
1916
1917
70.8k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
53.1k
    {
1919
53.1k
        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
53.1k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
53.1k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
53.1k
#endif
1932
53.1k
    }
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
17.7k
    short_delay_band = 35;
1950
17.7k
    ps->nr_allpass_bands = 22;
1951
17.7k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
17.7k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
17.7k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
637k
    for (i = 0; i < short_delay_band; i++)
1957
619k
    {
1958
619k
        ps->delay_D[i] = 14;
1959
619k
    }
1960
531k
    for (i = short_delay_band; i < 64; i++)
1961
513k
    {
1962
513k
        ps->delay_D[i] = 1;
1963
513k
    }
1964
1965
    /* mixing and phase */
1966
903k
    for (i = 0; i < 50; i++)
1967
885k
    {
1968
885k
        RE(ps->h11_prev[i]) = 1;
1969
885k
        IM(ps->h11_prev[i]) = 1;
1970
885k
        RE(ps->h12_prev[i]) = 1;
1971
885k
        IM(ps->h12_prev[i]) = 1;
1972
885k
    }
1973
1974
17.7k
    ps->phase_hist = 0;
1975
1976
371k
    for (i = 0; i < 20; i++)
1977
354k
    {
1978
354k
        RE(ps->ipd_prev[i][0]) = 0;
1979
354k
        IM(ps->ipd_prev[i][0]) = 0;
1980
354k
        RE(ps->ipd_prev[i][1]) = 0;
1981
354k
        IM(ps->ipd_prev[i][1]) = 0;
1982
354k
        RE(ps->opd_prev[i][0]) = 0;
1983
354k
        IM(ps->opd_prev[i][0]) = 0;
1984
354k
        RE(ps->opd_prev[i][1]) = 0;
1985
354k
        IM(ps->opd_prev[i][1]) = 0;
1986
354k
    }
1987
1988
17.7k
    return ps;
1989
17.7k
}
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
21.0k
{
1994
21.0k
    qmf_t X_hybrid_left[32][32] = {{{0}}};
1995
21.0k
    qmf_t X_hybrid_right[32][32] = {{{0}}};
1996
1997
    /* delta decoding of the bitstream data */
1998
21.0k
    ps_data_decode(ps);
1999
2000
    /* set up some parameters depending on filterbank type */
2001
21.0k
    if (ps->use34hybrid_bands)
2002
7.42k
    {
2003
7.42k
        ps->group_border = (uint8_t*)group_border34;
2004
7.42k
        ps->map_group2bk = (uint16_t*)map_group2bk34;
2005
7.42k
        ps->num_groups = 32+18;
2006
7.42k
        ps->num_hybrid_groups = 32;
2007
7.42k
        ps->nr_par_bands = 34;
2008
7.42k
        ps->decay_cutoff = 5;
2009
13.6k
    } else {
2010
13.6k
        ps->group_border = (uint8_t*)group_border20;
2011
13.6k
        ps->map_group2bk = (uint16_t*)map_group2bk20;
2012
13.6k
        ps->num_groups = 10+12;
2013
13.6k
        ps->num_hybrid_groups = 10;
2014
13.6k
        ps->nr_par_bands = 20;
2015
13.6k
        ps->decay_cutoff = 3;
2016
13.6k
    }
2017
2018
    /* Perform further analysis on the lowest subbands to get a higher
2019
     * frequency resolution
2020
     */
2021
21.0k
    hybrid_analysis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2022
21.0k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2023
2024
    /* decorrelate mono signal */
2025
21.0k
    ps_decorrelate(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2026
2027
    /* apply mixing and phase parameters */
2028
21.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
21.0k
    hybrid_synthesis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2032
21.0k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2033
2034
21.0k
    hybrid_synthesis((hyb_info*)ps->hyb, X_right, X_hybrid_right,
2035
21.0k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2036
2037
21.0k
    return 0;
2038
21.0k
}
2039
2040
#endif