]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/blob - libavcodec/g729dec.c
Remove not approved parts.
[frescor/ffmpeg.git] / libavcodec / g729dec.c
1 /*
2  * G.729 decoder
3  * Copyright (c) 2008 Vladimir Voroshilov
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 #include <stdlib.h>
22 #include <inttypes.h>
23 #include <limits.h>
24 #include <stdio.h>
25 #include <string.h>
26 #include <math.h>
27 #include <assert.h>
28
29 #include "avcodec.h"
30 #include "libavutil/avutil.h"
31 #include "bitstream.h"
32
33 /**
34  * minimum quantized LSF value (3.2.4)
35  * 0.005 in Q13
36  */
37 #define LSFQ_MIN                   40
38
39 /**
40  * maximum quantized LSF value (3.2.4)
41  * 3.135 in Q13
42  */
43 #define LSFQ_MAX                   25681
44
45 /**
46  * minimum LSF distance (3.2.4)
47  * 0.0391 in Q13
48  */
49 #define LSFQ_DIFF_MIN              321
50
51 /**
52  * minimum gain pitch value (3.8, Equation 47)
53  * 0.2 in (1.14)
54  */
55 #define SHARP_MIN                  3277
56
57 /**
58  * maximum gain pitch value (3.8, Equation 47)
59  * (EE) This does not comply with the specification.
60  * Specification says about 0.8, which should be
61  * 13107 in (1.14), but reference C code uses
62  * 13017 (equals to 0.7945) instead of it.
63  */
64 #define SHARP_MAX                  13017
65
66 /**
67  * \brief pseudo random number generator
68  */
69 static inline uint16_t g729_random(uint16_t value)
70 {
71     return 31821 * value + 13849;
72 }
73
74 /**
75  * Get parity bit of bit 2..7
76  */
77 static inline int g729_get_parity(uint8_t value)
78 {
79    return (0x6996966996696996ULL >> (value >> 2)) & 1;
80 }
81
82         ff_acelp_weighted_vector_sum(
83                 fc + pitch_delay_int[i],
84                 fc + pitch_delay_int[i],
85                 fc,
86                 1 << 14,
87                 av_clip(ctx->gain_pitch, SHARP_MIN, SHARP_MAX),
88                 0,
89                 14,
90                 ctx->subframe_size - pitch_delay_int[i]);
91
92             ctx->gain_pitch  = cb_gain_1st_8k[parm->gc_1st_index[i]][0] +
93                                cb_gain_2nd_8k[parm->gc_2nd_index[i]][0];
94             gain_corr_factor = cb_gain_1st_8k[parm->gc_1st_index[i]][1] +
95                                cb_gain_2nd_8k[parm->gc_2nd_index[i]][1];
96
97         ff_acelp_weighted_vector_sum(
98                 ctx->exc + i * ctx->subframe_size,
99                 ctx->exc + i * ctx->subframe_size,
100                 fc,
101                 (!voicing && ctx->frame_erasure) ? 0 : ctx->gain_pitch,
102                 ( voicing && ctx->frame_erasure) ? 0 : ctx->gain_code,
103                 1<<13,
104                 14,
105                 ctx->subframe_size);
106
107 AVCodec g729_decoder =
108 {
109     "g729",
110     CODEC_TYPE_AUDIO,
111     CODEC_ID_G729,
112     sizeof(G729_Context),
113     ff_g729_decoder_init,
114     NULL,
115     NULL,
116     ff_g729_decode_frame,
117     .long_name = NULL_IF_CONFIG_SMALL("G.729"),
118 };