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

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

?? modified_ebcot2.c

?? 這是我剛剛完成的關于JPEG2000的C語言實現的部分程序。小波變換是采用97變換
?? C
?? 第 1 頁 / 共 2 頁
字號:
/******************************************************************************
功能描述:
   Implements block_encode 
以下部分是對EBCOT的編碼。三個通道。四種編碼形式
功能描述:編碼過程中,每個系數總處于三種狀態之一:無效態,有效態,上下文有效態
******************************************************************************/
/*****************************************************************************/
// 程序: ebcot 編碼
// 版本:  V0.0
// 作者: 胡運平
// 最后修改時間 : 30, 6, 2005
/****************************************************************************/
#include <stdio.h>
#include<math.h>
#include<assert.h>
#include"fdwt.h"
#include"block_encode.h"

/******************************************************************************
//函數功能:
//輸入:1 3  7 15 31 63 127 255
//輸出  1 2  3  4  5  6  7  8
*******************************************************************************/
int log2i(int val)
{
	int i;
	if(val>=0 && val<=1)
		i=0;
		else if(val>=2 && val<=3)
		i= 1;
		else if(val>=4 && val<=7)
		 i =2;
		else if(val>=8 && val<=15)
		 i=3;
		else if(val>=16 && val<=31)
			i=4;
		else if(val>=32 && val<=63)
			i=5;
		else if(val>=64 && val<=127)
			i=6;
		else if(val>=128 && val<=255)
			i=7;

	return i;
}
/******************************************************************************
//輸入為block code 的小波量化系數,輸出為文件形式的(CX,D)
*******************************************************************************/
void block_encode(int block_bufferin[BLOCKLENGTH][BLOCKWIDTH])
{
	int i,j,k,m;
	int max;
	unsigned char c[BLOCKLENGTH][BLOCKWIDTH];//顯著性狀態。
	unsigned int f[BLOCKLENGTH][BLOCKWIDTH] = {0};
//	unsigned char kign;
	FILE *context;
	if ((context = fopen("context.raw","wb+")) == NULL)
	{
		printf("cannot open file\n");
		return;
	}
/*******************************************************************************
// x;//符號變量
// q;//顯著性狀態變量
// e;//延遲顯著性狀態變量 表示系數是否是第一次被量值改進,也叫細化信息位
// v;//樣本比特值
// pi;//編碼狀態變量 ,在每個位平面P的第一編碼過程中設置其值,若該樣本在該編碼過程
//中處理,置1,否則設成0 初始化所有狀態變量為0
********************************************************************************/
  for(i=0;i<BLOCKLENGTH;i++)
	for(j=0;j<BLOCKWIDTH;j++)
	{
		state_data_x[i][j] = 0;
		state_data_q[i][j] = 0;
		state_data_e[i][j] = 0;
		state_data_v[i][j] = 0;
		state_data_pi[i][j] = 0;
	}
/******************************************************************************
//小波系數的預處理,完成三個功能:碼塊生成過程,數據格式轉換過程,碼塊最大值查
找過程
//求單個碼塊的最大值和把符號位提取出來給符號變量X;符號變換,補碼形式變成源碼形式
*******************************************************************************/
	max = abs(block_bufferin[0][0]);
	for(i=0;i<BLOCKLENGTH;i++)
		for(j=0;j<BLOCKWIDTH;j++)
		{		
			state_data_x[i][j] = (block_bufferin[i][j]>>16 & 1);
			block_bufferin[i][j] = abs(block_bufferin[i][j]);
			if(block_bufferin[i][j]>max)
			max = block_bufferin[i][j];
		}
//環境狀態字初始化,16位,每一個總共表示有1個系數的所有狀態變量。
	for(i=0;i<BLOCKLENGTH;i++)
		for(j=0;j<BLOCKWIDTH;j++)
		{
			c[i][j] = 0;	
		}
/******************************************************************************
//預處理完畢可以進行下面的核心編碼操作,以四個系數作為一個stripe編碼,
//最高位平面開始編碼,最高位平面只進行cleanup通道編碼	
//依次經過三個編碼通道。
//環境狀態字給初值,12位,顯示重要性狀態值。狀態變量如下所示:
// x;//符號變量
// q;//顯著性狀態變量
// e;//延遲顯著性狀態變量 表示系數是否是第一次被量值改進,也叫細化信息位
// v;//樣本比特值
// pi;//編碼狀態變量 表示位平面上的比特值是否已經被編碼,也叫訪問信息位
********************************************************************************/
for(k=log2i(max);k>-1;k--)
{//位平面層數,從最高位平面到最低位平面0編碼
	for(i=0;i<BLOCKLENGTH;i++)
	{
		for(j=0;j<BLOCKWIDTH;j++)
		{
			c[i][j] = state_data_q[i][j];
			state_data_v[i][j] = ((block_bufferin[i][j]>>k) & 1);
			state_data_pi[i][j] = 0;
		//	printf("%d ",c[i][j]);
		//	printf("%d ",state_data[i][j].v);
		//	printf("%d ",state_data_x[i][j]);
		//	printf("%d ",block_bufferin[i][j]);
		}
	}
init_environment(f,c,state_data_x);

for(i=0;i<BLOCKLENGTH/4;i++)
{
	for(j=0;j<BLOCKWIDTH;j++)
	{
		if(k==log2i(max)) 
			goto RLC;
		else
		{
			for(m=0;m<4;m++)	
			{//開始重要性傳播位平面的重要性掃描通道,處理當前不顯著,但具有顯著鄰域的樣本
				if(state_data_q[4*i+m][j]==0 && init_significant(f[4*i+m][j],0)>0)
				{//當前系數不是重要性系數,上下文區域不是0							
					fprintf(context,"%d %d ",init_significant(f[4*i+m][j],0),state_data_v[4*i+m][j]);
					if(state_data_v[4*i+m][j])
					{
						state_data_q[4*i+m][j]  = 1;
						//unsigned char init_sign(unsigned int f, unsigned char v,int i,int j)
						fprintf(context,"%d %d ",init_sign(f[4*i+m][j],state_data_x[4*i+m][j]),state_data_x[4*i+m][j]);				
					}
					state_data_pi[4*i+m][j] = 1;
					
				}
				else
					state_data_pi[4*i+m][j] = 0;
			//開始幅值細化通過,位平面的幅度細化掃描通道
				if(state_data_q[4*i+m][j]==1 && state_data_pi[4*i+m][j]==0)  
				{//該系數是重要的,						
					fprintf(context,"%d %d ",init_magnitude(f[4*i+m][j],state_data_e[4*i+m][j]),state_data_v[4*i+m][j]);
					state_data_e[4*i+m][j] = 1;		
				}
			}

//開始清除通過
RLC:	if((init_significant(f[4*i][j],0)==0) && (init_significant(f[4*i+1][j],0)==0) &&
			(init_significant(f[4*i+2][j],0)==0) && (init_significant(f[4*i+3][j],0)==0))
		{
			if(!(state_data_v[4*i][j] | state_data_v[4*i+1][j] | 
				state_data_v[4*i+2][j] | state_data_v[4*i+3][j]))
			{
				fprintf(context,"%d %d ",17,0);
//				state_data_pi[4*i][j] = state_data_pi[4*i+1][j] =
//					state_data_pi[4*i+2][j] = state_data_pi[4*i+3][j] = 1;
				continue;
			}
			for(m = 0;m<4;m++)
			{
				if(state_data_v[4*i+m][j])
				{
					fprintf(context,"%d %d ",17,1);
					if(m == 0)
						{
							fprintf(context,"%d %d ",18,0);
							fprintf(context,"%d %d ",18,0);
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
						fprintf(context,"%d %d ",9,state_data_x[4*i+m][j]);						
						state_data_q[4*i+m][j] = 1;//重要性標志置1
//						state_data_pi[4*i+m][j] = 1;//標志此位被訪問過。
						//第二位開始編碼
						fprintf(context,"%d %d ",0,state_data_v[4*i+m+1][j]);
//						state_data_pi[4*i+m+1][j] = 1;//標志此位被訪問過。
						if(state_data_v[4*i+m+1][j])
						{
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
							fprintf(context,"%d %d ",9,state_data_x[4*i+m+1][j]);
							state_data_q[4*i+m+1][j] = 1;//重要性標志置1
						}
						//第三位開始編碼
						fprintf(context,"%d %d ",0,state_data_v[4*i+m+2][j]);
//						state_data_pi[4*i+m+2][j] = 1;//標志此位被訪問過。
						if(state_data_v[4*i+m+2][j])
						{
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
							fprintf(context,"%d %d ",9,state_data_x[4*i+m+2][j]);
							state_data_q[4*i+m+2][j] = 1;//重要性標志置1
						}
						//第四位開始編碼
						fprintf(context,"%d %d ",0,state_data_v[4*i+m+3][j]);
//						state_data_pi[4*i+m+3][j] = 1;//標志此位被訪問過。
						if(state_data_v[4*i+m+3][j])
						{
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
							fprintf(context,"%d %d ",9,state_data_x[4*i+m+3][j]);
							state_data_q[4*i+m+3][j] = 1;//重要性標志置1
						}	
						break;
						}
					 if(m == 1)
						{
							fprintf(context,"%d %d ",18,0);
							fprintf(context,"%d %d ",18,1);
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
						fprintf(context,"%d %d ",9,state_data_x[4*i+m][j]);						
						state_data_q[4*i+m][j] = 1;//重要性標志置1
//						state_data_pi[4*i+m-1][j] = 1;//標志此位被訪問過。
//						state_data_pi[4*i+m][j] = 1;//標志此位被訪問過。
						//第三位開始編碼
						fprintf(context,"%d %d ",0,state_data_v[4*i+m+1][j]);
//						state_data_pi[4*i+m+1][j] = 1;//標志此位被訪問過。
						if(state_data_v[4*i+m+1][j])
						{
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
							fprintf(context,"%d %d ",9,state_data_x[4*i+m+1][j]);
							state_data_q[4*i+m+1][j] = 1;//重要性標志置1
						}
						//第四位開始編碼
						fprintf(context,"%d %d ",0,state_data_v[4*i+m+2][j]);
//						state_data_pi[4*i+m+2][j] = 1;//標志此位被訪問過。
						if(state_data_v[4*i+m+2][j])
						{
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
							fprintf(context,"%d %d ",9,state_data_x[4*i+m+2][j]);
							state_data_q[4*i+m+2][j] = 1;//重要性標志置1

						}
						break;
						}
					 if(m == 2)
						{						
							fprintf(context,"%d %d ",18,1);
							fprintf(context,"%d %d ",18,0);
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
						fprintf(context,"%d %d ",9,state_data_x[4*i+m][j]);						
						state_data_q[4*i+m][j] = 1;//重要性標志置1
//						state_data_pi[4*i+m-2][j] = 1;//標志此位被訪問過。
//						state_data_pi[4*i+m-1][j] = 1;//標志此位被訪問過。
//						state_data_pi[4*i+m][j] = 1;//標志此位被訪問過。						
						fprintf(context,"%d %d ",0,state_data_v[4*i+m+1][j]);
//						state_data_pi[4*i+m+1][j] = 1;//標志此位被訪問過。
						if(state_data_v[4*i+m+1][j])
						{
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
							fprintf(context,"%d %d ",9,state_data_x[4*i+m+1][j]);
							state_data_q[4*i+m+1][j] = 1;//重要性標志置1
						}
						break;
						}
					if(m == 3)
						{
							fprintf(context,"%d %d ",18,1);
							fprintf(context,"%d %d ",18,1);
						//此時將符號位元編碼,有5種可能的情況(9-13)sign coding
						// Encode sign bit
						fprintf(context,"%d %d ",9,state_data_x[4*i+m][j]);						
						state_data_q[4*i+m][j] = 1;//重要性標志置1
//						state_data_pi[4*i+m-3][j] = 1;//標志此位被訪問過。
//						state_data_pi[4*i+m-2][j] = 1;//標志此位被訪問過。
//						state_data_pi[4*i+m-1][j] = 1;//標志此位被訪問過。
//						state_data_pi[4*i+m][j] = 1;//標志此位被訪問過。
						break;
						}						
					}
				}
				continue;
			}
			else 	
			{
				for(m=0;m<4;m++)
				{
			
					if(state_data_q[4*i+m][j]==0 && init_significant(f[4*i+m][j],0)==0)
					{//當前系數不是重要性系數							
						fprintf(context,"%d %d ",init_significant(f[4*i+m][j],0),state_data_v[4*i+m][j]);
						if(state_data_v[4*i+m][j])
						{
							state_data_q[4*i+m][j]  = 1;
							//unsigned char init_sign(unsigned int f, unsigned char v,int i,int j)
							fprintf(context,"%d %d ",init_sign(f[4*i+m][j],state_data_x[4*i+m][j]),state_data_x[4*i+m][j]);				
						}					
					}
				}
			}
	}
/******************************************************************************
//環境狀態字12位,顯示重要性狀態值。狀態變量如下所示:
// x;//符號變量
// q;//顯著性狀態變量
// e;//延遲顯著性狀態變量 表示系數是否是第一次被量值改進,也叫細化信息位
// v;//樣本比特值
// pi;//編碼狀態變量 表示位平面上的比特值是否已經被編碼,也叫訪問信息位
*******************************************************************************/		
	}
}
//到次為止完成三個通道的編碼。
}
	fclose(context);
}


void encode_allsubband(int block_bufferin[BLOCKLENGTH][BLOCKWIDTH],
						float interleave[LENGTH+8][WIDTH+8])
{
	int i,j,m=0,n=0;
	int image_size = LENGTH*WIDTH;
	int block_size = BLOCKLENGTH*BLOCKWIDTH;
	int blocksample[4][4] = 
	{
		{1,6,-5,0},
		{4,1,7,-4},
		{0,5,-2,-5},
		{-3,4,-3,1}
//		{1,2,3,4},
//		{1,2,3,4},
//		{1,2,3,4},
//		{1,2,3,4}
	};
//	long int c[16][8];
	//for(k=8;)
//	for(m=0;m<2;m++)
//		for(n=0;n<2;n++)
		{
			printf("\nThe block_code sample is:");
			for(i=0;i<BLOCKLENGTH;i++)
    			for(j=0;j<BLOCKWIDTH;j++)
				{
					//block_bufferin[i][j] = (floor)(interleave[i+4+m][j+4+n]+0.5);					
					block_bufferin[i][j] = blocksample[i][j];
					if((!j%4))
					printf("\n");
					printf("%d ",block_bufferin[i][j]);
				}

				block_encode(block_bufferin);
		}

}
/******************************************************************************
以上完成EBCOT的編碼,輸出送入MQ算術編碼器中
******************************************************************************/
void init_environment(unsigned int f[BLOCKLENGTH][BLOCKWIDTH],unsigned char 
	c[BLOCKLENGTH][BLOCKWIDTH],unsigned char state_data_x[BLOCKLENGTH][BLOCKWIDTH])
{
	struct entironment_data
	{
		unsigned  a12:1;
		unsigned  a11:1;
		unsigned  a10:1;
		unsigned  a9:1;
		unsigned  a8:1;
		unsigned  a7:1;
		unsigned  a6:1;
		unsigned  a5:1;
		unsigned  a4:1;
		unsigned  a3:1;
		unsigned  a2:1;
		unsigned  a1:1;
	}state[BLOCKLENGTH][BLOCKWIDTH];
	int i,j;
/******************************************************************************
//環境狀態變量              d0  v0  d1    a1  a5  a2             a9
							h0	x	h1	  a7  x   a8       a11   x  a12	
							d2	v1  d3	  a3  a6  a4			a10
******************************************************************************/
	state[0][0].a12 = state_data_x[0][1] & 1;
	state[0][0].a11 = 0;
	state[0][0].a10 = state_data_x[1][0] & 1;
	state[0][0].a9 = 0;
	state[0][0].a8 = c[0][1] & 1;
	state[0][0].a7 = 0;
	state[0][0].a6 = c[1][0] & 1;
	state[0][0].a5 = 0;
	state[0][0].a4 = c[1][1] & 1;
	state[0][0].a3 = 0;
	state[0][0].a2 = 0;
	state[0][0].a1 = 0;

	state[0][BLOCKWIDTH-1].a12 = 0;
	state[0][BLOCKWIDTH-1].a11 = state_data_x[0][BLOCKWIDTH-1-1] & 1;
	state[0][BLOCKWIDTH-1].a10 = state_data_x[1][BLOCKWIDTH-1] & 1;
	state[0][BLOCKWIDTH-1].a9 = 0;
	state[0][BLOCKWIDTH-1].a8 = 0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合天天综合网国产成人综合天| xnxx国产精品| 日韩精品一区二| 亚洲人成在线观看一区二区| 日韩在线卡一卡二| 99re这里都是精品| 久久先锋影音av鲁色资源网| 亚洲国产一区视频| 99国产精品国产精品毛片| 欧美成人精品1314www| 亚洲在线成人精品| 99精品视频一区二区| 久久久久国色av免费看影院| 午夜电影一区二区三区| 色香蕉成人二区免费| 国产精品久久网站| 国产v综合v亚洲欧| 久久九九久久九九| 国产综合一区二区| 日韩欧美视频在线| 午夜亚洲福利老司机| 色综合久久中文字幕综合网| 欧美国产精品一区二区三区| 久久精品国产秦先生| 欧美精品色综合| 午夜精品aaa| 欧美日韩三级一区二区| 亚洲欧美色一区| 91欧美一区二区| 国产精品毛片久久久久久| 国产一区在线精品| 久久精品亚洲国产奇米99| 精品一区二区三区免费视频| 日韩欧美自拍偷拍| 久久99久久精品| 欧美大片免费久久精品三p| 婷婷激情综合网| 日韩亚洲电影在线| 国产精品一色哟哟哟| 国产亚洲欧美一区在线观看| 国产精品夜夜嗨| 国产精品亲子乱子伦xxxx裸| 成人午夜精品在线| 亚洲激情五月婷婷| 欧美日韩电影在线播放| 秋霞成人午夜伦在线观看| 日韩欧美高清一区| 国产高清不卡一区二区| 国产女人aaa级久久久级| 99久久99久久综合| 亚洲国产成人av网| 宅男在线国产精品| 国内精品免费在线观看| 国产欧美久久久精品影院| 99久久精品免费| 亚洲18女电影在线观看| 日韩精品中文字幕在线一区| 激情综合网激情| 亚洲欧美一区二区久久| 欧美军同video69gay| 国产在线一区观看| 亚洲人成伊人成综合网小说| 91麻豆精品国产综合久久久久久| 国产在线看一区| 悠悠色在线精品| 精品国一区二区三区| 波多野结衣中文字幕一区二区三区 | 欧美日韩精品一区二区| 黄色日韩网站视频| 艳妇臀荡乳欲伦亚洲一区| 337p亚洲精品色噜噜噜| 成人激情图片网| 日韩电影网1区2区| 综合久久综合久久| 精品成人一区二区三区| 欧美视频自拍偷拍| 成人在线视频一区二区| 五月激情综合婷婷| 亚洲三级在线免费| 国产日韩高清在线| 欧美一区二区三区精品| 色天使色偷偷av一区二区| 久久99精品久久久久久动态图| 日韩一区在线看| 久久综合久色欧美综合狠狠| 欧美视频精品在线观看| 播五月开心婷婷综合| 国精产品一区一区三区mba视频| 亚洲成人777| 亚洲欧美日韩综合aⅴ视频| 国产欧美日本一区视频| 精品日本一线二线三线不卡| 在线观看免费亚洲| 99久久国产综合精品麻豆| 国产成人无遮挡在线视频| 另类的小说在线视频另类成人小视频在线| 亚洲三级在线免费观看| 1024成人网| 国产精品毛片高清在线完整版| 久久久精品国产99久久精品芒果| 欧美片网站yy| 欧美日韩久久一区| 色欧美日韩亚洲| 色综合网站在线| aa级大片欧美| av在线不卡观看免费观看| 成人免费的视频| 成人av在线网站| 成人综合婷婷国产精品久久蜜臀| 国产一区二区看久久| 精品午夜一区二区三区在线观看| 全国精品久久少妇| 久久se这里有精品| 国产一区二区三区四区五区美女 | 99精品视频在线观看| zzijzzij亚洲日本少妇熟睡| 国产一区二区三区四区在线观看| 精品综合久久久久久8888| 麻豆精品视频在线观看视频| 美国十次综合导航| 狠狠色丁香婷综合久久| 国产sm精品调教视频网站| 成人自拍视频在线| 色婷婷久久久亚洲一区二区三区 | 日日夜夜精品视频免费| 日韩成人免费看| 激情深爱一区二区| 国产高清在线观看免费不卡| 成人综合激情网| 91黄色免费看| 日韩一区二区三区在线| 国产婷婷色一区二区三区四区| 中文字幕不卡在线观看| 亚洲精品成人精品456| 肉丝袜脚交视频一区二区| 九九在线精品视频| 成人免费视频caoporn| 色老汉一区二区三区| 欧美精品tushy高清| 久久久久久久久久久久电影| 国产精品久久久久久久久久免费看| 亚洲人成网站在线| 麻豆视频观看网址久久| 懂色av中文一区二区三区| 欧洲av一区二区嗯嗯嗯啊| 欧美大黄免费观看| 亚洲欧美视频一区| 九九视频精品免费| 色猫猫国产区一区二在线视频| 欧美一级片在线观看| 国产精品日韩精品欧美在线| 午夜视频一区二区| 福利一区福利二区| 欧美日韩另类一区| 国产欧美精品一区aⅴ影院| 天天亚洲美女在线视频| 成人免费视频视频在线观看免费| 欧美久久久久久蜜桃| 自拍偷拍亚洲激情| 国产一区在线观看视频| 欧美日韩国产综合一区二区三区 | 精品成人一区二区| 亚洲高清中文字幕| bt欧美亚洲午夜电影天堂| 69成人精品免费视频| 综合激情成人伊人| 国产一区二区三区| 日韩亚洲欧美在线观看| 亚洲国产综合色| caoporn国产精品| 久久精品人人做人人综合 | 91黄色免费看| 欧美国产日韩精品免费观看| 日本欧美一区二区| 欧美性做爰猛烈叫床潮| 欧美极品aⅴ影院| 久久精品国产999大香线蕉| 欧美午夜精品一区二区三区| 国产精品久久久久久久岛一牛影视| 精品综合久久久久久8888| 91精品国产乱码久久蜜臀| 亚洲午夜视频在线观看| 色综合天天性综合| 国产精品九色蝌蚪自拍| 国产91在线观看| 2017欧美狠狠色| 狠狠色丁香九九婷婷综合五月| 欧美一级电影网站| 亚洲成人免费在线| 欧美日韩国产高清一区二区| 亚洲乱码日产精品bd| 91免费在线视频观看| 亚洲婷婷在线视频| 97se狠狠狠综合亚洲狠狠| 国产精品视频看| 欧美精品在线视频| 日韩精品成人一区二区在线| 欧美剧情片在线观看| 免费三级欧美电影| 欧美成人女星排行榜|