]> git.sesse.net Git - ffmpeg/blob - libavcodec/ivi_common.c
bink: get rid of double precision float use
[ffmpeg] / libavcodec / ivi_common.c
1 /*
2  * common functions for Indeo Video Interactive codecs (Indeo4 and Indeo5)
3  *
4  * Copyright (c) 2009 Maxim Poliakovski
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
25  * This file contains functions and data shared by both Indeo4 and
26  * Indeo5 decoders.
27  */
28
29 #define BITSTREAM_READER_LE
30 #include "avcodec.h"
31 #include "get_bits.h"
32 #include "ivi_common.h"
33 #include "libavutil/common.h"
34 #include "ivi_dsp.h"
35
36 extern const IVIHuffDesc ff_ivi_mb_huff_desc[8];  ///< static macroblock huffman tables
37 extern const IVIHuffDesc ff_ivi_blk_huff_desc[8]; ///< static block huffman tables
38
39 VLC ff_ivi_mb_vlc_tabs [8];
40 VLC ff_ivi_blk_vlc_tabs[8];
41
42 /**
43  *  Reverse "nbits" bits of the value "val" and return the result
44  *  in the least significant bits.
45  */
46 static uint16_t inv_bits(uint16_t val, int nbits)
47 {
48     uint16_t res;
49
50     if (nbits <= 8) {
51         res = av_reverse[val] >> (8-nbits);
52     } else
53         res = ((av_reverse[val & 0xFF] << 8) + (av_reverse[val >> 8])) >> (16-nbits);
54
55     return res;
56 }
57
58 int ff_ivi_create_huff_from_desc(const IVIHuffDesc *cb, VLC *vlc, int flag)
59 {
60     int         pos, i, j, codes_per_row, prefix, not_last_row;
61     uint16_t    codewords[256]; /* FIXME: move this temporal storage out? */
62     uint8_t     bits[256];
63
64     pos = 0; /* current position = 0 */
65
66     for (i = 0; i < cb->num_rows; i++) {
67         codes_per_row = 1 << cb->xbits[i];
68         not_last_row  = (i != cb->num_rows - 1);
69         prefix        = ((1 << i) - 1) << (cb->xbits[i] + not_last_row);
70
71         for (j = 0; j < codes_per_row; j++) {
72             if (pos >= 256) /* Some Indeo5 codebooks can have more than 256 */
73                 break;      /* elements, but only 256 codes are allowed! */
74
75             bits[pos] = i + cb->xbits[i] + not_last_row;
76             if (bits[pos] > IVI_VLC_BITS)
77                 return -1; /* invalid descriptor */
78
79             codewords[pos] = inv_bits((prefix | j), bits[pos]);
80             if (!bits[pos])
81                 bits[pos] = 1;
82
83             pos++;
84         }//for j
85     }//for i
86
87     /* number of codewords = pos */
88     return init_vlc(vlc, IVI_VLC_BITS, pos, bits, 1, 1, codewords, 2, 2,
89                     (flag ? INIT_VLC_USE_NEW_STATIC : 0) | INIT_VLC_LE);
90 }
91
92 void ff_ivi_init_static_vlc(void)
93 {
94     int i;
95     static VLC_TYPE table_data[8192 * 16][2];
96     static int initialized_vlcs = 0;
97
98     if (initialized_vlcs)
99         return;
100     for (i = 0; i < 8; i++) {
101         ff_ivi_mb_vlc_tabs[i].table = table_data + i * 2 * 8192;
102         ff_ivi_mb_vlc_tabs[i].table_allocated = 8192;
103         ff_ivi_create_huff_from_desc(&ff_ivi_mb_huff_desc[i],  &ff_ivi_mb_vlc_tabs[i],  1);
104         ff_ivi_blk_vlc_tabs[i].table = table_data + (i * 2 + 1) * 8192;
105         ff_ivi_blk_vlc_tabs[i].table_allocated = 8192;
106         ff_ivi_create_huff_from_desc(&ff_ivi_blk_huff_desc[i], &ff_ivi_blk_vlc_tabs[i], 1);
107     }
108     initialized_vlcs = 1;
109 }
110
111 int ff_ivi_dec_huff_desc(GetBitContext *gb, int desc_coded, int which_tab,
112                          IVIHuffTab *huff_tab, AVCodecContext *avctx)
113 {
114     int         i, result;
115     IVIHuffDesc new_huff;
116
117     if (!desc_coded) {
118         /* select default table */
119         huff_tab->tab = (which_tab) ? &ff_ivi_blk_vlc_tabs[7]
120             : &ff_ivi_mb_vlc_tabs [7];
121     } else {
122         huff_tab->tab_sel = get_bits(gb, 3);
123         if (huff_tab->tab_sel == 7) {
124             /* custom huffman table (explicitly encoded) */
125             new_huff.num_rows = get_bits(gb, 4);
126             if (!new_huff.num_rows) {
127                 av_log(avctx, AV_LOG_ERROR, "Empty custom Huffman table!\n");
128                 return AVERROR_INVALIDDATA;
129             }
130
131             for (i = 0; i < new_huff.num_rows; i++)
132                 new_huff.xbits[i] = get_bits(gb, 4);
133
134             /* Have we got the same custom table? Rebuild if not. */
135             if (ff_ivi_huff_desc_cmp(&new_huff, &huff_tab->cust_desc) || !huff_tab->cust_tab.table) {
136                 ff_ivi_huff_desc_copy(&huff_tab->cust_desc, &new_huff);
137
138                 if (huff_tab->cust_tab.table)
139                     ff_free_vlc(&huff_tab->cust_tab);
140                 result = ff_ivi_create_huff_from_desc(&huff_tab->cust_desc,
141                         &huff_tab->cust_tab, 0);
142                 if (result) {
143                     huff_tab->cust_desc.num_rows = 0; // reset faulty description
144                     av_log(avctx, AV_LOG_ERROR,
145                            "Error while initializing custom vlc table!\n");
146                     return result;
147                 }
148             }
149             huff_tab->tab = &huff_tab->cust_tab;
150         } else {
151             /* select one of predefined tables */
152             huff_tab->tab = (which_tab) ? &ff_ivi_blk_vlc_tabs[huff_tab->tab_sel]
153                 : &ff_ivi_mb_vlc_tabs [huff_tab->tab_sel];
154         }
155     }
156
157     return 0;
158 }
159
160 int ff_ivi_huff_desc_cmp(const IVIHuffDesc *desc1, const IVIHuffDesc *desc2)
161 {
162     return    desc1->num_rows != desc2->num_rows
163            || memcmp(desc1->xbits, desc2->xbits, desc1->num_rows);
164 }
165
166 void ff_ivi_huff_desc_copy(IVIHuffDesc *dst, const IVIHuffDesc *src)
167 {
168     dst->num_rows = src->num_rows;
169     memcpy(dst->xbits, src->xbits, src->num_rows);
170 }
171
172 av_cold int ff_ivi_init_planes(IVIPlaneDesc *planes, const IVIPicConfig *cfg)
173 {
174     int         p, b;
175     uint32_t    b_width, b_height, align_fac, width_aligned, height_aligned, buf_size;
176     IVIBandDesc *band;
177
178     ff_ivi_free_buffers(planes);
179
180     /* fill in the descriptor of the luminance plane */
181     planes[0].width     = cfg->pic_width;
182     planes[0].height    = cfg->pic_height;
183     planes[0].num_bands = cfg->luma_bands;
184
185     /* fill in the descriptors of the chrominance planes */
186     planes[1].width     = planes[2].width     = (cfg->pic_width  + 3) >> 2;
187     planes[1].height    = planes[2].height    = (cfg->pic_height + 3) >> 2;
188     planes[1].num_bands = planes[2].num_bands = cfg->chroma_bands;
189
190     for (p = 0; p < 3; p++) {
191         planes[p].bands = av_mallocz(planes[p].num_bands * sizeof(IVIBandDesc));
192         if (!planes[p].bands)
193             return AVERROR(ENOMEM);
194
195         /* select band dimensions: if there is only one band then it
196          *  has the full size, if there are several bands each of them
197          *  has only half size */
198         b_width  = planes[p].num_bands == 1 ? planes[p].width  : (planes[p].width  + 1) >> 1;
199         b_height = planes[p].num_bands == 1 ? planes[p].height : (planes[p].height + 1) >> 1;
200
201         /* luma   band buffers will be aligned on 16x16 (max macroblock size) */
202         /* chroma band buffers will be aligned on   8x8 (max macroblock size) */
203         align_fac       = p ? 8 : 16;
204         width_aligned   = FFALIGN(b_width , align_fac);
205         height_aligned  = FFALIGN(b_height, align_fac);
206         buf_size        = width_aligned * height_aligned * sizeof(int16_t);
207
208         for (b = 0; b < planes[p].num_bands; b++) {
209             band = &planes[p].bands[b]; /* select appropriate plane/band */
210             band->plane    = p;
211             band->band_num = b;
212             band->width    = b_width;
213             band->height   = b_height;
214             band->pitch    = width_aligned;
215             band->aheight  = height_aligned;
216             band->bufs[0]  = av_mallocz(buf_size);
217             band->bufs[1]  = av_mallocz(buf_size);
218             band->bufsize  = buf_size/2;
219             if (!band->bufs[0] || !band->bufs[1])
220                 return AVERROR(ENOMEM);
221
222             /* allocate the 3rd band buffer for scalability mode */
223             if (cfg->luma_bands > 1) {
224                 band->bufs[2] = av_mallocz(buf_size);
225                 if (!band->bufs[2])
226                     return AVERROR(ENOMEM);
227             }
228
229             planes[p].bands[0].blk_vlc.cust_desc.num_rows = 0; /* reset custom vlc */
230         }
231     }
232
233     return 0;
234 }
235
236 av_cold void ff_ivi_free_buffers(IVIPlaneDesc *planes)
237 {
238     int p, b, t;
239
240     for (p = 0; p < 3; p++) {
241         for (b = 0; b < planes[p].num_bands; b++) {
242             av_freep(&planes[p].bands[b].bufs[0]);
243             av_freep(&planes[p].bands[b].bufs[1]);
244             av_freep(&planes[p].bands[b].bufs[2]);
245
246             if (planes[p].bands[b].blk_vlc.cust_tab.table)
247                 ff_free_vlc(&planes[p].bands[b].blk_vlc.cust_tab);
248             for (t = 0; t < planes[p].bands[b].num_tiles; t++)
249                 av_freep(&planes[p].bands[b].tiles[t].mbs);
250             av_freep(&planes[p].bands[b].tiles);
251         }
252         av_freep(&planes[p].bands);
253     }
254 }
255
256 av_cold int ff_ivi_init_tiles(IVIPlaneDesc *planes, int tile_width, int tile_height)
257 {
258     int         p, b, x, y, x_tiles, y_tiles, t_width, t_height;
259     IVIBandDesc *band;
260     IVITile     *tile, *ref_tile;
261
262     for (p = 0; p < 3; p++) {
263         t_width  = !p ? tile_width  : (tile_width  + 3) >> 2;
264         t_height = !p ? tile_height : (tile_height + 3) >> 2;
265
266         if (!p && planes[0].num_bands == 4) {
267             t_width  >>= 1;
268             t_height >>= 1;
269         }
270         if(t_width<=0 || t_height<=0)
271             return AVERROR(EINVAL);
272
273         for (b = 0; b < planes[p].num_bands; b++) {
274             band = &planes[p].bands[b];
275             x_tiles = IVI_NUM_TILES(band->width, t_width);
276             y_tiles = IVI_NUM_TILES(band->height, t_height);
277             band->num_tiles = x_tiles * y_tiles;
278
279             av_freep(&band->tiles);
280             band->tiles = av_mallocz(band->num_tiles * sizeof(IVITile));
281             if (!band->tiles)
282                 return AVERROR(ENOMEM);
283
284             tile = band->tiles;
285
286             /* use the first luma band as reference for motion vectors
287              * and quant */
288             ref_tile = planes[0].bands[0].tiles;
289
290             for (y = 0; y < band->height; y += t_height) {
291                 for (x = 0; x < band->width; x += t_width) {
292                     tile->xpos     = x;
293                     tile->ypos     = y;
294                     tile->mb_size  = band->mb_size;
295                     tile->width    = FFMIN(band->width - x,  t_width);
296                     tile->height   = FFMIN(band->height - y, t_height);
297                     tile->is_empty = tile->data_size = 0;
298                     /* calculate number of macroblocks */
299                     tile->num_MBs  = IVI_MBs_PER_TILE(tile->width, tile->height,
300                                                       band->mb_size);
301
302                     av_freep(&tile->mbs);
303                     tile->mbs = av_malloc(tile->num_MBs * sizeof(IVIMbInfo));
304                     if (!tile->mbs)
305                         return AVERROR(ENOMEM);
306
307                     tile->ref_mbs = 0;
308                     if (p || b) {
309                         tile->ref_mbs = ref_tile->mbs;
310                         ref_tile++;
311                     }
312
313                     tile++;
314                 }
315             }
316
317         }// for b
318     }// for p
319
320     return 0;
321 }
322
323 int ff_ivi_dec_tile_data_size(GetBitContext *gb)
324 {
325     int    len;
326
327     len = 0;
328     if (get_bits1(gb)) {
329         len = get_bits(gb, 8);
330         if (len == 255)
331             len = get_bits_long(gb, 24);
332     }
333
334     /* align the bitstream reader on the byte boundary */
335     align_get_bits(gb);
336
337     return len;
338 }
339
340 int ff_ivi_decode_blocks(GetBitContext *gb, IVIBandDesc *band, IVITile *tile)
341 {
342     int         mbn, blk, num_blocks, num_coeffs, blk_size, scan_pos, run, val,
343                 pos, is_intra, mc_type = 0, mv_x, mv_y, col_mask;
344     uint8_t     col_flags[8];
345     int32_t     prev_dc, trvec[64];
346     uint32_t    cbp, sym, lo, hi, quant, buf_offs, q;
347     IVIMbInfo   *mb;
348     RVMapDesc   *rvmap = band->rv_map;
349     void (*mc_with_delta_func)(int16_t *buf, const int16_t *ref_buf, uint32_t pitch, int mc_type);
350     void (*mc_no_delta_func)  (int16_t *buf, const int16_t *ref_buf, uint32_t pitch, int mc_type);
351     const uint16_t  *base_tab;
352     const uint8_t   *scale_tab;
353
354     prev_dc = 0; /* init intra prediction for the DC coefficient */
355
356     blk_size   = band->blk_size;
357     col_mask   = blk_size - 1; /* column mask for tracking non-zero coeffs */
358     num_blocks = (band->mb_size != blk_size) ? 4 : 1; /* number of blocks per mb */
359     num_coeffs = blk_size * blk_size;
360     if (blk_size == 8) {
361         mc_with_delta_func = ff_ivi_mc_8x8_delta;
362         mc_no_delta_func   = ff_ivi_mc_8x8_no_delta;
363     } else {
364         mc_with_delta_func = ff_ivi_mc_4x4_delta;
365         mc_no_delta_func   = ff_ivi_mc_4x4_no_delta;
366     }
367
368     for (mbn = 0, mb = tile->mbs; mbn < tile->num_MBs; mb++, mbn++) {
369         is_intra = !mb->type;
370         cbp      = mb->cbp;
371         buf_offs = mb->buf_offs;
372
373         quant = av_clip(band->glob_quant + mb->q_delta, 0, 23);
374
375         base_tab  = is_intra ? band->intra_base  : band->inter_base;
376         scale_tab = is_intra ? band->intra_scale : band->inter_scale;
377         if (scale_tab)
378             quant = scale_tab[quant];
379
380         if (!is_intra) {
381             mv_x = mb->mv_x;
382             mv_y = mb->mv_y;
383             if (band->is_halfpel) {
384                 mc_type = ((mv_y & 1) << 1) | (mv_x & 1);
385                 mv_x >>= 1;
386                 mv_y >>= 1; /* convert halfpel vectors into fullpel ones */
387             }
388             if (mb->type) {
389                 int dmv_x, dmv_y, cx, cy;
390
391                 dmv_x = mb->mv_x >> band->is_halfpel;
392                 dmv_y = mb->mv_y >> band->is_halfpel;
393                 cx    = mb->mv_x &  band->is_halfpel;
394                 cy    = mb->mv_y &  band->is_halfpel;
395
396                 if (   mb->xpos + dmv_x < 0
397                     || mb->xpos + dmv_x + band->mb_size + cx > band->pitch
398                     || mb->ypos + dmv_y < 0
399                     || mb->ypos + dmv_y + band->mb_size + cy > band->aheight) {
400                     return AVERROR_INVALIDDATA;
401                 }
402             }
403         }
404
405         for (blk = 0; blk < num_blocks; blk++) {
406             /* adjust block position in the buffer according to its number */
407             if (blk & 1) {
408                 buf_offs += blk_size;
409             } else if (blk == 2) {
410                 buf_offs -= blk_size;
411                 buf_offs += blk_size * band->pitch;
412             }
413
414             if (cbp & 1) { /* block coded ? */
415                 scan_pos = -1;
416                 memset(trvec, 0, num_coeffs*sizeof(trvec[0])); /* zero transform vector */
417                 memset(col_flags, 0, sizeof(col_flags));      /* zero column flags */
418
419                 while (scan_pos <= num_coeffs) {
420                     sym = get_vlc2(gb, band->blk_vlc.tab->table, IVI_VLC_BITS, 1);
421                     if (sym == rvmap->eob_sym)
422                         break; /* End of block */
423
424                     if (sym == rvmap->esc_sym) { /* Escape - run/val explicitly coded using 3 vlc codes */
425                         run = get_vlc2(gb, band->blk_vlc.tab->table, IVI_VLC_BITS, 1) + 1;
426                         lo  = get_vlc2(gb, band->blk_vlc.tab->table, IVI_VLC_BITS, 1);
427                         hi  = get_vlc2(gb, band->blk_vlc.tab->table, IVI_VLC_BITS, 1);
428                         val = IVI_TOSIGNED((hi << 6) | lo); /* merge them and convert into signed val */
429                     } else {
430                         if (sym >= 256U) {
431                             av_log(NULL, AV_LOG_ERROR, "Invalid sym encountered: %d.\n", sym);
432                             return -1;
433                         }
434                         run = rvmap->runtab[sym];
435                         val = rvmap->valtab[sym];
436                     }
437
438                     /* de-zigzag and dequantize */
439                     scan_pos += run;
440                     if (scan_pos >= (unsigned)num_coeffs)
441                         break;
442                     pos = band->scan[scan_pos];
443
444                     if (!val)
445                         av_dlog(NULL, "Val = 0 encountered!\n");
446
447                     q = (base_tab[pos] * quant) >> 9;
448                     if (q > 1)
449                         val = val * q + FFSIGN(val) * (((q ^ 1) - 1) >> 1);
450                     trvec[pos] = val;
451                     col_flags[pos & col_mask] |= !!val; /* track columns containing non-zero coeffs */
452                 }// while
453
454                 if (scan_pos >= num_coeffs && sym != rvmap->eob_sym)
455                     return -1; /* corrupt block data */
456
457                 /* undoing DC coeff prediction for intra-blocks */
458                 if (is_intra && band->is_2d_trans) {
459                     prev_dc      += trvec[0];
460                     trvec[0]      = prev_dc;
461                     col_flags[0] |= !!prev_dc;
462                 }
463                 if(band->transform_size > band->blk_size){
464                     av_log(0, AV_LOG_ERROR, "Too large transform\n");
465                     return AVERROR_INVALIDDATA;
466                 }
467                 /* apply inverse transform */
468                 band->inv_transform(trvec, band->buf + buf_offs,
469                                     band->pitch, col_flags);
470
471                 /* apply motion compensation */
472                 if (!is_intra)
473                     mc_with_delta_func(band->buf + buf_offs,
474                                        band->ref_buf + buf_offs + mv_y * band->pitch + mv_x,
475                                        band->pitch, mc_type);
476             } else {
477                 /* block not coded */
478                 /* for intra blocks apply the dc slant transform */
479                 /* for inter - perform the motion compensation without delta */
480                 if (is_intra && band->dc_transform) {
481                     band->dc_transform(&prev_dc, band->buf + buf_offs,
482                                        band->pitch, blk_size);
483                 } else
484                     mc_no_delta_func(band->buf + buf_offs,
485                                      band->ref_buf + buf_offs + mv_y * band->pitch + mv_x,
486                                      band->pitch, mc_type);
487             }
488
489             cbp >>= 1;
490         }// for blk
491     }// for mbn
492
493     align_get_bits(gb);
494
495     return 0;
496 }
497
498 void ff_ivi_process_empty_tile(AVCodecContext *avctx, IVIBandDesc *band,
499                                IVITile *tile, int32_t mv_scale)
500 {
501     int             x, y, need_mc, mbn, blk, num_blocks, mv_x, mv_y, mc_type;
502     int             offs, mb_offset, row_offset;
503     IVIMbInfo       *mb, *ref_mb;
504     const int16_t   *src;
505     int16_t         *dst;
506     void (*mc_no_delta_func)(int16_t *buf, const int16_t *ref_buf, uint32_t pitch,
507                              int mc_type);
508
509     if( tile->num_MBs != IVI_MBs_PER_TILE(tile->width, tile->height, band->mb_size) ){
510         av_log(avctx, AV_LOG_ERROR, "allocated tile size %d mismatches parameters %d in ff_ivi_process_empty_tile()\n",
511                tile->num_MBs, IVI_MBs_PER_TILE(tile->width, tile->height, band->mb_size));
512         return;
513     }
514
515     offs       = tile->ypos * band->pitch + tile->xpos;
516     mb         = tile->mbs;
517     ref_mb     = tile->ref_mbs;
518     row_offset = band->mb_size * band->pitch;
519     need_mc    = 0; /* reset the mc tracking flag */
520
521     for (y = tile->ypos; y < (tile->ypos + tile->height); y += band->mb_size) {
522         mb_offset = offs;
523
524         for (x = tile->xpos; x < (tile->xpos + tile->width); x += band->mb_size) {
525             mb->xpos     = x;
526             mb->ypos     = y;
527             mb->buf_offs = mb_offset;
528
529             mb->type = 1; /* set the macroblocks type = INTER */
530             mb->cbp  = 0; /* all blocks are empty */
531
532             if (!band->qdelta_present && !band->plane && !band->band_num) {
533                 mb->q_delta = band->glob_quant;
534                 mb->mv_x    = 0;
535                 mb->mv_y    = 0;
536             }
537
538             if (band->inherit_qdelta && ref_mb)
539                 mb->q_delta = ref_mb->q_delta;
540
541             if (band->inherit_mv && ref_mb) {
542                 /* motion vector inheritance */
543                 if (mv_scale) {
544                     mb->mv_x = ivi_scale_mv(ref_mb->mv_x, mv_scale);
545                     mb->mv_y = ivi_scale_mv(ref_mb->mv_y, mv_scale);
546                 } else {
547                     mb->mv_x = ref_mb->mv_x;
548                     mb->mv_y = ref_mb->mv_y;
549                 }
550                 need_mc |= mb->mv_x || mb->mv_y; /* tracking non-zero motion vectors */
551             }
552
553             mb++;
554             if (ref_mb)
555                 ref_mb++;
556             mb_offset += band->mb_size;
557         } // for x
558         offs += row_offset;
559     } // for y
560
561     if (band->inherit_mv && need_mc) { /* apply motion compensation if there is at least one non-zero motion vector */
562         num_blocks = (band->mb_size != band->blk_size) ? 4 : 1; /* number of blocks per mb */
563         mc_no_delta_func = (band->blk_size == 8) ? ff_ivi_mc_8x8_no_delta
564                                                  : ff_ivi_mc_4x4_no_delta;
565
566         for (mbn = 0, mb = tile->mbs; mbn < tile->num_MBs; mb++, mbn++) {
567             mv_x = mb->mv_x;
568             mv_y = mb->mv_y;
569             if (!band->is_halfpel) {
570                 mc_type = 0; /* we have only fullpel vectors */
571             } else {
572                 mc_type = ((mv_y & 1) << 1) | (mv_x & 1);
573                 mv_x >>= 1;
574                 mv_y >>= 1; /* convert halfpel vectors into fullpel ones */
575             }
576
577             for (blk = 0; blk < num_blocks; blk++) {
578                 /* adjust block position in the buffer according with its number */
579                 offs = mb->buf_offs + band->blk_size * ((blk & 1) + !!(blk & 2) * band->pitch);
580                 mc_no_delta_func(band->buf + offs,
581                                  band->ref_buf + offs + mv_y * band->pitch + mv_x,
582                                  band->pitch, mc_type);
583             }
584         }
585     } else {
586         /* copy data from the reference tile into the current one */
587         src = band->ref_buf + tile->ypos * band->pitch + tile->xpos;
588         dst = band->buf     + tile->ypos * band->pitch + tile->xpos;
589         for (y = 0; y < tile->height; y++) {
590             memcpy(dst, src, tile->width*sizeof(band->buf[0]));
591             src += band->pitch;
592             dst += band->pitch;
593         }
594     }
595 }
596
597
598 #ifdef DEBUG
599 static uint16_t ivi_calc_band_checksum(IVIBandDesc *band)
600 {
601     int         x, y;
602     int16_t     *src, checksum;
603
604     src = band->buf;
605     checksum = 0;
606
607     for (y = 0; y < band->height; src += band->pitch, y++)
608         for (x = 0; x < band->width; x++)
609             checksum += src[x];
610
611     return checksum;
612 }
613 #endif
614
615 void ff_ivi_output_plane(IVIPlaneDesc *plane, uint8_t *dst, int dst_pitch)
616 {
617     int             x, y;
618     const int16_t   *src  = plane->bands[0].buf;
619     uint32_t        pitch = plane->bands[0].pitch;
620
621     if (!src)
622         return;
623
624     for (y = 0; y < plane->height; y++) {
625         for (x = 0; x < plane->width; x++)
626             dst[x] = av_clip_uint8(src[x] + 128);
627         src += pitch;
628         dst += dst_pitch;
629     }
630 }
631
632 /**
633  *  Decode an Indeo 4 or 5 band.
634  *
635  *  @param[in,out]  ctx    ptr to the decoder context
636  *  @param[in,out]  band   ptr to the band descriptor
637  *  @param[in]      avctx  ptr to the AVCodecContext
638  *  @return         result code: 0 = OK, -1 = error
639  */
640 static int decode_band(IVI45DecContext *ctx, int plane_num,
641                        IVIBandDesc *band, AVCodecContext *avctx)
642 {
643     int         result, i, t, idx1, idx2, pos;
644     IVITile     *tile;
645
646     band->buf     = band->bufs[ctx->dst_buf];
647     if (!band->buf) {
648         av_log(avctx, AV_LOG_ERROR, "Band buffer points to no data!\n");
649         return AVERROR_INVALIDDATA;
650     }
651     band->ref_buf = band->bufs[ctx->ref_buf];
652     band->data_ptr = ctx->frame_data + (get_bits_count(&ctx->gb) >> 3);
653
654     result = ctx->decode_band_hdr(ctx, band, avctx);
655     if (result) {
656         av_log(avctx, AV_LOG_ERROR, "Error while decoding band header: %d\n",
657                result);
658         return result;
659     }
660
661     if (band->is_empty) {
662         av_log(avctx, AV_LOG_ERROR, "Empty band encountered!\n");
663         return AVERROR_INVALIDDATA;
664     }
665
666     band->rv_map = &ctx->rvmap_tabs[band->rvmap_sel];
667
668     /* apply corrections to the selected rvmap table if present */
669     for (i = 0; i < band->num_corr; i++) {
670         idx1 = band->corr[i * 2];
671         idx2 = band->corr[i * 2 + 1];
672         FFSWAP(uint8_t, band->rv_map->runtab[idx1], band->rv_map->runtab[idx2]);
673         FFSWAP(int16_t, band->rv_map->valtab[idx1], band->rv_map->valtab[idx2]);
674         if (idx1 == band->rv_map->eob_sym || idx2 == band->rv_map->eob_sym)
675             band->rv_map->eob_sym ^= idx1 ^ idx2;
676         if (idx1 == band->rv_map->esc_sym || idx2 == band->rv_map->esc_sym)
677             band->rv_map->esc_sym ^= idx1 ^ idx2;
678     }
679
680     pos = get_bits_count(&ctx->gb);
681
682     for (t = 0; t < band->num_tiles; t++) {
683         tile = &band->tiles[t];
684
685         if (tile->mb_size != band->mb_size) {
686             av_log(avctx, AV_LOG_ERROR, "MB sizes mismatch: %d vs. %d\n",
687                    band->mb_size, tile->mb_size);
688             return AVERROR_INVALIDDATA;
689         }
690         tile->is_empty = get_bits1(&ctx->gb);
691         if (tile->is_empty) {
692             ff_ivi_process_empty_tile(avctx, band, tile,
693                                       (ctx->planes[0].bands[0].mb_size >> 3) - (band->mb_size >> 3));
694             av_dlog(avctx, "Empty tile encountered!\n");
695         } else {
696             tile->data_size = ff_ivi_dec_tile_data_size(&ctx->gb);
697             if (!tile->data_size) {
698                 av_log(avctx, AV_LOG_ERROR, "Tile data size is zero!\n");
699                 result = AVERROR_INVALIDDATA;
700                 break;
701             }
702
703             result = ctx->decode_mb_info(ctx, band, tile, avctx);
704             if (result < 0)
705                 break;
706
707             result = ff_ivi_decode_blocks(&ctx->gb, band, tile);
708             if (result < 0 || ((get_bits_count(&ctx->gb) - pos) >> 3) != tile->data_size) {
709                 av_log(avctx, AV_LOG_ERROR, "Corrupted tile data encountered!\n");
710                 break;
711             }
712
713             pos += tile->data_size << 3; // skip to next tile
714         }
715     }
716
717     /* restore the selected rvmap table by applying its corrections in reverse order */
718     for (i = band->num_corr-1; i >= 0; i--) {
719         idx1 = band->corr[i*2];
720         idx2 = band->corr[i*2+1];
721         FFSWAP(uint8_t, band->rv_map->runtab[idx1], band->rv_map->runtab[idx2]);
722         FFSWAP(int16_t, band->rv_map->valtab[idx1], band->rv_map->valtab[idx2]);
723         if (idx1 == band->rv_map->eob_sym || idx2 == band->rv_map->eob_sym)
724             band->rv_map->eob_sym ^= idx1 ^ idx2;
725         if (idx1 == band->rv_map->esc_sym || idx2 == band->rv_map->esc_sym)
726             band->rv_map->esc_sym ^= idx1 ^ idx2;
727     }
728
729 #ifdef DEBUG
730     if (band->checksum_present) {
731         uint16_t chksum = ivi_calc_band_checksum(band);
732         if (chksum != band->checksum) {
733             av_log(avctx, AV_LOG_ERROR,
734                    "Band checksum mismatch! Plane %d, band %d, received: %x, calculated: %x\n",
735                    band->plane, band->band_num, band->checksum, chksum);
736         }
737     }
738 #endif
739
740     align_get_bits(&ctx->gb);
741
742     return result;
743 }
744
745 int ff_ivi_decode_frame(AVCodecContext *avctx, void *data, int *data_size,
746                         AVPacket *avpkt)
747 {
748     IVI45DecContext *ctx = avctx->priv_data;
749     const uint8_t   *buf = avpkt->data;
750     int             buf_size = avpkt->size;
751     int             result, p, b;
752
753     init_get_bits(&ctx->gb, buf, buf_size * 8);
754     ctx->frame_data = buf;
755     ctx->frame_size = buf_size;
756
757     result = ctx->decode_pic_hdr(ctx, avctx);
758     if (result) {
759         av_log(avctx, AV_LOG_ERROR,
760                "Error while decoding picture header: %d\n", result);
761         return -1;
762     }
763     if (ctx->gop_invalid)
764         return AVERROR_INVALIDDATA;
765
766     if (ctx->gop_flags & IVI5_IS_PROTECTED) {
767         av_log(avctx, AV_LOG_ERROR, "Password-protected clip!\n");
768         return -1;
769     }
770
771     ctx->switch_buffers(ctx);
772
773     //{ START_TIMER;
774
775     if (ctx->is_nonnull_frame(ctx)) {
776         ctx->buf_invalid[ctx->dst_buf] = 1;
777         for (p = 0; p < 3; p++) {
778             for (b = 0; b < ctx->planes[p].num_bands; b++) {
779                 result = decode_band(ctx, p, &ctx->planes[p].bands[b], avctx);
780                 if (result) {
781                     av_log(avctx, AV_LOG_ERROR,
782                            "Error while decoding band: %d, plane: %d\n", b, p);
783                     return -1;
784                 }
785             }
786         }
787         ctx->buf_invalid[ctx->dst_buf] = 0;
788     }
789     if (ctx->buf_invalid[ctx->dst_buf])
790         return -1;
791
792     //STOP_TIMER("decode_planes"); }
793
794     /* If the bidirectional mode is enabled, next I and the following P frame will */
795     /* be sent together. Unfortunately the approach below seems to be the only way */
796     /* to handle the B-frames mode. That's exactly the same Intel decoders do.     */
797     if (avctx->codec_id == AV_CODEC_ID_INDEO4 && ctx->frame_type == 0/*FRAMETYPE_INTRA*/) {
798         while (get_bits(&ctx->gb, 8)); // skip version string
799         skip_bits_long(&ctx->gb, 64);  // skip padding, TODO: implement correct 8-bytes alignment
800         if (get_bits_left(&ctx->gb) > 18 && show_bits(&ctx->gb, 18) == 0x3FFF8)
801             av_log(avctx, AV_LOG_ERROR, "Buffer contains IP frames!\n");
802     }
803
804     if (!ctx->is_nonnull_frame(ctx))
805         return buf_size;
806
807     if (ctx->frame.data[0])
808         avctx->release_buffer(avctx, &ctx->frame);
809
810     ctx->frame.reference = 0;
811     avcodec_set_dimensions(avctx, ctx->planes[0].width, ctx->planes[0].height);
812     if ((result = avctx->get_buffer(avctx, &ctx->frame)) < 0) {
813         av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
814         return result;
815     }
816
817     if (ctx->is_scalable) {
818         if (avctx->codec_id == AV_CODEC_ID_INDEO4)
819             ff_ivi_recompose_haar(&ctx->planes[0], ctx->frame.data[0], ctx->frame.linesize[0], 4);
820         else
821             ff_ivi_recompose53   (&ctx->planes[0], ctx->frame.data[0], ctx->frame.linesize[0], 4);
822     } else {
823         ff_ivi_output_plane(&ctx->planes[0], ctx->frame.data[0], ctx->frame.linesize[0]);
824     }
825
826     ff_ivi_output_plane(&ctx->planes[2], ctx->frame.data[1], ctx->frame.linesize[1]);
827     ff_ivi_output_plane(&ctx->planes[1], ctx->frame.data[2], ctx->frame.linesize[2]);
828
829     *data_size = sizeof(AVFrame);
830     *(AVFrame*)data = ctx->frame;
831
832     return buf_size;
833 }
834
835 /**
836  *  Close Indeo5 decoder and clean up its context.
837  */
838 av_cold int ff_ivi_decode_close(AVCodecContext *avctx)
839 {
840     IVI45DecContext *ctx = avctx->priv_data;
841
842     ff_ivi_free_buffers(&ctx->planes[0]);
843
844     if (ctx->mb_vlc.cust_tab.table)
845         ff_free_vlc(&ctx->mb_vlc.cust_tab);
846
847     if (ctx->frame.data[0])
848         avctx->release_buffer(avctx, &ctx->frame);
849
850 #if IVI4_STREAM_ANALYSER
851     if (avctx->codec_id == AV_CODEC_ID_INDEO4) {
852     if (ctx->is_scalable)
853         av_log(avctx, AV_LOG_ERROR, "This video uses scalability mode!\n");
854     if (ctx->uses_tiling)
855         av_log(avctx, AV_LOG_ERROR, "This video uses local decoding!\n");
856     if (ctx->has_b_frames)
857         av_log(avctx, AV_LOG_ERROR, "This video contains B-frames!\n");
858     if (ctx->has_transp)
859         av_log(avctx, AV_LOG_ERROR, "Transparency mode is enabled!\n");
860     if (ctx->uses_haar)
861         av_log(avctx, AV_LOG_ERROR, "This video uses Haar transform!\n");
862     if (ctx->uses_fullpel)
863         av_log(avctx, AV_LOG_ERROR, "This video uses fullpel motion vectors!\n");
864     }
865 #endif
866
867     return 0;
868 }
869
870
871 /**
872  * These are 2x8 predefined Huffman codebooks for coding macroblock/block
873  * signals. They are specified using "huffman descriptors" in order to
874  * avoid huge static tables. The decoding tables will be generated at
875  * startup from these descriptors.
876  */
877 const IVIHuffDesc ff_ivi_mb_huff_desc[8] = {
878     {8,  {0, 4, 5, 4, 4, 4, 6, 6}},
879     {12, {0, 2, 2, 3, 3, 3, 3, 5, 3, 2, 2, 2}},
880     {12, {0, 2, 3, 4, 3, 3, 3, 3, 4, 3, 2, 2}},
881     {12, {0, 3, 4, 4, 3, 3, 3, 3, 3, 2, 2, 2}},
882     {13, {0, 4, 4, 3, 3, 3, 3, 2, 3, 3, 2, 1, 1}},
883     {9,  {0, 4, 4, 4, 4, 3, 3, 3, 2}},
884     {10, {0, 4, 4, 4, 4, 3, 3, 2, 2, 2}},
885     {12, {0, 4, 4, 4, 3, 3, 2, 3, 2, 2, 2, 2}}
886 };
887
888 const IVIHuffDesc ff_ivi_blk_huff_desc[8] = {
889     {10, {1, 2, 3, 4, 4, 7, 5, 5, 4, 1}},
890     {11, {2, 3, 4, 4, 4, 7, 5, 4, 3, 3, 2}},
891     {12, {2, 4, 5, 5, 5, 5, 6, 4, 4, 3, 1, 1}},
892     {13, {3, 3, 4, 4, 5, 6, 6, 4, 4, 3, 2, 1, 1}},
893     {11, {3, 4, 4, 5, 5, 5, 6, 5, 4, 2, 2}},
894     {13, {3, 4, 5, 5, 5, 5, 6, 4, 3, 3, 2, 1, 1}},
895     {13, {3, 4, 5, 5, 5, 6, 5, 4, 3, 3, 2, 1, 1}},
896     {9,  {3, 4, 4, 5, 5, 5, 6, 5, 5}}
897 };
898
899
900 /**
901  *  Scan patterns shared between indeo4 and indeo5
902  */
903 const uint8_t ff_ivi_vertical_scan_8x8[64] = {
904     0,  8, 16, 24, 32, 40, 48, 56,
905     1,  9, 17, 25, 33, 41, 49, 57,
906     2, 10, 18, 26, 34, 42, 50, 58,
907     3, 11, 19, 27, 35, 43, 51, 59,
908     4, 12, 20, 28, 36, 44, 52, 60,
909     5, 13, 21, 29, 37, 45, 53, 61,
910     6, 14, 22, 30, 38, 46, 54, 62,
911     7, 15, 23, 31, 39, 47, 55, 63
912 };
913
914 const uint8_t ff_ivi_horizontal_scan_8x8[64] = {
915      0,  1,  2,  3,  4,  5,  6,  7,
916      8,  9, 10, 11, 12, 13, 14, 15,
917     16, 17, 18, 19, 20, 21, 22, 23,
918     24, 25, 26, 27, 28, 29, 30, 31,
919     32, 33, 34, 35, 36, 37, 38, 39,
920     40, 41, 42, 43, 44, 45, 46, 47,
921     48, 49, 50, 51, 52, 53, 54, 55,
922     56, 57, 58, 59, 60, 61, 62, 63
923 };
924
925 const uint8_t ff_ivi_direct_scan_4x4[16] = {
926     0, 1, 4, 8, 5, 2, 3, 6, 9, 12, 13, 10, 7, 11, 14, 15
927 };
928
929
930 /**
931  *  Run-value (RLE) tables.
932  */
933 const RVMapDesc ff_ivi_rvmap_tabs[9] = {
934 {   /* MapTab0 */
935     5, /* eob_sym */
936     2, /* esc_sym */
937     /* run table */
938     {1,  1,  0,  1,  1,  0,  1,  1,  2,  2,  1,  1,  1,  1,  3,  3,
939      1,  1,  2,  2,  1,  1,  4,  4,  1,  1,  1,  1,  2,  2,  5,  5,
940      1,  1,  3,  3,  1,  1,  6,  6,  1,  2,  1,  2,  7,  7,  1,  1,
941      8,  8,  1,  1,  4,  2,  1,  4,  2,  1,  3,  3,  1,  1,  1,  9,
942      9,  1,  2,  1,  2,  1,  5,  5,  1,  1, 10, 10,  1,  1,  3,  3,
943      2,  2,  1,  1, 11, 11,  6,  4,  4,  1,  6,  1,  2,  1,  2, 12,
944      8,  1, 12,  7,  8,  7,  1, 16,  1, 16,  1,  3,  3, 13,  1, 13,
945      2,  2,  1, 15,  1,  5, 14, 15,  1,  5, 14,  1, 17,  8, 17,  8,
946      1,  4,  4,  2,  2,  1, 25, 25, 24, 24,  1,  3,  1,  3,  1,  8,
947      6,  7,  6,  1, 18,  8, 18,  1,  7, 23,  2,  2, 23,  1,  1, 21,
948     22,  9,  9, 22, 19,  1, 21,  5, 19,  5,  1, 33, 20, 33, 20,  8,
949      4,  4,  1, 32,  2,  2,  8,  3, 32, 26,  3,  1,  7,  7, 26,  6,
950      1,  6,  1,  1, 16,  1, 10,  1, 10,  2, 16, 29, 28,  2, 29, 28,
951      1, 27,  5,  8,  5, 27,  1,  8,  3,  7,  3, 31, 41, 31,  1, 41,
952      6,  1,  6,  7,  4,  4,  1,  1,  2,  1,  2, 11, 34, 30, 11,  1,
953     30, 15, 15, 34, 36, 40, 36, 40, 35, 35, 37, 37, 39, 39, 38, 38},
954
955     /* value table */
956     { 1,  -1,   0,   2,  -2,   0,   3,  -3,   1,  -1,   4,  -4,   5,  -5,   1,  -1,
957       6,  -6,   2,  -2,   7,  -7,   1,  -1,   8,  -8,   9,  -9,   3,  -3,   1,  -1,
958      10, -10,   2,  -2,  11, -11,   1,  -1,  12,   4, -12,  -4,   1,  -1,  13, -13,
959       1,  -1,  14, -14,   2,   5,  15,  -2,  -5, -15,  -3,   3,  16, -16,  17,   1,
960      -1, -17,   6,  18,  -6, -18,   2,  -2,  19, -19,   1,  -1,  20, -20,   4,  -4,
961       7,  -7,  21, -21,   1,  -1,   2,   3,  -3,  22,  -2, -22,   8,  23,  -8,   1,
962       2, -23,  -1,   2,  -2,  -2,  24,   1, -24,  -1,  25,   5,  -5,   1, -25,  -1,
963       9,  -9,  26,   1, -26,   3,   1,  -1,  27,  -3,  -1, -27,   1,   3,  -1,  -3,
964      28,  -4,   4,  10, -10, -28,   1,  -1,   1,  -1,  29,   6, -29,  -6,  30,  -4,
965       3,   3,  -3, -30,   1,   4,  -1,  31,  -3,   1,  11, -11,  -1, -31,  32,  -1,
966      -1,   2,  -2,   1,   1, -32,   1,   4,  -1,  -4,  33,  -1,   1,   1,  -1,   5,
967       5,  -5, -33,  -1, -12,  12,  -5,  -7,   1,   1,   7,  34,   4,  -4,  -1,   4,
968     -34,  -4,  35,  36,  -2, -35,  -2, -36,   2,  13,   2,  -1,   1, -13,   1,  -1,
969      37,   1,  -5,   6,   5,  -1,  38,  -6,  -8,   5,   8,  -1,   1,   1, -37,  -1,
970       5,  39,  -5,  -5,   6,  -6, -38, -39, -14,  40,  14,   2,   1,   1,  -2, -40,
971      -1,  -2,   2,  -1,  -1,  -1,   1,   1,   1,  -1,   1,  -1,   1,  -1,   1,  -1}
972 },{
973     /* MapTab1 */
974     0,  /* eob_sym */
975     38, /* esc_sym */
976     /* run table */
977     {0,  1,  1,  2,  2,  3,  3,  4,  4,  5,  5,  6,  8,  6,  8,  7,
978      7,  9,  9, 10, 10, 11, 11,  1, 12,  1, 12, 13, 13, 16, 14, 16,
979     14, 15, 15, 17, 17, 18,  0, 18, 19, 20, 21, 19, 22, 21, 20, 22,
980     25, 24,  2, 25, 24, 23, 23,  2, 26, 28, 26, 28, 29, 27, 29, 27,
981     33, 33,  1, 32,  1,  3, 32, 30, 36,  3, 36, 30, 31, 31, 35, 34,
982     37, 41, 34, 35, 37,  4, 41,  4, 49,  8,  8, 49, 40, 38,  5, 38,
983     40, 39,  5, 39, 42, 43, 42,  7, 57,  6, 43, 44,  6, 50,  7, 44,
984     57, 48, 50, 48, 45, 45, 46, 47, 51, 46, 47, 58,  1, 51, 58,  1,
985     52, 59, 53,  9, 52, 55, 55, 59, 53, 56, 54, 56, 54,  9, 64, 64,
986     60, 63, 60, 63, 61, 62, 61, 62,  2, 10,  2, 10, 11,  1, 11, 13,
987     12,  1, 12, 13, 16, 16,  8,  8, 14,  3,  3, 15, 14, 15,  4,  4,
988      1, 17, 17,  5,  1,  7,  7,  5,  6,  1,  2,  2,  6, 22,  1, 25,
989     21, 22,  8, 24,  1, 21, 25, 24,  8, 18, 18, 23,  9, 20, 23, 33,
990     29, 33, 20,  1, 19,  1, 29, 36,  9, 36, 19, 41, 28, 57, 32,  3,
991     28,  3,  1, 27, 49, 49,  1, 32, 26, 26,  2,  4,  4,  7, 57, 41,
992      2,  7, 10,  5, 37, 16, 10, 27,  8,  8, 13, 16, 37, 13,  1,  5},
993
994     /* value table */
995     {0,   1,  -1,   1,  -1,   1,  -1,   1,  -1,   1,  -1,   1,   1,  -1,  -1,   1,
996     -1,   1,  -1,   1,  -1,   1,  -1,   2,   1,  -2,  -1,   1,  -1,   1,   1,  -1,
997     -1,   1,  -1,   1,  -1,   1,   0,  -1,   1,   1,   1,  -1,   1,  -1,  -1,  -1,
998      1,   1,   2,  -1,  -1,   1,  -1,  -2,   1,   1,  -1,  -1,   1,   1,  -1,  -1,
999      1,  -1,   3,   1,  -3,   2,  -1,   1,   1,  -2,  -1,  -1,  -1,   1,   1,   1,
1000      1,   1,  -1,  -1,  -1,   2,  -1,  -2,   1,   2,  -2,  -1,   1,   1,   2,  -1,
1001     -1,   1,  -2,  -1,   1,   1,  -1,   2,   1,   2,  -1,   1,  -2,  -1,  -2,  -1,
1002     -1,   1,   1,  -1,   1,  -1,   1,   1,   1,  -1,  -1,   1,   4,  -1,  -1,  -4,
1003      1,   1,   1,   2,  -1,  -1,   1,  -1,  -1,   1,  -1,  -1,   1,  -2,   1,  -1,
1004      1,   1,  -1,  -1,   1,   1,  -1,  -1,   3,   2,  -3,  -2,   2,   5,  -2,   2,
1005      2,  -5,  -2,  -2,  -2,   2,  -3,   3,   2,   3,  -3,   2,  -2,  -2,   3,  -3,
1006      6,   2,  -2,   3,  -6,   3,  -3,  -3,   3,   7,  -4,   4,  -3,   2,  -7,   2,
1007      2,  -2,  -4,   2,   8,  -2,  -2,  -2,   4,   2,  -2,   2,   3,   2,  -2,  -2,
1008      2,   2,  -2,  -8,  -2,   9,  -2,   2,  -3,  -2,   2,  -2,   2,   2,   2,   4,
1009     -2,  -4,  10,   2,   2,  -2,  -9,  -2,   2,  -2,   5,   4,  -4,   4,  -2,   2,
1010     -5,  -4,  -3,   4,   2,  -3,   3,  -2,  -5,   5,   3,   3,  -2,  -3, -10,  -4}
1011 },{
1012     /* MapTab2 */
1013     2,  /* eob_sym */
1014     11, /* esc_sym */
1015     /* run table */
1016     {1,  1,  0,  2,  2,  1,  1,  3,  3,  4,  4,  0,  1,  1,  5,  5,
1017      2,  2,  6,  6,  7,  7,  1,  8,  1,  8,  3,  3,  9,  9,  1,  2,
1018      2,  1,  4, 10,  4, 10, 11, 11,  1,  5, 12, 12,  1,  5, 13, 13,
1019      3,  3,  6,  6,  2,  2, 14, 14, 16, 16, 15,  7, 15,  8,  8,  7,
1020      1,  1, 17, 17,  4,  4,  1,  1, 18, 18,  2,  2,  5,  5, 25,  3,
1021      9,  3, 25,  9, 19, 24, 19, 24,  1, 21, 20,  1, 21, 22, 20, 22,
1022     23, 23,  8,  6, 33,  6,  8, 33,  7,  7, 26, 26,  1, 32,  1, 32,
1023     28,  4, 28, 10, 29, 27, 27, 10, 41,  4, 29,  2,  2, 41, 36, 31,
1024     49, 31, 34, 30, 34, 36, 30, 35,  1, 49, 11,  5, 35, 11,  1,  3,
1025      3,  5, 37, 37,  8, 40,  8, 40, 12, 12, 42, 42,  1, 38, 16, 57,
1026      1,  6, 16, 39, 38,  6,  7,  7, 13, 13, 39, 43,  2, 43, 57,  2,
1027     50,  9, 44,  9, 50,  4, 15, 48, 44,  4,  1, 15, 48, 14, 14,  1,
1028     45, 45,  8,  3,  5,  8, 51, 47,  3, 46, 46, 47,  5, 51,  1, 17,
1029     17, 58,  1, 58,  2, 52, 52,  2, 53,  7, 59,  6,  6, 56, 53, 55,
1030      7, 55,  1, 54, 59, 56, 54, 10,  1, 10,  4, 60,  1, 60,  8,  4,
1031      8, 64, 64, 61,  1, 63,  3, 63, 62, 61,  5, 11,  5,  3, 11, 62},
1032
1033     /* value table */
1034     { 1,  -1,   0,   1,  -1,   2,  -2,   1,  -1,   1,  -1,   0,   3,  -3,   1,  -1,
1035       2,  -2,   1,  -1,   1,  -1,   4,   1,  -4,  -1,   2,  -2,   1,  -1,   5,   3,
1036      -3,  -5,   2,   1,  -2,  -1,   1,  -1,   6,   2,   1,  -1,  -6,  -2,   1,  -1,
1037       3,  -3,   2,  -2,   4,  -4,   1,  -1,   1,  -1,   1,   2,  -1,   2,  -2,  -2,
1038       7,  -7,   1,  -1,   3,  -3,   8,  -8,   1,  -1,   5,  -5,   3,  -3,   1,   4,
1039       2,  -4,  -1,  -2,   1,   1,  -1,  -1,   9,   1,   1,  -9,  -1,   1,  -1,  -1,
1040       1,  -1,   3,  -3,   1,   3,  -3,  -1,   3,  -3,   1,  -1,  10,   1, -10,  -1,
1041       1,   4,  -1,   2,   1,  -1,   1,  -2,   1,  -4,  -1,   6,  -6,  -1,   1,   1,
1042       1,  -1,   1,   1,  -1,  -1,  -1,   1,  11,  -1,  -2,   4,  -1,   2, -11,   5,
1043      -5,  -4,  -1,   1,   4,   1,  -4,  -1,  -2,   2,   1,  -1,  12,   1,  -2,   1,
1044     -12,   4,   2,   1,  -1,  -4,   4,  -4,   2,  -2,  -1,   1,   7,  -1,  -1,  -7,
1045      -1,  -3,   1,   3,   1,   5,   2,   1,  -1,  -5,  13,  -2,  -1,   2,  -2, -13,
1046       1,  -1,   5,   6,   5,  -5,   1,   1,  -6,   1,  -1,  -1,  -5,  -1,  14,   2,
1047      -2,   1, -14,  -1,   8,   1,  -1,  -8,   1,   5,   1,   5,  -5,   1,  -1,   1,
1048      -5,  -1,  15,   1,  -1,  -1,  -1,   3, -15,  -3,   6,   1,  16,  -1,   6,  -6,
1049      -6,   1,  -1,   1, -16,   1,   7,  -1,   1,  -1,  -6,  -3,   6,  -7,   3,  -1}
1050 },{
1051     /* MapTab3 */
1052     0,  /* eob_sym */
1053     35, /* esc_sym */
1054     /* run table */
1055     {0,  1,  1,  2,  2,  3,  3,  4,  4,  1,  1,  5,  5,  6,  6,  7,
1056      7,  8,  8,  9,  9,  2,  2, 10, 10,  1,  1, 11, 11, 12, 12,  3,
1057      3, 13, 13,  0, 14, 14, 16, 15, 16, 15,  4,  4, 17,  1, 17,  1,
1058      5,  5, 18, 18,  2,  2,  6,  6,  8, 19,  7,  8,  7, 19, 20, 20,
1059     21, 21, 22, 24, 22, 24, 23, 23,  1,  1, 25, 25,  3,  3, 26, 26,
1060      9,  9, 27, 27, 28, 28, 33, 29,  4, 33, 29,  1,  4,  1, 32, 32,
1061      2,  2, 31, 10, 30, 10, 30, 31, 34, 34,  5,  5, 36, 36, 35, 41,
1062     35, 11, 41, 11, 37,  1,  8,  8, 37,  6,  1,  6, 40,  7,  7, 40,
1063     12, 38, 12, 39, 39, 38, 49, 13, 49, 13,  3, 42,  3, 42, 16, 16,
1064     43, 43, 14, 14,  1,  1, 44, 15, 44, 15,  2,  2, 57, 48, 50, 48,
1065     57, 50,  4, 45, 45,  4, 46, 47, 47, 46,  1, 51,  1, 17, 17, 51,
1066      8,  9,  9,  5, 58,  8, 58,  5, 52, 52, 55, 56, 53, 56, 55, 59,
1067     59, 53, 54,  1,  6, 54,  7,  7,  6,  1,  2,  3,  2,  3, 64, 60,
1068     60, 10, 10, 64, 61, 62, 61, 63,  1, 63, 62,  1, 18, 24, 18,  4,
1069     25,  4,  8, 21, 21,  1, 24, 22, 25, 22,  8, 11, 19, 11, 23,  1,
1070     20, 23, 19, 20,  5, 12,  5,  1, 16,  2, 12, 13,  2, 13,  1, 16},
1071
1072     /* value table */
1073     { 0,   1,  -1,   1,  -1,   1,  -1,   1,  -1,   2,  -2,   1,  -1,   1,  -1,   1,
1074      -1,   1,  -1,   1,  -1,   2,  -2,   1,  -1,   3,  -3,   1,  -1,   1,  -1,   2,
1075      -2,   1,  -1,   0,   1,  -1,   1,   1,  -1,  -1,   2,  -2,   1,   4,  -1,  -4,
1076       2,  -2,   1,  -1,  -3,   3,   2,  -2,   2,   1,   2,  -2,  -2,  -1,   1,  -1,
1077       1,  -1,   1,   1,  -1,  -1,   1,  -1,   5,  -5,   1,  -1,   3,  -3,   1,  -1,
1078       2,  -2,   1,  -1,   1,  -1,   1,   1,   3,  -1,  -1,   6,  -3,  -6,  -1,   1,
1079       4,  -4,   1,   2,   1,  -2,  -1,  -1,   1,  -1,   3,  -3,   1,  -1,   1,   1,
1080      -1,   2,  -1,  -2,   1,   7,  -3,   3,  -1,   3,  -7,  -3,   1,  -3,   3,  -1,
1081       2,   1,  -2,   1,  -1,  -1,   1,   2,  -1,  -2,  -4,  -1,   4,   1,   2,  -2,
1082       1,  -1,  -2,   2,   8,  -8,  -1,   2,   1,  -2,  -5,   5,   1,  -1,  -1,   1,
1083      -1,   1,   4,  -1,   1,  -4,  -1,  -1,   1,   1,   9,   1,  -9,   2,  -2,  -1,
1084      -4,   3,  -3,  -4,  -1,   4,   1,   4,   1,  -1,   1,  -1,   1,   1,  -1,   1,
1085      -1,  -1,  -1,  10,   4,   1,   4,  -4,  -4, -10,   6,   5,  -6,  -5,   1,  -1,
1086       1,   3,  -3,  -1,   1,  -1,  -1,  -1,  11,   1,   1, -11,  -2,  -2,   2,   5,
1087      -2,  -5,  -5,   2,  -2,  12,   2,  -2,   2,   2,   5,  -3,  -2,   3,  -2, -12,
1088      -2,   2,   2,   2,  -5,   3,   5,  13,  -3,   7,  -3,  -3,  -7,   3, -13,   3}
1089 },{
1090     /* MapTab4 */
1091     0,  /* eob_sym */
1092     34, /* esc_sym */
1093     /* run table */
1094     {0,  1,  1,  1,  2,  2,  1,  3,  3,  1,  1,  1,  4,  4,  1,  5,
1095      2,  1,  5,  2,  1,  1,  6,  6,  1,  1,  1,  1,  1,  7,  3,  1,
1096      2,  3,  0,  1,  2,  7,  1,  1,  1,  8,  1,  1,  8,  1,  1,  1,
1097      9,  1,  9,  1,  2,  1,  1,  2,  1,  1, 10,  4,  1, 10,  1,  4,
1098      1,  1,  1,  1,  1,  3,  1,  1,  1,  3,  2,  1,  5,  1,  1,  1,
1099      2,  5,  1, 11,  1, 11,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
1100      2,  1,  6,  1,  6,  1,  1,  2,  1,  1,  1,  1,  1,  1,  1, 12,
1101      3,  1, 12,  1,  1,  1,  2,  1,  1,  3,  1,  1,  1,  1,  1,  1,
1102      4,  1,  1,  1,  2,  1,  1,  4,  1,  1,  1,  1,  1,  1,  2,  1,
1103      1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  3,  1,  2,  1,  1,  5,
1104      1,  1,  1,  1,  1,  7,  1,  7,  1,  1,  2,  3,  1,  1,  1,  1,
1105      5,  1,  1,  1,  1,  1,  1,  2, 13,  1,  1,  1,  1,  1,  1,  1,
1106      1,  1,  1,  1,  1,  1,  1,  1, 13,  2,  1,  1,  4,  1,  1,  1,
1107      3,  1,  6,  1,  1,  1, 14,  1,  1,  1,  1,  1, 14,  6,  1,  1,
1108      1,  1, 15,  2,  4,  1,  2,  3, 15,  1,  1,  1,  8,  1,  1,  8,
1109      1,  1,  1,  1,  1,  1,  1,  1,  2,  1,  1,  1,  1,  1,  1,  1},
1110
1111     /* value table */
1112     { 0,   1,  -1,   2,   1,  -1,  -2,   1,  -1,   3,  -3,   4,   1,  -1,  -4,   1,
1113       2,   5,  -1,  -2,  -5,   6,   1,  -1,  -6,   7,  -7,   8,  -8,   1,   2,   9,
1114       3,  -2,   0,  -9,  -3,  -1,  10, -10,  11,   1, -11,  12,  -1, -12,  13, -13,
1115       1,  14,  -1, -14,   4,  15, -15,  -4,  16, -16,   1,   2,  17,  -1, -17,  -2,
1116      18, -18,  19, -19,  20,   3, -20,  21, -21,  -3,   5,  22,   2, -22, -23,  23,
1117      -5,  -2,  24,   1, -24,  -1,  25, -25,  26, -26, -27,  27,  28,  29, -28, -29,
1118       6,  30,   2, -31,  -2, -30,  31,  -6, -32,  32,  33, -33,  34, -35, -34,   1,
1119       4, -36,  -1,  35,  37,  36,   7, -37,  38,  -4, -38,  39,  41,  40, -40, -39,
1120       3,  42, -43, -41,  -7, -42,  43,  -3,  44, -44,  45, -45,  46,  47,   8, -47,
1121     -48, -46,  50, -50,  48,  49,  51, -49,  52, -52,   5, -51,  -8, -53,  53,   3,
1122     -56,  56,  55,  54, -54,   2,  60,  -2, -55,  58,   9,  -5,  59,  57, -57, -63,
1123      -3, -58, -60, -61,  61, -59, -62,  -9,   1,  64,  62,  69, -64,  63,  65, -67,
1124     -68,  66, -65,  68, -66, -69,  67, -70,  -1,  10,  71, -71,   4,  73,  72,  70,
1125       6, -76,  -3,  74, -78, -74,   1,  78,  80, -72, -75,  76,  -1,   3, -73,  79,
1126      75,  77,   1,  11,  -4, -79, -10,  -6,  -1, -77, -83, -80,   2,  81, -84,  -2,
1127      83, -81,  82, -82,  84, -87, -86,  85, -11, -85,  86, -89,  87, -88,  88,  89}
1128 },{
1129     /* MapTab5 */
1130     2,  /* eob_sym */
1131     33, /* esc_sym */
1132     /* run table */
1133     {1,  1,  0,  2,  1,  2,  1,  3,  3,  1,  1,  4,  4,  2,  2,  1,
1134      1,  5,  5,  6,  1,  6,  1,  7,  7,  3,  3,  2,  8,  2,  8,  1,
1135      1,  0,  9,  9,  1,  1, 10,  4, 10,  4, 11, 11,  2,  1,  2,  1,
1136     12, 12,  3,  3,  1,  1, 13,  5,  5, 13, 14,  1,  1, 14,  2,  2,
1137      6,  6, 15,  1,  1, 15, 16,  4,  7, 16,  4,  7,  1,  1,  3,  3,
1138      8,  8,  2,  2,  1,  1, 17, 17,  1,  1, 18, 18,  5,  5,  2,  2,
1139      1,  1,  9, 19,  9, 19, 20,  3,  3, 20,  1, 10, 21,  1, 10,  4,
1140      4, 21, 22,  6,  6, 22,  1,  1, 23, 24,  2,  2, 23, 24, 11,  1,
1141      1, 11,  7, 25,  7,  1,  1, 25,  8,  8,  3, 26,  3,  1, 12,  2,
1142      2, 26,  1, 12,  5,  5, 27,  4,  1,  4,  1, 27, 28,  1, 28, 13,
1143      1, 13,  2, 29,  2,  1, 32,  6,  1, 30, 14, 29, 14,  6,  3, 31,
1144      3,  1, 30,  1, 32, 31, 33,  9, 33,  1,  1,  7,  9,  7,  2,  2,
1145      1,  1,  4, 36, 34,  4,  5, 10, 10,  5, 34,  1,  1, 35,  8,  8,
1146     36,  3, 35,  1, 15,  3,  2,  1, 16, 15, 16,  2, 37,  1, 37,  1,
1147      1,  1,  6,  6, 38,  1, 38, 11,  1, 39, 39, 40, 11,  2, 41,  4,
1148     40,  1,  2,  4,  1,  1,  1, 41,  3,  1,  3,  1,  5,  7,  5,  7},
1149
1150     /* value table */
1151     { 1,  -1,   0,   1,   2,  -1,  -2,   1,  -1,   3,  -3,   1,  -1,   2,  -2,   4,
1152      -4,   1,  -1,   1,   5,  -1,  -5,   1,  -1,   2,  -2,   3,   1,  -3,  -1,   6,
1153      -6,   0,   1,  -1,   7,  -7,   1,   2,  -1,  -2,   1,  -1,   4,   8,  -4,  -8,
1154       1,  -1,   3,  -3,   9,  -9,   1,   2,  -2,  -1,   1,  10, -10,  -1,   5,  -5,
1155       2,  -2,   1,  11, -11,  -1,   1,   3,   2,  -1,  -3,  -2,  12, -12,   4,  -4,
1156       2,  -2,  -6,   6,  13, -13,   1,  -1,  14, -14,   1,  -1,   3,  -3,   7,  -7,
1157      15, -15,   2,   1,  -2,  -1,   1,   5,  -5,  -1, -16,   2,   1,  16,  -2,   4,
1158      -4,  -1,   1,   3,  -3,  -1,  17, -17,   1,   1,  -8,   8,  -1,  -1,   2,  18,
1159     -18,  -2,   3,   1,  -3,  19, -19,  -1,   3,  -3,   6,   1,  -6,  20,   2,   9,
1160      -9,  -1, -20,  -2,   4,  -4,   1,  -5,  21,   5, -21,  -1,   1, -22,  -1,   2,
1161      22,  -2,  10,   1, -10,  23,   1,   4, -23,   1,   2,  -1,  -2,  -4,  -7,   1,
1162       7, -24,  -1,  24,  -1,  -1,   1,   3,  -1, -25,  25,   4,  -3,  -4,  11, -11,
1163      26, -26,   6,   1,   1,  -6,  -5,  -3,   3,   5,  -1, -27,  27,   1,   4,  -4,
1164      -1,  -8,  -1,  28,   2,   8, -12, -28,  -2,  -2,   2,  12,  -1,  29,   1, -29,
1165      30, -30,   5,  -5,   1, -31,  -1,   3,  31,  -1,   1,   1,  -3, -13,   1,  -7,
1166      -1, -32,  13,   7,  32,  33, -33,  -1,  -9, -34,   9,  34,  -6,   5,   6,  -5}
1167 },{
1168     /* MapTab6 */
1169     2,  /* eob_sym */
1170     13, /* esc_sym */
1171     /* run table */
1172     {1,  1,  0,  1,  1,  2,  2,  1,  1,  3,  3,  1,  1,  0,  2,  2,
1173      4,  1,  4,  1,  1,  1,  5,  5,  1,  1,  6,  6,  2,  2,  1,  1,
1174      3,  3,  7,  7,  1,  1,  8,  8,  1,  1,  2,  2,  1,  9,  1,  9,
1175      4,  4, 10,  1,  1, 10,  1,  1, 11, 11,  3,  3,  1,  2,  1,  2,
1176      1,  1, 12, 12,  5,  5,  1,  1, 13,  1,  1, 13,  2,  2,  1,  1,
1177      6,  6,  1,  1,  4, 14,  4, 14,  3,  1,  3,  1,  1,  1, 15,  7,
1178     15,  2,  2,  7,  1,  1,  1,  8,  1,  8, 16, 16,  1,  1,  1,  1,
1179      2,  1,  1,  2,  1,  1,  3,  5,  5,  3,  4,  1,  1,  4,  1,  1,
1180     17, 17,  9,  1,  1,  9,  2,  2,  1,  1, 10, 10,  1,  6,  1,  1,
1181      6, 18,  1,  1, 18,  1,  1,  1,  2,  2,  3,  1,  3,  1,  1,  1,
1182      4,  1, 19,  1, 19,  7,  1,  1, 20,  1,  4, 20,  1,  7, 11,  2,
1183      1, 11, 21,  2,  8,  5,  1,  8,  1,  5, 21,  1,  1,  1, 22,  1,
1184      1, 22,  1,  1,  3,  3,  1, 23,  2, 12, 24,  1,  1,  2,  1,  1,
1185     12, 23,  1,  1, 24,  1,  1,  1,  4,  1,  1,  1,  2,  1,  6,  6,
1186      4,  2,  1,  1,  1,  1,  1,  1,  1, 14, 13,  3,  1, 25,  9, 25,
1187     14,  1,  9,  3, 13,  1,  1,  1,  1,  1, 10,  1,  1,  2, 10,  2},
1188
1189     /* value table */
1190     {-20,  -1,   0,   2,  -2,   1,  -1,   3,  -3,   1,  -1,   4,  -4,   0,   2,  -2,
1191        1,   5,  -1,  -5,   6,  -6,   1,  -1,   7,  -7,   1,  -1,   3,  -3,   8,  -8,
1192        2,  -2,   1,  -1,   9,  -9,   1,  -1,  10, -10,   4,  -4,  11,   1, -11,  -1,
1193        2,  -2,   1,  12, -12,  -1,  13, -13,   1,  -1,   3,  -3,  14,   5, -14,  -5,
1194      -15,  15,  -1,   1,   2,  -2,  16, -16,   1,  17, -17,  -1,   6,  -6,  18, -18,
1195        2,  -2, -19,  19,  -3,   1,   3,  -1,   4,  20,  -4,   1, -21,  21,   1,   2,
1196       -1,  -7,   7,  -2,  22, -22,  23,   2, -23,  -2,   1,  -1, -24,  24, -25,  25,
1197       -8, -26,  26,   8, -27,  27,   5,   3,  -3,  -5,  -4,  28, -28,   4,  29, -29,
1198        1,  -1,  -2, -30,  30,   2,   9,  -9, -31,  31,   2,  -2, -32,   3,  32, -33,
1199       -3,   1,  33, -34,  -1,  34, -35,  35, -10,  10,  -6,  36,   6, -36,  37, -37,
1200       -5,  38,   1, -38,  -1,   3,  39, -39,  -1,  40,   5,   1, -40,  -3,   2, -11,
1201      -41,  -2,   1,  11,  -3,  -4,  41,   3,  42,   4,  -1, -43, -42,  43,   1, -44,
1202       45,  -1,  44, -45,  -7,   7, -46,   1, -12,   2,   1, -47,  46,  12,  47,  48,
1203       -2,  -1, -48,  49,  -1, -50, -49,  50,  -6, -51,  51,  52, -13,  53,  -4,   4,
1204        6,  13, -53, -52, -54,  55,  54, -55, -56,  -2,   2,  -8,  56,   1,  -3,  -1,
1205        2,  58,   3,   8,  -2,  57, -58, -60, -59, -57,  -3,  60,  59, -14,   3,  14}
1206 },{
1207     /* MapTab7 */
1208     2,  /* eob_sym */
1209     38, /* esc_sym */
1210     /* run table */
1211     {1,  1,  0,  2,  2,  1,  1,  3,  3,  4,  4,  5,  5,  1,  1,  6,
1212      6,  2,  2,  7,  7,  8,  8,  1,  1,  3,  3,  9,  9, 10, 10,  1,
1213      1,  2,  2,  4,  4, 11,  0, 11, 12, 12, 13, 13,  1,  1,  5,  5,
1214     14, 14, 15, 16, 15, 16,  3,  3,  1,  6,  1,  6,  2,  2,  7,  7,
1215      8,  8, 17, 17,  1,  1,  4,  4, 18, 18,  2,  2,  1, 19,  1, 20,
1216     19, 20, 21, 21,  3,  3, 22, 22,  5,  5, 24,  1,  1, 23,  9, 23,
1217     24,  9,  2,  2, 10,  1,  1, 10,  6,  6, 25,  4,  4, 25,  7,  7,
1218     26,  8,  1,  8,  3,  1, 26,  3, 11, 11, 27, 27,  2, 28,  1,  2,
1219     28,  1, 12, 12,  5,  5, 29, 13, 13, 29, 32,  1,  1, 33, 31, 30,
1220     32,  4, 30, 33,  4, 31,  3, 14,  1,  1,  3, 34, 34,  2,  2, 14,
1221      6,  6, 35, 36, 35, 36,  1, 15,  1, 16, 16, 15,  7,  9,  7,  9,
1222     37,  8,  8, 37,  1,  1, 39,  2, 38, 39,  2, 40,  5, 38, 40,  5,
1223      3,  3,  4,  4, 10, 10,  1,  1,  1,  1, 41,  2, 41,  2,  6,  6,
1224      1,  1, 11, 42, 11, 43,  3, 42,  3, 17,  4, 43,  1, 17,  7,  1,
1225      8, 44,  4,  7, 44,  5,  8,  2,  5,  1,  2, 48, 45,  1, 12, 45,
1226     12, 48, 13, 13,  1,  9,  9, 46,  1, 46, 47, 47, 49, 18, 18, 49},
1227
1228     /* value table */
1229     { 1,  -1,   0,   1,  -1,   2,  -2,   1,  -1,   1,  -1,   1,  -1,   3,  -3,   1,
1230      -1,  -2,   2,   1,  -1,   1,  -1,   4,  -4,  -2,   2,   1,  -1,   1,  -1,   5,
1231      -5,  -3,   3,   2,  -2,   1,   0,  -1,   1,  -1,   1,  -1,   6,  -6,   2,  -2,
1232       1,  -1,   1,   1,  -1,  -1,  -3,   3,   7,   2,  -7,  -2,  -4,   4,   2,  -2,
1233       2,  -2,   1,  -1,   8,  -8,   3,  -3,   1,  -1,  -5,   5,   9,   1,  -9,   1,
1234      -1,  -1,   1,  -1,  -4,   4,   1,  -1,   3,  -3,   1, -10,  10,   1,   2,  -1,
1235      -1,  -2,   6,  -6,   2,  11, -11,  -2,   3,  -3,   1,  -4,   4,  -1,   3,  -3,
1236       1,   3,  12,  -3,  -5, -12,  -1,   5,   2,  -2,   1,  -1,  -7,   1,  13,   7,
1237      -1, -13,   2,  -2,   4,  -4,   1,   2,  -2,  -1,   1,  14, -14,   1,   1,   1,
1238      -1,  -5,  -1,  -1,   5,  -1,  -6,   2, -15,  15,   6,   1,  -1,  -8,   8,  -2,
1239      -4,   4,   1,   1,  -1,  -1,  16,   2, -16,  -2,   2,  -2,   4,   3,  -4,  -3,
1240      -1,  -4,   4,   1, -17,  17,  -1,  -9,   1,   1,   9,   1,  -5,  -1,  -1,   5,
1241      -7,   7,   6,  -6,   3,  -3,  18, -18,  19, -19,   1, -10,  -1,  10,  -5,   5,
1242      20, -20,  -3,   1,   3,   1,   8,  -1,  -8,   2,   7,  -1, -21,  -2,   5,  21,
1243       5,  -1,  -7,  -5,   1,  -6,  -5, -11,   6,  22,  11,   1,   1, -22,  -3,  -1,
1244       3,  -1,   3,  -3, -23,   4,  -4,   1,  23,  -1,   1,  -1,   1,  -2,   2,  -1}
1245 },{
1246     /* MapTab8 */
1247     4,  /* eob_sym */
1248     11, /* esc_sym */
1249     /* run table */
1250     {1,  1,  1,  1,  0,  2,  2,  1,  1,  3,  3,  0,  1,  1,  2,  2,
1251      4,  4,  1,  1,  5,  5,  1,  1,  2,  2,  3,  3,  6,  6,  1,  1,
1252      7,  7,  8,  1,  8,  2,  2,  1,  4,  4,  1,  3,  1,  3,  9,  9,
1253      2,  2,  1,  5,  1,  5, 10, 10,  1,  1, 11, 11,  3,  6,  3,  4,
1254      4,  6,  2,  2,  1, 12,  1, 12,  7, 13,  7, 13,  1,  1,  8,  8,
1255      2,  2, 14, 14, 16, 15, 16,  5,  5,  1,  3, 15,  1,  3,  4,  4,
1256      1,  1, 17, 17,  2,  2,  6,  6,  1, 18,  1, 18, 22, 21, 22, 21,
1257     25, 24, 25, 19,  9, 20,  9, 23, 19, 24, 20,  3, 23,  7,  3,  1,
1258      1,  7, 28, 26, 29,  5, 28, 26,  5,  8, 29,  4,  8, 27,  2,  2,
1259      4, 27,  1,  1, 10, 36, 10, 33, 33, 36, 30,  1, 32, 32,  1, 30,
1260      6, 31, 31, 35,  3,  6, 11, 11,  3,  2, 35,  2, 34,  1, 34,  1,
1261     37, 37, 12,  7, 12,  5, 41,  5,  4,  7,  1,  8, 13,  4,  1, 41,
1262     13, 38,  8, 38,  9,  1, 40, 40,  9,  1, 39,  2,  2, 49, 39, 42,
1263      3,  3, 14, 16, 49, 14, 16, 42, 43, 43,  6,  6, 15,  1,  1, 15,
1264     44, 44,  1,  1, 50, 48,  4,  5,  4,  7,  5,  2, 10, 10, 48,  7,
1265     50, 45,  2,  1, 45,  8,  8,  1, 46, 46,  3, 47, 47,  3,  1,  1},
1266
1267     /* value table */
1268     { 1,  -1,   2,  -2,   0,   1,  -1,   3,  -3,   1,  -1,   0,   4,  -4,   2,  -2,
1269       1,  -1,   5,  -5,   1,  -1,   6,  -6,   3,  -3,   2,  -2,   1,  -1,   7,  -7,
1270       1,  -1,   1,   8,  -1,   4,  -4,  -8,   2,  -2,   9,   3,  -9,  -3,   1,  -1,
1271       5,  -5,  10,   2, -10,  -2,   1,  -1,  11, -11,   1,  -1,  -4,   2,   4,   3,
1272      -3,  -2,   6,  -6,  12,   1, -12,  -1,   2,   1,  -2,  -1,  13, -13,   2,  -2,
1273       7,  -7,   1,  -1,   1,   1,  -1,   3,  -3,  14,   5,  -1, -14,  -5,   4,  -4,
1274      15, -15,   1,  -1,   8,  -8,  -3,   3,  16,   1, -16,  -1,   1,   1,  -1,  -1,
1275       1,   1,  -1,   1,   2,   1,  -2,   1,  -1,  -1,  -1,   6,  -1,   3,  -6,  17,
1276     -17,  -3,   1,   1,   1,   4,  -1,  -1,  -4,   3,  -1,   5,  -3,  -1,  -9,   9,
1277      -5,   1,  18, -18,   2,   1,  -2,   1,  -1,  -1,   1,  19,  -1,   1, -19,  -1,
1278       4,   1,  -1,   1,   7,  -4,  -2,   2,  -7,  10,  -1, -10,   1,  20,  -1, -20,
1279       1,  -1,   2,   4,  -2,   5,   1,  -5,   6,  -4,  21,   4,   2,  -6, -21,  -1,
1280      -2,   1,  -4,  -1,  -3,  22,  -1,   1,   3, -22,  -1,  11, -11,   1,   1,   1,
1281       8,  -8,   2,   2,  -1,  -2,  -2,  -1,   1,  -1,  -5,   5,   2,  23, -23,  -2,
1282       1,  -1,  24, -24,  -1,  -1,   7,   6,  -7,   5,  -6,  12,  -3,   3,   1,  -5,
1283       1,   1, -12,  25,  -1,  -5,   5, -25,  -1,   1,   9,   1,  -1,  -9,  26, -26}
1284 }
1285 };