/* * Java port of parts of the ffmpeg Mpeg4 base decoder. * Copyright (c) 2003 Jonathan Hueber. * * Copyright (c) 2001 Fabrice Bellard. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * See Credits file and Readme for details */ package net.sourceforge.jffmpeg.codecs.video.mpeg4.mp42.v2tables; import net.sourceforge.jffmpeg.codecs.utils.VLCTable; /** * non intra picture macro block coded block pattern + mb type */ public class V2DiscreteCosineChrominance extends VLCTable { public V2DiscreteCosineChrominance() { vlcCodes = new long[ 512 ][ 2 ]; long[][] h263ChromCodes = new long[][] { {3,2}, {2,2}, {1,2}, {1,3}, {1,4}, {1,5}, {1,6}, {1,7}, {1,8}, {1,9}, {1,10}, {1,11}, {1,12}, }; for ( int level = -256; level < 256; level++ ) { /* Get size in bits */ int size = 0; int v = (level < 0) ? -level : level; while ( v != 0 ) { v >>= 1; size++; } int l = (level < 0) ? (-level)^((1 << size) - 1) : level; long uni_code = h263ChromCodes[ size ][0]; long uni_len = h263ChromCodes[ size ][1]; /* Munge */ uni_code ^= (1 << uni_len) - 1; if ( size > 0 ) { uni_code <<= size; uni_code |= l; uni_len += size; if ( size > 8 ) { uni_code <<= 1; uni_code |= 1; uni_len++; } } vlcCodes[ level + 256 ][ 0 ] = uni_code; vlcCodes[ level + 256 ][ 1 ] = uni_len; } createHighSpeedTable(); } }