Coverage Report

Created: 2026-03-20 06:59

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