亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? aricacm.c

?? ezw程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
/* $Copyright Issue
 * ----------------
 * Most of the code on arithemtic coding are modified from 
 * I.H. Witten, R.M. Neal, and J.G. Cleary, "Arithmetic coding for data
 * compression," Communnication ACM, vol 30, pp. 520-540, June 1987.
 *
 * The statistical table is implemented using Binary Index Tree as described in
 * P. M. Fenwick, "A new data structure for cumulative frequency tables,"
 * Softw. Pract. Exper. 24, 3 (Mar. 1994), 327-336.
 *
 * The idea of having the arithemetic coder to read/write bits directly was
 * from G. Davis code in "Wavelet Compression Construction Kit". His code
 * can only do write but has problem with synchronisation when doing read.
 * I fixed that with a virtual table approach.
 *
 * Mow-Song, Ng 2/9/2002
 * msng@mmu.edu.my
 * http://www.pesona.mmu.edu.my/~msng
 *
 * I do not claim copyright to the code, but if you use them or modify them,
 * please drop me a mail.
 *
 */
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/

#include "aricacm.h"

//#define __F_SCALE_

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
/* Source context */
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
Context *ContextAlloc(void)
{
	Context *context;

	if((context=(Context *)malloc(sizeof(Context)))==NULL){
		return NULL;
	}
	context->Tree=NULL;
	context->nSymbols=0;
	context->TotalFreq=0;
	context->p2half=0;
	context->MaxCount = 0;
	
	return context;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
int ContextInitialize(Context *context, int nSymbols, int MaxCount, int set)
{
	int i;

	context->nSymbols=nSymbols;
   context->TotalFreq=0;

	i=1;
	while(context->nSymbols > i){
		i<<=1;
	}
	context->p2half=i>>1;

	if (context->Tree!=NULL){
		free(context->Tree);
	}

   if ((context->Tree = (int *)calloc(context->nSymbols, sizeof(int)))==NULL){
      free(context);
      return 0;
   }

	if (set==1){
		for (i=0; i<context->nSymbols; i++){
			ContextPutValue(context, 1, i);
		}
	}

	context->MaxCount = MaxCount;

   return 1;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ContextDealloc(Context *context)
{
	if (context!=NULL){
		free(context->Tree);
		free(context);
	}
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
int ContextGetCumul(Context *context, int ix)
{
   unsigned int sum;

	if (ix<0){
		return 0;
	}

	sum = context->Tree[0];

   while(ix>0){
      sum = sum+context->Tree[ix];
      ix = ix & (ix-1);		
   }

   return sum;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ContextPutValue(Context *context, int val, int ix)
{
	assert(ix>=0);

	if (ix==0){
		context->Tree[0]+=val;
	}
	else{
		while(ix < context->nSymbols){
			context->Tree[ix] = context->Tree[ix] + val;
			ix = 2*ix - (ix & (ix-1));
		}
	}

   context->TotalFreq+=val;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
int ContextGetProb(Context *context, int ix)
{
   int val, parent;

	assert(ix>=0 && ix<context->nSymbols);

	val = context->Tree[ix];

   if (ix>0){
      parent= ix & (ix-1);
      ix = ix-1;
      while (parent != ix ){
         val = val - context->Tree[ix];
         ix = ix & (ix -1);
      }
   }

   return val;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
int ContextGetSymbol(Context *context, int cumFreq)
{
   int baseIx, testIx, half;

   if (cumFreq++<context->Tree[0]){
      return 0;
   }
   
	cumFreq-=context->Tree[0];
	baseIx=0;
   half = context->p2half;

   while (half>0){
      testIx = baseIx+half;

      if (cumFreq>context->Tree[testIx] && testIx < context->nSymbols){
		   baseIx=testIx;
			cumFreq-=context->Tree[testIx];
      }
      half>>=1;
   }
   return baseIx+1;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ContextScaleDown(Context *context)
{
   int i;
	
   for (i=context->nSymbols-1; i>=0; i--){
		ContextPutValue(context, -ContextGetProb(context, i)/2, i);
   }
}


/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
void ContextUpdate(Context *context, int val, int ix)
{
	if (context->TotalFreq > context->MaxCount){
#ifdef __F_SCALE_
		fprintf(stderr, "Scale down\n");
#endif
      ContextScaleDown(context);
   }

   ContextPutValue(context, val, ix);
	
}


/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
double ContextGetCost(Context *context, int symbol)
{
	double cost;
   
   cost = -ONELOG2*log( ((double)ContextGetProb(context, symbol))/context->TotalFreq);

	return cost;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
void ContextPrintTable(Context *context, FILE *fp)
{
	int i;

	fprintf(fp, "--------------------------------------------------------------------\n");
	for (i=0; i<context->nSymbols; i++){
		fprintf(fp, "index:%5d  freq:%7d  cumul freq:%8d  stored:%7d\n",
			i, ContextGetProb(context, i), ContextGetCumul(context, i), context->Tree[i]);
	} 
	fprintf(fp, "Total: %d\n", context->TotalFreq);
}


/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
/* Arithmetic encoder */
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
ArithEncoder *ArithEncoderAlloc(BIT_FILE *bs)
{
	ArithEncoder *encoder;

	if ((encoder=(ArithEncoder *)malloc(sizeof(ArithEncoder)))==NULL){
		return NULL;
	}

	encoder->bs=bs;

	return encoder;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ArithEncoderDealloc(ArithEncoder *encoder)
{
	if (encoder!=NULL){
		free(encoder);
	}
}


/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ArithEncoderStart(ArithEncoder *encoder)
{
	encoder->low=0;
	encoder->high=TopValue;
	encoder->range=encoder->high-encoder->low+1;
	encoder->BitsToFollow=0;
	encoder->nBitsOutput=0;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ArithEncoderEncode(ArithEncoder *encoder, int countLeft, int count, int countTotal)
{
	encoder->high= encoder->low+(encoder->range*count)/countTotal - 1;
	encoder->low = encoder->low+(encoder->range*countLeft)/countTotal;

	for (;;){
		if (encoder->high<Half){
			ArithEncoderBitPlusFollow(encoder, 0);
		}
		else if (encoder->low>=Half){
			ArithEncoderBitPlusFollow(encoder, 1);
			encoder->low-=Half;
			encoder->high-=Half;
		}
		else if (encoder->low>=FirstQtr &&
			encoder->high< ThirdQtr){
			encoder->BitsToFollow++;
			encoder->low-=FirstQtr;
			encoder->high-=FirstQtr;
		}
		else{
			break;
		}
		encoder->low=2*encoder->low;
		encoder->high=2*encoder->high + 1;
	}
}


/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ArithEncoderBitPlusFollow(ArithEncoder *encoder, int bit)
{
	if (encoder->bs!=NULL){
		OutputBit(encoder->bs, bit);
		encoder->nBitsOutput++;
		
		while(encoder->BitsToFollow>0){
			OutputBit(encoder->bs, !bit);
			encoder->nBitsOutput++;
			encoder->BitsToFollow-=1;
		}
	}
	else{
		encoder->nBitsOutput++;
		encoder->nBitsOutput++;
		
		while(encoder->BitsToFollow>0){
			encoder->nBitsOutput++;
			encoder->nBitsOutput++;
			encoder->BitsToFollow-=1;
		}
	}
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ArithEncoderDone(ArithEncoder *encoder)
{
	encoder->BitsToFollow+=1;

	if (encoder->low<FirstQtr){
		ArithEncoderBitPlusFollow(encoder, 0);
	}
	else{
		ArithEncoderBitPlusFollow(encoder, 1);
	}
}


/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
int  ArithEncoderNBitsOutput(ArithEncoder *encoder)
{
	// The actual bits "output" at the moment should includes the 
	// BitsToFollow and the two bits at the end of encoding 
	return (encoder->nBitsOutput + encoder->BitsToFollow + 2);
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
/* Arithmetic decoder */
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
ArithDecoder *ArithDecoderAlloc(BIT_FILE *bs)
{
	ArithDecoder *decoder;

	if ((decoder=(ArithDecoder *)malloc(sizeof(ArithDecoder)))==NULL){
		return NULL;
	}

	decoder->bs=bs;

	return decoder;
}


/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ArithDecoderDealloc(ArithDecoder *decoder)
{
	if (decoder!=NULL){
		free(decoder);
	}
}


/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ArithDecoderStart(ArithDecoder *decoder)
{
	int i;

	decoder->eof = 0;
	decoder->value = 0;
	for(i=0; i<CodeValueBits; i++){
		decoder->value = 2*decoder->value+InputBit(decoder->bs, &decoder->eof);
		if (decoder->eof){
			return;
		}
	}
	decoder->low = 0;
	decoder->high = TopValue;
	decoder->range = decoder->high - decoder->low + 1;
	decoder->nBitsInput = CodeValueBits;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void ArithDecoderDecode(ArithDecoder *decoder, int countLeft, int count, int countTotal)
{
	decoder->high=decoder->low+(decoder->range*count)/countTotal-1;
	decoder->low =decoder->low+(decoder->range*countLeft)/countTotal;

	for (;;){
		if (decoder->high<Half){
		}
		else if (decoder->low>=Half){
			decoder->value-=Half;
			decoder->low-=Half;
			decoder->high-=Half;
		}
		else if (decoder->low>=FirstQtr &&
			decoder->high<ThirdQtr){
			decoder->value-=FirstQtr;
			decoder->low-=FirstQtr;
			decoder->high-=FirstQtr;
		}
		else{
			break;
		}

		decoder->low = 2*decoder->low;
		decoder->high= 2*decoder->high + 1;
		decoder->value= 2*decoder->value + InputBit(decoder->bs, &decoder->eof);
		/* there may be some problem here */
		if (decoder->eof){
			break;
		}
		decoder->nBitsInput++;
	}

	return;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
int  ArithDecoderNBitsInput(ArithDecoder *decoder)
{
	// not much to comppute ;-)
	return decoder->nBitsInput;
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
/* BasicCoder - from G.Davis code */
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
BasicCoder *BasicCoderAlloc(int nSymbols, int MaxCount)
{

	BasicCoder *coder;

	if ((coder=(BasicCoder *)malloc(sizeof(BasicCoder)))==NULL){
		return NULL;
	}
	
	coder->nSymbols = nSymbols;
	coder->context = ContextAlloc();	
	ContextInitialize(coder->context, nSymbols, MaxCount, 1);
	coder->EndOfStreamSymbol = coder->context->nSymbols-1;

	return coder;

}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
void BasicCoderDealloc(BasicCoder *coder)
{
	if (coder != NULL){
		ContextDealloc(coder->context);
		free(coder);
	}
}

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/	
double BasicCoderEncode(BasicCoder *coder, ArithEncoder *encoder, 
								  int symbol, Boolean update)
{
	double bits;

	bits = ContextGetCost(coder->context, symbol);

	if (encoder!=NULL){
		encoder->range = encoder->high - encoder->low + 1;
		ArithEncoderEncode(encoder, ContextGetCumul(coder->context, symbol-1),
			ContextGetCumul(coder->context, symbol), coder->context->TotalFreq);
	}

	if (update){
		ContextUpdate(coder->context, 1, symbol);
	}

	return bits;

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91国内精品野花午夜精品| 日本v片在线高清不卡在线观看| 欧美一区二区精品在线| 色狠狠色噜噜噜综合网| 91福利社在线观看| 91福利社在线观看| 欧美日韩一区中文字幕| 欧美日韩国产高清一区二区三区 | 欧美日韩激情一区二区| 欧美在线观看你懂的| 欧美做爰猛烈大尺度电影无法无天| 91日韩精品一区| 91免费版pro下载短视频| 色av成人天堂桃色av| 精品视频在线免费看| 欧美另类z0zxhd电影| 日韩免费电影网站| 久久久国产精品午夜一区ai换脸| 日本一区二区在线不卡| 亚洲精品视频在线观看网站| 天天综合网天天综合色| 久久不见久久见中文字幕免费| 国产一区二区三区黄视频| 成人app下载| 欧美精品在线观看播放| 2019国产精品| 亚洲激情图片qvod| 日韩和的一区二区| 国产专区欧美精品| 色狠狠综合天天综合综合| 91精品久久久久久久91蜜桃| 精品va天堂亚洲国产| 久久精品视频免费观看| 久久久久国产精品麻豆ai换脸| 日韩毛片在线免费观看| 美女视频一区在线观看| 91免费观看在线| 欧美成人福利视频| 一卡二卡三卡日韩欧美| 久久99这里只有精品| av午夜精品一区二区三区| 欧美一级欧美三级在线观看| 国产三级一区二区| 亚洲第一激情av| 不卡一区二区中文字幕| 色天使久久综合网天天| 337p日本欧洲亚洲大胆色噜噜| 亚洲品质自拍视频| 久久国产三级精品| 欧美日韩中文字幕一区| 国产精品久久久久久久久久久免费看 | 日韩国产欧美在线播放| 国产毛片精品国产一区二区三区| 欧美网站一区二区| 日韩美女视频一区二区| 国产精品99久久久| 欧美精品一区二区三区一线天视频 | 国产亚洲精品中文字幕| 婷婷久久综合九色国产成人 | 亚洲国产毛片aaaaa无费看| 成人免费观看男女羞羞视频| 欧美一区二区三区免费大片| 一区二区三区四区亚洲| 不卡一区在线观看| 国产精品免费免费| 国产成人av一区二区| 欧美成人aa大片| 日韩avvvv在线播放| 欧美裸体一区二区三区| 亚洲一二三区不卡| 欧美日韩色综合| 亚洲国产美女搞黄色| 欧美在线免费视屏| 亚洲成人1区2区| 欧美亚洲免费在线一区| 亚洲国产精品影院| 91麻豆精品国产91久久久| 国产成人精品免费网站| 欧美久久久久久久久久| 亚洲午夜电影在线观看| 欧美色国产精品| 男女男精品网站| 久久久久国产成人精品亚洲午夜| 国产毛片精品国产一区二区三区| 久久久久久久久久久电影| 国产成人免费在线视频| 亚洲婷婷综合色高清在线| 色美美综合视频| 天堂影院一区二区| 精品国产区一区| 成人激情av网| 亚洲一区二三区| 日韩视频免费直播| 丁香婷婷综合网| 亚洲午夜视频在线| 欧美一级高清大全免费观看| 国产精品一区二区在线看| 国产精品美女久久福利网站| 欧洲亚洲国产日韩| 久久国产欧美日韩精品| 国产精品久久久久久亚洲毛片 | 国产资源在线一区| 综合电影一区二区三区| 在线播放91灌醉迷j高跟美女| 久久国内精品自在自线400部| 欧美国产国产综合| 欧美日韩国产色站一区二区三区| 美女视频一区二区三区| 亚洲欧美日韩久久精品| 精品少妇一区二区三区日产乱码| 国产99久久久久| 不卡电影一区二区三区| 亚洲第一激情av| 中文字幕不卡三区| 欧美一区欧美二区| 色婷婷综合激情| 激情综合网av| 亚洲第一福利视频在线| 国产欧美精品一区| 日韩午夜在线播放| 欧美怡红院视频| 成人午夜激情影院| 美女视频黄免费的久久 | 亚洲一区在线视频观看| 亚洲精品一区二区在线观看| 在线观看日韩电影| 成人av在线一区二区| 国产专区欧美精品| 免费在线观看成人| 亚洲高清免费在线| 亚洲精品视频一区二区| 国产精品久久夜| 视频在线观看国产精品| 亚洲色图欧美偷拍| 国产精品美女久久久久久久| 精品欧美黑人一区二区三区| 精品视频在线免费看| 91福利社在线观看| 91官网在线免费观看| 91成人在线观看喷潮| 93久久精品日日躁夜夜躁欧美| 国产成人99久久亚洲综合精品| 久久国产视频网| 国产在线一区二区| 久久综合综合久久综合| 久久99精品国产麻豆婷婷洗澡| 日韩专区欧美专区| 三级成人在线视频| 日本不卡中文字幕| 久久精品国产一区二区三区免费看| 亚洲国产欧美日韩另类综合| 亚洲综合999| 五月婷婷久久丁香| 日韩精品电影一区亚洲| 青青草91视频| 国产精品一级在线| 国产成人亚洲精品青草天美| 国产精品一区二区在线观看不卡| 国产尤物一区二区在线| 丰满亚洲少妇av| hitomi一区二区三区精品| 91亚洲精品一区二区乱码| 99精品国产热久久91蜜凸| 精品久久久久久最新网址| 久久综合狠狠综合久久综合88| 久久久99精品久久| 亚洲图片另类小说| 日韩二区三区在线观看| 久久se精品一区二区| 成人亚洲精品久久久久软件| 99久久精品情趣| 在线电影欧美成精品| 久久精品亚洲乱码伦伦中文| 国产精品女同一区二区三区| 亚洲男同1069视频| 视频一区中文字幕国产| 国产91精品免费| 欧美伊人久久久久久午夜久久久久| 7777精品伊人久久久大香线蕉超级流畅| 日韩一区二区三区av| 国产精品美女久久久久aⅴ | 91网站视频在线观看| 欧美三级在线播放| 精品久久久久久久久久久久包黑料 | 99视频有精品| 欧美丰满美乳xxx高潮www| 久久婷婷成人综合色| 依依成人综合视频| 国内精品久久久久影院一蜜桃| 97国产一区二区| 欧美一区二区人人喊爽| 亚洲手机成人高清视频| 久久黄色级2电影| 欧美专区在线观看一区| 久久综合成人精品亚洲另类欧美 | 另类调教123区 | 精品国产一二三区| 亚洲精品中文字幕在线观看| 九九国产精品视频| 欧美日韩高清一区二区不卡|