www.pudn.com > av3dec_20050318.zip > sam_HuffmanDec.c
/* *********************************************************************** * COPYRIGHT AND WARRANTY INFORMATION * * Copyright 2004, Audio Video Coding Standard, Part III * * This software module was originally developed by * * JungHoe Kim (kjh94@samsung.com), Samsung AIT * * edited by * * Lei Miao (win.miaolei@samsung.com), Samsung AIT * * DISCLAIMER OF WARRANTY * * These software programs are available to the users without any * license fee or royalty on an "as is" basis. The AVS disclaims * any and all warranties, whether express, implied, or statutory, * including any implied warranties of merchantability or of fitness * for a particular purpose. In no event shall the contributors or * the AVS be liable for any incidental, punitive, or consequential * damages of any kind whatsoever arising from the use of this program. * * This disclaimer of warranty extends to the user of this program * and user's customers, employees, agents, transferees, successors, * and assigns. * * The AVS does not represent or warrant that the program furnished * hereunder are free of infringement of any third-party patents. * Commercial implementations of AVS, including shareware, may be * subject to royalty fees to patent holders. Information regarding * the AVS patent policy is available from the AVS Web site at * http://www.avs.org.cn * * THIS IS NOT A GRANT OF PATENT RIGHTS - SEE THE AVS PATENT POLICY. ************************************************************************ */ #include#include unsigned int codeBookBin[2]; unsigned int codeBookLenBin[2]; int siCodeMode; void BSHCDecInit(void); int BSHCDecHuff(unsigned int *table,unsigned int *len,int range,int *decData); int BSHCModelSelect(int model,int bpl); void BSHCDecInit(void) { codeBookBin[0] = 0; codeBookBin[1] = 1; codeBookLenBin[0] = 1; codeBookLenBin[1] = 1; } int BSHCDecHuff(unsigned int *table,unsigned int *len,int range,int *decData) { int i,j; unsigned int val; int bitCnt; val = getbitsfrombuf(1); bitCnt=1; for(j=1;j<32;j++) /*max length for HUFF is 32*/ { for(i=0;i 4) { modelNum = 20+bpl; } return modelNum; }