Coverage Report

Created: 2025-08-26 06:13

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