Coverage Report

Created: 2026-04-01 06:58

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/proc/self/cwd/libfaad/ps_dec.c
Line
Count
Source
1
/*
2
** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
3
** Copyright (C) 2003-2005 M. Bakker, Nero AG, http://www.nero.com
4
**
5
** This program is free software; you can redistribute it and/or modify
6
** it under the terms of the GNU General Public License as published by
7
** the Free Software Foundation; either version 2 of the License, or
8
** (at your option) any later version.
9
**
10
** This program is distributed in the hope that it will be useful,
11
** but WITHOUT ANY WARRANTY; without even the implied warranty of
12
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
** GNU General Public License for more details.
14
**
15
** You should have received a copy of the GNU General Public License
16
** along with this program; if not, write to the Free Software
17
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18
**
19
** Any non-GPL usage of this software or parts of this software is strictly
20
** forbidden.
21
**
22
** The "appropriate copyright message" mentioned in section 2c of the GPLv2
23
** must read: "Code from FAAD2 is copyright (c) Nero AG, www.nero.com"
24
**
25
** Commercial non-GPL licensing of this software is possible.
26
** For more info contact Nero AG through Mpeg4AAClicense@nero.com.
27
**
28
** $Id: ps_dec.c,v 1.16 2009/01/26 22:32:31 menno Exp $
29
**/
30
31
#include "common.h"
32
33
#ifdef PS_DEC
34
35
#include <stdlib.h>
36
#include <stdio.h>
37
#include "ps_dec.h"
38
#include "ps_tables.h"
39
40
/* constants */
41
50.8M
#define NEGATE_IPD_MASK            (0x1000)
42
384k
#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
29.3k
{
198
29.3k
    uint8_t i;
199
200
29.3k
    hyb_info *hyb = (hyb_info*)faad_malloc(sizeof(hyb_info));
201
202
29.3k
    hyb->resolution34[0] = 12;
203
29.3k
    hyb->resolution34[1] = 8;
204
29.3k
    hyb->resolution34[2] = 4;
205
29.3k
    hyb->resolution34[3] = 4;
206
29.3k
    hyb->resolution34[4] = 4;
207
208
29.3k
    hyb->resolution20[0] = 8;
209
29.3k
    hyb->resolution20[1] = 2;
210
29.3k
    hyb->resolution20[2] = 2;
211
212
29.3k
    hyb->frame_len = numTimeSlotsRate;
213
214
29.3k
    hyb->work = (qmf_t*)faad_malloc((hyb->frame_len+12) * sizeof(qmf_t));
215
29.3k
    memset(hyb->work, 0, (hyb->frame_len+12) * sizeof(qmf_t));
216
217
29.3k
    hyb->buffer = (qmf_t**)faad_malloc(5 * sizeof(qmf_t*));
218
176k
    for (i = 0; i < 5; i++)
219
146k
    {
220
146k
        hyb->buffer[i] = (qmf_t*)faad_malloc(hyb->frame_len * sizeof(qmf_t));
221
146k
        memset(hyb->buffer[i], 0, hyb->frame_len * sizeof(qmf_t));
222
146k
    }
223
224
29.3k
    hyb->temp = (qmf_t**)faad_malloc(hyb->frame_len * sizeof(qmf_t*));
225
958k
    for (i = 0; i < hyb->frame_len; i++)
226
929k
    {
227
929k
        hyb->temp[i] = (qmf_t*)faad_malloc(12 /*max*/ * sizeof(qmf_t));
228
929k
    }
229
230
29.3k
    return hyb;
231
29.3k
}
232
233
static void hybrid_free(hyb_info *hyb)
234
29.3k
{
235
29.3k
    uint8_t i;
236
237
29.3k
  if (!hyb) return;
238
239
29.3k
    if (hyb->work)
240
29.3k
        faad_free(hyb->work);
241
242
176k
    for (i = 0; i < 5; i++)
243
146k
    {
244
146k
        if (hyb->buffer[i])
245
146k
            faad_free(hyb->buffer[i]);
246
146k
    }
247
29.3k
    if (hyb->buffer)
248
29.3k
        faad_free(hyb->buffer);
249
250
958k
    for (i = 0; i < hyb->frame_len; i++)
251
929k
    {
252
929k
        if (hyb->temp[i])
253
929k
            faad_free(hyb->temp[i]);
254
929k
    }
255
29.3k
    if (hyb->temp)
256
29.3k
        faad_free(hyb->temp);
257
258
29.3k
    faad_free(hyb);
259
29.3k
}
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
51.9k
{
265
51.9k
    uint8_t i;
266
51.9k
    (void)hyb;  /* TODO: remove parameter? */
267
268
1.68M
    for (i = 0; i < frame_len; i++)
269
1.63M
    {
270
1.63M
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
1.63M
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
1.63M
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
1.63M
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
1.63M
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
1.63M
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
1.63M
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
1.63M
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
1.63M
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
1.63M
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
1.63M
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
1.63M
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
1.63M
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
1.63M
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
1.63M
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
1.63M
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
1.63M
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
1.63M
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
1.63M
    }
293
51.9k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
25.9k
{
265
25.9k
    uint8_t i;
266
25.9k
    (void)hyb;  /* TODO: remove parameter? */
267
268
841k
    for (i = 0; i < frame_len; i++)
269
815k
    {
270
815k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
815k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
815k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
815k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
815k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
815k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
815k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
815k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
815k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
815k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
815k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
815k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
815k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
815k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
815k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
815k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
815k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
815k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
815k
    }
293
25.9k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
25.9k
{
265
25.9k
    uint8_t i;
266
25.9k
    (void)hyb;  /* TODO: remove parameter? */
267
268
841k
    for (i = 0; i < frame_len; i++)
269
815k
    {
270
815k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
815k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
815k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
815k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
815k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
815k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
815k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
815k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
815k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
815k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
815k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
815k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
815k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
815k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
815k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
815k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
815k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
815k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
815k
    }
293
25.9k
}
294
295
/* complex filter, size 4 */
296
static void channel_filter4(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
297
                            qmf_t *buffer, qmf_t **X_hybrid)
298
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
689k
    for (i = 0; i < frame_len; i++)
304
667k
    {
305
667k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
667k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
667k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
667k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
667k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
667k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
667k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
667k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
667k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
667k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
667k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
667k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
667k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
667k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
667k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
667k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
667k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
667k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
667k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
667k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
667k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
667k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
667k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
667k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
667k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
667k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
667k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
667k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
667k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
667k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
667k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
667k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
667k
    }
349
21.6k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
8.58k
{
299
8.58k
    uint8_t i;
300
8.58k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
8.58k
    (void)hyb;  /* TODO: remove parameter? */
302
303
273k
    for (i = 0; i < frame_len; i++)
304
265k
    {
305
265k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
265k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
265k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
265k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
265k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
265k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
265k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
265k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
265k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
265k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
265k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
265k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
265k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
265k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
265k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
265k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
265k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
265k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
265k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
265k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
265k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
265k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
265k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
265k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
265k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
265k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
265k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
265k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
265k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
265k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
265k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
265k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
265k
    }
349
8.58k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
13.1k
{
299
13.1k
    uint8_t i;
300
13.1k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
13.1k
    (void)hyb;  /* TODO: remove parameter? */
302
303
415k
    for (i = 0; i < frame_len; i++)
304
402k
    {
305
402k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
402k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
402k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
402k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
402k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
402k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
402k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
402k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
402k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
402k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
402k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
402k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
402k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
402k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
402k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
402k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
402k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
402k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
402k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
402k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
402k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
402k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
402k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
402k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
402k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
402k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
402k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
402k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
402k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
402k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
402k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
402k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
402k
    }
349
13.1k
}
350
351
static void INLINE DCT3_4_unscaled(real_t *y, real_t *x)
352
2.52M
{
353
2.52M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
2.52M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
2.52M
    f1 = x[0] - f0;
357
2.52M
    f2 = x[0] + f0;
358
2.52M
    f3 = x[1] + x[3];
359
2.52M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
2.52M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
2.52M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
2.52M
    f7 = f4 + f5;
363
2.52M
    f8 = f6 - f5;
364
2.52M
    y[3] = f2 - f8;
365
2.52M
    y[0] = f2 + f8;
366
2.52M
    y[2] = f1 - f7;
367
2.52M
    y[1] = f1 + f7;
368
2.52M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.10M
{
353
1.10M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.10M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.10M
    f1 = x[0] - f0;
357
1.10M
    f2 = x[0] + f0;
358
1.10M
    f3 = x[1] + x[3];
359
1.10M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.10M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.10M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.10M
    f7 = f4 + f5;
363
1.10M
    f8 = f6 - f5;
364
1.10M
    y[3] = f2 - f8;
365
1.10M
    y[0] = f2 + f8;
366
1.10M
    y[2] = f1 - f7;
367
1.10M
    y[1] = f1 + f7;
368
1.10M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.41M
{
353
1.41M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.41M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.41M
    f1 = x[0] - f0;
357
1.41M
    f2 = x[0] + f0;
358
1.41M
    f3 = x[1] + x[3];
359
1.41M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.41M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.41M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.41M
    f7 = f4 + f5;
363
1.41M
    f8 = f6 - f5;
364
1.41M
    y[3] = f2 - f8;
365
1.41M
    y[0] = f2 + f8;
366
1.41M
    y[2] = f1 - f7;
367
1.41M
    y[1] = f1 + f7;
368
1.41M
}
369
370
/* complex filter, size 8 */
371
static void channel_filter8(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
372
                            qmf_t *buffer, qmf_t **X_hybrid)
373
40.4k
{
374
40.4k
    uint8_t i, n;
375
40.4k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
40.4k
    real_t x[4];
377
40.4k
    (void)hyb;  /* TODO: remove parameter? */
378
379
1.30M
    for (i = 0; i < frame_len; i++)
380
1.26M
    {
381
1.26M
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
1.26M
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
1.26M
        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.26M
        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.26M
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
1.26M
        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.26M
        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.26M
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
6.30M
        for (n = 0; n < 4; n++)
392
5.04M
        {
393
5.04M
            x[n] = input_re1[n] - input_im1[3-n];
394
5.04M
        }
395
1.26M
        DCT3_4_unscaled(x, x);
396
1.26M
        QMF_RE(X_hybrid[i][7]) = x[0];
397
1.26M
        QMF_RE(X_hybrid[i][5]) = x[2];
398
1.26M
        QMF_RE(X_hybrid[i][3]) = x[3];
399
1.26M
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
6.30M
        for (n = 0; n < 4; n++)
402
5.04M
        {
403
5.04M
            x[n] = input_re1[n] + input_im1[3-n];
404
5.04M
        }
405
1.26M
        DCT3_4_unscaled(x, x);
406
1.26M
        QMF_RE(X_hybrid[i][6]) = x[1];
407
1.26M
        QMF_RE(X_hybrid[i][4]) = x[3];
408
1.26M
        QMF_RE(X_hybrid[i][2]) = x[2];
409
1.26M
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
1.26M
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
1.26M
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
1.26M
        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.26M
        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.26M
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
1.26M
        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.26M
        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.26M
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
6.30M
        for (n = 0; n < 4; n++)
422
5.04M
        {
423
5.04M
            x[n] = input_im2[n] + input_re2[3-n];
424
5.04M
        }
425
1.26M
        DCT3_4_unscaled(x, x);
426
1.26M
        QMF_IM(X_hybrid[i][7]) = x[0];
427
1.26M
        QMF_IM(X_hybrid[i][5]) = x[2];
428
1.26M
        QMF_IM(X_hybrid[i][3]) = x[3];
429
1.26M
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
6.30M
        for (n = 0; n < 4; n++)
432
5.04M
        {
433
5.04M
            x[n] = input_im2[n] - input_re2[3-n];
434
5.04M
        }
435
1.26M
        DCT3_4_unscaled(x, x);
436
1.26M
        QMF_IM(X_hybrid[i][6]) = x[1];
437
1.26M
        QMF_IM(X_hybrid[i][4]) = x[3];
438
1.26M
        QMF_IM(X_hybrid[i][2]) = x[2];
439
1.26M
        QMF_IM(X_hybrid[i][0]) = x[0];
440
1.26M
    }
441
40.4k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
20.2k
{
374
20.2k
    uint8_t i, n;
375
20.2k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
20.2k
    real_t x[4];
377
20.2k
    (void)hyb;  /* TODO: remove parameter? */
378
379
650k
    for (i = 0; i < frame_len; i++)
380
630k
    {
381
630k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
630k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
630k
        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
630k
        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
630k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
630k
        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
630k
        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
630k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.15M
        for (n = 0; n < 4; n++)
392
2.52M
        {
393
2.52M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.52M
        }
395
630k
        DCT3_4_unscaled(x, x);
396
630k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
630k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
630k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
630k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.15M
        for (n = 0; n < 4; n++)
402
2.52M
        {
403
2.52M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.52M
        }
405
630k
        DCT3_4_unscaled(x, x);
406
630k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
630k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
630k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
630k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
630k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
630k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
630k
        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
630k
        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
630k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
630k
        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
630k
        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
630k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.15M
        for (n = 0; n < 4; n++)
422
2.52M
        {
423
2.52M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.52M
        }
425
630k
        DCT3_4_unscaled(x, x);
426
630k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
630k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
630k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
630k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.15M
        for (n = 0; n < 4; n++)
432
2.52M
        {
433
2.52M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.52M
        }
435
630k
        DCT3_4_unscaled(x, x);
436
630k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
630k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
630k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
630k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
630k
    }
441
20.2k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
20.2k
{
374
20.2k
    uint8_t i, n;
375
20.2k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
20.2k
    real_t x[4];
377
20.2k
    (void)hyb;  /* TODO: remove parameter? */
378
379
650k
    for (i = 0; i < frame_len; i++)
380
630k
    {
381
630k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
630k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
630k
        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
630k
        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
630k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
630k
        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
630k
        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
630k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.15M
        for (n = 0; n < 4; n++)
392
2.52M
        {
393
2.52M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.52M
        }
395
630k
        DCT3_4_unscaled(x, x);
396
630k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
630k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
630k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
630k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.15M
        for (n = 0; n < 4; n++)
402
2.52M
        {
403
2.52M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.52M
        }
405
630k
        DCT3_4_unscaled(x, x);
406
630k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
630k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
630k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
630k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
630k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
630k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
630k
        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
630k
        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
630k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
630k
        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
630k
        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
630k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.15M
        for (n = 0; n < 4; n++)
422
2.52M
        {
423
2.52M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.52M
        }
425
630k
        DCT3_4_unscaled(x, x);
426
630k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
630k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
630k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
630k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.15M
        for (n = 0; n < 4; n++)
432
2.52M
        {
433
2.52M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.52M
        }
435
630k
        DCT3_4_unscaled(x, x);
436
630k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
630k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
630k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
630k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
630k
    }
441
20.2k
}
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
353k
{
445
353k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
353k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
353k
    f1 = x[0] + f0;
449
353k
    f2 = x[0] - f0;
450
353k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
353k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
353k
    f5 = f4 - x[4];
453
353k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
353k
    f7 = f6 - f3;
455
353k
    y[0] = f1 + f6 + f4;
456
353k
    y[1] = f2 + f3 - x[4];
457
353k
    y[2] = f7 + f2 - f5;
458
353k
    y[3] = f1 - f7 - f5;
459
353k
    y[4] = f1 - f3 - x[4];
460
353k
    y[5] = f2 - f6 + f4;
461
353k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
536k
{
445
536k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
536k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
536k
    f1 = x[0] + f0;
449
536k
    f2 = x[0] - f0;
450
536k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
536k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
536k
    f5 = f4 - x[4];
453
536k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
536k
    f7 = f6 - f3;
455
536k
    y[0] = f1 + f6 + f4;
456
536k
    y[1] = f2 + f3 - x[4];
457
536k
    y[2] = f7 + f2 - f5;
458
536k
    y[3] = f1 - f7 - f5;
459
536k
    y[4] = f1 - f3 - x[4];
460
536k
    y[5] = f2 - f6 + f4;
461
536k
}
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
459k
    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.23k
{
467
7.23k
    uint8_t i, n;
468
7.23k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
7.23k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
7.23k
    (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
667k
        {
496
667k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
667k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
667k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
667k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
667k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
667k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
667k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
667k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
667k
        }
506
222k
    }
507
7.23k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
7.23k
{
467
7.23k
    uint8_t i, n;
468
7.23k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
7.23k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
7.23k
    (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
667k
        {
496
667k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
667k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
667k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
667k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
667k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
667k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
667k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
667k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
667k
        }
506
222k
    }
507
7.23k
}
508
509
/* Hybrid analysis: further split up QMF subbands
510
 * to improve frequency resolution
511
 */
512
static void hybrid_analysis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
513
                            uint8_t use34, uint8_t numTimeSlotsRate)
514
20.2k
{
515
20.2k
    uint8_t k, n, band;
516
20.2k
    uint8_t offset = 0;
517
20.2k
    uint8_t qmf_bands = (use34) ? 5 : 3;
518
20.2k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
519
520
95.3k
    for (band = 0; band < qmf_bands; band++)
521
75.1k
    {
522
        /* build working buffer */
523
75.1k
        memcpy(hyb->work, hyb->buffer[band], 12 * sizeof(qmf_t));
524
525
        /* add new samples */
526
2.41M
        for (n = 0; n < hyb->frame_len; n++)
527
2.33M
        {
528
2.33M
            QMF_RE(hyb->work[12 + n]) = QMF_RE(X[n + 6 /*delay*/][band]);
529
2.33M
            QMF_IM(hyb->work[12 + n]) = QMF_IM(X[n + 6 /*delay*/][band]);
530
2.33M
        }
531
532
        /* store samples */
533
75.1k
        memcpy(hyb->buffer[band], hyb->work + hyb->frame_len, 12 * sizeof(qmf_t));
534
535
536
75.1k
        switch(resolution[band])
537
75.1k
        {
538
25.9k
        case 2:
539
            /* Type B real filter, Q[p] = 2 */
540
25.9k
            channel_filter2(hyb, hyb->frame_len, p2_13_20, hyb->work, hyb->temp);
541
25.9k
            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
20.2k
        case 8:
547
            /* Type A complex filter, Q[p] = 8 */
548
20.2k
            channel_filter8(hyb, hyb->frame_len, (use34) ? p8_13_34 : p8_13_20,
549
20.2k
                hyb->work, hyb->temp);
550
20.2k
            break;
551
7.23k
        case 12:
552
            /* Type A complex filter, Q[p] = 12 */
553
7.23k
            channel_filter12(hyb, hyb->frame_len, p12_13_34, hyb->work, hyb->temp);
554
7.23k
            break;
555
75.1k
        }
556
557
2.41M
        for (n = 0; n < hyb->frame_len; n++)
558
2.33M
        {
559
14.3M
            for (k = 0; k < resolution[band]; k++)
560
12.0M
            {
561
12.0M
                QMF_RE(X_hybrid[n][offset + k]) = QMF_RE(hyb->temp[n][k]);
562
12.0M
                QMF_IM(X_hybrid[n][offset + k]) = QMF_IM(hyb->temp[n][k]);
563
12.0M
            }
564
2.33M
        }
565
75.1k
        offset += resolution[band];
566
75.1k
    }
567
568
    /* group hybrid channels */
569
20.2k
    if (!use34)
570
12.9k
    {
571
420k
        for (n = 0; n < numTimeSlotsRate; n++)
572
407k
        {
573
407k
            QMF_RE(X_hybrid[n][3]) += QMF_RE(X_hybrid[n][4]);
574
407k
            QMF_IM(X_hybrid[n][3]) += QMF_IM(X_hybrid[n][4]);
575
407k
            QMF_RE(X_hybrid[n][4]) = 0;
576
407k
            QMF_IM(X_hybrid[n][4]) = 0;
577
578
407k
            QMF_RE(X_hybrid[n][2]) += QMF_RE(X_hybrid[n][5]);
579
407k
            QMF_IM(X_hybrid[n][2]) += QMF_IM(X_hybrid[n][5]);
580
407k
            QMF_RE(X_hybrid[n][5]) = 0;
581
407k
            QMF_IM(X_hybrid[n][5]) = 0;
582
407k
        }
583
12.9k
    }
584
20.2k
}
585
586
static void hybrid_synthesis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
587
                             uint8_t use34, uint8_t numTimeSlotsRate)
588
40.4k
{
589
40.4k
    uint8_t k, n, band;
590
40.4k
    uint8_t offset = 0;
591
40.4k
    uint8_t qmf_bands = (use34) ? 5 : 3;
592
40.4k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
593
40.4k
    (void)numTimeSlotsRate;  /* TODO: remove parameter? */
594
595
190k
    for(band = 0; band < qmf_bands; band++)
596
150k
    {
597
4.82M
        for (n = 0; n < hyb->frame_len; n++)
598
4.66M
        {
599
4.66M
            QMF_RE(X[n][band]) = 0;
600
4.66M
            QMF_IM(X[n][band]) = 0;
601
602
28.6M
            for (k = 0; k < resolution[band]; k++)
603
24.0M
            {
604
24.0M
                QMF_RE(X[n][band]) += QMF_RE(X_hybrid[n][offset + k]);
605
24.0M
                QMF_IM(X[n][band]) += QMF_IM(X_hybrid[n][offset + k]);
606
24.0M
            }
607
4.66M
        }
608
150k
        offset += resolution[band];
609
150k
    }
610
40.4k
}
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
413k
{
615
413k
    if (i < min)
616
48.1k
        return min;
617
365k
    else if (i > max)
618
5.47k
        return max;
619
360k
    else
620
360k
        return i;
621
413k
}
622
623
//int iid = 0;
624
625
/* delta decode array */
626
static void delta_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
627
                         uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
628
                         int8_t min_index, int8_t max_index)
629
71.2k
{
630
71.2k
    int8_t i;
631
632
71.2k
    if (enable == 1)
633
34.8k
    {
634
34.8k
        if (dt_flag == 0)
635
21.5k
        {
636
            /* delta coded in frequency direction */
637
21.5k
            index[0] = 0 + index[0];
638
21.5k
            index[0] = delta_clip(index[0], min_index, max_index);
639
640
267k
            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
21.5k
        } else {
646
            /* delta coded in time direction */
647
159k
            for (i = 0; i < nr_par; i++)
648
146k
            {
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
146k
                index[i] = index_prev[i*stride] + index[i];
656
                //tmp2 = index[i];
657
146k
                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
146k
            }
667
13.3k
        }
668
36.3k
    } else {
669
        /* set indices to zero */
670
62.7k
        for (i = 0; i < nr_par; i++)
671
26.3k
        {
672
26.3k
            index[i] = 0;
673
26.3k
        }
674
36.3k
    }
675
676
    /* coarse */
677
71.2k
    if (stride == 2)
678
48.9k
    {
679
313k
        for (i = (nr_par<<1)-1; i > 0; i--)
680
264k
        {
681
264k
            index[i] = index[i>>1];
682
264k
        }
683
48.9k
    }
684
71.2k
}
685
686
/* delta modulo decode array */
687
/* in: log2 value of the modulo value to allow using AND instead of MOD */
688
static void delta_modulo_decode(uint8_t enable, int8_t *index, int8_t *index_prev,
689
                                uint8_t dt_flag, uint8_t nr_par, uint8_t stride,
690
                                int8_t and_modulo)
691
71.2k
{
692
71.2k
    int8_t i;
693
694
71.2k
    if (enable == 1)
695
22.3k
    {
696
22.3k
        if (dt_flag == 0)
697
13.3k
        {
698
            /* delta coded in frequency direction */
699
13.3k
            index[0] = 0 + index[0];
700
13.3k
            index[0] &= and_modulo;
701
702
58.7k
            for (i = 1; i < nr_par; i++)
703
45.4k
            {
704
45.4k
                index[i] = index[i-1] + index[i];
705
45.4k
                index[i] &= and_modulo;
706
45.4k
            }
707
13.3k
        } else {
708
            /* delta coded in time direction */
709
29.3k
            for (i = 0; i < nr_par; i++)
710
20.3k
            {
711
20.3k
                index[i] = index_prev[i*stride] + index[i];
712
20.3k
                index[i] &= and_modulo;
713
20.3k
            }
714
8.97k
        }
715
48.9k
    } else {
716
        /* set indices to zero */
717
166k
        for (i = 0; i < nr_par; i++)
718
118k
        {
719
118k
            index[i] = 0;
720
118k
        }
721
48.9k
    }
722
723
    /* coarse */
724
71.2k
    if (stride == 2)
725
0
    {
726
0
        index[0] = 0;
727
0
        for (i = (nr_par<<1)-1; i > 0; i--)
728
0
        {
729
0
            index[i] = index[i>>1];
730
0
        }
731
0
    }
732
71.2k
}
733
734
#ifdef PS_LOW_POWER
735
static void map34indexto20(int8_t *index, uint8_t bins)
736
{
737
    index[0] = (2*index[0]+index[1])/3;
738
    index[1] = (index[1]+2*index[2])/3;
739
    index[2] = (2*index[3]+index[4])/3;
740
    index[3] = (index[4]+2*index[5])/3;
741
    index[4] = (index[6]+index[7])/2;
742
    index[5] = (index[8]+index[9])/2;
743
    index[6] = index[10];
744
    index[7] = index[11];
745
    index[8] = (index[12]+index[13])/2;
746
    index[9] = (index[14]+index[15])/2;
747
    index[10] = index[16];
748
749
    if (bins == 34)
750
    {
751
        index[11] = index[17];
752
        index[12] = index[18];
753
        index[13] = index[19];
754
        index[14] = (index[20]+index[21])/2;
755
        index[15] = (index[22]+index[23])/2;
756
        index[16] = (index[24]+index[25])/2;
757
        index[17] = (index[26]+index[27])/2;
758
        index[18] = (index[28]+index[29]+index[30]+index[31])/4;
759
        index[19] = (index[32]+index[33])/2;
760
    }
761
}
762
#endif
763
764
static void map20indexto34(int8_t *index, uint8_t bins)
765
25.7k
{
766
25.7k
    index[0] = index[0];
767
25.7k
    index[1] = (index[0] + index[1])/2;
768
25.7k
    index[2] = index[1];
769
25.7k
    index[3] = index[2];
770
25.7k
    index[4] = (index[2] + index[3])/2;
771
25.7k
    index[5] = index[3];
772
25.7k
    index[6] = index[4];
773
25.7k
    index[7] = index[4];
774
25.7k
    index[8] = index[5];
775
25.7k
    index[9] = index[5];
776
25.7k
    index[10] = index[6];
777
25.7k
    index[11] = index[7];
778
25.7k
    index[12] = index[8];
779
25.7k
    index[13] = index[8];
780
25.7k
    index[14] = index[9];
781
25.7k
    index[15] = index[9];
782
25.7k
    index[16] = index[10];
783
784
25.7k
    if (bins == 34)
785
12.0k
    {
786
12.0k
        index[17] = index[11];
787
12.0k
        index[18] = index[12];
788
12.0k
        index[19] = index[13];
789
12.0k
        index[20] = index[14];
790
12.0k
        index[21] = index[14];
791
12.0k
        index[22] = index[15];
792
12.0k
        index[23] = index[15];
793
12.0k
        index[24] = index[16];
794
12.0k
        index[25] = index[16];
795
12.0k
        index[26] = index[17];
796
12.0k
        index[27] = index[17];
797
12.0k
        index[28] = index[18];
798
12.0k
        index[29] = index[18];
799
12.0k
        index[30] = index[18];
800
12.0k
        index[31] = index[18];
801
12.0k
        index[32] = index[19];
802
12.0k
        index[33] = index[19];
803
12.0k
    }
804
25.7k
}
805
806
/* parse the bitstream data decoded in ps_data() */
807
static void ps_data_decode(ps_info *ps)
808
20.2k
{
809
20.2k
    uint8_t env, bin;
810
811
    /* ps data not available, use data from previous frame */
812
20.2k
    if (ps->ps_data_available == 0)
813
5.06k
    {
814
5.06k
        ps->num_env = 0;
815
5.06k
    }
816
817
55.8k
    for (env = 0; env < ps->num_env; env++)
818
35.6k
    {
819
35.6k
        int8_t *iid_index_prev;
820
35.6k
        int8_t *icc_index_prev;
821
35.6k
        int8_t *ipd_index_prev;
822
35.6k
        int8_t *opd_index_prev;
823
824
35.6k
        int8_t num_iid_steps = (ps->iid_mode < 3) ? 7 : 15 /*fine quant*/;
825
826
35.6k
        if (env == 0)
827
10.5k
        {
828
            /* take last envelope from previous frame */
829
10.5k
            iid_index_prev = ps->iid_index_prev;
830
10.5k
            icc_index_prev = ps->icc_index_prev;
831
10.5k
            ipd_index_prev = ps->ipd_index_prev;
832
10.5k
            opd_index_prev = ps->opd_index_prev;
833
25.0k
        } else {
834
            /* take index values from previous envelope */
835
25.0k
            iid_index_prev = ps->iid_index[env - 1];
836
25.0k
            icc_index_prev = ps->icc_index[env - 1];
837
25.0k
            ipd_index_prev = ps->ipd_index[env - 1];
838
25.0k
            opd_index_prev = ps->opd_index[env - 1];
839
25.0k
        }
840
841
//        iid = 1;
842
        /* delta decode iid parameters */
843
35.6k
        delta_decode(ps->enable_iid, ps->iid_index[env], iid_index_prev,
844
35.6k
            ps->iid_dt[env], ps->nr_iid_par,
845
35.6k
            (ps->iid_mode == 0 || ps->iid_mode == 3) ? 2 : 1,
846
35.6k
            -num_iid_steps, num_iid_steps);
847
//        iid = 0;
848
849
        /* delta decode icc parameters */
850
35.6k
        delta_decode(ps->enable_icc, ps->icc_index[env], icc_index_prev,
851
35.6k
            ps->icc_dt[env], ps->nr_icc_par,
852
35.6k
            (ps->icc_mode == 0 || ps->icc_mode == 3) ? 2 : 1,
853
35.6k
            0, 7);
854
855
        /* delta modulo decode ipd parameters */
856
35.6k
        delta_modulo_decode(ps->enable_ipdopd, ps->ipd_index[env], ipd_index_prev,
857
35.6k
            ps->ipd_dt[env], ps->nr_ipdopd_par, 1, 7);
858
859
        /* delta modulo decode opd parameters */
860
35.6k
        delta_modulo_decode(ps->enable_ipdopd, ps->opd_index[env], opd_index_prev,
861
35.6k
            ps->opd_dt[env], ps->nr_ipdopd_par, 1, 7);
862
35.6k
    }
863
864
    /* handle error case */
865
20.2k
    if (ps->num_env == 0)
866
9.65k
    {
867
        /* force to 1 */
868
9.65k
        ps->num_env = 1;
869
870
9.65k
        if (ps->enable_iid)
871
6.41k
        {
872
224k
            for (bin = 0; bin < 34; bin++)
873
218k
                ps->iid_index[0][bin] = ps->iid_index_prev[bin];
874
6.41k
        } else {
875
113k
            for (bin = 0; bin < 34; bin++)
876
110k
                ps->iid_index[0][bin] = 0;
877
3.23k
        }
878
879
9.65k
        if (ps->enable_icc)
880
4.80k
        {
881
168k
            for (bin = 0; bin < 34; bin++)
882
163k
                ps->icc_index[0][bin] = ps->icc_index_prev[bin];
883
4.84k
        } else {
884
169k
            for (bin = 0; bin < 34; bin++)
885
164k
                ps->icc_index[0][bin] = 0;
886
4.84k
        }
887
888
9.65k
        if (ps->enable_ipdopd)
889
1.73k
        {
890
31.1k
            for (bin = 0; bin < 17; bin++)
891
29.4k
            {
892
29.4k
                ps->ipd_index[0][bin] = ps->ipd_index_prev[bin];
893
29.4k
                ps->opd_index[0][bin] = ps->opd_index_prev[bin];
894
29.4k
            }
895
7.92k
        } else {
896
142k
            for (bin = 0; bin < 17; bin++)
897
134k
            {
898
134k
                ps->ipd_index[0][bin] = 0;
899
134k
                ps->opd_index[0][bin] = 0;
900
134k
            }
901
7.92k
        }
902
9.65k
    }
903
904
    /* update previous indices */
905
707k
    for (bin = 0; bin < 34; bin++)
906
687k
        ps->iid_index_prev[bin] = ps->iid_index[ps->num_env-1][bin];
907
707k
    for (bin = 0; bin < 34; bin++)
908
687k
        ps->icc_index_prev[bin] = ps->icc_index[ps->num_env-1][bin];
909
363k
    for (bin = 0; bin < 17; bin++)
910
343k
    {
911
343k
        ps->ipd_index_prev[bin] = ps->ipd_index[ps->num_env-1][bin];
912
343k
        ps->opd_index_prev[bin] = ps->opd_index[ps->num_env-1][bin];
913
343k
    }
914
915
20.2k
    ps->ps_data_available = 0;
916
917
20.2k
    if (ps->frame_class == 0)
918
12.1k
    {
919
12.1k
        ps->border_position[0] = 0;
920
22.3k
        for (env = 1; env < ps->num_env; env++)
921
10.2k
        {
922
10.2k
            ps->border_position[env] = (env * ps->numTimeSlotsRate) / ps->num_env;
923
10.2k
        }
924
12.1k
        ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
925
12.1k
    } else {
926
8.06k
        ps->border_position[0] = 0;
927
928
8.06k
        if (ps->border_position[ps->num_env] < ps->numTimeSlotsRate)
929
6.16k
        {
930
215k
            for (bin = 0; bin < 34; bin++)
931
209k
            {
932
209k
                ps->iid_index[ps->num_env][bin] = ps->iid_index[ps->num_env-1][bin];
933
209k
                ps->icc_index[ps->num_env][bin] = ps->icc_index[ps->num_env-1][bin];
934
209k
            }
935
110k
            for (bin = 0; bin < 17; bin++)
936
104k
            {
937
104k
                ps->ipd_index[ps->num_env][bin] = ps->ipd_index[ps->num_env-1][bin];
938
104k
                ps->opd_index[ps->num_env][bin] = ps->opd_index[ps->num_env-1][bin];
939
104k
            }
940
6.16k
            ps->num_env++;
941
6.16k
            ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
942
6.16k
        }
943
944
29.0k
        for (env = 1; env < ps->num_env; env++)
945
21.0k
        {
946
21.0k
            int8_t thr = ps->numTimeSlotsRate - (ps->num_env - env);
947
948
21.0k
            if (ps->border_position[env] > thr)
949
4.62k
            {
950
4.62k
                ps->border_position[env] = thr;
951
16.4k
            } else {
952
16.4k
                thr = ps->border_position[env-1]+1;
953
16.4k
                if (ps->border_position[env] < thr)
954
8.69k
                {
955
8.69k
                    ps->border_position[env] = thr;
956
8.69k
                }
957
16.4k
            }
958
21.0k
        }
959
8.06k
    }
960
961
    /* make sure that the indices of all parameters can be mapped
962
     * to the same hybrid synthesis filterbank
963
     */
964
#ifdef PS_LOW_POWER
965
    for (env = 0; env < ps->num_env; env++)
966
    {
967
        if (ps->iid_mode == 2 || ps->iid_mode == 5)
968
            map34indexto20(ps->iid_index[env], 34);
969
        if (ps->icc_mode == 2 || ps->icc_mode == 5)
970
            map34indexto20(ps->icc_index[env], 34);
971
972
        /* disable ipd/opd */
973
        for (bin = 0; bin < 17; bin++)
974
        {
975
            ps->aaIpdIndex[env][bin] = 0;
976
            ps->aaOpdIndex[env][bin] = 0;
977
        }
978
    }
979
#else
980
20.2k
    if (ps->use34hybrid_bands)
981
7.23k
    {
982
19.9k
        for (env = 0; env < ps->num_env; env++)
983
12.7k
        {
984
12.7k
            if (ps->iid_mode != 2 && ps->iid_mode != 5)
985
6.81k
                map20indexto34(ps->iid_index[env], 34);
986
12.7k
            if (ps->icc_mode != 2 && ps->icc_mode != 5)
987
5.25k
                map20indexto34(ps->icc_index[env], 34);
988
12.7k
            if (ps->ipd_mode != 2 && ps->ipd_mode != 5)
989
6.81k
            {
990
6.81k
                map20indexto34(ps->ipd_index[env], 17);
991
6.81k
                map20indexto34(ps->opd_index[env], 17);
992
6.81k
            }
993
12.7k
        }
994
7.23k
    }
995
20.2k
#endif
996
997
#if 0
998
    for (env = 0; env < ps->num_env; env++)
999
    {
1000
        printf("iid[env:%d]:", env);
1001
        for (bin = 0; bin < 34; bin++)
1002
        {
1003
            printf(" %d", ps->iid_index[env][bin]);
1004
        }
1005
        printf("\n");
1006
    }
1007
    for (env = 0; env < ps->num_env; env++)
1008
    {
1009
        printf("icc[env:%d]:", env);
1010
        for (bin = 0; bin < 34; bin++)
1011
        {
1012
            printf(" %d", ps->icc_index[env][bin]);
1013
        }
1014
        printf("\n");
1015
    }
1016
    for (env = 0; env < ps->num_env; env++)
1017
    {
1018
        printf("ipd[env:%d]:", env);
1019
        for (bin = 0; bin < 17; bin++)
1020
        {
1021
            printf(" %d", ps->ipd_index[env][bin]);
1022
        }
1023
        printf("\n");
1024
    }
1025
    for (env = 0; env < ps->num_env; env++)
1026
    {
1027
        printf("opd[env:%d]:", env);
1028
        for (bin = 0; bin < 17; bin++)
1029
        {
1030
            printf(" %d", ps->opd_index[env][bin]);
1031
        }
1032
        printf("\n");
1033
    }
1034
    printf("\n");
1035
#endif
1036
20.2k
}
1037
1038
/* decorrelate the mono signal using an allpass filter */
1039
static void ps_decorrelate(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
1040
                           qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32])
1041
20.2k
{
1042
20.2k
    uint8_t gr, n, bk;
1043
20.2k
    uint8_t temp_delay = 0;
1044
20.2k
    uint8_t sb, maxsb;
1045
20.2k
    const complex_t *Phi_Fract_SubQmf;
1046
20.2k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
20.2k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
20.2k
    real_t P[32][34];
1049
20.2k
    real_t G_TransientRatio[32][34] = {{0}};
1050
20.2k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
20.2k
    if (ps->use34hybrid_bands)
1055
7.23k
    {
1056
7.23k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
12.9k
    } else{
1058
12.9k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
12.9k
    }
1060
1061
    /* clear the energy values */
1062
667k
    for (n = 0; n < 32; n++)
1063
646k
    {
1064
22.6M
        for (bk = 0; bk < 34; bk++)
1065
21.9M
        {
1066
21.9M
            P[n][bk] = 0;
1067
21.9M
        }
1068
646k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
667k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
647k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
647k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
647k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
2.22M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
1.57M
        {
1081
50.8M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
49.3M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
49.3M
                if (gr < ps->num_hybrid_groups)
1089
11.2M
                {
1090
11.2M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
11.2M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
38.1M
                } else {
1093
38.1M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
38.1M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
38.1M
                }
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.3M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
21.3M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
27.9M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
49.3M
            }
1109
1.57M
        }
1110
647k
    }
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
525k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
505k
    {
1129
16.2M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
15.7M
        {
1131
15.7M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
15.7M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
15.7M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
124k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
15.7M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
15.7M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
15.7M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
15.7M
            nrg = ps->P_prev[bk];
1144
15.7M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
15.7M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
15.7M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
15.6M
            {
1150
15.6M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
15.6M
            } else {
1152
93.6k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
93.6k
            }
1154
15.7M
        }
1155
505k
    }
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
667k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
647k
    {
1174
647k
        if (gr < ps->num_hybrid_groups)
1175
361k
            maxsb = ps->group_border[gr] + 1;
1176
285k
        else
1177
285k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
2.22M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
1.57M
        {
1182
1.57M
            real_t g_DecaySlope;
1183
1.57M
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
1.57M
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
381k
            {
1188
381k
                g_DecaySlope = FRAC_CONST(1.0);
1189
1.19M
            } else {
1190
1.19M
                int8_t decay = ps->decay_cutoff - sb;
1191
1.19M
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
814k
                {
1193
814k
                    g_DecaySlope = 0;
1194
814k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
384k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
384k
                }
1198
1.19M
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
6.31M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
4.73M
            {
1203
4.73M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
4.73M
            }
1205
1206
1207
            /* set delay indices */
1208
1.57M
            temp_delay = ps->saved_delay;
1209
6.31M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
4.73M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
50.8M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
49.3M
            {
1214
49.3M
                complex_t tmp, tmp0, R0;
1215
49.3M
                uint8_t m;
1216
1217
49.3M
                if (gr < ps->num_hybrid_groups)
1218
11.2M
                {
1219
                    /* hybrid filterbank input */
1220
11.2M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
11.2M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
38.1M
                } else {
1223
                    /* QMF filterbank input */
1224
38.1M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
38.1M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
38.1M
                }
1227
1228
49.3M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
25.9M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
25.9M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
25.9M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
25.9M
                    RE(R0) = RE(tmp);
1236
25.9M
                    IM(R0) = IM(tmp);
1237
25.9M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
25.9M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
25.9M
                } else {
1240
                    /* allpass filter */
1241
23.4M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
23.4M
                    if (gr < ps->num_hybrid_groups)
1245
11.2M
                    {
1246
                        /* select data from the hybrid subbands */
1247
11.2M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
11.2M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
11.2M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
11.2M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
11.2M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
11.2M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
12.1M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
12.1M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
12.1M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
12.1M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
12.1M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
12.1M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
12.1M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
12.1M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
23.4M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
23.4M
                    RE(R0) = RE(tmp);
1271
23.4M
                    IM(R0) = IM(tmp);
1272
93.6M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
70.2M
                    {
1274
70.2M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
70.2M
                        if (gr < ps->num_hybrid_groups)
1278
33.6M
                        {
1279
                            /* select data from the hybrid subbands */
1280
33.6M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
33.6M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
33.6M
                            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
12.2M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
12.2M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
12.2M
                            }
1291
36.5M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
36.5M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
36.5M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
36.5M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
36.5M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
36.5M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
70.2M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
70.2M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
70.2M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
70.2M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
70.2M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
70.2M
                        if (gr < ps->num_hybrid_groups)
1314
33.6M
                        {
1315
33.6M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
33.6M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
36.5M
                        } else {
1318
36.5M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
36.5M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
36.5M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
70.2M
                        RE(R0) = RE(tmp);
1324
70.2M
                        IM(R0) = IM(tmp);
1325
70.2M
                    }
1326
23.4M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
49.3M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
49.3M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
49.3M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
49.3M
                if (gr < ps->num_hybrid_groups)
1336
11.2M
                {
1337
                    /* hybrid */
1338
11.2M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
11.2M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
38.1M
                } else {
1341
                    /* QMF */
1342
38.1M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
38.1M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
38.1M
                }
1345
1346
                /* Update delay buffer index */
1347
49.3M
                if (++temp_delay >= 2)
1348
24.6M
                {
1349
24.6M
                    temp_delay = 0;
1350
24.6M
                }
1351
1352
                /* update delay indices */
1353
49.3M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
25.9M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
25.9M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
18.8M
                    {
1358
18.8M
                        ps->delay_buf_index_delay[sb] = 0;
1359
18.8M
                    }
1360
25.9M
                }
1361
1362
197M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
147M
                {
1364
147M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
37.8M
                    {
1366
37.8M
                        temp_delay_ser[m] = 0;
1367
37.8M
                    }
1368
147M
                }
1369
49.3M
            }
1370
1.57M
        }
1371
647k
    }
1372
1373
    /* update delay indices */
1374
20.2k
    ps->saved_delay = temp_delay;
1375
80.8k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
60.6k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
20.2k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
8.81k
{
1042
8.81k
    uint8_t gr, n, bk;
1043
8.81k
    uint8_t temp_delay = 0;
1044
8.81k
    uint8_t sb, maxsb;
1045
8.81k
    const complex_t *Phi_Fract_SubQmf;
1046
8.81k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
8.81k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
8.81k
    real_t P[32][34];
1049
8.81k
    real_t G_TransientRatio[32][34] = {{0}};
1050
8.81k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
8.81k
    if (ps->use34hybrid_bands)
1055
2.86k
    {
1056
2.86k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
5.95k
    } else{
1058
5.95k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
5.95k
    }
1060
1061
    /* clear the energy values */
1062
290k
    for (n = 0; n < 32; n++)
1063
282k
    {
1064
9.87M
        for (bk = 0; bk < 34; bk++)
1065
9.59M
        {
1066
9.59M
            P[n][bk] = 0;
1067
9.59M
        }
1068
282k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
282k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
274k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
274k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
274k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
957k
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
683k
        {
1081
22.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
21.3M
            {
1083
21.3M
#ifdef FIXED_POINT
1084
21.3M
                uint32_t in_re, in_im;
1085
21.3M
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
21.3M
                if (gr < ps->num_hybrid_groups)
1089
4.70M
                {
1090
4.70M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
4.70M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
16.6M
                } else {
1093
16.6M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
16.6M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
16.6M
                }
1096
1097
                /* accumulate energy */
1098
21.3M
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
21.3M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
21.3M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
21.3M
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
21.3M
            }
1109
683k
        }
1110
274k
    }
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
225k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
216k
    {
1129
6.97M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
6.76M
        {
1131
6.76M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
6.76M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
6.76M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
15.2k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
6.76M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
6.76M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
6.76M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
6.76M
            nrg = ps->P_prev[bk];
1144
6.76M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
6.76M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
6.76M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
6.75M
            {
1150
6.75M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
6.75M
            } else {
1152
9.64k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
9.64k
            }
1154
6.76M
        }
1155
216k
    }
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
282k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
274k
    {
1174
274k
        if (gr < ps->num_hybrid_groups)
1175
151k
            maxsb = ps->group_border[gr] + 1;
1176
122k
        else
1177
122k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
957k
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
683k
        {
1182
683k
            real_t g_DecaySlope;
1183
683k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
683k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
159k
            {
1188
159k
                g_DecaySlope = FRAC_CONST(1.0);
1189
523k
            } else {
1190
523k
                int8_t decay = ps->decay_cutoff - sb;
1191
523k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
355k
                {
1193
355k
                    g_DecaySlope = 0;
1194
355k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
167k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
167k
                }
1198
523k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
2.73M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.04M
            {
1203
2.04M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.04M
            }
1205
1206
1207
            /* set delay indices */
1208
683k
            temp_delay = ps->saved_delay;
1209
2.73M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.04M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
22.0M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
21.3M
            {
1214
21.3M
                complex_t tmp, tmp0, R0;
1215
21.3M
                uint8_t m;
1216
1217
21.3M
                if (gr < ps->num_hybrid_groups)
1218
4.70M
                {
1219
                    /* hybrid filterbank input */
1220
4.70M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
4.70M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
16.6M
                } else {
1223
                    /* QMF filterbank input */
1224
16.6M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
16.6M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
16.6M
                }
1227
1228
21.3M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
11.3M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
11.3M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
11.3M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
11.3M
                    RE(R0) = RE(tmp);
1236
11.3M
                    IM(R0) = IM(tmp);
1237
11.3M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
11.3M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
11.3M
                } else {
1240
                    /* allpass filter */
1241
10.0M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
10.0M
                    if (gr < ps->num_hybrid_groups)
1245
4.70M
                    {
1246
                        /* select data from the hybrid subbands */
1247
4.70M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
4.70M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
4.70M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
4.70M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
4.70M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
4.70M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
5.34M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
5.34M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
5.34M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
5.34M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
5.34M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
5.34M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
5.34M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
5.34M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
10.0M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
10.0M
                    RE(R0) = RE(tmp);
1271
10.0M
                    IM(R0) = IM(tmp);
1272
40.2M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
30.1M
                    {
1274
30.1M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
30.1M
                        if (gr < ps->num_hybrid_groups)
1278
14.1M
                        {
1279
                            /* select data from the hybrid subbands */
1280
14.1M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
14.1M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
14.1M
                            if (ps->use34hybrid_bands)
1284
8.50M
                            {
1285
8.50M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
8.50M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
8.50M
                            } else {
1288
5.62M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
5.62M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
5.62M
                            }
1291
16.0M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
16.0M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
16.0M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
16.0M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
16.0M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
16.0M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
30.1M
                        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.1M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
30.1M
                        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.1M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
30.1M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
30.1M
                        if (gr < ps->num_hybrid_groups)
1314
14.1M
                        {
1315
14.1M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
14.1M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
16.0M
                        } else {
1318
16.0M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
16.0M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
16.0M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
30.1M
                        RE(R0) = RE(tmp);
1324
30.1M
                        IM(R0) = IM(tmp);
1325
30.1M
                    }
1326
10.0M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
21.3M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
21.3M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
21.3M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
21.3M
                if (gr < ps->num_hybrid_groups)
1336
4.70M
                {
1337
                    /* hybrid */
1338
4.70M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
4.70M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
16.6M
                } else {
1341
                    /* QMF */
1342
16.6M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
16.6M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
16.6M
                }
1345
1346
                /* Update delay buffer index */
1347
21.3M
                if (++temp_delay >= 2)
1348
10.6M
                {
1349
10.6M
                    temp_delay = 0;
1350
10.6M
                }
1351
1352
                /* update delay indices */
1353
21.3M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
11.3M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
11.3M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
8.21M
                    {
1358
8.21M
                        ps->delay_buf_index_delay[sb] = 0;
1359
8.21M
                    }
1360
11.3M
                }
1361
1362
85.4M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
64.1M
                {
1364
64.1M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
16.3M
                    {
1366
16.3M
                        temp_delay_ser[m] = 0;
1367
16.3M
                    }
1368
64.1M
                }
1369
21.3M
            }
1370
683k
        }
1371
274k
    }
1372
1373
    /* update delay indices */
1374
8.81k
    ps->saved_delay = temp_delay;
1375
35.2k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
26.4k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
8.81k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
11.3k
{
1042
11.3k
    uint8_t gr, n, bk;
1043
11.3k
    uint8_t temp_delay = 0;
1044
11.3k
    uint8_t sb, maxsb;
1045
11.3k
    const complex_t *Phi_Fract_SubQmf;
1046
11.3k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
11.3k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
11.3k
    real_t P[32][34];
1049
11.3k
    real_t G_TransientRatio[32][34] = {{0}};
1050
11.3k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
11.3k
    if (ps->use34hybrid_bands)
1055
4.36k
    {
1056
4.36k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
7.02k
    } else{
1058
7.02k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
7.02k
    }
1060
1061
    /* clear the energy values */
1062
376k
    for (n = 0; n < 32; n++)
1063
364k
    {
1064
12.7M
        for (bk = 0; bk < 34; bk++)
1065
12.4M
        {
1066
12.4M
            P[n][bk] = 0;
1067
12.4M
        }
1068
364k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
384k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
373k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
373k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
373k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
1.26M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
896k
        {
1081
28.8M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
27.9M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
27.9M
                if (gr < ps->num_hybrid_groups)
1089
6.51M
                {
1090
6.51M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
6.51M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
21.4M
                } else {
1093
21.4M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
21.4M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
21.4M
                }
1096
1097
                /* accumulate energy */
1098
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
27.9M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
27.9M
#endif
1108
27.9M
            }
1109
896k
        }
1110
373k
    }
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
300k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
289k
    {
1129
9.28M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
8.99M
        {
1131
8.99M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
8.99M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
8.99M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
109k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
8.99M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
8.99M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
8.99M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
8.99M
            nrg = ps->P_prev[bk];
1144
8.99M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
8.99M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
8.99M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
8.91M
            {
1150
8.91M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
8.91M
            } else {
1152
83.9k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
83.9k
            }
1154
8.99M
        }
1155
289k
    }
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
384k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
373k
    {
1174
373k
        if (gr < ps->num_hybrid_groups)
1175
210k
            maxsb = ps->group_border[gr] + 1;
1176
162k
        else
1177
162k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
1.26M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
896k
        {
1182
896k
            real_t g_DecaySlope;
1183
896k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
896k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
221k
            {
1188
221k
                g_DecaySlope = FRAC_CONST(1.0);
1189
675k
            } else {
1190
675k
                int8_t decay = ps->decay_cutoff - sb;
1191
675k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
458k
                {
1193
458k
                    g_DecaySlope = 0;
1194
458k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
216k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
216k
                }
1198
675k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
3.58M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.68M
            {
1203
2.68M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.68M
            }
1205
1206
1207
            /* set delay indices */
1208
896k
            temp_delay = ps->saved_delay;
1209
3.58M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.68M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
28.8M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
27.9M
            {
1214
27.9M
                complex_t tmp, tmp0, R0;
1215
27.9M
                uint8_t m;
1216
1217
27.9M
                if (gr < ps->num_hybrid_groups)
1218
6.51M
                {
1219
                    /* hybrid filterbank input */
1220
6.51M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
6.51M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
21.4M
                } else {
1223
                    /* QMF filterbank input */
1224
21.4M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
21.4M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
21.4M
                }
1227
1228
27.9M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
14.5M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
14.5M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
14.5M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
14.5M
                    RE(R0) = RE(tmp);
1236
14.5M
                    IM(R0) = IM(tmp);
1237
14.5M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
14.5M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
14.5M
                } else {
1240
                    /* allpass filter */
1241
13.3M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
13.3M
                    if (gr < ps->num_hybrid_groups)
1245
6.51M
                    {
1246
                        /* select data from the hybrid subbands */
1247
6.51M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
6.51M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
6.51M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
6.51M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
6.51M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
6.51M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
6.84M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
6.84M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
6.84M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
6.84M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
6.84M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
6.84M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
6.84M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
6.84M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
13.3M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
13.3M
                    RE(R0) = RE(tmp);
1271
13.3M
                    IM(R0) = IM(tmp);
1272
53.4M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
40.0M
                    {
1274
40.0M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
40.0M
                        if (gr < ps->num_hybrid_groups)
1278
19.5M
                        {
1279
                            /* select data from the hybrid subbands */
1280
19.5M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
19.5M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
19.5M
                            if (ps->use34hybrid_bands)
1284
12.8M
                            {
1285
12.8M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
12.8M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
12.8M
                            } else {
1288
6.65M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
6.65M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
6.65M
                            }
1291
20.5M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
20.5M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
20.5M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
20.5M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
20.5M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
20.5M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
40.0M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
40.0M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
40.0M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
40.0M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
40.0M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
40.0M
                        if (gr < ps->num_hybrid_groups)
1314
19.5M
                        {
1315
19.5M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
19.5M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
20.5M
                        } else {
1318
20.5M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
20.5M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
20.5M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
40.0M
                        RE(R0) = RE(tmp);
1324
40.0M
                        IM(R0) = IM(tmp);
1325
40.0M
                    }
1326
13.3M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
27.9M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
27.9M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
27.9M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
27.9M
                if (gr < ps->num_hybrid_groups)
1336
6.51M
                {
1337
                    /* hybrid */
1338
6.51M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
6.51M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
21.4M
                } else {
1341
                    /* QMF */
1342
21.4M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
21.4M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
21.4M
                }
1345
1346
                /* Update delay buffer index */
1347
27.9M
                if (++temp_delay >= 2)
1348
13.9M
                {
1349
13.9M
                    temp_delay = 0;
1350
13.9M
                }
1351
1352
                /* update delay indices */
1353
27.9M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
14.5M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
14.5M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
10.5M
                    {
1358
10.5M
                        ps->delay_buf_index_delay[sb] = 0;
1359
10.5M
                    }
1360
14.5M
                }
1361
1362
111M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
83.8M
                {
1364
83.8M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
21.4M
                    {
1366
21.4M
                        temp_delay_ser[m] = 0;
1367
21.4M
                    }
1368
83.8M
                }
1369
27.9M
            }
1370
896k
        }
1371
373k
    }
1372
1373
    /* update delay indices */
1374
11.3k
    ps->saved_delay = temp_delay;
1375
45.5k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
34.1k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
11.3k
}
1378
1379
#if 0
1380
#ifdef FIXED_POINT
1381
#define step(shift) \
1382
    if ((0x40000000l >> shift) + root <= value)       \
1383
    {                                                 \
1384
        value -= (0x40000000l >> shift) + root;       \
1385
        root = (root >> 1) | (0x40000000l >> shift);  \
1386
    } else {                                          \
1387
        root = root >> 1;                             \
1388
    }
1389
1390
/* fixed point square root approximation */
1391
static real_t ps_sqrt(real_t value)
1392
{
1393
    real_t root = 0;
1394
1395
    step( 0); step( 2); step( 4); step( 6);
1396
    step( 8); step(10); step(12); step(14);
1397
    step(16); step(18); step(20); step(22);
1398
    step(24); step(26); step(28); step(30);
1399
1400
    if (root < value)
1401
        ++root;
1402
1403
    root <<= (REAL_BITS/2);
1404
1405
    return root;
1406
}
1407
#else
1408
#define ps_sqrt(A) sqrt(A)
1409
#endif
1410
#endif
1411
1412
static const real_t ipdopd_cos_tab[] = {
1413
    FRAC_CONST(1.000000000000000),
1414
    FRAC_CONST(0.707106781186548),
1415
    FRAC_CONST(0.000000000000000),
1416
    FRAC_CONST(-0.707106781186547),
1417
    FRAC_CONST(-1.000000000000000),
1418
    FRAC_CONST(-0.707106781186548),
1419
    FRAC_CONST(-0.000000000000000),
1420
    FRAC_CONST(0.707106781186547),
1421
    FRAC_CONST(1.000000000000000)
1422
};
1423
1424
static const real_t ipdopd_sin_tab[] = {
1425
    FRAC_CONST(0.000000000000000),
1426
    FRAC_CONST(0.707106781186547),
1427
    FRAC_CONST(1.000000000000000),
1428
    FRAC_CONST(0.707106781186548),
1429
    FRAC_CONST(0.000000000000000),
1430
    FRAC_CONST(-0.707106781186547),
1431
    FRAC_CONST(-1.000000000000000),
1432
    FRAC_CONST(-0.707106781186548),
1433
    FRAC_CONST(-0.000000000000000)
1434
};
1435
1436
static real_t magnitude_c(complex_t c)
1437
435k
{
1438
#ifdef FIXED_POINT
1439
464k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
#define ALPHA FRAC_CONST(0.948059448969)
1441
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
232k
    real_t abs_inphase = ps_abs(RE(c));
1444
232k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
232k
    if (abs_inphase > abs_quadrature) {
1447
195k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
195k
    } else {
1449
36.5k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
36.5k
    }
1451
#else
1452
203k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
435k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
232k
{
1438
232k
#ifdef FIXED_POINT
1439
232k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
232k
#define ALPHA FRAC_CONST(0.948059448969)
1441
232k
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
232k
    real_t abs_inphase = ps_abs(RE(c));
1444
232k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
232k
    if (abs_inphase > abs_quadrature) {
1447
195k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
195k
    } else {
1449
36.5k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
36.5k
    }
1451
#else
1452
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
232k
}
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
20.2k
{
1459
20.2k
    uint8_t n;
1460
20.2k
    uint8_t gr;
1461
20.2k
    uint8_t bk = 0;
1462
20.2k
    uint8_t sb, maxsb;
1463
20.2k
    uint8_t env;
1464
20.2k
    uint8_t nr_ipdopd_par;
1465
20.2k
    complex_t h11, h12, h21, h22;  // COEF
1466
20.2k
    complex_t H11, H12, H21, H22;  // COEF
1467
20.2k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
20.2k
    complex_t tempLeft, tempRight; // FRAC
1469
20.2k
    complex_t phaseLeft, phaseRight; // FRAC
1470
20.2k
    real_t L;
1471
20.2k
    const real_t *sf_iid;
1472
20.2k
    uint8_t no_iid_steps;
1473
1474
20.2k
    if (ps->iid_mode >= 3)
1475
7.90k
    {
1476
7.90k
        no_iid_steps = 15;
1477
7.90k
        sf_iid = sf_iid_fine;
1478
12.3k
    } else {
1479
12.3k
        no_iid_steps = 7;
1480
12.3k
        sf_iid = sf_iid_normal;
1481
12.3k
    }
1482
1483
20.2k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
12.4k
    {
1485
12.4k
        nr_ipdopd_par = 11; /* resolution */
1486
12.4k
    } else {
1487
7.78k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
7.78k
    }
1489
1490
667k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
647k
    {
1492
647k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
647k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
2.13M
        for (env = 0; env < ps->num_env; env++)
1498
1.48M
        {
1499
1.48M
            uint8_t abs_iid = (uint8_t)abs(ps->iid_index[env][bk]);
1500
            /* index range is supposed to be -7...7 or -15...15 depending on iid_mode
1501
                (Table 8.24, ISO/IEC 14496-3:2005).
1502
                if it is outside these boundaries, this is most likely an error. sanitize
1503
                it and try to process further. */
1504
1.48M
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
341
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
341
                    -no_iid_steps);
1507
341
                ps->iid_index[env][bk] = -no_iid_steps;
1508
341
                abs_iid = no_iid_steps;
1509
1.48M
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
231
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
231
                    no_iid_steps);
1512
231
                ps->iid_index[env][bk] = no_iid_steps;
1513
231
                abs_iid = no_iid_steps;
1514
231
            }
1515
1.48M
            if (ps->icc_index[env][bk] < 0) {
1516
440
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
440
                ps->icc_index[env][bk] = 0;
1518
1.48M
            } else if (ps->icc_index[env][bk] > 7) {
1519
0
                fprintf(stderr, "Warning: invalid icc_index: %d > 7\n", ps->icc_index[env][bk]);
1520
0
                ps->icc_index[env][bk] = 7;
1521
0
            }
1522
1523
1.48M
            if (ps->icc_mode < 3)
1524
857k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
857k
                real_t c_1, c_2;  // COEF
1527
857k
                real_t cosa, sina;  // COEF
1528
857k
                real_t cosb, sinb;  // COEF
1529
857k
                real_t ab1, ab2;  // COEF
1530
857k
                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
857k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
857k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
857k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
857k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
857k
                if (ps->iid_mode >= 3)
1550
285k
                {
1551
285k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
285k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
571k
                } else {
1554
571k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
571k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
571k
                }
1557
1558
857k
                ab1 = MUL_C(cosb, cosa);
1559
857k
                ab2 = MUL_C(sinb, sina);
1560
857k
                ab3 = MUL_C(sinb, cosa);
1561
857k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
857k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
857k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
857k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
857k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
857k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
632k
                real_t sina, cosa;  // COEF
1571
632k
                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
632k
                if (ps->iid_mode >= 3)
1607
377k
                {
1608
377k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
377k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
377k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
377k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
377k
                } else {
1613
254k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
254k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
254k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
254k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
254k
                }
1618
1619
632k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
632k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
632k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
632k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
632k
            }
1624
1.48M
            IM(h11) = IM(h12) = IM(h21) = IM(h22) = 0;
1625
1626
            /* calculate phase rotation parameters H_xy */
1627
            /* note that the imaginary part of these parameters are only calculated when
1628
               IPD and OPD are enabled
1629
             */
1630
1.48M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
217k
            {
1632
217k
                int8_t i;
1633
217k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
217k
                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
116k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
116k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
116k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
116k
                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
217k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
217k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
217k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
217k
                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
116k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
116k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
116k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
116k
                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
217k
                if (i == 0)
1675
110k
                {
1676
110k
                    i = 2;
1677
110k
                }
1678
217k
                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
116k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
116k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
116k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
116k
                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
217k
                xy = magnitude_c(tempRight);
1716
217k
                pq = magnitude_c(tempLeft);
1717
1718
217k
                if (xy != 0)
1719
217k
                {
1720
217k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
217k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
217k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
217k
                xypq = MUL_F(xy, pq);
1728
1729
217k
                if (xypq != 0)
1730
217k
                {
1731
217k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
217k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
217k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
217k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
217k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
217k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
217k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
217k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
217k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
217k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
217k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
217k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
217k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
217k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
217k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
1.48M
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
1.48M
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
1.48M
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
1.48M
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
1.48M
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
1.48M
            RE(H11) = RE(ps->h11_prev[gr]);
1766
1.48M
            RE(H12) = RE(ps->h12_prev[gr]);
1767
1.48M
            RE(H21) = RE(ps->h21_prev[gr]);
1768
1.48M
            RE(H22) = RE(ps->h22_prev[gr]);
1769
1.48M
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
1.48M
            RE(ps->h11_prev[gr]) = RE(h11);
1772
1.48M
            RE(ps->h12_prev[gr]) = RE(h12);
1773
1.48M
            RE(ps->h21_prev[gr]) = RE(h21);
1774
1.48M
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
1.48M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
217k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
217k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
217k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
217k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
217k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
217k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
217k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
217k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
217k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
217k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
30.4k
                {
1792
30.4k
                    IM(deltaH11) = -IM(deltaH11);
1793
30.4k
                    IM(deltaH12) = -IM(deltaH12);
1794
30.4k
                    IM(deltaH21) = -IM(deltaH21);
1795
30.4k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
30.4k
                    IM(H11) = -IM(H11);
1798
30.4k
                    IM(H12) = -IM(H12);
1799
30.4k
                    IM(H21) = -IM(H21);
1800
30.4k
                    IM(H22) = -IM(H22);
1801
30.4k
                }
1802
1803
217k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
217k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
217k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
217k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
217k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
21.6M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
20.1M
            {
1812
                /* addition finalises the interpolation over every n */
1813
20.1M
                RE(H11) += RE(deltaH11);
1814
20.1M
                RE(H12) += RE(deltaH12);
1815
20.1M
                RE(H21) += RE(deltaH21);
1816
20.1M
                RE(H22) += RE(deltaH22);
1817
20.1M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
2.48M
                {
1819
2.48M
                    IM(H11) += IM(deltaH11);
1820
2.48M
                    IM(H12) += IM(deltaH12);
1821
2.48M
                    IM(H21) += IM(deltaH21);
1822
2.48M
                    IM(H22) += IM(deltaH22);
1823
2.48M
                }
1824
1825
                /* channel is an alias to the subband */
1826
69.4M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
49.3M
                {
1828
49.3M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
49.3M
                    if (gr < ps->num_hybrid_groups)
1832
11.2M
                    {
1833
11.2M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
11.2M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
11.2M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
11.2M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
38.1M
                    } else {
1838
38.1M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
38.1M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
38.1M
                        RE(inRight) = RE(X_right[n][sb]);
1841
38.1M
                        IM(inRight) = IM(X_right[n][sb]);
1842
38.1M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
49.3M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
49.3M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
49.3M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
49.3M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
49.3M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
2.49M
                    {
1855
                        /* apply rotation */
1856
2.49M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
2.49M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
2.49M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
2.49M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
2.49M
                    }
1861
1862
                    /* store final samples */
1863
49.3M
                    if (gr < ps->num_hybrid_groups)
1864
11.2M
                    {
1865
11.2M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
11.2M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
11.2M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
11.2M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
38.1M
                    } else {
1870
38.1M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
38.1M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
38.1M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
38.1M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
38.1M
                    }
1875
49.3M
                }
1876
20.1M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
1.48M
            ps->phase_hist++;
1880
1.48M
            if (ps->phase_hist == 2)
1881
744k
            {
1882
744k
                ps->phase_hist = 0;
1883
744k
            }
1884
1.48M
        }
1885
647k
    }
1886
20.2k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
8.81k
{
1459
8.81k
    uint8_t n;
1460
8.81k
    uint8_t gr;
1461
8.81k
    uint8_t bk = 0;
1462
8.81k
    uint8_t sb, maxsb;
1463
8.81k
    uint8_t env;
1464
8.81k
    uint8_t nr_ipdopd_par;
1465
8.81k
    complex_t h11, h12, h21, h22;  // COEF
1466
8.81k
    complex_t H11, H12, H21, H22;  // COEF
1467
8.81k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
8.81k
    complex_t tempLeft, tempRight; // FRAC
1469
8.81k
    complex_t phaseLeft, phaseRight; // FRAC
1470
8.81k
    real_t L;
1471
8.81k
    const real_t *sf_iid;
1472
8.81k
    uint8_t no_iid_steps;
1473
1474
8.81k
    if (ps->iid_mode >= 3)
1475
3.35k
    {
1476
3.35k
        no_iid_steps = 15;
1477
3.35k
        sf_iid = sf_iid_fine;
1478
5.46k
    } else {
1479
5.46k
        no_iid_steps = 7;
1480
5.46k
        sf_iid = sf_iid_normal;
1481
5.46k
    }
1482
1483
8.81k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
5.50k
    {
1485
5.50k
        nr_ipdopd_par = 11; /* resolution */
1486
5.50k
    } else {
1487
3.30k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
3.30k
    }
1489
1490
282k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
274k
    {
1492
274k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
274k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
952k
        for (env = 0; env < ps->num_env; env++)
1498
678k
        {
1499
678k
            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
678k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
96
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
96
                    -no_iid_steps);
1507
96
                ps->iid_index[env][bk] = -no_iid_steps;
1508
96
                abs_iid = no_iid_steps;
1509
678k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
57
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
57
                    no_iid_steps);
1512
57
                ps->iid_index[env][bk] = no_iid_steps;
1513
57
                abs_iid = no_iid_steps;
1514
57
            }
1515
678k
            if (ps->icc_index[env][bk] < 0) {
1516
103
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
103
                ps->icc_index[env][bk] = 0;
1518
678k
            } 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
678k
            if (ps->icc_mode < 3)
1524
325k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
325k
                real_t c_1, c_2;  // COEF
1527
325k
                real_t cosa, sina;  // COEF
1528
325k
                real_t cosb, sinb;  // COEF
1529
325k
                real_t ab1, ab2;  // COEF
1530
325k
                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
325k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
325k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
325k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
325k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
325k
                if (ps->iid_mode >= 3)
1550
57.8k
                {
1551
57.8k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
57.8k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
267k
                } else {
1554
267k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
267k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
267k
                }
1557
1558
325k
                ab1 = MUL_C(cosb, cosa);
1559
325k
                ab2 = MUL_C(sinb, sina);
1560
325k
                ab3 = MUL_C(sinb, cosa);
1561
325k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
325k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
325k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
325k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
325k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
353k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
353k
                real_t sina, cosa;  // COEF
1571
353k
                real_t cosg, sing;  // COEF
1572
1573
                /*
1574
                real_t c, rho, mu, alpha, gamma;
1575
                uint8_t i;
1576
1577
                i = ps->iid_index[env][bk];
1578
                c = (real_t)pow(10.0, ((i)?(((i>0)?1:-1)*quant_iid[((i>0)?i:-i)-1]):0.)/20.0);
1579
                rho = quant_rho[ps->icc_index[env][bk]];
1580
1581
                if (rho == 0.0f && c == 1.)
1582
                {
1583
                    alpha = (real_t)M_PI/4.0f;
1584
                    rho = 0.05f;
1585
                } else {
1586
                    if (rho <= 0.05f)
1587
                    {
1588
                        rho = 0.05f;
1589
                    }
1590
                    alpha = 0.5f*(real_t)atan( (2.0f*c*rho) / (c*c-1.0f) );
1591
1592
                    if (alpha < 0.)
1593
                    {
1594
                        alpha += (real_t)M_PI/2.0f;
1595
                    }
1596
                    if (rho < 0.)
1597
                    {
1598
                        alpha += (real_t)M_PI;
1599
                    }
1600
                }
1601
                mu = c+1.0f/c;
1602
                mu = 1+(4.0f*rho*rho-4.0f)/(mu*mu);
1603
                gamma = (real_t)atan(sqrt((1.0f-sqrt(mu))/(1.0f+sqrt(mu))));
1604
                */
1605
1606
353k
                if (ps->iid_mode >= 3)
1607
229k
                {
1608
229k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
229k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
229k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
229k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
229k
                } else {
1613
123k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
123k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
123k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
123k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
123k
                }
1618
1619
353k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
353k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
353k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
353k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
353k
            }
1624
678k
            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
678k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
116k
            {
1632
116k
                int8_t i;
1633
116k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
116k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
116k
#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
116k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
116k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
116k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
116k
                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
116k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
116k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
116k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
116k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
116k
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
116k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
116k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
116k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
116k
                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
116k
                if (i == 0)
1675
58.6k
                {
1676
58.6k
                    i = 2;
1677
58.6k
                }
1678
116k
                i--;
1679
1680
                /* get value before previous */
1681
116k
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
116k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
116k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
116k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
116k
                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
116k
                xy = magnitude_c(tempRight);
1716
116k
                pq = magnitude_c(tempLeft);
1717
1718
116k
                if (xy != 0)
1719
116k
                {
1720
116k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
116k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
116k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
116k
                xypq = MUL_F(xy, pq);
1728
1729
116k
                if (xypq != 0)
1730
116k
                {
1731
116k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
116k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
116k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
116k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
116k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
116k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
116k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
116k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
116k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
116k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
116k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
116k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
116k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
116k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
116k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
678k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
678k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
678k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
678k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
678k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
678k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
678k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
678k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
678k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
678k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
678k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
678k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
678k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
678k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
678k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
116k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
116k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
116k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
116k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
116k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
116k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
116k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
116k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
116k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
116k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
17.0k
                {
1792
17.0k
                    IM(deltaH11) = -IM(deltaH11);
1793
17.0k
                    IM(deltaH12) = -IM(deltaH12);
1794
17.0k
                    IM(deltaH21) = -IM(deltaH21);
1795
17.0k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
17.0k
                    IM(H11) = -IM(H11);
1798
17.0k
                    IM(H12) = -IM(H12);
1799
17.0k
                    IM(H21) = -IM(H21);
1800
17.0k
                    IM(H22) = -IM(H22);
1801
17.0k
                }
1802
1803
116k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
116k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
116k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
116k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
116k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
9.23M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
8.55M
            {
1812
                /* addition finalises the interpolation over every n */
1813
8.55M
                RE(H11) += RE(deltaH11);
1814
8.55M
                RE(H12) += RE(deltaH12);
1815
8.55M
                RE(H21) += RE(deltaH21);
1816
8.55M
                RE(H22) += RE(deltaH22);
1817
8.55M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
1.17M
                {
1819
1.17M
                    IM(H11) += IM(deltaH11);
1820
1.17M
                    IM(H12) += IM(deltaH12);
1821
1.17M
                    IM(H21) += IM(deltaH21);
1822
1.17M
                    IM(H22) += IM(deltaH22);
1823
1.17M
                }
1824
1825
                /* channel is an alias to the subband */
1826
29.9M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
21.3M
                {
1828
21.3M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
21.3M
                    if (gr < ps->num_hybrid_groups)
1832
4.70M
                    {
1833
4.70M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
4.70M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
4.70M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
4.70M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
16.6M
                    } else {
1838
16.6M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
16.6M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
16.6M
                        RE(inRight) = RE(X_right[n][sb]);
1841
16.6M
                        IM(inRight) = IM(X_right[n][sb]);
1842
16.6M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
21.3M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
21.3M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
21.3M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
21.3M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
21.3M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.18M
                    {
1855
                        /* apply rotation */
1856
1.18M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.18M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.18M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.18M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.18M
                    }
1861
1862
                    /* store final samples */
1863
21.3M
                    if (gr < ps->num_hybrid_groups)
1864
4.70M
                    {
1865
4.70M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
4.70M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
4.70M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
4.70M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
16.6M
                    } else {
1870
16.6M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
16.6M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
16.6M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
16.6M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
16.6M
                    }
1875
21.3M
                }
1876
8.55M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
678k
            ps->phase_hist++;
1880
678k
            if (ps->phase_hist == 2)
1881
339k
            {
1882
339k
                ps->phase_hist = 0;
1883
339k
            }
1884
678k
        }
1885
274k
    }
1886
8.81k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
11.3k
{
1459
11.3k
    uint8_t n;
1460
11.3k
    uint8_t gr;
1461
11.3k
    uint8_t bk = 0;
1462
11.3k
    uint8_t sb, maxsb;
1463
11.3k
    uint8_t env;
1464
11.3k
    uint8_t nr_ipdopd_par;
1465
11.3k
    complex_t h11, h12, h21, h22;  // COEF
1466
11.3k
    complex_t H11, H12, H21, H22;  // COEF
1467
11.3k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
11.3k
    complex_t tempLeft, tempRight; // FRAC
1469
11.3k
    complex_t phaseLeft, phaseRight; // FRAC
1470
11.3k
    real_t L;
1471
11.3k
    const real_t *sf_iid;
1472
11.3k
    uint8_t no_iid_steps;
1473
1474
11.3k
    if (ps->iid_mode >= 3)
1475
4.55k
    {
1476
4.55k
        no_iid_steps = 15;
1477
4.55k
        sf_iid = sf_iid_fine;
1478
6.84k
    } else {
1479
6.84k
        no_iid_steps = 7;
1480
6.84k
        sf_iid = sf_iid_normal;
1481
6.84k
    }
1482
1483
11.3k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
6.92k
    {
1485
6.92k
        nr_ipdopd_par = 11; /* resolution */
1486
6.92k
    } else {
1487
4.47k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
4.47k
    }
1489
1490
384k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
373k
    {
1492
373k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
373k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.18M
        for (env = 0; env < ps->num_env; env++)
1498
810k
        {
1499
810k
            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
810k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
245
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
245
                    -no_iid_steps);
1507
245
                ps->iid_index[env][bk] = -no_iid_steps;
1508
245
                abs_iid = no_iid_steps;
1509
810k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
174
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
174
                    no_iid_steps);
1512
174
                ps->iid_index[env][bk] = no_iid_steps;
1513
174
                abs_iid = no_iid_steps;
1514
174
            }
1515
810k
            if (ps->icc_index[env][bk] < 0) {
1516
337
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
337
                ps->icc_index[env][bk] = 0;
1518
810k
            } 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
810k
            if (ps->icc_mode < 3)
1524
531k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
531k
                real_t c_1, c_2;  // COEF
1527
531k
                real_t cosa, sina;  // COEF
1528
531k
                real_t cosb, sinb;  // COEF
1529
531k
                real_t ab1, ab2;  // COEF
1530
531k
                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
531k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
531k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
531k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
531k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
531k
                if (ps->iid_mode >= 3)
1550
227k
                {
1551
227k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
227k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
304k
                } else {
1554
304k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
304k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
304k
                }
1557
1558
531k
                ab1 = MUL_C(cosb, cosa);
1559
531k
                ab2 = MUL_C(sinb, sina);
1560
531k
                ab3 = MUL_C(sinb, cosa);
1561
531k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
531k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
531k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
531k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
531k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
531k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
279k
                real_t sina, cosa;  // COEF
1571
279k
                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
279k
                if (ps->iid_mode >= 3)
1607
148k
                {
1608
148k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
148k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
148k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
148k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
148k
                } else {
1613
130k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
130k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
130k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
130k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
130k
                }
1618
1619
279k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
279k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
279k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
279k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
279k
            }
1624
810k
            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
810k
            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.4k
                {
1676
51.4k
                    i = 2;
1677
51.4k
                }
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
810k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
810k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
810k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
810k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
810k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
810k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
810k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
810k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
810k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
810k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
810k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
810k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
810k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
810k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
810k
            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.4k
                {
1792
13.4k
                    IM(deltaH11) = -IM(deltaH11);
1793
13.4k
                    IM(deltaH12) = -IM(deltaH12);
1794
13.4k
                    IM(deltaH21) = -IM(deltaH21);
1795
13.4k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
13.4k
                    IM(H11) = -IM(H11);
1798
13.4k
                    IM(H12) = -IM(H12);
1799
13.4k
                    IM(H21) = -IM(H21);
1800
13.4k
                    IM(H22) = -IM(H22);
1801
13.4k
                }
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
12.3M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
11.5M
            {
1812
                /* addition finalises the interpolation over every n */
1813
11.5M
                RE(H11) += RE(deltaH11);
1814
11.5M
                RE(H12) += RE(deltaH12);
1815
11.5M
                RE(H21) += RE(deltaH21);
1816
11.5M
                RE(H22) += RE(deltaH22);
1817
11.5M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
1.30M
                {
1819
1.30M
                    IM(H11) += IM(deltaH11);
1820
1.30M
                    IM(H12) += IM(deltaH12);
1821
1.30M
                    IM(H21) += IM(deltaH21);
1822
1.30M
                    IM(H22) += IM(deltaH22);
1823
1.30M
                }
1824
1825
                /* channel is an alias to the subband */
1826
39.5M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
27.9M
                {
1828
27.9M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
27.9M
                    if (gr < ps->num_hybrid_groups)
1832
6.51M
                    {
1833
6.51M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
6.51M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
6.51M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
6.51M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
21.4M
                    } else {
1838
21.4M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
21.4M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
21.4M
                        RE(inRight) = RE(X_right[n][sb]);
1841
21.4M
                        IM(inRight) = IM(X_right[n][sb]);
1842
21.4M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
27.9M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
27.9M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
27.9M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
27.9M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
27.9M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.30M
                    {
1855
                        /* apply rotation */
1856
1.30M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.30M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.30M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.30M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.30M
                    }
1861
1862
                    /* store final samples */
1863
27.9M
                    if (gr < ps->num_hybrid_groups)
1864
6.51M
                    {
1865
6.51M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
6.51M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
6.51M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
6.51M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
21.4M
                    } else {
1870
21.4M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
21.4M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
21.4M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
21.4M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
21.4M
                    }
1875
27.9M
                }
1876
11.5M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
810k
            ps->phase_hist++;
1880
810k
            if (ps->phase_hist == 2)
1881
405k
            {
1882
405k
                ps->phase_hist = 0;
1883
405k
            }
1884
810k
        }
1885
373k
    }
1886
11.3k
}
1887
1888
void ps_free(ps_info *ps)
1889
29.3k
{
1890
    /* free hybrid filterbank structures */
1891
29.3k
    hybrid_free(ps->hyb);
1892
1893
29.3k
    faad_free(ps);
1894
29.3k
}
1895
1896
ps_info *ps_init(uint8_t sr_index, uint8_t numTimeSlotsRate)
1897
29.3k
{
1898
29.3k
    uint8_t i;
1899
29.3k
    uint8_t short_delay_band;
1900
1901
29.3k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
29.3k
    memset(ps, 0, sizeof(ps_info));
1903
1904
29.3k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
29.3k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
29.3k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
29.3k
    ps->saved_delay = 0;
1911
1912
1.91M
    for (i = 0; i < 64; i++)
1913
1.88M
    {
1914
1.88M
        ps->delay_buf_index_delay[i] = 0;
1915
1.88M
    }
1916
1917
117k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
88.1k
    {
1919
88.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
88.1k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
88.1k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
88.1k
#endif
1932
88.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
29.3k
    short_delay_band = 35;
1950
29.3k
    ps->nr_allpass_bands = 22;
1951
29.3k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
29.3k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
29.3k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
1.05M
    for (i = 0; i < short_delay_band; i++)
1957
1.02M
    {
1958
1.02M
        ps->delay_D[i] = 14;
1959
1.02M
    }
1960
881k
    for (i = short_delay_band; i < 64; i++)
1961
852k
    {
1962
852k
        ps->delay_D[i] = 1;
1963
852k
    }
1964
1965
    /* mixing and phase */
1966
1.49M
    for (i = 0; i < 50; i++)
1967
1.46M
    {
1968
1.46M
        RE(ps->h11_prev[i]) = 1;
1969
1.46M
        IM(ps->h11_prev[i]) = 1;
1970
1.46M
        RE(ps->h12_prev[i]) = 1;
1971
1.46M
        IM(ps->h12_prev[i]) = 1;
1972
1.46M
    }
1973
1974
29.3k
    ps->phase_hist = 0;
1975
1976
617k
    for (i = 0; i < 20; i++)
1977
587k
    {
1978
587k
        RE(ps->ipd_prev[i][0]) = 0;
1979
587k
        IM(ps->ipd_prev[i][0]) = 0;
1980
587k
        RE(ps->ipd_prev[i][1]) = 0;
1981
587k
        IM(ps->ipd_prev[i][1]) = 0;
1982
587k
        RE(ps->opd_prev[i][0]) = 0;
1983
587k
        IM(ps->opd_prev[i][0]) = 0;
1984
587k
        RE(ps->opd_prev[i][1]) = 0;
1985
587k
        IM(ps->opd_prev[i][1]) = 0;
1986
587k
    }
1987
1988
29.3k
    return ps;
1989
29.3k
}
ps_init
Line
Count
Source
1897
13.2k
{
1898
13.2k
    uint8_t i;
1899
13.2k
    uint8_t short_delay_band;
1900
1901
13.2k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
13.2k
    memset(ps, 0, sizeof(ps_info));
1903
1904
13.2k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
13.2k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
13.2k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
13.2k
    ps->saved_delay = 0;
1911
1912
863k
    for (i = 0; i < 64; i++)
1913
850k
    {
1914
850k
        ps->delay_buf_index_delay[i] = 0;
1915
850k
    }
1916
1917
53.1k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
39.8k
    {
1919
39.8k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
39.8k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
39.8k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
39.8k
#endif
1932
39.8k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
13.2k
    short_delay_band = 35;
1950
13.2k
    ps->nr_allpass_bands = 22;
1951
13.2k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
13.2k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
13.2k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
478k
    for (i = 0; i < short_delay_band; i++)
1957
464k
    {
1958
464k
        ps->delay_D[i] = 14;
1959
464k
    }
1960
398k
    for (i = short_delay_band; i < 64; i++)
1961
385k
    {
1962
385k
        ps->delay_D[i] = 1;
1963
385k
    }
1964
1965
    /* mixing and phase */
1966
677k
    for (i = 0; i < 50; i++)
1967
664k
    {
1968
664k
        RE(ps->h11_prev[i]) = 1;
1969
664k
        IM(ps->h11_prev[i]) = 1;
1970
664k
        RE(ps->h12_prev[i]) = 1;
1971
664k
        IM(ps->h12_prev[i]) = 1;
1972
664k
    }
1973
1974
13.2k
    ps->phase_hist = 0;
1975
1976
278k
    for (i = 0; i < 20; i++)
1977
265k
    {
1978
265k
        RE(ps->ipd_prev[i][0]) = 0;
1979
265k
        IM(ps->ipd_prev[i][0]) = 0;
1980
265k
        RE(ps->ipd_prev[i][1]) = 0;
1981
265k
        IM(ps->ipd_prev[i][1]) = 0;
1982
265k
        RE(ps->opd_prev[i][0]) = 0;
1983
265k
        IM(ps->opd_prev[i][0]) = 0;
1984
265k
        RE(ps->opd_prev[i][1]) = 0;
1985
265k
        IM(ps->opd_prev[i][1]) = 0;
1986
265k
    }
1987
1988
13.2k
    return ps;
1989
13.2k
}
ps_init
Line
Count
Source
1897
16.1k
{
1898
16.1k
    uint8_t i;
1899
16.1k
    uint8_t short_delay_band;
1900
1901
16.1k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
16.1k
    memset(ps, 0, sizeof(ps_info));
1903
1904
16.1k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
16.1k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
16.1k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
16.1k
    ps->saved_delay = 0;
1911
1912
1.04M
    for (i = 0; i < 64; i++)
1913
1.03M
    {
1914
1.03M
        ps->delay_buf_index_delay[i] = 0;
1915
1.03M
    }
1916
1917
64.4k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
48.3k
    {
1919
48.3k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
48.3k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
48.3k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
48.3k
#endif
1932
48.3k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
16.1k
    short_delay_band = 35;
1950
16.1k
    ps->nr_allpass_bands = 22;
1951
16.1k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
16.1k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
16.1k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
579k
    for (i = 0; i < short_delay_band; i++)
1957
563k
    {
1958
563k
        ps->delay_D[i] = 14;
1959
563k
    }
1960
483k
    for (i = short_delay_band; i < 64; i++)
1961
467k
    {
1962
467k
        ps->delay_D[i] = 1;
1963
467k
    }
1964
1965
    /* mixing and phase */
1966
821k
    for (i = 0; i < 50; i++)
1967
805k
    {
1968
805k
        RE(ps->h11_prev[i]) = 1;
1969
805k
        IM(ps->h11_prev[i]) = 1;
1970
805k
        RE(ps->h12_prev[i]) = 1;
1971
805k
        IM(ps->h12_prev[i]) = 1;
1972
805k
    }
1973
1974
16.1k
    ps->phase_hist = 0;
1975
1976
338k
    for (i = 0; i < 20; i++)
1977
322k
    {
1978
322k
        RE(ps->ipd_prev[i][0]) = 0;
1979
322k
        IM(ps->ipd_prev[i][0]) = 0;
1980
322k
        RE(ps->ipd_prev[i][1]) = 0;
1981
322k
        IM(ps->ipd_prev[i][1]) = 0;
1982
322k
        RE(ps->opd_prev[i][0]) = 0;
1983
322k
        IM(ps->opd_prev[i][0]) = 0;
1984
322k
        RE(ps->opd_prev[i][1]) = 0;
1985
322k
        IM(ps->opd_prev[i][1]) = 0;
1986
322k
    }
1987
1988
16.1k
    return ps;
1989
16.1k
}
1990
1991
/* main Parametric Stereo decoding function */
1992
uint8_t ps_decode(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64])
1993
20.2k
{
1994
20.2k
    qmf_t X_hybrid_left[32][32] = {{{0}}};
1995
20.2k
    qmf_t X_hybrid_right[32][32] = {{{0}}};
1996
1997
    /* delta decoding of the bitstream data */
1998
20.2k
    ps_data_decode(ps);
1999
2000
    /* set up some parameters depending on filterbank type */
2001
20.2k
    if (ps->use34hybrid_bands)
2002
7.23k
    {
2003
7.23k
        ps->group_border = (uint8_t*)group_border34;
2004
7.23k
        ps->map_group2bk = (uint16_t*)map_group2bk34;
2005
7.23k
        ps->num_groups = 32+18;
2006
7.23k
        ps->num_hybrid_groups = 32;
2007
7.23k
        ps->nr_par_bands = 34;
2008
7.23k
        ps->decay_cutoff = 5;
2009
12.9k
    } else {
2010
12.9k
        ps->group_border = (uint8_t*)group_border20;
2011
12.9k
        ps->map_group2bk = (uint16_t*)map_group2bk20;
2012
12.9k
        ps->num_groups = 10+12;
2013
12.9k
        ps->num_hybrid_groups = 10;
2014
12.9k
        ps->nr_par_bands = 20;
2015
12.9k
        ps->decay_cutoff = 3;
2016
12.9k
    }
2017
2018
    /* Perform further analysis on the lowest subbands to get a higher
2019
     * frequency resolution
2020
     */
2021
20.2k
    hybrid_analysis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2022
20.2k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2023
2024
    /* decorrelate mono signal */
2025
20.2k
    ps_decorrelate(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2026
2027
    /* apply mixing and phase parameters */
2028
20.2k
    ps_mix_phase(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2029
2030
    /* hybrid synthesis, to rebuild the SBR QMF matrices */
2031
20.2k
    hybrid_synthesis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2032
20.2k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2033
2034
20.2k
    hybrid_synthesis((hyb_info*)ps->hyb, X_right, X_hybrid_right,
2035
20.2k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2036
2037
20.2k
    return 0;
2038
20.2k
}
2039
2040
#endif