Coverage Report

Created: 2026-01-10 06:29

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