annotate g729dec.c @ 7780:b35486af268e libavcodec

Another set of approved G.729 chunks (from decoder core)
author voroshil
date Wed, 03 Sep 2008 01:07:03 +0000
parents 272a13ae94c0
children ca4a5c6c275c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
7597
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
1 /*
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
2 * G.729 decoder
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
3 * Copyright (c) 2008 Vladimir Voroshilov
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
4 *
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
5 * This file is part of FFmpeg.
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
6 *
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
11 *
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
15 * Lesser General Public License for more details.
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
16 *
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
20 */
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
21 #include <stdlib.h>
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
22 #include <inttypes.h>
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
23 #include <limits.h>
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
24 #include <stdio.h>
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
25 #include <string.h>
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
26 #include <math.h>
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
27 #include <assert.h>
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
28
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
29 #include "avcodec.h"
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
30 #include "libavutil/avutil.h"
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
31 #include "bitstream.h"
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
32
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
33 /**
7668
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
34 * minimum quantized LSF value (3.2.4)
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
35 * 0.005 in Q13
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
36 */
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
37 #define LSFQ_MIN 40
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
38
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
39 /**
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
40 * maximum quantized LSF value (3.2.4)
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
41 * 3.135 in Q13
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
42 */
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
43 #define LSFQ_MAX 25681
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
44
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
45 /**
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
46 * minimum LSF distance (3.2.4)
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
47 * 0.0391 in Q13
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
48 */
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
49 #define LSFQ_DIFF_MIN 321
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
50
bdb1bdcd4cd0 Move from g729.h all definitions which are used only in g729dec.c
voroshil
parents: 7597
diff changeset
51 /**
7693
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
52 * minimum gain pitch value (3.8, Equation 47)
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
53 * 0.2 in (1.14)
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
54 */
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
55 #define SHARP_MIN 3277
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
56
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
57 /**
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
58 * maximum gain pitch value (3.8, Equation 47)
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
59 * (EE) This does not comply with the specification.
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
60 * Specification says about 0.8, which should be
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
61 * 13107 in (1.14), but reference C code uses
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
62 * 13017 (equals to 0.7945) instead of it.
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
63 */
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
64 #define SHARP_MAX 13017
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
65
dc309e45a671 Another set of definitions for G.729
voroshil
parents: 7668
diff changeset
66 /**
7597
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
67 * \brief pseudo random number generator
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
68 */
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
69 static inline uint16_t g729_random(uint16_t value)
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
70 {
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
71 return 31821 * value + 13849;
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
72 }
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
73
7773
272a13ae94c0 Parity bit calculation routine for G.729
voroshil
parents: 7693
diff changeset
74 /**
272a13ae94c0 Parity bit calculation routine for G.729
voroshil
parents: 7693
diff changeset
75 * Get parity bit of bit 2..7
272a13ae94c0 Parity bit calculation routine for G.729
voroshil
parents: 7693
diff changeset
76 */
272a13ae94c0 Parity bit calculation routine for G.729
voroshil
parents: 7693
diff changeset
77 static inline int g729_get_parity(uint8_t value)
272a13ae94c0 Parity bit calculation routine for G.729
voroshil
parents: 7693
diff changeset
78 {
272a13ae94c0 Parity bit calculation routine for G.729
voroshil
parents: 7693
diff changeset
79 return (0x6996966996696996ULL >> (value >> 2)) & 1;
272a13ae94c0 Parity bit calculation routine for G.729
voroshil
parents: 7693
diff changeset
80 }
272a13ae94c0 Parity bit calculation routine for G.729
voroshil
parents: 7693
diff changeset
81
7780
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
82 /*
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
83 This filter enhances harmonic components of the fixed-codebook vector to
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
84 improve the quality of the reconstructed speech.
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
85
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
86 / fc_v[i], i < pitch_delay
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
87 fc_v[i] = <
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
88 \ fc_v[i] + gain_pitch * fc_v[i-pitch_delay], i >= pitch_delay
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
89 */
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
90 ff_acelp_weighted_vector_sum(
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
91 fc + pitch_delay_int[i],
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
92 fc + pitch_delay_int[i],
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
93 fc,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
94 1 << 14,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
95 av_clip(ctx->gain_pitch, SHARP_MIN, SHARP_MAX),
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
96 0,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
97 14,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
98 ctx->subframe_size - pitch_delay_int[i]);
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
99
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
100 ctx->gain_pitch = cb_gain_1st_8k[parm->gc_1st_index[i]][0] +
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
101 cb_gain_2nd_8k[parm->gc_2nd_index[i]][0];
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
102 gain_corr_factor = cb_gain_1st_8k[parm->gc_1st_index[i]][1] +
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
103 cb_gain_2nd_8k[parm->gc_2nd_index[i]][1];
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
104
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
105 /* Routine requires rounding to lowest. */
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
106 ff_acelp_interpolate(
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
107 ctx->exc + i*ctx->subframe_size,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
108 ctx->exc + i*ctx->subframe_size - pitch_delay_3x/3,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
109 ff_acelp_interp_filter,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
110 6,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
111 (pitch_delay_3x%3)<<1,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
112 10,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
113 ctx->subframe_size);
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
114
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
115 ff_acelp_weighted_vector_sum(
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
116 ctx->exc + i * ctx->subframe_size,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
117 ctx->exc + i * ctx->subframe_size,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
118 fc,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
119 (!voicing && ctx->frame_erasure) ? 0 : ctx->gain_pitch,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
120 ( voicing && ctx->frame_erasure) ? 0 : ctx->gain_code,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
121 1<<13,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
122 14,
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
123 ctx->subframe_size);
b35486af268e Another set of approved G.729 chunks (from decoder core)
voroshil
parents: 7773
diff changeset
124
7597
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
125 AVCodec g729_decoder =
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
126 {
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
127 "g729",
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
128 CODEC_TYPE_AUDIO,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
129 CODEC_ID_G729,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
130 sizeof(G729_Context),
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
131 ff_g729_decoder_init,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
132 NULL,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
133 NULL,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
134 ff_g729_decode_frame,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
135 .long_name = NULL_IF_CONFIG_SMALL("G.729"),
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
136 };