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

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

?? ac_en.h

?? 用VC++對單幅圖象進行熵編碼壓縮,同時具有解壓縮的功能.
?? H
字號:
/////////////////////////////////////////////
//
//    AC_En.h
//    文件內容:算術編碼
//    
//    作    者:丁貴廣
//    制作日期:2003.7.26
//    西安電子科技大學 AI Lab    
//
/////////////////////////////////////////////
# include "stdlib.h"
# include "stdio.h"
# include "math.h"
/**************************************************************************
 定義算術編碼的概率模型表
 **************************************************************************/
static unsigned short qe_value[47]=
					{0x5601,0x3401,0x1801,0x0ac1,0x0521,0x0221,0x5601,0x5401,
					 0x4801,0x3801,0x3001,0x2401,0x1c01,0x1601,0x5601,0x5401,
					 0x5101,0x4801,0x3801,0x3401,0x3001,0x2801,0x2401,0x2201,
					 0x1c01,0x1801,0x1601,0x1401,0x1201,0x1101,0x0ac1,0x09c1,
					 0x08a1,0x0521,0x0441,0x02a1,0x0221,0x0141,0x0111,0x0085,
					 0x0049,0x0025,0x0015,0x0009,0x0005,0x0001,0x5601};
static unsigned short nmps[47]=
					{1, 2, 3, 4, 5, 38,7, 8, 9, 10,11,12,13,29,15,16,17,18,19,20,
					 21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,
					 41,42,43,44,45,45,46};
static unsigned short nlps[47]=
					{1, 6, 9, 12,29,33,6, 14,14,14,17,18,20,21,14,14,15,16,17,18,
					 19,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,
					 38,39,40,41,42,43,46};
static unsigned short flag[47]=
					{1,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
					 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};

static unsigned short a_register,ct,mps[20],index[20];
static unsigned long c_register,bp,b0,b1,CC;

static FILE *fp_out;
static FILE *fp_in;

static long BytesLimit,sc,TByteLimit;              // size limited by compressed image size.
static long num_of_packed_bytes=0;                 // total bytes written out.
static long num_of_unpacked_bytes=0;                   // total bytes read in.
long pack1(short,short,short);
void byteout();
/**************************************************************************
 Init_AC_QM_Encoder(void)
 完成算術編碼的初始化
 **************************************************************************/
void Init_AC_QM_Encoder(void)
{ short i;
  a_register=0x8000;
  c_register=0;
  ct=12;
  bp=0;
  sc=0;
  for(i=0;i<20;i++){
	  index[i]=0;
	  mps[i]=0;
	  if(i==0)  index[i]=4;
	  if(i==17) index[i]=3;
	  if((i==18)||(i==19)) index[i]=46;
	}
}
/**************************************************************************
 pack1()
 算術編碼的主函數
 **************************************************************************/
long pack1(
	 short bit_num,
	 short bit_value,
	 short con)
{
short  i,f_bit;

	for(i=0;i<bit_num;i++){

		f_bit=bit_value>>i;

		if((f_bit&1)==mps[con]){
			a_register-=qe_value[index[con]];

			if((a_register&0x8000)==0){

				if(a_register<qe_value[index[con]]) a_register=qe_value[index[con]];
				else c_register+=qe_value[index[con]];
				index[con]=nmps[index[con]];

				do{
					a_register<<=1;
					c_register<<=1;
					ct--;
					if (ct==0) {
					  byteout();
					  if(sc>=BytesLimit) return -1;
					 }
				 }while ((a_register&0x8000)==0);

			 }
			else c_register+=qe_value[index[con]];
		 }

		else {
			a_register-=qe_value[index[con]];

			if(a_register<qe_value[index[con]]) c_register+=qe_value[index[con]];
			else a_register=qe_value[index[con]];

			if (flag[index[con]]==1) mps[con]=1-mps[con];

			index[con]=nlps[index[con]];

			 do{
					a_register<<=1;
					c_register<<=1;
					ct--;
					if (ct==0) {
					  byteout();
					  if(sc>=BytesLimit) return -1;
					 }
			 }while ((a_register&0x8000)==0);
		 }
	 }

	 return 0;
}
/**************************************************************************
 pack1()
 算術編碼的字節輸出函數
 **************************************************************************/
void byteout( void)
{
  if(bp==0){

		 b0=c_register>>19;
		 bp++;
		 c_register&=0x7ffff;
		 ct=8;
	 }
  else{

	  if (b0==0xff) {
			 b1=c_register>>20;
			 bp++;
			 c_register&=0xfffff;
			 ct=7;
		}

	  else{
		 if (c_register>=0x8000000){
			 b0++;
			 c_register&=0x7ffffff;
			 if(b0==0xff){
				  b1=c_register>>20;
				  bp++;
				  c_register&=0xfffff;
				  ct=7;
				}
			 else{
				  b1=c_register>>19;
				  bp++;
				  c_register&=0x7ffff;
				  ct=8;
				}
			}

		 else{
			 b1=c_register>>19;
			 bp++;
			 c_register&=0x7ffff;
			 ct=8;
			}
		}
	fwrite(&b0,sizeof(char),1,fp_out);
	sc++;
	b0=b1;
	}
}
/**************************************************************************
 flush()
 算術編碼的終止函數
 **************************************************************************/
void flush(void)
{
	 unsigned long tempc;

	 tempc=c_register+a_register;
	 c_register|=0xffff;

	 if (c_register>=tempc)  c_register-=0x8000;

	 c_register<<=ct;
	 byteout();

	 c_register<<=ct;
	 byteout();

	 if (b0!=0xff) fwrite(&b0,sizeof(char),1,fp_out);
	 else bp--;

}
/**************************************************************************
 MaxinMatrix()
 功能:返回圖像中的最大值
 **************************************************************************/
short MaxinMatrix(BYTE *image, short x_size, short y_size)
{
	short i,j,max;
	max=abs(image[0]);
	for(i=0;i<y_size;i++)
		for(j=0;j<x_size;j++)
			if(abs(image[i*x_size+j])>max)	max=abs(image[i*x_size+j]);
	return max;
}
/**************************************************************************
 Bitplane_coding()
 功能:編碼一個位平面
 **************************************************************************/
short Bitplane_coding(BYTE *image,short n,short x_size,short y_size)
{
	short i,j,Sn;
	for(i=0;i<x_size;i++)
		for(j=0;j<y_size;j++)
		{
			Sn=(abs(image[i*x_size+j])>>n)&1;
			pack1(1,Sn,0);
		}
	return 0;
}
/**************************************************************************
 Encoding_Pass()
 功能:編碼整幅圖像
 **************************************************************************/
short Encoding_Pass(
	BYTE *image,
	short x_size,
	short y_size)
{ 
	short n;
	n=(short)(log10(MaxinMatrix(image,x_size,y_size))/log10(2));
	if(pack1(4,n,0)==-1) return -1;
	while(n>=0) 
	{
		if(Bitplane_coding(image,n,x_size,y_size)==-1) return -1;
		n--;
	}

	return 0;
}
/**************************************************************************
 AC_code()
 功能:算術編碼入口函數
 **************************************************************************/
void AC_code(   
	BYTE *image,
	short x_size,
	short y_size)
{	
	BytesLimit=(long)(x_size*y_size);           // lossless.
	Init_AC_QM_Encoder();
	if(Encoding_Pass(image,x_size,y_size)==-1) goto END;
END:flush();
	fclose(fp_out);
	return;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产伦精品一区二区三区免费迷| 日本一区中文字幕| 国产欧美精品区一区二区三区| 678五月天丁香亚洲综合网| 欧美体内she精视频| 色噜噜狠狠一区二区三区果冻| 99久久精品国产观看| www.亚洲国产| 91丝袜呻吟高潮美腿白嫩在线观看| 国产999精品久久久久久| 粉嫩高潮美女一区二区三区| 国产成人av资源| a级高清视频欧美日韩| 一本在线高清不卡dvd| 欧美日韩免费不卡视频一区二区三区| 欧美综合视频在线观看| 欧美日韩一区二区三区免费看| 欧美另类z0zxhd电影| 日韩欧美专区在线| 国产嫩草影院久久久久| 亚洲视频一二三| 日本美女视频一区二区| 国产福利91精品一区二区三区| 成人av网站在线| 欧美三级日韩三级| 久久亚洲综合色一区二区三区 | 日韩精彩视频在线观看| 麻豆国产欧美日韩综合精品二区| 久久91精品久久久久久秒播| 成人一级视频在线观看| 日本韩国欧美国产| 久久综合久久99| 亚洲欧美国产77777| 奇米影视一区二区三区小说| 国产精品99久| 欧美精品黑人性xxxx| 国产视频亚洲色图| 亚洲国产一二三| 国产黄人亚洲片| 欧美色综合影院| 国产精品免费av| 亚洲一级在线观看| 韩国女主播一区| 欧美日韩极品在线观看一区| 欧美国产一区在线| 丝袜美腿亚洲综合| 一本色道久久综合亚洲91| 精品日韩欧美在线| 亚洲h在线观看| 91视频xxxx| 国产欧美精品在线观看| 蜜臀av一级做a爰片久久| 色婷婷激情久久| 国产精品福利av| 国产精品自在欧美一区| 91精品国产欧美日韩| 亚洲色图视频网站| 国产精品自拍三区| 日韩精品一区二区三区视频在线观看| 一区二区三区四区国产精品| 99re视频精品| 国产精品你懂的在线欣赏| 91免费看视频| 国产精品免费视频一区| 国产成人丝袜美腿| 亚洲精品在线观| 秋霞成人午夜伦在线观看| 欧洲精品中文字幕| 亚洲裸体在线观看| 成av人片一区二区| 国产精品美女久久久久久久久 | 天天色综合天天| 欧美亚洲动漫制服丝袜| 亚洲免费电影在线| 91蜜桃网址入口| 亚洲女人小视频在线观看| 99国产精品久久久久久久久久| 国产精品网站在线观看| 成人精品小蝌蚪| 国产精品久久久久久久久免费樱桃| 国产精品一区二区在线观看网站| 精品对白一区国产伦| 国产精品18久久久久久久网站| 久久久精品免费网站| 国产91精品露脸国语对白| 国产精品久久久久一区二区三区 | 在线成人免费视频| 青青草原综合久久大伊人精品优势| 欧美日韩亚洲丝袜制服| 日本视频中文字幕一区二区三区| 欧美三级视频在线观看| 午夜精彩视频在线观看不卡| 日韩一级片在线观看| 粉嫩av一区二区三区| 亚洲日本va午夜在线影院| 欧美性受xxxx| 久久精品噜噜噜成人av农村| 亚洲国产成人自拍| 欧美日韩一级二级| 韩国理伦片一区二区三区在线播放| 国产视频一区二区在线观看| 7777精品久久久大香线蕉| 秋霞影院一区二区| 欧美国产精品一区二区| 欧美在线视频你懂得| 日日夜夜免费精品| 国产日韩欧美电影| 欧美日韩国产综合一区二区| 国产伦精品一区二区三区免费迷 | 日本韩国欧美一区二区三区| 日韩中文字幕av电影| 国产精品免费人成网站| 7777精品伊人久久久大香线蕉超级流畅 | 国产日韩欧美一区二区三区乱码 | 一区二区三区四区在线播放| 日韩一级成人av| 99re热这里只有精品免费视频| 免费成人深夜小野草| |精品福利一区二区三区| 51精品秘密在线观看| kk眼镜猥琐国模调教系列一区二区| 九色|91porny| 亚洲综合一区二区| 中文在线一区二区 | 一本久久a久久免费精品不卡| 狠狠色丁香久久婷婷综合_中 | 国产成人在线视频网站| 午夜精品福利在线| 亚洲欧美一区二区三区孕妇| 久久精品一区蜜桃臀影院| 在线成人av网站| 日本高清无吗v一区| 国产91精品精华液一区二区三区| 亚洲国产美女搞黄色| 国产精品情趣视频| 久久这里只精品最新地址| 这里只有精品99re| 欧美自拍偷拍一区| 色综合咪咪久久| 成人黄色在线网站| 国产精品一二一区| 九一九一国产精品| 久久国产日韩欧美精品| 日韩国产高清在线| 日本不卡中文字幕| 日本va欧美va精品| 日本成人中文字幕| 久久er99热精品一区二区| 久久成人免费电影| 久久97超碰国产精品超碰| 精品一区二区三区av| 捆绑调教美女网站视频一区| 久久精工是国产品牌吗| 久久精品国内一区二区三区| 麻豆久久久久久久| 国产乱子伦视频一区二区三区| 精品一区二区三区免费播放 | 99精品视频一区| 色婷婷综合久久久久中文| 色婷婷综合久久久| 欧美日本一区二区| 欧美一区二区三区的| 日韩精品在线一区| 国产日产亚洲精品系列| 国产精品美日韩| 亚洲自拍偷拍av| 日本伊人色综合网| 国产精品一区二区免费不卡| 成人av影院在线| 欧美日韩和欧美的一区二区| 欧美电影免费观看高清完整版在| 精品国产不卡一区二区三区| 国产农村妇女精品| 亚洲国产一二三| 久久国产婷婷国产香蕉| 99热国产精品| 91精品在线一区二区| 久久久久9999亚洲精品| 亚洲欧洲综合另类| 久久精品国产精品亚洲精品| 国产91色综合久久免费分享| 色哟哟一区二区三区| 欧美一级艳片视频免费观看| 欧美激情一区三区| 五月婷婷另类国产| 高清国产一区二区| 欧美色精品在线视频| 久久久久久亚洲综合| 一区二区国产盗摄色噜噜| 久久99国产精品久久99果冻传媒| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美疯狂做受xxxx富婆| 国产精品久久久久久久浪潮网站| 午夜精品久久一牛影视| 国产丶欧美丶日本不卡视频| 欧美午夜精品免费| 日本一区二区三区四区在线视频| 天堂va蜜桃一区二区三区漫画版| 成人精品免费网站| 日韩欧美在线观看一区二区三区|