annotate g729dec.c @ 7773:272a13ae94c0 libavcodec

Parity bit calculation routine for G.729
author voroshil
date Tue, 02 Sep 2008 17:15:28 +0000
parents dc309e45a671
children b35486af268e
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
7597
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
82 AVCodec g729_decoder =
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
83 {
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
84 "g729",
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
85 CODEC_TYPE_AUDIO,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
86 CODEC_ID_G729,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
87 sizeof(G729_Context),
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
88 ff_g729_decoder_init,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
89 NULL,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
90 NULL,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
91 ff_g729_decode_frame,
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
92 .long_name = NULL_IF_CONFIG_SMALL("G.729"),
7060f0338be3 G.729 decoder main code
voroshil
parents:
diff changeset
93 };