Mercurial > libavcodec.hg
annotate ac3dec.c @ 6323:e6da66f378c7 libavcodec
mpegvideo.h has two function declarations with the 'inline' specifier
but no definition for those functions. The C standard requires a
definition to appear in the same translation unit for any function
declared with 'inline'. Most of the files including mpegvideo.h do not
define those functions. Fix this by removing the 'inline' specifiers
from the header.
patch by Uoti Urpala
author | diego |
---|---|
date | Sun, 03 Feb 2008 17:54:30 +0000 |
parents | a35b838ab955 |
children | de7502093922 |
rev | line source |
---|---|
5328 | 1 /* |
2 * AC-3 Audio Decoder | |
5316
a09b700fcfca
AC-3 decoder, soc revision 56, Aug 17 14:21:58 2006 UTC by cloud9
jbr
parents:
5315
diff
changeset
|
3 * This code is developed as part of Google Summer of Code 2006 Program. |
a09b700fcfca
AC-3 decoder, soc revision 56, Aug 17 14:21:58 2006 UTC by cloud9
jbr
parents:
5315
diff
changeset
|
4 * |
5328 | 5 * Copyright (c) 2006 Kartikey Mahendra BHATT (bhattkm at gmail dot com). |
5377
2020fab0e37a
update license header. add copyright for myself. correct and complete the statement about liba52.
jbr
parents:
5376
diff
changeset
|
6 * Copyright (c) 2007 Justin Ruggles |
5316
a09b700fcfca
AC-3 decoder, soc revision 56, Aug 17 14:21:58 2006 UTC by cloud9
jbr
parents:
5315
diff
changeset
|
7 * |
5377
2020fab0e37a
update license header. add copyright for myself. correct and complete the statement about liba52.
jbr
parents:
5376
diff
changeset
|
8 * Portions of this code are derived from liba52 |
5316
a09b700fcfca
AC-3 decoder, soc revision 56, Aug 17 14:21:58 2006 UTC by cloud9
jbr
parents:
5315
diff
changeset
|
9 * http://liba52.sourceforge.net |
5377
2020fab0e37a
update license header. add copyright for myself. correct and complete the statement about liba52.
jbr
parents:
5376
diff
changeset
|
10 * Copyright (C) 2000-2003 Michel Lespinasse <walken@zoy.org> |
2020fab0e37a
update license header. add copyright for myself. correct and complete the statement about liba52.
jbr
parents:
5376
diff
changeset
|
11 * Copyright (C) 1999-2000 Aaron Holtzman <aholtzma@ess.engr.uvic.ca> |
5316
a09b700fcfca
AC-3 decoder, soc revision 56, Aug 17 14:21:58 2006 UTC by cloud9
jbr
parents:
5315
diff
changeset
|
12 * |
5328 | 13 * This file is part of FFmpeg. |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
14 * |
5328 | 15 * FFmpeg is free software; you can redistribute it and/or |
5329 | 16 * modify it under the terms of the GNU General Public |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
17 * License as published by the Free Software Foundation; either |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
18 * version 2 of the License, or (at your option) any later version. |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
19 * |
5328 | 20 * FFmpeg is distributed in the hope that it will be useful, |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
5326 | 23 * General Public License for more details. |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
24 * |
5326 | 25 * You should have received a copy of the GNU General Public |
5328 | 26 * License along with FFmpeg; if not, write to the Free Software |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
27 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
28 */ |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
29 |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
30 #include <stdio.h> |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
31 #include <stddef.h> |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
32 #include <math.h> |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
33 #include <string.h> |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
34 |
5315
31033309ebc9
AC-3 decoder, soc revision 55, Aug 17 12:25:24 2006 UTC by cloud9
jbr
parents:
5314
diff
changeset
|
35 #include "avcodec.h" |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
36 #include "ac3_parser.h" |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
37 #include "bitstream.h" |
6098 | 38 #include "crc.h" |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
39 #include "dsputil.h" |
5330 | 40 #include "random.h" |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
41 |
5415 | 42 /** |
43 * Table of bin locations for rematrixing bands | |
44 * reference: Section 7.5.2 Rematrixing : Frequency Band Definitions | |
45 */ | |
5678
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
46 static const uint8_t rematrix_band_tab[5] = { 13, 25, 37, 61, 253 }; |
5415 | 47 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
48 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
49 * table for exponent to scale_factor mapping |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
50 * scale_factors[i] = 2 ^ -i |
5325
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
51 */ |
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
52 static float scale_factors[25]; |
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
53 |
5375 | 54 /** table for grouping exponents */ |
5678
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
55 static uint8_t exp_ungroup_tab[128][3]; |
5325
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
56 |
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
57 |
5456 | 58 /** tables for ungrouping mantissas */ |
59 static float b1_mantissas[32][3]; | |
60 static float b2_mantissas[128][3]; | |
61 static float b3_mantissas[8]; | |
62 static float b4_mantissas[128][2]; | |
63 static float b5_mantissas[16]; | |
5325
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
64 |
5456 | 65 /** |
66 * Quantization table: levels for symmetric. bits for asymmetric. | |
67 * reference: Table 7.18 Mapping of bap to Quantizer | |
68 */ | |
6006 | 69 static const uint8_t quantization_tab[16] = { |
5456 | 70 0, 3, 5, 7, 11, 15, |
71 5, 6, 7, 8, 9, 10, 11, 12, 14, 16 | |
72 }; | |
5325
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
73 |
5457
0a5849a4858b
use table for converting dynamic range codes to scale factors
jbr
parents:
5456
diff
changeset
|
74 /** dynamic range table. converts codes to scale factors. */ |
6006 | 75 static float dynamic_range_tab[256]; |
5457
0a5849a4858b
use table for converting dynamic range codes to scale factors
jbr
parents:
5456
diff
changeset
|
76 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
77 /** Adjustments in dB gain */ |
5325
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
78 #define LEVEL_MINUS_3DB 0.7071067811865476 |
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
79 #define LEVEL_MINUS_4POINT5DB 0.5946035575013605 |
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
80 #define LEVEL_MINUS_6DB 0.5000000000000000 |
5480 | 81 #define LEVEL_MINUS_9DB 0.3535533905932738 |
5325
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
82 #define LEVEL_ZERO 0.0000000000000000 |
5480 | 83 #define LEVEL_ONE 1.0000000000000000 |
84 | |
85 static const float gain_levels[6] = { | |
86 LEVEL_ZERO, | |
87 LEVEL_ONE, | |
88 LEVEL_MINUS_3DB, | |
89 LEVEL_MINUS_4POINT5DB, | |
90 LEVEL_MINUS_6DB, | |
91 LEVEL_MINUS_9DB | |
92 }; | |
93 | |
94 /** | |
95 * Table for center mix levels | |
96 * reference: Section 5.4.2.4 cmixlev | |
97 */ | |
6005 | 98 static const uint8_t center_levels[4] = { 2, 3, 4, 3 }; |
5325
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
99 |
5480 | 100 /** |
101 * Table for surround mix levels | |
102 * reference: Section 5.4.2.5 surmixlev | |
103 */ | |
6005 | 104 static const uint8_t surround_levels[4] = { 2, 4, 0, 4 }; |
5325
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
105 |
5480 | 106 /** |
107 * Table for default stereo downmixing coefficients | |
108 * reference: Section 7.8.2 Downmixing Into Two Channels | |
109 */ | |
110 static const uint8_t ac3_default_coeffs[8][5][2] = { | |
111 { { 1, 0 }, { 0, 1 }, }, | |
112 { { 2, 2 }, }, | |
113 { { 1, 0 }, { 0, 1 }, }, | |
114 { { 1, 0 }, { 3, 3 }, { 0, 1 }, }, | |
115 { { 1, 0 }, { 0, 1 }, { 4, 4 }, }, | |
116 { { 1, 0 }, { 3, 3 }, { 0, 1 }, { 5, 5 }, }, | |
117 { { 1, 0 }, { 0, 1 }, { 4, 0 }, { 0, 4 }, }, | |
118 { { 1, 0 }, { 3, 3 }, { 0, 1 }, { 4, 0 }, { 0, 4 }, }, | |
119 }; | |
5325
0d963101e0d7
AC-3 decoder, soc revision 402, Jul 14 13:45:14 2007 UTC by jbr
jbr
parents:
5324
diff
changeset
|
120 |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
121 /* override ac3.h to include coupling channel */ |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
122 #undef AC3_MAX_CHANNELS |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
123 #define AC3_MAX_CHANNELS 7 |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
124 #define CPL_CH 0 |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
125 |
5412
3f6a6dda6b2d
remove broken downmixing. will add new implementation later.
jbr
parents:
5393
diff
changeset
|
126 #define AC3_OUTPUT_LFEON 8 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
127 |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
128 typedef struct { |
6005 | 129 int channel_mode; ///< channel mode (acmod) |
6006 | 130 int block_switch[AC3_MAX_CHANNELS]; ///< block switch flags |
131 int dither_flag[AC3_MAX_CHANNELS]; ///< dither flags | |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
132 int dither_all; ///< true if all channels are dithered |
6006 | 133 int cpl_in_use; ///< coupling in use |
134 int channel_in_cpl[AC3_MAX_CHANNELS]; ///< channel in coupling | |
135 int phase_flags_in_use; ///< phase flags in use | |
6123
8d88831a2777
fix phase flag processing for the case when coupling coordinates are reused
jbr
parents:
6117
diff
changeset
|
136 int phase_flags[18]; ///< phase flags |
6006 | 137 int cpl_band_struct[18]; ///< coupling band structure |
138 int num_rematrixing_bands; ///< number of rematrixing bands | |
139 int rematrixing_flags[4]; ///< rematrixing flags | |
140 int exp_strategy[AC3_MAX_CHANNELS]; ///< exponent strategies | |
6003 | 141 int snr_offset[AC3_MAX_CHANNELS]; ///< signal-to-noise ratio offsets |
142 int fast_gain[AC3_MAX_CHANNELS]; ///< fast gain values (signal-to-mask ratio) | |
143 int dba_mode[AC3_MAX_CHANNELS]; ///< delta bit allocation mode | |
144 int dba_nsegs[AC3_MAX_CHANNELS]; ///< number of delta segments | |
145 uint8_t dba_offsets[AC3_MAX_CHANNELS][8]; ///< delta segment offsets | |
146 uint8_t dba_lengths[AC3_MAX_CHANNELS][8]; ///< delta segment lengths | |
147 uint8_t dba_values[AC3_MAX_CHANNELS][8]; ///< delta values for each segment | |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
148 |
6093 | 149 int sample_rate; ///< sample frequency, in Hz |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
150 int bit_rate; ///< stream bit rate, in bits-per-second |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
151 int frame_size; ///< current frame size, in bytes |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
152 |
6006 | 153 int channels; ///< number of total channels |
154 int fbw_channels; ///< number of full-bandwidth channels | |
6005 | 155 int lfe_on; ///< lfe channel in use |
5516 | 156 int lfe_ch; ///< index of LFE channel |
157 int output_mode; ///< output channel configuration | |
158 int out_channels; ///< number of output channels | |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
159 |
6126
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
160 int center_mix_level; ///< Center mix level index |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
161 int surround_mix_level; ///< Surround mix level index |
5516 | 162 float downmix_coeffs[AC3_MAX_CHANNELS][2]; ///< stereo downmix coefficients |
6006 | 163 float dynamic_range[2]; ///< dynamic range |
164 float cpl_coords[AC3_MAX_CHANNELS][18]; ///< coupling coordinates | |
165 int num_cpl_bands; ///< number of coupling bands | |
166 int num_cpl_subbands; ///< number of coupling sub bands | |
167 int start_freq[AC3_MAX_CHANNELS]; ///< start frequency bin | |
168 int end_freq[AC3_MAX_CHANNELS]; ///< end frequency bin | |
5335 | 169 AC3BitAllocParameters bit_alloc_params; ///< bit allocation parameters |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
170 |
5516 | 171 int8_t dexps[AC3_MAX_CHANNELS][256]; ///< decoded exponents |
172 uint8_t bap[AC3_MAX_CHANNELS][256]; ///< bit allocation pointers | |
173 int16_t psd[AC3_MAX_CHANNELS][256]; ///< scaled exponents | |
6003 | 174 int16_t band_psd[AC3_MAX_CHANNELS][50]; ///< interpolated exponents |
5516 | 175 int16_t mask[AC3_MAX_CHANNELS][50]; ///< masking curve values |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
176 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
177 DECLARE_ALIGNED_16(float, transform_coeffs[AC3_MAX_CHANNELS][256]); ///< transform coefficients |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
178 |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
179 /* For IMDCT. */ |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
180 MDCTContext imdct_512; ///< for 512 sample IMDCT |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
181 MDCTContext imdct_256; ///< for 256 sample IMDCT |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
182 DSPContext dsp; ///< for optimization |
5516 | 183 float add_bias; ///< offset for float_to_int16 conversion |
184 float mul_bias; ///< scaling for float_to_int16 conversion | |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
185 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
186 DECLARE_ALIGNED_16(float, output[AC3_MAX_CHANNELS-1][256]); ///< output after imdct transform and windowing |
5479
943c732c905d
use dsputil for float to signed 16-bit sample conversion
jbr
parents:
5477
diff
changeset
|
187 DECLARE_ALIGNED_16(short, int_output[AC3_MAX_CHANNELS-1][256]); ///< final 16-bit integer output |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
188 DECLARE_ALIGNED_16(float, delay[AC3_MAX_CHANNELS-1][256]); ///< delay - added to the next block |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
189 DECLARE_ALIGNED_16(float, tmp_imdct[256]); ///< temporary storage for imdct transform |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
190 DECLARE_ALIGNED_16(float, tmp_output[512]); ///< temporary storage for output before windowing |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
191 DECLARE_ALIGNED_16(float, window[256]); ///< window coefficients |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
192 |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
193 /* Miscellaneous. */ |
6089 | 194 GetBitContext gbc; ///< bitstream reader |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
195 AVRandomState dith_state; ///< for dither generation |
5516 | 196 AVCodecContext *avctx; ///< parent context |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
197 } AC3DecodeContext; |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
198 |
5310
9aa9197034d7
AC-3 decoder, soc revision 40, Aug 9 00:10:14 2006 UTC by cloud9
jbr
parents:
5309
diff
changeset
|
199 /** |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
200 * Symmetrical Dequantization |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
201 * reference: Section 7.3.3 Expansion of Mantissas for Symmetrical Quantization |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
202 * Tables 7.19 to 7.23 |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
203 */ |
5456 | 204 static inline float |
205 symmetric_dequant(int code, int levels) | |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
206 { |
5456 | 207 return (code - (levels >> 1)) * (2.0f / levels); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
208 } |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
209 |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
210 /* |
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
211 * Initialize tables at runtime. |
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
212 */ |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
213 static void ac3_tables_init(void) |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
214 { |
5375 | 215 int i; |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
216 |
5456 | 217 /* generate grouped mantissa tables |
218 reference: Section 7.3.5 Ungrouping of Mantissas */ | |
219 for(i=0; i<32; i++) { | |
220 /* bap=1 mantissas */ | |
221 b1_mantissas[i][0] = symmetric_dequant( i / 9 , 3); | |
222 b1_mantissas[i][1] = symmetric_dequant((i % 9) / 3, 3); | |
223 b1_mantissas[i][2] = symmetric_dequant((i % 9) % 3, 3); | |
224 } | |
225 for(i=0; i<128; i++) { | |
226 /* bap=2 mantissas */ | |
227 b2_mantissas[i][0] = symmetric_dequant( i / 25 , 5); | |
228 b2_mantissas[i][1] = symmetric_dequant((i % 25) / 5, 5); | |
229 b2_mantissas[i][2] = symmetric_dequant((i % 25) % 5, 5); | |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
230 |
5456 | 231 /* bap=4 mantissas */ |
232 b4_mantissas[i][0] = symmetric_dequant(i / 11, 11); | |
233 b4_mantissas[i][1] = symmetric_dequant(i % 11, 11); | |
234 } | |
235 /* generate ungrouped mantissa tables | |
236 reference: Tables 7.21 and 7.23 */ | |
237 for(i=0; i<7; i++) { | |
238 /* bap=3 mantissas */ | |
239 b3_mantissas[i] = symmetric_dequant(i, 7); | |
240 } | |
241 for(i=0; i<15; i++) { | |
242 /* bap=5 mantissas */ | |
243 b5_mantissas[i] = symmetric_dequant(i, 15); | |
244 } | |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
245 |
5457
0a5849a4858b
use table for converting dynamic range codes to scale factors
jbr
parents:
5456
diff
changeset
|
246 /* generate dynamic range table |
0a5849a4858b
use table for converting dynamic range codes to scale factors
jbr
parents:
5456
diff
changeset
|
247 reference: Section 7.7.1 Dynamic Range Control */ |
0a5849a4858b
use table for converting dynamic range codes to scale factors
jbr
parents:
5456
diff
changeset
|
248 for(i=0; i<256; i++) { |
0a5849a4858b
use table for converting dynamic range codes to scale factors
jbr
parents:
5456
diff
changeset
|
249 int v = (i >> 5) - ((i >> 7) << 3) - 5; |
6006 | 250 dynamic_range_tab[i] = powf(2.0f, v) * ((i & 0x1F) | 0x20); |
5457
0a5849a4858b
use table for converting dynamic range codes to scale factors
jbr
parents:
5456
diff
changeset
|
251 } |
0a5849a4858b
use table for converting dynamic range codes to scale factors
jbr
parents:
5456
diff
changeset
|
252 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
253 /* generate scale factors for exponents and asymmetrical dequantization |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
254 reference: Section 7.3.2 Expansion of Mantissas for Asymmetric Quantization */ |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
255 for (i = 0; i < 25; i++) |
5456 | 256 scale_factors[i] = pow(2.0, -i); |
5375 | 257 |
258 /* generate exponent tables | |
259 reference: Section 7.1.3 Exponent Decoding */ | |
260 for(i=0; i<128; i++) { | |
5678
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
261 exp_ungroup_tab[i][0] = i / 25; |
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
262 exp_ungroup_tab[i][1] = (i % 25) / 5; |
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
263 exp_ungroup_tab[i][2] = (i % 25) % 5; |
5375 | 264 } |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
265 } |
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
266 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
267 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
268 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
269 * AVCodec initialization |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
270 */ |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
271 static int ac3_decode_init(AVCodecContext *avctx) |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
272 { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
273 AC3DecodeContext *s = avctx->priv_data; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
274 s->avctx = avctx; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
275 |
5331 | 276 ac3_common_init(); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
277 ac3_tables_init(); |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
278 ff_mdct_init(&s->imdct_256, 8, 1); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
279 ff_mdct_init(&s->imdct_512, 9, 1); |
6142
a35b838ab955
Add variable alpha and size of half window for Kaiser-Bessel Derived window
superdump
parents:
6139
diff
changeset
|
280 ff_kbd_window_init(s->window, 5.0, 256); |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
281 dsputil_init(&s->dsp, avctx); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
282 av_init_random(0, &s->dith_state); |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
283 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
284 /* set bias values for float to int16 conversion */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
285 if(s->dsp.float_to_int16 == ff_float_to_int16_c) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
286 s->add_bias = 385.0f; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
287 s->mul_bias = 1.0f; |
5479
943c732c905d
use dsputil for float to signed 16-bit sample conversion
jbr
parents:
5477
diff
changeset
|
288 } else { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
289 s->add_bias = 0.0f; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
290 s->mul_bias = 32767.0f; |
5479
943c732c905d
use dsputil for float to signed 16-bit sample conversion
jbr
parents:
5477
diff
changeset
|
291 } |
943c732c905d
use dsputil for float to signed 16-bit sample conversion
jbr
parents:
5477
diff
changeset
|
292 |
6112 | 293 /* allow downmixing to stereo or mono */ |
294 if (avctx->channels > 0 && avctx->request_channels > 0 && | |
295 avctx->request_channels < avctx->channels && | |
296 avctx->request_channels <= 2) { | |
297 avctx->channels = avctx->request_channels; | |
298 } | |
299 | |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
300 return 0; |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
301 } |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
302 |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
303 /** |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
304 * Parse the 'sync info' and 'bit stream info' from the AC-3 bitstream. |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
305 * GetBitContext within AC3DecodeContext must point to |
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
306 * start of the synchronized ac3 bitstream. |
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
307 */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
308 static int ac3_parse_header(AC3DecodeContext *s) |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
309 { |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
310 AC3HeaderInfo hdr; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
311 GetBitContext *gbc = &s->gbc; |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
312 int err, i; |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
313 |
6089 | 314 err = ff_ac3_parse_header(gbc->buffer, &hdr); |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
315 if(err) |
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
316 return err; |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
317 |
6117 | 318 if(hdr.bitstream_id > 10) |
319 return AC3_PARSE_ERROR_BSID; | |
320 | |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
321 /* get decoding parameters from header info */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
322 s->bit_alloc_params.sr_code = hdr.sr_code; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
323 s->channel_mode = hdr.channel_mode; |
6091 | 324 s->lfe_on = hdr.lfe_on; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
325 s->bit_alloc_params.sr_shift = hdr.sr_shift; |
6093 | 326 s->sample_rate = hdr.sample_rate; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
327 s->bit_rate = hdr.bit_rate; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
328 s->channels = hdr.channels; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
329 s->fbw_channels = s->channels - s->lfe_on; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
330 s->lfe_ch = s->fbw_channels + 1; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
331 s->frame_size = hdr.frame_size; |
5412
3f6a6dda6b2d
remove broken downmixing. will add new implementation later.
jbr
parents:
5393
diff
changeset
|
332 |
3f6a6dda6b2d
remove broken downmixing. will add new implementation later.
jbr
parents:
5393
diff
changeset
|
333 /* set default output to all source channels */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
334 s->out_channels = s->channels; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
335 s->output_mode = s->channel_mode; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
336 if(s->lfe_on) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
337 s->output_mode |= AC3_OUTPUT_LFEON; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
338 |
6126
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
339 /* set default mix levels */ |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
340 s->center_mix_level = 3; // -4.5dB |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
341 s->surround_mix_level = 4; // -6.0dB |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
342 |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
343 /* skip over portion of header which has already been read */ |
6089 | 344 skip_bits(gbc, 16); // skip the sync_word |
345 skip_bits(gbc, 16); // skip crc1 | |
346 skip_bits(gbc, 8); // skip fscod and frmsizecod | |
347 skip_bits(gbc, 11); // skip bsid, bsmod, and acmod | |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
348 if(s->channel_mode == AC3_CHMODE_STEREO) { |
6089 | 349 skip_bits(gbc, 2); // skip dsurmod |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
350 } else { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
351 if((s->channel_mode & 1) && s->channel_mode != AC3_CHMODE_MONO) |
6126
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
352 s->center_mix_level = center_levels[get_bits(gbc, 2)]; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
353 if(s->channel_mode & 4) |
6126
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
354 s->surround_mix_level = surround_levels[get_bits(gbc, 2)]; |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
355 } |
6089 | 356 skip_bits1(gbc); // skip lfeon |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
357 |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
358 /* read the rest of the bsi. read twice for dual mono mode. */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
359 i = !(s->channel_mode); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
360 do { |
6089 | 361 skip_bits(gbc, 5); // skip dialog normalization |
362 if (get_bits1(gbc)) | |
363 skip_bits(gbc, 8); //skip compression | |
364 if (get_bits1(gbc)) | |
365 skip_bits(gbc, 8); //skip language code | |
366 if (get_bits1(gbc)) | |
367 skip_bits(gbc, 7); //skip audio production information | |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
368 } while (i--); |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
369 |
6089 | 370 skip_bits(gbc, 2); //skip copyright bit and original bitstream bit |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
371 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
372 /* skip the timecodes (or extra bitstream information for Alternate Syntax) |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
373 TODO: read & use the xbsi1 downmix levels */ |
6089 | 374 if (get_bits1(gbc)) |
375 skip_bits(gbc, 14); //skip timecode1 / xbsi1 | |
376 if (get_bits1(gbc)) | |
377 skip_bits(gbc, 14); //skip timecode2 / xbsi2 | |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
378 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
379 /* skip additional bitstream info */ |
6089 | 380 if (get_bits1(gbc)) { |
381 i = get_bits(gbc, 6); | |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
382 do { |
6089 | 383 skip_bits(gbc, 8); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
384 } while(i--); |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
385 } |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
386 |
6126
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
387 return 0; |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
388 } |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
389 |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
390 /** |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
391 * Set stereo downmixing coefficients based on frame header info. |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
392 * reference: Section 7.8.2 Downmixing Into Two Channels |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
393 */ |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
394 static void set_downmix_coeffs(AC3DecodeContext *s) |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
395 { |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
396 int i; |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
397 float cmix = gain_levels[s->center_mix_level]; |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
398 float smix = gain_levels[s->surround_mix_level]; |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
399 |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
400 for(i=0; i<s->fbw_channels; i++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
401 s->downmix_coeffs[i][0] = gain_levels[ac3_default_coeffs[s->channel_mode][i][0]]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
402 s->downmix_coeffs[i][1] = gain_levels[ac3_default_coeffs[s->channel_mode][i][1]]; |
5480 | 403 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
404 if(s->channel_mode > 1 && s->channel_mode & 1) { |
6126
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
405 s->downmix_coeffs[1][0] = s->downmix_coeffs[1][1] = cmix; |
5480 | 406 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
407 if(s->channel_mode == AC3_CHMODE_2F1R || s->channel_mode == AC3_CHMODE_3F1R) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
408 int nf = s->channel_mode - 2; |
6126
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
409 s->downmix_coeffs[nf][0] = s->downmix_coeffs[nf][1] = smix * LEVEL_MINUS_3DB; |
5480 | 410 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
411 if(s->channel_mode == AC3_CHMODE_2F2R || s->channel_mode == AC3_CHMODE_3F2R) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
412 int nf = s->channel_mode - 4; |
6126
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
413 s->downmix_coeffs[nf][0] = s->downmix_coeffs[nf+1][1] = smix; |
5480 | 414 } |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
415 } |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
416 |
5376 | 417 /** |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
418 * Decode the grouped exponents according to exponent strategy. |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
419 * reference: Section 7.1.3 Exponent Decoding |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
420 */ |
6089 | 421 static void decode_exponents(GetBitContext *gbc, int exp_strategy, int ngrps, |
5389
cf99cf2d3af9
use consistent data type for exponents. needs to be int8_t to pass to bit allocation.
jbr
parents:
5388
diff
changeset
|
422 uint8_t absexp, int8_t *dexps) |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
423 { |
6006 | 424 int i, j, grp, group_size; |
5375 | 425 int dexp[256]; |
426 int expacc, prevexp; | |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
427 |
5375 | 428 /* unpack groups */ |
6006 | 429 group_size = exp_strategy + (exp_strategy == EXP_D45); |
5375 | 430 for(grp=0,i=0; grp<ngrps; grp++) { |
6089 | 431 expacc = get_bits(gbc, 7); |
5678
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
432 dexp[i++] = exp_ungroup_tab[expacc][0]; |
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
433 dexp[i++] = exp_ungroup_tab[expacc][1]; |
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
434 dexp[i++] = exp_ungroup_tab[expacc][2]; |
5375 | 435 } |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
436 |
5375 | 437 /* convert to absolute exps and expand groups */ |
438 prevexp = absexp; | |
439 for(i=0; i<ngrps*3; i++) { | |
440 prevexp = av_clip(prevexp + dexp[i]-2, 0, 24); | |
6006 | 441 for(j=0; j<group_size; j++) { |
442 dexps[(i*group_size)+j] = prevexp; | |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
443 } |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
444 } |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
445 } |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
446 |
5451
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
447 /** |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
448 * Generate transform coefficients for each coupled channel in the coupling |
5451
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
449 * range using the coupling coefficients and coupling coordinates. |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
450 * reference: Section 7.4.3 Coupling Coordinate Format |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
451 */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
452 static void uncouple_channels(AC3DecodeContext *s) |
5451
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
453 { |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
454 int i, j, ch, bnd, subbnd; |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
455 |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
456 subbnd = -1; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
457 i = s->start_freq[CPL_CH]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
458 for(bnd=0; bnd<s->num_cpl_bands; bnd++) { |
5451
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
459 do { |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
460 subbnd++; |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
461 for(j=0; j<12; j++) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
462 for(ch=1; ch<=s->fbw_channels; ch++) { |
6123
8d88831a2777
fix phase flag processing for the case when coupling coordinates are reused
jbr
parents:
6117
diff
changeset
|
463 if(s->channel_in_cpl[ch]) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
464 s->transform_coeffs[ch][i] = s->transform_coeffs[CPL_CH][i] * s->cpl_coords[ch][bnd] * 8.0f; |
6123
8d88831a2777
fix phase flag processing for the case when coupling coordinates are reused
jbr
parents:
6117
diff
changeset
|
465 if (ch == 2 && s->phase_flags[bnd]) |
8d88831a2777
fix phase flag processing for the case when coupling coordinates are reused
jbr
parents:
6117
diff
changeset
|
466 s->transform_coeffs[ch][i] = -s->transform_coeffs[ch][i]; |
8d88831a2777
fix phase flag processing for the case when coupling coordinates are reused
jbr
parents:
6117
diff
changeset
|
467 } |
5451
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
468 } |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
469 i++; |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
470 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
471 } while(s->cpl_band_struct[subbnd]); |
5451
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
472 } |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
473 } |
19bb5e64a57c
split out coupling coefficient reconstruction into a separate function
jbr
parents:
5435
diff
changeset
|
474 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
475 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
476 * Grouped mantissas for 3-level 5-level and 11-level quantization |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
477 */ |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
478 typedef struct { |
5456 | 479 float b1_mant[3]; |
480 float b2_mant[3]; | |
481 float b4_mant[2]; | |
482 int b1ptr; | |
483 int b2ptr; | |
484 int b4ptr; | |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
485 } mant_groups; |
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
486 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
487 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
488 * Get the transform coefficients for a particular channel |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
489 * reference: Section 7.3 Quantization and Decoding of Mantissas |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
490 */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
491 static int get_transform_coeffs_ch(AC3DecodeContext *s, int ch_index, mant_groups *m) |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
492 { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
493 GetBitContext *gbc = &s->gbc; |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
494 int i, gcode, tbap, start, end; |
5310
9aa9197034d7
AC-3 decoder, soc revision 40, Aug 9 00:10:14 2006 UTC by cloud9
jbr
parents:
5309
diff
changeset
|
495 uint8_t *exps; |
9aa9197034d7
AC-3 decoder, soc revision 40, Aug 9 00:10:14 2006 UTC by cloud9
jbr
parents:
5309
diff
changeset
|
496 uint8_t *bap; |
9aa9197034d7
AC-3 decoder, soc revision 40, Aug 9 00:10:14 2006 UTC by cloud9
jbr
parents:
5309
diff
changeset
|
497 float *coeffs; |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
498 |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
499 exps = s->dexps[ch_index]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
500 bap = s->bap[ch_index]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
501 coeffs = s->transform_coeffs[ch_index]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
502 start = s->start_freq[ch_index]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
503 end = s->end_freq[ch_index]; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
504 |
5452
190d793a22e7
merge decoding of coupling channel coefficients and regular channel coefficients
jbr
parents:
5451
diff
changeset
|
505 for (i = start; i < end; i++) { |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
506 tbap = bap[i]; |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
507 switch (tbap) { |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
508 case 0: |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
509 coeffs[i] = ((av_random(&s->dith_state) & 0xFFFF) / 65535.0f) - 0.5f; |
5453 | 510 break; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
511 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
512 case 1: |
5456 | 513 if(m->b1ptr > 2) { |
6089 | 514 gcode = get_bits(gbc, 5); |
5456 | 515 m->b1_mant[0] = b1_mantissas[gcode][0]; |
516 m->b1_mant[1] = b1_mantissas[gcode][1]; | |
517 m->b1_mant[2] = b1_mantissas[gcode][2]; | |
518 m->b1ptr = 0; | |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
519 } |
5456 | 520 coeffs[i] = m->b1_mant[m->b1ptr++]; |
5453 | 521 break; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
522 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
523 case 2: |
5456 | 524 if(m->b2ptr > 2) { |
6089 | 525 gcode = get_bits(gbc, 7); |
5456 | 526 m->b2_mant[0] = b2_mantissas[gcode][0]; |
527 m->b2_mant[1] = b2_mantissas[gcode][1]; | |
528 m->b2_mant[2] = b2_mantissas[gcode][2]; | |
529 m->b2ptr = 0; | |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
530 } |
5456 | 531 coeffs[i] = m->b2_mant[m->b2ptr++]; |
5453 | 532 break; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
533 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
534 case 3: |
6089 | 535 coeffs[i] = b3_mantissas[get_bits(gbc, 3)]; |
5453 | 536 break; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
537 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
538 case 4: |
5456 | 539 if(m->b4ptr > 1) { |
6089 | 540 gcode = get_bits(gbc, 7); |
5456 | 541 m->b4_mant[0] = b4_mantissas[gcode][0]; |
542 m->b4_mant[1] = b4_mantissas[gcode][1]; | |
543 m->b4ptr = 0; | |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
544 } |
5456 | 545 coeffs[i] = m->b4_mant[m->b4ptr++]; |
5453 | 546 break; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
547 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
548 case 5: |
6089 | 549 coeffs[i] = b5_mantissas[get_bits(gbc, 4)]; |
5453 | 550 break; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
551 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
552 default: |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
553 /* asymmetric dequantization */ |
6089 | 554 coeffs[i] = get_sbits(gbc, quantization_tab[tbap]) * scale_factors[quantization_tab[tbap]-1]; |
5453 | 555 break; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
556 } |
5453 | 557 coeffs[i] *= scale_factors[exps[i]]; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
558 } |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
559 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
560 return 0; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
561 } |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
562 |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
563 /** |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
564 * Remove random dithering from coefficients with zero-bit mantissas |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
565 * reference: Section 7.3.4 Dither for Zero Bit Mantissas (bap=0) |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
566 */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
567 static void remove_dithering(AC3DecodeContext *s) { |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
568 int ch, i; |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
569 int end=0; |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
570 float *coeffs; |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
571 uint8_t *bap; |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
572 |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
573 for(ch=1; ch<=s->fbw_channels; ch++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
574 if(!s->dither_flag[ch]) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
575 coeffs = s->transform_coeffs[ch]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
576 bap = s->bap[ch]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
577 if(s->channel_in_cpl[ch]) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
578 end = s->start_freq[CPL_CH]; |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
579 else |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
580 end = s->end_freq[ch]; |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
581 for(i=0; i<end; i++) { |
6095 | 582 if(!bap[i]) |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
583 coeffs[i] = 0.0f; |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
584 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
585 if(s->channel_in_cpl[ch]) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
586 bap = s->bap[CPL_CH]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
587 for(; i<s->end_freq[CPL_CH]; i++) { |
6095 | 588 if(!bap[i]) |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
589 coeffs[i] = 0.0f; |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
590 } |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
591 } |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
592 } |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
593 } |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
594 } |
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
595 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
596 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
597 * Get the transform coefficients. |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
598 */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
599 static int get_transform_coeffs(AC3DecodeContext *s) |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
600 { |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
601 int ch, end; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
602 int got_cplchan = 0; |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
603 mant_groups m; |
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
604 |
5456 | 605 m.b1ptr = m.b2ptr = m.b4ptr = 3; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
606 |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
607 for (ch = 1; ch <= s->channels; ch++) { |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
608 /* transform coefficients for full-bandwidth channel */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
609 if (get_transform_coeffs_ch(s, ch, &m)) |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
610 return -1; |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
611 /* tranform coefficients for coupling channel come right after the |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
612 coefficients for the first coupled channel*/ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
613 if (s->channel_in_cpl[ch]) { |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
614 if (!got_cplchan) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
615 if (get_transform_coeffs_ch(s, CPL_CH, &m)) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
616 av_log(s->avctx, AV_LOG_ERROR, "error in decoupling channels\n"); |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
617 return -1; |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
618 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
619 uncouple_channels(s); |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
620 got_cplchan = 1; |
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
621 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
622 end = s->end_freq[CPL_CH]; |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
623 } else { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
624 end = s->end_freq[ch]; |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
625 } |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
626 do |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
627 s->transform_coeffs[ch][end] = 0; |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
628 while(++end < 256); |
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
629 } |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
630 |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
631 /* if any channel doesn't use dithering, zero appropriate coefficients */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
632 if(!s->dither_all) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
633 remove_dithering(s); |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
634 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
635 return 0; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
636 } |
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
637 |
5415 | 638 /** |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
639 * Stereo rematrixing. |
5415 | 640 * reference: Section 7.5.4 Rematrixing : Decoding Technique |
641 */ | |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
642 static void do_rematrixing(AC3DecodeContext *s) |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
643 { |
5415 | 644 int bnd, i; |
5310
9aa9197034d7
AC-3 decoder, soc revision 40, Aug 9 00:10:14 2006 UTC by cloud9
jbr
parents:
5309
diff
changeset
|
645 int end, bndend; |
5415 | 646 float tmp0, tmp1; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
647 |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
648 end = FFMIN(s->end_freq[1], s->end_freq[2]); |
5310
9aa9197034d7
AC-3 decoder, soc revision 40, Aug 9 00:10:14 2006 UTC by cloud9
jbr
parents:
5309
diff
changeset
|
649 |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
650 for(bnd=0; bnd<s->num_rematrixing_bands; bnd++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
651 if(s->rematrixing_flags[bnd]) { |
5678
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
652 bndend = FFMIN(end, rematrix_band_tab[bnd+1]); |
53c43e7156bc
cosmetics: rename variables. tbl->tab for consistency with other AC3 tables
jbr
parents:
5677
diff
changeset
|
653 for(i=rematrix_band_tab[bnd]; i<bndend; i++) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
654 tmp0 = s->transform_coeffs[1][i]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
655 tmp1 = s->transform_coeffs[2][i]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
656 s->transform_coeffs[1][i] = tmp0 + tmp1; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
657 s->transform_coeffs[2][i] = tmp0 - tmp1; |
5415 | 658 } |
659 } | |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
660 } |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
661 } |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
662 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
663 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
664 * Perform the 256-point IMDCT |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
665 */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
666 static void do_imdct_256(AC3DecodeContext *s, int chindex) |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
667 { |
5336 | 668 int i, k; |
5435 | 669 DECLARE_ALIGNED_16(float, x[128]); |
5336 | 670 FFTComplex z[2][64]; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
671 float *o_ptr = s->tmp_output; |
5336 | 672 |
673 for(i=0; i<2; i++) { | |
674 /* de-interleave coefficients */ | |
675 for(k=0; k<128; k++) { | |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
676 x[k] = s->transform_coeffs[chindex][2*k+i]; |
5336 | 677 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
678 |
5336 | 679 /* run standard IMDCT */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
680 s->imdct_256.fft.imdct_calc(&s->imdct_256, o_ptr, x, s->tmp_imdct); |
5336 | 681 |
682 /* reverse the post-rotation & reordering from standard IMDCT */ | |
683 for(k=0; k<32; k++) { | |
684 z[i][32+k].re = -o_ptr[128+2*k]; | |
685 z[i][32+k].im = -o_ptr[2*k]; | |
686 z[i][31-k].re = o_ptr[2*k+1]; | |
687 z[i][31-k].im = o_ptr[128+2*k+1]; | |
688 } | |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
689 } |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
690 |
5336 | 691 /* apply AC-3 post-rotation & reordering */ |
692 for(k=0; k<64; k++) { | |
693 o_ptr[ 2*k ] = -z[0][ k].im; | |
694 o_ptr[ 2*k+1] = z[0][63-k].re; | |
695 o_ptr[128+2*k ] = -z[0][ k].re; | |
696 o_ptr[128+2*k+1] = z[0][63-k].im; | |
697 o_ptr[256+2*k ] = -z[1][ k].re; | |
698 o_ptr[256+2*k+1] = z[1][63-k].im; | |
699 o_ptr[384+2*k ] = z[1][ k].im; | |
700 o_ptr[384+2*k+1] = -z[1][63-k].re; | |
5322
b55b8c792066
AC-3 decoder, soc revision 72, Sep 7 04:20:00 2006 UTC by cloud9
jbr
parents:
5321
diff
changeset
|
701 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
702 } |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
703 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
704 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
705 * Inverse MDCT Transform. |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
706 * Convert frequency domain coefficients to time-domain audio samples. |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
707 * reference: Section 7.9.4 Transformation Equations |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
708 */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
709 static inline void do_imdct(AC3DecodeContext *s) |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
710 { |
5336 | 711 int ch; |
6006 | 712 int channels; |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
713 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
714 /* Don't perform the IMDCT on the LFE channel unless it's used in the output */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
715 channels = s->fbw_channels; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
716 if(s->output_mode & AC3_OUTPUT_LFEON) |
6006 | 717 channels++; |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
718 |
6006 | 719 for (ch=1; ch<=channels; ch++) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
720 if (s->block_switch[ch]) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
721 do_imdct_256(s, ch); |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
722 } else { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
723 s->imdct_512.fft.imdct_calc(&s->imdct_512, s->tmp_output, |
6091 | 724 s->transform_coeffs[ch], s->tmp_imdct); |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
725 } |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
726 /* For the first half of the block, apply the window, add the delay |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
727 from the previous block, and send to output */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
728 s->dsp.vector_fmul_add_add(s->output[ch-1], s->tmp_output, |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
729 s->window, s->delay[ch-1], 0, 256, 1); |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
730 /* For the second half of the block, apply the window and store the |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
731 samples to delay, to be combined with the next block */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
732 s->dsp.vector_fmul_reverse(s->delay[ch-1], s->tmp_output+256, |
6091 | 733 s->window, 256); |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
734 } |
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
735 } |
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
736 |
5480 | 737 /** |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
738 * Downmix the output to mono or stereo. |
5480 | 739 */ |
6094
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
740 static void ac3_downmix(AC3DecodeContext *s) |
5480 | 741 { |
742 int i, j; | |
743 float v0, v1, s0, s1; | |
744 | |
745 for(i=0; i<256; i++) { | |
746 v0 = v1 = s0 = s1 = 0.0f; | |
6094
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
747 for(j=0; j<s->fbw_channels; j++) { |
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
748 v0 += s->output[j][i] * s->downmix_coeffs[j][0]; |
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
749 v1 += s->output[j][i] * s->downmix_coeffs[j][1]; |
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
750 s0 += s->downmix_coeffs[j][0]; |
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
751 s1 += s->downmix_coeffs[j][1]; |
5480 | 752 } |
753 v0 /= s0; | |
754 v1 /= s1; | |
6094
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
755 if(s->output_mode == AC3_CHMODE_MONO) { |
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
756 s->output[0][i] = (v0 + v1) * LEVEL_MINUS_3DB; |
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
757 } else if(s->output_mode == AC3_CHMODE_STEREO) { |
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
758 s->output[0][i] = v0; |
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
759 s->output[1][i] = v1; |
5480 | 760 } |
761 } | |
762 } | |
763 | |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
764 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
765 * Parse an audio block from AC-3 bitstream. |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
766 */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
767 static int ac3_parse_audio_block(AC3DecodeContext *s, int blk) |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
768 { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
769 int fbw_channels = s->fbw_channels; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
770 int channel_mode = s->channel_mode; |
5471
37c1944ca4ee
make exponent decoding consistent (prepare for merging coupling and lfe code with normal channel code).
jbr
parents:
5461
diff
changeset
|
771 int i, bnd, seg, ch; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
772 GetBitContext *gbc = &s->gbc; |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
773 uint8_t bit_alloc_stages[AC3_MAX_CHANNELS]; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
774 |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
775 memset(bit_alloc_stages, 0, AC3_MAX_CHANNELS); |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
776 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
777 /* block switch flags */ |
6031
9d3f52380cb3
Revert commit made in revision 11228. I'm getting some strange results in the
jbr
parents:
6025
diff
changeset
|
778 for (ch = 1; ch <= fbw_channels; ch++) |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
779 s->block_switch[ch] = get_bits1(gbc); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
780 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
781 /* dithering flags */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
782 s->dither_all = 1; |
6006 | 783 for (ch = 1; ch <= fbw_channels; ch++) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
784 s->dither_flag[ch] = get_bits1(gbc); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
785 if(!s->dither_flag[ch]) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
786 s->dither_all = 0; |
5454
5b497d971546
dither zero-bit mantissas by default. remove dithering only if it's explicitly turned off.
jbr
parents:
5453
diff
changeset
|
787 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
788 |
5497 | 789 /* dynamic range */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
790 i = !(s->channel_mode); |
5497 | 791 do { |
6089 | 792 if(get_bits1(gbc)) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
793 s->dynamic_range[i] = ((dynamic_range_tab[get_bits(gbc, 8)]-1.0) * |
6091 | 794 s->avctx->drc_scale)+1.0; |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
795 } else if(blk == 0) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
796 s->dynamic_range[i] = 1.0f; |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
797 } |
5497 | 798 } while(i--); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
799 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
800 /* coupling strategy */ |
6089 | 801 if (get_bits1(gbc)) { |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
802 memset(bit_alloc_stages, 3, AC3_MAX_CHANNELS); |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
803 s->cpl_in_use = get_bits1(gbc); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
804 if (s->cpl_in_use) { |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
805 /* coupling in use */ |
6006 | 806 int cpl_begin_freq, cpl_end_freq; |
5414 | 807 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
808 /* determine which channels are coupled */ |
6006 | 809 for (ch = 1; ch <= fbw_channels; ch++) |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
810 s->channel_in_cpl[ch] = get_bits1(gbc); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
811 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
812 /* phase flags in use */ |
6005 | 813 if (channel_mode == AC3_CHMODE_STEREO) |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
814 s->phase_flags_in_use = get_bits1(gbc); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
815 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
816 /* coupling frequency range and band structure */ |
6089 | 817 cpl_begin_freq = get_bits(gbc, 4); |
818 cpl_end_freq = get_bits(gbc, 4); | |
6006 | 819 if (3 + cpl_end_freq - cpl_begin_freq < 0) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
820 av_log(s->avctx, AV_LOG_ERROR, "3+cplendf = %d < cplbegf = %d\n", 3+cpl_end_freq, cpl_begin_freq); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
821 return -1; |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
822 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
823 s->num_cpl_bands = s->num_cpl_subbands = 3 + cpl_end_freq - cpl_begin_freq; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
824 s->start_freq[CPL_CH] = cpl_begin_freq * 12 + 37; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
825 s->end_freq[CPL_CH] = cpl_end_freq * 12 + 73; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
826 for (bnd = 0; bnd < s->num_cpl_subbands - 1; bnd++) { |
6089 | 827 if (get_bits1(gbc)) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
828 s->cpl_band_struct[bnd] = 1; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
829 s->num_cpl_bands--; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
830 } |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
831 } |
6124
d06c62429572
make sure that the last coupling band stops at the end of the coupling range
jbr
parents:
6123
diff
changeset
|
832 s->cpl_band_struct[s->num_cpl_subbands-1] = 0; |
5388 | 833 } else { |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
834 /* coupling not in use */ |
6006 | 835 for (ch = 1; ch <= fbw_channels; ch++) |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
836 s->channel_in_cpl[ch] = 0; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
837 } |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
838 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
839 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
840 /* coupling coordinates */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
841 if (s->cpl_in_use) { |
6006 | 842 int cpl_coords_exist = 0; |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
843 |
6006 | 844 for (ch = 1; ch <= fbw_channels; ch++) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
845 if (s->channel_in_cpl[ch]) { |
6089 | 846 if (get_bits1(gbc)) { |
6006 | 847 int master_cpl_coord, cpl_coord_exp, cpl_coord_mant; |
848 cpl_coords_exist = 1; | |
6089 | 849 master_cpl_coord = 3 * get_bits(gbc, 2); |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
850 for (bnd = 0; bnd < s->num_cpl_bands; bnd++) { |
6089 | 851 cpl_coord_exp = get_bits(gbc, 4); |
852 cpl_coord_mant = get_bits(gbc, 4); | |
6006 | 853 if (cpl_coord_exp == 15) |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
854 s->cpl_coords[ch][bnd] = cpl_coord_mant / 16.0f; |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
855 else |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
856 s->cpl_coords[ch][bnd] = (cpl_coord_mant + 16.0f) / 32.0f; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
857 s->cpl_coords[ch][bnd] *= scale_factors[cpl_coord_exp + master_cpl_coord]; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
858 } |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
859 } |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
860 } |
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
861 } |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
862 /* phase flags */ |
6123
8d88831a2777
fix phase flag processing for the case when coupling coordinates are reused
jbr
parents:
6117
diff
changeset
|
863 if (channel_mode == AC3_CHMODE_STEREO && cpl_coords_exist) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
864 for (bnd = 0; bnd < s->num_cpl_bands; bnd++) { |
6123
8d88831a2777
fix phase flag processing for the case when coupling coordinates are reused
jbr
parents:
6117
diff
changeset
|
865 s->phase_flags[bnd] = s->phase_flags_in_use? get_bits1(gbc) : 0; |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
866 } |
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
867 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
868 } |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
869 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
870 /* stereo rematrixing strategy and band structure */ |
6005 | 871 if (channel_mode == AC3_CHMODE_STEREO) { |
6125 | 872 if (get_bits1(gbc)) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
873 s->num_rematrixing_bands = 4; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
874 if(s->cpl_in_use && s->start_freq[CPL_CH] <= 61) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
875 s->num_rematrixing_bands -= 1 + (s->start_freq[CPL_CH] == 37); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
876 for(bnd=0; bnd<s->num_rematrixing_bands; bnd++) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
877 s->rematrixing_flags[bnd] = get_bits1(gbc); |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
878 } |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
879 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
880 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
881 /* exponent strategies for each channel */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
882 s->exp_strategy[CPL_CH] = EXP_REUSE; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
883 s->exp_strategy[s->lfe_ch] = EXP_REUSE; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
884 for (ch = !s->cpl_in_use; ch <= s->channels; ch++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
885 if(ch == s->lfe_ch) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
886 s->exp_strategy[ch] = get_bits(gbc, 1); |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
887 else |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
888 s->exp_strategy[ch] = get_bits(gbc, 2); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
889 if(s->exp_strategy[ch] != EXP_REUSE) |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
890 bit_alloc_stages[ch] = 3; |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
891 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
892 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
893 /* channel bandwidth */ |
6006 | 894 for (ch = 1; ch <= fbw_channels; ch++) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
895 s->start_freq[ch] = 0; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
896 if (s->exp_strategy[ch] != EXP_REUSE) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
897 int prev = s->end_freq[ch]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
898 if (s->channel_in_cpl[ch]) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
899 s->end_freq[ch] = s->start_freq[CPL_CH]; |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
900 else { |
6089 | 901 int bandwidth_code = get_bits(gbc, 6); |
6006 | 902 if (bandwidth_code > 60) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
903 av_log(s->avctx, AV_LOG_ERROR, "bandwidth code = %d > 60", bandwidth_code); |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
904 return -1; |
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
905 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
906 s->end_freq[ch] = bandwidth_code * 3 + 73; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
907 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
908 if(blk > 0 && s->end_freq[ch] != prev) |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
909 memset(bit_alloc_stages, 3, AC3_MAX_CHANNELS); |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
910 } |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
911 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
912 s->start_freq[s->lfe_ch] = 0; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
913 s->end_freq[s->lfe_ch] = 7; |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
914 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
915 /* decode exponents for each channel */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
916 for (ch = !s->cpl_in_use; ch <= s->channels; ch++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
917 if (s->exp_strategy[ch] != EXP_REUSE) { |
6006 | 918 int group_size, num_groups; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
919 group_size = 3 << (s->exp_strategy[ch] - 1); |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
920 if(ch == CPL_CH) |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
921 num_groups = (s->end_freq[ch] - s->start_freq[ch]) / group_size; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
922 else if(ch == s->lfe_ch) |
6006 | 923 num_groups = 2; |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
924 else |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
925 num_groups = (s->end_freq[ch] + group_size - 4) / group_size; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
926 s->dexps[ch][0] = get_bits(gbc, 4) << !ch; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
927 decode_exponents(gbc, s->exp_strategy[ch], num_groups, s->dexps[ch][0], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
928 &s->dexps[ch][s->start_freq[ch]+!!ch]); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
929 if(ch != CPL_CH && ch != s->lfe_ch) |
6089 | 930 skip_bits(gbc, 2); /* skip gainrng */ |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
931 } |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
932 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
933 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
934 /* bit allocation information */ |
6089 | 935 if (get_bits1(gbc)) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
936 s->bit_alloc_params.slow_decay = ff_ac3_slow_decay_tab[get_bits(gbc, 2)] >> s->bit_alloc_params.sr_shift; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
937 s->bit_alloc_params.fast_decay = ff_ac3_fast_decay_tab[get_bits(gbc, 2)] >> s->bit_alloc_params.sr_shift; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
938 s->bit_alloc_params.slow_gain = ff_ac3_slow_gain_tab[get_bits(gbc, 2)]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
939 s->bit_alloc_params.db_per_bit = ff_ac3_db_per_bit_tab[get_bits(gbc, 2)]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
940 s->bit_alloc_params.floor = ff_ac3_floor_tab[get_bits(gbc, 3)]; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
941 for(ch=!s->cpl_in_use; ch<=s->channels; ch++) { |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
942 bit_alloc_stages[ch] = FFMAX(bit_alloc_stages[ch], 2); |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
943 } |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
944 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
945 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
946 /* signal-to-noise ratio offsets and fast gains (signal-to-mask ratios) */ |
6089 | 947 if (get_bits1(gbc)) { |
5393 | 948 int csnr; |
6089 | 949 csnr = (get_bits(gbc, 6) - 15) << 4; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
950 for (ch = !s->cpl_in_use; ch <= s->channels; ch++) { /* snr offset and fast gain */ |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
951 s->snr_offset[ch] = (csnr + get_bits(gbc, 4)) << 2; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
952 s->fast_gain[ch] = ff_ac3_fast_gain_tab[get_bits(gbc, 3)]; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
953 } |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
954 memset(bit_alloc_stages, 3, AC3_MAX_CHANNELS); |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
955 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
956 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
957 /* coupling leak information */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
958 if (s->cpl_in_use && get_bits1(gbc)) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
959 s->bit_alloc_params.cpl_fast_leak = get_bits(gbc, 3); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
960 s->bit_alloc_params.cpl_slow_leak = get_bits(gbc, 3); |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
961 bit_alloc_stages[CPL_CH] = FFMAX(bit_alloc_stages[CPL_CH], 2); |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
962 } |
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
963 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
964 /* delta bit allocation information */ |
6089 | 965 if (get_bits1(gbc)) { |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
966 /* delta bit allocation exists (strategy) */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
967 for (ch = !s->cpl_in_use; ch <= fbw_channels; ch++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
968 s->dba_mode[ch] = get_bits(gbc, 2); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
969 if (s->dba_mode[ch] == DBA_RESERVED) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
970 av_log(s->avctx, AV_LOG_ERROR, "delta bit allocation strategy reserved\n"); |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
971 return -1; |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
972 } |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
973 bit_alloc_stages[ch] = FFMAX(bit_alloc_stages[ch], 2); |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
974 } |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
975 /* channel delta offset, len and bit allocation */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
976 for (ch = !s->cpl_in_use; ch <= fbw_channels; ch++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
977 if (s->dba_mode[ch] == DBA_NEW) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
978 s->dba_nsegs[ch] = get_bits(gbc, 3); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
979 for (seg = 0; seg <= s->dba_nsegs[ch]; seg++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
980 s->dba_offsets[ch][seg] = get_bits(gbc, 5); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
981 s->dba_lengths[ch][seg] = get_bits(gbc, 4); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
982 s->dba_values[ch][seg] = get_bits(gbc, 3); |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
983 } |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
984 } |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
985 } |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
986 } else if(blk == 0) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
987 for(ch=0; ch<=s->channels; ch++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
988 s->dba_mode[ch] = DBA_NONE; |
5386
d6347c3cb329
Use shared AC-3 header parsing. Move some initializations to block parsing function.
jbr
parents:
5385
diff
changeset
|
989 } |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
990 } |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
991 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
992 /* Bit allocation */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
993 for(ch=!s->cpl_in_use; ch<=s->channels; ch++) { |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
994 if(bit_alloc_stages[ch] > 2) { |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
995 /* Exponent mapping into PSD and PSD integration */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
996 ff_ac3_bit_alloc_calc_psd(s->dexps[ch], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
997 s->start_freq[ch], s->end_freq[ch], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
998 s->psd[ch], s->band_psd[ch]); |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
999 } |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
1000 if(bit_alloc_stages[ch] > 1) { |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
1001 /* Compute excitation function, Compute masking curve, and |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
1002 Apply delta bit allocation */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1003 ff_ac3_bit_alloc_calc_mask(&s->bit_alloc_params, s->band_psd[ch], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1004 s->start_freq[ch], s->end_freq[ch], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1005 s->fast_gain[ch], (ch == s->lfe_ch), |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1006 s->dba_mode[ch], s->dba_nsegs[ch], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1007 s->dba_offsets[ch], s->dba_lengths[ch], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1008 s->dba_values[ch], s->mask[ch]); |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
1009 } |
5476
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
1010 if(bit_alloc_stages[ch] > 0) { |
e50f0d583a36
consolidate decoding of lfe and coupling channels with decoding of full-bandwidth channels.
jbr
parents:
5475
diff
changeset
|
1011 /* Compute bit allocation */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1012 ff_ac3_bit_alloc_calc_bap(s->mask[ch], s->psd[ch], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1013 s->start_freq[ch], s->end_freq[ch], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1014 s->snr_offset[ch], |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1015 s->bit_alloc_params.floor, |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1016 s->bap[ch]); |
5461
c427d8950769
cosmetics: use braces when it makes the code easier to read.
jbr
parents:
5460
diff
changeset
|
1017 } |
5310
9aa9197034d7
AC-3 decoder, soc revision 40, Aug 9 00:10:14 2006 UTC by cloud9
jbr
parents:
5309
diff
changeset
|
1018 } |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
1019 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
1020 /* unused dummy data */ |
6089 | 1021 if (get_bits1(gbc)) { |
1022 int skipl = get_bits(gbc, 9); | |
5309
0662a270aab7
AC-3 decoder, soc revision 38, Aug 7 00:03:00 2006 UTC by cloud9
jbr
parents:
5308
diff
changeset
|
1023 while(skipl--) |
6089 | 1024 skip_bits(gbc, 8); |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1025 } |
5499 | 1026 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1027 /* unpack the transform coefficients |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
1028 this also uncouples channels if coupling is in use. */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1029 if (get_transform_coeffs(s)) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1030 av_log(s->avctx, AV_LOG_ERROR, "Error in routine get_transform_coeffs\n"); |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1031 return -1; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
1032 } |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
1033 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1034 /* recover coefficients if rematrixing is in use */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1035 if(s->channel_mode == AC3_CHMODE_STEREO) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1036 do_rematrixing(s); |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1037 |
6032
f74202e7e896
Skip dialog normalization. It shouldn't be used by the decoder, and there is
jbr
parents:
6031
diff
changeset
|
1038 /* apply scaling to coefficients (headroom, dynrng) */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1039 for(ch=1; ch<=s->channels; ch++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1040 float gain = 2.0f * s->mul_bias; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1041 if(s->channel_mode == AC3_CHMODE_DUALMONO) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1042 gain *= s->dynamic_range[ch-1]; |
5412
3f6a6dda6b2d
remove broken downmixing. will add new implementation later.
jbr
parents:
5393
diff
changeset
|
1043 } else { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1044 gain *= s->dynamic_range[0]; |
5412
3f6a6dda6b2d
remove broken downmixing. will add new implementation later.
jbr
parents:
5393
diff
changeset
|
1045 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1046 for(i=0; i<s->end_freq[ch]; i++) { |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1047 s->transform_coeffs[ch][i] *= gain; |
5412
3f6a6dda6b2d
remove broken downmixing. will add new implementation later.
jbr
parents:
5393
diff
changeset
|
1048 } |
3f6a6dda6b2d
remove broken downmixing. will add new implementation later.
jbr
parents:
5393
diff
changeset
|
1049 } |
5318
ef4ef249ca72
AC-3 decoder, soc revision 58, Aug 19 14:20:45 2006 UTC by cloud9
jbr
parents:
5317
diff
changeset
|
1050 |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1051 do_imdct(s); |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
1052 |
6031
9d3f52380cb3
Revert commit made in revision 11228. I'm getting some strange results in the
jbr
parents:
6025
diff
changeset
|
1053 /* downmix output if needed */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1054 if(s->channels != s->out_channels && !((s->output_mode & AC3_OUTPUT_LFEON) && |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1055 s->fbw_channels == s->out_channels)) { |
6094
07fc769bf4e2
pass an AC3DecodeContext to ac3_downmix() instead of multiple arguments
jbr
parents:
6093
diff
changeset
|
1056 ac3_downmix(s); |
5480 | 1057 } |
1058 | |
5479
943c732c905d
use dsputil for float to signed 16-bit sample conversion
jbr
parents:
5477
diff
changeset
|
1059 /* convert float to 16-bit integer */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1060 for(ch=0; ch<s->out_channels; ch++) { |
5480 | 1061 for(i=0; i<256; i++) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1062 s->output[ch][i] += s->add_bias; |
5480 | 1063 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1064 s->dsp.float_to_int16(s->int_output[ch], s->output[ch], 256); |
5479
943c732c905d
use dsputil for float to signed 16-bit sample conversion
jbr
parents:
5477
diff
changeset
|
1065 } |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
1066 |
5479
943c732c905d
use dsputil for float to signed 16-bit sample conversion
jbr
parents:
5477
diff
changeset
|
1067 return 0; |
5306
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
1068 } |
abc5c130b448
AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9
jbr
parents:
5305
diff
changeset
|
1069 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
1070 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
1071 * Decode a single AC-3 frame. |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
1072 */ |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
1073 static int ac3_decode_frame(AVCodecContext * avctx, void *data, int *data_size, uint8_t *buf, int buf_size) |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1074 { |
6092 | 1075 AC3DecodeContext *s = avctx->priv_data; |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
1076 int16_t *out_samples = (int16_t *)data; |
5680 | 1077 int i, blk, ch, err; |
5318
ef4ef249ca72
AC-3 decoder, soc revision 58, Aug 19 14:20:45 2006 UTC by cloud9
jbr
parents:
5317
diff
changeset
|
1078 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
1079 /* initialize the GetBitContext with the start of valid AC-3 Frame */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1080 init_get_bits(&s->gbc, buf, buf_size * 8); |
5305
5892b4a6380b
AC-3 decoder, soc revision 31, Jul 14 23:53:28 2006 UTC by cloud9
jbr
parents:
5304
diff
changeset
|
1081 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
1082 /* parse the syncinfo */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1083 err = ac3_parse_header(s); |
5680 | 1084 if(err) { |
1085 switch(err) { | |
1086 case AC3_PARSE_ERROR_SYNC: | |
1087 av_log(avctx, AV_LOG_ERROR, "frame sync error\n"); | |
1088 break; | |
1089 case AC3_PARSE_ERROR_BSID: | |
1090 av_log(avctx, AV_LOG_ERROR, "invalid bitstream id\n"); | |
1091 break; | |
1092 case AC3_PARSE_ERROR_SAMPLE_RATE: | |
1093 av_log(avctx, AV_LOG_ERROR, "invalid sample rate\n"); | |
1094 break; | |
1095 case AC3_PARSE_ERROR_FRAME_SIZE: | |
1096 av_log(avctx, AV_LOG_ERROR, "invalid frame size\n"); | |
1097 break; | |
1098 default: | |
1099 av_log(avctx, AV_LOG_ERROR, "invalid header\n"); | |
1100 break; | |
1101 } | |
1102 return -1; | |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1103 } |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
1104 |
5681 | 1105 /* check that reported frame size fits in input buffer */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1106 if(s->frame_size > buf_size) { |
5681 | 1107 av_log(avctx, AV_LOG_ERROR, "incomplete frame\n"); |
1108 return -1; | |
1109 } | |
1110 | |
6098 | 1111 /* check for crc mismatch */ |
6133 | 1112 if(avctx->error_resilience >= FF_ER_CAREFUL) { |
6108 | 1113 if(av_crc(av_crc_get_table(AV_CRC_16_ANSI), 0, &buf[2], s->frame_size-2)) { |
6103 | 1114 av_log(avctx, AV_LOG_ERROR, "frame CRC mismatch\n"); |
1115 return -1; | |
1116 } | |
1117 /* TODO: error concealment */ | |
6102
896e1cd9a7fe
only check ac3 crc if AVCodecContext.error_resilience > 0
jbr
parents:
6098
diff
changeset
|
1118 } |
6098 | 1119 |
1120 avctx->sample_rate = s->sample_rate; | |
1121 avctx->bit_rate = s->bit_rate; | |
1122 | |
5412
3f6a6dda6b2d
remove broken downmixing. will add new implementation later.
jbr
parents:
5393
diff
changeset
|
1123 /* channel config */ |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1124 s->out_channels = s->channels; |
6021 | 1125 if (avctx->request_channels > 0 && avctx->request_channels <= 2 && |
6113 | 1126 avctx->request_channels < s->channels) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1127 s->out_channels = avctx->request_channels; |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1128 s->output_mode = avctx->request_channels == 1 ? AC3_CHMODE_MONO : AC3_CHMODE_STEREO; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
1129 } |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1130 avctx->channels = s->out_channels; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
1131 |
6126
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
1132 /* set downmixing coefficients if needed */ |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
1133 if(s->channels != s->out_channels && !((s->output_mode & AC3_OUTPUT_LFEON) && |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
1134 s->fbw_channels == s->out_channels)) { |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
1135 set_downmix_coeffs(s); |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
1136 } |
c24cd5282108
split out init of downmix coeffs into a separate function that can be called
jbr
parents:
6125
diff
changeset
|
1137 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
1138 /* parse the audio blocks */ |
5474
3e07472540c6
cosmetics: use more appropriate names for iterator variables.
jbr
parents:
5472
diff
changeset
|
1139 for (blk = 0; blk < NB_BLOCKS; blk++) { |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1140 if (ac3_parse_audio_block(s, blk)) { |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1141 av_log(avctx, AV_LOG_ERROR, "error parsing the audio block\n"); |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1142 *data_size = 0; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1143 return s->frame_size; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1144 } |
5474
3e07472540c6
cosmetics: use more appropriate names for iterator variables.
jbr
parents:
5472
diff
changeset
|
1145 for (i = 0; i < 256; i++) |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1146 for (ch = 0; ch < s->out_channels; ch++) |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1147 *(out_samples++) = s->int_output[ch][i]; |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1148 } |
5413
28c20633db55
BLOCK_SIZE is not used properly, just use numbers instead to avoid confusion
jbr
parents:
5412
diff
changeset
|
1149 *data_size = NB_BLOCKS * 256 * avctx->channels * sizeof (int16_t); |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1150 return s->frame_size; |
5303
b8821ff5c30d
AC-3 decoder, soc revision 9, Jun 14 03:52:02 2006 UTC by cloud9
jbr
parents:
diff
changeset
|
1151 } |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1152 |
5515
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
1153 /** |
b499866a3397
comments modification: add, clean up, Doxygenize, and reword
jbr
parents:
5499
diff
changeset
|
1154 * Uninitialize the AC-3 decoder. |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
1155 */ |
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
1156 static int ac3_decode_end(AVCodecContext *avctx) |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1157 { |
6092 | 1158 AC3DecodeContext *s = avctx->priv_data; |
6090
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1159 ff_mdct_end(&s->imdct_512); |
b7b19fbc4746
cosmetics: rename all AC3DecodeContext variables from ctx to s
jbr
parents:
6089
diff
changeset
|
1160 ff_mdct_end(&s->imdct_256); |
5321
fcb2a52c88fe
AC-3 decoder, soc revision 71, Sep 4 09:47:12 2006 UTC by cloud9
jbr
parents:
5320
diff
changeset
|
1161 |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1162 return 0; |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1163 } |
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1164 |
5334
d406baea3275
no need for the decoder to have the license as a prefix
jbr
parents:
5333
diff
changeset
|
1165 AVCodec ac3_decoder = { |
5315
31033309ebc9
AC-3 decoder, soc revision 55, Aug 17 12:25:24 2006 UTC by cloud9
jbr
parents:
5314
diff
changeset
|
1166 .name = "ac3", |
31033309ebc9
AC-3 decoder, soc revision 55, Aug 17 12:25:24 2006 UTC by cloud9
jbr
parents:
5314
diff
changeset
|
1167 .type = CODEC_TYPE_AUDIO, |
31033309ebc9
AC-3 decoder, soc revision 55, Aug 17 12:25:24 2006 UTC by cloud9
jbr
parents:
5314
diff
changeset
|
1168 .id = CODEC_ID_AC3, |
31033309ebc9
AC-3 decoder, soc revision 55, Aug 17 12:25:24 2006 UTC by cloud9
jbr
parents:
5314
diff
changeset
|
1169 .priv_data_size = sizeof (AC3DecodeContext), |
31033309ebc9
AC-3 decoder, soc revision 55, Aug 17 12:25:24 2006 UTC by cloud9
jbr
parents:
5314
diff
changeset
|
1170 .init = ac3_decode_init, |
31033309ebc9
AC-3 decoder, soc revision 55, Aug 17 12:25:24 2006 UTC by cloud9
jbr
parents:
5314
diff
changeset
|
1171 .close = ac3_decode_end, |
31033309ebc9
AC-3 decoder, soc revision 55, Aug 17 12:25:24 2006 UTC by cloud9
jbr
parents:
5314
diff
changeset
|
1172 .decode = ac3_decode_frame, |
5304
eff51058fe13
AC-3 decoder, soc revision 26, Jul 5 04:55:15 2006 UTC by cloud9
jbr
parents:
5303
diff
changeset
|
1173 }; |