Coverage Report

Created: 2025-07-11 06:40

/proc/self/cwd/libfaad/lt_predict.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: lt_predict.c,v 1.27 2007/11/01 12:33:31 menno Exp $
29
**/
30
31
32
#include "common.h"
33
#include "structs.h"
34
35
#ifdef LTP_DEC
36
37
#include <stdlib.h>
38
#include "syntax.h"
39
#include "lt_predict.h"
40
#include "filtbank.h"
41
#include "tns.h"
42
43
44
/* static function declarations */
45
static int16_t real_to_int16(real_t sig_in);
46
47
48
/* check if the object type is an object type that can have LTP */
49
uint8_t is_ltp_ot(uint8_t object_type)
50
1.19M
{
51
1.19M
#ifdef LTP_DEC
52
1.19M
    if ((object_type == LTP)
53
1.19M
#ifdef ERROR_RESILIENCE
54
1.19M
        || (object_type == ER_LTP)
55
1.19M
#endif
56
1.19M
#ifdef LD_DEC
57
1.19M
        || (object_type == LD)
58
1.19M
#endif
59
1.19M
        )
60
475k
    {
61
475k
        return 1;
62
475k
    }
63
716k
#endif
64
65
716k
    return 0;
66
1.19M
}
67
68
ALIGN static const real_t codebook[8] =
69
{
70
    REAL_CONST(0.570829),
71
    REAL_CONST(0.696616),
72
    REAL_CONST(0.813004),
73
    REAL_CONST(0.911304),
74
    REAL_CONST(0.984900),
75
    REAL_CONST(1.067894),
76
    REAL_CONST(1.194601),
77
    REAL_CONST(1.369533)
78
};
79
80
void lt_prediction(ic_stream *ics, ltp_info *ltp, real_t *spec,
81
                   int16_t *lt_pred_stat, fb_info *fb, uint8_t win_shape,
82
                   uint8_t win_shape_prev, uint8_t sr_index,
83
                   uint8_t object_type, uint16_t frame_len)
84
177k
{
85
177k
    uint8_t sfb;
86
177k
    uint16_t bin, i, num_samples;
87
177k
    ALIGN real_t x_est[2048];
88
177k
    ALIGN real_t X_est[2048];
89
90
177k
    if (ics->window_sequence != EIGHT_SHORT_SEQUENCE)
91
167k
    {
92
167k
        if (ltp->data_present)
93
12.6k
        {
94
12.6k
            num_samples = frame_len << 1;
95
96
24.5M
            for(i = 0; i < num_samples; i++)
97
24.5M
            {
98
                /* The extra lookback M (N/2 for LD, 0 for LTP) is handled
99
                   in the buffer updating */
100
101
#if 0
102
                x_est[i] = MUL_R_C(lt_pred_stat[num_samples + i - ltp->lag],
103
                    codebook[ltp->coef]);
104
#else
105
                /* lt_pred_stat is a 16 bit int, multiplied with the fixed point real
106
                   this gives a real for x_est
107
                */
108
24.5M
                x_est[i] = (real_t)lt_pred_stat[num_samples + i - ltp->lag] * codebook[ltp->coef];
109
24.5M
#endif
110
24.5M
            }
111
112
12.6k
            filter_bank_ltp(fb, ics->window_sequence, win_shape, win_shape_prev,
113
12.6k
                x_est, X_est, object_type, frame_len);
114
115
12.6k
            tns_encode_frame(ics, &(ics->tns), sr_index, object_type, X_est,
116
12.6k
                frame_len);
117
118
27.7k
            for (sfb = 0; sfb < ltp->last_band; sfb++)
119
15.1k
            {
120
15.1k
                if (ltp->long_used[sfb])
121
5.00k
                {
122
5.00k
                    uint16_t low  = ics->swb_offset[sfb];
123
5.00k
                    uint16_t high = min(ics->swb_offset[sfb+1], ics->swb_offset_max);
124
125
69.5k
                    for (bin = low; bin < high; bin++)
126
64.5k
                    {
127
64.5k
                        spec[bin] += X_est[bin];
128
64.5k
                    }
129
5.00k
                }
130
15.1k
            }
131
12.6k
        }
132
167k
    }
133
177k
}
134
135
#ifdef FIXED_POINT
136
static INLINE int16_t real_to_int16(real_t sig_in)
137
203M
{
138
203M
    if (sig_in >= 0)
139
202M
    {
140
202M
        sig_in += (1 << (REAL_BITS-1));
141
202M
        if (sig_in >= REAL_CONST(32768))
142
139k
            return 32767;
143
202M
    } else {
144
1.23M
        sig_in += -(1 << (REAL_BITS-1));
145
1.23M
        if (sig_in <= REAL_CONST(-32768))
146
119k
            return -32768;
147
1.23M
    }
148
149
203M
    return (int16_t)(sig_in >> REAL_BITS);
150
203M
}
151
#else
152
static INLINE int16_t real_to_int16(real_t sig_in)
153
152M
{
154
152M
    if (sig_in >= 0)
155
149M
    {
156
149M
#ifndef HAS_LRINTF
157
149M
        sig_in += 0.5f;
158
149M
#endif
159
149M
        if (sig_in >= 32768.0f)
160
331k
            return 32767;
161
149M
    } else {
162
3.20M
#ifndef HAS_LRINTF
163
3.20M
        sig_in += -0.5f;
164
3.20M
#endif
165
3.20M
        if (sig_in <= -32768.0f)
166
339k
            return -32768;
167
3.20M
    }
168
169
151M
    return (int16_t)lrintf(sig_in);
170
152M
}
171
#endif
172
173
void lt_update_state(int16_t *lt_pred_stat, real_t *time, real_t *overlap,
174
                     uint16_t frame_len, uint8_t object_type)
175
177k
{
176
177k
    uint16_t i;
177
178
    /*
179
     * The reference point for index i and the content of the buffer
180
     * lt_pred_stat are arranged so that lt_pred_stat(0 ... N/2 - 1) contains the
181
     * last aliased half window from the IMDCT, and lt_pred_stat(N/2 ... N-1)
182
     * is always all zeros. The rest of lt_pred_stat (i<0) contains the previous
183
     * fully reconstructed time domain samples, i.e., output of the decoder.
184
     *
185
     * These values are shifted up by N*2 to avoid (i<0)
186
     *
187
     * For the LD object type an extra 512 samples lookback is accomodated here.
188
     */
189
177k
#ifdef LD_DEC
190
177k
    if (object_type == LD)
191
4.05k
    {
192
2.01M
        for (i = 0; i < frame_len; i++)
193
2.00M
        {
194
2.00M
            lt_pred_stat[i]  /* extra 512 */  = lt_pred_stat[i + frame_len];
195
2.00M
            lt_pred_stat[frame_len + i]       = lt_pred_stat[i + (frame_len * 2)];
196
2.00M
            lt_pred_stat[(frame_len * 2) + i] = real_to_int16(time[i]);
197
2.00M
            lt_pred_stat[(frame_len * 3) + i] = real_to_int16(overlap[i]);
198
2.00M
        }
199
173k
    } else {
200
173k
#endif
201
176M
        for (i = 0; i < frame_len; i++)
202
175M
        {
203
175M
            lt_pred_stat[i]                   = lt_pred_stat[i + frame_len];
204
175M
            lt_pred_stat[frame_len + i]       = real_to_int16(time[i]);
205
175M
            lt_pred_stat[(frame_len * 2) + i] = real_to_int16(overlap[i]);
206
#if 0 /* set to zero once upon initialisation */
207
            lt_pred_stat[(frame_len * 3) + i] = 0;
208
#endif
209
175M
        }
210
173k
#ifdef LD_DEC
211
173k
    }
212
177k
#endif
213
177k
}
214
215
#endif