Coverage Report

Created: 2025-08-29 06:11

/proc/self/cwd/libfaad/ps_dec.c
Line
Count
Source (jump to first uncovered line)
1
/*
2
** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
3
** Copyright (C) 2003-2005 M. Bakker, Nero AG, http://www.nero.com
4
**
5
** This program is free software; you can redistribute it and/or modify
6
** it under the terms of the GNU General Public License as published by
7
** the Free Software Foundation; either version 2 of the License, or
8
** (at your option) any later version.
9
**
10
** This program is distributed in the hope that it will be useful,
11
** but WITHOUT ANY WARRANTY; without even the implied warranty of
12
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
** GNU General Public License for more details.
14
**
15
** You should have received a copy of the GNU General Public License
16
** along with this program; if not, write to the Free Software
17
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18
**
19
** Any non-GPL usage of this software or parts of this software is strictly
20
** forbidden.
21
**
22
** The "appropriate copyright message" mentioned in section 2c of the GPLv2
23
** must read: "Code from FAAD2 is copyright (c) Nero AG, www.nero.com"
24
**
25
** Commercial non-GPL licensing of this software is possible.
26
** For more info contact Nero AG through Mpeg4AAClicense@nero.com.
27
**
28
** $Id: ps_dec.c,v 1.16 2009/01/26 22:32:31 menno Exp $
29
**/
30
31
#include "common.h"
32
33
#ifdef PS_DEC
34
35
#include <stdlib.h>
36
#include <stdio.h>
37
#include "ps_dec.h"
38
#include "ps_tables.h"
39
40
/* constants */
41
50.5M
#define NEGATE_IPD_MASK            (0x1000)
42
376k
#define DECAY_SLOPE                FRAC_CONST(0.05)
43
#define COEF_SQRT2                 COEF_CONST(1.4142135623731)
44
45
/* tables */
46
/* filters are mirrored in coef 6, second half left out */
47
static const real_t p8_13_20[7] =
48
{
49
    FRAC_CONST(0.00746082949812),
50
    FRAC_CONST(0.02270420949825),
51
    FRAC_CONST(0.04546865930473),
52
    FRAC_CONST(0.07266113929591),
53
    FRAC_CONST(0.09885108575264),
54
    FRAC_CONST(0.11793710567217),
55
    FRAC_CONST(0.125)
56
};
57
58
static const real_t p2_13_20[7] =
59
{
60
    FRAC_CONST(0.0),
61
    FRAC_CONST(0.01899487526049),
62
    FRAC_CONST(0.0),
63
    FRAC_CONST(-0.07293139167538),
64
    FRAC_CONST(0.0),
65
    FRAC_CONST(0.30596630545168),
66
    FRAC_CONST(0.5)
67
};
68
69
static const real_t p12_13_34[7] =
70
{
71
    FRAC_CONST(0.04081179924692),
72
    FRAC_CONST(0.03812810994926),
73
    FRAC_CONST(0.05144908135699),
74
    FRAC_CONST(0.06399831151592),
75
    FRAC_CONST(0.07428313801106),
76
    FRAC_CONST(0.08100347892914),
77
    FRAC_CONST(0.08333333333333)
78
};
79
80
static const real_t p8_13_34[7] =
81
{
82
    FRAC_CONST(0.01565675600122),
83
    FRAC_CONST(0.03752716391991),
84
    FRAC_CONST(0.05417891378782),
85
    FRAC_CONST(0.08417044116767),
86
    FRAC_CONST(0.10307344158036),
87
    FRAC_CONST(0.12222452249753),
88
    FRAC_CONST(0.125)
89
};
90
91
static const real_t p4_13_34[7] =
92
{
93
    FRAC_CONST(-0.05908211155639),
94
    FRAC_CONST(-0.04871498374946),
95
    FRAC_CONST(0.0),
96
    FRAC_CONST(0.07778723915851),
97
    FRAC_CONST(0.16486303567403),
98
    FRAC_CONST(0.23279856662996),
99
    FRAC_CONST(0.25)
100
};
101
102
#ifdef PARAM_32KHZ
103
static const uint8_t delay_length_d[2][NO_ALLPASS_LINKS] = {
104
    { 1, 2, 3 } /* d_24kHz */,
105
    { 3, 4, 5 } /* d_48kHz */
106
};
107
#else
108
static const uint8_t delay_length_d[NO_ALLPASS_LINKS] = {
109
    3, 4, 5 /* d_48kHz */
110
};
111
#endif
112
static const real_t filter_a[NO_ALLPASS_LINKS] = { /* a(m) = exp(-d_48kHz(m)/7) */
113
    FRAC_CONST(0.65143905753106),
114
    FRAC_CONST(0.56471812200776),
115
    FRAC_CONST(0.48954165955695)
116
};
117
118
static const uint8_t group_border20[10+12 + 1] =
119
{
120
    6, 7, 0, 1, 2, 3, /* 6 subqmf subbands */
121
    9, 8,             /* 2 subqmf subbands */
122
    10, 11,           /* 2 subqmf subbands */
123
    3, 4, 5, 6, 7, 8, 9, 11, 14, 18, 23, 35, 64
124
};
125
126
static const uint8_t group_border34[32+18 + 1] =
127
{
128
     0,  1,  2,  3,  4,  5,  6,  7,  8,  9,  10, 11, /* 12 subqmf subbands */
129
     12, 13, 14, 15, 16, 17, 18, 19,                 /*  8 subqmf subbands */
130
     20, 21, 22, 23,                                 /*  4 subqmf subbands */
131
     24, 25, 26, 27,                                 /*  4 subqmf subbands */
132
     28, 29, 30, 31,                                 /*  4 subqmf subbands */
133
     32-27, 33-27, 34-27, 35-27, 36-27, 37-27, 38-27, 40-27, 42-27, 44-27, 46-27, 48-27, 51-27, 54-27, 57-27, 60-27, 64-27, 68-27, 91-27
134
};
135
136
static const uint16_t map_group2bk20[10+12] =
137
{
138
    (NEGATE_IPD_MASK | 1), (NEGATE_IPD_MASK | 0),
139
    0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19
140
};
141
142
static const uint16_t map_group2bk34[32+18] =
143
{
144
    0,  1,  2,  3,  4,  5,  6,  6,  7, (NEGATE_IPD_MASK | 2), (NEGATE_IPD_MASK | 1), (NEGATE_IPD_MASK | 0),
145
    10, 10, 4,  5,  6,  7,  8,  9,
146
    10, 11, 12, 9,
147
    14, 11, 12, 13,
148
    14, 15, 16, 13,
149
    16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33
150
};
151
152
/* type definitions */
153
typedef struct
154
{
155
    uint8_t frame_len;
156
    uint8_t resolution20[3];
157
    uint8_t resolution34[5];
158
159
    qmf_t *work;
160
    qmf_t **buffer;
161
    qmf_t **temp;
162
} hyb_info;
163
164
/* static function declarations */
165
static void ps_data_decode(ps_info *ps);
166
static hyb_info *hybrid_init(uint8_t numTimeSlotsRate);
167
static void channel_filter2(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
168
                            qmf_t *buffer, qmf_t **X_hybrid);
169
static void INLINE DCT3_4_unscaled(real_t *y, real_t *x);
170
static void channel_filter8(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
171
                            qmf_t *buffer, qmf_t **X_hybrid);
172
static void hybrid_analysis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
173
                            uint8_t use34, uint8_t numTimeSlotsRate);
174
static void hybrid_synthesis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
175
                             uint8_t use34, uint8_t numTimeSlotsRate);
176
static int8_t delta_clip(int8_t i, int8_t min, int8_t max);
177
static void delta_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
178
                         uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
179
                         int8_t min_index, int8_t max_index);
180
static void delta_modulo_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
181
                                uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
182
                                int8_t and_modulo);
183
static void map20indexto34(int8_t *index, uint8_t bins);
184
#ifdef PS_LOW_POWER
185
static void map34indexto20(int8_t *index, uint8_t bins);
186
#endif
187
static void ps_data_decode(ps_info *ps);
188
static void ps_decorrelate(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
189
                           qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32]);
190
static void ps_mix_phase(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
191
                         qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32]);
192
193
/*  */
194
195
196
static hyb_info *hybrid_init(uint8_t numTimeSlotsRate)
197
30.7k
{
198
30.7k
    uint8_t i;
199
200
30.7k
    hyb_info *hyb = (hyb_info*)faad_malloc(sizeof(hyb_info));
201
202
30.7k
    hyb->resolution34[0] = 12;
203
30.7k
    hyb->resolution34[1] = 8;
204
30.7k
    hyb->resolution34[2] = 4;
205
30.7k
    hyb->resolution34[3] = 4;
206
30.7k
    hyb->resolution34[4] = 4;
207
208
30.7k
    hyb->resolution20[0] = 8;
209
30.7k
    hyb->resolution20[1] = 2;
210
30.7k
    hyb->resolution20[2] = 2;
211
212
30.7k
    hyb->frame_len = numTimeSlotsRate;
213
214
30.7k
    hyb->work = (qmf_t*)faad_malloc((hyb->frame_len+12) * sizeof(qmf_t));
215
30.7k
    memset(hyb->work, 0, (hyb->frame_len+12) * sizeof(qmf_t));
216
217
30.7k
    hyb->buffer = (qmf_t**)faad_malloc(5 * sizeof(qmf_t*));
218
184k
    for (i = 0; i < 5; i++)
219
153k
    {
220
153k
        hyb->buffer[i] = (qmf_t*)faad_malloc(hyb->frame_len * sizeof(qmf_t));
221
153k
        memset(hyb->buffer[i], 0, hyb->frame_len * sizeof(qmf_t));
222
153k
    }
223
224
30.7k
    hyb->temp = (qmf_t**)faad_malloc(hyb->frame_len * sizeof(qmf_t*));
225
1.00M
    for (i = 0; i < hyb->frame_len; i++)
226
972k
    {
227
972k
        hyb->temp[i] = (qmf_t*)faad_malloc(12 /*max*/ * sizeof(qmf_t));
228
972k
    }
229
230
30.7k
    return hyb;
231
30.7k
}
232
233
static void hybrid_free(hyb_info *hyb)
234
30.7k
{
235
30.7k
    uint8_t i;
236
237
30.7k
  if (!hyb) return;
238
239
30.7k
    if (hyb->work)
240
30.7k
        faad_free(hyb->work);
241
242
184k
    for (i = 0; i < 5; i++)
243
153k
    {
244
153k
        if (hyb->buffer[i])
245
153k
            faad_free(hyb->buffer[i]);
246
153k
    }
247
30.7k
    if (hyb->buffer)
248
30.7k
        faad_free(hyb->buffer);
249
250
1.00M
    for (i = 0; i < hyb->frame_len; i++)
251
972k
    {
252
972k
        if (hyb->temp[i])
253
972k
            faad_free(hyb->temp[i]);
254
972k
    }
255
30.7k
    if (hyb->temp)
256
30.7k
        faad_free(hyb->temp);
257
258
30.7k
    faad_free(hyb);
259
30.7k
}
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
46.9k
{
265
46.9k
    uint8_t i;
266
46.9k
    (void)hyb;  /* TODO: remove parameter? */
267
268
1.52M
    for (i = 0; i < frame_len; i++)
269
1.47M
    {
270
1.47M
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
1.47M
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
1.47M
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
1.47M
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
1.47M
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
1.47M
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
1.47M
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
1.47M
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
1.47M
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
1.47M
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
1.47M
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
1.47M
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
1.47M
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
1.47M
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
1.47M
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
1.47M
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
1.47M
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
1.47M
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
1.47M
    }
293
46.9k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
23.4k
{
265
23.4k
    uint8_t i;
266
23.4k
    (void)hyb;  /* TODO: remove parameter? */
267
268
761k
    for (i = 0; i < frame_len; i++)
269
738k
    {
270
738k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
738k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
738k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
738k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
738k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
738k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
738k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
738k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
738k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
738k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
738k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
738k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
738k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
738k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
738k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
738k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
738k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
738k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
738k
    }
293
23.4k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
23.4k
{
265
23.4k
    uint8_t i;
266
23.4k
    (void)hyb;  /* TODO: remove parameter? */
267
268
761k
    for (i = 0; i < frame_len; i++)
269
738k
    {
270
738k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
738k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
738k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
738k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
738k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
738k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
738k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
738k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
738k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
738k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
738k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
738k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
738k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
738k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
738k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
738k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
738k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
738k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
738k
    }
293
23.4k
}
294
295
/* complex filter, size 4 */
296
static void channel_filter4(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
297
                            qmf_t *buffer, qmf_t **X_hybrid)
298
24.3k
{
299
24.3k
    uint8_t i;
300
24.3k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
24.3k
    (void)hyb;  /* TODO: remove parameter? */
302
303
772k
    for (i = 0; i < frame_len; i++)
304
748k
    {
305
748k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
748k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
748k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
748k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
748k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
748k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
748k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
748k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
748k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
748k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
748k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
748k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
748k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
748k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
748k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
748k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
748k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
748k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
748k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
748k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
748k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
748k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
748k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
748k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
748k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
748k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
748k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
748k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
748k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
748k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
748k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
748k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
748k
    }
349
24.3k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
11.5k
{
299
11.5k
    uint8_t i;
300
11.5k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
11.5k
    (void)hyb;  /* TODO: remove parameter? */
302
303
365k
    for (i = 0; i < frame_len; i++)
304
353k
    {
305
353k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
353k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
353k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
353k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
353k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
353k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
353k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
353k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
353k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
353k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
353k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
353k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
353k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
353k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
353k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
353k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
353k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
353k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
353k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
353k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
353k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
353k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
353k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
353k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
353k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
353k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
353k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
353k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
353k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
353k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
353k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
353k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
353k
    }
349
11.5k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
12.8k
{
299
12.8k
    uint8_t i;
300
12.8k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
12.8k
    (void)hyb;  /* TODO: remove parameter? */
302
303
407k
    for (i = 0; i < frame_len; i++)
304
394k
    {
305
394k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
394k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
394k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
394k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
394k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
394k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
394k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
394k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
394k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
394k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
394k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
394k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
394k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
394k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
394k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
394k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
394k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
394k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
394k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
394k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
394k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
394k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
394k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
394k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
394k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
394k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
394k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
394k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
394k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
394k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
394k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
394k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
394k
    }
349
12.8k
}
350
351
static void INLINE DCT3_4_unscaled(real_t *y, real_t *x)
352
2.47M
{
353
2.47M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
2.47M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
2.47M
    f1 = x[0] - f0;
357
2.47M
    f2 = x[0] + f0;
358
2.47M
    f3 = x[1] + x[3];
359
2.47M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
2.47M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
2.47M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
2.47M
    f7 = f4 + f5;
363
2.47M
    f8 = f6 - f5;
364
2.47M
    y[3] = f2 - f8;
365
2.47M
    y[0] = f2 + f8;
366
2.47M
    y[2] = f1 - f7;
367
2.47M
    y[1] = f1 + f7;
368
2.47M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.06M
{
353
1.06M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.06M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.06M
    f1 = x[0] - f0;
357
1.06M
    f2 = x[0] + f0;
358
1.06M
    f3 = x[1] + x[3];
359
1.06M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.06M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.06M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.06M
    f7 = f4 + f5;
363
1.06M
    f8 = f6 - f5;
364
1.06M
    y[3] = f2 - f8;
365
1.06M
    y[0] = f2 + f8;
366
1.06M
    y[2] = f1 - f7;
367
1.06M
    y[1] = f1 + f7;
368
1.06M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.41M
{
353
1.41M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.41M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.41M
    f1 = x[0] - f0;
357
1.41M
    f2 = x[0] + f0;
358
1.41M
    f3 = x[1] + x[3];
359
1.41M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.41M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.41M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.41M
    f7 = f4 + f5;
363
1.41M
    f8 = f6 - f5;
364
1.41M
    y[3] = f2 - f8;
365
1.41M
    y[0] = f2 + f8;
366
1.41M
    y[2] = f1 - f7;
367
1.41M
    y[1] = f1 + f7;
368
1.41M
}
369
370
/* complex filter, size 8 */
371
static void channel_filter8(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
372
                            qmf_t *buffer, qmf_t **X_hybrid)
373
39.6k
{
374
39.6k
    uint8_t i, n;
375
39.6k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
39.6k
    real_t x[4];
377
39.6k
    (void)hyb;  /* TODO: remove parameter? */
378
379
1.27M
    for (i = 0; i < frame_len; i++)
380
1.23M
    {
381
1.23M
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
1.23M
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
1.23M
        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.23M
        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.23M
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
1.23M
        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.23M
        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.23M
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
6.18M
        for (n = 0; n < 4; n++)
392
4.94M
        {
393
4.94M
            x[n] = input_re1[n] - input_im1[3-n];
394
4.94M
        }
395
1.23M
        DCT3_4_unscaled(x, x);
396
1.23M
        QMF_RE(X_hybrid[i][7]) = x[0];
397
1.23M
        QMF_RE(X_hybrid[i][5]) = x[2];
398
1.23M
        QMF_RE(X_hybrid[i][3]) = x[3];
399
1.23M
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
6.18M
        for (n = 0; n < 4; n++)
402
4.94M
        {
403
4.94M
            x[n] = input_re1[n] + input_im1[3-n];
404
4.94M
        }
405
1.23M
        DCT3_4_unscaled(x, x);
406
1.23M
        QMF_RE(X_hybrid[i][6]) = x[1];
407
1.23M
        QMF_RE(X_hybrid[i][4]) = x[3];
408
1.23M
        QMF_RE(X_hybrid[i][2]) = x[2];
409
1.23M
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
1.23M
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
1.23M
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
1.23M
        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.23M
        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.23M
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
1.23M
        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.23M
        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.23M
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
6.18M
        for (n = 0; n < 4; n++)
422
4.94M
        {
423
4.94M
            x[n] = input_im2[n] + input_re2[3-n];
424
4.94M
        }
425
1.23M
        DCT3_4_unscaled(x, x);
426
1.23M
        QMF_IM(X_hybrid[i][7]) = x[0];
427
1.23M
        QMF_IM(X_hybrid[i][5]) = x[2];
428
1.23M
        QMF_IM(X_hybrid[i][3]) = x[3];
429
1.23M
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
6.18M
        for (n = 0; n < 4; n++)
432
4.94M
        {
433
4.94M
            x[n] = input_im2[n] - input_re2[3-n];
434
4.94M
        }
435
1.23M
        DCT3_4_unscaled(x, x);
436
1.23M
        QMF_IM(X_hybrid[i][6]) = x[1];
437
1.23M
        QMF_IM(X_hybrid[i][4]) = x[3];
438
1.23M
        QMF_IM(X_hybrid[i][2]) = x[2];
439
1.23M
        QMF_IM(X_hybrid[i][0]) = x[0];
440
1.23M
    }
441
39.6k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
19.8k
{
374
19.8k
    uint8_t i, n;
375
19.8k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
19.8k
    real_t x[4];
377
19.8k
    (void)hyb;  /* TODO: remove parameter? */
378
379
638k
    for (i = 0; i < frame_len; i++)
380
618k
    {
381
618k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
618k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
618k
        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
618k
        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
618k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
618k
        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
618k
        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
618k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.09M
        for (n = 0; n < 4; n++)
392
2.47M
        {
393
2.47M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.47M
        }
395
618k
        DCT3_4_unscaled(x, x);
396
618k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
618k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
618k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
618k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.09M
        for (n = 0; n < 4; n++)
402
2.47M
        {
403
2.47M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.47M
        }
405
618k
        DCT3_4_unscaled(x, x);
406
618k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
618k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
618k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
618k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
618k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
618k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
618k
        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
618k
        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
618k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
618k
        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
618k
        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
618k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.09M
        for (n = 0; n < 4; n++)
422
2.47M
        {
423
2.47M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.47M
        }
425
618k
        DCT3_4_unscaled(x, x);
426
618k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
618k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
618k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
618k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.09M
        for (n = 0; n < 4; n++)
432
2.47M
        {
433
2.47M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.47M
        }
435
618k
        DCT3_4_unscaled(x, x);
436
618k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
618k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
618k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
618k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
618k
    }
441
19.8k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
19.8k
{
374
19.8k
    uint8_t i, n;
375
19.8k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
19.8k
    real_t x[4];
377
19.8k
    (void)hyb;  /* TODO: remove parameter? */
378
379
638k
    for (i = 0; i < frame_len; i++)
380
618k
    {
381
618k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
618k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
618k
        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
618k
        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
618k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
618k
        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
618k
        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
618k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.09M
        for (n = 0; n < 4; n++)
392
2.47M
        {
393
2.47M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.47M
        }
395
618k
        DCT3_4_unscaled(x, x);
396
618k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
618k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
618k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
618k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.09M
        for (n = 0; n < 4; n++)
402
2.47M
        {
403
2.47M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.47M
        }
405
618k
        DCT3_4_unscaled(x, x);
406
618k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
618k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
618k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
618k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
618k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
618k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
618k
        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
618k
        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
618k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
618k
        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
618k
        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
618k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.09M
        for (n = 0; n < 4; n++)
422
2.47M
        {
423
2.47M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.47M
        }
425
618k
        DCT3_4_unscaled(x, x);
426
618k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
618k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
618k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
618k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.09M
        for (n = 0; n < 4; n++)
432
2.47M
        {
433
2.47M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.47M
        }
435
618k
        DCT3_4_unscaled(x, x);
436
618k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
618k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
618k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
618k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
618k
    }
441
19.8k
}
442
443
static void INLINE DCT3_6_unscaled(real_t *y, real_t *x)
444
997k
{
445
997k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
997k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
997k
    f1 = x[0] + f0;
449
997k
    f2 = x[0] - f0;
450
997k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
997k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
997k
    f5 = f4 - x[4];
453
997k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
997k
    f7 = f6 - f3;
455
997k
    y[0] = f1 + f6 + f4;
456
997k
    y[1] = f2 + f3 - x[4];
457
997k
    y[2] = f7 + f2 - f5;
458
997k
    y[3] = f1 - f7 - f5;
459
997k
    y[4] = f1 - f3 - x[4];
460
997k
    y[5] = f2 - f6 + f4;
461
997k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
471k
{
445
471k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
471k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
471k
    f1 = x[0] + f0;
449
471k
    f2 = x[0] - f0;
450
471k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
471k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
471k
    f5 = f4 - x[4];
453
471k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
471k
    f7 = f6 - f3;
455
471k
    y[0] = f1 + f6 + f4;
456
471k
    y[1] = f2 + f3 - x[4];
457
471k
    y[2] = f7 + f2 - f5;
458
471k
    y[3] = f1 - f7 - f5;
459
471k
    y[4] = f1 - f3 - x[4];
460
471k
    y[5] = f2 - f6 + f4;
461
471k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
525k
{
445
525k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
525k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
525k
    f1 = x[0] + f0;
449
525k
    f2 = x[0] - f0;
450
525k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
525k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
525k
    f5 = f4 - x[4];
453
525k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
525k
    f7 = f6 - f3;
455
525k
    y[0] = f1 + f6 + f4;
456
525k
    y[1] = f2 + f3 - x[4];
457
525k
    y[2] = f7 + f2 - f5;
458
525k
    y[3] = f1 - f7 - f5;
459
525k
    y[4] = f1 - f3 - x[4];
460
525k
    y[5] = f2 - f6 + f4;
461
525k
}
462
463
/* complex filter, size 12 */
464
static void channel_filter12(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
465
                             qmf_t *buffer, qmf_t **X_hybrid)
466
16.2k
{
467
16.2k
    uint8_t i, n;
468
16.2k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
16.2k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
16.2k
    (void)hyb;  /* TODO: remove parameter? */
471
472
514k
    for (i = 0; i < frame_len; i++)
473
498k
    {
474
3.49M
        for (n = 0; n < 6; n++)
475
2.99M
        {
476
2.99M
            if (n == 0)
477
498k
            {
478
498k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
498k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
2.49M
            } else {
481
2.49M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
2.49M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
2.49M
            }
484
2.99M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
2.99M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
2.99M
        }
487
488
498k
        DCT3_6_unscaled(out_re1, input_re1);
489
498k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
498k
        DCT3_6_unscaled(out_im1, input_im1);
492
498k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
1.99M
        for (n = 0; n < 6; n += 2)
495
1.49M
        {
496
1.49M
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
1.49M
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
1.49M
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
1.49M
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
1.49M
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
1.49M
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
1.49M
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
1.49M
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
1.49M
        }
506
498k
    }
507
16.2k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
8.10k
{
467
8.10k
    uint8_t i, n;
468
8.10k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
8.10k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
8.10k
    (void)hyb;  /* TODO: remove parameter? */
471
472
257k
    for (i = 0; i < frame_len; i++)
473
249k
    {
474
1.74M
        for (n = 0; n < 6; n++)
475
1.49M
        {
476
1.49M
            if (n == 0)
477
249k
            {
478
249k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
249k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.24M
            } else {
481
1.24M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.24M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.24M
            }
484
1.49M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.49M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.49M
        }
487
488
249k
        DCT3_6_unscaled(out_re1, input_re1);
489
249k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
249k
        DCT3_6_unscaled(out_im1, input_im1);
492
249k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
997k
        for (n = 0; n < 6; n += 2)
495
748k
        {
496
748k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
748k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
748k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
748k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
748k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
748k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
748k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
748k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
748k
        }
506
249k
    }
507
8.10k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
8.10k
{
467
8.10k
    uint8_t i, n;
468
8.10k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
8.10k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
8.10k
    (void)hyb;  /* TODO: remove parameter? */
471
472
257k
    for (i = 0; i < frame_len; i++)
473
249k
    {
474
1.74M
        for (n = 0; n < 6; n++)
475
1.49M
        {
476
1.49M
            if (n == 0)
477
249k
            {
478
249k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
249k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.24M
            } else {
481
1.24M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.24M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.24M
            }
484
1.49M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.49M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.49M
        }
487
488
249k
        DCT3_6_unscaled(out_re1, input_re1);
489
249k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
249k
        DCT3_6_unscaled(out_im1, input_im1);
492
249k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
997k
        for (n = 0; n < 6; n += 2)
495
748k
        {
496
748k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
748k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
748k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
748k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
748k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
748k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
748k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
748k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
748k
        }
506
249k
    }
507
8.10k
}
508
509
/* Hybrid analysis: further split up QMF subbands
510
 * to improve frequency resolution
511
 */
512
static void hybrid_analysis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
513
                            uint8_t use34, uint8_t numTimeSlotsRate)
514
19.8k
{
515
19.8k
    uint8_t k, n, band;
516
19.8k
    uint8_t offset = 0;
517
19.8k
    uint8_t qmf_bands = (use34) ? 5 : 3;
518
19.8k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
519
520
95.5k
    for (band = 0; band < qmf_bands; band++)
521
75.7k
    {
522
        /* build working buffer */
523
75.7k
        memcpy(hyb->work, hyb->buffer[band], 12 * sizeof(qmf_t));
524
525
        /* add new samples */
526
2.42M
        for (n = 0; n < hyb->frame_len; n++)
527
2.35M
        {
528
2.35M
            QMF_RE(hyb->work[12 + n]) = QMF_RE(X[n + 6 /*delay*/][band]);
529
2.35M
            QMF_IM(hyb->work[12 + n]) = QMF_IM(X[n + 6 /*delay*/][band]);
530
2.35M
        }
531
532
        /* store samples */
533
75.7k
        memcpy(hyb->buffer[band], hyb->work + hyb->frame_len, 12 * sizeof(qmf_t));
534
535
536
75.7k
        switch(resolution[band])
537
75.7k
        {
538
23.4k
        case 2:
539
            /* Type B real filter, Q[p] = 2 */
540
23.4k
            channel_filter2(hyb, hyb->frame_len, p2_13_20, hyb->work, hyb->temp);
541
23.4k
            break;
542
24.3k
        case 4:
543
            /* Type A complex filter, Q[p] = 4 */
544
24.3k
            channel_filter4(hyb, hyb->frame_len, p4_13_34, hyb->work, hyb->temp);
545
24.3k
            break;
546
19.8k
        case 8:
547
            /* Type A complex filter, Q[p] = 8 */
548
19.8k
            channel_filter8(hyb, hyb->frame_len, (use34) ? p8_13_34 : p8_13_20,
549
19.8k
                hyb->work, hyb->temp);
550
19.8k
            break;
551
8.10k
        case 12:
552
            /* Type A complex filter, Q[p] = 12 */
553
8.10k
            channel_filter12(hyb, hyb->frame_len, p12_13_34, hyb->work, hyb->temp);
554
8.10k
            break;
555
75.7k
        }
556
557
2.42M
        for (n = 0; n < hyb->frame_len; n++)
558
2.35M
        {
559
14.7M
            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.35M
        }
565
75.7k
        offset += resolution[band];
566
75.7k
    }
567
568
    /* group hybrid channels */
569
19.8k
    if (!use34)
570
11.7k
    {
571
380k
        for (n = 0; n < numTimeSlotsRate; n++)
572
369k
        {
573
369k
            QMF_RE(X_hybrid[n][3]) += QMF_RE(X_hybrid[n][4]);
574
369k
            QMF_IM(X_hybrid[n][3]) += QMF_IM(X_hybrid[n][4]);
575
369k
            QMF_RE(X_hybrid[n][4]) = 0;
576
369k
            QMF_IM(X_hybrid[n][4]) = 0;
577
578
369k
            QMF_RE(X_hybrid[n][2]) += QMF_RE(X_hybrid[n][5]);
579
369k
            QMF_IM(X_hybrid[n][2]) += QMF_IM(X_hybrid[n][5]);
580
369k
            QMF_RE(X_hybrid[n][5]) = 0;
581
369k
            QMF_IM(X_hybrid[n][5]) = 0;
582
369k
        }
583
11.7k
    }
584
19.8k
}
585
586
static void hybrid_synthesis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
587
                             uint8_t use34, uint8_t numTimeSlotsRate)
588
39.6k
{
589
39.6k
    uint8_t k, n, band;
590
39.6k
    uint8_t offset = 0;
591
39.6k
    uint8_t qmf_bands = (use34) ? 5 : 3;
592
39.6k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
593
39.6k
    (void)numTimeSlotsRate;  /* TODO: remove parameter? */
594
595
191k
    for(band = 0; band < qmf_bands; band++)
596
151k
    {
597
4.85M
        for (n = 0; n < hyb->frame_len; n++)
598
4.70M
        {
599
4.70M
            QMF_RE(X[n][band]) = 0;
600
4.70M
            QMF_IM(X[n][band]) = 0;
601
602
29.5M
            for (k = 0; k < resolution[band]; k++)
603
24.8M
            {
604
24.8M
                QMF_RE(X[n][band]) += QMF_RE(X_hybrid[n][offset + k]);
605
24.8M
                QMF_IM(X[n][band]) += QMF_IM(X_hybrid[n][offset + k]);
606
24.8M
            }
607
4.70M
        }
608
151k
        offset += resolution[band];
609
151k
    }
610
39.6k
}
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
484k
{
615
484k
    if (i < min)
616
75.5k
        return min;
617
408k
    else if (i > max)
618
10.6k
        return max;
619
398k
    else
620
398k
        return i;
621
484k
}
622
623
//int iid = 0;
624
625
/* delta decode array */
626
static void delta_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
627
                         uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
628
                         int8_t min_index, int8_t max_index)
629
67.1k
{
630
67.1k
    int8_t i;
631
632
67.1k
    if (enable == 1)
633
34.4k
    {
634
34.4k
        if (dt_flag == 0)
635
20.1k
        {
636
            /* delta coded in frequency direction */
637
20.1k
            index[0] = 0 + index[0];
638
20.1k
            index[0] = delta_clip(index[0], min_index, max_index);
639
640
289k
            for (i = 1; i < nr_par; i++)
641
269k
            {
642
269k
                index[i] = index[i-1] + index[i];
643
269k
                index[i] = delta_clip(index[i], min_index, max_index);
644
269k
            }
645
20.1k
        } else {
646
            /* delta coded in time direction */
647
209k
            for (i = 0; i < nr_par; i++)
648
195k
            {
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
195k
                index[i] = index_prev[i*stride] + index[i];
656
                //tmp2 = index[i];
657
195k
                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
195k
            }
667
14.2k
        }
668
34.4k
    } else {
669
        /* set indices to zero */
670
59.0k
        for (i = 0; i < nr_par; i++)
671
26.3k
        {
672
26.3k
            index[i] = 0;
673
26.3k
        }
674
32.6k
    }
675
676
    /* coarse */
677
67.1k
    if (stride == 2)
678
43.6k
    {
679
277k
        for (i = (nr_par<<1)-1; i > 0; i--)
680
233k
        {
681
233k
            index[i] = index[i>>1];
682
233k
        }
683
43.6k
    }
684
67.1k
}
685
686
/* delta modulo decode array */
687
/* in: log2 value of the modulo value to allow using AND instead of MOD */
688
static void delta_modulo_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
689
                                uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
690
                                int8_t and_modulo)
691
67.1k
{
692
67.1k
    int8_t i;
693
694
67.1k
    if (enable == 1)
695
20.3k
    {
696
20.3k
        if (dt_flag == 0)
697
11.4k
        {
698
            /* delta coded in frequency direction */
699
11.4k
            index[0] = 0 + index[0];
700
11.4k
            index[0] &= and_modulo;
701
702
43.5k
            for (i = 1; i < nr_par; i++)
703
32.0k
            {
704
32.0k
                index[i] = index[i-1] + index[i];
705
32.0k
                index[i] &= and_modulo;
706
32.0k
            }
707
11.4k
        } else {
708
            /* delta coded in time direction */
709
30.4k
            for (i = 0; i < nr_par; i++)
710
21.6k
            {
711
21.6k
                index[i] = index_prev[i*stride] + index[i];
712
21.6k
                index[i] &= and_modulo;
713
21.6k
            }
714
8.84k
        }
715
46.7k
    } else {
716
        /* set indices to zero */
717
170k
        for (i = 0; i < nr_par; i++)
718
123k
        {
719
123k
            index[i] = 0;
720
123k
        }
721
46.7k
    }
722
723
    /* coarse */
724
67.1k
    if (stride == 2)
725
0
    {
726
0
        index[0] = 0;
727
0
        for (i = (nr_par<<1)-1; i > 0; i--)
728
0
        {
729
0
            index[i] = index[i>>1];
730
0
        }
731
0
    }
732
67.1k
}
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
33.0k
{
766
33.0k
    index[0] = index[0];
767
33.0k
    index[1] = (index[0] + index[1])/2;
768
33.0k
    index[2] = index[1];
769
33.0k
    index[3] = index[2];
770
33.0k
    index[4] = (index[2] + index[3])/2;
771
33.0k
    index[5] = index[3];
772
33.0k
    index[6] = index[4];
773
33.0k
    index[7] = index[4];
774
33.0k
    index[8] = index[5];
775
33.0k
    index[9] = index[5];
776
33.0k
    index[10] = index[6];
777
33.0k
    index[11] = index[7];
778
33.0k
    index[12] = index[8];
779
33.0k
    index[13] = index[8];
780
33.0k
    index[14] = index[9];
781
33.0k
    index[15] = index[9];
782
33.0k
    index[16] = index[10];
783
784
33.0k
    if (bins == 34)
785
14.0k
    {
786
14.0k
        index[17] = index[11];
787
14.0k
        index[18] = index[12];
788
14.0k
        index[19] = index[13];
789
14.0k
        index[20] = index[14];
790
14.0k
        index[21] = index[14];
791
14.0k
        index[22] = index[15];
792
14.0k
        index[23] = index[15];
793
14.0k
        index[24] = index[16];
794
14.0k
        index[25] = index[16];
795
14.0k
        index[26] = index[17];
796
14.0k
        index[27] = index[17];
797
14.0k
        index[28] = index[18];
798
14.0k
        index[29] = index[18];
799
14.0k
        index[30] = index[18];
800
14.0k
        index[31] = index[18];
801
14.0k
        index[32] = index[19];
802
14.0k
        index[33] = index[19];
803
14.0k
    }
804
33.0k
}
805
806
/* parse the bitstream data decoded in ps_data() */
807
static void ps_data_decode(ps_info *ps)
808
19.8k
{
809
19.8k
    uint8_t env, bin;
810
811
    /* ps data not available, use data from previous frame */
812
19.8k
    if (ps->ps_data_available == 0)
813
4.93k
    {
814
4.93k
        ps->num_env = 0;
815
4.93k
    }
816
817
53.4k
    for (env = 0; env < ps->num_env; env++)
818
33.5k
    {
819
33.5k
        int8_t *iid_index_prev;
820
33.5k
        int8_t *icc_index_prev;
821
33.5k
        int8_t *ipd_index_prev;
822
33.5k
        int8_t *opd_index_prev;
823
824
33.5k
        int8_t num_iid_steps = (ps->iid_mode < 3) ? 7 : 15 /*fine quant*/;
825
826
33.5k
        if (env == 0)
827
10.1k
        {
828
            /* take last envelope from previous frame */
829
10.1k
            iid_index_prev = ps->iid_index_prev;
830
10.1k
            icc_index_prev = ps->icc_index_prev;
831
10.1k
            ipd_index_prev = ps->ipd_index_prev;
832
10.1k
            opd_index_prev = ps->opd_index_prev;
833
23.4k
        } else {
834
            /* take index values from previous envelope */
835
23.4k
            iid_index_prev = ps->iid_index[env - 1];
836
23.4k
            icc_index_prev = ps->icc_index[env - 1];
837
23.4k
            ipd_index_prev = ps->ipd_index[env - 1];
838
23.4k
            opd_index_prev = ps->opd_index[env - 1];
839
23.4k
        }
840
841
//        iid = 1;
842
        /* delta decode iid parameters */
843
33.5k
        delta_decode(ps->enable_iid, ps->iid_index[env], iid_index_prev,
844
33.5k
            ps->iid_dt[env], ps->nr_iid_par,
845
33.5k
            (ps->iid_mode == 0 || ps->iid_mode == 3) ? 2 : 1,
846
33.5k
            -num_iid_steps, num_iid_steps);
847
//        iid = 0;
848
849
        /* delta decode icc parameters */
850
33.5k
        delta_decode(ps->enable_icc, ps->icc_index[env], icc_index_prev,
851
33.5k
            ps->icc_dt[env], ps->nr_icc_par,
852
33.5k
            (ps->icc_mode == 0 || ps->icc_mode == 3) ? 2 : 1,
853
33.5k
            0, 7);
854
855
        /* delta modulo decode ipd parameters */
856
33.5k
        delta_modulo_decode(ps->enable_ipdopd, ps->ipd_index[env], ipd_index_prev,
857
33.5k
            ps->ipd_dt[env], ps->nr_ipdopd_par, 1, 7);
858
859
        /* delta modulo decode opd parameters */
860
33.5k
        delta_modulo_decode(ps->enable_ipdopd, ps->opd_index[env], opd_index_prev,
861
33.5k
            ps->opd_dt[env], ps->nr_ipdopd_par, 1, 7);
862
33.5k
    }
863
864
    /* handle error case */
865
19.8k
    if (ps->num_env == 0)
866
9.71k
    {
867
        /* force to 1 */
868
9.71k
        ps->num_env = 1;
869
870
9.71k
        if (ps->enable_iid)
871
6.95k
        {
872
243k
            for (bin = 0; bin < 34; bin++)
873
236k
                ps->iid_index[0][bin] = ps->iid_index_prev[bin];
874
6.95k
        } else {
875
96.8k
            for (bin = 0; bin < 34; bin++)
876
94.0k
                ps->iid_index[0][bin] = 0;
877
2.76k
        }
878
879
9.71k
        if (ps->enable_icc)
880
5.03k
        {
881
176k
            for (bin = 0; bin < 34; bin++)
882
171k
                ps->icc_index[0][bin] = ps->icc_index_prev[bin];
883
5.03k
        } else {
884
163k
            for (bin = 0; bin < 34; bin++)
885
159k
                ps->icc_index[0][bin] = 0;
886
4.68k
        }
887
888
9.71k
        if (ps->enable_ipdopd)
889
1.00k
        {
890
18.1k
            for (bin = 0; bin < 17; bin++)
891
17.1k
            {
892
17.1k
                ps->ipd_index[0][bin] = ps->ipd_index_prev[bin];
893
17.1k
                ps->opd_index[0][bin] = ps->opd_index_prev[bin];
894
17.1k
            }
895
8.71k
        } else {
896
156k
            for (bin = 0; bin < 17; bin++)
897
148k
            {
898
148k
                ps->ipd_index[0][bin] = 0;
899
148k
                ps->opd_index[0][bin] = 0;
900
148k
            }
901
8.71k
        }
902
9.71k
    }
903
904
    /* update previous indices */
905
694k
    for (bin = 0; bin < 34; bin++)
906
674k
        ps->iid_index_prev[bin] = ps->iid_index[ps->num_env-1][bin];
907
694k
    for (bin = 0; bin < 34; bin++)
908
674k
        ps->icc_index_prev[bin] = ps->icc_index[ps->num_env-1][bin];
909
357k
    for (bin = 0; bin < 17; bin++)
910
337k
    {
911
337k
        ps->ipd_index_prev[bin] = ps->ipd_index[ps->num_env-1][bin];
912
337k
        ps->opd_index_prev[bin] = ps->opd_index[ps->num_env-1][bin];
913
337k
    }
914
915
19.8k
    ps->ps_data_available = 0;
916
917
19.8k
    if (ps->frame_class == 0)
918
12.2k
    {
919
12.2k
        ps->border_position[0] = 0;
920
21.9k
        for (env = 1; env < ps->num_env; env++)
921
9.67k
        {
922
9.67k
            ps->border_position[env] = (env * ps->numTimeSlotsRate) / ps->num_env;
923
9.67k
        }
924
12.2k
        ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
925
12.2k
    } else {
926
7.59k
        ps->border_position[0] = 0;
927
928
7.59k
        if (ps->border_position[ps->num_env] < ps->numTimeSlotsRate)
929
5.45k
        {
930
190k
            for (bin = 0; bin < 34; bin++)
931
185k
            {
932
185k
                ps->iid_index[ps->num_env][bin] = ps->iid_index[ps->num_env-1][bin];
933
185k
                ps->icc_index[ps->num_env][bin] = ps->icc_index[ps->num_env-1][bin];
934
185k
            }
935
98.2k
            for (bin = 0; bin < 17; bin++)
936
92.7k
            {
937
92.7k
                ps->ipd_index[ps->num_env][bin] = ps->ipd_index[ps->num_env-1][bin];
938
92.7k
                ps->opd_index[ps->num_env][bin] = ps->opd_index[ps->num_env-1][bin];
939
92.7k
            }
940
5.45k
            ps->num_env++;
941
5.45k
            ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
942
5.45k
        }
943
944
26.8k
        for (env = 1; env < ps->num_env; env++)
945
19.2k
        {
946
19.2k
            int8_t thr = ps->numTimeSlotsRate - (ps->num_env - env);
947
948
19.2k
            if (ps->border_position[env] > thr)
949
5.31k
            {
950
5.31k
                ps->border_position[env] = thr;
951
13.9k
            } else {
952
13.9k
                thr = ps->border_position[env-1]+1;
953
13.9k
                if (ps->border_position[env] < thr)
954
7.15k
                {
955
7.15k
                    ps->border_position[env] = thr;
956
7.15k
                }
957
13.9k
            }
958
19.2k
        }
959
7.59k
    }
960
961
    /* make sure that the indices of all parameters can be mapped
962
     * to the same hybrid synthesis filterbank
963
     */
964
#ifdef PS_LOW_POWER
965
    for (env = 0; env < ps->num_env; env++)
966
    {
967
        if (ps->iid_mode == 2 || ps->iid_mode == 5)
968
            map34indexto20(ps->iid_index[env], 34);
969
        if (ps->icc_mode == 2 || ps->icc_mode == 5)
970
            map34indexto20(ps->icc_index[env], 34);
971
972
        /* disable ipd/opd */
973
        for (bin = 0; bin < 17; bin++)
974
        {
975
            ps->aaIpdIndex[env][bin] = 0;
976
            ps->aaOpdIndex[env][bin] = 0;
977
        }
978
    }
979
#else
980
19.8k
    if (ps->use34hybrid_bands)
981
8.10k
    {
982
23.2k
        for (env = 0; env < ps->num_env; env++)
983
15.1k
        {
984
15.1k
            if (ps->iid_mode != 2 && ps->iid_mode != 5)
985
9.46k
                map20indexto34(ps->iid_index[env], 34);
986
15.1k
            if (ps->icc_mode != 2 && ps->icc_mode != 5)
987
4.61k
                map20indexto34(ps->icc_index[env], 34);
988
15.1k
            if (ps->ipd_mode != 2 && ps->ipd_mode != 5)
989
9.46k
            {
990
9.46k
                map20indexto34(ps->ipd_index[env], 17);
991
9.46k
                map20indexto34(ps->opd_index[env], 17);
992
9.46k
            }
993
15.1k
        }
994
8.10k
    }
995
19.8k
#endif
996
997
#if 0
998
    for (env = 0; env < ps->num_env; env++)
999
    {
1000
        printf("iid[env:%d]:", env);
1001
        for (bin = 0; bin < 34; bin++)
1002
        {
1003
            printf(" %d", ps->iid_index[env][bin]);
1004
        }
1005
        printf("\n");
1006
    }
1007
    for (env = 0; env < ps->num_env; env++)
1008
    {
1009
        printf("icc[env:%d]:", env);
1010
        for (bin = 0; bin < 34; bin++)
1011
        {
1012
            printf(" %d", ps->icc_index[env][bin]);
1013
        }
1014
        printf("\n");
1015
    }
1016
    for (env = 0; env < ps->num_env; env++)
1017
    {
1018
        printf("ipd[env:%d]:", env);
1019
        for (bin = 0; bin < 17; bin++)
1020
        {
1021
            printf(" %d", ps->ipd_index[env][bin]);
1022
        }
1023
        printf("\n");
1024
    }
1025
    for (env = 0; env < ps->num_env; env++)
1026
    {
1027
        printf("opd[env:%d]:", env);
1028
        for (bin = 0; bin < 17; bin++)
1029
        {
1030
            printf(" %d", ps->opd_index[env][bin]);
1031
        }
1032
        printf("\n");
1033
    }
1034
    printf("\n");
1035
#endif
1036
19.8k
}
1037
1038
/* decorrelate the mono signal using an allpass filter */
1039
static void ps_decorrelate(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
1040
                           qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32])
1041
19.8k
{
1042
19.8k
    uint8_t gr, n, bk;
1043
19.8k
    uint8_t temp_delay = 0;
1044
19.8k
    uint8_t sb, maxsb;
1045
19.8k
    const complex_t *Phi_Fract_SubQmf;
1046
19.8k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
19.8k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
19.8k
    real_t P[32][34];
1049
19.8k
    real_t G_TransientRatio[32][34] = {{0}};
1050
19.8k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
19.8k
    if (ps->use34hybrid_bands)
1055
8.10k
    {
1056
8.10k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
11.7k
    } else{
1058
11.7k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
11.7k
    }
1060
1061
    /* clear the energy values */
1062
654k
    for (n = 0; n < 32; n++)
1063
634k
    {
1064
22.2M
        for (bk = 0; bk < 34; bk++)
1065
21.5M
        {
1066
21.5M
            P[n][bk] = 0;
1067
21.5M
        }
1068
634k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
683k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
663k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
663k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
663k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
2.23M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
1.57M
        {
1081
50.5M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
49.0M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
49.0M
                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
37.3M
                } else {
1093
37.3M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
37.3M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
37.3M
                }
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
21.2M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
21.2M
                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.7M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
49.0M
            }
1109
1.57M
        }
1110
663k
    }
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
530k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
510k
    {
1129
16.4M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
15.8M
        {
1131
15.8M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
15.8M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
15.8M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
147k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
15.8M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
15.8M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
15.8M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
15.8M
            nrg = ps->P_prev[bk];
1144
15.8M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
15.8M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
15.8M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
15.7M
            {
1150
15.7M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
15.7M
            } else {
1152
108k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
108k
            }
1154
15.8M
        }
1155
510k
    }
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
683k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
663k
    {
1174
663k
        if (gr < ps->num_hybrid_groups)
1175
376k
            maxsb = ps->group_border[gr] + 1;
1176
286k
        else
1177
286k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
2.23M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
1.57M
        {
1182
1.57M
            real_t g_DecaySlope;
1183
1.57M
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
1.57M
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
396k
            {
1188
396k
                g_DecaySlope = FRAC_CONST(1.0);
1189
1.17M
            } else {
1190
1.17M
                int8_t decay = ps->decay_cutoff - sb;
1191
1.17M
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
797k
                {
1193
797k
                    g_DecaySlope = 0;
1194
797k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
376k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
376k
                }
1198
1.17M
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
6.28M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
4.71M
            {
1203
4.71M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
4.71M
            }
1205
1206
1207
            /* set delay indices */
1208
1.57M
            temp_delay = ps->saved_delay;
1209
6.28M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
4.71M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
50.5M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
49.0M
            {
1214
49.0M
                complex_t tmp, tmp0, R0;
1215
49.0M
                uint8_t m;
1216
1217
49.0M
                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
37.3M
                } else {
1223
                    /* QMF filterbank input */
1224
37.3M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
37.3M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
37.3M
                }
1227
1228
49.0M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
25.4M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
25.4M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
25.4M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
25.4M
                    RE(R0) = RE(tmp);
1236
25.4M
                    IM(R0) = IM(tmp);
1237
25.4M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
25.4M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
25.4M
                } else {
1240
                    /* allpass filter */
1241
23.5M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
23.5M
                    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
11.9M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
11.9M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
11.9M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
11.9M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
11.9M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
11.9M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
11.9M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
11.9M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
23.5M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
23.5M
                    RE(R0) = RE(tmp);
1271
23.5M
                    IM(R0) = IM(tmp);
1272
94.3M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
70.7M
                    {
1274
70.7M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
70.7M
                        if (gr < ps->num_hybrid_groups)
1278
35.0M
                        {
1279
                            /* select data from the hybrid subbands */
1280
35.0M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
35.0M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
35.0M
                            if (ps->use34hybrid_bands)
1284
23.9M
                            {
1285
23.9M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
23.9M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
23.9M
                            } else {
1288
11.1M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
11.1M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
11.1M
                            }
1291
35.7M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
35.7M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
35.7M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
35.7M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
35.7M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
35.7M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
70.7M
                        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
70.7M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
70.7M
                        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
70.7M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
70.7M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
70.7M
                        if (gr < ps->num_hybrid_groups)
1314
35.0M
                        {
1315
35.0M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
35.0M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
35.7M
                        } else {
1318
35.7M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
35.7M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
35.7M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
70.7M
                        RE(R0) = RE(tmp);
1324
70.7M
                        IM(R0) = IM(tmp);
1325
70.7M
                    }
1326
23.5M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
49.0M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
49.0M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
49.0M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
49.0M
                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
37.3M
                } else {
1341
                    /* QMF */
1342
37.3M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
37.3M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
37.3M
                }
1345
1346
                /* Update delay buffer index */
1347
49.0M
                if (++temp_delay >= 2)
1348
24.4M
                {
1349
24.4M
                    temp_delay = 0;
1350
24.4M
                }
1351
1352
                /* update delay indices */
1353
49.0M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
25.4M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
25.4M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
18.4M
                    {
1358
18.4M
                        ps->delay_buf_index_delay[sb] = 0;
1359
18.4M
                    }
1360
25.4M
                }
1361
1362
196M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
147M
                {
1364
147M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
37.5M
                    {
1366
37.5M
                        temp_delay_ser[m] = 0;
1367
37.5M
                    }
1368
147M
                }
1369
49.0M
            }
1370
1.57M
        }
1371
663k
    }
1372
1373
    /* update delay indices */
1374
19.8k
    ps->saved_delay = temp_delay;
1375
79.3k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
59.5k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
19.8k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
8.53k
{
1042
8.53k
    uint8_t gr, n, bk;
1043
8.53k
    uint8_t temp_delay = 0;
1044
8.53k
    uint8_t sb, maxsb;
1045
8.53k
    const complex_t *Phi_Fract_SubQmf;
1046
8.53k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
8.53k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
8.53k
    real_t P[32][34];
1049
8.53k
    real_t G_TransientRatio[32][34] = {{0}};
1050
8.53k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
8.53k
    if (ps->use34hybrid_bands)
1055
3.83k
    {
1056
3.83k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
4.69k
    } else{
1058
4.69k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
4.69k
    }
1060
1061
    /* clear the energy values */
1062
281k
    for (n = 0; n < 32; n++)
1063
273k
    {
1064
9.55M
        for (bk = 0; bk < 34; bk++)
1065
9.28M
        {
1066
9.28M
            P[n][bk] = 0;
1067
9.28M
        }
1068
273k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
303k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
295k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
295k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
295k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
977k
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
682k
        {
1081
21.9M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
21.2M
            {
1083
21.2M
#ifdef FIXED_POINT
1084
21.2M
                uint32_t in_re, in_im;
1085
21.2M
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
21.2M
                if (gr < ps->num_hybrid_groups)
1089
5.26M
                {
1090
5.26M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
5.26M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
16.0M
                } else {
1093
16.0M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
16.0M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
16.0M
                }
1096
1097
                /* accumulate energy */
1098
21.2M
#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
21.2M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
21.2M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
21.2M
                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
21.2M
            }
1109
682k
        }
1110
295k
    }
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
232k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
224k
    {
1129
7.20M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
6.98M
        {
1131
6.98M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
6.98M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
6.98M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
30.1k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
6.98M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
6.98M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
6.98M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
6.98M
            nrg = ps->P_prev[bk];
1144
6.98M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
6.98M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
6.98M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
6.97M
            {
1150
6.97M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
6.97M
            } else {
1152
10.8k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
10.8k
            }
1154
6.98M
        }
1155
224k
    }
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
303k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
295k
    {
1174
295k
        if (gr < ps->num_hybrid_groups)
1175
169k
            maxsb = ps->group_border[gr] + 1;
1176
125k
        else
1177
125k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
977k
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
682k
        {
1182
682k
            real_t g_DecaySlope;
1183
682k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
682k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
178k
            {
1188
178k
                g_DecaySlope = FRAC_CONST(1.0);
1189
504k
            } else {
1190
504k
                int8_t decay = ps->decay_cutoff - sb;
1191
504k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
342k
                {
1193
342k
                    g_DecaySlope = 0;
1194
342k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
162k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
162k
                }
1198
504k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
2.73M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.04M
            {
1203
2.04M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.04M
            }
1205
1206
1207
            /* set delay indices */
1208
682k
            temp_delay = ps->saved_delay;
1209
2.73M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.04M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
21.9M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
21.2M
            {
1214
21.2M
                complex_t tmp, tmp0, R0;
1215
21.2M
                uint8_t m;
1216
1217
21.2M
                if (gr < ps->num_hybrid_groups)
1218
5.26M
                {
1219
                    /* hybrid filterbank input */
1220
5.26M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
5.26M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
16.0M
                } else {
1223
                    /* QMF filterbank input */
1224
16.0M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
16.0M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
16.0M
                }
1227
1228
21.2M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
10.9M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
10.9M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
10.9M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
10.9M
                    RE(R0) = RE(tmp);
1236
10.9M
                    IM(R0) = IM(tmp);
1237
10.9M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
10.9M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
10.9M
                } else {
1240
                    /* allpass filter */
1241
10.3M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
10.3M
                    if (gr < ps->num_hybrid_groups)
1245
5.26M
                    {
1246
                        /* select data from the hybrid subbands */
1247
5.26M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
5.26M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
5.26M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
5.26M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
5.26M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
5.26M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
5.26M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
5.09M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
5.09M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
5.09M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
5.09M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
5.09M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
5.09M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
5.09M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
10.3M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
10.3M
                    RE(R0) = RE(tmp);
1271
10.3M
                    IM(R0) = IM(tmp);
1272
41.4M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
31.0M
                    {
1274
31.0M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
31.0M
                        if (gr < ps->num_hybrid_groups)
1278
15.7M
                        {
1279
                            /* select data from the hybrid subbands */
1280
15.7M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
15.7M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
15.7M
                            if (ps->use34hybrid_bands)
1284
11.3M
                            {
1285
11.3M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
11.3M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
11.3M
                            } else {
1288
4.45M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
4.45M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
4.45M
                            }
1291
15.7M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
15.2M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
15.2M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
15.2M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
15.2M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
15.2M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
31.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
31.0M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
31.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
31.0M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
31.0M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
31.0M
                        if (gr < ps->num_hybrid_groups)
1314
15.7M
                        {
1315
15.7M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
15.7M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
15.7M
                        } else {
1318
15.2M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
15.2M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
15.2M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
31.0M
                        RE(R0) = RE(tmp);
1324
31.0M
                        IM(R0) = IM(tmp);
1325
31.0M
                    }
1326
10.3M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
21.2M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
21.2M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
21.2M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
21.2M
                if (gr < ps->num_hybrid_groups)
1336
5.26M
                {
1337
                    /* hybrid */
1338
5.26M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
5.26M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
16.0M
                } else {
1341
                    /* QMF */
1342
16.0M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
16.0M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
16.0M
                }
1345
1346
                /* Update delay buffer index */
1347
21.2M
                if (++temp_delay >= 2)
1348
10.6M
                {
1349
10.6M
                    temp_delay = 0;
1350
10.6M
                }
1351
1352
                /* update delay indices */
1353
21.2M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
10.9M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
10.9M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
7.93M
                    {
1358
7.93M
                        ps->delay_buf_index_delay[sb] = 0;
1359
7.93M
                    }
1360
10.9M
                }
1361
1362
85.1M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
63.8M
                {
1364
63.8M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
16.2M
                    {
1366
16.2M
                        temp_delay_ser[m] = 0;
1367
16.2M
                    }
1368
63.8M
                }
1369
21.2M
            }
1370
682k
        }
1371
295k
    }
1372
1373
    /* update delay indices */
1374
8.53k
    ps->saved_delay = temp_delay;
1375
34.1k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
25.5k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
8.53k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
11.3k
{
1042
11.3k
    uint8_t gr, n, bk;
1043
11.3k
    uint8_t temp_delay = 0;
1044
11.3k
    uint8_t sb, maxsb;
1045
11.3k
    const complex_t *Phi_Fract_SubQmf;
1046
11.3k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
11.3k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
11.3k
    real_t P[32][34];
1049
11.3k
    real_t G_TransientRatio[32][34] = {{0}};
1050
11.3k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
11.3k
    if (ps->use34hybrid_bands)
1055
4.27k
    {
1056
4.27k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
7.03k
    } else{
1058
7.03k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
7.03k
    }
1060
1061
    /* clear the energy values */
1062
373k
    for (n = 0; n < 32; n++)
1063
361k
    {
1064
12.6M
        for (bk = 0; bk < 34; bk++)
1065
12.3M
        {
1066
12.3M
            P[n][bk] = 0;
1067
12.3M
        }
1068
361k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
379k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
368k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
368k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
368k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
1.25M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
888k
        {
1081
28.6M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
27.7M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
27.7M
                if (gr < ps->num_hybrid_groups)
1089
6.43M
                {
1090
6.43M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
6.43M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
21.2M
                } else {
1093
21.2M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
21.2M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
21.2M
                }
1096
1097
                /* accumulate energy */
1098
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
27.7M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
27.7M
#endif
1108
27.7M
            }
1109
888k
        }
1110
368k
    }
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
297k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
285k
    {
1129
9.19M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
8.91M
        {
1131
8.91M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
8.91M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
8.91M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
116k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
8.91M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
8.91M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
8.91M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
8.91M
            nrg = ps->P_prev[bk];
1144
8.91M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
8.91M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
8.91M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
8.81M
            {
1150
8.81M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
8.81M
            } else {
1152
97.3k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
97.3k
            }
1154
8.91M
        }
1155
285k
    }
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
379k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
368k
    {
1174
368k
        if (gr < ps->num_hybrid_groups)
1175
207k
            maxsb = ps->group_border[gr] + 1;
1176
161k
        else
1177
161k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
1.25M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
888k
        {
1182
888k
            real_t g_DecaySlope;
1183
888k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
888k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
218k
            {
1188
218k
                g_DecaySlope = FRAC_CONST(1.0);
1189
669k
            } else {
1190
669k
                int8_t decay = ps->decay_cutoff - sb;
1191
669k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
455k
                {
1193
455k
                    g_DecaySlope = 0;
1194
455k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
214k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
214k
                }
1198
669k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
3.55M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.66M
            {
1203
2.66M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.66M
            }
1205
1206
1207
            /* set delay indices */
1208
888k
            temp_delay = ps->saved_delay;
1209
3.55M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.66M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
28.6M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
27.7M
            {
1214
27.7M
                complex_t tmp, tmp0, R0;
1215
27.7M
                uint8_t m;
1216
1217
27.7M
                if (gr < ps->num_hybrid_groups)
1218
6.43M
                {
1219
                    /* hybrid filterbank input */
1220
6.43M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
6.43M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
21.2M
                } else {
1223
                    /* QMF filterbank input */
1224
21.2M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
21.2M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
21.2M
                }
1227
1228
27.7M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
14.4M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
14.4M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
14.4M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
14.4M
                    RE(R0) = RE(tmp);
1236
14.4M
                    IM(R0) = IM(tmp);
1237
14.4M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
14.4M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
14.4M
                } else {
1240
                    /* allpass filter */
1241
13.2M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
13.2M
                    if (gr < ps->num_hybrid_groups)
1245
6.43M
                    {
1246
                        /* select data from the hybrid subbands */
1247
6.43M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
6.43M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
6.43M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
6.43M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
6.43M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
6.43M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
6.80M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
6.80M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
6.80M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
6.80M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
6.80M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
6.80M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
6.80M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
6.80M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
13.2M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
13.2M
                    RE(R0) = RE(tmp);
1271
13.2M
                    IM(R0) = IM(tmp);
1272
52.9M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
39.7M
                    {
1274
39.7M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
39.7M
                        if (gr < ps->num_hybrid_groups)
1278
19.2M
                        {
1279
                            /* select data from the hybrid subbands */
1280
19.2M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
19.2M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
19.2M
                            if (ps->use34hybrid_bands)
1284
12.6M
                            {
1285
12.6M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
12.6M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
12.6M
                            } else {
1288
6.65M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
6.65M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
6.65M
                            }
1291
20.4M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
20.4M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
20.4M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
20.4M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
20.4M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
20.4M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
39.7M
                        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
39.7M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
39.7M
                        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
39.7M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
39.7M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
39.7M
                        if (gr < ps->num_hybrid_groups)
1314
19.2M
                        {
1315
19.2M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
19.2M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
20.4M
                        } else {
1318
20.4M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
20.4M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
20.4M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
39.7M
                        RE(R0) = RE(tmp);
1324
39.7M
                        IM(R0) = IM(tmp);
1325
39.7M
                    }
1326
13.2M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
27.7M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
27.7M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
27.7M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
27.7M
                if (gr < ps->num_hybrid_groups)
1336
6.43M
                {
1337
                    /* hybrid */
1338
6.43M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
6.43M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
21.2M
                } else {
1341
                    /* QMF */
1342
21.2M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
21.2M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
21.2M
                }
1345
1346
                /* Update delay buffer index */
1347
27.7M
                if (++temp_delay >= 2)
1348
13.8M
                {
1349
13.8M
                    temp_delay = 0;
1350
13.8M
                }
1351
1352
                /* update delay indices */
1353
27.7M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
14.4M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
14.4M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
10.5M
                    {
1358
10.5M
                        ps->delay_buf_index_delay[sb] = 0;
1359
10.5M
                    }
1360
14.4M
                }
1361
1362
110M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
83.1M
                {
1364
83.1M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
21.3M
                    {
1366
21.3M
                        temp_delay_ser[m] = 0;
1367
21.3M
                    }
1368
83.1M
                }
1369
27.7M
            }
1370
888k
        }
1371
368k
    }
1372
1373
    /* update delay indices */
1374
11.3k
    ps->saved_delay = temp_delay;
1375
45.2k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
33.9k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
11.3k
}
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
352k
{
1438
#ifdef FIXED_POINT
1439
341k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
#define ALPHA FRAC_CONST(0.948059448969)
1441
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
170k
    real_t abs_inphase = ps_abs(RE(c));
1444
170k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
170k
    if (abs_inphase > abs_quadrature) {
1447
133k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
133k
    } else {
1449
36.8k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
36.8k
    }
1451
#else
1452
182k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
352k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
170k
{
1438
170k
#ifdef FIXED_POINT
1439
170k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
170k
#define ALPHA FRAC_CONST(0.948059448969)
1441
170k
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
170k
    real_t abs_inphase = ps_abs(RE(c));
1444
170k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
170k
    if (abs_inphase > abs_quadrature) {
1447
133k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
133k
    } else {
1449
36.8k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
36.8k
    }
1451
#else
1452
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
170k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
182k
{
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
182k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
182k
#endif
1454
182k
}
1455
1456
static void ps_mix_phase(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
1457
                         qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32])
1458
19.8k
{
1459
19.8k
    uint8_t n;
1460
19.8k
    uint8_t gr;
1461
19.8k
    uint8_t bk = 0;
1462
19.8k
    uint8_t sb, maxsb;
1463
19.8k
    uint8_t env;
1464
19.8k
    uint8_t nr_ipdopd_par;
1465
19.8k
    complex_t h11, h12, h21, h22;  // COEF
1466
19.8k
    complex_t H11, H12, H21, H22;  // COEF
1467
19.8k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
19.8k
    complex_t tempLeft, tempRight; // FRAC
1469
19.8k
    complex_t phaseLeft, phaseRight; // FRAC
1470
19.8k
    real_t L;
1471
19.8k
    const real_t *sf_iid;
1472
19.8k
    uint8_t no_iid_steps;
1473
1474
19.8k
    if (ps->iid_mode >= 3)
1475
8.68k
    {
1476
8.68k
        no_iid_steps = 15;
1477
8.68k
        sf_iid = sf_iid_fine;
1478
11.1k
    } else {
1479
11.1k
        no_iid_steps = 7;
1480
11.1k
        sf_iid = sf_iid_normal;
1481
11.1k
    }
1482
1483
19.8k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
11.4k
    {
1485
11.4k
        nr_ipdopd_par = 11; /* resolution */
1486
11.4k
    } else {
1487
8.36k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
8.36k
    }
1489
1490
683k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
663k
    {
1492
663k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
663k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
2.15M
        for (env = 0; env < ps->num_env; env++)
1498
1.49M
        {
1499
1.49M
            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.49M
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
387
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
387
                    -no_iid_steps);
1507
387
                ps->iid_index[env][bk] = -no_iid_steps;
1508
387
                abs_iid = no_iid_steps;
1509
1.49M
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
230
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
230
                    no_iid_steps);
1512
230
                ps->iid_index[env][bk] = no_iid_steps;
1513
230
                abs_iid = no_iid_steps;
1514
230
            }
1515
1.49M
            if (ps->icc_index[env][bk] < 0) {
1516
476
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
476
                ps->icc_index[env][bk] = 0;
1518
1.49M
            } 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.49M
            if (ps->icc_mode < 3)
1524
852k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
852k
                real_t c_1, c_2;  // COEF
1527
852k
                real_t cosa, sina;  // COEF
1528
852k
                real_t cosb, sinb;  // COEF
1529
852k
                real_t ab1, ab2;  // COEF
1530
852k
                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
852k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
852k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
852k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
852k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
852k
                if (ps->iid_mode >= 3)
1550
310k
                {
1551
310k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
310k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
541k
                } else {
1554
541k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
541k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
541k
                }
1557
1558
852k
                ab1 = MUL_C(cosb, cosa);
1559
852k
                ab2 = MUL_C(sinb, sina);
1560
852k
                ab3 = MUL_C(sinb, cosa);
1561
852k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
852k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
852k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
852k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
852k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
852k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
643k
                real_t sina, cosa;  // COEF
1571
643k
                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
643k
                if (ps->iid_mode >= 3)
1607
411k
                {
1608
411k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
411k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
411k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
411k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
411k
                } 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
643k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
643k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
643k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
643k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
643k
            }
1624
1.49M
            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.49M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
176k
            {
1632
176k
                int8_t i;
1633
176k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
176k
                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
85.3k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
85.3k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
85.3k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
85.3k
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
91.0k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
91.0k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
91.0k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
91.0k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
#endif
1652
1653
                /* save current value */
1654
176k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
176k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
176k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
176k
                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
85.3k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
85.3k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
85.3k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
85.3k
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
91.0k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
91.0k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
91.0k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
91.0k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
#endif
1672
1673
                /* ringbuffer index */
1674
176k
                if (i == 0)
1675
89.0k
                {
1676
89.0k
                    i = 2;
1677
89.0k
                }
1678
176k
                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
85.3k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
85.3k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
85.3k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
85.3k
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
91.0k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
91.0k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
91.0k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
91.0k
                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
176k
                xy = magnitude_c(tempRight);
1716
176k
                pq = magnitude_c(tempLeft);
1717
1718
176k
                if (xy != 0)
1719
176k
                {
1720
176k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
176k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
176k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
176k
                xypq = MUL_F(xy, pq);
1728
1729
176k
                if (xypq != 0)
1730
176k
                {
1731
176k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
176k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
176k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
176k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
176k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
176k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
176k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
176k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
176k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
176k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
176k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
176k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
176k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
176k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
176k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
1.49M
            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.49M
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
1.49M
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
1.49M
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
1.49M
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
1.49M
            RE(H11) = RE(ps->h11_prev[gr]);
1766
1.49M
            RE(H12) = RE(ps->h12_prev[gr]);
1767
1.49M
            RE(H21) = RE(ps->h21_prev[gr]);
1768
1.49M
            RE(H22) = RE(ps->h22_prev[gr]);
1769
1.49M
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
1.49M
            RE(ps->h11_prev[gr]) = RE(h11);
1772
1.49M
            RE(ps->h12_prev[gr]) = RE(h12);
1773
1.49M
            RE(ps->h21_prev[gr]) = RE(h21);
1774
1.49M
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
1.49M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
176k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
176k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
176k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
176k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
176k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
176k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
176k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
176k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
176k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
176k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
25.2k
                {
1792
25.2k
                    IM(deltaH11) = -IM(deltaH11);
1793
25.2k
                    IM(deltaH12) = -IM(deltaH12);
1794
25.2k
                    IM(deltaH21) = -IM(deltaH21);
1795
25.2k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
25.2k
                    IM(H11) = -IM(H11);
1798
25.2k
                    IM(H12) = -IM(H12);
1799
25.2k
                    IM(H21) = -IM(H21);
1800
25.2k
                    IM(H22) = -IM(H22);
1801
25.2k
                }
1802
1803
176k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
176k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
176k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
176k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
176k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
22.1M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
20.6M
            {
1812
                /* addition finalises the interpolation over every n */
1813
20.6M
                RE(H11) += RE(deltaH11);
1814
20.6M
                RE(H12) += RE(deltaH12);
1815
20.6M
                RE(H21) += RE(deltaH21);
1816
20.6M
                RE(H22) += RE(deltaH22);
1817
20.6M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
1.85M
                {
1819
1.85M
                    IM(H11) += IM(deltaH11);
1820
1.85M
                    IM(H12) += IM(deltaH12);
1821
1.85M
                    IM(H21) += IM(deltaH21);
1822
1.85M
                    IM(H22) += IM(deltaH22);
1823
1.85M
                }
1824
1825
                /* channel is an alias to the subband */
1826
69.6M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
49.0M
                {
1828
49.0M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
49.0M
                    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
37.3M
                    } else {
1838
37.3M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
37.3M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
37.3M
                        RE(inRight) = RE(X_right[n][sb]);
1841
37.3M
                        IM(inRight) = IM(X_right[n][sb]);
1842
37.3M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
49.0M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
49.0M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
49.0M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
49.0M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
49.0M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.85M
                    {
1855
                        /* apply rotation */
1856
1.85M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.85M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.85M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.85M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.85M
                    }
1861
1862
                    /* store final samples */
1863
49.0M
                    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
37.3M
                    } else {
1870
37.3M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
37.3M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
37.3M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
37.3M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
37.3M
                    }
1875
49.0M
                }
1876
20.6M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
1.49M
            ps->phase_hist++;
1880
1.49M
            if (ps->phase_hist == 2)
1881
748k
            {
1882
748k
                ps->phase_hist = 0;
1883
748k
            }
1884
1.49M
        }
1885
663k
    }
1886
19.8k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
8.53k
{
1459
8.53k
    uint8_t n;
1460
8.53k
    uint8_t gr;
1461
8.53k
    uint8_t bk = 0;
1462
8.53k
    uint8_t sb, maxsb;
1463
8.53k
    uint8_t env;
1464
8.53k
    uint8_t nr_ipdopd_par;
1465
8.53k
    complex_t h11, h12, h21, h22;  // COEF
1466
8.53k
    complex_t H11, H12, H21, H22;  // COEF
1467
8.53k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
8.53k
    complex_t tempLeft, tempRight; // FRAC
1469
8.53k
    complex_t phaseLeft, phaseRight; // FRAC
1470
8.53k
    real_t L;
1471
8.53k
    const real_t *sf_iid;
1472
8.53k
    uint8_t no_iid_steps;
1473
1474
8.53k
    if (ps->iid_mode >= 3)
1475
3.61k
    {
1476
3.61k
        no_iid_steps = 15;
1477
3.61k
        sf_iid = sf_iid_fine;
1478
4.91k
    } else {
1479
4.91k
        no_iid_steps = 7;
1480
4.91k
        sf_iid = sf_iid_normal;
1481
4.91k
    }
1482
1483
8.53k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
4.60k
    {
1485
4.60k
        nr_ipdopd_par = 11; /* resolution */
1486
4.60k
    } else {
1487
3.92k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
3.92k
    }
1489
1490
303k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
295k
    {
1492
295k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
295k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
976k
        for (env = 0; env < ps->num_env; env++)
1498
680k
        {
1499
680k
            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
680k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
96
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
96
                    -no_iid_steps);
1507
96
                ps->iid_index[env][bk] = -no_iid_steps;
1508
96
                abs_iid = no_iid_steps;
1509
680k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
79
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
79
                    no_iid_steps);
1512
79
                ps->iid_index[env][bk] = no_iid_steps;
1513
79
                abs_iid = no_iid_steps;
1514
79
            }
1515
680k
            if (ps->icc_index[env][bk] < 0) {
1516
91
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
91
                ps->icc_index[env][bk] = 0;
1518
680k
            } 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
680k
            if (ps->icc_mode < 3)
1524
327k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
327k
                real_t c_1, c_2;  // COEF
1527
327k
                real_t cosa, sina;  // COEF
1528
327k
                real_t cosb, sinb;  // COEF
1529
327k
                real_t ab1, ab2;  // COEF
1530
327k
                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
327k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
327k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
327k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
327k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
327k
                if (ps->iid_mode >= 3)
1550
73.2k
                {
1551
73.2k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
73.2k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
253k
                } else {
1554
253k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
253k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
253k
                }
1557
1558
327k
                ab1 = MUL_C(cosb, cosa);
1559
327k
                ab2 = MUL_C(sinb, sina);
1560
327k
                ab3 = MUL_C(sinb, cosa);
1561
327k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
327k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
327k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
327k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
327k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
353k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
353k
                real_t sina, cosa;  // COEF
1571
353k
                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
353k
                if (ps->iid_mode >= 3)
1607
241k
                {
1608
241k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
241k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
241k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
241k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
241k
                } 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
353k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
353k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
353k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
353k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
353k
            }
1624
680k
            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
680k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
85.3k
            {
1632
85.3k
                int8_t i;
1633
85.3k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
85.3k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
85.3k
#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
85.3k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
85.3k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
85.3k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
85.3k
                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
85.3k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
85.3k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
85.3k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
85.3k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
85.3k
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
85.3k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
85.3k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
85.3k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
85.3k
                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
85.3k
                if (i == 0)
1675
43.0k
                {
1676
43.0k
                    i = 2;
1677
43.0k
                }
1678
85.3k
                i--;
1679
1680
                /* get value before previous */
1681
85.3k
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
85.3k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
85.3k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
85.3k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
85.3k
                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
85.3k
                xy = magnitude_c(tempRight);
1716
85.3k
                pq = magnitude_c(tempLeft);
1717
1718
85.3k
                if (xy != 0)
1719
85.3k
                {
1720
85.3k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
85.3k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
85.3k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
85.3k
                xypq = MUL_F(xy, pq);
1728
1729
85.3k
                if (xypq != 0)
1730
85.3k
                {
1731
85.3k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
85.3k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
85.3k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
85.3k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
85.3k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
85.3k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
85.3k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
85.3k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
85.3k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
85.3k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
85.3k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
85.3k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
85.3k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
85.3k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
85.3k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
680k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
680k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
680k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
680k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
680k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
680k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
680k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
680k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
680k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
680k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
680k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
680k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
680k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
680k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
680k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
85.3k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
85.3k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
85.3k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
85.3k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
85.3k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
85.3k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
85.3k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
85.3k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
85.3k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
85.3k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
12.0k
                {
1792
12.0k
                    IM(deltaH11) = -IM(deltaH11);
1793
12.0k
                    IM(deltaH12) = -IM(deltaH12);
1794
12.0k
                    IM(deltaH21) = -IM(deltaH21);
1795
12.0k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
12.0k
                    IM(H11) = -IM(H11);
1798
12.0k
                    IM(H12) = -IM(H12);
1799
12.0k
                    IM(H21) = -IM(H21);
1800
12.0k
                    IM(H22) = -IM(H22);
1801
12.0k
                }
1802
1803
85.3k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
85.3k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
85.3k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
85.3k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
85.3k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
9.85M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
9.16M
            {
1812
                /* addition finalises the interpolation over every n */
1813
9.16M
                RE(H11) += RE(deltaH11);
1814
9.16M
                RE(H12) += RE(deltaH12);
1815
9.16M
                RE(H21) += RE(deltaH21);
1816
9.16M
                RE(H22) += RE(deltaH22);
1817
9.16M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
941k
                {
1819
941k
                    IM(H11) += IM(deltaH11);
1820
941k
                    IM(H12) += IM(deltaH12);
1821
941k
                    IM(H21) += IM(deltaH21);
1822
941k
                    IM(H22) += IM(deltaH22);
1823
941k
                }
1824
1825
                /* channel is an alias to the subband */
1826
30.4M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
21.2M
                {
1828
21.2M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
21.2M
                    if (gr < ps->num_hybrid_groups)
1832
5.26M
                    {
1833
5.26M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
5.26M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
5.26M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
5.26M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
16.0M
                    } else {
1838
16.0M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
16.0M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
16.0M
                        RE(inRight) = RE(X_right[n][sb]);
1841
16.0M
                        IM(inRight) = IM(X_right[n][sb]);
1842
16.0M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
21.2M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
21.2M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
21.2M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
21.2M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
21.2M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
945k
                    {
1855
                        /* apply rotation */
1856
945k
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
945k
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
945k
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
945k
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
945k
                    }
1861
1862
                    /* store final samples */
1863
21.2M
                    if (gr < ps->num_hybrid_groups)
1864
5.26M
                    {
1865
5.26M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
5.26M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
5.26M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
5.26M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
16.0M
                    } else {
1870
16.0M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
16.0M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
16.0M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
16.0M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
16.0M
                    }
1875
21.2M
                }
1876
9.16M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
680k
            ps->phase_hist++;
1880
680k
            if (ps->phase_hist == 2)
1881
340k
            {
1882
340k
                ps->phase_hist = 0;
1883
340k
            }
1884
680k
        }
1885
295k
    }
1886
8.53k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
11.3k
{
1459
11.3k
    uint8_t n;
1460
11.3k
    uint8_t gr;
1461
11.3k
    uint8_t bk = 0;
1462
11.3k
    uint8_t sb, maxsb;
1463
11.3k
    uint8_t env;
1464
11.3k
    uint8_t nr_ipdopd_par;
1465
11.3k
    complex_t h11, h12, h21, h22;  // COEF
1466
11.3k
    complex_t H11, H12, H21, H22;  // COEF
1467
11.3k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
11.3k
    complex_t tempLeft, tempRight; // FRAC
1469
11.3k
    complex_t phaseLeft, phaseRight; // FRAC
1470
11.3k
    real_t L;
1471
11.3k
    const real_t *sf_iid;
1472
11.3k
    uint8_t no_iid_steps;
1473
1474
11.3k
    if (ps->iid_mode >= 3)
1475
5.07k
    {
1476
5.07k
        no_iid_steps = 15;
1477
5.07k
        sf_iid = sf_iid_fine;
1478
6.23k
    } else {
1479
6.23k
        no_iid_steps = 7;
1480
6.23k
        sf_iid = sf_iid_normal;
1481
6.23k
    }
1482
1483
11.3k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
6.86k
    {
1485
6.86k
        nr_ipdopd_par = 11; /* resolution */
1486
6.86k
    } else {
1487
4.43k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
4.43k
    }
1489
1490
379k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
368k
    {
1492
368k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
368k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.18M
        for (env = 0; env < ps->num_env; env++)
1498
815k
        {
1499
815k
            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
815k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
291
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
291
                    -no_iid_steps);
1507
291
                ps->iid_index[env][bk] = -no_iid_steps;
1508
291
                abs_iid = no_iid_steps;
1509
815k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
151
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
151
                    no_iid_steps);
1512
151
                ps->iid_index[env][bk] = no_iid_steps;
1513
151
                abs_iid = no_iid_steps;
1514
151
            }
1515
815k
            if (ps->icc_index[env][bk] < 0) {
1516
385
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
385
                ps->icc_index[env][bk] = 0;
1518
815k
            } 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
815k
            if (ps->icc_mode < 3)
1524
525k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
525k
                real_t c_1, c_2;  // COEF
1527
525k
                real_t cosa, sina;  // COEF
1528
525k
                real_t cosb, sinb;  // COEF
1529
525k
                real_t ab1, ab2;  // COEF
1530
525k
                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
525k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
525k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
525k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
525k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
525k
                if (ps->iid_mode >= 3)
1550
237k
                {
1551
237k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
237k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
288k
                } else {
1554
288k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
288k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
288k
                }
1557
1558
525k
                ab1 = MUL_C(cosb, cosa);
1559
525k
                ab2 = MUL_C(sinb, sina);
1560
525k
                ab3 = MUL_C(sinb, cosa);
1561
525k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
525k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
525k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
525k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
525k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
525k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
289k
                real_t sina, cosa;  // COEF
1571
289k
                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
289k
                if (ps->iid_mode >= 3)
1607
170k
                {
1608
170k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
170k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
170k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
170k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
170k
                } else {
1613
119k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
119k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
119k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
119k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
119k
                }
1618
1619
289k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
289k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
289k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
289k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
289k
            }
1624
815k
            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
815k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
91.0k
            {
1632
91.0k
                int8_t i;
1633
91.0k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
91.0k
                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
91.0k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
91.0k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
91.0k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
91.0k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
91.0k
#endif
1652
1653
                /* save current value */
1654
91.0k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
91.0k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
91.0k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
91.0k
                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
91.0k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
91.0k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
91.0k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
91.0k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
91.0k
#endif
1672
1673
                /* ringbuffer index */
1674
91.0k
                if (i == 0)
1675
45.9k
                {
1676
45.9k
                    i = 2;
1677
45.9k
                }
1678
91.0k
                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
91.0k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
91.0k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
91.0k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
91.0k
                IM(tempRight) += MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1692
91.0k
#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
91.0k
                xy = magnitude_c(tempRight);
1716
91.0k
                pq = magnitude_c(tempLeft);
1717
1718
91.0k
                if (xy != 0)
1719
91.0k
                {
1720
91.0k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
91.0k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
91.0k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
91.0k
                xypq = MUL_F(xy, pq);
1728
1729
91.0k
                if (xypq != 0)
1730
91.0k
                {
1731
91.0k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
91.0k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
91.0k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
91.0k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
91.0k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
91.0k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
91.0k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
91.0k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
91.0k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
91.0k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
91.0k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
91.0k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
91.0k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
91.0k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
91.0k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
815k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
815k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
815k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
815k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
815k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
815k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
815k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
815k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
815k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
815k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
815k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
815k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
815k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
815k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
815k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
91.0k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
91.0k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
91.0k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
91.0k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
91.0k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
91.0k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
91.0k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
91.0k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
91.0k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
91.0k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
13.2k
                {
1792
13.2k
                    IM(deltaH11) = -IM(deltaH11);
1793
13.2k
                    IM(deltaH12) = -IM(deltaH12);
1794
13.2k
                    IM(deltaH21) = -IM(deltaH21);
1795
13.2k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
13.2k
                    IM(H11) = -IM(H11);
1798
13.2k
                    IM(H12) = -IM(H12);
1799
13.2k
                    IM(H21) = -IM(H21);
1800
13.2k
                    IM(H22) = -IM(H22);
1801
13.2k
                }
1802
1803
91.0k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
91.0k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
91.0k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
91.0k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
91.0k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
12.2M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
11.4M
            {
1812
                /* addition finalises the interpolation over every n */
1813
11.4M
                RE(H11) += RE(deltaH11);
1814
11.4M
                RE(H12) += RE(deltaH12);
1815
11.4M
                RE(H21) += RE(deltaH21);
1816
11.4M
                RE(H22) += RE(deltaH22);
1817
11.4M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
912k
                {
1819
912k
                    IM(H11) += IM(deltaH11);
1820
912k
                    IM(H12) += IM(deltaH12);
1821
912k
                    IM(H21) += IM(deltaH21);
1822
912k
                    IM(H22) += IM(deltaH22);
1823
912k
                }
1824
1825
                /* channel is an alias to the subband */
1826
39.1M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
27.7M
                {
1828
27.7M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
27.7M
                    if (gr < ps->num_hybrid_groups)
1832
6.43M
                    {
1833
6.43M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
6.43M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
6.43M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
6.43M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
21.2M
                    } else {
1838
21.2M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
21.2M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
21.2M
                        RE(inRight) = RE(X_right[n][sb]);
1841
21.2M
                        IM(inRight) = IM(X_right[n][sb]);
1842
21.2M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
27.7M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
27.7M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
27.7M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
27.7M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
27.7M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
914k
                    {
1855
                        /* apply rotation */
1856
914k
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
914k
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
914k
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
914k
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
914k
                    }
1861
1862
                    /* store final samples */
1863
27.7M
                    if (gr < ps->num_hybrid_groups)
1864
6.43M
                    {
1865
6.43M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
6.43M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
6.43M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
6.43M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
21.2M
                    } else {
1870
21.2M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
21.2M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
21.2M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
21.2M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
21.2M
                    }
1875
27.7M
                }
1876
11.4M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
815k
            ps->phase_hist++;
1880
815k
            if (ps->phase_hist == 2)
1881
407k
            {
1882
407k
                ps->phase_hist = 0;
1883
407k
            }
1884
815k
        }
1885
368k
    }
1886
11.3k
}
1887
1888
void ps_free(ps_info *ps)
1889
30.7k
{
1890
    /* free hybrid filterbank structures */
1891
30.7k
    hybrid_free(ps->hyb);
1892
1893
30.7k
    faad_free(ps);
1894
30.7k
}
1895
1896
ps_info *ps_init(uint8_t sr_index, uint8_t numTimeSlotsRate)
1897
30.7k
{
1898
30.7k
    uint8_t i;
1899
30.7k
    uint8_t short_delay_band;
1900
1901
30.7k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
30.7k
    memset(ps, 0, sizeof(ps_info));
1903
1904
30.7k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
30.7k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
30.7k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
30.7k
    ps->saved_delay = 0;
1911
1912
1.99M
    for (i = 0; i < 64; i++)
1913
1.96M
    {
1914
1.96M
        ps->delay_buf_index_delay[i] = 0;
1915
1.96M
    }
1916
1917
123k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
92.2k
    {
1919
92.2k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
92.2k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
92.2k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
92.2k
#endif
1932
92.2k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
30.7k
    short_delay_band = 35;
1950
30.7k
    ps->nr_allpass_bands = 22;
1951
30.7k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
30.7k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
30.7k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
1.10M
    for (i = 0; i < short_delay_band; i++)
1957
1.07M
    {
1958
1.07M
        ps->delay_D[i] = 14;
1959
1.07M
    }
1960
922k
    for (i = short_delay_band; i < 64; i++)
1961
892k
    {
1962
892k
        ps->delay_D[i] = 1;
1963
892k
    }
1964
1965
    /* mixing and phase */
1966
1.56M
    for (i = 0; i < 50; i++)
1967
1.53M
    {
1968
1.53M
        RE(ps->h11_prev[i]) = 1;
1969
1.53M
        IM(ps->h11_prev[i]) = 1;
1970
1.53M
        RE(ps->h12_prev[i]) = 1;
1971
1.53M
        IM(ps->h12_prev[i]) = 1;
1972
1.53M
    }
1973
1974
30.7k
    ps->phase_hist = 0;
1975
1976
646k
    for (i = 0; i < 20; i++)
1977
615k
    {
1978
615k
        RE(ps->ipd_prev[i][0]) = 0;
1979
615k
        IM(ps->ipd_prev[i][0]) = 0;
1980
615k
        RE(ps->ipd_prev[i][1]) = 0;
1981
615k
        IM(ps->ipd_prev[i][1]) = 0;
1982
615k
        RE(ps->opd_prev[i][0]) = 0;
1983
615k
        IM(ps->opd_prev[i][0]) = 0;
1984
615k
        RE(ps->opd_prev[i][1]) = 0;
1985
615k
        IM(ps->opd_prev[i][1]) = 0;
1986
615k
    }
1987
1988
30.7k
    return ps;
1989
30.7k
}
ps_init
Line
Count
Source
1897
13.4k
{
1898
13.4k
    uint8_t i;
1899
13.4k
    uint8_t short_delay_band;
1900
1901
13.4k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
13.4k
    memset(ps, 0, sizeof(ps_info));
1903
1904
13.4k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
13.4k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
13.4k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
13.4k
    ps->saved_delay = 0;
1911
1912
876k
    for (i = 0; i < 64; i++)
1913
863k
    {
1914
863k
        ps->delay_buf_index_delay[i] = 0;
1915
863k
    }
1916
1917
53.9k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
40.4k
    {
1919
40.4k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
40.4k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
40.4k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
40.4k
#endif
1932
40.4k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
13.4k
    short_delay_band = 35;
1950
13.4k
    ps->nr_allpass_bands = 22;
1951
13.4k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
13.4k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
13.4k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
485k
    for (i = 0; i < short_delay_band; i++)
1957
472k
    {
1958
472k
        ps->delay_D[i] = 14;
1959
472k
    }
1960
404k
    for (i = short_delay_band; i < 64; i++)
1961
391k
    {
1962
391k
        ps->delay_D[i] = 1;
1963
391k
    }
1964
1965
    /* mixing and phase */
1966
688k
    for (i = 0; i < 50; i++)
1967
674k
    {
1968
674k
        RE(ps->h11_prev[i]) = 1;
1969
674k
        IM(ps->h11_prev[i]) = 1;
1970
674k
        RE(ps->h12_prev[i]) = 1;
1971
674k
        IM(ps->h12_prev[i]) = 1;
1972
674k
    }
1973
1974
13.4k
    ps->phase_hist = 0;
1975
1976
283k
    for (i = 0; i < 20; i++)
1977
269k
    {
1978
269k
        RE(ps->ipd_prev[i][0]) = 0;
1979
269k
        IM(ps->ipd_prev[i][0]) = 0;
1980
269k
        RE(ps->ipd_prev[i][1]) = 0;
1981
269k
        IM(ps->ipd_prev[i][1]) = 0;
1982
269k
        RE(ps->opd_prev[i][0]) = 0;
1983
269k
        IM(ps->opd_prev[i][0]) = 0;
1984
269k
        RE(ps->opd_prev[i][1]) = 0;
1985
269k
        IM(ps->opd_prev[i][1]) = 0;
1986
269k
    }
1987
1988
13.4k
    return ps;
1989
13.4k
}
ps_init
Line
Count
Source
1897
17.2k
{
1898
17.2k
    uint8_t i;
1899
17.2k
    uint8_t short_delay_band;
1900
1901
17.2k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
17.2k
    memset(ps, 0, sizeof(ps_info));
1903
1904
17.2k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
17.2k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
17.2k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
17.2k
    ps->saved_delay = 0;
1911
1912
1.12M
    for (i = 0; i < 64; i++)
1913
1.10M
    {
1914
1.10M
        ps->delay_buf_index_delay[i] = 0;
1915
1.10M
    }
1916
1917
69.0k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
51.8k
    {
1919
51.8k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
51.8k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
51.8k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
51.8k
#endif
1932
51.8k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
17.2k
    short_delay_band = 35;
1950
17.2k
    ps->nr_allpass_bands = 22;
1951
17.2k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
17.2k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
17.2k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
621k
    for (i = 0; i < short_delay_band; i++)
1957
604k
    {
1958
604k
        ps->delay_D[i] = 14;
1959
604k
    }
1960
518k
    for (i = short_delay_band; i < 64; i++)
1961
500k
    {
1962
500k
        ps->delay_D[i] = 1;
1963
500k
    }
1964
1965
    /* mixing and phase */
1966
880k
    for (i = 0; i < 50; i++)
1967
863k
    {
1968
863k
        RE(ps->h11_prev[i]) = 1;
1969
863k
        IM(ps->h11_prev[i]) = 1;
1970
863k
        RE(ps->h12_prev[i]) = 1;
1971
863k
        IM(ps->h12_prev[i]) = 1;
1972
863k
    }
1973
1974
17.2k
    ps->phase_hist = 0;
1975
1976
362k
    for (i = 0; i < 20; i++)
1977
345k
    {
1978
345k
        RE(ps->ipd_prev[i][0]) = 0;
1979
345k
        IM(ps->ipd_prev[i][0]) = 0;
1980
345k
        RE(ps->ipd_prev[i][1]) = 0;
1981
345k
        IM(ps->ipd_prev[i][1]) = 0;
1982
345k
        RE(ps->opd_prev[i][0]) = 0;
1983
345k
        IM(ps->opd_prev[i][0]) = 0;
1984
345k
        RE(ps->opd_prev[i][1]) = 0;
1985
345k
        IM(ps->opd_prev[i][1]) = 0;
1986
345k
    }
1987
1988
17.2k
    return ps;
1989
17.2k
}
1990
1991
/* main Parametric Stereo decoding function */
1992
uint8_t ps_decode(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64])
1993
19.8k
{
1994
19.8k
    qmf_t X_hybrid_left[32][32] = {{{0}}};
1995
19.8k
    qmf_t X_hybrid_right[32][32] = {{{0}}};
1996
1997
    /* delta decoding of the bitstream data */
1998
19.8k
    ps_data_decode(ps);
1999
2000
    /* set up some parameters depending on filterbank type */
2001
19.8k
    if (ps->use34hybrid_bands)
2002
8.10k
    {
2003
8.10k
        ps->group_border = (uint8_t*)group_border34;
2004
8.10k
        ps->map_group2bk = (uint16_t*)map_group2bk34;
2005
8.10k
        ps->num_groups = 32+18;
2006
8.10k
        ps->num_hybrid_groups = 32;
2007
8.10k
        ps->nr_par_bands = 34;
2008
8.10k
        ps->decay_cutoff = 5;
2009
11.7k
    } else {
2010
11.7k
        ps->group_border = (uint8_t*)group_border20;
2011
11.7k
        ps->map_group2bk = (uint16_t*)map_group2bk20;
2012
11.7k
        ps->num_groups = 10+12;
2013
11.7k
        ps->num_hybrid_groups = 10;
2014
11.7k
        ps->nr_par_bands = 20;
2015
11.7k
        ps->decay_cutoff = 3;
2016
11.7k
    }
2017
2018
    /* Perform further analysis on the lowest subbands to get a higher
2019
     * frequency resolution
2020
     */
2021
19.8k
    hybrid_analysis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2022
19.8k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2023
2024
    /* decorrelate mono signal */
2025
19.8k
    ps_decorrelate(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2026
2027
    /* apply mixing and phase parameters */
2028
19.8k
    ps_mix_phase(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2029
2030
    /* hybrid synthesis, to rebuild the SBR QMF matrices */
2031
19.8k
    hybrid_synthesis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2032
19.8k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2033
2034
19.8k
    hybrid_synthesis((hyb_info*)ps->hyb, X_right, X_hybrid_right,
2035
19.8k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2036
2037
19.8k
    return 0;
2038
19.8k
}
2039
2040
#endif