Coverage Report

Created: 2026-06-10 06:48

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