Coverage Report

Created: 2025-10-13 06:47

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
53.0M
#define NEGATE_IPD_MASK            (0x1000)
42
398k
#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.1k
{
198
32.1k
    uint8_t i;
199
200
32.1k
    hyb_info *hyb = (hyb_info*)faad_malloc(sizeof(hyb_info));
201
202
32.1k
    hyb->resolution34[0] = 12;
203
32.1k
    hyb->resolution34[1] = 8;
204
32.1k
    hyb->resolution34[2] = 4;
205
32.1k
    hyb->resolution34[3] = 4;
206
32.1k
    hyb->resolution34[4] = 4;
207
208
32.1k
    hyb->resolution20[0] = 8;
209
32.1k
    hyb->resolution20[1] = 2;
210
32.1k
    hyb->resolution20[2] = 2;
211
212
32.1k
    hyb->frame_len = numTimeSlotsRate;
213
214
32.1k
    hyb->work = (qmf_t*)faad_malloc((hyb->frame_len+12) * sizeof(qmf_t));
215
32.1k
    memset(hyb->work, 0, (hyb->frame_len+12) * sizeof(qmf_t));
216
217
32.1k
    hyb->buffer = (qmf_t**)faad_malloc(5 * sizeof(qmf_t*));
218
192k
    for (i = 0; i < 5; i++)
219
160k
    {
220
160k
        hyb->buffer[i] = (qmf_t*)faad_malloc(hyb->frame_len * sizeof(qmf_t));
221
160k
        memset(hyb->buffer[i], 0, hyb->frame_len * sizeof(qmf_t));
222
160k
    }
223
224
32.1k
    hyb->temp = (qmf_t**)faad_malloc(hyb->frame_len * sizeof(qmf_t*));
225
1.04M
    for (i = 0; i < hyb->frame_len; i++)
226
1.01M
    {
227
1.01M
        hyb->temp[i] = (qmf_t*)faad_malloc(12 /*max*/ * sizeof(qmf_t));
228
1.01M
    }
229
230
32.1k
    return hyb;
231
32.1k
}
232
233
static void hybrid_free(hyb_info *hyb)
234
32.1k
{
235
32.1k
    uint8_t i;
236
237
32.1k
  if (!hyb) return;
238
239
32.1k
    if (hyb->work)
240
32.1k
        faad_free(hyb->work);
241
242
192k
    for (i = 0; i < 5; i++)
243
160k
    {
244
160k
        if (hyb->buffer[i])
245
160k
            faad_free(hyb->buffer[i]);
246
160k
    }
247
32.1k
    if (hyb->buffer)
248
32.1k
        faad_free(hyb->buffer);
249
250
1.04M
    for (i = 0; i < hyb->frame_len; i++)
251
1.01M
    {
252
1.01M
        if (hyb->temp[i])
253
1.01M
            faad_free(hyb->temp[i]);
254
1.01M
    }
255
32.1k
    if (hyb->temp)
256
32.1k
        faad_free(hyb->temp);
257
258
32.1k
    faad_free(hyb);
259
32.1k
}
260
261
/* real filter, size 2 */
262
static void channel_filter2(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
263
                            qmf_t *buffer, qmf_t **X_hybrid)
264
51.8k
{
265
51.8k
    uint8_t i;
266
51.8k
    (void)hyb;  /* TODO: remove parameter? */
267
268
1.67M
    for (i = 0; i < frame_len; i++)
269
1.62M
    {
270
1.62M
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
1.62M
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
1.62M
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
1.62M
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
1.62M
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
1.62M
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
1.62M
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
1.62M
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
1.62M
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
1.62M
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
1.62M
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
1.62M
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
1.62M
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
1.62M
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
1.62M
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
1.62M
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
1.62M
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
1.62M
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
1.62M
    }
293
51.8k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
25.9k
{
265
25.9k
    uint8_t i;
266
25.9k
    (void)hyb;  /* TODO: remove parameter? */
267
268
839k
    for (i = 0; i < frame_len; i++)
269
813k
    {
270
813k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
813k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
813k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
813k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
813k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
813k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
813k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
813k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
813k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
813k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
813k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
813k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
813k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
813k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
813k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
813k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
813k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
813k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
813k
    }
293
25.9k
}
ps_dec.c:channel_filter2
Line
Count
Source
264
25.9k
{
265
25.9k
    uint8_t i;
266
25.9k
    (void)hyb;  /* TODO: remove parameter? */
267
268
839k
    for (i = 0; i < frame_len; i++)
269
813k
    {
270
813k
        real_t r0 = MUL_F(filter[0],(QMF_RE(buffer[0+i]) + QMF_RE(buffer[12+i])));
271
813k
        real_t r1 = MUL_F(filter[1],(QMF_RE(buffer[1+i]) + QMF_RE(buffer[11+i])));
272
813k
        real_t r2 = MUL_F(filter[2],(QMF_RE(buffer[2+i]) + QMF_RE(buffer[10+i])));
273
813k
        real_t r3 = MUL_F(filter[3],(QMF_RE(buffer[3+i]) + QMF_RE(buffer[9+i])));
274
813k
        real_t r4 = MUL_F(filter[4],(QMF_RE(buffer[4+i]) + QMF_RE(buffer[8+i])));
275
813k
        real_t r5 = MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
276
813k
        real_t r6 = MUL_F(filter[6],QMF_RE(buffer[6+i]));
277
813k
        real_t i0 = MUL_F(filter[0],(QMF_IM(buffer[0+i]) + QMF_IM(buffer[12+i])));
278
813k
        real_t i1 = MUL_F(filter[1],(QMF_IM(buffer[1+i]) + QMF_IM(buffer[11+i])));
279
813k
        real_t i2 = MUL_F(filter[2],(QMF_IM(buffer[2+i]) + QMF_IM(buffer[10+i])));
280
813k
        real_t i3 = MUL_F(filter[3],(QMF_IM(buffer[3+i]) + QMF_IM(buffer[9+i])));
281
813k
        real_t i4 = MUL_F(filter[4],(QMF_IM(buffer[4+i]) + QMF_IM(buffer[8+i])));
282
813k
        real_t i5 = MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
283
813k
        real_t i6 = MUL_F(filter[6],QMF_IM(buffer[6+i]));
284
285
        /* q = 0 */
286
813k
        QMF_RE(X_hybrid[i][0]) = r0 + r1 + r2 + r3 + r4 + r5 + r6;
287
813k
        QMF_IM(X_hybrid[i][0]) = i0 + i1 + i2 + i3 + i4 + i5 + i6;
288
289
        /* q = 1 */
290
813k
        QMF_RE(X_hybrid[i][1]) = r0 - r1 + r2 - r3 + r4 - r5 + r6;
291
813k
        QMF_IM(X_hybrid[i][1]) = i0 - i1 + i2 - i3 + i4 - i5 + i6;
292
813k
    }
293
25.9k
}
294
295
/* complex filter, size 4 */
296
static void channel_filter4(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
297
                            qmf_t *buffer, qmf_t **X_hybrid)
298
24.0k
{
299
24.0k
    uint8_t i;
300
24.0k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
24.0k
    (void)hyb;  /* TODO: remove parameter? */
302
303
763k
    for (i = 0; i < frame_len; i++)
304
739k
    {
305
739k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
739k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
739k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
739k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
739k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
739k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
739k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
739k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
739k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
739k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
739k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
739k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
739k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
739k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
739k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
739k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
739k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
739k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
739k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
739k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
739k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
739k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
739k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
739k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
739k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
739k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
739k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
739k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
739k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
739k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
739k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
739k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
739k
    }
349
24.0k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
11.6k
{
299
11.6k
    uint8_t i;
300
11.6k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
11.6k
    (void)hyb;  /* TODO: remove parameter? */
302
303
368k
    for (i = 0; i < frame_len; i++)
304
357k
    {
305
357k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
357k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
357k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
357k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
357k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
357k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
357k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
357k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
357k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
357k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
357k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
357k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
357k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
357k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
357k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
357k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
357k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
357k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
357k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
357k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
357k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
357k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
357k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
357k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
357k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
357k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
357k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
357k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
357k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
357k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
357k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
357k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
357k
    }
349
11.6k
}
ps_dec.c:channel_filter4
Line
Count
Source
298
12.4k
{
299
12.4k
    uint8_t i;
300
12.4k
    real_t input_re1[2], input_re2[2], input_im1[2], input_im2[2];
301
12.4k
    (void)hyb;  /* TODO: remove parameter? */
302
303
394k
    for (i = 0; i < frame_len; i++)
304
382k
    {
305
382k
        input_re1[0] = -MUL_F(filter[2], (QMF_RE(buffer[i+2]) + QMF_RE(buffer[i+10]))) +
306
382k
            MUL_F(filter[6], QMF_RE(buffer[i+6]));
307
382k
        input_re1[1] = MUL_F(FRAC_CONST(-0.70710678118655),
308
382k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) + QMF_RE(buffer[i+11]))) +
309
382k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) + QMF_RE(buffer[i+9]))) -
310
382k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) + QMF_RE(buffer[i+7])))));
311
312
382k
        input_im1[0] = MUL_F(filter[0], (QMF_IM(buffer[i+0]) - QMF_IM(buffer[i+12]))) -
313
382k
            MUL_F(filter[4], (QMF_IM(buffer[i+4]) - QMF_IM(buffer[i+8])));
314
382k
        input_im1[1] = MUL_F(FRAC_CONST(0.70710678118655),
315
382k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) - QMF_IM(buffer[i+11]))) -
316
382k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) - QMF_IM(buffer[i+9]))) -
317
382k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) - QMF_IM(buffer[i+7])))));
318
319
382k
        input_re2[0] = MUL_F(filter[0], (QMF_RE(buffer[i+0]) - QMF_RE(buffer[i+12]))) -
320
382k
            MUL_F(filter[4], (QMF_RE(buffer[i+4]) - QMF_RE(buffer[i+8])));
321
382k
        input_re2[1] = MUL_F(FRAC_CONST(0.70710678118655),
322
382k
            (MUL_F(filter[1], (QMF_RE(buffer[i+1]) - QMF_RE(buffer[i+11]))) -
323
382k
            MUL_F(filter[3], (QMF_RE(buffer[i+3]) - QMF_RE(buffer[i+9]))) -
324
382k
            MUL_F(filter[5], (QMF_RE(buffer[i+5]) - QMF_RE(buffer[i+7])))));
325
326
382k
        input_im2[0] = -MUL_F(filter[2], (QMF_IM(buffer[i+2]) + QMF_IM(buffer[i+10]))) +
327
382k
            MUL_F(filter[6], QMF_IM(buffer[i+6]));
328
382k
        input_im2[1] = MUL_F(FRAC_CONST(-0.70710678118655),
329
382k
            (MUL_F(filter[1], (QMF_IM(buffer[i+1]) + QMF_IM(buffer[i+11]))) +
330
382k
            MUL_F(filter[3], (QMF_IM(buffer[i+3]) + QMF_IM(buffer[i+9]))) -
331
382k
            MUL_F(filter[5], (QMF_IM(buffer[i+5]) + QMF_IM(buffer[i+7])))));
332
333
        /* q == 0 */
334
382k
        QMF_RE(X_hybrid[i][0]) =  input_re1[0] + input_re1[1] + input_im1[0] + input_im1[1];
335
382k
        QMF_IM(X_hybrid[i][0]) = -input_re2[0] - input_re2[1] + input_im2[0] + input_im2[1];
336
337
        /* q == 1 */
338
382k
        QMF_RE(X_hybrid[i][1]) =  input_re1[0] - input_re1[1] - input_im1[0] + input_im1[1];
339
382k
        QMF_IM(X_hybrid[i][1]) =  input_re2[0] - input_re2[1] + input_im2[0] - input_im2[1];
340
341
        /* q == 2 */
342
382k
        QMF_RE(X_hybrid[i][2]) =  input_re1[0] - input_re1[1] + input_im1[0] - input_im1[1];
343
382k
        QMF_IM(X_hybrid[i][2]) = -input_re2[0] + input_re2[1] + input_im2[0] - input_im2[1];
344
345
        /* q == 3 */
346
382k
        QMF_RE(X_hybrid[i][3]) =  input_re1[0] + input_re1[1] - input_im1[0] - input_im1[1];
347
382k
        QMF_IM(X_hybrid[i][3]) =  input_re2[0] + input_re2[1] + input_im2[0] + input_im2[1];
348
382k
    }
349
12.4k
}
350
351
static void INLINE DCT3_4_unscaled(real_t *y, real_t *x)
352
2.61M
{
353
2.61M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
2.61M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
2.61M
    f1 = x[0] - f0;
357
2.61M
    f2 = x[0] + f0;
358
2.61M
    f3 = x[1] + x[3];
359
2.61M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
2.61M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
2.61M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
2.61M
    f7 = f4 + f5;
363
2.61M
    f8 = f6 - f5;
364
2.61M
    y[3] = f2 - f8;
365
2.61M
    y[0] = f2 + f8;
366
2.61M
    y[2] = f1 - f7;
367
2.61M
    y[1] = f1 + f7;
368
2.61M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.21M
{
353
1.21M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.21M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.21M
    f1 = x[0] - f0;
357
1.21M
    f2 = x[0] + f0;
358
1.21M
    f3 = x[1] + x[3];
359
1.21M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.21M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.21M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.21M
    f7 = f4 + f5;
363
1.21M
    f8 = f6 - f5;
364
1.21M
    y[3] = f2 - f8;
365
1.21M
    y[0] = f2 + f8;
366
1.21M
    y[2] = f1 - f7;
367
1.21M
    y[1] = f1 + f7;
368
1.21M
}
ps_dec.c:DCT3_4_unscaled
Line
Count
Source
352
1.39M
{
353
1.39M
    real_t f0, f1, f2, f3, f4, f5, f6, f7, f8;
354
355
1.39M
    f0 = MUL_F(x[2], FRAC_CONST(0.7071067811865476));
356
1.39M
    f1 = x[0] - f0;
357
1.39M
    f2 = x[0] + f0;
358
1.39M
    f3 = x[1] + x[3];
359
1.39M
    f4 = MUL_C(x[1], COEF_CONST(1.3065629648763766));
360
1.39M
    f5 = MUL_F(f3, FRAC_CONST(-0.9238795325112866));
361
1.39M
    f6 = MUL_F(x[3], FRAC_CONST(-0.5411961001461967));
362
1.39M
    f7 = f4 + f5;
363
1.39M
    f8 = f6 - f5;
364
1.39M
    y[3] = f2 - f8;
365
1.39M
    y[0] = f2 + f8;
366
1.39M
    y[2] = f1 - f7;
367
1.39M
    y[1] = f1 + f7;
368
1.39M
}
369
370
/* complex filter, size 8 */
371
static void channel_filter8(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
372
                            qmf_t *buffer, qmf_t **X_hybrid)
373
41.9k
{
374
41.9k
    uint8_t i, n;
375
41.9k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
41.9k
    real_t x[4];
377
41.9k
    (void)hyb;  /* TODO: remove parameter? */
378
379
1.34M
    for (i = 0; i < frame_len; i++)
380
1.30M
    {
381
1.30M
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
1.30M
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
1.30M
        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.30M
        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.30M
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
1.30M
        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.30M
        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.30M
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
6.53M
        for (n = 0; n < 4; n++)
392
5.22M
        {
393
5.22M
            x[n] = input_re1[n] - input_im1[3-n];
394
5.22M
        }
395
1.30M
        DCT3_4_unscaled(x, x);
396
1.30M
        QMF_RE(X_hybrid[i][7]) = x[0];
397
1.30M
        QMF_RE(X_hybrid[i][5]) = x[2];
398
1.30M
        QMF_RE(X_hybrid[i][3]) = x[3];
399
1.30M
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
6.53M
        for (n = 0; n < 4; n++)
402
5.22M
        {
403
5.22M
            x[n] = input_re1[n] + input_im1[3-n];
404
5.22M
        }
405
1.30M
        DCT3_4_unscaled(x, x);
406
1.30M
        QMF_RE(X_hybrid[i][6]) = x[1];
407
1.30M
        QMF_RE(X_hybrid[i][4]) = x[3];
408
1.30M
        QMF_RE(X_hybrid[i][2]) = x[2];
409
1.30M
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
1.30M
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
1.30M
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
1.30M
        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.30M
        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.30M
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
1.30M
        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.30M
        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.30M
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
6.53M
        for (n = 0; n < 4; n++)
422
5.22M
        {
423
5.22M
            x[n] = input_im2[n] + input_re2[3-n];
424
5.22M
        }
425
1.30M
        DCT3_4_unscaled(x, x);
426
1.30M
        QMF_IM(X_hybrid[i][7]) = x[0];
427
1.30M
        QMF_IM(X_hybrid[i][5]) = x[2];
428
1.30M
        QMF_IM(X_hybrid[i][3]) = x[3];
429
1.30M
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
6.53M
        for (n = 0; n < 4; n++)
432
5.22M
        {
433
5.22M
            x[n] = input_im2[n] - input_re2[3-n];
434
5.22M
        }
435
1.30M
        DCT3_4_unscaled(x, x);
436
1.30M
        QMF_IM(X_hybrid[i][6]) = x[1];
437
1.30M
        QMF_IM(X_hybrid[i][4]) = x[3];
438
1.30M
        QMF_IM(X_hybrid[i][2]) = x[2];
439
1.30M
        QMF_IM(X_hybrid[i][0]) = x[0];
440
1.30M
    }
441
41.9k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
20.9k
{
374
20.9k
    uint8_t i, n;
375
20.9k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
20.9k
    real_t x[4];
377
20.9k
    (void)hyb;  /* TODO: remove parameter? */
378
379
674k
    for (i = 0; i < frame_len; i++)
380
653k
    {
381
653k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
653k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
653k
        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
653k
        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
653k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
653k
        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
653k
        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
653k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.26M
        for (n = 0; n < 4; n++)
392
2.61M
        {
393
2.61M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.61M
        }
395
653k
        DCT3_4_unscaled(x, x);
396
653k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
653k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
653k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
653k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.26M
        for (n = 0; n < 4; n++)
402
2.61M
        {
403
2.61M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.61M
        }
405
653k
        DCT3_4_unscaled(x, x);
406
653k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
653k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
653k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
653k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
653k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
653k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
653k
        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
653k
        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
653k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
653k
        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
653k
        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
653k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.26M
        for (n = 0; n < 4; n++)
422
2.61M
        {
423
2.61M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.61M
        }
425
653k
        DCT3_4_unscaled(x, x);
426
653k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
653k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
653k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
653k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.26M
        for (n = 0; n < 4; n++)
432
2.61M
        {
433
2.61M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.61M
        }
435
653k
        DCT3_4_unscaled(x, x);
436
653k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
653k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
653k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
653k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
653k
    }
441
20.9k
}
ps_dec.c:channel_filter8
Line
Count
Source
373
20.9k
{
374
20.9k
    uint8_t i, n;
375
20.9k
    real_t input_re1[4], input_re2[4], input_im1[4], input_im2[4];
376
20.9k
    real_t x[4];
377
20.9k
    (void)hyb;  /* TODO: remove parameter? */
378
379
674k
    for (i = 0; i < frame_len; i++)
380
653k
    {
381
653k
        input_re1[0] =  MUL_F(filter[6],QMF_RE(buffer[6+i]));
382
653k
        input_re1[1] =  MUL_F(filter[5],(QMF_RE(buffer[5+i]) + QMF_RE(buffer[7+i])));
383
653k
        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
653k
        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
653k
        input_im1[0] = MUL_F(filter[5],(QMF_IM(buffer[7+i]) - QMF_IM(buffer[5+i])));
387
653k
        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
653k
        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
653k
        input_im1[3] = MUL_F(filter[2],(QMF_IM(buffer[10+i]) - QMF_IM(buffer[2+i])));
390
391
3.26M
        for (n = 0; n < 4; n++)
392
2.61M
        {
393
2.61M
            x[n] = input_re1[n] - input_im1[3-n];
394
2.61M
        }
395
653k
        DCT3_4_unscaled(x, x);
396
653k
        QMF_RE(X_hybrid[i][7]) = x[0];
397
653k
        QMF_RE(X_hybrid[i][5]) = x[2];
398
653k
        QMF_RE(X_hybrid[i][3]) = x[3];
399
653k
        QMF_RE(X_hybrid[i][1]) = x[1];
400
401
3.26M
        for (n = 0; n < 4; n++)
402
2.61M
        {
403
2.61M
            x[n] = input_re1[n] + input_im1[3-n];
404
2.61M
        }
405
653k
        DCT3_4_unscaled(x, x);
406
653k
        QMF_RE(X_hybrid[i][6]) = x[1];
407
653k
        QMF_RE(X_hybrid[i][4]) = x[3];
408
653k
        QMF_RE(X_hybrid[i][2]) = x[2];
409
653k
        QMF_RE(X_hybrid[i][0]) = x[0];
410
411
653k
        input_im2[0] =  MUL_F(filter[6],QMF_IM(buffer[6+i]));
412
653k
        input_im2[1] =  MUL_F(filter[5],(QMF_IM(buffer[5+i]) + QMF_IM(buffer[7+i])));
413
653k
        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
653k
        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
653k
        input_re2[0] = MUL_F(filter[5],(QMF_RE(buffer[7+i]) - QMF_RE(buffer[5+i])));
417
653k
        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
653k
        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
653k
        input_re2[3] = MUL_F(filter[2],(QMF_RE(buffer[10+i]) - QMF_RE(buffer[2+i])));
420
421
3.26M
        for (n = 0; n < 4; n++)
422
2.61M
        {
423
2.61M
            x[n] = input_im2[n] + input_re2[3-n];
424
2.61M
        }
425
653k
        DCT3_4_unscaled(x, x);
426
653k
        QMF_IM(X_hybrid[i][7]) = x[0];
427
653k
        QMF_IM(X_hybrid[i][5]) = x[2];
428
653k
        QMF_IM(X_hybrid[i][3]) = x[3];
429
653k
        QMF_IM(X_hybrid[i][1]) = x[1];
430
431
3.26M
        for (n = 0; n < 4; n++)
432
2.61M
        {
433
2.61M
            x[n] = input_im2[n] - input_re2[3-n];
434
2.61M
        }
435
653k
        DCT3_4_unscaled(x, x);
436
653k
        QMF_IM(X_hybrid[i][6]) = x[1];
437
653k
        QMF_IM(X_hybrid[i][4]) = x[3];
438
653k
        QMF_IM(X_hybrid[i][2]) = x[2];
439
653k
        QMF_IM(X_hybrid[i][0]) = x[0];
440
653k
    }
441
20.9k
}
442
443
static void INLINE DCT3_6_unscaled(real_t *y, real_t *x)
444
986k
{
445
986k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
986k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
986k
    f1 = x[0] + f0;
449
986k
    f2 = x[0] - f0;
450
986k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
986k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
986k
    f5 = f4 - x[4];
453
986k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
986k
    f7 = f6 - f3;
455
986k
    y[0] = f1 + f6 + f4;
456
986k
    y[1] = f2 + f3 - x[4];
457
986k
    y[2] = f7 + f2 - f5;
458
986k
    y[3] = f1 - f7 - f5;
459
986k
    y[4] = f1 - f3 - x[4];
460
986k
    y[5] = f2 - f6 + f4;
461
986k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
476k
{
445
476k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
476k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
476k
    f1 = x[0] + f0;
449
476k
    f2 = x[0] - f0;
450
476k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
476k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
476k
    f5 = f4 - x[4];
453
476k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
476k
    f7 = f6 - f3;
455
476k
    y[0] = f1 + f6 + f4;
456
476k
    y[1] = f2 + f3 - x[4];
457
476k
    y[2] = f7 + f2 - f5;
458
476k
    y[3] = f1 - f7 - f5;
459
476k
    y[4] = f1 - f3 - x[4];
460
476k
    y[5] = f2 - f6 + f4;
461
476k
}
ps_dec.c:DCT3_6_unscaled
Line
Count
Source
444
509k
{
445
509k
    real_t f0, f1, f2, f3, f4, f5, f6, f7;
446
447
509k
    f0 = MUL_F(x[3], FRAC_CONST(0.70710678118655));
448
509k
    f1 = x[0] + f0;
449
509k
    f2 = x[0] - f0;
450
509k
    f3 = MUL_F((x[1] - x[5]), FRAC_CONST(0.70710678118655));
451
509k
    f4 = MUL_F(x[2], FRAC_CONST(0.86602540378444)) + MUL_F(x[4], FRAC_CONST(0.5));
452
509k
    f5 = f4 - x[4];
453
509k
    f6 = MUL_F(x[1], FRAC_CONST(0.96592582628907)) + MUL_F(x[5], FRAC_CONST(0.25881904510252));
454
509k
    f7 = f6 - f3;
455
509k
    y[0] = f1 + f6 + f4;
456
509k
    y[1] = f2 + f3 - x[4];
457
509k
    y[2] = f7 + f2 - f5;
458
509k
    y[3] = f1 - f7 - f5;
459
509k
    y[4] = f1 - f3 - x[4];
460
509k
    y[5] = f2 - f6 + f4;
461
509k
}
462
463
/* complex filter, size 12 */
464
static void channel_filter12(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
465
                             qmf_t *buffer, qmf_t **X_hybrid)
466
16.0k
{
467
16.0k
    uint8_t i, n;
468
16.0k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
16.0k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
16.0k
    (void)hyb;  /* TODO: remove parameter? */
471
472
509k
    for (i = 0; i < frame_len; i++)
473
493k
    {
474
3.45M
        for (n = 0; n < 6; n++)
475
2.95M
        {
476
2.95M
            if (n == 0)
477
493k
            {
478
493k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
493k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
2.46M
            } else {
481
2.46M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
2.46M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
2.46M
            }
484
2.95M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
2.95M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
2.95M
        }
487
488
493k
        DCT3_6_unscaled(out_re1, input_re1);
489
493k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
493k
        DCT3_6_unscaled(out_im1, input_im1);
492
493k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
1.97M
        for (n = 0; n < 6; n += 2)
495
1.47M
        {
496
1.47M
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
1.47M
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
1.47M
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
1.47M
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
1.47M
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
1.47M
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
1.47M
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
1.47M
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
1.47M
        }
506
493k
    }
507
16.0k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
8.01k
{
467
8.01k
    uint8_t i, n;
468
8.01k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
8.01k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
8.01k
    (void)hyb;  /* TODO: remove parameter? */
471
472
254k
    for (i = 0; i < frame_len; i++)
473
246k
    {
474
1.72M
        for (n = 0; n < 6; n++)
475
1.47M
        {
476
1.47M
            if (n == 0)
477
246k
            {
478
246k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
246k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.23M
            } else {
481
1.23M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.23M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.23M
            }
484
1.47M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.47M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.47M
        }
487
488
246k
        DCT3_6_unscaled(out_re1, input_re1);
489
246k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
246k
        DCT3_6_unscaled(out_im1, input_im1);
492
246k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
986k
        for (n = 0; n < 6; n += 2)
495
739k
        {
496
739k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
739k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
739k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
739k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
739k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
739k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
739k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
739k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
739k
        }
506
246k
    }
507
8.01k
}
ps_dec.c:channel_filter12
Line
Count
Source
466
8.01k
{
467
8.01k
    uint8_t i, n;
468
8.01k
    real_t input_re1[6], input_re2[6], input_im1[6], input_im2[6];
469
8.01k
    real_t out_re1[6], out_re2[6], out_im1[6], out_im2[6];
470
8.01k
    (void)hyb;  /* TODO: remove parameter? */
471
472
254k
    for (i = 0; i < frame_len; i++)
473
246k
    {
474
1.72M
        for (n = 0; n < 6; n++)
475
1.47M
        {
476
1.47M
            if (n == 0)
477
246k
            {
478
246k
                input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
479
246k
                input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
480
1.23M
            } else {
481
1.23M
                input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
482
1.23M
                input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
483
1.23M
            }
484
1.47M
            input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
485
1.47M
            input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
486
1.47M
        }
487
488
246k
        DCT3_6_unscaled(out_re1, input_re1);
489
246k
        DCT3_6_unscaled(out_re2, input_re2);
490
491
246k
        DCT3_6_unscaled(out_im1, input_im1);
492
246k
        DCT3_6_unscaled(out_im2, input_im2);
493
494
986k
        for (n = 0; n < 6; n += 2)
495
739k
        {
496
739k
            QMF_RE(X_hybrid[i][n]) = out_re1[n] - out_im1[n];
497
739k
            QMF_IM(X_hybrid[i][n]) = out_re2[n] + out_im2[n];
498
739k
            QMF_RE(X_hybrid[i][n+1]) = out_re1[n+1] + out_im1[n+1];
499
739k
            QMF_IM(X_hybrid[i][n+1]) = out_re2[n+1] - out_im2[n+1];
500
501
739k
            QMF_RE(X_hybrid[i][10-n]) = out_re1[n+1] - out_im1[n+1];
502
739k
            QMF_IM(X_hybrid[i][10-n]) = out_re2[n+1] + out_im2[n+1];
503
739k
            QMF_RE(X_hybrid[i][11-n]) = out_re1[n] + out_im1[n];
504
739k
            QMF_IM(X_hybrid[i][11-n]) = out_re2[n] - out_im2[n];
505
739k
        }
506
246k
    }
507
8.01k
}
508
509
/* Hybrid analysis: further split up QMF subbands
510
 * to improve frequency resolution
511
 */
512
static void hybrid_analysis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
513
                            uint8_t use34, uint8_t numTimeSlotsRate)
514
20.9k
{
515
20.9k
    uint8_t k, n, band;
516
20.9k
    uint8_t offset = 0;
517
20.9k
    uint8_t qmf_bands = (use34) ? 5 : 3;
518
20.9k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
519
520
99.9k
    for (band = 0; band < qmf_bands; band++)
521
78.9k
    {
522
        /* build working buffer */
523
78.9k
        memcpy(hyb->work, hyb->buffer[band], 12 * sizeof(qmf_t));
524
525
        /* add new samples */
526
2.53M
        for (n = 0; n < hyb->frame_len; n++)
527
2.45M
        {
528
2.45M
            QMF_RE(hyb->work[12 + n]) = QMF_RE(X[n + 6 /*delay*/][band]);
529
2.45M
            QMF_IM(hyb->work[12 + n]) = QMF_IM(X[n + 6 /*delay*/][band]);
530
2.45M
        }
531
532
        /* store samples */
533
78.9k
        memcpy(hyb->buffer[band], hyb->work + hyb->frame_len, 12 * sizeof(qmf_t));
534
535
536
78.9k
        switch(resolution[band])
537
78.9k
        {
538
25.9k
        case 2:
539
            /* Type B real filter, Q[p] = 2 */
540
25.9k
            channel_filter2(hyb, hyb->frame_len, p2_13_20, hyb->work, hyb->temp);
541
25.9k
            break;
542
24.0k
        case 4:
543
            /* Type A complex filter, Q[p] = 4 */
544
24.0k
            channel_filter4(hyb, hyb->frame_len, p4_13_34, hyb->work, hyb->temp);
545
24.0k
            break;
546
20.9k
        case 8:
547
            /* Type A complex filter, Q[p] = 8 */
548
20.9k
            channel_filter8(hyb, hyb->frame_len, (use34) ? p8_13_34 : p8_13_20,
549
20.9k
                hyb->work, hyb->temp);
550
20.9k
            break;
551
8.01k
        case 12:
552
            /* Type A complex filter, Q[p] = 12 */
553
8.01k
            channel_filter12(hyb, hyb->frame_len, p12_13_34, hyb->work, hyb->temp);
554
8.01k
            break;
555
78.9k
        }
556
557
2.53M
        for (n = 0; n < hyb->frame_len; n++)
558
2.45M
        {
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.45M
        }
565
78.9k
        offset += resolution[band];
566
78.9k
    }
567
568
    /* group hybrid channels */
569
20.9k
    if (!use34)
570
12.9k
    {
571
419k
        for (n = 0; n < numTimeSlotsRate; n++)
572
406k
        {
573
406k
            QMF_RE(X_hybrid[n][3]) += QMF_RE(X_hybrid[n][4]);
574
406k
            QMF_IM(X_hybrid[n][3]) += QMF_IM(X_hybrid[n][4]);
575
406k
            QMF_RE(X_hybrid[n][4]) = 0;
576
406k
            QMF_IM(X_hybrid[n][4]) = 0;
577
578
406k
            QMF_RE(X_hybrid[n][2]) += QMF_RE(X_hybrid[n][5]);
579
406k
            QMF_IM(X_hybrid[n][2]) += QMF_IM(X_hybrid[n][5]);
580
406k
            QMF_RE(X_hybrid[n][5]) = 0;
581
406k
            QMF_IM(X_hybrid[n][5]) = 0;
582
406k
        }
583
12.9k
    }
584
20.9k
}
585
586
static void hybrid_synthesis(hyb_info *hyb, qmf_t X[32][64], qmf_t X_hybrid[32][32],
587
                             uint8_t use34, uint8_t numTimeSlotsRate)
588
41.9k
{
589
41.9k
    uint8_t k, n, band;
590
41.9k
    uint8_t offset = 0;
591
41.9k
    uint8_t qmf_bands = (use34) ? 5 : 3;
592
41.9k
    uint8_t *resolution = (use34) ? hyb->resolution34 : hyb->resolution20;
593
41.9k
    (void)numTimeSlotsRate;  /* TODO: remove parameter? */
594
595
199k
    for(band = 0; band < qmf_bands; band++)
596
157k
    {
597
5.06M
        for (n = 0; n < hyb->frame_len; n++)
598
4.90M
        {
599
4.90M
            QMF_RE(X[n][band]) = 0;
600
4.90M
            QMF_IM(X[n][band]) = 0;
601
602
30.4M
            for (k = 0; k < resolution[band]; k++)
603
25.5M
            {
604
25.5M
                QMF_RE(X[n][band]) += QMF_RE(X_hybrid[n][offset + k]);
605
25.5M
                QMF_IM(X[n][band]) += QMF_IM(X_hybrid[n][offset + k]);
606
25.5M
            }
607
4.90M
        }
608
157k
        offset += resolution[band];
609
157k
    }
610
41.9k
}
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
510k
{
615
510k
    if (i < min)
616
72.1k
        return min;
617
438k
    else if (i > max)
618
10.2k
        return max;
619
428k
    else
620
428k
        return i;
621
510k
}
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
73.0k
{
630
73.0k
    int8_t i;
631
632
73.0k
    if (enable == 1)
633
36.7k
    {
634
36.7k
        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
322k
            for (i = 1; i < nr_par; i++)
641
300k
            {
642
300k
                index[i] = index[i-1] + index[i];
643
300k
                index[i] = delta_clip(index[i], min_index, max_index);
644
300k
            }
645
22.4k
        } else {
646
            /* delta coded in time direction */
647
202k
            for (i = 0; i < nr_par; i++)
648
188k
            {
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
188k
                index[i] = index_prev[i*stride] + index[i];
656
                //tmp2 = index[i];
657
188k
                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
188k
            }
667
14.3k
        }
668
36.7k
    } else {
669
        /* set indices to zero */
670
62.5k
        for (i = 0; i < nr_par; i++)
671
26.1k
        {
672
26.1k
            index[i] = 0;
673
26.1k
        }
674
36.3k
    }
675
676
    /* coarse */
677
73.0k
    if (stride == 2)
678
47.1k
    {
679
278k
        for (i = (nr_par<<1)-1; i > 0; i--)
680
231k
        {
681
231k
            index[i] = index[i>>1];
682
231k
        }
683
47.1k
    }
684
73.0k
}
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
73.0k
{
692
73.0k
    int8_t i;
693
694
73.0k
    if (enable == 1)
695
23.7k
    {
696
23.7k
        if (dt_flag == 0)
697
14.0k
        {
698
            /* delta coded in frequency direction */
699
14.0k
            index[0] = 0 + index[0];
700
14.0k
            index[0] &= and_modulo;
701
702
48.7k
            for (i = 1; i < nr_par; i++)
703
34.6k
            {
704
34.6k
                index[i] = index[i-1] + index[i];
705
34.6k
                index[i] &= and_modulo;
706
34.6k
            }
707
14.0k
        } else {
708
            /* delta coded in time direction */
709
29.8k
            for (i = 0; i < nr_par; i++)
710
20.1k
            {
711
20.1k
                index[i] = index_prev[i*stride] + index[i];
712
20.1k
                index[i] &= and_modulo;
713
20.1k
            }
714
9.68k
        }
715
49.3k
    } else {
716
        /* set indices to zero */
717
172k
        for (i = 0; i < nr_par; i++)
718
123k
        {
719
123k
            index[i] = 0;
720
123k
        }
721
49.3k
    }
722
723
    /* coarse */
724
73.0k
    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
73.0k
}
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
34.8k
{
766
34.8k
    index[0] = index[0];
767
34.8k
    index[1] = (index[0] + index[1])/2;
768
34.8k
    index[2] = index[1];
769
34.8k
    index[3] = index[2];
770
34.8k
    index[4] = (index[2] + index[3])/2;
771
34.8k
    index[5] = index[3];
772
34.8k
    index[6] = index[4];
773
34.8k
    index[7] = index[4];
774
34.8k
    index[8] = index[5];
775
34.8k
    index[9] = index[5];
776
34.8k
    index[10] = index[6];
777
34.8k
    index[11] = index[7];
778
34.8k
    index[12] = index[8];
779
34.8k
    index[13] = index[8];
780
34.8k
    index[14] = index[9];
781
34.8k
    index[15] = index[9];
782
34.8k
    index[16] = index[10];
783
784
34.8k
    if (bins == 34)
785
14.6k
    {
786
14.6k
        index[17] = index[11];
787
14.6k
        index[18] = index[12];
788
14.6k
        index[19] = index[13];
789
14.6k
        index[20] = index[14];
790
14.6k
        index[21] = index[14];
791
14.6k
        index[22] = index[15];
792
14.6k
        index[23] = index[15];
793
14.6k
        index[24] = index[16];
794
14.6k
        index[25] = index[16];
795
14.6k
        index[26] = index[17];
796
14.6k
        index[27] = index[17];
797
14.6k
        index[28] = index[18];
798
14.6k
        index[29] = index[18];
799
14.6k
        index[30] = index[18];
800
14.6k
        index[31] = index[18];
801
14.6k
        index[32] = index[19];
802
14.6k
        index[33] = index[19];
803
14.6k
    }
804
34.8k
}
805
806
/* parse the bitstream data decoded in ps_data() */
807
static void ps_data_decode(ps_info *ps)
808
20.9k
{
809
20.9k
    uint8_t env, bin;
810
811
    /* ps data not available, use data from previous frame */
812
20.9k
    if (ps->ps_data_available == 0)
813
5.32k
    {
814
5.32k
        ps->num_env = 0;
815
5.32k
    }
816
817
57.5k
    for (env = 0; env < ps->num_env; env++)
818
36.5k
    {
819
36.5k
        int8_t *iid_index_prev;
820
36.5k
        int8_t *icc_index_prev;
821
36.5k
        int8_t *ipd_index_prev;
822
36.5k
        int8_t *opd_index_prev;
823
824
36.5k
        int8_t num_iid_steps = (ps->iid_mode < 3) ? 7 : 15 /*fine quant*/;
825
826
36.5k
        if (env == 0)
827
10.9k
        {
828
            /* take last envelope from previous frame */
829
10.9k
            iid_index_prev = ps->iid_index_prev;
830
10.9k
            icc_index_prev = ps->icc_index_prev;
831
10.9k
            ipd_index_prev = ps->ipd_index_prev;
832
10.9k
            opd_index_prev = ps->opd_index_prev;
833
25.5k
        } else {
834
            /* take index values from previous envelope */
835
25.5k
            iid_index_prev = ps->iid_index[env - 1];
836
25.5k
            icc_index_prev = ps->icc_index[env - 1];
837
25.5k
            ipd_index_prev = ps->ipd_index[env - 1];
838
25.5k
            opd_index_prev = ps->opd_index[env - 1];
839
25.5k
        }
840
841
//        iid = 1;
842
        /* delta decode iid parameters */
843
36.5k
        delta_decode(ps->enable_iid, ps->iid_index[env], iid_index_prev,
844
36.5k
            ps->iid_dt[env], ps->nr_iid_par,
845
36.5k
            (ps->iid_mode == 0 || ps->iid_mode == 3) ? 2 : 1,
846
36.5k
            -num_iid_steps, num_iid_steps);
847
//        iid = 0;
848
849
        /* delta decode icc parameters */
850
36.5k
        delta_decode(ps->enable_icc, ps->icc_index[env], icc_index_prev,
851
36.5k
            ps->icc_dt[env], ps->nr_icc_par,
852
36.5k
            (ps->icc_mode == 0 || ps->icc_mode == 3) ? 2 : 1,
853
36.5k
            0, 7);
854
855
        /* delta modulo decode ipd parameters */
856
36.5k
        delta_modulo_decode(ps->enable_ipdopd, ps->ipd_index[env], ipd_index_prev,
857
36.5k
            ps->ipd_dt[env], ps->nr_ipdopd_par, 1, 7);
858
859
        /* delta modulo decode opd parameters */
860
36.5k
        delta_modulo_decode(ps->enable_ipdopd, ps->opd_index[env], opd_index_prev,
861
36.5k
            ps->opd_dt[env], ps->nr_ipdopd_par, 1, 7);
862
36.5k
    }
863
864
    /* handle error case */
865
20.9k
    if (ps->num_env == 0)
866
10.0k
    {
867
        /* force to 1 */
868
10.0k
        ps->num_env = 1;
869
870
10.0k
        if (ps->enable_iid)
871
6.80k
        {
872
238k
            for (bin = 0; bin < 34; bin++)
873
231k
                ps->iid_index[0][bin] = ps->iid_index_prev[bin];
874
6.80k
        } else {
875
112k
            for (bin = 0; bin < 34; bin++)
876
108k
                ps->iid_index[0][bin] = 0;
877
3.20k
        }
878
879
10.0k
        if (ps->enable_icc)
880
4.97k
        {
881
174k
            for (bin = 0; bin < 34; bin++)
882
169k
                ps->icc_index[0][bin] = ps->icc_index_prev[bin];
883
5.03k
        } else {
884
176k
            for (bin = 0; bin < 34; bin++)
885
171k
                ps->icc_index[0][bin] = 0;
886
5.03k
        }
887
888
10.0k
        if (ps->enable_ipdopd)
889
1.17k
        {
890
21.1k
            for (bin = 0; bin < 17; bin++)
891
19.9k
            {
892
19.9k
                ps->ipd_index[0][bin] = ps->ipd_index_prev[bin];
893
19.9k
                ps->opd_index[0][bin] = ps->opd_index_prev[bin];
894
19.9k
            }
895
8.83k
        } else {
896
159k
            for (bin = 0; bin < 17; bin++)
897
150k
            {
898
150k
                ps->ipd_index[0][bin] = 0;
899
150k
                ps->opd_index[0][bin] = 0;
900
150k
            }
901
8.83k
        }
902
10.0k
    }
903
904
    /* update previous indices */
905
733k
    for (bin = 0; bin < 34; bin++)
906
712k
        ps->iid_index_prev[bin] = ps->iid_index[ps->num_env-1][bin];
907
733k
    for (bin = 0; bin < 34; bin++)
908
712k
        ps->icc_index_prev[bin] = ps->icc_index[ps->num_env-1][bin];
909
377k
    for (bin = 0; bin < 17; bin++)
910
356k
    {
911
356k
        ps->ipd_index_prev[bin] = ps->ipd_index[ps->num_env-1][bin];
912
356k
        ps->opd_index_prev[bin] = ps->opd_index[ps->num_env-1][bin];
913
356k
    }
914
915
20.9k
    ps->ps_data_available = 0;
916
917
20.9k
    if (ps->frame_class == 0)
918
12.6k
    {
919
12.6k
        ps->border_position[0] = 0;
920
22.9k
        for (env = 1; env < ps->num_env; env++)
921
10.3k
        {
922
10.3k
            ps->border_position[env] = (env * ps->numTimeSlotsRate) / ps->num_env;
923
10.3k
        }
924
12.6k
        ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
925
12.6k
    } else {
926
8.33k
        ps->border_position[0] = 0;
927
928
8.33k
        if (ps->border_position[ps->num_env] < ps->numTimeSlotsRate)
929
6.19k
        {
930
216k
            for (bin = 0; bin < 34; bin++)
931
210k
            {
932
210k
                ps->iid_index[ps->num_env][bin] = ps->iid_index[ps->num_env-1][bin];
933
210k
                ps->icc_index[ps->num_env][bin] = ps->icc_index[ps->num_env-1][bin];
934
210k
            }
935
111k
            for (bin = 0; bin < 17; bin++)
936
105k
            {
937
105k
                ps->ipd_index[ps->num_env][bin] = ps->ipd_index[ps->num_env-1][bin];
938
105k
                ps->opd_index[ps->num_env][bin] = ps->opd_index[ps->num_env-1][bin];
939
105k
            }
940
6.19k
            ps->num_env++;
941
6.19k
            ps->border_position[ps->num_env] = ps->numTimeSlotsRate;
942
6.19k
        }
943
944
29.8k
        for (env = 1; env < ps->num_env; env++)
945
21.4k
        {
946
21.4k
            int8_t thr = ps->numTimeSlotsRate - (ps->num_env - env);
947
948
21.4k
            if (ps->border_position[env] > thr)
949
5.27k
            {
950
5.27k
                ps->border_position[env] = thr;
951
16.1k
            } else {
952
16.1k
                thr = ps->border_position[env-1]+1;
953
16.1k
                if (ps->border_position[env] < thr)
954
8.45k
                {
955
8.45k
                    ps->border_position[env] = thr;
956
8.45k
                }
957
16.1k
            }
958
21.4k
        }
959
8.33k
    }
960
961
    /* make sure that the indices of all parameters can be mapped
962
     * to the same hybrid synthesis filterbank
963
     */
964
#ifdef PS_LOW_POWER
965
    for (env = 0; env < ps->num_env; env++)
966
    {
967
        if (ps->iid_mode == 2 || ps->iid_mode == 5)
968
            map34indexto20(ps->iid_index[env], 34);
969
        if (ps->icc_mode == 2 || ps->icc_mode == 5)
970
            map34indexto20(ps->icc_index[env], 34);
971
972
        /* disable ipd/opd */
973
        for (bin = 0; bin < 17; bin++)
974
        {
975
            ps->aaIpdIndex[env][bin] = 0;
976
            ps->aaOpdIndex[env][bin] = 0;
977
        }
978
    }
979
#else
980
20.9k
    if (ps->use34hybrid_bands)
981
8.01k
    {
982
23.5k
        for (env = 0; env < ps->num_env; env++)
983
15.5k
        {
984
15.5k
            if (ps->iid_mode != 2 && ps->iid_mode != 5)
985
10.0k
                map20indexto34(ps->iid_index[env], 34);
986
15.5k
            if (ps->icc_mode != 2 && ps->icc_mode != 5)
987
4.59k
                map20indexto34(ps->icc_index[env], 34);
988
15.5k
            if (ps->ipd_mode != 2 && ps->ipd_mode != 5)
989
10.0k
            {
990
10.0k
                map20indexto34(ps->ipd_index[env], 17);
991
10.0k
                map20indexto34(ps->opd_index[env], 17);
992
10.0k
            }
993
15.5k
        }
994
8.01k
    }
995
20.9k
#endif
996
997
#if 0
998
    for (env = 0; env < ps->num_env; env++)
999
    {
1000
        printf("iid[env:%d]:", env);
1001
        for (bin = 0; bin < 34; bin++)
1002
        {
1003
            printf(" %d", ps->iid_index[env][bin]);
1004
        }
1005
        printf("\n");
1006
    }
1007
    for (env = 0; env < ps->num_env; env++)
1008
    {
1009
        printf("icc[env:%d]:", env);
1010
        for (bin = 0; bin < 34; bin++)
1011
        {
1012
            printf(" %d", ps->icc_index[env][bin]);
1013
        }
1014
        printf("\n");
1015
    }
1016
    for (env = 0; env < ps->num_env; env++)
1017
    {
1018
        printf("ipd[env:%d]:", env);
1019
        for (bin = 0; bin < 17; bin++)
1020
        {
1021
            printf(" %d", ps->ipd_index[env][bin]);
1022
        }
1023
        printf("\n");
1024
    }
1025
    for (env = 0; env < ps->num_env; env++)
1026
    {
1027
        printf("opd[env:%d]:", env);
1028
        for (bin = 0; bin < 17; bin++)
1029
        {
1030
            printf(" %d", ps->opd_index[env][bin]);
1031
        }
1032
        printf("\n");
1033
    }
1034
    printf("\n");
1035
#endif
1036
20.9k
}
1037
1038
/* decorrelate the mono signal using an allpass filter */
1039
static void ps_decorrelate(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
1040
                           qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32])
1041
20.9k
{
1042
20.9k
    uint8_t gr, n, bk;
1043
20.9k
    uint8_t temp_delay = 0;
1044
20.9k
    uint8_t sb, maxsb;
1045
20.9k
    const complex_t *Phi_Fract_SubQmf;
1046
20.9k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
20.9k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
20.9k
    real_t P[32][34];
1049
20.9k
    real_t G_TransientRatio[32][34] = {{0}};
1050
20.9k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
20.9k
    if (ps->use34hybrid_bands)
1055
8.01k
    {
1056
8.01k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
12.9k
    } else{
1058
12.9k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
12.9k
    }
1060
1061
    /* clear the energy values */
1062
692k
    for (n = 0; n < 32; n++)
1063
671k
    {
1064
23.4M
        for (bk = 0; bk < 34; bk++)
1065
22.8M
        {
1066
22.8M
            P[n][bk] = 0;
1067
22.8M
        }
1068
671k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
706k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
685k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
685k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
685k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
2.33M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
1.64M
        {
1081
53.1M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
51.4M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
51.4M
                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
39.4M
                } else {
1093
39.4M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
39.4M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
39.4M
                }
1096
1097
                /* accumulate energy */
1098
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
24.0M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
24.0M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
27.4M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
51.4M
            }
1109
1.64M
        }
1110
685k
    }
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
552k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
531k
    {
1129
17.0M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
16.5M
        {
1131
16.5M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
16.5M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
16.5M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
166k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
16.5M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
16.5M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
16.5M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
16.5M
            nrg = ps->P_prev[bk];
1144
16.5M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
16.5M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
16.5M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
16.4M
            {
1150
16.4M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
16.4M
            } else {
1152
140k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
140k
            }
1154
16.5M
        }
1155
531k
    }
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
706k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
685k
    {
1174
685k
        if (gr < ps->num_hybrid_groups)
1175
385k
            maxsb = ps->group_border[gr] + 1;
1176
299k
        else
1177
299k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
2.33M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
1.64M
        {
1182
1.64M
            real_t g_DecaySlope;
1183
1.64M
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
1.64M
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
406k
            {
1188
406k
                g_DecaySlope = FRAC_CONST(1.0);
1189
1.24M
            } else {
1190
1.24M
                int8_t decay = ps->decay_cutoff - sb;
1191
1.24M
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
843k
                {
1193
843k
                    g_DecaySlope = 0;
1194
843k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
398k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
398k
                }
1198
1.24M
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
6.59M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
4.94M
            {
1203
4.94M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
4.94M
            }
1205
1206
1207
            /* set delay indices */
1208
1.64M
            temp_delay = ps->saved_delay;
1209
6.59M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
4.94M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
53.1M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
51.4M
            {
1214
51.4M
                complex_t tmp, tmp0, R0;
1215
51.4M
                uint8_t m;
1216
1217
51.4M
                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
39.4M
                } else {
1223
                    /* QMF filterbank input */
1224
39.4M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
39.4M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
39.4M
                }
1227
1228
51.4M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
26.8M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
26.8M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
26.8M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
26.8M
                    RE(R0) = RE(tmp);
1236
26.8M
                    IM(R0) = IM(tmp);
1237
26.8M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
26.8M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
26.8M
                } else {
1240
                    /* allpass filter */
1241
24.6M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
24.6M
                    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.6M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
12.6M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
12.6M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
12.6M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
12.6M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
12.6M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
12.6M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
12.6M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
24.6M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
24.6M
                    RE(R0) = RE(tmp);
1271
24.6M
                    IM(R0) = IM(tmp);
1272
98.4M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
73.8M
                    {
1274
73.8M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
73.8M
                        if (gr < ps->num_hybrid_groups)
1278
35.9M
                        {
1279
                            /* select data from the hybrid subbands */
1280
35.9M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
35.9M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
35.9M
                            if (ps->use34hybrid_bands)
1284
23.7M
                            {
1285
23.7M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
23.7M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
23.7M
                            } else {
1288
12.2M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
12.2M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
12.2M
                            }
1291
37.8M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
37.8M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
37.8M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
37.8M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
37.8M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
37.8M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
73.8M
                        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
73.8M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
73.8M
                        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
73.8M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
73.8M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
73.8M
                        if (gr < ps->num_hybrid_groups)
1314
35.9M
                        {
1315
35.9M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
35.9M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
37.8M
                        } else {
1318
37.8M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
37.8M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
37.8M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
73.8M
                        RE(R0) = RE(tmp);
1324
73.8M
                        IM(R0) = IM(tmp);
1325
73.8M
                    }
1326
24.6M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
51.4M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
51.4M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
51.4M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
51.4M
                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
39.4M
                } else {
1341
                    /* QMF */
1342
39.4M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
39.4M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
39.4M
                }
1345
1346
                /* Update delay buffer index */
1347
51.4M
                if (++temp_delay >= 2)
1348
25.7M
                {
1349
25.7M
                    temp_delay = 0;
1350
25.7M
                }
1351
1352
                /* update delay indices */
1353
51.4M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
26.8M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
26.8M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
19.5M
                    {
1358
19.5M
                        ps->delay_buf_index_delay[sb] = 0;
1359
19.5M
                    }
1360
26.8M
                }
1361
1362
205M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
154M
                {
1364
154M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
39.4M
                    {
1366
39.4M
                        temp_delay_ser[m] = 0;
1367
39.4M
                    }
1368
154M
                }
1369
51.4M
            }
1370
1.64M
        }
1371
685k
    }
1372
1373
    /* update delay indices */
1374
20.9k
    ps->saved_delay = temp_delay;
1375
83.8k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
62.9k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
20.9k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
9.74k
{
1042
9.74k
    uint8_t gr, n, bk;
1043
9.74k
    uint8_t temp_delay = 0;
1044
9.74k
    uint8_t sb, maxsb;
1045
9.74k
    const complex_t *Phi_Fract_SubQmf;
1046
9.74k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
9.74k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
9.74k
    real_t P[32][34];
1049
9.74k
    real_t G_TransientRatio[32][34] = {{0}};
1050
9.74k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
9.74k
    if (ps->use34hybrid_bands)
1055
3.87k
    {
1056
3.87k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
5.87k
    } else{
1058
5.87k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
5.87k
    }
1060
1061
    /* clear the energy values */
1062
321k
    for (n = 0; n < 32; n++)
1063
311k
    {
1064
10.9M
        for (bk = 0; bk < 34; bk++)
1065
10.5M
        {
1066
10.5M
            P[n][bk] = 0;
1067
10.5M
        }
1068
311k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
332k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
322k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
322k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
322k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
1.09M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
769k
        {
1081
24.7M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
24.0M
            {
1083
24.0M
#ifdef FIXED_POINT
1084
24.0M
                uint32_t in_re, in_im;
1085
24.0M
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
24.0M
                if (gr < ps->num_hybrid_groups)
1089
5.66M
                {
1090
5.66M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
5.66M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
18.3M
                } else {
1093
18.3M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
18.3M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
18.3M
                }
1096
1097
                /* accumulate energy */
1098
24.0M
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
24.0M
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
24.0M
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
24.0M
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
#endif
1108
24.0M
            }
1109
769k
        }
1110
322k
    }
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
258k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
249k
    {
1129
8.01M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
7.76M
        {
1131
7.76M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
7.76M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
7.76M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
23.6k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
7.76M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
7.76M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
7.76M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
7.76M
            nrg = ps->P_prev[bk];
1144
7.76M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
7.76M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
7.76M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
7.75M
            {
1150
7.75M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
7.75M
            } else {
1152
9.72k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
9.72k
            }
1154
7.76M
        }
1155
249k
    }
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
332k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
322k
    {
1174
322k
        if (gr < ps->num_hybrid_groups)
1175
182k
            maxsb = ps->group_border[gr] + 1;
1176
140k
        else
1177
140k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
1.09M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
769k
        {
1182
769k
            real_t g_DecaySlope;
1183
769k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
769k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
192k
            {
1188
192k
                g_DecaySlope = FRAC_CONST(1.0);
1189
576k
            } else {
1190
576k
                int8_t decay = ps->decay_cutoff - sb;
1191
576k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
391k
                {
1193
391k
                    g_DecaySlope = 0;
1194
391k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
185k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
185k
                }
1198
576k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
3.07M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.30M
            {
1203
2.30M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.30M
            }
1205
1206
1207
            /* set delay indices */
1208
769k
            temp_delay = ps->saved_delay;
1209
3.07M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.30M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
24.7M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
24.0M
            {
1214
24.0M
                complex_t tmp, tmp0, R0;
1215
24.0M
                uint8_t m;
1216
1217
24.0M
                if (gr < ps->num_hybrid_groups)
1218
5.66M
                {
1219
                    /* hybrid filterbank input */
1220
5.66M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
5.66M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
18.3M
                } else {
1223
                    /* QMF filterbank input */
1224
18.3M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
18.3M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
18.3M
                }
1227
1228
24.0M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
12.4M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
12.4M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
12.4M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
12.4M
                    RE(R0) = RE(tmp);
1236
12.4M
                    IM(R0) = IM(tmp);
1237
12.4M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
12.4M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
12.4M
                } else {
1240
                    /* allpass filter */
1241
11.5M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
11.5M
                    if (gr < ps->num_hybrid_groups)
1245
5.66M
                    {
1246
                        /* select data from the hybrid subbands */
1247
5.66M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
5.66M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
5.66M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
5.66M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
5.66M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
5.66M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
5.85M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
5.85M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
5.85M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
5.85M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
5.85M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
5.85M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
5.85M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
5.85M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
11.5M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
11.5M
                    RE(R0) = RE(tmp);
1271
11.5M
                    IM(R0) = IM(tmp);
1272
46.0M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
34.5M
                    {
1274
34.5M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
34.5M
                        if (gr < ps->num_hybrid_groups)
1278
17.0M
                        {
1279
                            /* select data from the hybrid subbands */
1280
17.0M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
17.0M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
17.0M
                            if (ps->use34hybrid_bands)
1284
11.4M
                            {
1285
11.4M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
11.4M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
11.4M
                            } else {
1288
5.55M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
5.55M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
5.55M
                            }
1291
17.5M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
17.5M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
17.5M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
17.5M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
17.5M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
17.5M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
34.5M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
34.5M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
34.5M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
34.5M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
34.5M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
34.5M
                        if (gr < ps->num_hybrid_groups)
1314
17.0M
                        {
1315
17.0M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
17.0M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
17.5M
                        } else {
1318
17.5M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
17.5M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
17.5M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
34.5M
                        RE(R0) = RE(tmp);
1324
34.5M
                        IM(R0) = IM(tmp);
1325
34.5M
                    }
1326
11.5M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
24.0M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
24.0M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
24.0M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
24.0M
                if (gr < ps->num_hybrid_groups)
1336
5.66M
                {
1337
                    /* hybrid */
1338
5.66M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
5.66M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
18.3M
                } else {
1341
                    /* QMF */
1342
18.3M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
18.3M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
18.3M
                }
1345
1346
                /* Update delay buffer index */
1347
24.0M
                if (++temp_delay >= 2)
1348
11.9M
                {
1349
11.9M
                    temp_delay = 0;
1350
11.9M
                }
1351
1352
                /* update delay indices */
1353
24.0M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
12.4M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
12.4M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
9.06M
                    {
1358
9.06M
                        ps->delay_buf_index_delay[sb] = 0;
1359
9.06M
                    }
1360
12.4M
                }
1361
1362
96.0M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
72.0M
                {
1364
72.0M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
18.3M
                    {
1366
18.3M
                        temp_delay_ser[m] = 0;
1367
18.3M
                    }
1368
72.0M
                }
1369
24.0M
            }
1370
769k
        }
1371
322k
    }
1372
1373
    /* update delay indices */
1374
9.74k
    ps->saved_delay = temp_delay;
1375
38.9k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
29.2k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
9.74k
}
ps_dec.c:ps_decorrelate
Line
Count
Source
1041
11.2k
{
1042
11.2k
    uint8_t gr, n, bk;
1043
11.2k
    uint8_t temp_delay = 0;
1044
11.2k
    uint8_t sb, maxsb;
1045
11.2k
    const complex_t *Phi_Fract_SubQmf;
1046
11.2k
    uint8_t temp_delay_ser[NO_ALLPASS_LINKS];
1047
11.2k
    real_t P_SmoothPeakDecayDiffNrg, nrg;
1048
11.2k
    real_t P[32][34];
1049
11.2k
    real_t G_TransientRatio[32][34] = {{0}};
1050
11.2k
    complex_t inputLeft;
1051
1052
1053
    /* chose hybrid filterbank: 20 or 34 band case */
1054
11.2k
    if (ps->use34hybrid_bands)
1055
4.14k
    {
1056
4.14k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf34;
1057
7.08k
    } else{
1058
7.08k
        Phi_Fract_SubQmf = Phi_Fract_SubQmf20;
1059
7.08k
    }
1060
1061
    /* clear the energy values */
1062
370k
    for (n = 0; n < 32; n++)
1063
359k
    {
1064
12.5M
        for (bk = 0; bk < 34; bk++)
1065
12.2M
        {
1066
12.2M
            P[n][bk] = 0;
1067
12.2M
        }
1068
359k
    }
1069
1070
    /* calculate the energy in each parameter band b(k) */
1071
374k
    for (gr = 0; gr < ps->num_groups; gr++)
1072
362k
    {
1073
        /* select the parameter index b(k) to which this group belongs */
1074
362k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1075
1076
        /* select the upper subband border for this group */
1077
362k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr]+1 : ps->group_border[gr+1];
1078
1079
1.24M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1080
880k
        {
1081
28.3M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1082
27.4M
            {
1083
#ifdef FIXED_POINT
1084
                uint32_t in_re, in_im;
1085
#endif
1086
1087
                /* input from hybrid subbands or QMF subbands */
1088
27.4M
                if (gr < ps->num_hybrid_groups)
1089
6.31M
                {
1090
6.31M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1091
6.31M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1092
21.1M
                } else {
1093
21.1M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1094
21.1M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1095
21.1M
                }
1096
1097
                /* accumulate energy */
1098
#ifdef FIXED_POINT
1099
                /* NOTE: all input is scaled by 2^(-5) because of fixed point QMF
1100
                 * meaning that P will be scaled by 2^(-10) compared to floating point version
1101
                 */
1102
                in_re = ((abs(RE(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1103
                in_im = ((abs(IM(inputLeft))+(1<<(REAL_BITS-1)))>>REAL_BITS);
1104
                P[n][bk] += in_re*in_re + in_im*in_im;
1105
#else
1106
27.4M
                P[n][bk] += MUL_R(RE(inputLeft),RE(inputLeft)) + MUL_R(IM(inputLeft),IM(inputLeft));
1107
27.4M
#endif
1108
27.4M
            }
1109
880k
        }
1110
362k
    }
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
293k
    for (bk = 0; bk < ps->nr_par_bands; bk++)
1128
282k
    {
1129
9.08M
        for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1130
8.80M
        {
1131
8.80M
            const real_t gamma = COEF_CONST(1.5);
1132
1133
8.80M
            ps->P_PeakDecayNrg[bk] = MUL_F(ps->P_PeakDecayNrg[bk], ps->alpha_decay);
1134
8.80M
            if (ps->P_PeakDecayNrg[bk] < P[n][bk])
1135
143k
                ps->P_PeakDecayNrg[bk] = P[n][bk];
1136
1137
            /* apply smoothing filter to peak decay energy */
1138
8.80M
            P_SmoothPeakDecayDiffNrg = ps->P_SmoothPeakDecayDiffNrg_prev[bk];
1139
8.80M
            P_SmoothPeakDecayDiffNrg += MUL_F((ps->P_PeakDecayNrg[bk] - P[n][bk] - ps->P_SmoothPeakDecayDiffNrg_prev[bk]), ps->alpha_smooth);
1140
8.80M
            ps->P_SmoothPeakDecayDiffNrg_prev[bk] = P_SmoothPeakDecayDiffNrg;
1141
1142
            /* apply smoothing filter to energy */
1143
8.80M
            nrg = ps->P_prev[bk];
1144
8.80M
            nrg += MUL_F((P[n][bk] - ps->P_prev[bk]), ps->alpha_smooth);
1145
8.80M
            ps->P_prev[bk] = nrg;
1146
1147
            /* calculate transient ratio */
1148
8.80M
            if (MUL_C(P_SmoothPeakDecayDiffNrg, gamma) <= nrg)
1149
8.67M
            {
1150
8.67M
                G_TransientRatio[n][bk] = REAL_CONST(1.0);
1151
8.67M
            } else {
1152
131k
                G_TransientRatio[n][bk] = DIV_R(nrg, (MUL_C(P_SmoothPeakDecayDiffNrg, gamma)));
1153
131k
            }
1154
8.80M
        }
1155
282k
    }
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
374k
    for (gr = 0; gr < ps->num_groups; gr++)
1173
362k
    {
1174
362k
        if (gr < ps->num_hybrid_groups)
1175
203k
            maxsb = ps->group_border[gr] + 1;
1176
159k
        else
1177
159k
            maxsb = ps->group_border[gr + 1];
1178
1179
        /* QMF channel */
1180
1.24M
        for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1181
880k
        {
1182
880k
            real_t g_DecaySlope;
1183
880k
            real_t g_DecaySlope_filt[NO_ALLPASS_LINKS];
1184
1185
            /* g_DecaySlope: [0..1] */
1186
880k
            if (gr < ps->num_hybrid_groups || sb <= ps->decay_cutoff)
1187
214k
            {
1188
214k
                g_DecaySlope = FRAC_CONST(1.0);
1189
665k
            } else {
1190
665k
                int8_t decay = ps->decay_cutoff - sb;
1191
665k
                if (decay <= -20 /* -1/DECAY_SLOPE */)
1192
452k
                {
1193
452k
                    g_DecaySlope = 0;
1194
452k
                } else {
1195
                    /* decay(int)*decay_slope(frac) = g_DecaySlope(frac) */
1196
213k
                    g_DecaySlope = FRAC_CONST(1.0) + DECAY_SLOPE * decay;
1197
213k
                }
1198
665k
            }
1199
1200
            /* calculate g_DecaySlope_filt for every n multiplied by filter_a[n] */
1201
3.52M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1202
2.64M
            {
1203
2.64M
                g_DecaySlope_filt[n] = MUL_F(g_DecaySlope, filter_a[n]);
1204
2.64M
            }
1205
1206
1207
            /* set delay indices */
1208
880k
            temp_delay = ps->saved_delay;
1209
3.52M
            for (n = 0; n < NO_ALLPASS_LINKS; n++)
1210
2.64M
                temp_delay_ser[n] = ps->delay_buf_index_ser[n];
1211
1212
28.3M
            for (n = ps->border_position[0]; n < ps->border_position[ps->num_env]; n++)
1213
27.4M
            {
1214
27.4M
                complex_t tmp, tmp0, R0;
1215
27.4M
                uint8_t m;
1216
1217
27.4M
                if (gr < ps->num_hybrid_groups)
1218
6.31M
                {
1219
                    /* hybrid filterbank input */
1220
6.31M
                    RE(inputLeft) = QMF_RE(X_hybrid_left[n][sb]);
1221
6.31M
                    IM(inputLeft) = QMF_IM(X_hybrid_left[n][sb]);
1222
21.1M
                } else {
1223
                    /* QMF filterbank input */
1224
21.1M
                    RE(inputLeft) = QMF_RE(X_left[n][sb]);
1225
21.1M
                    IM(inputLeft) = QMF_IM(X_left[n][sb]);
1226
21.1M
                }
1227
1228
27.4M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1229
14.3M
                {
1230
                    /* delay */
1231
1232
                    /* never hybrid subbands here, always QMF subbands */
1233
14.3M
                    RE(tmp) = RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1234
14.3M
                    IM(tmp) = IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]);
1235
14.3M
                    RE(R0) = RE(tmp);
1236
14.3M
                    IM(R0) = IM(tmp);
1237
14.3M
                    RE(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = RE(inputLeft);
1238
14.3M
                    IM(ps->delay_Qmf[ps->delay_buf_index_delay[sb]][sb]) = IM(inputLeft);
1239
14.3M
                } else {
1240
                    /* allpass filter */
1241
13.0M
                    complex_t Phi_Fract;
1242
1243
                    /* fetch parameters */
1244
13.0M
                    if (gr < ps->num_hybrid_groups)
1245
6.31M
                    {
1246
                        /* select data from the hybrid subbands */
1247
6.31M
                        RE(tmp0) = RE(ps->delay_SubQmf[temp_delay][sb]);
1248
6.31M
                        IM(tmp0) = IM(ps->delay_SubQmf[temp_delay][sb]);
1249
1250
6.31M
                        RE(ps->delay_SubQmf[temp_delay][sb]) = RE(inputLeft);
1251
6.31M
                        IM(ps->delay_SubQmf[temp_delay][sb]) = IM(inputLeft);
1252
1253
6.31M
                        RE(Phi_Fract) = RE(Phi_Fract_SubQmf[sb]);
1254
6.31M
                        IM(Phi_Fract) = IM(Phi_Fract_SubQmf[sb]);
1255
6.76M
                    } else {
1256
                        /* select data from the QMF subbands */
1257
6.76M
                        RE(tmp0) = RE(ps->delay_Qmf[temp_delay][sb]);
1258
6.76M
                        IM(tmp0) = IM(ps->delay_Qmf[temp_delay][sb]);
1259
1260
6.76M
                        RE(ps->delay_Qmf[temp_delay][sb]) = RE(inputLeft);
1261
6.76M
                        IM(ps->delay_Qmf[temp_delay][sb]) = IM(inputLeft);
1262
1263
6.76M
                        RE(Phi_Fract) = RE(Phi_Fract_Qmf[sb]);
1264
6.76M
                        IM(Phi_Fract) = IM(Phi_Fract_Qmf[sb]);
1265
6.76M
                    }
1266
1267
                    /* z^(-2) * Phi_Fract[k] */
1268
13.0M
                    ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Phi_Fract), IM(Phi_Fract));
1269
1270
13.0M
                    RE(R0) = RE(tmp);
1271
13.0M
                    IM(R0) = IM(tmp);
1272
52.3M
                    for (m = 0; m < NO_ALLPASS_LINKS; m++)
1273
39.2M
                    {
1274
39.2M
                        complex_t Q_Fract_allpass, tmp2;
1275
1276
                        /* fetch parameters */
1277
39.2M
                        if (gr < ps->num_hybrid_groups)
1278
18.9M
                        {
1279
                            /* select data from the hybrid subbands */
1280
18.9M
                            RE(tmp0) = RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1281
18.9M
                            IM(tmp0) = IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]);
1282
1283
18.9M
                            if (ps->use34hybrid_bands)
1284
12.2M
                            {
1285
12.2M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf34[sb][m]);
1286
12.2M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf34[sb][m]);
1287
12.2M
                            } else {
1288
6.69M
                                RE(Q_Fract_allpass) = RE(Q_Fract_allpass_SubQmf20[sb][m]);
1289
6.69M
                                IM(Q_Fract_allpass) = IM(Q_Fract_allpass_SubQmf20[sb][m]);
1290
6.69M
                            }
1291
20.2M
                        } else {
1292
                            /* select data from the QMF subbands */
1293
20.2M
                            RE(tmp0) = RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1294
20.2M
                            IM(tmp0) = IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]);
1295
1296
20.2M
                            RE(Q_Fract_allpass) = RE(Q_Fract_allpass_Qmf[sb][m]);
1297
20.2M
                            IM(Q_Fract_allpass) = IM(Q_Fract_allpass_Qmf[sb][m]);
1298
20.2M
                        }
1299
1300
                        /* delay by a fraction */
1301
                        /* z^(-d(m)) * Q_Fract_allpass[k,m] */
1302
39.2M
                        ComplexMult(&RE(tmp), &IM(tmp), RE(tmp0), IM(tmp0), RE(Q_Fract_allpass), IM(Q_Fract_allpass));
1303
1304
                        /* -a(m) * g_DecaySlope[k] */
1305
39.2M
                        RE(tmp) += -MUL_F(g_DecaySlope_filt[m], RE(R0));
1306
39.2M
                        IM(tmp) += -MUL_F(g_DecaySlope_filt[m], IM(R0));
1307
1308
                        /* -a(m) * g_DecaySlope[k] * Q_Fract_allpass[k,m] * z^(-d(m)) */
1309
39.2M
                        RE(tmp2) = RE(R0) + MUL_F(g_DecaySlope_filt[m], RE(tmp));
1310
39.2M
                        IM(tmp2) = IM(R0) + MUL_F(g_DecaySlope_filt[m], IM(tmp));
1311
1312
                        /* store sample */
1313
39.2M
                        if (gr < ps->num_hybrid_groups)
1314
18.9M
                        {
1315
18.9M
                            RE(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1316
18.9M
                            IM(ps->delay_SubQmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1317
20.2M
                        } else {
1318
20.2M
                            RE(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = RE(tmp2);
1319
20.2M
                            IM(ps->delay_Qmf_ser[m][temp_delay_ser[m]][sb]) = IM(tmp2);
1320
20.2M
                        }
1321
1322
                        /* store for next iteration (or as output value if last iteration) */
1323
39.2M
                        RE(R0) = RE(tmp);
1324
39.2M
                        IM(R0) = IM(tmp);
1325
39.2M
                    }
1326
13.0M
                }
1327
1328
                /* select b(k) for reading the transient ratio */
1329
27.4M
                bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1330
1331
                /* duck if a past transient is found */
1332
27.4M
                RE(R0) = MUL_R(G_TransientRatio[n][bk], RE(R0));
1333
27.4M
                IM(R0) = MUL_R(G_TransientRatio[n][bk], IM(R0));
1334
1335
27.4M
                if (gr < ps->num_hybrid_groups)
1336
6.31M
                {
1337
                    /* hybrid */
1338
6.31M
                    QMF_RE(X_hybrid_right[n][sb]) = RE(R0);
1339
6.31M
                    QMF_IM(X_hybrid_right[n][sb]) = IM(R0);
1340
21.1M
                } else {
1341
                    /* QMF */
1342
21.1M
                    QMF_RE(X_right[n][sb]) = RE(R0);
1343
21.1M
                    QMF_IM(X_right[n][sb]) = IM(R0);
1344
21.1M
                }
1345
1346
                /* Update delay buffer index */
1347
27.4M
                if (++temp_delay >= 2)
1348
13.7M
                {
1349
13.7M
                    temp_delay = 0;
1350
13.7M
                }
1351
1352
                /* update delay indices */
1353
27.4M
                if (sb > ps->nr_allpass_bands && gr >= ps->num_hybrid_groups)
1354
14.3M
                {
1355
                    /* delay_D depends on the samplerate, it can hold the values 14 and 1 */
1356
14.3M
                    if (++ps->delay_buf_index_delay[sb] >= ps->delay_D[sb])
1357
10.4M
                    {
1358
10.4M
                        ps->delay_buf_index_delay[sb] = 0;
1359
10.4M
                    }
1360
14.3M
                }
1361
1362
109M
                for (m = 0; m < NO_ALLPASS_LINKS; m++)
1363
82.3M
                {
1364
82.3M
                    if (++temp_delay_ser[m] >= ps->num_sample_delay_ser[m])
1365
21.1M
                    {
1366
21.1M
                        temp_delay_ser[m] = 0;
1367
21.1M
                    }
1368
82.3M
                }
1369
27.4M
            }
1370
880k
        }
1371
362k
    }
1372
1373
    /* update delay indices */
1374
11.2k
    ps->saved_delay = temp_delay;
1375
44.9k
    for (n = 0; n < NO_ALLPASS_LINKS; n++)
1376
33.6k
        ps->delay_buf_index_ser[n] = temp_delay_ser[n];
1377
11.2k
}
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
379k
{
1438
#ifdef FIXED_POINT
1439
395k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
#define ALPHA FRAC_CONST(0.948059448969)
1441
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
197k
    real_t abs_inphase = ps_abs(RE(c));
1444
197k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
197k
    if (abs_inphase > abs_quadrature) {
1447
169k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
169k
    } else {
1449
28.1k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
28.1k
    }
1451
#else
1452
181k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
379k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
197k
{
1438
197k
#ifdef FIXED_POINT
1439
197k
#define ps_abs(A) (((A) > 0) ? (A) : (-(A)))
1440
197k
#define ALPHA FRAC_CONST(0.948059448969)
1441
197k
#define BETA  FRAC_CONST(0.392699081699)
1442
1443
197k
    real_t abs_inphase = ps_abs(RE(c));
1444
197k
    real_t abs_quadrature = ps_abs(IM(c));
1445
1446
197k
    if (abs_inphase > abs_quadrature) {
1447
169k
        return MUL_F(abs_inphase, ALPHA) + MUL_F(abs_quadrature, BETA);
1448
169k
    } else {
1449
28.1k
        return MUL_F(abs_quadrature, ALPHA) + MUL_F(abs_inphase, BETA);
1450
28.1k
    }
1451
#else
1452
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
#endif
1454
197k
}
ps_dec.c:magnitude_c
Line
Count
Source
1437
181k
{
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
181k
    return sqrt(RE(c)*RE(c) + IM(c)*IM(c));
1453
181k
#endif
1454
181k
}
1455
1456
static void ps_mix_phase(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64],
1457
                         qmf_t X_hybrid_left[32][32], qmf_t X_hybrid_right[32][32])
1458
20.9k
{
1459
20.9k
    uint8_t n;
1460
20.9k
    uint8_t gr;
1461
20.9k
    uint8_t bk = 0;
1462
20.9k
    uint8_t sb, maxsb;
1463
20.9k
    uint8_t env;
1464
20.9k
    uint8_t nr_ipdopd_par;
1465
20.9k
    complex_t h11, h12, h21, h22;  // COEF
1466
20.9k
    complex_t H11, H12, H21, H22;  // COEF
1467
20.9k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
20.9k
    complex_t tempLeft, tempRight; // FRAC
1469
20.9k
    complex_t phaseLeft, phaseRight; // FRAC
1470
20.9k
    real_t L;
1471
20.9k
    const real_t *sf_iid;
1472
20.9k
    uint8_t no_iid_steps;
1473
1474
20.9k
    if (ps->iid_mode >= 3)
1475
8.66k
    {
1476
8.66k
        no_iid_steps = 15;
1477
8.66k
        sf_iid = sf_iid_fine;
1478
12.3k
    } else {
1479
12.3k
        no_iid_steps = 7;
1480
12.3k
        sf_iid = sf_iid_normal;
1481
12.3k
    }
1482
1483
20.9k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
12.3k
    {
1485
12.3k
        nr_ipdopd_par = 11; /* resolution */
1486
12.3k
    } else {
1487
8.57k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
8.57k
    }
1489
1490
706k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
685k
    {
1492
685k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
685k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
2.28M
        for (env = 0; env < ps->num_env; env++)
1498
1.59M
        {
1499
1.59M
            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.59M
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
382
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
382
                    -no_iid_steps);
1507
382
                ps->iid_index[env][bk] = -no_iid_steps;
1508
382
                abs_iid = no_iid_steps;
1509
1.59M
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
245
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
245
                    no_iid_steps);
1512
245
                ps->iid_index[env][bk] = no_iid_steps;
1513
245
                abs_iid = no_iid_steps;
1514
245
            }
1515
1.59M
            if (ps->icc_index[env][bk] < 0) {
1516
491
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
491
                ps->icc_index[env][bk] = 0;
1518
1.59M
            } 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.59M
            if (ps->icc_mode < 3)
1524
930k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
930k
                real_t c_1, c_2;  // COEF
1527
930k
                real_t cosa, sina;  // COEF
1528
930k
                real_t cosb, sinb;  // COEF
1529
930k
                real_t ab1, ab2;  // COEF
1530
930k
                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
930k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
930k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
930k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
930k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
930k
                if (ps->iid_mode >= 3)
1550
318k
                {
1551
318k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
318k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
612k
                } else {
1554
612k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
612k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
612k
                }
1557
1558
930k
                ab1 = MUL_C(cosb, cosa);
1559
930k
                ab2 = MUL_C(sinb, sina);
1560
930k
                ab3 = MUL_C(sinb, cosa);
1561
930k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
930k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
930k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
930k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
930k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
930k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
665k
                real_t sina, cosa;  // COEF
1571
665k
                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
665k
                if (ps->iid_mode >= 3)
1607
439k
                {
1608
439k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
439k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
439k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
439k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
439k
                } else {
1613
225k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
225k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
225k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
225k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
225k
                }
1618
1619
665k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
665k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
665k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
665k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
665k
            }
1624
1.59M
            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.59M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
189k
            {
1632
189k
                int8_t i;
1633
189k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
189k
                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
98.8k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
98.8k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
98.8k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
98.8k
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
90.8k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
90.8k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
90.8k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
90.8k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
#endif
1652
1653
                /* save current value */
1654
189k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
189k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
189k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
189k
                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
98.8k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
98.8k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
98.8k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
98.8k
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
90.8k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
90.8k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
90.8k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
90.8k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
#endif
1672
1673
                /* ringbuffer index */
1674
189k
                if (i == 0)
1675
95.7k
                {
1676
95.7k
                    i = 2;
1677
95.7k
                }
1678
189k
                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
98.8k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
98.8k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
98.8k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
98.8k
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
90.8k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
90.8k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
90.8k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
90.8k
                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
189k
                xy = magnitude_c(tempRight);
1716
189k
                pq = magnitude_c(tempLeft);
1717
1718
189k
                if (xy != 0)
1719
189k
                {
1720
189k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
189k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
189k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
189k
                xypq = MUL_F(xy, pq);
1728
1729
189k
                if (xypq != 0)
1730
189k
                {
1731
189k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
189k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
189k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
189k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
189k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
189k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
189k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
189k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
189k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
189k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
189k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
189k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
189k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
189k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
189k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
1.59M
            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.59M
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
1.59M
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
1.59M
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
1.59M
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
1.59M
            RE(H11) = RE(ps->h11_prev[gr]);
1766
1.59M
            RE(H12) = RE(ps->h12_prev[gr]);
1767
1.59M
            RE(H21) = RE(ps->h21_prev[gr]);
1768
1.59M
            RE(H22) = RE(ps->h22_prev[gr]);
1769
1.59M
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
1.59M
            RE(ps->h11_prev[gr]) = RE(h11);
1772
1.59M
            RE(ps->h12_prev[gr]) = RE(h12);
1773
1.59M
            RE(ps->h21_prev[gr]) = RE(h21);
1774
1.59M
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
1.59M
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
189k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
189k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
189k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
189k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
189k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
189k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
189k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
189k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
189k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
189k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
27.2k
                {
1792
27.2k
                    IM(deltaH11) = -IM(deltaH11);
1793
27.2k
                    IM(deltaH12) = -IM(deltaH12);
1794
27.2k
                    IM(deltaH21) = -IM(deltaH21);
1795
27.2k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
27.2k
                    IM(H11) = -IM(H11);
1798
27.2k
                    IM(H12) = -IM(H12);
1799
27.2k
                    IM(H21) = -IM(H21);
1800
27.2k
                    IM(H22) = -IM(H22);
1801
27.2k
                }
1802
1803
189k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
189k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
189k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
189k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
189k
            }
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
1.97M
                {
1819
1.97M
                    IM(H11) += IM(deltaH11);
1820
1.97M
                    IM(H12) += IM(deltaH12);
1821
1.97M
                    IM(H21) += IM(deltaH21);
1822
1.97M
                    IM(H22) += IM(deltaH22);
1823
1.97M
                }
1824
1825
                /* channel is an alias to the subband */
1826
72.8M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
51.4M
                {
1828
51.4M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
51.4M
                    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
39.4M
                    } else {
1838
39.4M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
39.4M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
39.4M
                        RE(inRight) = RE(X_right[n][sb]);
1841
39.4M
                        IM(inRight) = IM(X_right[n][sb]);
1842
39.4M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
51.4M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
51.4M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
51.4M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
51.4M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
51.4M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.98M
                    {
1855
                        /* apply rotation */
1856
1.98M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.98M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.98M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.98M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.98M
                    }
1861
1862
                    /* store final samples */
1863
51.4M
                    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
39.4M
                    } else {
1870
39.4M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
39.4M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
39.4M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
39.4M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
39.4M
                    }
1875
51.4M
                }
1876
21.3M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
1.59M
            ps->phase_hist++;
1880
1.59M
            if (ps->phase_hist == 2)
1881
798k
            {
1882
798k
                ps->phase_hist = 0;
1883
798k
            }
1884
1.59M
        }
1885
685k
    }
1886
20.9k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
9.74k
{
1459
9.74k
    uint8_t n;
1460
9.74k
    uint8_t gr;
1461
9.74k
    uint8_t bk = 0;
1462
9.74k
    uint8_t sb, maxsb;
1463
9.74k
    uint8_t env;
1464
9.74k
    uint8_t nr_ipdopd_par;
1465
9.74k
    complex_t h11, h12, h21, h22;  // COEF
1466
9.74k
    complex_t H11, H12, H21, H22;  // COEF
1467
9.74k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
9.74k
    complex_t tempLeft, tempRight; // FRAC
1469
9.74k
    complex_t phaseLeft, phaseRight; // FRAC
1470
9.74k
    real_t L;
1471
9.74k
    const real_t *sf_iid;
1472
9.74k
    uint8_t no_iid_steps;
1473
1474
9.74k
    if (ps->iid_mode >= 3)
1475
3.75k
    {
1476
3.75k
        no_iid_steps = 15;
1477
3.75k
        sf_iid = sf_iid_fine;
1478
5.98k
    } else {
1479
5.98k
        no_iid_steps = 7;
1480
5.98k
        sf_iid = sf_iid_normal;
1481
5.98k
    }
1482
1483
9.74k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
5.64k
    {
1485
5.64k
        nr_ipdopd_par = 11; /* resolution */
1486
5.64k
    } else {
1487
4.09k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
4.09k
    }
1489
1490
332k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
322k
    {
1492
322k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
322k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.09M
        for (env = 0; env < ps->num_env; env++)
1498
768k
        {
1499
768k
            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
768k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
104
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
104
                    -no_iid_steps);
1507
104
                ps->iid_index[env][bk] = -no_iid_steps;
1508
104
                abs_iid = no_iid_steps;
1509
768k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
91
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
91
                    no_iid_steps);
1512
91
                ps->iid_index[env][bk] = no_iid_steps;
1513
91
                abs_iid = no_iid_steps;
1514
91
            }
1515
768k
            if (ps->icc_index[env][bk] < 0) {
1516
99
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
99
                ps->icc_index[env][bk] = 0;
1518
768k
            } 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
768k
            if (ps->icc_mode < 3)
1524
391k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
391k
                real_t c_1, c_2;  // COEF
1527
391k
                real_t cosa, sina;  // COEF
1528
391k
                real_t cosb, sinb;  // COEF
1529
391k
                real_t ab1, ab2;  // COEF
1530
391k
                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
391k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
391k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
391k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
391k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
391k
                if (ps->iid_mode >= 3)
1550
71.7k
                {
1551
71.7k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
71.7k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
319k
                } else {
1554
319k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
319k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
319k
                }
1557
1558
391k
                ab1 = MUL_C(cosb, cosa);
1559
391k
                ab2 = MUL_C(sinb, sina);
1560
391k
                ab3 = MUL_C(sinb, cosa);
1561
391k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
391k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
391k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
391k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
391k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
391k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
376k
                real_t sina, cosa;  // COEF
1571
376k
                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
376k
                if (ps->iid_mode >= 3)
1607
257k
                {
1608
257k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
257k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
257k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
257k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
257k
                } else {
1613
119k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
119k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
119k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
119k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
119k
                }
1618
1619
376k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
376k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
376k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
376k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
376k
            }
1624
768k
            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
768k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
98.8k
            {
1632
98.8k
                int8_t i;
1633
98.8k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
98.8k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
98.8k
#ifdef FIXED_POINT
1640
                /* divide by 4*2, shift right 3 bits;
1641
                   extra halving to avoid overflows; it is ok, because result is normalized */
1642
98.8k
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
98.8k
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
98.8k
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
98.8k
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
#endif
1652
1653
                /* save current value */
1654
98.8k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
98.8k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
98.8k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
98.8k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
98.8k
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
98.8k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
98.8k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
98.8k
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
98.8k
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
#endif
1672
1673
                /* ringbuffer index */
1674
98.8k
                if (i == 0)
1675
49.9k
                {
1676
49.9k
                    i = 2;
1677
49.9k
                }
1678
98.8k
                i--;
1679
1680
                /* get value before previous */
1681
98.8k
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
98.8k
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
98.8k
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
98.8k
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
98.8k
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
                IM(tempRight) += MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1692
#endif
1693
1694
#if 0 /* original code */
1695
                ipd = (float)atan2(IM(tempLeft), RE(tempLeft));
1696
                opd = (float)atan2(IM(tempRight), RE(tempRight));
1697
1698
                /* phase rotation */
1699
                RE(phaseLeft) = (float)cos(opd);
1700
                IM(phaseLeft) = (float)sin(opd);
1701
                opd -= ipd;
1702
                RE(phaseRight) = (float)cos(opd);
1703
                IM(phaseRight) = (float)sin(opd);
1704
#else
1705
1706
                // x = IM(tempLeft)
1707
                // y = RE(tempLeft)
1708
                // p = IM(tempRight)
1709
                // q = RE(tempRight)
1710
                // cos(atan2(x,y)) = y/sqrt((x*x) + (y*y))
1711
                // sin(atan2(x,y)) = x/sqrt((x*x) + (y*y))
1712
                // cos(atan2(x,y)-atan2(p,q)) = (y*q + x*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1713
                // sin(atan2(x,y)-atan2(p,q)) = (x*q - y*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1714
1715
98.8k
                xy = magnitude_c(tempRight);
1716
98.8k
                pq = magnitude_c(tempLeft);
1717
1718
98.8k
                if (xy != 0)
1719
98.8k
                {
1720
98.8k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
98.8k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
98.8k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
98.8k
                xypq = MUL_F(xy, pq);
1728
1729
98.8k
                if (xypq != 0)
1730
98.8k
                {
1731
98.8k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
98.8k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
98.8k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
98.8k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
98.8k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
98.8k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
98.8k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
98.8k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
98.8k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
98.8k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
98.8k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
98.8k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
98.8k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
98.8k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
98.8k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
768k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
768k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
768k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
768k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
768k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
768k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
768k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
768k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
768k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
768k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
768k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
768k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
768k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
768k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
768k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
98.8k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
98.8k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
98.8k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
98.8k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
98.8k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
98.8k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
98.8k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
98.8k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
98.8k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
98.8k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
14.1k
                {
1792
14.1k
                    IM(deltaH11) = -IM(deltaH11);
1793
14.1k
                    IM(deltaH12) = -IM(deltaH12);
1794
14.1k
                    IM(deltaH21) = -IM(deltaH21);
1795
14.1k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
14.1k
                    IM(H11) = -IM(H11);
1798
14.1k
                    IM(H12) = -IM(H12);
1799
14.1k
                    IM(H21) = -IM(H21);
1800
14.1k
                    IM(H22) = -IM(H22);
1801
14.1k
                }
1802
1803
98.8k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
98.8k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
98.8k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
98.8k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
98.8k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
10.8M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
10.0M
            {
1812
                /* addition finalises the interpolation over every n */
1813
10.0M
                RE(H11) += RE(deltaH11);
1814
10.0M
                RE(H12) += RE(deltaH12);
1815
10.0M
                RE(H21) += RE(deltaH21);
1816
10.0M
                RE(H22) += RE(deltaH22);
1817
10.0M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
1.09M
                {
1819
1.09M
                    IM(H11) += IM(deltaH11);
1820
1.09M
                    IM(H12) += IM(deltaH12);
1821
1.09M
                    IM(H21) += IM(deltaH21);
1822
1.09M
                    IM(H22) += IM(deltaH22);
1823
1.09M
                }
1824
1825
                /* channel is an alias to the subband */
1826
34.0M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
24.0M
                {
1828
24.0M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
24.0M
                    if (gr < ps->num_hybrid_groups)
1832
5.66M
                    {
1833
5.66M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
5.66M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
5.66M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
5.66M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
18.3M
                    } else {
1838
18.3M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
18.3M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
18.3M
                        RE(inRight) = RE(X_right[n][sb]);
1841
18.3M
                        IM(inRight) = IM(X_right[n][sb]);
1842
18.3M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
24.0M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
24.0M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
24.0M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
24.0M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
24.0M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
1.09M
                    {
1855
                        /* apply rotation */
1856
1.09M
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
1.09M
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
1.09M
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
1.09M
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
1.09M
                    }
1861
1862
                    /* store final samples */
1863
24.0M
                    if (gr < ps->num_hybrid_groups)
1864
5.66M
                    {
1865
5.66M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
5.66M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
5.66M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
5.66M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
18.3M
                    } else {
1870
18.3M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
18.3M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
18.3M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
18.3M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
18.3M
                    }
1875
24.0M
                }
1876
10.0M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
768k
            ps->phase_hist++;
1880
768k
            if (ps->phase_hist == 2)
1881
384k
            {
1882
384k
                ps->phase_hist = 0;
1883
384k
            }
1884
768k
        }
1885
322k
    }
1886
9.74k
}
ps_dec.c:ps_mix_phase
Line
Count
Source
1458
11.2k
{
1459
11.2k
    uint8_t n;
1460
11.2k
    uint8_t gr;
1461
11.2k
    uint8_t bk = 0;
1462
11.2k
    uint8_t sb, maxsb;
1463
11.2k
    uint8_t env;
1464
11.2k
    uint8_t nr_ipdopd_par;
1465
11.2k
    complex_t h11, h12, h21, h22;  // COEF
1466
11.2k
    complex_t H11, H12, H21, H22;  // COEF
1467
11.2k
    complex_t deltaH11, deltaH12, deltaH21, deltaH22;  // COEF
1468
11.2k
    complex_t tempLeft, tempRight; // FRAC
1469
11.2k
    complex_t phaseLeft, phaseRight; // FRAC
1470
11.2k
    real_t L;
1471
11.2k
    const real_t *sf_iid;
1472
11.2k
    uint8_t no_iid_steps;
1473
1474
11.2k
    if (ps->iid_mode >= 3)
1475
4.90k
    {
1476
4.90k
        no_iid_steps = 15;
1477
4.90k
        sf_iid = sf_iid_fine;
1478
6.32k
    } else {
1479
6.32k
        no_iid_steps = 7;
1480
6.32k
        sf_iid = sf_iid_normal;
1481
6.32k
    }
1482
1483
11.2k
    if (ps->ipd_mode == 0 || ps->ipd_mode == 3)
1484
6.74k
    {
1485
6.74k
        nr_ipdopd_par = 11; /* resolution */
1486
6.74k
    } else {
1487
4.48k
        nr_ipdopd_par = ps->nr_ipdopd_par;
1488
4.48k
    }
1489
1490
374k
    for (gr = 0; gr < ps->num_groups; gr++)
1491
362k
    {
1492
362k
        bk = (~NEGATE_IPD_MASK) & ps->map_group2bk[gr];
1493
1494
        /* use one channel per group in the subqmf domain */
1495
362k
        maxsb = (gr < ps->num_hybrid_groups) ? ps->group_border[gr] + 1 : ps->group_border[gr + 1];
1496
1497
1.19M
        for (env = 0; env < ps->num_env; env++)
1498
827k
        {
1499
827k
            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
827k
            if (ps->iid_index[env][bk] < -no_iid_steps) {
1505
278
                fprintf(stderr, "Warning: invalid iid_index: %d < %d\n", ps->iid_index[env][bk],
1506
278
                    -no_iid_steps);
1507
278
                ps->iid_index[env][bk] = -no_iid_steps;
1508
278
                abs_iid = no_iid_steps;
1509
827k
            } else if (ps->iid_index[env][bk] > no_iid_steps) {
1510
154
                fprintf(stderr, "Warning: invalid iid_index: %d > %d\n", ps->iid_index[env][bk],
1511
154
                    no_iid_steps);
1512
154
                ps->iid_index[env][bk] = no_iid_steps;
1513
154
                abs_iid = no_iid_steps;
1514
154
            }
1515
827k
            if (ps->icc_index[env][bk] < 0) {
1516
392
                fprintf(stderr, "Warning: invalid icc_index: %d < 0\n", ps->icc_index[env][bk]);
1517
392
                ps->icc_index[env][bk] = 0;
1518
827k
            } 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
827k
            if (ps->icc_mode < 3)
1524
539k
            {
1525
                /* type 'A' mixing as described in 8.6.4.6.2.1 */
1526
539k
                real_t c_1, c_2;  // COEF
1527
539k
                real_t cosa, sina;  // COEF
1528
539k
                real_t cosb, sinb;  // COEF
1529
539k
                real_t ab1, ab2;  // COEF
1530
539k
                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
539k
                c_1 = sf_iid[no_iid_steps + ps->iid_index[env][bk]];
1543
539k
                c_2 = sf_iid[no_iid_steps - ps->iid_index[env][bk]];
1544
1545
                /* calculate alpha and beta using the ICC parameters */
1546
539k
                cosa = cos_alphas[ps->icc_index[env][bk]];
1547
539k
                sina = sin_alphas[ps->icc_index[env][bk]];
1548
1549
539k
                if (ps->iid_mode >= 3)
1550
246k
                {
1551
246k
                    cosb = cos_betas_fine[abs_iid][ps->icc_index[env][bk]];
1552
246k
                    sinb = sin_betas_fine[abs_iid][ps->icc_index[env][bk]];
1553
292k
                } else {
1554
292k
                    cosb = cos_betas_normal[abs_iid][ps->icc_index[env][bk]];
1555
292k
                    sinb = sin_betas_normal[abs_iid][ps->icc_index[env][bk]];
1556
292k
                }
1557
1558
539k
                ab1 = MUL_C(cosb, cosa);
1559
539k
                ab2 = MUL_C(sinb, sina);
1560
539k
                ab3 = MUL_C(sinb, cosa);
1561
539k
                ab4 = MUL_C(cosb, sina);
1562
1563
                /* h_xy: COEF */
1564
539k
                RE(h11) = MUL_C(c_2, (ab1 - ab2));
1565
539k
                RE(h12) = MUL_C(c_1, (ab1 + ab2));
1566
539k
                RE(h21) = MUL_C(c_2, (ab3 + ab4));
1567
539k
                RE(h22) = MUL_C(c_1, (ab3 - ab4));
1568
539k
            } else {
1569
                /* type 'B' mixing as described in 8.6.4.6.2.2 */
1570
288k
                real_t sina, cosa;  // COEF
1571
288k
                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
288k
                if (ps->iid_mode >= 3)
1607
181k
                {
1608
181k
                    cosa = sincos_alphas_B_fine[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1609
181k
                    sina = sincos_alphas_B_fine[30 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1610
181k
                    cosg = cos_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1611
181k
                    sing = sin_gammas_fine[abs_iid][ps->icc_index[env][bk]];
1612
181k
                } else {
1613
106k
                    cosa = sincos_alphas_B_normal[no_iid_steps + ps->iid_index[env][bk]][ps->icc_index[env][bk]];
1614
106k
                    sina = sincos_alphas_B_normal[14 - (no_iid_steps + ps->iid_index[env][bk])][ps->icc_index[env][bk]];
1615
106k
                    cosg = cos_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1616
106k
                    sing = sin_gammas_normal[abs_iid][ps->icc_index[env][bk]];
1617
106k
                }
1618
1619
288k
                RE(h11) = MUL_C(COEF_SQRT2, MUL_C(cosa, cosg));
1620
288k
                RE(h12) = MUL_C(COEF_SQRT2, MUL_C(sina, cosg));
1621
288k
                RE(h21) = MUL_C(COEF_SQRT2, MUL_C(-cosa, sing));
1622
288k
                RE(h22) = MUL_C(COEF_SQRT2, MUL_C(sina, sing));
1623
288k
            }
1624
827k
            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
827k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1631
90.8k
            {
1632
90.8k
                int8_t i;
1633
90.8k
                real_t xy, pq, xypq;  // FRAC
1634
1635
                /* ringbuffer index */
1636
90.8k
                i = ps->phase_hist;
1637
1638
                /* previous value */
1639
#ifdef FIXED_POINT
1640
                /* divide by 4*2, shift right 3 bits;
1641
                   extra halving to avoid overflows; it is ok, because result is normalized */
1642
                RE(tempLeft)  = RE(ps->ipd_prev[bk][i]) >> 3;
1643
                IM(tempLeft)  = IM(ps->ipd_prev[bk][i]) >> 3;
1644
                RE(tempRight) = RE(ps->opd_prev[bk][i]) >> 3;
1645
                IM(tempRight) = IM(ps->opd_prev[bk][i]) >> 3;
1646
#else
1647
90.8k
                RE(tempLeft)  = MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1648
90.8k
                IM(tempLeft)  = MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.25));
1649
90.8k
                RE(tempRight) = MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1650
90.8k
                IM(tempRight) = MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.25));
1651
90.8k
#endif
1652
1653
                /* save current value */
1654
90.8k
                RE(ps->ipd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->ipd_index[env][bk])];
1655
90.8k
                IM(ps->ipd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->ipd_index[env][bk])];
1656
90.8k
                RE(ps->opd_prev[bk][i]) = ipdopd_cos_tab[abs(ps->opd_index[env][bk])];
1657
90.8k
                IM(ps->opd_prev[bk][i]) = ipdopd_sin_tab[abs(ps->opd_index[env][bk])];
1658
1659
                /* add current value */
1660
#ifdef FIXED_POINT
1661
                /* extra halving to avoid overflows */
1662
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]) >> 1;
1663
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]) >> 1;
1664
                RE(tempRight) += RE(ps->opd_prev[bk][i]) >> 1;
1665
                IM(tempRight) += IM(ps->opd_prev[bk][i]) >> 1;
1666
#else
1667
90.8k
                RE(tempLeft)  += RE(ps->ipd_prev[bk][i]);
1668
90.8k
                IM(tempLeft)  += IM(ps->ipd_prev[bk][i]);
1669
90.8k
                RE(tempRight) += RE(ps->opd_prev[bk][i]);
1670
90.8k
                IM(tempRight) += IM(ps->opd_prev[bk][i]);
1671
90.8k
#endif
1672
1673
                /* ringbuffer index */
1674
90.8k
                if (i == 0)
1675
45.8k
                {
1676
45.8k
                    i = 2;
1677
45.8k
                }
1678
90.8k
                i--;
1679
1680
                /* get value before previous */
1681
#ifdef FIXED_POINT
1682
                /* dividing by 2*2, shift right 2 bits; extra halving to avoid overflows */
1683
                RE(tempLeft)  += (RE(ps->ipd_prev[bk][i]) >> 2);
1684
                IM(tempLeft)  += (IM(ps->ipd_prev[bk][i]) >> 2);
1685
                RE(tempRight) += (RE(ps->opd_prev[bk][i]) >> 2);
1686
                IM(tempRight) += (IM(ps->opd_prev[bk][i]) >> 2);
1687
#else
1688
90.8k
                RE(tempLeft)  += MUL_F(RE(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1689
90.8k
                IM(tempLeft)  += MUL_F(IM(ps->ipd_prev[bk][i]), FRAC_CONST(0.5));
1690
90.8k
                RE(tempRight) += MUL_F(RE(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1691
90.8k
                IM(tempRight) += MUL_F(IM(ps->opd_prev[bk][i]), FRAC_CONST(0.5));
1692
90.8k
#endif
1693
1694
#if 0 /* original code */
1695
                ipd = (float)atan2(IM(tempLeft), RE(tempLeft));
1696
                opd = (float)atan2(IM(tempRight), RE(tempRight));
1697
1698
                /* phase rotation */
1699
                RE(phaseLeft) = (float)cos(opd);
1700
                IM(phaseLeft) = (float)sin(opd);
1701
                opd -= ipd;
1702
                RE(phaseRight) = (float)cos(opd);
1703
                IM(phaseRight) = (float)sin(opd);
1704
#else
1705
1706
                // x = IM(tempLeft)
1707
                // y = RE(tempLeft)
1708
                // p = IM(tempRight)
1709
                // q = RE(tempRight)
1710
                // cos(atan2(x,y)) = y/sqrt((x*x) + (y*y))
1711
                // sin(atan2(x,y)) = x/sqrt((x*x) + (y*y))
1712
                // cos(atan2(x,y)-atan2(p,q)) = (y*q + x*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1713
                // sin(atan2(x,y)-atan2(p,q)) = (x*q - y*p) / ( sqrt((x*x) + (y*y)) * sqrt((p*p) + (q*q)) );
1714
1715
90.8k
                xy = magnitude_c(tempRight);
1716
90.8k
                pq = magnitude_c(tempLeft);
1717
1718
90.8k
                if (xy != 0)
1719
90.8k
                {
1720
90.8k
                    RE(phaseLeft) = DIV_F(RE(tempRight), xy);
1721
90.8k
                    IM(phaseLeft) = DIV_F(IM(tempRight), xy);
1722
90.8k
                } else {
1723
0
                    RE(phaseLeft) = 0;
1724
0
                    IM(phaseLeft) = 0;
1725
0
                }
1726
1727
90.8k
                xypq = MUL_F(xy, pq);
1728
1729
90.8k
                if (xypq != 0)
1730
90.8k
                {
1731
90.8k
                    real_t tmp1 = MUL_F(RE(tempRight), RE(tempLeft)) + MUL_F(IM(tempRight), IM(tempLeft));
1732
90.8k
                    real_t tmp2 = MUL_F(IM(tempRight), RE(tempLeft)) - MUL_F(RE(tempRight), IM(tempLeft));
1733
1734
90.8k
                    RE(phaseRight) = DIV_F(tmp1, xypq);
1735
90.8k
                    IM(phaseRight) = DIV_F(tmp2, xypq);
1736
90.8k
                } else {
1737
0
                    RE(phaseRight) = 0;
1738
0
                    IM(phaseRight) = 0;
1739
0
                }
1740
1741
90.8k
#endif
1742
1743
                /* MUL_F(COEF, REAL) = COEF */
1744
90.8k
                IM(h11) = MUL_F(RE(h11), IM(phaseLeft));
1745
90.8k
                IM(h12) = MUL_F(RE(h12), IM(phaseRight));
1746
90.8k
                IM(h21) = MUL_F(RE(h21), IM(phaseLeft));
1747
90.8k
                IM(h22) = MUL_F(RE(h22), IM(phaseRight));
1748
1749
90.8k
                RE(h11) = MUL_F(RE(h11), RE(phaseLeft));
1750
90.8k
                RE(h12) = MUL_F(RE(h12), RE(phaseRight));
1751
90.8k
                RE(h21) = MUL_F(RE(h21), RE(phaseLeft));
1752
90.8k
                RE(h22) = MUL_F(RE(h22), RE(phaseRight));
1753
90.8k
            }
1754
1755
            /* length of the envelope n_e+1 - n_e (in time samples) */
1756
            /* 0 < L <= 32: integer */
1757
827k
            L = (real_t)(ps->border_position[env + 1] - ps->border_position[env]);
1758
1759
            /* obtain final H_xy by means of linear interpolation */
1760
827k
            RE(deltaH11) = (RE(h11) - RE(ps->h11_prev[gr])) / L;
1761
827k
            RE(deltaH12) = (RE(h12) - RE(ps->h12_prev[gr])) / L;
1762
827k
            RE(deltaH21) = (RE(h21) - RE(ps->h21_prev[gr])) / L;
1763
827k
            RE(deltaH22) = (RE(h22) - RE(ps->h22_prev[gr])) / L;
1764
1765
827k
            RE(H11) = RE(ps->h11_prev[gr]);
1766
827k
            RE(H12) = RE(ps->h12_prev[gr]);
1767
827k
            RE(H21) = RE(ps->h21_prev[gr]);
1768
827k
            RE(H22) = RE(ps->h22_prev[gr]);
1769
827k
            IM(H11) = IM(H12) = IM(H21) = IM(H22) = 0;
1770
1771
827k
            RE(ps->h11_prev[gr]) = RE(h11);
1772
827k
            RE(ps->h12_prev[gr]) = RE(h12);
1773
827k
            RE(ps->h21_prev[gr]) = RE(h21);
1774
827k
            RE(ps->h22_prev[gr]) = RE(h22);
1775
1776
            /* only calculate imaginary part when needed */
1777
827k
            if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1778
90.8k
            {
1779
                /* obtain final H_xy by means of linear interpolation */
1780
90.8k
                IM(deltaH11) = (IM(h11) - IM(ps->h11_prev[gr])) / L;
1781
90.8k
                IM(deltaH12) = (IM(h12) - IM(ps->h12_prev[gr])) / L;
1782
90.8k
                IM(deltaH21) = (IM(h21) - IM(ps->h21_prev[gr])) / L;
1783
90.8k
                IM(deltaH22) = (IM(h22) - IM(ps->h22_prev[gr])) / L;
1784
1785
90.8k
                IM(H11) = IM(ps->h11_prev[gr]);
1786
90.8k
                IM(H12) = IM(ps->h12_prev[gr]);
1787
90.8k
                IM(H21) = IM(ps->h21_prev[gr]);
1788
90.8k
                IM(H22) = IM(ps->h22_prev[gr]);
1789
1790
90.8k
                if ((NEGATE_IPD_MASK & ps->map_group2bk[gr]) != 0)
1791
13.1k
                {
1792
13.1k
                    IM(deltaH11) = -IM(deltaH11);
1793
13.1k
                    IM(deltaH12) = -IM(deltaH12);
1794
13.1k
                    IM(deltaH21) = -IM(deltaH21);
1795
13.1k
                    IM(deltaH22) = -IM(deltaH22);
1796
1797
13.1k
                    IM(H11) = -IM(H11);
1798
13.1k
                    IM(H12) = -IM(H12);
1799
13.1k
                    IM(H21) = -IM(H21);
1800
13.1k
                    IM(H22) = -IM(H22);
1801
13.1k
                }
1802
1803
90.8k
                IM(ps->h11_prev[gr]) = IM(h11);
1804
90.8k
                IM(ps->h12_prev[gr]) = IM(h12);
1805
90.8k
                IM(ps->h21_prev[gr]) = IM(h21);
1806
90.8k
                IM(ps->h22_prev[gr]) = IM(h22);
1807
90.8k
            }
1808
1809
            /* apply H_xy to the current envelope band of the decorrelated subband */
1810
12.1M
            for (n = ps->border_position[env]; n < ps->border_position[env + 1]; n++)
1811
11.2M
            {
1812
                /* addition finalises the interpolation over every n */
1813
11.2M
                RE(H11) += RE(deltaH11);
1814
11.2M
                RE(H12) += RE(deltaH12);
1815
11.2M
                RE(H21) += RE(deltaH21);
1816
11.2M
                RE(H22) += RE(deltaH22);
1817
11.2M
                if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1818
883k
                {
1819
883k
                    IM(H11) += IM(deltaH11);
1820
883k
                    IM(H12) += IM(deltaH12);
1821
883k
                    IM(H21) += IM(deltaH21);
1822
883k
                    IM(H22) += IM(deltaH22);
1823
883k
                }
1824
1825
                /* channel is an alias to the subband */
1826
38.7M
                for (sb = ps->group_border[gr]; sb < maxsb; sb++)
1827
27.4M
                {
1828
27.4M
                    complex_t inLeft, inRight;  // precision_of in(Left|Right) == precision_of X_(left|right)
1829
1830
                    /* load decorrelated samples */
1831
27.4M
                    if (gr < ps->num_hybrid_groups)
1832
6.31M
                    {
1833
6.31M
                        RE(inLeft) =  RE(X_hybrid_left[n][sb]);
1834
6.31M
                        IM(inLeft) =  IM(X_hybrid_left[n][sb]);
1835
6.31M
                        RE(inRight) = RE(X_hybrid_right[n][sb]);
1836
6.31M
                        IM(inRight) = IM(X_hybrid_right[n][sb]);
1837
21.1M
                    } else {
1838
21.1M
                        RE(inLeft) =  RE(X_left[n][sb]);
1839
21.1M
                        IM(inLeft) =  IM(X_left[n][sb]);
1840
21.1M
                        RE(inRight) = RE(X_right[n][sb]);
1841
21.1M
                        IM(inRight) = IM(X_right[n][sb]);
1842
21.1M
                    }
1843
1844
                    /* precision_of temp(Left|Right) == precision_of X_(left|right) */
1845
1846
                    /* apply mixing */
1847
27.4M
                    RE(tempLeft) =  MUL_C(RE(H11), RE(inLeft)) + MUL_C(RE(H21), RE(inRight));
1848
27.4M
                    IM(tempLeft) =  MUL_C(RE(H11), IM(inLeft)) + MUL_C(RE(H21), IM(inRight));
1849
27.4M
                    RE(tempRight) = MUL_C(RE(H12), RE(inLeft)) + MUL_C(RE(H22), RE(inRight));
1850
27.4M
                    IM(tempRight) = MUL_C(RE(H12), IM(inLeft)) + MUL_C(RE(H22), IM(inRight));
1851
1852
                    /* only perform imaginary operations when needed */
1853
27.4M
                    if ((ps->enable_ipdopd) && (bk < nr_ipdopd_par))
1854
887k
                    {
1855
                        /* apply rotation */
1856
887k
                        RE(tempLeft)  -= MUL_C(IM(H11), IM(inLeft)) + MUL_C(IM(H21), IM(inRight));
1857
887k
                        IM(tempLeft)  += MUL_C(IM(H11), RE(inLeft)) + MUL_C(IM(H21), RE(inRight));
1858
887k
                        RE(tempRight) -= MUL_C(IM(H12), IM(inLeft)) + MUL_C(IM(H22), IM(inRight));
1859
887k
                        IM(tempRight) += MUL_C(IM(H12), RE(inLeft)) + MUL_C(IM(H22), RE(inRight));
1860
887k
                    }
1861
1862
                    /* store final samples */
1863
27.4M
                    if (gr < ps->num_hybrid_groups)
1864
6.31M
                    {
1865
6.31M
                        RE(X_hybrid_left[n][sb])  = RE(tempLeft);
1866
6.31M
                        IM(X_hybrid_left[n][sb])  = IM(tempLeft);
1867
6.31M
                        RE(X_hybrid_right[n][sb]) = RE(tempRight);
1868
6.31M
                        IM(X_hybrid_right[n][sb]) = IM(tempRight);
1869
21.1M
                    } else {
1870
21.1M
                        RE(X_left[n][sb])  = RE(tempLeft);
1871
21.1M
                        IM(X_left[n][sb])  = IM(tempLeft);
1872
21.1M
                        RE(X_right[n][sb]) = RE(tempRight);
1873
21.1M
                        IM(X_right[n][sb]) = IM(tempRight);
1874
21.1M
                    }
1875
27.4M
                }
1876
11.2M
            }
1877
1878
            /* shift phase smoother's circular buffer index */
1879
827k
            ps->phase_hist++;
1880
827k
            if (ps->phase_hist == 2)
1881
413k
            {
1882
413k
                ps->phase_hist = 0;
1883
413k
            }
1884
827k
        }
1885
362k
    }
1886
11.2k
}
1887
1888
void ps_free(ps_info *ps)
1889
32.1k
{
1890
    /* free hybrid filterbank structures */
1891
32.1k
    hybrid_free(ps->hyb);
1892
1893
32.1k
    faad_free(ps);
1894
32.1k
}
1895
1896
ps_info *ps_init(uint8_t sr_index, uint8_t numTimeSlotsRate)
1897
32.1k
{
1898
32.1k
    uint8_t i;
1899
32.1k
    uint8_t short_delay_band;
1900
1901
32.1k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
32.1k
    memset(ps, 0, sizeof(ps_info));
1903
1904
32.1k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
32.1k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
32.1k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
32.1k
    ps->saved_delay = 0;
1911
1912
2.08M
    for (i = 0; i < 64; i++)
1913
2.05M
    {
1914
2.05M
        ps->delay_buf_index_delay[i] = 0;
1915
2.05M
    }
1916
1917
128k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
96.4k
    {
1919
96.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
96.4k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
96.4k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
96.4k
#endif
1932
96.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
32.1k
    short_delay_band = 35;
1950
32.1k
    ps->nr_allpass_bands = 22;
1951
32.1k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
32.1k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
32.1k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
1.15M
    for (i = 0; i < short_delay_band; i++)
1957
1.12M
    {
1958
1.12M
        ps->delay_D[i] = 14;
1959
1.12M
    }
1960
964k
    for (i = short_delay_band; i < 64; i++)
1961
932k
    {
1962
932k
        ps->delay_D[i] = 1;
1963
932k
    }
1964
1965
    /* mixing and phase */
1966
1.63M
    for (i = 0; i < 50; i++)
1967
1.60M
    {
1968
1.60M
        RE(ps->h11_prev[i]) = 1;
1969
1.60M
        IM(ps->h11_prev[i]) = 1;
1970
1.60M
        RE(ps->h12_prev[i]) = 1;
1971
1.60M
        IM(ps->h12_prev[i]) = 1;
1972
1.60M
    }
1973
1974
32.1k
    ps->phase_hist = 0;
1975
1976
674k
    for (i = 0; i < 20; i++)
1977
642k
    {
1978
642k
        RE(ps->ipd_prev[i][0]) = 0;
1979
642k
        IM(ps->ipd_prev[i][0]) = 0;
1980
642k
        RE(ps->ipd_prev[i][1]) = 0;
1981
642k
        IM(ps->ipd_prev[i][1]) = 0;
1982
642k
        RE(ps->opd_prev[i][0]) = 0;
1983
642k
        IM(ps->opd_prev[i][0]) = 0;
1984
642k
        RE(ps->opd_prev[i][1]) = 0;
1985
642k
        IM(ps->opd_prev[i][1]) = 0;
1986
642k
    }
1987
1988
32.1k
    return ps;
1989
32.1k
}
ps_init
Line
Count
Source
1897
15.3k
{
1898
15.3k
    uint8_t i;
1899
15.3k
    uint8_t short_delay_band;
1900
1901
15.3k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
15.3k
    memset(ps, 0, sizeof(ps_info));
1903
1904
15.3k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
15.3k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
15.3k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
15.3k
    ps->saved_delay = 0;
1911
1912
996k
    for (i = 0; i < 64; i++)
1913
981k
    {
1914
981k
        ps->delay_buf_index_delay[i] = 0;
1915
981k
    }
1916
1917
61.3k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
45.9k
    {
1919
45.9k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
45.9k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
45.9k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
45.9k
#endif
1932
45.9k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
15.3k
    short_delay_band = 35;
1950
15.3k
    ps->nr_allpass_bands = 22;
1951
15.3k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
15.3k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
15.3k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
551k
    for (i = 0; i < short_delay_band; i++)
1957
536k
    {
1958
536k
        ps->delay_D[i] = 14;
1959
536k
    }
1960
459k
    for (i = short_delay_band; i < 64; i++)
1961
444k
    {
1962
444k
        ps->delay_D[i] = 1;
1963
444k
    }
1964
1965
    /* mixing and phase */
1966
781k
    for (i = 0; i < 50; i++)
1967
766k
    {
1968
766k
        RE(ps->h11_prev[i]) = 1;
1969
766k
        IM(ps->h11_prev[i]) = 1;
1970
766k
        RE(ps->h12_prev[i]) = 1;
1971
766k
        IM(ps->h12_prev[i]) = 1;
1972
766k
    }
1973
1974
15.3k
    ps->phase_hist = 0;
1975
1976
321k
    for (i = 0; i < 20; i++)
1977
306k
    {
1978
306k
        RE(ps->ipd_prev[i][0]) = 0;
1979
306k
        IM(ps->ipd_prev[i][0]) = 0;
1980
306k
        RE(ps->ipd_prev[i][1]) = 0;
1981
306k
        IM(ps->ipd_prev[i][1]) = 0;
1982
306k
        RE(ps->opd_prev[i][0]) = 0;
1983
306k
        IM(ps->opd_prev[i][0]) = 0;
1984
306k
        RE(ps->opd_prev[i][1]) = 0;
1985
306k
        IM(ps->opd_prev[i][1]) = 0;
1986
306k
    }
1987
1988
15.3k
    return ps;
1989
15.3k
}
ps_init
Line
Count
Source
1897
16.8k
{
1898
16.8k
    uint8_t i;
1899
16.8k
    uint8_t short_delay_band;
1900
1901
16.8k
    ps_info *ps = (ps_info*)faad_malloc(sizeof(ps_info));
1902
16.8k
    memset(ps, 0, sizeof(ps_info));
1903
1904
16.8k
    ps->hyb = hybrid_init(numTimeSlotsRate);
1905
16.8k
    ps->numTimeSlotsRate = numTimeSlotsRate;
1906
1907
16.8k
    ps->ps_data_available = 0;
1908
1909
    /* delay stuff*/
1910
16.8k
    ps->saved_delay = 0;
1911
1912
1.09M
    for (i = 0; i < 64; i++)
1913
1.07M
    {
1914
1.07M
        ps->delay_buf_index_delay[i] = 0;
1915
1.07M
    }
1916
1917
67.2k
    for (i = 0; i < NO_ALLPASS_LINKS; i++)
1918
50.4k
    {
1919
50.4k
        ps->delay_buf_index_ser[i] = 0;
1920
#ifdef PARAM_32KHZ
1921
        if (sr_index <= 5) /* >= 32 kHz*/
1922
        {
1923
            ps->num_sample_delay_ser[i] = delay_length_d[1][i];
1924
        } else {
1925
            ps->num_sample_delay_ser[i] = delay_length_d[0][i];
1926
        }
1927
#else
1928
50.4k
        (void)sr_index;
1929
        /* THESE ARE CONSTANTS NOW */
1930
50.4k
        ps->num_sample_delay_ser[i] = delay_length_d[i];
1931
50.4k
#endif
1932
50.4k
    }
1933
1934
#ifdef PARAM_32KHZ
1935
    if (sr_index <= 5) /* >= 32 kHz*/
1936
    {
1937
        short_delay_band = 35;
1938
        ps->nr_allpass_bands = 22;
1939
        ps->alpha_decay = FRAC_CONST(0.76592833836465);
1940
        ps->alpha_smooth = FRAC_CONST(0.25);
1941
    } else {
1942
        short_delay_band = 64;
1943
        ps->nr_allpass_bands = 45;
1944
        ps->alpha_decay = FRAC_CONST(0.58664621951003);
1945
        ps->alpha_smooth = FRAC_CONST(0.6);
1946
    }
1947
#else
1948
    /* THESE ARE CONSTANTS NOW */
1949
16.8k
    short_delay_band = 35;
1950
16.8k
    ps->nr_allpass_bands = 22;
1951
16.8k
    ps->alpha_decay = FRAC_CONST(0.76592833836465);
1952
16.8k
    ps->alpha_smooth = FRAC_CONST(0.25);
1953
16.8k
#endif
1954
1955
    /* THESE ARE CONSTANT NOW IF PS IS INDEPENDANT OF SAMPLERATE */
1956
605k
    for (i = 0; i < short_delay_band; i++)
1957
588k
    {
1958
588k
        ps->delay_D[i] = 14;
1959
588k
    }
1960
504k
    for (i = short_delay_band; i < 64; i++)
1961
487k
    {
1962
487k
        ps->delay_D[i] = 1;
1963
487k
    }
1964
1965
    /* mixing and phase */
1966
857k
    for (i = 0; i < 50; i++)
1967
840k
    {
1968
840k
        RE(ps->h11_prev[i]) = 1;
1969
840k
        IM(ps->h11_prev[i]) = 1;
1970
840k
        RE(ps->h12_prev[i]) = 1;
1971
840k
        IM(ps->h12_prev[i]) = 1;
1972
840k
    }
1973
1974
16.8k
    ps->phase_hist = 0;
1975
1976
352k
    for (i = 0; i < 20; i++)
1977
336k
    {
1978
336k
        RE(ps->ipd_prev[i][0]) = 0;
1979
336k
        IM(ps->ipd_prev[i][0]) = 0;
1980
336k
        RE(ps->ipd_prev[i][1]) = 0;
1981
336k
        IM(ps->ipd_prev[i][1]) = 0;
1982
336k
        RE(ps->opd_prev[i][0]) = 0;
1983
336k
        IM(ps->opd_prev[i][0]) = 0;
1984
336k
        RE(ps->opd_prev[i][1]) = 0;
1985
336k
        IM(ps->opd_prev[i][1]) = 0;
1986
336k
    }
1987
1988
16.8k
    return ps;
1989
16.8k
}
1990
1991
/* main Parametric Stereo decoding function */
1992
uint8_t ps_decode(ps_info *ps, qmf_t X_left[38][64], qmf_t X_right[38][64])
1993
20.9k
{
1994
20.9k
    qmf_t X_hybrid_left[32][32] = {{{0}}};
1995
20.9k
    qmf_t X_hybrid_right[32][32] = {{{0}}};
1996
1997
    /* delta decoding of the bitstream data */
1998
20.9k
    ps_data_decode(ps);
1999
2000
    /* set up some parameters depending on filterbank type */
2001
20.9k
    if (ps->use34hybrid_bands)
2002
8.01k
    {
2003
8.01k
        ps->group_border = (uint8_t*)group_border34;
2004
8.01k
        ps->map_group2bk = (uint16_t*)map_group2bk34;
2005
8.01k
        ps->num_groups = 32+18;
2006
8.01k
        ps->num_hybrid_groups = 32;
2007
8.01k
        ps->nr_par_bands = 34;
2008
8.01k
        ps->decay_cutoff = 5;
2009
12.9k
    } else {
2010
12.9k
        ps->group_border = (uint8_t*)group_border20;
2011
12.9k
        ps->map_group2bk = (uint16_t*)map_group2bk20;
2012
12.9k
        ps->num_groups = 10+12;
2013
12.9k
        ps->num_hybrid_groups = 10;
2014
12.9k
        ps->nr_par_bands = 20;
2015
12.9k
        ps->decay_cutoff = 3;
2016
12.9k
    }
2017
2018
    /* Perform further analysis on the lowest subbands to get a higher
2019
     * frequency resolution
2020
     */
2021
20.9k
    hybrid_analysis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2022
20.9k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2023
2024
    /* decorrelate mono signal */
2025
20.9k
    ps_decorrelate(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2026
2027
    /* apply mixing and phase parameters */
2028
20.9k
    ps_mix_phase(ps, X_left, X_right, X_hybrid_left, X_hybrid_right);
2029
2030
    /* hybrid synthesis, to rebuild the SBR QMF matrices */
2031
20.9k
    hybrid_synthesis((hyb_info*)ps->hyb, X_left, X_hybrid_left,
2032
20.9k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2033
2034
20.9k
    hybrid_synthesis((hyb_info*)ps->hyb, X_right, X_hybrid_right,
2035
20.9k
        ps->use34hybrid_bands, ps->numTimeSlotsRate);
2036
2037
20.9k
    return 0;
2038
20.9k
}
2039
2040
#endif