Coverage Report

Created: 2025-10-10 06:50

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/proc/self/cwd/libfaad/ps_dec.c
Line
Count
Source
1
/*
2
** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
3
** Copyright (C) 2003-2005 M. Bakker, Nero AG, http://www.nero.com
4
**
5
** This program is free software; you can redistribute it and/or modify
6
** it under the terms of the GNU General Public License as published by
7
** the Free Software Foundation; either version 2 of the License, or
8
** (at your option) any later version.
9
**
10
** This program is distributed in the hope that it will be useful,
11
** but WITHOUT ANY WARRANTY; without even the implied warranty of
12
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
** GNU General Public License for more details.
14
**
15
** You should have received a copy of the GNU General Public License
16
** along with this program; if not, write to the Free Software
17
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18
**
19
** Any non-GPL usage of this software or parts of this software is strictly
20
** forbidden.
21
**
22
** The "appropriate copyright message" mentioned in section 2c of the GPLv2
23
** must read: "Code from FAAD2 is copyright (c) Nero AG, www.nero.com"
24
**
25
** Commercial non-GPL licensing of this software is possible.
26
** For more info contact Nero AG through Mpeg4AAClicense@nero.com.
27
**
28
** $Id: ps_dec.c,v 1.16 2009/01/26 22:32:31 menno Exp $
29
**/
30
31
#include "common.h"
32
33
#ifdef PS_DEC
34
35
#include <stdlib.h>
36
#include <stdio.h>
37
#include "ps_dec.h"
38
#include "ps_tables.h"
39
40
/* constants */
41
50.3M
#define NEGATE_IPD_MASK            (0x1000)
42
378k
#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
990k
    {
227
990k
        hyb->temp[i] = (qmf_t*)faad_malloc(12 /*max*/ * sizeof(qmf_t));
228
990k
    }
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
990k
    {
252
990k
        if (hyb->temp[i])
253
990k
            faad_free(hyb->temp[i]);
254
990k
    }
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
49.5k
{
265
49.5k
    uint8_t i;
266
49.5k
    (void)hyb;  /* TODO: remove parameter? */
267
268
1.60M
    for (i = 0; i < frame_len; i++)
269
1.55M
    {
270
1.55M
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
1.55M
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
1.55M
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
1.55M
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
1.55M
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
1.55M
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
1.55M
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
1.55M
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
1.55M
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
1.55M
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
1.55M
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
1.55M
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
1.55M
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
1.55M
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
1.55M
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
1.55M
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
1.55M
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
1.55M
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
1.55M
    }
293
49.5k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
24.7k
{
265
24.7k
    uint8_t i;
266
24.7k
    (void)hyb;  /* TODO: remove parameter? */
267
268
802k
    for (i = 0; i < frame_len; i++)
269
777k
    {
270
777k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
777k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
777k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
777k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
777k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
777k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
777k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
777k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
777k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
777k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
777k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
777k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
777k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
777k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
777k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
777k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
777k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
777k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
777k
    }
293
24.7k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
24.7k
{
265
24.7k
    uint8_t i;
266
24.7k
    (void)hyb;  /* TODO: remove parameter? */
267
268
802k
    for (i = 0; i < frame_len; i++)
269
777k
    {
270
777k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
777k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
777k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
777k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
777k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
777k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
777k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
777k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
777k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
777k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
777k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
777k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
777k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
777k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
777k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
777k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
777k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
777k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
777k
    }
293
24.7k
}
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.6k
{
299
22.6k
    uint8_t i;
300
22.6k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
22.6k
    (void)hyb;  /* TODO: remove parameter? */
302
303
718k
    for (i = 0; i < frame_len; i++)
304
695k
    {
305
695k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
695k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
695k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
695k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
695k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
695k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
695k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
695k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
695k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
695k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
695k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
695k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
695k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
695k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
695k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
695k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
695k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
695k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
695k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
695k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
695k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
695k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
695k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
695k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
695k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
695k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
695k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
695k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
695k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
695k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
695k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
695k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
695k
    }
349
22.6k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
10.5k
{
299
10.5k
    uint8_t i;
300
10.5k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
10.5k
    (void)hyb;  /* TODO: remove parameter? */
302
303
334k
    for (i = 0; i < frame_len; i++)
304
324k
    {
305
324k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
324k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
324k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
324k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
324k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
324k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
324k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
324k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
324k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
324k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
324k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
324k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
324k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
324k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
324k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
324k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
324k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
324k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
324k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
324k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
324k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
324k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
324k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
324k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
324k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
324k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
324k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
324k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
324k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
324k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
324k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
324k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
324k
    }
349
10.5k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
12.0k
{
299
12.0k
    uint8_t i;
300
12.0k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
12.0k
    (void)hyb;  /* TODO: remove parameter? */
302
303
383k
    for (i = 0; i < frame_len; i++)
304
371k
    {
305
371k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
371k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
371k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
371k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
371k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
371k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
371k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
371k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
371k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
371k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
371k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
371k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
371k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
371k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
371k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
371k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
371k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
371k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
371k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
371k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
371k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
371k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
371k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
371k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
371k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
371k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
371k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
371k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
371k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
371k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
371k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
371k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
371k
    }
349
12.0k
}
350
351
static void INLINE DCT3_4_unscaled(real_t *y, real_t *x)
352
2.48M
{
353
2.48M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
2.48M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
2.48M
    f1 = x[0] - f0;
357
2.48M
    f2 = x[0] + f0;
358
2.48M
    f3 = x[1] + x[3];
359
2.48M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
2.48M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
2.48M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
2.48M
    f7 = f4 + f5;
363
2.48M
    f8 = f6 - f5;
364
2.48M
    y[3] = f2 - f8;
365
2.48M
    y[0] = f2 + f8;
366
2.48M
    y[2] = f1 - f7;
367
2.48M
    y[1] = f1 + f7;
368
2.48M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.11M
{
353
1.11M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.11M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.11M
    f1 = x[0] - f0;
357
1.11M
    f2 = x[0] + f0;
358
1.11M
    f3 = x[1] + x[3];
359
1.11M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.11M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.11M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.11M
    f7 = f4 + f5;
363
1.11M
    f8 = f6 - f5;
364
1.11M
    y[3] = f2 - f8;
365
1.11M
    y[0] = f2 + f8;
366
1.11M
    y[2] = f1 - f7;
367
1.11M
    y[1] = f1 + f7;
368
1.11M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.36M
{
353
1.36M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.36M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.36M
    f1 = x[0] - f0;
357
1.36M
    f2 = x[0] + f0;
358
1.36M
    f3 = x[1] + x[3];
359
1.36M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.36M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.36M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.36M
    f7 = f4 + f5;
363
1.36M
    f8 = f6 - f5;
364
1.36M
    y[3] = f2 - f8;
365
1.36M
    y[0] = f2 + f8;
366
1.36M
    y[2] = f1 - f7;
367
1.36M
    y[1] = f1 + f7;
368
1.36M
}
369
370
/* complex filter, size 8 */
371
static void channel_filter8(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
372
                            qmf_t *buffer, qmf_t **X_hybrid)
373
39.8k
{
374
39.8k
    uint8_t i, n;
375
39.8k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
39.8k
    real_t x[4];
377
39.8k
    (void)hyb;  /* TODO: remove parameter? */
378
379
1.28M
    for (i = 0; i < frame_len; i++)
380
1.24M
    {
381
1.24M
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
1.24M
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
1.24M
        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.24M
        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.24M
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
1.24M
        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.24M
        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.24M
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
6.20M
        for (n = 0; n < 4; n++)
392
4.96M
        {
393
4.96M
            x[n] = input_re1[n] - input_im1[3-n];
394
4.96M
        }
395
1.24M
        DCT3_4_unscaled(x, x);
396
1.24M
        QMF_RE(X_hybrid[i][7]) = x[0];
397
1.24M
        QMF_RE(X_hybrid[i][5]) = x[2];
398
1.24M
        QMF_RE(X_hybrid[i][3]) = x[3];
399
1.24M
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
6.20M
        for (n = 0; n < 4; n++)
402
4.96M
        {
403
4.96M
            x[n] = input_re1[n] + input_im1[3-n];
404
4.96M
        }
405
1.24M
        DCT3_4_unscaled(x, x);
406
1.24M
        QMF_RE(X_hybrid[i][6]) = x[1];
407
1.24M
        QMF_RE(X_hybrid[i][4]) = x[3];
408
1.24M
        QMF_RE(X_hybrid[i][2]) = x[2];
409
1.24M
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
1.24M
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
1.24M
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
1.24M
        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.24M
        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.24M
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
1.24M
        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.24M
        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.24M
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
6.20M
        for (n = 0; n < 4; n++)
422
4.96M
        {
423
4.96M
            x[n] = input_im2[n] + input_re2[3-n];
424
4.96M
        }
425
1.24M
        DCT3_4_unscaled(x, x);
426
1.24M
        QMF_IM(X_hybrid[i][7]) = x[0];
427
1.24M
        QMF_IM(X_hybrid[i][5]) = x[2];
428
1.24M
        QMF_IM(X_hybrid[i][3]) = x[3];
429
1.24M
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
6.20M
        for (n = 0; n < 4; n++)
432
4.96M
        {
433
4.96M
            x[n] = input_im2[n] - input_re2[3-n];
434
4.96M
        }
435
1.24M
        DCT3_4_unscaled(x, x);
436
1.24M
        QMF_IM(X_hybrid[i][6]) = x[1];
437
1.24M
        QMF_IM(X_hybrid[i][4]) = x[3];
438
1.24M
        QMF_IM(X_hybrid[i][2]) = x[2];
439
1.24M
        QMF_IM(X_hybrid[i][0]) = x[0];
440
1.24M
    }
441
39.8k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
19.9k
{
374
19.9k
    uint8_t i, n;
375
19.9k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
19.9k
    real_t x[4];
377
19.9k
    (void)hyb;  /* TODO: remove parameter? */
378
379
640k
    for (i = 0; i < frame_len; i++)
380
620k
    {
381
620k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
620k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
620k
        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
620k
        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
620k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
620k
        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
620k
        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
620k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.10M
        for (n = 0; n < 4; n++)
392
2.48M
        {
393
2.48M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.48M
        }
395
620k
        DCT3_4_unscaled(x, x);
396
620k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
620k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
620k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
620k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.10M
        for (n = 0; n < 4; n++)
402
2.48M
        {
403
2.48M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.48M
        }
405
620k
        DCT3_4_unscaled(x, x);
406
620k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
620k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
620k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
620k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
620k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
620k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
620k
        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
620k
        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
620k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
620k
        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
620k
        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
620k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.10M
        for (n = 0; n < 4; n++)
422
2.48M
        {
423
2.48M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.48M
        }
425
620k
        DCT3_4_unscaled(x, x);
426
620k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
620k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
620k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
620k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.10M
        for (n = 0; n < 4; n++)
432
2.48M
        {
433
2.48M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.48M
        }
435
620k
        DCT3_4_unscaled(x, x);
436
620k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
620k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
620k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
620k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
620k
    }
441
19.9k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
19.9k
{
374
19.9k
    uint8_t i, n;
375
19.9k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
19.9k
    real_t x[4];
377
19.9k
    (void)hyb;  /* TODO: remove parameter? */
378
379
640k
    for (i = 0; i < frame_len; i++)
380
620k
    {
381
620k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
620k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
620k
        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
620k
        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
620k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
620k
        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
620k
        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
620k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.10M
        for (n = 0; n < 4; n++)
392
2.48M
        {
393
2.48M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.48M
        }
395
620k
        DCT3_4_unscaled(x, x);
396
620k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
620k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
620k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
620k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.10M
        for (n = 0; n < 4; n++)
402
2.48M
        {
403
2.48M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.48M
        }
405
620k
        DCT3_4_unscaled(x, x);
406
620k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
620k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
620k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
620k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
620k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
620k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
620k
        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
620k
        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
620k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
620k
        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
620k
        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
620k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.10M
        for (n = 0; n < 4; n++)
422
2.48M
        {
423
2.48M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.48M
        }
425
620k
        DCT3_4_unscaled(x, x);
426
620k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
620k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
620k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
620k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.10M
        for (n = 0; n < 4; n++)
432
2.48M
        {
433
2.48M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.48M
        }
435
620k
        DCT3_4_unscaled(x, x);
436
620k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
620k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
620k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
620k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
620k
    }
441
19.9k
}
442
443
static void INLINE DCT3_6_unscaled(real_t *y, real_t *x)
444
927k
{
445
927k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
927k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
927k
    f1 = x[0] + f0;
449
927k
    f2 = x[0] - f0;
450
927k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
927k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
927k
    f5 = f4 - x[4];
453
927k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
927k
    f7 = f6 - f3;
455
927k
    y[0] = f1 + f6 + f4;
456
927k
    y[1] = f2 + f3 - x[4];
457
927k
    y[2] = f7 + f2 - f5;
458
927k
    y[3] = f1 - f7 - f5;
459
927k
    y[4] = f1 - f3 - x[4];
460
927k
    y[5] = f2 - f6 + f4;
461
927k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
432k
{
445
432k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
432k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
432k
    f1 = x[0] + f0;
449
432k
    f2 = x[0] - f0;
450
432k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
432k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
432k
    f5 = f4 - x[4];
453
432k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
432k
    f7 = f6 - f3;
455
432k
    y[0] = f1 + f6 + f4;
456
432k
    y[1] = f2 + f3 - x[4];
457
432k
    y[2] = f7 + f2 - f5;
458
432k
    y[3] = f1 - f7 - f5;
459
432k
    y[4] = f1 - f3 - x[4];
460
432k
    y[5] = f2 - f6 + f4;
461
432k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
495k
{
445
495k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
495k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
495k
    f1 = x[0] + f0;
449
495k
    f2 = x[0] - f0;
450
495k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
495k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
495k
    f5 = f4 - x[4];
453
495k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
495k
    f7 = f6 - f3;
455
495k
    y[0] = f1 + f6 + f4;
456
495k
    y[1] = f2 + f3 - x[4];
457
495k
    y[2] = f7 + f2 - f5;
458
495k
    y[3] = f1 - f7 - f5;
459
495k
    y[4] = f1 - f3 - x[4];
460
495k
    y[5] = f2 - f6 + f4;
461
495k
}
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
15.0k
{
467
15.0k
    uint8_t i, n;
468
15.0k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
15.0k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
15.0k
    (void)hyb;  /* TODO: remove parameter? */
471
472
478k
    for (i = 0; i < frame_len; i++)
473
463k
    {
474
3.24M
        for (n = 0; n < 6; n++)
475
2.78M
        {
476
2.78M
            if (n == 0)
477
463k
            {
478
463k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
463k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
2.31M
            } else {
481
2.31M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
2.31M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
2.31M
            }
484
2.78M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
2.78M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
2.78M
        }
487
488
463k
        DCT3_6_unscaled(out_re1, input_re1);
489
463k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
463k
        DCT3_6_unscaled(out_im1, input_im1);
492
463k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
1.85M
        for (n = 0; n < 6; n += 2)
495
1.39M
        {
496
1.39M
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
1.39M
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
1.39M
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
1.39M
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
1.39M
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
1.39M
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
1.39M
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
1.39M
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
1.39M
        }
506
463k
    }
507
15.0k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
7.53k
{
467
7.53k
    uint8_t i, n;
468
7.53k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
7.53k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
7.53k
    (void)hyb;  /* TODO: remove parameter? */
471
472
239k
    for (i = 0; i < frame_len; i++)
473
231k
    {
474
1.62M
        for (n = 0; n < 6; n++)
475
1.39M
        {
476
1.39M
            if (n == 0)
477
231k
            {
478
231k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
231k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.15M
            } else {
481
1.15M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.15M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.15M
            }
484
1.39M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.39M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.39M
        }
487
488
231k
        DCT3_6_unscaled(out_re1, input_re1);
489
231k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
231k
        DCT3_6_unscaled(out_im1, input_im1);
492
231k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
927k
        for (n = 0; n < 6; n += 2)
495
695k
        {
496
695k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
695k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
695k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
695k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
695k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
695k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
695k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
695k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
695k
        }
506
231k
    }
507
7.53k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
7.53k
{
467
7.53k
    uint8_t i, n;
468
7.53k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
7.53k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
7.53k
    (void)hyb;  /* TODO: remove parameter? */
471
472
239k
    for (i = 0; i < frame_len; i++)
473
231k
    {
474
1.62M
        for (n = 0; n < 6; n++)
475
1.39M
        {
476
1.39M
            if (n == 0)
477
231k
            {
478
231k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
231k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.15M
            } else {
481
1.15M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.15M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.15M
            }
484
1.39M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.39M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.39M
        }
487
488
231k
        DCT3_6_unscaled(out_re1, input_re1);
489
231k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
231k
        DCT3_6_unscaled(out_im1, input_im1);
492
231k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
927k
        for (n = 0; n < 6; n += 2)
495
695k
        {
496
695k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
695k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
695k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
695k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
695k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
695k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
695k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
695k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
695k
        }
506
231k
    }
507
7.53k
}
508
509
/* Hybrid analysis: further split up QMF subbands
510
 * to improve frequency resolution
511
 */
512
static void hybrid_analysis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
513
                            uint8_t use34, uint8_t numTimeSlotsRate)
514
19.9k
{
515
19.9k
    uint8_t k, n, band;
516
19.9k
    uint8_t offset = 0;
517
19.9k
    uint8_t qmf_bands = (use34) ? 5 : 3;
518
19.9k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
519
520
94.7k
    for (band = 0; band < qmf_bands; band++)
521
74.8k
    {
522
        /* build working buffer */
523
74.8k
        memcpy(hyb->work, hyb->buffer[band], 12 * sizeof(qmf_t));
524
525
        /* add new samples */
526
2.40M
        for (n = 0; n < hyb->frame_len; n++)
527
2.32M
        {
528
2.32M
            QMF_RE(hyb->work[12 + n]) = QMF_RE(X[n + 6 /*delay*/][band]);
529
2.32M
            QMF_IM(hyb->work[12 + n]) = QMF_IM(X[n + 6 /*delay*/][band]);
530
2.32M
        }
531
532
        /* store samples */
533
74.8k
        memcpy(hyb->buffer[band], hyb->work + hyb->frame_len, 12 * sizeof(qmf_t));
534
535
536
74.8k
        switch(resolution[band])
537
74.8k
        {
538
24.7k
        case 2:
539
            /* Type B real filter, Q[p] = 2 */
540
24.7k
            channel_filter2(hyb, hyb->frame_len, p2_13_20, hyb->work, hyb->temp);
541
24.7k
            break;
542
22.6k
        case 4:
543
            /* Type A complex filter, Q[p] = 4 */
544
22.6k
            channel_filter4(hyb, hyb->frame_len, p4_13_34, hyb->work, hyb->temp);
545
22.6k
            break;
546
19.9k
        case 8:
547
            /* Type A complex filter, Q[p] = 8 */
548
19.9k
            channel_filter8(hyb, hyb->frame_len, (use34) ? p8_13_34 : p8_13_20,
549
19.9k
                hyb->work, hyb->temp);
550
19.9k
            break;
551
7.53k
        case 12:
552
            /* Type A complex filter, Q[p] = 12 */
553
7.53k
            channel_filter12(hyb, hyb->frame_len, p12_13_34, hyb->work, hyb->temp);
554
7.53k
            break;
555
74.8k
        }
556
557
2.40M
        for (n = 0; n < hyb->frame_len; n++)
558
2.32M
        {
559
14.4M
            for (k = 0; k < resolution[band]; k++)
560
12.0M
            {
561
12.0M
                QMF_RE(X_hybrid[n][offset + k]) = QMF_RE(hyb->temp[n][k]);
562
12.0M
                QMF_IM(X_hybrid[n][offset + k]) = QMF_IM(hyb->temp[n][k]);
563
12.0M
            }
564
2.32M
        }
565
74.8k
        offset += resolution[band];
566
74.8k
    }
567
568
    /* group hybrid channels */
569
19.9k
    if (!use34)
570
12.3k
    {
571
401k
        for (n = 0; n < numTimeSlotsRate; n++)
572
388k
        {
573
388k
            QMF_RE(X_hybrid[n][3]) += QMF_RE(X_hybrid[n][4]);
574
388k
            QMF_IM(X_hybrid[n][3]) += QMF_IM(X_hybrid[n][4]);
575
388k
            QMF_RE(X_hybrid[n][4]) = 0;
576
388k
            QMF_IM(X_hybrid[n][4]) = 0;
577
578
388k
            QMF_RE(X_hybrid[n][2]) += QMF_RE(X_hybrid[n][5]);
579
388k
            QMF_IM(X_hybrid[n][2]) += QMF_IM(X_hybrid[n][5]);
580
388k
            QMF_RE(X_hybrid[n][5]) = 0;
581
388k
            QMF_IM(X_hybrid[n][5]) = 0;
582
388k
        }
583
12.3k
    }
584
19.9k
}
585
586
static void hybrid_synthesis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
587
                             uint8_t use34, uint8_t numTimeSlotsRate)
588
39.8k
{
589
39.8k
    uint8_t k, n, band;
590
39.8k
    uint8_t offset = 0;
591
39.8k
    uint8_t qmf_bands = (use34) ? 5 : 3;
592
39.8k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
593
39.8k
    (void)numTimeSlotsRate;  /* TODO: remove parameter? */
594
595
189k
    for(band = 0; band < qmf_bands; band++)
596
149k
    {
597
4.80M
        for (n = 0; n < hyb->frame_len; n++)
598
4.65M
        {
599
4.65M
            QMF_RE(X[n][band]) = 0;
600
4.65M
            QMF_IM(X[n][band]) = 0;
601
602
28.8M
            for (k = 0; k < resolution[band]; k++)
603
24.1M
            {
604
24.1M
                QMF_RE(X[n][band]) += QMF_RE(X_hybrid[n][offset + k]);
605
24.1M
                QMF_IM(X[n][band]) += QMF_IM(X_hybrid[n][offset + k]);
606
24.1M
            }
607
4.65M
        }
608
149k
        offset += resolution[band];
609
149k
    }
610
39.8k
}
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
488k
{
615
488k
    if (i < min)
616
69.7k
        return min;
617
418k
    else if (i > max)
618
10.1k
        return max;
619
408k
    else
620
408k
        return i;
621
488k
}
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
69.4k
{
630
69.4k
    int8_t i;
631
632
69.4k
    if (enable == 1)
633
34.7k
    {
634
34.7k
        if (dt_flag == 0)
635
21.2k
        {
636
            /* delta coded in frequency direction */
637
21.2k
            index[0] = 0 + index[0];
638
21.2k
            index[0] = delta_clip(index[0], min_index, max_index);
639
640
309k
            for (i = 1; i < nr_par; i++)
641
287k
            {
642
287k
                index[i] = index[i-1] + index[i];
643
287k
                index[i] = delta_clip(index[i], min_index, max_index);
644
287k
            }
645
21.2k
        } else {
646
            /* delta coded in time direction */
647
193k
            for (i = 0; i < nr_par; i++)
648
179k
            {
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
179k
                index[i] = index_prev[i*stride] + index[i];
656
                //tmp2 = index[i];
657
179k
                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
179k
            }
667
13.5k
        }
668
34.7k
    } else {
669
        /* set indices to zero */
670
59.2k
        for (i = 0; i < nr_par; i++)
671
24.6k
        {
672
24.6k
            index[i] = 0;
673
24.6k
        }
674
34.6k
    }
675
676
    /* coarse */
677
69.4k
    if (stride == 2)
678
44.7k
    {
679
260k
        for (i = (nr_par<<1)-1; i > 0; i--)
680
215k
        {
681
215k
            index[i] = index[i>>1];
682
215k
        }
683
44.7k
    }
684
69.4k
}
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
69.4k
{
692
69.4k
    int8_t i;
693
694
69.4k
    if (enable == 1)
695
22.6k
    {
696
22.6k
        if (dt_flag == 0)
697
13.1k
        {
698
            /* delta coded in frequency direction */
699
13.1k
            index[0] = 0 + index[0];
700
13.1k
            index[0] &= and_modulo;
701
702
45.5k
            for (i = 1; i < nr_par; i++)
703
32.3k
            {
704
32.3k
                index[i] = index[i-1] + index[i];
705
32.3k
                index[i] &= and_modulo;
706
32.3k
            }
707
13.1k
        } else {
708
            /* delta coded in time direction */
709
28.8k
            for (i = 0; i < nr_par; i++)
710
19.3k
            {
711
19.3k
                index[i] = index_prev[i*stride] + index[i];
712
19.3k
                index[i] &= and_modulo;
713
19.3k
            }
714
9.44k
        }
715
46.7k
    } else {
716
        /* set indices to zero */
717
161k
        for (i = 0; i < nr_par; i++)
718
115k
        {
719
115k
            index[i] = 0;
720
115k
        }
721
46.7k
    }
722
723
    /* coarse */
724
69.4k
    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
69.4k
}
733
734
#ifdef PS_LOW_POWER
735
static void map34indexto20(int8_t *index, uint8_t bins)
736
{
737
    index[0] = (2*index[0]+index[1])/3;
738
    index[1] = (index[1]+2*index[2])/3;
739
    index[2] = (2*index[3]+index[4])/3;
740
    index[3] = (index[4]+2*index[5])/3;
741
    index[4] = (index[6]+index[7])/2;
742
    index[5] = (index[8]+index[9])/2;
743
    index[6] = index[10];
744
    index[7] = index[11];
745
    index[8] = (index[12]+index[13])/2;
746
    index[9] = (index[14]+index[15])/2;
747
    index[10] = index[16];
748
749
    if (bins == 34)
750
    {
751
        index[11] = index[17];
752
        index[12] = index[18];
753
        index[13] = index[19];
754
        index[14] = (index[20]+index[21])/2;
755
        index[15] = (index[22]+index[23])/2;
756
        index[16] = (index[24]+index[25])/2;
757
        index[17] = (index[26]+index[27])/2;
758
        index[18] = (index[28]+index[29]+index[30]+index[31])/4;
759
        index[19] = (index[32]+index[33])/2;
760
    }
761
}
762
#endif
763
764
static void map20indexto34(int8_t *index, uint8_t bins)
765
33.3k
{
766
33.3k
    index[0] = index[0];
767
33.3k
    index[1] = (index[0] + index[1])/2;
768
33.3k
    index[2] = index[1];
769
33.3k
    index[3] = index[2];
770
33.3k
    index[4] = (index[2] + index[3])/2;
771
33.3k
    index[5] = index[3];
772
33.3k
    index[6] = index[4];
773
33.3k
    index[7] = index[4];
774
33.3k
    index[8] = index[5];
775
33.3k
    index[9] = index[5];
776
33.3k
    index[10] = index[6];
777
33.3k
    index[11] = index[7];
778
33.3k
    index[12] = index[8];
779
33.3k
    index[13] = index[8];
780
33.3k
    index[14] = index[9];
781
33.3k
    index[15] = index[9];
782
33.3k
    index[16] = index[10];
783
784
33.3k
    if (bins == 34)
785
13.9k
    {
786
13.9k
        index[17] = index[11];
787
13.9k
        index[18] = index[12];
788
13.9k
        index[19] = index[13];
789
13.9k
        index[20] = index[14];
790
13.9k
        index[21] = index[14];
791
13.9k
        index[22] = index[15];
792
13.9k
        index[23] = index[15];
793
13.9k
        index[24] = index[16];
794
13.9k
        index[25] = index[16];
795
13.9k
        index[26] = index[17];
796
13.9k
        index[27] = index[17];
797
13.9k
        index[28] = index[18];
798
13.9k
        index[29] = index[18];
799
13.9k
        index[30] = index[18];
800
13.9k
        index[31] = index[18];
801
13.9k
        index[32] = index[19];
802
13.9k
        index[33] = index[19];
803
13.9k
    }
804
33.3k
}
805
806
/* parse the bitstream data decoded in ps_data() */
807
static void ps_data_decode(ps_info *ps)
808
19.9k
{
809
19.9k
    uint8_t env, bin;
810
811
    /* ps data not available, use data from previous frame */
812
19.9k
    if (ps->ps_data_available == 0)
813
5.03k
    {
814
5.03k
        ps->num_env = 0;
815
5.03k
    }
816
817
54.6k
    for (env = 0; env < ps->num_env; env++)
818
34.7k
    {
819
34.7k
        int8_t *iid_index_prev;
820
34.7k
        int8_t *icc_index_prev;
821
34.7k
        int8_t *ipd_index_prev;
822
34.7k
        int8_t *opd_index_prev;
823
824
34.7k
        int8_t num_iid_steps = (ps->iid_mode < 3) ? 7 : 15 /*fine quant*/;
825
826
34.7k
        if (env == 0)
827
10.4k
        {
828
            /* take last envelope from previous frame */
829
10.4k
            iid_index_prev = ps->iid_index_prev;
830
10.4k
            icc_index_prev = ps->icc_index_prev;
831
10.4k
            ipd_index_prev = ps->ipd_index_prev;
832
10.4k
            opd_index_prev = ps->opd_index_prev;
833
24.2k
        } else {
834
            /* take index values from previous envelope */
835
24.2k
            iid_index_prev = ps->iid_index[env - 1];
836
24.2k
            icc_index_prev = ps->icc_index[env - 1];
837
24.2k
            ipd_index_prev = ps->ipd_index[env - 1];
838
24.2k
            opd_index_prev = ps->opd_index[env - 1];
839
24.2k
        }
840
841
//        iid = 1;
842
        /* delta decode iid parameters */
843
34.7k
        delta_decode(ps->enable_iid, ps->iid_index[env], iid_index_prev,
844
34.7k
            ps->iid_dt[env], ps->nr_iid_par,
845
34.7k
            (ps->iid_mode == 0 || ps->iid_mode == 3) ? 2 : 1,
846
34.7k
            -num_iid_steps, num_iid_steps);
847
//        iid = 0;
848
849
        /* delta decode icc parameters */
850
34.7k
        delta_decode(ps->enable_icc, ps->icc_index[env], icc_index_prev,
851
34.7k
            ps->icc_dt[env], ps->nr_icc_par,
852
34.7k
            (ps->icc_mode == 0 || ps->icc_mode == 3) ? 2 : 1,
853
34.7k
            0, 7);
854
855
        /* delta modulo decode ipd parameters */
856
34.7k
        delta_modulo_decode(ps->enable_ipdopd, ps->ipd_index[env], ipd_index_prev,
857
34.7k
            ps->ipd_dt[env], ps->nr_ipdopd_par, 1, 7);
858
859
        /* delta modulo decode opd parameters */
860
34.7k
        delta_modulo_decode(ps->enable_ipdopd, ps->opd_index[env], opd_index_prev,
861
34.7k
            ps->opd_dt[env], ps->nr_ipdopd_par, 1, 7);
862
34.7k
    }
863
864
    /* handle error case */
865
19.9k
    if (ps->num_env == 0)
866
9.43k
    {
867
        /* force to 1 */
868
9.43k
        ps->num_env = 1;
869
870
9.43k
        if (ps->enable_iid)
871
6.35k
        {
872
222k
            for (bin = 0; bin < 34; bin++)
873
216k
                ps->iid_index[0][bin] = ps->iid_index_prev[bin];
874
6.35k
        } else {
875
107k
            for (bin = 0; bin < 34; bin++)
876
104k
                ps->iid_index[0][bin] = 0;
877
3.07k
        }
878
879
9.43k
        if (ps->enable_icc)
880
4.75k
        {
881
166k
            for (bin = 0; bin < 34; bin++)
882
161k
                ps->icc_index[0][bin] = ps->icc_index_prev[bin];
883
4.75k
        } else {
884
163k
            for (bin = 0; bin < 34; bin++)
885
159k
                ps->icc_index[0][bin] = 0;
886
4.68k
        }
887
888
9.43k
        if (ps->enable_ipdopd)
889
1.11k
        {
890
20.1k
            for (bin = 0; bin < 17; bin++)
891
19.0k
            {
892
19.0k
                ps->ipd_index[0][bin] = ps->ipd_index_prev[bin];
893
19.0k
                ps->opd_index[0][bin] = ps->opd_index_prev[bin];
894
19.0k
            }
895
8.31k
        } else {
896
149k
            for (bin = 0; bin < 17; bin++)
897
141k
            {
898
141k
                ps->ipd_index[0][bin] = 0;
899
141k
                ps->opd_index[0][bin] = 0;
900
141k
            }
901
8.31k
        }
902
9.43k
    }
903
904
    /* update previous indices */
905
697k
    for (bin = 0; bin < 34; bin++)
906
677k
        ps->iid_index_prev[bin] = ps->iid_index[ps->num_env-1][bin];
907
697k
    for (bin = 0; bin < 34; bin++)
908
677k
        ps->icc_index_prev[bin] = ps->icc_index[ps->num_env-1][bin];
909
358k
    for (bin = 0; bin < 17; bin++)
910
338k
    {
911
338k
        ps->ipd_index_prev[bin] = ps->ipd_index[ps->num_env-1][bin];
912
338k
        ps->opd_index_prev[bin] = ps->opd_index[ps->num_env-1][bin];
913
338k
    }
914
915
19.9k
    ps->ps_data_available = 0;
916
917
19.9k
    if (ps->frame_class == 0)
918
11.9k
    {
919
11.9k
        ps->border_position[0] = 0;
920
21.6k
        for (env = 1; env < ps->num_env; env++)
921
9.74k
        {
922
9.74k
            ps->border_position[env] = (env * ps->numTimeSlotsRate) / ps->num_env;
923
9.74k
        }
924
11.9k
        ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
925
11.9k
    } else {
926
7.99k
        ps->border_position[0] = 0;
927
928
7.99k
        if (ps->border_position[ps->num_env] < ps->numTimeSlotsRate)
929
5.94k
        {
930
208k
            for (bin = 0; bin < 34; bin++)
931
202k
            {
932
202k
                ps->iid_index[ps->num_env][bin] = ps->iid_index[ps->num_env-1][bin];
933
202k
                ps->icc_index[ps->num_env][bin] = ps->icc_index[ps->num_env-1][bin];
934
202k
            }
935
107k
            for (bin = 0; bin < 17; bin++)
936
101k
            {
937
101k
                ps->ipd_index[ps->num_env][bin] = ps->ipd_index[ps->num_env-1][bin];
938
101k
                ps->opd_index[ps->num_env][bin] = ps->opd_index[ps->num_env-1][bin];
939
101k
            }
940
5.94k
            ps->num_env++;
941
5.94k
            ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
942
5.94k
        }
943
944
28.4k
        for (env = 1; env < ps->num_env; env++)
945
20.4k
        {
946
20.4k
            int8_t thr = ps->numTimeSlotsRate - (ps->num_env - env);
947
948
20.4k
            if (ps->border_position[env] > thr)
949
5.09k
            {
950
5.09k
                ps->border_position[env] = thr;
951
15.3k
            } else {
952
15.3k
                thr = ps->border_position[env-1]+1;
953
15.3k
                if (ps->border_position[env] < thr)
954
8.14k
                {
955
8.14k
                    ps->border_position[env] = thr;
956
8.14k
                }
957
15.3k
            }
958
20.4k
        }
959
7.99k
    }
960
961
    /* make sure that the indices of all parameters can be mapped
962
     * to the same hybrid synthesis filterbank
963
     */
964
#ifdef PS_LOW_POWER
965
    for (env = 0; env < ps->num_env; env++)
966
    {
967
        if (ps->iid_mode == 2 || ps->iid_mode == 5)
968
            map34indexto20(ps->iid_index[env], 34);
969
        if (ps->icc_mode == 2 || ps->icc_mode == 5)
970
            map34indexto20(ps->icc_index[env], 34);
971
972
        /* disable ipd/opd */
973
        for (bin = 0; bin < 17; bin++)
974
        {
975
            ps->aaIpdIndex[env][bin] = 0;
976
            ps->aaOpdIndex[env][bin] = 0;
977
        }
978
    }
979
#else
980
19.9k
    if (ps->use34hybrid_bands)
981
7.53k
    {
982
22.3k
        for (env = 0; env < ps->num_env; env++)
983
14.8k
        {
984
14.8k
            if (ps->iid_mode != 2 && ps->iid_mode != 5)
985
9.67k
                map20indexto34(ps->iid_index[env], 34);
986
14.8k
            if (ps->icc_mode != 2 && ps->icc_mode != 5)
987
4.30k
                map20indexto34(ps->icc_index[env], 34);
988
14.8k
            if (ps->ipd_mode != 2 && ps->ipd_mode != 5)
989
9.67k
            {
990
9.67k
                map20indexto34(ps->ipd_index[env], 17);
991
9.67k
                map20indexto34(ps->opd_index[env], 17);
992
9.67k
            }
993
14.8k
        }
994
7.53k
    }
995
19.9k
#endif
996
997
#if 0
998
    for (env = 0; env < ps->num_env; env++)
999
    {
1000
        printf("iid[env:%d]:", env);
1001
        for (bin = 0; bin < 34; bin++)
1002
        {
1003
            printf(" %d", ps->iid_index[env][bin]);
1004
        }
1005
        printf("\n");
1006
    }
1007
    for (env = 0; env < ps->num_env; env++)
1008
    {
1009
        printf("icc[env:%d]:", env);
1010
        for (bin = 0; bin < 34; bin++)
1011
        {
1012
            printf(" %d", ps->icc_index[env][bin]);
1013
        }
1014
        printf("\n");
1015
    }
1016
    for (env = 0; env < ps->num_env; env++)
1017
    {
1018
        printf("ipd[env:%d]:", env);
1019
        for (bin = 0; bin < 17; bin++)
1020
        {
1021
            printf(" %d", ps->ipd_index[env][bin]);
1022
        }
1023
        printf("\n");
1024
    }
1025
    for (env = 0; env < ps->num_env; env++)
1026
    {
1027
        printf("opd[env:%d]:", env);
1028
        for (bin = 0; bin < 17; bin++)
1029
        {
1030
            printf(" %d", ps->opd_index[env][bin]);
1031
        }
1032
        printf("\n");
1033
    }
1034
    printf("\n");
1035
#endif
1036
19.9k
}
1037
1038
/* decorrelate the mono signal using an allpass filter */
1039
static void ps_decorrelate(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
1040
                           qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32])
1041
19.9k
{
1042
19.9k
    uint8_t gr, n, bk;
1043
19.9k
    uint8_t temp_delay = 0;
1044
19.9k
    uint8_t sb, maxsb;
1045
19.9k
    const complex_t *Phi_Fract_SubQmf;
1046
19.9k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
19.9k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
19.9k
    real_t P[32][34];
1049
19.9k
    real_t G_TransientRatio[32][34] = {{0}};
1050
19.9k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
19.9k
    if (ps->use34hybrid_bands)
1055
7.53k
    {
1056
7.53k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
12.3k
    } else{
1058
12.3k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
12.3k
    }
1060
1061
    /* clear the energy values */
1062
657k
    for (n = 0; n < 32; n++)
1063
637k
    {
1064
22.3M
        for (bk = 0; bk < 34; bk++)
1065
21.6M
        {
1066
21.6M
            P[n][bk] = 0;
1067
21.6M
        }
1068
637k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
669k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
649k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
649k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
649k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
2.21M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
1.56M
        {
1081
50.4M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
48.8M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
48.8M
                if (gr < ps->num_hybrid_groups)
1089
11.3M
                {
1090
11.3M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
11.3M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
37.5M
                } else {
1093
37.5M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
37.5M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
37.5M
                }
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
22.0M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
22.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
26.7M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
48.8M
            }
1109
1.56M
        }
1110
649k
    }
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
523k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
503k
    {
1129
16.2M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
15.7M
        {
1131
15.7M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
15.7M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
15.7M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
162k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
15.7M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
15.7M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
15.7M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
15.7M
            nrg = ps->P_prev[bk];
1144
15.7M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
15.7M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
15.7M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
15.5M
            {
1150
15.5M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
15.5M
            } else {
1152
138k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
138k
            }
1154
15.7M
        }
1155
503k
    }
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
669k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
649k
    {
1174
649k
        if (gr < ps->num_hybrid_groups)
1175
365k
            maxsb = ps->group_border[gr] + 1;
1176
284k
        else
1177
284k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
2.21M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
1.56M
        {
1182
1.56M
            real_t g_DecaySlope;
1183
1.56M
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
1.56M
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
384k
            {
1188
384k
                g_DecaySlope = FRAC_CONST(1.0);
1189
1.18M
            } else {
1190
1.18M
                int8_t decay = ps->decay_cutoff - sb;
1191
1.18M
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
801k
                {
1193
801k
                    g_DecaySlope = 0;
1194
801k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
378k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
378k
                }
1198
1.18M
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
6.26M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
4.69M
            {
1203
4.69M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
4.69M
            }
1205
1206
1207
            /* set delay indices */
1208
1.56M
            temp_delay = ps->saved_delay;
1209
6.26M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
4.69M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
50.4M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
48.8M
            {
1214
48.8M
                complex_t tmp, tmp0, R0;
1215
48.8M
                uint8_t m;
1216
1217
48.8M
                if (gr < ps->num_hybrid_groups)
1218
11.3M
                {
1219
                    /* hybrid filterbank input */
1220
11.3M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
11.3M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
37.5M
                } else {
1223
                    /* QMF filterbank input */
1224
37.5M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
37.5M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
37.5M
                }
1227
1228
48.8M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
25.5M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
25.5M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
25.5M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
25.5M
                    RE(R0) = RE(tmp);
1236
25.5M
                    IM(R0) = IM(tmp);
1237
25.5M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
25.5M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
25.5M
                } else {
1240
                    /* allpass filter */
1241
23.3M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
23.3M
                    if (gr < ps->num_hybrid_groups)
1245
11.3M
                    {
1246
                        /* select data from the hybrid subbands */
1247
11.3M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
11.3M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
11.3M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
11.3M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
11.3M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
11.3M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
11.9M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
11.9M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
11.9M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
11.9M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
11.9M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
11.9M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
11.9M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
11.9M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
23.3M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
23.3M
                    RE(R0) = RE(tmp);
1271
23.3M
                    IM(R0) = IM(tmp);
1272
93.2M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
69.9M
                    {
1274
69.9M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
69.9M
                        if (gr < ps->num_hybrid_groups)
1278
34.0M
                        {
1279
                            /* select data from the hybrid subbands */
1280
34.0M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
34.0M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
34.0M
                            if (ps->use34hybrid_bands)
1284
22.3M
                            {
1285
22.3M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
22.3M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
22.3M
                            } else {
1288
11.7M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
11.7M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
11.7M
                            }
1291
35.9M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
35.9M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
35.9M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
35.9M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
35.9M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
35.9M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
69.9M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
69.9M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
69.9M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
69.9M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
69.9M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
69.9M
                        if (gr < ps->num_hybrid_groups)
1314
34.0M
                        {
1315
34.0M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
34.0M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
35.9M
                        } else {
1318
35.9M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
35.9M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
35.9M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
69.9M
                        RE(R0) = RE(tmp);
1324
69.9M
                        IM(R0) = IM(tmp);
1325
69.9M
                    }
1326
23.3M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
48.8M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
48.8M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
48.8M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
48.8M
                if (gr < ps->num_hybrid_groups)
1336
11.3M
                {
1337
                    /* hybrid */
1338
11.3M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
11.3M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
37.5M
                } else {
1341
                    /* QMF */
1342
37.5M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
37.5M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
37.5M
                }
1345
1346
                /* Update delay buffer index */
1347
48.8M
                if (++temp_delay >= 2)
1348
24.4M
                {
1349
24.4M
                    temp_delay = 0;
1350
24.4M
                }
1351
1352
                /* update delay indices */
1353
48.8M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
25.5M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
25.5M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
18.5M
                    {
1358
18.5M
                        ps->delay_buf_index_delay[sb] = 0;
1359
18.5M
                    }
1360
25.5M
                }
1361
1362
195M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
146M
                {
1364
146M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
37.4M
                    {
1366
37.4M
                        temp_delay_ser[m] = 0;
1367
37.4M
                    }
1368
146M
                }
1369
48.8M
            }
1370
1.56M
        }
1371
649k
    }
1372
1373
    /* update delay indices */
1374
19.9k
    ps->saved_delay = temp_delay;
1375
79.6k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
59.7k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
19.9k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
8.98k
{
1042
8.98k
    uint8_t gr, n, bk;
1043
8.98k
    uint8_t temp_delay = 0;
1044
8.98k
    uint8_t sb, maxsb;
1045
8.98k
    const complex_t *Phi_Fract_SubQmf;
1046
8.98k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
8.98k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
8.98k
    real_t P[32][34];
1049
8.98k
    real_t G_TransientRatio[32][34] = {{0}};
1050
8.98k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
8.98k
    if (ps->use34hybrid_bands)
1055
3.51k
    {
1056
3.51k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
5.46k
    } else{
1058
5.46k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
5.46k
    }
1060
1061
    /* clear the energy values */
1062
296k
    for (n = 0; n < 32; n++)
1063
287k
    {
1064
10.0M
        for (bk = 0; bk < 34; bk++)
1065
9.77M
        {
1066
9.77M
            P[n][bk] = 0;
1067
9.77M
        }
1068
287k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
304k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
295k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
295k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
295k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
1.00M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
707k
        {
1081
22.7M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
22.0M
            {
1083
22.0M
#ifdef FIXED_POINT
1084
22.0M
                uint32_t in_re, in_im;
1085
22.0M
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
22.0M
                if (gr < ps->num_hybrid_groups)
1089
5.18M
                {
1090
5.18M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
5.18M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
16.9M
                } else {
1093
16.9M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
16.9M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
16.9M
                }
1096
1097
                /* accumulate energy */
1098
22.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
22.0M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
22.0M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
22.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
22.0M
            }
1109
707k
        }
1110
295k
    }
1111
1112
#if 0
1113
    for (n = 0; n < 32; n++)
1114
    {
1115
        for (bk = 0; bk < 34; bk++)
1116
        {
1117
#ifdef FIXED_POINT
1118
            printf("%d %d: %d\n", n, bk, P[n][bk] /*/(float)REAL_PRECISION*/);
1119
#else
1120
            printf("%d %d: %f\n", n, bk, P[n][bk]/1024.0);
1121
#endif
1122
        }
1123
    }
1124
#endif
1125
1126
    /* calculate transient reduction ratio for each parameter band b(k) */
1127
237k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
228k
    {
1129
7.35M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
7.12M
        {
1131
7.12M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
7.12M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
7.12M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
23.8k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
7.12M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
7.12M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
7.12M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
7.12M
            nrg = ps->P_prev[bk];
1144
7.12M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
7.12M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
7.12M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
7.11M
            {
1150
7.11M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
7.11M
            } else {
1152
9.56k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
9.56k
            }
1154
7.12M
        }
1155
228k
    }
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
304k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
295k
    {
1174
295k
        if (gr < ps->num_hybrid_groups)
1175
167k
            maxsb = ps->group_border[gr] + 1;
1176
128k
        else
1177
128k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
1.00M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
707k
        {
1182
707k
            real_t g_DecaySlope;
1183
707k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
707k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
176k
            {
1188
176k
                g_DecaySlope = FRAC_CONST(1.0);
1189
531k
            } else {
1190
531k
                int8_t decay = ps->decay_cutoff - sb;
1191
531k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
361k
                {
1193
361k
                    g_DecaySlope = 0;
1194
361k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
170k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
170k
                }
1198
531k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
2.83M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.12M
            {
1203
2.12M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.12M
            }
1205
1206
1207
            /* set delay indices */
1208
707k
            temp_delay = ps->saved_delay;
1209
2.83M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.12M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
22.7M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
22.0M
            {
1214
22.0M
                complex_t tmp, tmp0, R0;
1215
22.0M
                uint8_t m;
1216
1217
22.0M
                if (gr < ps->num_hybrid_groups)
1218
5.18M
                {
1219
                    /* hybrid filterbank input */
1220
5.18M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
5.18M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
16.9M
                } else {
1223
                    /* QMF filterbank input */
1224
16.9M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
16.9M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
16.9M
                }
1227
1228
22.0M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
11.5M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
11.5M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
11.5M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
11.5M
                    RE(R0) = RE(tmp);
1236
11.5M
                    IM(R0) = IM(tmp);
1237
11.5M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
11.5M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
11.5M
                } else {
1240
                    /* allpass filter */
1241
10.5M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
10.5M
                    if (gr < ps->num_hybrid_groups)
1245
5.18M
                    {
1246
                        /* select data from the hybrid subbands */
1247
5.18M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
5.18M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
5.18M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
5.18M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
5.18M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
5.18M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
5.39M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
5.39M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
5.39M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
5.39M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
5.39M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
5.39M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
5.39M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
5.39M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
10.5M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
10.5M
                    RE(R0) = RE(tmp);
1271
10.5M
                    IM(R0) = IM(tmp);
1272
42.3M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
31.7M
                    {
1274
31.7M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
31.7M
                        if (gr < ps->num_hybrid_groups)
1278
15.5M
                        {
1279
                            /* select data from the hybrid subbands */
1280
15.5M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
15.5M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
15.5M
                            if (ps->use34hybrid_bands)
1284
10.3M
                            {
1285
10.3M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
10.3M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
10.3M
                            } else {
1288
5.17M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
5.17M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
5.17M
                            }
1291
16.1M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
16.1M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
16.1M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
16.1M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
16.1M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
16.1M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
31.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
31.7M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
31.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
31.7M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
31.7M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
31.7M
                        if (gr < ps->num_hybrid_groups)
1314
15.5M
                        {
1315
15.5M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
15.5M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
16.1M
                        } else {
1318
16.1M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
16.1M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
16.1M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
31.7M
                        RE(R0) = RE(tmp);
1324
31.7M
                        IM(R0) = IM(tmp);
1325
31.7M
                    }
1326
10.5M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
22.0M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
22.0M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
22.0M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
22.0M
                if (gr < ps->num_hybrid_groups)
1336
5.18M
                {
1337
                    /* hybrid */
1338
5.18M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
5.18M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
16.9M
                } else {
1341
                    /* QMF */
1342
16.9M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
16.9M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
16.9M
                }
1345
1346
                /* Update delay buffer index */
1347
22.0M
                if (++temp_delay >= 2)
1348
11.0M
                {
1349
11.0M
                    temp_delay = 0;
1350
11.0M
                }
1351
1352
                /* update delay indices */
1353
22.0M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
11.5M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
11.5M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
8.35M
                    {
1358
8.35M
                        ps->delay_buf_index_delay[sb] = 0;
1359
8.35M
                    }
1360
11.5M
                }
1361
1362
88.3M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
66.2M
                {
1364
66.2M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
16.8M
                    {
1366
16.8M
                        temp_delay_ser[m] = 0;
1367
16.8M
                    }
1368
66.2M
                }
1369
22.0M
            }
1370
707k
        }
1371
295k
    }
1372
1373
    /* update delay indices */
1374
8.98k
    ps->saved_delay = temp_delay;
1375
35.9k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
26.9k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
8.98k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
10.9k
{
1042
10.9k
    uint8_t gr, n, bk;
1043
10.9k
    uint8_t temp_delay = 0;
1044
10.9k
    uint8_t sb, maxsb;
1045
10.9k
    const complex_t *Phi_Fract_SubQmf;
1046
10.9k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
10.9k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
10.9k
    real_t P[32][34];
1049
10.9k
    real_t G_TransientRatio[32][34] = {{0}};
1050
10.9k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
10.9k
    if (ps->use34hybrid_bands)
1055
4.02k
    {
1056
4.02k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
6.91k
    } else{
1058
6.91k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
6.91k
    }
1060
1061
    /* clear the energy values */
1062
361k
    for (n = 0; n < 32; n++)
1063
350k
    {
1064
12.2M
        for (bk = 0; bk < 34; bk++)
1065
11.9M
        {
1066
11.9M
            P[n][bk] = 0;
1067
11.9M
        }
1068
350k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
364k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
353k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
353k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
353k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
1.21M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
857k
        {
1081
27.6M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
26.7M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
26.7M
                if (gr < ps->num_hybrid_groups)
1089
6.14M
                {
1090
6.14M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
6.14M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
20.6M
                } else {
1093
20.6M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
20.6M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
20.6M
                }
1096
1097
                /* accumulate energy */
1098
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
26.7M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
26.7M
#endif
1108
26.7M
            }
1109
857k
        }
1110
353k
    }
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
286k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
275k
    {
1129
8.85M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
8.57M
        {
1131
8.57M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
8.57M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
8.57M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
138k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
8.57M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
8.57M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
8.57M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
8.57M
            nrg = ps->P_prev[bk];
1144
8.57M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
8.57M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
8.57M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
8.44M
            {
1150
8.44M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
8.44M
            } else {
1152
128k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
128k
            }
1154
8.57M
        }
1155
275k
    }
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
364k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
353k
    {
1174
353k
        if (gr < ps->num_hybrid_groups)
1175
197k
            maxsb = ps->group_border[gr] + 1;
1176
155k
        else
1177
155k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
1.21M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
857k
        {
1182
857k
            real_t g_DecaySlope;
1183
857k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
857k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
208k
            {
1188
208k
                g_DecaySlope = FRAC_CONST(1.0);
1189
648k
            } else {
1190
648k
                int8_t decay = ps->decay_cutoff - sb;
1191
648k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
440k
                {
1193
440k
                    g_DecaySlope = 0;
1194
440k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
207k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
207k
                }
1198
648k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
3.42M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.57M
            {
1203
2.57M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.57M
            }
1205
1206
1207
            /* set delay indices */
1208
857k
            temp_delay = ps->saved_delay;
1209
3.42M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.57M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
27.6M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
26.7M
            {
1214
26.7M
                complex_t tmp, tmp0, R0;
1215
26.7M
                uint8_t m;
1216
1217
26.7M
                if (gr < ps->num_hybrid_groups)
1218
6.14M
                {
1219
                    /* hybrid filterbank input */
1220
6.14M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
6.14M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
20.6M
                } else {
1223
                    /* QMF filterbank input */
1224
20.6M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
20.6M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
20.6M
                }
1227
1228
26.7M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
14.0M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
14.0M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
14.0M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
14.0M
                    RE(R0) = RE(tmp);
1236
14.0M
                    IM(R0) = IM(tmp);
1237
14.0M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
14.0M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
14.0M
                } else {
1240
                    /* allpass filter */
1241
12.7M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
12.7M
                    if (gr < ps->num_hybrid_groups)
1245
6.14M
                    {
1246
                        /* select data from the hybrid subbands */
1247
6.14M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
6.14M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
6.14M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
6.14M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
6.14M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
6.14M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
6.59M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
6.59M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
6.59M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
6.59M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
6.59M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
6.59M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
6.59M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
6.59M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
12.7M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
12.7M
                    RE(R0) = RE(tmp);
1271
12.7M
                    IM(R0) = IM(tmp);
1272
50.9M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
38.2M
                    {
1274
38.2M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
38.2M
                        if (gr < ps->num_hybrid_groups)
1278
18.4M
                        {
1279
                            /* select data from the hybrid subbands */
1280
18.4M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
18.4M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
18.4M
                            if (ps->use34hybrid_bands)
1284
11.9M
                            {
1285
11.9M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
11.9M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
11.9M
                            } else {
1288
6.53M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
6.53M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
6.53M
                            }
1291
19.7M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
19.7M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
19.7M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
19.7M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
19.7M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
19.7M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
38.2M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
38.2M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
38.2M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
38.2M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
38.2M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
38.2M
                        if (gr < ps->num_hybrid_groups)
1314
18.4M
                        {
1315
18.4M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
18.4M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
19.7M
                        } else {
1318
19.7M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
19.7M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
19.7M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
38.2M
                        RE(R0) = RE(tmp);
1324
38.2M
                        IM(R0) = IM(tmp);
1325
38.2M
                    }
1326
12.7M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
26.7M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
26.7M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
26.7M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
26.7M
                if (gr < ps->num_hybrid_groups)
1336
6.14M
                {
1337
                    /* hybrid */
1338
6.14M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
6.14M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
20.6M
                } else {
1341
                    /* QMF */
1342
20.6M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
20.6M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
20.6M
                }
1345
1346
                /* Update delay buffer index */
1347
26.7M
                if (++temp_delay >= 2)
1348
13.3M
                {
1349
13.3M
                    temp_delay = 0;
1350
13.3M
                }
1351
1352
                /* update delay indices */
1353
26.7M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
14.0M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
14.0M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
10.1M
                    {
1358
10.1M
                        ps->delay_buf_index_delay[sb] = 0;
1359
10.1M
                    }
1360
14.0M
                }
1361
1362
107M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
80.2M
                {
1364
80.2M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
20.5M
                    {
1366
20.5M
                        temp_delay_ser[m] = 0;
1367
20.5M
                    }
1368
80.2M
                }
1369
26.7M
            }
1370
857k
        }
1371
353k
    }
1372
1373
    /* update delay indices */
1374
10.9k
    ps->saved_delay = temp_delay;
1375
43.7k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
32.8k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
10.9k
}
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
362k
{
1438
#ifdef FIXED_POINT
1439
362k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
#define ALPHA FRAC_CONST(0.948059448969)
1441
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
181k
    real_t abs_inphase = ps_abs(RE(c));
1444
181k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
181k
    if (abs_inphase > abs_quadrature) {
1447
154k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
154k
    } else {
1449
26.9k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
26.9k
    }
1451
#else
1452
180k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
362k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
181k
{
1438
181k
#ifdef FIXED_POINT
1439
181k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
181k
#define ALPHA FRAC_CONST(0.948059448969)
1441
181k
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
181k
    real_t abs_inphase = ps_abs(RE(c));
1444
181k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
181k
    if (abs_inphase > abs_quadrature) {
1447
154k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
154k
    } else {
1449
26.9k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
26.9k
    }
1451
#else
1452
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
181k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
180k
{
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
180k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
180k
#endif
1454
180k
}
1455
1456
static void ps_mix_phase(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
1457
                         qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32])
1458
19.9k
{
1459
19.9k
    uint8_t n;
1460
19.9k
    uint8_t gr;
1461
19.9k
    uint8_t bk = 0;
1462
19.9k
    uint8_t sb, maxsb;
1463
19.9k
    uint8_t env;
1464
19.9k
    uint8_t nr_ipdopd_par;
1465
19.9k
    complex_t h11, h12, h21, h22;  // COEF
1466
19.9k
    complex_t H11, H12, H21, H22;  // COEF
1467
19.9k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
19.9k
    complex_t tempLeft, tempRight; // FRAC
1469
19.9k
    complex_t phaseLeft, phaseRight; // FRAC
1470
19.9k
    real_t L;
1471
19.9k
    const real_t *sf_iid;
1472
19.9k
    uint8_t no_iid_steps;
1473
1474
19.9k
    if (ps->iid_mode >= 3)
1475
8.28k
    {
1476
8.28k
        no_iid_steps = 15;
1477
8.28k
        sf_iid = sf_iid_fine;
1478
11.6k
    } else {
1479
11.6k
        no_iid_steps = 7;
1480
11.6k
        sf_iid = sf_iid_normal;
1481
11.6k
    }
1482
1483
19.9k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
11.8k
    {
1485
11.8k
        nr_ipdopd_par = 11; /* resolution */
1486
11.8k
    } else {
1487
8.07k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
8.07k
    }
1489
1490
669k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
649k
    {
1492
649k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
649k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
2.16M
        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
403
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
403
                    -no_iid_steps);
1507
403
                ps->iid_index[env][bk] = -no_iid_steps;
1508
403
                abs_iid = no_iid_steps;
1509
1.51M
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
232
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
232
                    no_iid_steps);
1512
232
                ps->iid_index[env][bk] = no_iid_steps;
1513
232
                abs_iid = no_iid_steps;
1514
232
            }
1515
1.51M
            if (ps->icc_index[env][bk] < 0) {
1516
496
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
496
                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
881k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
881k
                real_t c_1, c_2;  // COEF
1527
881k
                real_t cosa, sina;  // COEF
1528
881k
                real_t cosb, sinb;  // COEF
1529
881k
                real_t ab1, ab2;  // COEF
1530
881k
                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
881k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
881k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
881k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
881k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
881k
                if (ps->iid_mode >= 3)
1550
298k
                {
1551
298k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
298k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
583k
                } else {
1554
583k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
583k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
583k
                }
1557
1558
881k
                ab1 = MUL_C(cosb, cosa);
1559
881k
                ab2 = MUL_C(sinb, sina);
1560
881k
                ab3 = MUL_C(sinb, cosa);
1561
881k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
881k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
881k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
881k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
881k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
881k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
635k
                real_t sina, cosa;  // COEF
1571
635k
                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
635k
                if (ps->iid_mode >= 3)
1607
418k
                {
1608
418k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
418k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
418k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
418k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
418k
                } else {
1613
216k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
216k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
216k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
216k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
216k
                }
1618
1619
635k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
635k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
635k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
635k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
635k
            }
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
181k
            {
1632
181k
                int8_t i;
1633
181k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
181k
                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
90.6k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
90.6k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
90.6k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
90.6k
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
90.4k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
90.4k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
90.4k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
90.4k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
#endif
1652
1653
                /* save current value */
1654
181k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
181k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
181k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
181k
                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
90.6k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
90.6k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
90.6k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
90.6k
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
90.4k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
90.4k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
90.4k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
90.4k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
#endif
1672
1673
                /* ringbuffer index */
1674
181k
                if (i == 0)
1675
91.4k
                {
1676
91.4k
                    i = 2;
1677
91.4k
                }
1678
181k
                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
90.6k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
90.6k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
90.6k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
90.6k
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
90.4k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
90.4k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
90.4k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
90.4k
                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
181k
                xy = magnitude_c(tempRight);
1716
181k
                pq = magnitude_c(tempLeft);
1717
1718
181k
                if (xy != 0)
1719
181k
                {
1720
181k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
181k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
181k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
181k
                xypq = MUL_F(xy, pq);
1728
1729
181k
                if (xypq != 0)
1730
181k
                {
1731
181k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
181k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
181k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
181k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
181k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
181k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
181k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
181k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
181k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
181k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
181k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
181k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
181k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
181k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
181k
            }
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
181k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
181k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
181k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
181k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
181k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
181k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
181k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
181k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
181k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
181k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
25.9k
                {
1792
25.9k
                    IM(deltaH11) = -IM(deltaH11);
1793
25.9k
                    IM(deltaH12) = -IM(deltaH12);
1794
25.9k
                    IM(deltaH21) = -IM(deltaH21);
1795
25.9k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
25.9k
                    IM(H11) = -IM(H11);
1798
25.9k
                    IM(H12) = -IM(H12);
1799
25.9k
                    IM(H21) = -IM(H21);
1800
25.9k
                    IM(H22) = -IM(H22);
1801
25.9k
                }
1802
1803
181k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
181k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
181k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
181k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
181k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
21.7M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
20.2M
            {
1812
                /* addition finalises the interpolation over every n */
1813
20.2M
                RE(H11) += RE(deltaH11);
1814
20.2M
                RE(H12) += RE(deltaH12);
1815
20.2M
                RE(H21) += RE(deltaH21);
1816
20.2M
                RE(H22) += RE(deltaH22);
1817
20.2M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
1.87M
                {
1819
1.87M
                    IM(H11) += IM(deltaH11);
1820
1.87M
                    IM(H12) += IM(deltaH12);
1821
1.87M
                    IM(H21) += IM(deltaH21);
1822
1.87M
                    IM(H22) += IM(deltaH22);
1823
1.87M
                }
1824
1825
                /* channel is an alias to the subband */
1826
69.0M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
48.8M
                {
1828
48.8M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
48.8M
                    if (gr < ps->num_hybrid_groups)
1832
11.3M
                    {
1833
11.3M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
11.3M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
11.3M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
11.3M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
37.5M
                    } else {
1838
37.5M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
37.5M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
37.5M
                        RE(inRight) = RE(X_right[n][sb]);
1841
37.5M
                        IM(inRight) = IM(X_right[n][sb]);
1842
37.5M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
48.8M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
48.8M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
48.8M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
48.8M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
48.8M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.88M
                    {
1855
                        /* apply rotation */
1856
1.88M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.88M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.88M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.88M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.88M
                    }
1861
1862
                    /* store final samples */
1863
48.8M
                    if (gr < ps->num_hybrid_groups)
1864
11.3M
                    {
1865
11.3M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
11.3M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
11.3M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
11.3M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
37.5M
                    } else {
1870
37.5M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
37.5M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
37.5M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
37.5M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
37.5M
                    }
1875
48.8M
                }
1876
20.2M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
1.51M
            ps->phase_hist++;
1880
1.51M
            if (ps->phase_hist == 2)
1881
758k
            {
1882
758k
                ps->phase_hist = 0;
1883
758k
            }
1884
1.51M
        }
1885
649k
    }
1886
19.9k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
8.98k
{
1459
8.98k
    uint8_t n;
1460
8.98k
    uint8_t gr;
1461
8.98k
    uint8_t bk = 0;
1462
8.98k
    uint8_t sb, maxsb;
1463
8.98k
    uint8_t env;
1464
8.98k
    uint8_t nr_ipdopd_par;
1465
8.98k
    complex_t h11, h12, h21, h22;  // COEF
1466
8.98k
    complex_t H11, H12, H21, H22;  // COEF
1467
8.98k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
8.98k
    complex_t tempLeft, tempRight; // FRAC
1469
8.98k
    complex_t phaseLeft, phaseRight; // FRAC
1470
8.98k
    real_t L;
1471
8.98k
    const real_t *sf_iid;
1472
8.98k
    uint8_t no_iid_steps;
1473
1474
8.98k
    if (ps->iid_mode >= 3)
1475
3.50k
    {
1476
3.50k
        no_iid_steps = 15;
1477
3.50k
        sf_iid = sf_iid_fine;
1478
5.47k
    } else {
1479
5.47k
        no_iid_steps = 7;
1480
5.47k
        sf_iid = sf_iid_normal;
1481
5.47k
    }
1482
1483
8.98k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
5.27k
    {
1485
5.27k
        nr_ipdopd_par = 11; /* resolution */
1486
5.27k
    } else {
1487
3.70k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
3.70k
    }
1489
1490
304k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
295k
    {
1492
295k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
295k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.00M
        for (env = 0; env < ps->num_env; env++)
1498
709k
        {
1499
709k
            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
709k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
82
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
82
                    -no_iid_steps);
1507
82
                ps->iid_index[env][bk] = -no_iid_steps;
1508
82
                abs_iid = no_iid_steps;
1509
709k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
79
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
79
                    no_iid_steps);
1512
79
                ps->iid_index[env][bk] = no_iid_steps;
1513
79
                abs_iid = no_iid_steps;
1514
79
            }
1515
709k
            if (ps->icc_index[env][bk] < 0) {
1516
101
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
101
                ps->icc_index[env][bk] = 0;
1518
709k
            } 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
709k
            if (ps->icc_mode < 3)
1524
361k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
361k
                real_t c_1, c_2;  // COEF
1527
361k
                real_t cosa, sina;  // COEF
1528
361k
                real_t cosb, sinb;  // COEF
1529
361k
                real_t ab1, ab2;  // COEF
1530
361k
                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
361k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
361k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
361k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
361k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
361k
                if (ps->iid_mode >= 3)
1550
64.0k
                {
1551
64.0k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
64.0k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
297k
                } else {
1554
297k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
297k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
297k
                }
1557
1558
361k
                ab1 = MUL_C(cosb, cosa);
1559
361k
                ab2 = MUL_C(sinb, sina);
1560
361k
                ab3 = MUL_C(sinb, cosa);
1561
361k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
361k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
361k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
361k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
361k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
361k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
348k
                real_t sina, cosa;  // COEF
1571
348k
                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
348k
                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
109k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
109k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
109k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
109k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
109k
                }
1618
1619
348k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
348k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
348k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
348k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
348k
            }
1624
709k
            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
709k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
90.6k
            {
1632
90.6k
                int8_t i;
1633
90.6k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
90.6k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
90.6k
#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
90.6k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
90.6k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
90.6k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
90.6k
                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
90.6k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
90.6k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
90.6k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
90.6k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
90.6k
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
90.6k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
90.6k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
90.6k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
90.6k
                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
90.6k
                if (i == 0)
1675
45.7k
                {
1676
45.7k
                    i = 2;
1677
45.7k
                }
1678
90.6k
                i--;
1679
1680
                /* get value before previous */
1681
90.6k
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
90.6k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
90.6k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
90.6k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
90.6k
                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
90.6k
                xy = magnitude_c(tempRight);
1716
90.6k
                pq = magnitude_c(tempLeft);
1717
1718
90.6k
                if (xy != 0)
1719
90.6k
                {
1720
90.6k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
90.6k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
90.6k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
90.6k
                xypq = MUL_F(xy, pq);
1728
1729
90.6k
                if (xypq != 0)
1730
90.6k
                {
1731
90.6k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
90.6k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
90.6k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
90.6k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
90.6k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
90.6k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
90.6k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
90.6k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
90.6k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
90.6k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
90.6k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
90.6k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
90.6k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
90.6k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
90.6k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
709k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
709k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
709k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
709k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
709k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
709k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
709k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
709k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
709k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
709k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
709k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
709k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
709k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
709k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
709k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
90.6k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
90.6k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
90.6k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
90.6k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
90.6k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
90.6k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
90.6k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
90.6k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
90.6k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
90.6k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
12.9k
                {
1792
12.9k
                    IM(deltaH11) = -IM(deltaH11);
1793
12.9k
                    IM(deltaH12) = -IM(deltaH12);
1794
12.9k
                    IM(deltaH21) = -IM(deltaH21);
1795
12.9k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
12.9k
                    IM(H11) = -IM(H11);
1798
12.9k
                    IM(H12) = -IM(H12);
1799
12.9k
                    IM(H21) = -IM(H21);
1800
12.9k
                    IM(H22) = -IM(H22);
1801
12.9k
                }
1802
1803
90.6k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
90.6k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
90.6k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
90.6k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
90.6k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
9.91M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
9.20M
            {
1812
                /* addition finalises the interpolation over every n */
1813
9.20M
                RE(H11) += RE(deltaH11);
1814
9.20M
                RE(H12) += RE(deltaH12);
1815
9.20M
                RE(H21) += RE(deltaH21);
1816
9.20M
                RE(H22) += RE(deltaH22);
1817
9.20M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
992k
                {
1819
992k
                    IM(H11) += IM(deltaH11);
1820
992k
                    IM(H12) += IM(deltaH12);
1821
992k
                    IM(H21) += IM(deltaH21);
1822
992k
                    IM(H22) += IM(deltaH22);
1823
992k
                }
1824
1825
                /* channel is an alias to the subband */
1826
31.2M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
22.0M
                {
1828
22.0M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
22.0M
                    if (gr < ps->num_hybrid_groups)
1832
5.18M
                    {
1833
5.18M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
5.18M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
5.18M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
5.18M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
16.9M
                    } else {
1838
16.9M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
16.9M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
16.9M
                        RE(inRight) = RE(X_right[n][sb]);
1841
16.9M
                        IM(inRight) = IM(X_right[n][sb]);
1842
16.9M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
22.0M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
22.0M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
22.0M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
22.0M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
22.0M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
996k
                    {
1855
                        /* apply rotation */
1856
996k
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
996k
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
996k
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
996k
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
996k
                    }
1861
1862
                    /* store final samples */
1863
22.0M
                    if (gr < ps->num_hybrid_groups)
1864
5.18M
                    {
1865
5.18M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
5.18M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
5.18M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
5.18M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
16.9M
                    } else {
1870
16.9M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
16.9M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
16.9M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
16.9M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
16.9M
                    }
1875
22.0M
                }
1876
9.20M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
709k
            ps->phase_hist++;
1880
709k
            if (ps->phase_hist == 2)
1881
354k
            {
1882
354k
                ps->phase_hist = 0;
1883
354k
            }
1884
709k
        }
1885
295k
    }
1886
8.98k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
10.9k
{
1459
10.9k
    uint8_t n;
1460
10.9k
    uint8_t gr;
1461
10.9k
    uint8_t bk = 0;
1462
10.9k
    uint8_t sb, maxsb;
1463
10.9k
    uint8_t env;
1464
10.9k
    uint8_t nr_ipdopd_par;
1465
10.9k
    complex_t h11, h12, h21, h22;  // COEF
1466
10.9k
    complex_t H11, H12, H21, H22;  // COEF
1467
10.9k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
10.9k
    complex_t tempLeft, tempRight; // FRAC
1469
10.9k
    complex_t phaseLeft, phaseRight; // FRAC
1470
10.9k
    real_t L;
1471
10.9k
    const real_t *sf_iid;
1472
10.9k
    uint8_t no_iid_steps;
1473
1474
10.9k
    if (ps->iid_mode >= 3)
1475
4.78k
    {
1476
4.78k
        no_iid_steps = 15;
1477
4.78k
        sf_iid = sf_iid_fine;
1478
6.15k
    } else {
1479
6.15k
        no_iid_steps = 7;
1480
6.15k
        sf_iid = sf_iid_normal;
1481
6.15k
    }
1482
1483
10.9k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
6.57k
    {
1485
6.57k
        nr_ipdopd_par = 11; /* resolution */
1486
6.57k
    } else {
1487
4.36k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
4.36k
    }
1489
1490
364k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
353k
    {
1492
353k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
353k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.16M
        for (env = 0; env < ps->num_env; env++)
1498
806k
        {
1499
806k
            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
806k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
321
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
321
                    -no_iid_steps);
1507
321
                ps->iid_index[env][bk] = -no_iid_steps;
1508
321
                abs_iid = no_iid_steps;
1509
806k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
153
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
153
                    no_iid_steps);
1512
153
                ps->iid_index[env][bk] = no_iid_steps;
1513
153
                abs_iid = no_iid_steps;
1514
153
            }
1515
806k
            if (ps->icc_index[env][bk] < 0) {
1516
395
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
395
                ps->icc_index[env][bk] = 0;
1518
806k
            } 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
806k
            if (ps->icc_mode < 3)
1524
520k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
520k
                real_t c_1, c_2;  // COEF
1527
520k
                real_t cosa, sina;  // COEF
1528
520k
                real_t cosb, sinb;  // COEF
1529
520k
                real_t ab1, ab2;  // COEF
1530
520k
                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
520k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
520k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
520k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
520k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
520k
                if (ps->iid_mode >= 3)
1550
234k
                {
1551
234k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
234k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
285k
                } else {
1554
285k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
285k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
285k
                }
1557
1558
520k
                ab1 = MUL_C(cosb, cosa);
1559
520k
                ab2 = MUL_C(sinb, sina);
1560
520k
                ab3 = MUL_C(sinb, cosa);
1561
520k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
520k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
520k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
520k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
520k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
520k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
286k
                real_t sina, cosa;  // COEF
1571
286k
                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
286k
                if (ps->iid_mode >= 3)
1607
179k
                {
1608
179k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
179k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
179k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
179k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
179k
                } else {
1613
107k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
107k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
107k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
107k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
107k
                }
1618
1619
286k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
286k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
286k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
286k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
286k
            }
1624
806k
            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
806k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
90.4k
            {
1632
90.4k
                int8_t i;
1633
90.4k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
90.4k
                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
90.4k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
90.4k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
90.4k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
90.4k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
90.4k
#endif
1652
1653
                /* save current value */
1654
90.4k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
90.4k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
90.4k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
90.4k
                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
90.4k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
90.4k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
90.4k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
90.4k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
90.4k
#endif
1672
1673
                /* ringbuffer index */
1674
90.4k
                if (i == 0)
1675
45.6k
                {
1676
45.6k
                    i = 2;
1677
45.6k
                }
1678
90.4k
                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
90.4k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
90.4k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
90.4k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
90.4k
                IM(tempRight) += MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1692
90.4k
#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
90.4k
                xy = magnitude_c(tempRight);
1716
90.4k
                pq = magnitude_c(tempLeft);
1717
1718
90.4k
                if (xy != 0)
1719
90.4k
                {
1720
90.4k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
90.4k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
90.4k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
90.4k
                xypq = MUL_F(xy, pq);
1728
1729
90.4k
                if (xypq != 0)
1730
90.4k
                {
1731
90.4k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
90.4k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
90.4k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
90.4k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
90.4k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
90.4k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
90.4k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
90.4k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
90.4k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
90.4k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
90.4k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
90.4k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
90.4k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
90.4k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
90.4k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
806k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
806k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
806k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
806k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
806k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
806k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
806k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
806k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
806k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
806k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
806k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
806k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
806k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
806k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
806k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
90.4k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
90.4k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
90.4k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
90.4k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
90.4k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
90.4k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
90.4k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
90.4k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
90.4k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
90.4k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
13.0k
                {
1792
13.0k
                    IM(deltaH11) = -IM(deltaH11);
1793
13.0k
                    IM(deltaH12) = -IM(deltaH12);
1794
13.0k
                    IM(deltaH21) = -IM(deltaH21);
1795
13.0k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
13.0k
                    IM(H11) = -IM(H11);
1798
13.0k
                    IM(H12) = -IM(H12);
1799
13.0k
                    IM(H21) = -IM(H21);
1800
13.0k
                    IM(H22) = -IM(H22);
1801
13.0k
                }
1802
1803
90.4k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
90.4k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
90.4k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
90.4k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
90.4k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
11.8M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
10.9M
            {
1812
                /* addition finalises the interpolation over every n */
1813
10.9M
                RE(H11) += RE(deltaH11);
1814
10.9M
                RE(H12) += RE(deltaH12);
1815
10.9M
                RE(H21) += RE(deltaH21);
1816
10.9M
                RE(H22) += RE(deltaH22);
1817
10.9M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
885k
                {
1819
885k
                    IM(H11) += IM(deltaH11);
1820
885k
                    IM(H12) += IM(deltaH12);
1821
885k
                    IM(H21) += IM(deltaH21);
1822
885k
                    IM(H22) += IM(deltaH22);
1823
885k
                }
1824
1825
                /* channel is an alias to the subband */
1826
37.7M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
26.7M
                {
1828
26.7M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
26.7M
                    if (gr < ps->num_hybrid_groups)
1832
6.14M
                    {
1833
6.14M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
6.14M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
6.14M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
6.14M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
20.6M
                    } else {
1838
20.6M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
20.6M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
20.6M
                        RE(inRight) = RE(X_right[n][sb]);
1841
20.6M
                        IM(inRight) = IM(X_right[n][sb]);
1842
20.6M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
26.7M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
26.7M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
26.7M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
26.7M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
26.7M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
889k
                    {
1855
                        /* apply rotation */
1856
889k
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
889k
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
889k
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
889k
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
889k
                    }
1861
1862
                    /* store final samples */
1863
26.7M
                    if (gr < ps->num_hybrid_groups)
1864
6.14M
                    {
1865
6.14M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
6.14M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
6.14M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
6.14M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
20.6M
                    } else {
1870
20.6M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
20.6M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
20.6M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
20.6M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
20.6M
                    }
1875
26.7M
                }
1876
10.9M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
806k
            ps->phase_hist++;
1880
806k
            if (ps->phase_hist == 2)
1881
403k
            {
1882
403k
                ps->phase_hist = 0;
1883
403k
            }
1884
806k
        }
1885
353k
    }
1886
10.9k
}
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
908k
    {
1962
908k
        ps->delay_D[i] = 1;
1963
908k
    }
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.5k
{
1898
14.5k
    uint8_t i;
1899
14.5k
    uint8_t short_delay_band;
1900
1901
14.5k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
14.5k
    memset(ps, 0, sizeof(ps_info));
1903
1904
14.5k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
14.5k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
14.5k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
14.5k
    ps->saved_delay = 0;
1911
1912
948k
    for (i = 0; i < 64; i++)
1913
933k
    {
1914
933k
        ps->delay_buf_index_delay[i] = 0;
1915
933k
    }
1916
1917
58.3k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
43.7k
    {
1919
43.7k
        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.7k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
43.7k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
43.7k
#endif
1932
43.7k
    }
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.5k
    short_delay_band = 35;
1950
14.5k
    ps->nr_allpass_bands = 22;
1951
14.5k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
14.5k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
14.5k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
525k
    for (i = 0; i < short_delay_band; i++)
1957
510k
    {
1958
510k
        ps->delay_D[i] = 14;
1959
510k
    }
1960
437k
    for (i = short_delay_band; i < 64; i++)
1961
423k
    {
1962
423k
        ps->delay_D[i] = 1;
1963
423k
    }
1964
1965
    /* mixing and phase */
1966
744k
    for (i = 0; i < 50; i++)
1967
729k
    {
1968
729k
        RE(ps->h11_prev[i]) = 1;
1969
729k
        IM(ps->h11_prev[i]) = 1;
1970
729k
        RE(ps->h12_prev[i]) = 1;
1971
729k
        IM(ps->h12_prev[i]) = 1;
1972
729k
    }
1973
1974
14.5k
    ps->phase_hist = 0;
1975
1976
306k
    for (i = 0; i < 20; i++)
1977
291k
    {
1978
291k
        RE(ps->ipd_prev[i][0]) = 0;
1979
291k
        IM(ps->ipd_prev[i][0]) = 0;
1980
291k
        RE(ps->ipd_prev[i][1]) = 0;
1981
291k
        IM(ps->ipd_prev[i][1]) = 0;
1982
291k
        RE(ps->opd_prev[i][0]) = 0;
1983
291k
        IM(ps->opd_prev[i][0]) = 0;
1984
291k
        RE(ps->opd_prev[i][1]) = 0;
1985
291k
        IM(ps->opd_prev[i][1]) = 0;
1986
291k
    }
1987
1988
14.5k
    return ps;
1989
14.5k
}
ps_init
Line
Count
Source
1897
16.7k
{
1898
16.7k
    uint8_t i;
1899
16.7k
    uint8_t short_delay_band;
1900
1901
16.7k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
16.7k
    memset(ps, 0, sizeof(ps_info));
1903
1904
16.7k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
16.7k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
16.7k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
16.7k
    ps->saved_delay = 0;
1911
1912
1.08M
    for (i = 0; i < 64; i++)
1913
1.07M
    {
1914
1.07M
        ps->delay_buf_index_delay[i] = 0;
1915
1.07M
    }
1916
1917
66.9k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
50.2k
    {
1919
50.2k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
50.2k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
50.2k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
50.2k
#endif
1932
50.2k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
16.7k
    short_delay_band = 35;
1950
16.7k
    ps->nr_allpass_bands = 22;
1951
16.7k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
16.7k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
16.7k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
602k
    for (i = 0; i < short_delay_band; i++)
1957
585k
    {
1958
585k
        ps->delay_D[i] = 14;
1959
585k
    }
1960
502k
    for (i = short_delay_band; i < 64; i++)
1961
485k
    {
1962
485k
        ps->delay_D[i] = 1;
1963
485k
    }
1964
1965
    /* mixing and phase */
1966
853k
    for (i = 0; i < 50; i++)
1967
836k
    {
1968
836k
        RE(ps->h11_prev[i]) = 1;
1969
836k
        IM(ps->h11_prev[i]) = 1;
1970
836k
        RE(ps->h12_prev[i]) = 1;
1971
836k
        IM(ps->h12_prev[i]) = 1;
1972
836k
    }
1973
1974
16.7k
    ps->phase_hist = 0;
1975
1976
351k
    for (i = 0; i < 20; i++)
1977
334k
    {
1978
334k
        RE(ps->ipd_prev[i][0]) = 0;
1979
334k
        IM(ps->ipd_prev[i][0]) = 0;
1980
334k
        RE(ps->ipd_prev[i][1]) = 0;
1981
334k
        IM(ps->ipd_prev[i][1]) = 0;
1982
334k
        RE(ps->opd_prev[i][0]) = 0;
1983
334k
        IM(ps->opd_prev[i][0]) = 0;
1984
334k
        RE(ps->opd_prev[i][1]) = 0;
1985
334k
        IM(ps->opd_prev[i][1]) = 0;
1986
334k
    }
1987
1988
16.7k
    return ps;
1989
16.7k
}
1990
1991
/* main Parametric Stereo decoding function */
1992
uint8_t ps_decode(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64])
1993
19.9k
{
1994
19.9k
    qmf_t X_hybrid_left[32][32] = {{{0}}};
1995
19.9k
    qmf_t X_hybrid_right[32][32] = {{{0}}};
1996
1997
    /* delta decoding of the bitstream data */
1998
19.9k
    ps_data_decode(ps);
1999
2000
    /* set up some parameters depending on filterbank type */
2001
19.9k
    if (ps->use34hybrid_bands)
2002
7.53k
    {
2003
7.53k
        ps->group_border = (uint8_t*)group_border34;
2004
7.53k
        ps->map_group2bk = (uint16_t*)map_group2bk34;
2005
7.53k
        ps->num_groups = 32+18;
2006
7.53k
        ps->num_hybrid_groups = 32;
2007
7.53k
        ps->nr_par_bands = 34;
2008
7.53k
        ps->decay_cutoff = 5;
2009
12.3k
    } else {
2010
12.3k
        ps->group_border = (uint8_t*)group_border20;
2011
12.3k
        ps->map_group2bk = (uint16_t*)map_group2bk20;
2012
12.3k
        ps->num_groups = 10+12;
2013
12.3k
        ps->num_hybrid_groups = 10;
2014
12.3k
        ps->nr_par_bands = 20;
2015
12.3k
        ps->decay_cutoff = 3;
2016
12.3k
    }
2017
2018
    /* Perform further analysis on the lowest subbands to get a higher
2019
     * frequency resolution
2020
     */
2021
19.9k
    hybrid_analysis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2022
19.9k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2023
2024
    /* decorrelate mono signal */
2025
19.9k
    ps_decorrelate(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2026
2027
    /* apply mixing and phase parameters */
2028
19.9k
    ps_mix_phase(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2029
2030
    /* hybrid synthesis, to rebuild the SBR QMF matrices */
2031
19.9k
    hybrid_synthesis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2032
19.9k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2033
2034
19.9k
    hybrid_synthesis((hyb_info*)ps->hyb, X_right, X_hybrid_right,
2035
19.9k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2036
2037
19.9k
    return 0;
2038
19.9k
}
2039
2040
#endif