|
808
|
1 /*
|
|
|
2 * VC-1 and WMV3 decoder
|
|
|
3 * copyright (c) 2006 Konstantin Shishkov
|
|
|
4 * (c) 2005 anonymous, Alex Beregszaszi, Michael Niedermayer
|
|
|
5 *
|
|
|
6 * This file is part of FFmpeg.
|
|
|
7 *
|
|
|
8 * FFmpeg is free software; you can redistribute it and/or
|
|
|
9 * modify it under the terms of the GNU Lesser General Public
|
|
|
10 * License as published by the Free Software Foundation; either
|
|
|
11 * version 2.1 of the License, or (at your option) any later version.
|
|
|
12 *
|
|
|
13 * FFmpeg is distributed in the hope that it will be useful,
|
|
|
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
16 * Lesser General Public License for more details.
|
|
|
17 *
|
|
|
18 * You should have received a copy of the GNU Lesser General Public
|
|
|
19 * License along with FFmpeg; if not, write to the Free Software
|
|
|
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
21 */
|
|
|
22
|
|
|
23 /**
|
|
|
24 * @file vc1data.h
|
|
|
25 * VC-1 tables.
|
|
|
26 */
|
|
|
27
|
|
|
28 #ifndef VC1DATA_H
|
|
|
29 #define VC1DATA_H
|
|
|
30
|
|
|
31 #if 0 //original bfraction from vc9data.h, not conforming to standard
|
|
|
32 /* Denominator used for vc1_bfraction_lut */
|
|
|
33 #define B_FRACTION_DEN 840
|
|
|
34
|
|
|
35 /* bfraction is fractional, we scale to the GCD 3*5*7*8 = 840 */
|
|
|
36 const int16_t vc1_bfraction_lut[23] = {
|
|
|
37 420 /*1/2*/, 280 /*1/3*/, 560 /*2/3*/, 210 /*1/4*/,
|
|
|
38 630 /*3/4*/, 168 /*1/5*/, 336 /*2/5*/,
|
|
|
39 504 /*3/5*/, 672 /*4/5*/, 140 /*1/6*/, 700 /*5/6*/,
|
|
|
40 120 /*1/7*/, 240 /*2/7*/, 360 /*3/7*/, 480 /*4/7*/,
|
|
|
41 600 /*5/7*/, 720 /*6/7*/, 105 /*1/8*/, 315 /*3/8*/,
|
|
|
42 525 /*5/8*/, 735 /*7/8*/,
|
|
|
43 -1 /*inv.*/, 0 /*BI fm*/
|
|
|
44 };
|
|
|
45 #else
|
|
|
46 /* Denominator used for vc1_bfraction_lut */
|
|
|
47 #define B_FRACTION_DEN 256
|
|
|
48
|
|
|
49 /* pre-computed scales for all bfractions and base=256 */
|
|
|
50 const int16_t vc1_bfraction_lut[23] = {
|
|
|
51 128 /*1/2*/, 85 /*1/3*/, 170 /*2/3*/, 64 /*1/4*/,
|
|
|
52 192 /*3/4*/, 51 /*1/5*/, 102 /*2/5*/,
|
|
|
53 153 /*3/5*/, 204 /*4/5*/, 43 /*1/6*/, 215 /*5/6*/,
|
|
|
54 37 /*1/7*/, 74 /*2/7*/, 111 /*3/7*/, 148 /*4/7*/,
|
|
|
55 185 /*5/7*/, 222 /*6/7*/, 32 /*1/8*/, 96 /*3/8*/,
|
|
|
56 160 /*5/8*/, 224 /*7/8*/,
|
|
|
57 -1 /*inv.*/, 0 /*BI fm*/
|
|
|
58 };
|
|
|
59 #endif
|
|
|
60
|
|
|
61 const uint8_t vc1_bfraction_bits[23] = {
|
|
|
62 3, 3, 3, 3,
|
|
|
63 3, 3, 3,
|
|
|
64 7, 7, 7, 7,
|
|
|
65 7, 7, 7, 7,
|
|
|
66 7, 7, 7, 7,
|
|
|
67 7, 7,
|
|
|
68 7, 7
|
|
|
69 };
|
|
|
70 const uint8_t vc1_bfraction_codes[23] = {
|
|
|
71 0, 1, 2, 3,
|
|
|
72 4, 5, 6,
|
|
|
73 112, 113, 114, 115,
|
|
|
74 116, 117, 118, 119,
|
|
|
75 120, 121, 122, 123,
|
|
|
76 124, 125,
|
|
|
77 126, 127
|
|
|
78 };
|
|
|
79
|
|
|
80 //Same as H.264
|
|
|
81 static const AVRational vc1_pixel_aspect[16]={
|
|
|
82 {0, 1},
|
|
|
83 {1, 1},
|
|
|
84 {12, 11},
|
|
|
85 {10, 11},
|
|
|
86 {16, 11},
|
|
|
87 {40, 33},
|
|
|
88 {24, 11},
|
|
|
89 {20, 11},
|
|
|
90 {32, 11},
|
|
|
91 {80, 33},
|
|
|
92 {18, 11},
|
|
|
93 {15, 11},
|
|
|
94 {64, 33},
|
|
|
95 {160, 99},
|
|
|
96 {0, 1},
|
|
|
97 {0, 1}
|
|
|
98 };
|
|
|
99
|
|
|
100 /* BitPlane IMODE - such a small table... */
|
|
|
101 static const uint8_t vc1_imode_codes[7] = {
|
|
|
102 0, 2, 1, 3, 1, 2, 3
|
|
|
103 };
|
|
|
104 static const uint8_t vc1_imode_bits[7] = {
|
|
|
105 4, 2, 3, 2, 4, 3, 3
|
|
|
106 };
|
|
|
107
|
|
|
108 /* Normal-2 imode */
|
|
|
109 static const uint8_t vc1_norm2_codes[4] = {
|
|
|
110 0, 4, 5, 3
|
|
|
111 };
|
|
|
112 static const uint8_t vc1_norm2_bits[4] = {
|
|
|
113 1, 3, 3, 2
|
|
|
114 };
|
|
|
115
|
|
|
116 static const uint16_t vc1_norm6_codes[64] = {
|
|
|
117 0x001, 0x002, 0x003, 0x000, 0x004, 0x001, 0x002, 0x047, 0x005, 0x003, 0x004, 0x04B, 0x005, 0x04D, 0x04E, 0x30E,
|
|
|
118 0x006, 0x006, 0x007, 0x053, 0x008, 0x055, 0x056, 0x30D, 0x009, 0x059, 0x05A, 0x30C, 0x05C, 0x30B, 0x30A, 0x037,
|
|
|
119 0x007, 0x00A, 0x00B, 0x043, 0x00C, 0x045, 0x046, 0x309, 0x00D, 0x049, 0x04A, 0x308, 0x04C, 0x307, 0x306, 0x036,
|
|
|
120 0x00E, 0x051, 0x052, 0x305, 0x054, 0x304, 0x303, 0x035, 0x058, 0x302, 0x301, 0x034, 0x300, 0x033, 0x032, 0x007,
|
|
|
121 };
|
|
|
122
|
|
|
123 static const uint8_t vc1_norm6_bits[64] = {
|
|
|
124 1, 4, 4, 8, 4, 8, 8, 10, 4, 8, 8, 10, 8, 10, 10, 13,
|
|
|
125 4, 8, 8, 10, 8, 10, 10, 13, 8, 10, 10, 13, 10, 13, 13, 9,
|
|
|
126 4, 8, 8, 10, 8, 10, 10, 13, 8, 10, 10, 13, 10, 13, 13, 9,
|
|
|
127 8, 10, 10, 13, 10, 13, 13, 9, 10, 13, 13, 9, 13, 9, 9, 6,
|
|
|
128 };
|
|
|
129 /* Normal-6 imode */
|
|
|
130 static const uint8_t vc1_norm6_spec[64][5] = {
|
|
|
131 { 0, 1, 1 },
|
|
|
132 { 1, 2, 4 },
|
|
|
133 { 2, 3, 4 },
|
|
|
134 { 3, 0, 8 },
|
|
|
135 { 4, 4, 4 },
|
|
|
136 { 5, 1, 8 },
|
|
|
137 { 6, 2, 8 },
|
|
|
138 { 7, 2, 5, 7, 5 },
|
|
|
139 { 8, 5, 4 },
|
|
|
140 { 9, 3, 8 },
|
|
|
141 {10, 4, 8 },
|
|
|
142 {11, 2, 5, 11, 5 },
|
|
|
143 {12, 5, 8 },
|
|
|
144 {13, 2, 5, 13, 5 },
|
|
|
145 {14, 2, 5, 14, 5 },
|
|
|
146 {15, 3, 5, 14, 8 },
|
|
|
147 {16, 6, 4 },
|
|
|
148 {17, 6, 8 },
|
|
|
149 {18, 7, 8 },
|
|
|
150 {19, 2, 5, 19, 5 },
|
|
|
151 {20, 8, 8 },
|
|
|
152 {21, 2, 5, 21, 5 },
|
|
|
153 {22, 2, 5, 22, 5 },
|
|
|
154 {23, 3, 5, 13, 8 },
|
|
|
155 {24, 9, 8 },
|
|
|
156 {25, 2, 5, 25, 5 },
|
|
|
157 {26, 2, 5, 26, 5 },
|
|
|
158 {27, 3, 5, 12, 8 },
|
|
|
159 {28, 2, 5, 28, 5 },
|
|
|
160 {29, 3, 5, 11, 8 },
|
|
|
161 {30, 3, 5, 10, 8 },
|
|
|
162 {31, 3, 5, 7, 4 },
|
|
|
163 {32, 7, 4 },
|
|
|
164 {33, 10, 8 },
|
|
|
165 {34, 11, 8 },
|
|
|
166 {35, 2, 5, 3, 5 },
|
|
|
167 {36, 12, 8 },
|
|
|
168 {37, 2, 5, 5, 5 },
|
|
|
169 {38, 2, 5, 6, 5 },
|
|
|
170 {39, 3, 5, 9, 8 },
|
|
|
171 {40, 13, 8 },
|
|
|
172 {41, 2, 5, 9, 5 },
|
|
|
173 {42, 2, 5, 10, 5 },
|
|
|
174 {43, 3, 5, 8, 8 },
|
|
|
175 {44, 2, 5, 12, 5 },
|
|
|
176 {45, 3, 5, 7, 8 },
|
|
|
177 {46, 3, 5, 6, 8 },
|
|
|
178 {47, 3, 5, 6, 4 },
|
|
|
179 {48, 14, 8 },
|
|
|
180 {49, 2, 5, 17, 5 },
|
|
|
181 {50, 2, 5, 18, 5 },
|
|
|
182 {51, 3, 5, 5, 8 },
|
|
|
183 {52, 2, 5, 20, 5 },
|
|
|
184 {53, 3, 5, 4, 8 },
|
|
|
185 {54, 3, 5, 3, 8 },
|
|
|
186 {55, 3, 5, 5, 4 },
|
|
|
187 {56, 2, 5, 24, 5 },
|
|
|
188 {57, 3, 5, 2, 8 },
|
|
|
189 {58, 3, 5, 1, 8 },
|
|
|
190 {59, 3, 5, 4, 4 },
|
|
|
191 {60, 3, 5, 0, 8 },
|
|
|
192 {61, 3, 5, 3, 4 },
|
|
|
193 {62, 3, 5, 2, 4 },
|
|
|
194 {63, 3, 5, 1, 1 },
|
|
|
195 };
|
|
|
196
|
|
|
197 /* 4MV Block pattern VLC tables */
|
|
|
198 static const uint8_t vc1_4mv_block_pattern_codes[4][16] = {
|
|
|
199 { 14, 58, 59, 25, 12, 26, 15, 15, 13, 24, 27, 0, 28, 1, 2, 2},
|
|
|
200 { 8, 18, 19, 4, 20, 5, 30, 11, 21, 31, 6, 12, 7, 13, 14, 0},
|
|
|
201 { 15, 6, 7, 2, 8, 3, 28, 9, 10, 29, 4, 11, 5, 12, 13, 0},
|
|
|
202 { 0, 11, 12, 4, 13, 5, 30, 16, 14, 31, 6, 17, 7, 18, 19, 19}
|
|
|
203 };
|
|
|
204 static const uint8_t vc1_4mv_block_pattern_bits[4][16] = {
|
|
|
205 { 5, 6, 6, 5, 5, 5, 5, 4, 5, 5, 5, 3, 5, 3, 3, 2},
|
|
|
206 { 4, 5, 5, 4, 5, 4, 5, 4, 5, 5, 4, 4, 4, 4, 4, 2},
|
|
|
207 { 4, 4, 4, 4, 4, 4, 5, 4, 4, 5, 4, 4, 4, 4, 4, 3},
|
|
|
208 { 2, 4, 4, 4, 4, 4, 5, 5, 4, 5, 4, 5, 4, 5, 5, 4}
|
|
|
209 };
|
|
|
210
|
|
|
211 const uint8_t wmv3_dc_scale_table[32]={
|
|
|
212 0, 2, 4, 8, 8, 8, 9, 9,10,10,11,11,12,12,13,13,14,14,15,15,16,16,17,17,18,18,19,19,20,20,21,21
|
|
|
213 };
|
|
|
214
|
|
|
215 /* P-Picture CBPCY VLC tables */
|
|
|
216 #if 1 // Looks like original tables are not conforming to standard at all. Are they used for old WMV?
|
|
|
217 static const uint16_t vc1_cbpcy_p_codes[4][64] = {
|
|
|
218 {
|
|
|
219 0, 6, 15, 13, 13, 11, 3, 13, 5, 8, 49, 10, 12, 114, 102, 119,
|
|
|
220 1, 54, 96, 8, 10, 111, 5, 15, 12, 10, 2, 12, 13, 115, 53, 63,
|
|
|
221 1, 7, 1, 7, 14, 12, 4, 14, 1, 9, 97, 11, 7, 58, 52, 62,
|
|
|
222 4, 103, 1, 9, 11, 56, 101, 118, 4, 110, 100, 30, 2, 5, 4, 3
|
|
|
223 },
|
|
|
224 {
|
|
|
225 0, 9, 1, 18, 5, 14, 237, 26, 3, 121, 3, 22, 13, 16, 6, 30,
|
|
|
226 2, 10, 1, 20, 12, 241, 5, 28, 16, 12, 3, 24, 28, 124, 239, 247,
|
|
|
227 1, 240, 1, 19, 18, 15, 4, 27, 1, 122, 2, 23, 1, 17, 7, 31,
|
|
|
228 1, 11, 2, 21, 19, 246, 238, 29, 17, 13, 236, 25, 58, 63, 8, 125
|
|
|
229 },
|
|
|
230 {
|
|
|
231 0, 201, 25, 231, 5, 221, 1, 3, 2, 414, 2, 241, 16, 225, 195, 492,
|
|
|
232 2, 412, 1, 240, 7, 224, 98, 245, 1, 220, 96, 5, 9, 230, 101, 247,
|
|
|
233 1, 102, 1, 415, 24, 3, 2, 244, 3, 54, 3, 484, 17, 114, 200, 493,
|
|
|
234 3, 413, 1, 4, 13, 113, 99, 485, 4, 111, 194, 243, 5, 29, 26, 31
|
|
|
235 },
|
|
|
236 {
|
|
|
237 0, 28, 12, 44, 3, 36, 20, 52, 2, 32, 16, 48, 8, 40, 24, 28,
|
|
|
238 1, 30, 14, 46, 6, 38, 22, 54, 3, 34, 18, 50, 10, 42, 26, 30,
|
|
|
239 1, 29, 13, 45, 5, 37, 21, 53, 2, 33, 17, 49, 9, 41, 25, 29,
|
|
|
240 1, 31, 15, 47, 7, 39, 23, 55, 4, 35, 19, 51, 11, 43, 27, 31
|
|
|
241 }
|
|
|
242 };
|
|
|
243
|
|
|
244 static const uint8_t vc1_cbpcy_p_bits[4][64] = {
|
|
|
245 {
|
|
|
246 13, 13, 7, 13, 7, 13, 13, 12, 6, 13, 7, 12, 6, 8, 8, 8,
|
|
|
247 5, 7, 8, 12, 6, 8, 13, 12, 7, 13, 13, 12, 6, 8, 7, 7,
|
|
|
248 6, 13, 8, 12, 7, 13, 13, 12, 7, 13, 8, 12, 5, 7, 7, 7,
|
|
|
249 6, 8, 13, 12, 6, 7, 8, 8, 5, 8, 8, 6, 3, 3, 3, 2
|
|
|
250 },
|
|
|
251 {
|
|
|
252 14, 13, 8, 13, 3, 13, 8, 13, 3, 7, 8, 13, 4, 13, 13, 13,
|
|
|
253 3, 13, 13, 13, 4, 8, 13, 13, 5, 13, 13, 13, 5, 7, 8, 8,
|
|
|
254 3, 8, 14, 13, 5, 13, 13, 13, 4, 7, 13, 13, 6, 13, 13, 13,
|
|
|
255 5, 13, 8, 13, 5, 8, 8, 13, 5, 13, 8, 13, 6, 6, 13, 7
|
|
|
256 },
|
|
|
257 {
|
|
|
258 13, 8, 6, 8, 4, 8, 13, 12, 4, 9, 8, 8, 5, 8, 8, 9,
|
|
|
259 5, 9, 10, 8, 4, 8, 7, 8, 6, 8, 7, 13, 4, 8, 7, 8,
|
|
|
260 5, 7, 8, 9, 6, 13, 13, 8, 4, 6, 8, 9, 5, 7, 8, 9,
|
|
|
261 5, 9, 9, 13, 5, 7, 7, 9, 4, 7, 8, 8, 3, 5, 5, 5
|
|
|
262 },
|
|
|
263 {
|
|
|
264 9, 9, 9, 9, 2, 9, 9, 9, 2, 9, 9, 9, 9, 9, 9, 8,
|
|
|
265 3, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 8,
|
|
|
266 2, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 8,
|
|
|
267 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 8
|
|
|
268 }
|
|
|
269 };
|
|
|
270 #else
|
|
|
271 static const uint16_t vc1_cbpcy_p_codes[4][64] = {
|
|
|
272 {
|
|
|
273 0, 1, 1, 4, 5, 1, 12, 4, 13, 14, 10, 11, 12, 7, 13, 2,
|
|
|
274 15, 1, 96, 1, 49, 97, 2, 100, 3, 4, 5, 101, 102, 52, 53, 4,
|
|
|
275 6, 7, 54, 103, 8, 9, 10, 110, 11, 12, 111, 56, 114, 58, 115, 5,
|
|
|
276 13, 7, 8, 9, 10, 11, 12, 30, 13, 14, 15, 118, 119, 62, 63, 3
|
|
|
277 },
|
|
|
278 {
|
|
|
279 0, 1, 2, 1, 3, 1, 16, 17, 5, 18, 12, 19, 13, 1, 28, 58,
|
|
|
280 1, 1, 1, 2, 3, 2, 3, 236, 237, 4, 5, 238, 6, 7, 239, 8,
|
|
|
281 9, 240, 10, 11, 121, 122, 12, 13, 14, 15, 241, 246, 16, 17, 124, 63,
|
|
|
282 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 247, 125
|
|
|
283 },
|
|
|
284 {
|
|
|
285 0, 1, 2, 3, 2, 3, 1, 4, 5, 24, 7, 13, 16, 17, 9, 5,
|
|
|
286 25, 1, 1, 1, 2, 3, 96, 194, 1, 2, 98, 99, 195, 200, 101, 26,
|
|
|
287 201, 102, 412, 413, 414, 54, 220, 111, 221, 3, 224, 113, 225, 114, 230, 29,
|
|
|
288 231, 415, 240, 4, 241, 484, 5, 243, 3, 244, 245, 485, 492, 493, 247, 31
|
|
|
289 },
|
|
|
290 {
|
|
|
291 0, 1, 1, 1, 2, 2, 3, 4, 3, 5, 6, 7, 8, 9, 10, 11,
|
|
|
292 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27,
|
|
|
293 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43,
|
|
|
294 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 28, 29, 30, 31
|
|
|
295 }
|
|
|
296 };
|
|
|
297 static const uint8_t vc1_cbpcy_p_bits[4][64] = {
|
|
|
298 {
|
|
|
299 13, 6, 5, 6, 6, 7, 7, 5, 7, 7, 6, 6, 6, 5, 6, 3,
|
|
|
300 7, 8, 8, 13, 7, 8, 13, 8, 13, 13, 13, 8, 8, 7, 7, 3,
|
|
|
301 13, 13, 7, 8, 13, 13, 13, 8, 13, 13, 8, 7, 8, 7, 8, 3,
|
|
|
302 13, 12, 12, 12, 12, 12, 12, 6, 12, 12, 12, 8, 8, 7, 7, 2
|
|
|
303 },
|
|
|
304 {
|
|
|
305 14, 3, 3, 5, 3, 4, 5, 5, 3, 5, 4, 5, 4, 6, 5, 6,
|
|
|
306 8, 14, 13, 8, 8, 13, 13, 8, 8, 13, 13, 8, 13, 13, 8, 13,
|
|
|
307 13, 8, 13, 13, 7, 7, 13, 13, 13, 13, 8, 8, 13, 13, 7, 6,
|
|
|
308 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 8, 7
|
|
|
309 },
|
|
|
310 {
|
|
|
311 13, 5, 5, 5, 4, 4, 6, 4, 4, 6, 4, 5, 5, 5, 4, 3,
|
|
|
312 6, 8, 10, 9, 8, 8, 7, 8, 13, 13, 7, 7, 8, 8, 7, 5,
|
|
|
313 8, 7, 9, 9, 9, 6, 8, 7, 8, 13, 8, 7, 8, 7, 8, 5,
|
|
|
314 8, 9, 8, 13, 8, 9, 13, 8, 12, 8, 8, 9, 9, 9, 8, 5
|
|
|
315 },
|
|
|
316 {
|
|
|
317 9, 2, 3, 9, 2, 9, 9, 9, 2, 9, 9, 9, 9, 9, 9, 9,
|
|
|
318 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9,
|
|
|
319 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9,
|
|
|
320 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 8, 8, 8, 8
|
|
|
321 }
|
|
|
322 };
|
|
|
323 #endif
|
|
|
324
|
|
|
325 /* MacroBlock Transform Type: 7.1.3.11, p89
|
|
|
326 * 8x8:B
|
|
|
327 * 8x4:B:btm 8x4:B:top 8x4:B:both,
|
|
|
328 * 4x8:B:right 4x8:B:left 4x8:B:both
|
|
|
329 * 4x4:B 8x8:MB
|
|
|
330 * 8x4:MB:btm 8x4:MB:top 8x4,MB,both
|
|
|
331 * 4x8,MB,right 4x8,MB,left
|
|
|
332 * 4x4,MB */
|
|
|
333 static const uint16_t vc1_ttmb_codes[3][16] = {
|
|
|
334 {
|
|
|
335 0x0003,
|
|
|
336 0x002E, 0x005F, 0x0000,
|
|
|
337 0x0016, 0x0015, 0x0001,
|
|
|
338 0x0004, 0x0014,
|
|
|
339 0x02F1, 0x0179, 0x017B,
|
|
|
340 0x0BC0, 0x0BC1, 0x05E1,
|
|
|
341 0x017A
|
|
|
342 },
|
|
|
343 {
|
|
|
344 0x0006,
|
|
|
345 0x0006, 0x0003, 0x0007,
|
|
|
346 0x000F, 0x000E, 0x0000,
|
|
|
347 0x0002, 0x0002,
|
|
|
348 0x0014, 0x0011, 0x000B,
|
|
|
349 0x0009, 0x0021, 0x0015,
|
|
|
350 0x0020
|
|
|
351 },
|
|
|
352 {
|
|
|
353 0x0006,
|
|
|
354 0x0000, 0x000E, 0x0005,
|
|
|
355 0x0002, 0x0003, 0x0003,
|
|
|
356 0x000F, 0x0002,
|
|
|
357 0x0081, 0x0021, 0x0009,
|
|
|
358 0x0101, 0x0041, 0x0011,
|
|
|
359 0x0100
|
|
|
360 }
|
|
|
361 };
|
|
|
362
|
|
|
363 static const uint8_t vc1_ttmb_bits[3][16] = {
|
|
|
364 {
|
|
|
365 2,
|
|
|
366 6, 7, 2,
|
|
|
367 5, 5, 2,
|
|
|
368 3, 5,
|
|
|
369 10, 9, 9,
|
|
|
370 12, 12, 11,
|
|
|
371 9
|
|
|
372 },
|
|
|
373 {
|
|
|
374 3,
|
|
|
375 4, 4, 4,
|
|
|
376 4, 4, 3,
|
|
|
377 3, 2,
|
|
|
378 7, 7, 6,
|
|
|
379 6, 8, 7,
|
|
|
380 8
|
|
|
381 },
|
|
|
382 {
|
|
|
383 3,
|
|
|
384 3, 4, 5,
|
|
|
385 3, 3, 4,
|
|
|
386 4, 2,
|
|
|
387 10, 8, 6,
|
|
|
388 11, 9, 7,
|
|
|
389 11
|
|
|
390 }
|
|
|
391 };
|
|
|
392
|
|
|
393 /* TTBLK (Transform Type per Block) tables */
|
|
|
394 static const uint8_t vc1_ttblk_codes[3][8] = {
|
|
|
395 { 0, 1, 3, 5, 16, 17, 18, 19},
|
|
|
396 { 3, 0, 1, 2, 3, 5, 8, 9},
|
|
|
397 { 1, 0, 1, 4, 6, 7, 10, 11}
|
|
|
398 };
|
|
|
399 static const uint8_t vc1_ttblk_bits[3][8] = {
|
|
|
400 { 2, 2, 2, 3, 5, 5, 5, 5},
|
|
|
401 { 2, 3, 3, 3, 3, 3, 4, 4},
|
|
|
402 { 2, 3, 3, 3, 3, 3, 4, 4}
|
|
|
403 };
|
|
|
404
|
|
|
405 /* SUBBLKPAT tables, p93-94, reordered */
|
|
|
406 static const uint8_t vc1_subblkpat_codes[3][15] = {
|
|
|
407 { 14, 12, 7, 11, 9, 26, 2, 10, 27, 8, 0, 6, 1, 15, 1},
|
|
|
408 { 14, 0, 8, 15, 10, 4, 23, 13, 5, 9, 25, 3, 24, 22, 1},
|
|
|
409 { 5, 6, 2, 2, 8, 0, 28, 3, 1, 3, 29, 1, 19, 18, 15}
|
|
|
410 };
|
|
|
411 static const uint8_t vc1_subblkpat_bits[3][15] = {
|
|
|
412 { 5, 5, 5, 5, 5, 6, 4, 5, 6, 5, 4, 5, 4, 5, 1},
|
|
|
413 { 4, 3, 4, 4, 4, 5, 5, 4, 5, 4, 5, 4, 5, 5, 2},
|
|
|
414 { 3, 3, 4, 3, 4, 5, 5, 3, 5, 4, 5, 4, 5, 5, 4}
|
|
|
415 };
|
|
|
416
|
|
|
417 /* MV differential tables, p265 */
|
|
|
418 static const uint16_t vc1_mv_diff_codes[4][73] = {
|
|
|
419 {
|
|
|
420 0, 2, 3, 8, 576, 3, 2, 6,
|
|
|
421 5, 577, 578, 7, 8, 9, 40, 19,
|
|
|
422 37, 82, 21, 22, 23, 579, 580, 166,
|
|
|
423 96, 167, 49, 194, 195, 581, 582, 583,
|
|
|
424 292, 293, 294, 13, 2, 7, 24, 50,
|
|
|
425 102, 295, 13, 7, 8, 18, 50, 103,
|
|
|
426 38, 20, 21, 22, 39, 204, 103, 23,
|
|
|
427 24, 25, 104, 410, 105, 106, 107, 108,
|
|
|
428 109, 220, 411, 442, 222, 443, 446, 447,
|
|
|
429 7 /* 73 elements */
|
|
|
430 },
|
|
|
431 {
|
|
|
432 0, 4, 5, 3, 4, 3, 4, 5,
|
|
|
433 20, 6, 21, 44, 45, 46, 3008, 95,
|
|
|
434 112, 113, 57, 3009, 3010, 116, 117, 3011,
|
|
|
435 118, 3012, 3013, 3014, 3015, 3016, 3017, 3018,
|
|
|
436 3019, 3020, 3021, 3022, 1, 4, 15, 160,
|
|
|
437 161, 41, 6, 11, 42, 162, 43, 119,
|
|
|
438 56, 57, 58, 163, 236, 237, 3023, 119,
|
|
|
439 120, 242, 122, 486, 1512, 487, 246, 494,
|
|
|
440 1513, 495, 1514, 1515, 1516, 1517, 1518, 1519,
|
|
|
441 31 /* 73 elements */
|
|
|
442 },
|
|
|
443 {
|
|
|
444 0, 512, 513, 514, 515, 2, 3, 258,
|
|
|
445 259, 260, 261, 262, 263, 264, 265, 266,
|
|
|
446 267, 268, 269, 270, 271, 272, 273, 274,
|
|
|
447 275, 276, 277, 278, 279, 280, 281, 282,
|
|
|
448 283, 284, 285, 286, 1, 5, 287, 288,
|
|
|
449 289, 290, 6, 7, 291, 292, 293, 294,
|
|
|
450 295, 296, 297, 298, 299, 300, 301, 302,
|
|
|
451 303, 304, 305, 306, 307, 308, 309, 310,
|
|
|
452 311, 312, 313, 314, 315, 316, 317, 318,
|
|
|
453 319 /* 73 elements */
|
|
|
454 },
|
|
|
455 {
|
|
|
456 0, 1, 1, 2, 3, 4, 1, 5,
|
|
|
457 4, 3, 5, 8, 6, 9, 10, 11,
|
|
|
458 12, 7, 104, 14, 105, 4, 10, 15,
|
|
|
459 11, 6, 14, 8, 106, 107, 108, 15,
|
|
|
460 109, 9, 55, 10, 1, 2, 1, 2,
|
|
|
461 3, 12, 6, 2, 6, 7, 28, 7,
|
|
|
462 15, 8, 5, 18, 29, 152, 77, 24,
|
|
|
463 25, 26, 39, 108, 13, 109, 55, 56,
|
|
|
464 57, 116, 11, 153, 234, 235, 118, 119,
|
|
|
465 15 /* 73 elements */
|
|
|
466 }
|
|
|
467 };
|
|
|
468 static const uint8_t vc1_mv_diff_bits[4][73] = {
|
|
|
469 {
|
|
|
470 6, 7, 7, 8, 14, 6, 5, 6, 7, 14, 14, 6, 6, 6, 8, 9,
|
|
|
471 10, 9, 7, 7, 7, 14, 14, 10, 9, 10, 8, 10, 10, 14, 14, 14,
|
|
|
472 13, 13, 13, 6, 3, 5, 6, 8, 9, 13, 5, 4, 4, 5, 7, 9,
|
|
|
473 6, 5, 5, 5, 6, 9, 8, 5, 5, 5, 7, 10, 7, 7, 7, 7,
|
|
|
474 7, 8, 10, 9, 8, 9, 9, 9, 3 /* 73 elements */
|
|
|
475 },
|
|
|
476 {
|
|
|
477 5, 7, 7, 6, 6, 5, 5, 6, 7, 5, 7, 8, 8, 8, 14, 9,
|
|
|
478 9, 9, 8, 14, 14, 9, 9, 14, 9, 14, 14, 14, 14, 14, 14, 14,
|
|
|
479 14, 14, 14, 14, 2, 3, 6, 8, 8, 6, 3, 4, 6, 8, 6, 9,
|
|
|
480 6, 6, 6, 8, 8, 8, 14, 7, 7, 8, 7, 9, 13, 9, 8, 9,
|
|
|
481 13, 9, 13, 13, 13, 13, 13, 13, 5 /* 73 elements */
|
|
|
482
|
|
|
483 },
|
|
|
484 {
|
|
|
485 3, 12, 12, 12, 12, 3, 4, 11, 11, 11, 11, 11, 11, 11, 11, 11,
|
|
|
486 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11,
|
|
|
487 11, 11, 11, 11, 1, 5, 11, 11, 11, 11, 4, 4, 11, 11, 11, 11,
|
|
|
488 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11,
|
|
|
489 11, 11, 11, 11, 11, 11, 11, 11, 11 /* 73 elements */
|
|
|
490 },
|
|
|
491 {
|
|
|
492 15, 11, 15, 15, 15, 15, 12, 15, 12, 11, 12, 12, 15, 12, 12, 12,
|
|
|
493 12, 15, 15, 12, 15, 10, 11, 12, 11, 10, 11, 10, 15, 15, 15, 11,
|
|
|
494 15, 10, 14, 10, 4, 4, 5, 7, 8, 9, 5, 3, 4, 5, 6, 8,
|
|
|
495 5, 4, 3, 5, 6, 8, 7, 5, 5, 5, 6, 7, 9, 7, 6, 6,
|
|
|
496 6, 7, 10, 8, 8, 8, 7, 7, 4 /* 73 elements */
|
|
|
497 }
|
|
|
498 };
|
|
|
499
|
|
|
500 /* DC differentials low+hi-mo, p217 are the same as in msmpeg4data .h */
|
|
|
501
|
|
|
502 /* Scantables/ZZ scan are at 11.9 (p262) and 8.1.1.12 (p10) */
|
|
|
503 static const int8_t vc1_normal_zz[64] = {
|
|
|
504 0, 8, 1, 2, 9, 16, 24, 17,
|
|
|
505 10, 3, 4, 11, 18, 25, 32, 40,
|
|
|
506 33, 48, 26, 19, 12, 5, 6, 13,
|
|
|
507 20, 27, 34, 41, 56, 49, 57, 42,
|
|
|
508 35, 28, 21, 14, 7, 15, 22, 29,
|
|
|
509 36, 43, 50, 58, 51, 59, 44, 37,
|
|
|
510 30, 23, 31, 38, 45, 52, 60, 53,
|
|
|
511 61, 46, 39, 47, 54, 62, 55, 63
|
|
|
512 };
|
|
|
513
|
|
|
514 static const int8_t vc1_horizontal_zz [64] = /* Table 227 */
|
|
|
515 {
|
|
|
516 0, 1, 8, 2, 3, 9, 16, 24,
|
|
|
517 17, 10, 4, 5, 11, 18, 25, 32,
|
|
|
518 40, 48, 33, 26, 19, 12, 6, 7,
|
|
|
519 13, 20, 27, 34, 41, 56, 49, 57,
|
|
|
520 42, 35, 28, 21, 14, 15, 22, 29,
|
|
|
521 36, 43, 50, 58, 51, 44, 37, 30,
|
|
|
522 23, 31, 38, 45, 52, 59, 60, 53,
|
|
|
523 46, 39, 47, 54, 61, 62, 55, 63
|
|
|
524 };
|
|
|
525
|
|
|
526 static const int8_t vc1_vertical_zz [64] = /* Table 228 */
|
|
|
527 {
|
|
|
528 0, 8, 16, 1, 24, 32, 40, 9,
|
|
|
529 2, 3, 10, 17, 25, 48, 56, 41,
|
|
|
530 33, 26, 18, 11, 4, 5, 12, 19,
|
|
|
531 27, 34, 49, 57, 50, 42, 35, 28,
|
|
|
532 20, 13, 6, 7, 14, 21, 29, 36,
|
|
|
533 43, 51, 58, 59, 52, 44, 37, 30,
|
|
|
534 22, 15, 23, 31, 38, 45, 60, 53,
|
|
|
535 46, 39, 47, 54, 61, 62, 55, 63
|
|
|
536 };
|
|
|
537
|
|
|
538 static const int8_t vc1_simple_progressive_8x8_zz [64] =
|
|
|
539 /* Table 229 */
|
|
|
540 {
|
|
|
541 0, 8, 1, 2, 9, 16, 24, 17,
|
|
|
542 10, 3, 4, 11, 18, 25, 32, 40,
|
|
|
543 48, 56, 41, 33, 26, 19, 12, 5,
|
|
|
544 6, 13, 20, 27, 34, 49, 57, 58,
|
|
|
545 50, 42, 35, 28, 21, 14, 7, 15,
|
|
|
546 22, 29, 36, 43, 51, 59, 60, 52,
|
|
|
547 44, 37, 30, 23, 31, 38, 45, 53,
|
|
|
548 61, 62, 54, 46, 39, 47, 55, 63
|
|
|
549 };
|
|
|
550
|
|
|
551 static const int8_t vc1_simple_progressive_8x4_zz [32] = /* Table 230 */
|
|
|
552 {
|
|
|
553 0, 1, 2, 8, 3, 9, 10, 16,
|
|
|
554 4, 11, 17, 24, 18, 12, 5, 19,
|
|
|
555 25, 13, 20, 26, 27, 6, 21, 28,
|
|
|
556 14, 22, 29, 7, 30, 15, 23, 31
|
|
|
557 };
|
|
|
558
|
|
|
559 static const int8_t vc1_simple_progressive_4x8_zz [32] = /* Table 231 */
|
|
|
560 {
|
|
|
561 0, 8, 1, 16,
|
|
|
562 9, 24, 17, 2,
|
|
|
563 32, 10, 25, 40,
|
|
|
564 18, 48, 33, 26,
|
|
|
565 56, 41, 34, 3,
|
|
|
566 49, 57, 11, 42,
|
|
|
567 19, 50, 27, 58,
|
|
|
568 35, 43, 51, 59
|
|
|
569 };
|
|
|
570
|
|
|
571 /* Table 232 */
|
|
|
572 static const int8_t vc1_simple_progressive_4x4_zz [16] =
|
|
|
573 {
|
|
|
574 0, 8, 16, 1,
|
|
|
575 9, 24, 17, 2,
|
|
|
576 10, 18, 25, 3,
|
|
|
577 11, 26, 19, 27
|
|
|
578 };
|
|
|
579
|
|
|
580 static const int8_t vc1_adv_progressive_8x4_zz [32] = /* Table 233 */
|
|
|
581 {
|
|
|
582 0, 8, 1, 16, 2, 9, 10, 3,
|
|
|
583 24, 17, 4, 11, 18, 12, 5, 19,
|
|
|
584 25, 13, 20, 26, 27, 6, 21, 28,
|
|
|
585 14, 22, 29, 7, 30, 15, 23, 31
|
|
|
586 };
|
|
|
587
|
|
|
588 static const int8_t vc1_adv_progressive_4x8_zz [32] = /* Table 234 */
|
|
|
589 {
|
|
|
590 0, 1, 8, 2,
|
|
|
591 9, 16, 17, 24,
|
|
|
592 10, 32, 25, 18,
|
|
|
593 40, 3, 33, 26,
|
|
|
594 48, 11, 56, 41,
|
|
|
595 34, 49, 57, 42,
|
|
|
596 19, 50, 27, 58,
|
|
|
597 35, 43, 51, 59
|
|
|
598 };
|
|
|
599
|
|
|
600 static const int8_t vc1_adv_interlaced_8x8_zz [64] = /* Table 235 */
|
|
|
601 {
|
|
|
602 0, 8, 1, 16, 24, 9, 2, 32,
|
|
|
603 40, 48, 56, 17, 10, 3, 25, 18,
|
|
|
604 11, 4, 33, 41, 49, 57, 26, 34,
|
|
|
605 42, 50, 58, 19, 12, 5, 27, 20,
|
|
|
606 13, 6, 35, 28, 21, 14, 7, 15,
|
|
|
607 22, 29, 36, 43, 51, 59, 60, 52,
|
|
|
608 44, 37, 30, 23, 31, 38, 45, 53,
|
|
|
609 61, 62, 54, 46, 39, 47, 55, 63
|
|
|
610 };
|
|
|
611
|
|
|
612 static const int8_t vc1_adv_interlaced_8x4_zz [32] = /* Table 236 */
|
|
|
613 {
|
|
|
614 0, 8, 16, 24, 1, 9, 2, 17,
|
|
|
615 25, 10, 3, 18, 26, 4, 11, 19,
|
|
|
616 12, 5, 13, 20, 27, 6, 21, 28,
|
|
|
617 14, 22, 29, 7, 30, 15, 23, 31
|
|
|
618 };
|
|
|
619
|
|
|
620 static const int8_t vc1_adv_interlaced_4x8_zz [32] = /* Table 237 */
|
|
|
621 {
|
|
|
622 0, 1, 2, 8,
|
|
|
623 16, 9, 24, 17,
|
|
|
624 10, 3, 32, 40,
|
|
|
625 48, 56, 25, 18,
|
|
|
626 33, 26, 41, 34,
|
|
|
627 49, 57, 11, 42,
|
|
|
628 19, 50, 27, 58,
|
|
|
629 35, 43, 51, 59
|
|
|
630 };
|
|
|
631
|
|
|
632 static const int8_t vc1_adv_interlaced_4x4_zz [16] = /* Table 238 */
|
|
|
633 {
|
|
|
634 0, 8, 16, 24,
|
|
|
635 1, 9, 17, 2,
|
|
|
636 25, 10, 18, 3,
|
|
|
637 26, 11, 19, 27
|
|
|
638 };
|
|
|
639
|
|
|
640
|
|
|
641 /* DQScale as specified in 8.1.3.9 - almost identical to 0x40000/i */
|
|
|
642 static const int32_t vc1_dqscale[63] = {
|
|
|
643 0x40000, 0x20000, 0x15555, 0x10000, 0xCCCD, 0xAAAB, 0x9249, 0x8000,
|
|
|
644 0x71C7, 0x6666, 0x5D17, 0x5555, 0x4EC5, 0x4925, 0x4444, 0x4000,
|
|
|
645 0x3C3C, 0x38E4, 0x35E5, 0x3333, 0x30C3, 0x2E8C, 0x2C86, 0x2AAB,
|
|
|
646 0x28F6, 0x2762, 0x25ED, 0x2492, 0x234F, 0x2222, 0x2108, 0x2000,
|
|
|
647 0x1F08, 0x1E1E, 0x1D42, 0x1C72, 0x1BAD, 0x1AF3, 0x1A42, 0x199A,
|
|
|
648 0x18FA, 0x1862, 0x17D0, 0x1746, 0x16C1, 0x1643, 0x15CA, 0x1555,
|
|
|
649 0x14E6, 0x147B, 0x1414, 0x13B1, 0x1352, 0x12F7, 0x129E, 0x1249,
|
|
|
650 0x11F7, 0x11A8, 0x115B, 0x1111, 0x10C9, 0x1084, 0x1000
|
|
|
651 };
|
|
|
652 #endif /* VC1DATA_H */
|