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

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

?? codezt.c

?? 好東西呢
?? C
字號:

// <> "stop" functionality needed

//#define WRITE_ZT
#define WRITE_ZT_PLANE 7

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <crblib/inc.h>
#include <crblib/arithc.h>
#include <crblib/codeutil.h>
#include "coder.h"
#include "image.h"

#define SIGN_CONTEXTS		4

#define TOTMAX			4000
#define INC				30

#define bitModel(bit,P0,PT)		do { PT += INC; if (!(bit)) P0 += INC;  if ( PT > TOTMAX ) { PT >>= 1; P0 >>= 1; P0++; PT += 2; } } while(0)
#define bitEnc(bit,ari,P0,PT)	do { arithEncBit(ari,P0,PT,bit);	bitModel(bit,P0,PT); } while(0)
#define bitDec(bit,ari,P0,PT)	do { bit = arithDecBit(ari,P0,PT);	bitModel(bit,P0,PT); } while(0)

typedef struct {
	arithInfo *ari;
	int signs_p0[SIGN_CONTEXTS],signs_pt[SIGN_CONTEXTS];
} signInfo;

void * initSigns(arithInfo *ari);
void freeSigns(void *sign_coder);

void encodeSigns(signInfo *me,int *band,int w,int h,int fullw,int *parent);
void decodeSigns(signInfo *me,int *band,int w,int h,int fullw,int *parent);

void * initSigns(arithInfo *ari)
{
signInfo *d;
int i;

	if ( (d = new(signInfo)) == NULL )
		errexit("ozero init failed");

	d->ari = ari;

	for(i=0;i<SIGN_CONTEXTS;i++) {
		d->signs_p0[i] = 100;
		d->signs_pt[i] = 200;
	}
return d;
}

void freeSigns(signInfo *d)
{
	if ( d ) {
		free(d);
	}
}

void encodeSigns(signInfo *me,int *band,int width,int height,int fullw,int *parent)
{
int x,y,context; //,V;
int *dp;
arithInfo *ari;
int *signs_p0,*signs_pt;

	ari = me->ari;
	signs_p0 = me->signs_p0;
	signs_pt = me->signs_pt;

	dp = band;

	for(x=0;x<width;x++) {
		if ( *dp == 0 ) { dp++; continue; }
		if ( x == 0 ) context = 0;
		else context = (dp[-1]&1);
		bitEnc((*dp&1),ari,signs_p0[context],signs_pt[context]);
		dp++;
	}
	dp += fullw - width;

	for(y=1;y<height;y++) {
		if ( *dp == 0 ) dp++;
		else {
			context = ((dp[-fullw]&1)<<1);
			bitEnc((*dp&1),ari,signs_p0[context],signs_pt[context]);
			dp++;
		}

		for(x=1;x<width;x++) {
			if ( *dp == 0 ) { dp++; continue; }
			context = (dp[-1]&1) + ((dp[-fullw]&1)<<1);

			bitEnc((*dp&1),ari,signs_p0[context],signs_pt[context]);
			dp++;
		}
		dp += fullw - width;
	}
}

void decodeSigns(signInfo *me,int *band,int width,int height,int fullw,int *parent)
{
int x,y,sign,context;
int *dp;
arithInfo *ari;
int *signs_p0,*signs_pt;

	ari = me->ari;
	signs_p0 = me->signs_p0;
	signs_pt = me->signs_pt;

	dp = band;

	for(x=0;x<width;x++) {
		if ( *dp == 0 ) { dp++; continue; }
		if ( x == 0 ) context = 0;
		else context = (dp[-1]&1);
		bitDec(sign,ari,signs_p0[context],signs_pt[context]);
		*dp++ += sign;
	}
	dp += fullw - width;

	for(y=1;y<height;y++) {

		if ( *dp == 0 ) dp++;
		else {
			context = ((dp[-fullw]&1)<<1);
			bitDec(sign,ari,signs_p0[context],signs_pt[context]);
			*dp++ += sign;
		}

		for(x=1;x<width;x++) {
			if ( *dp == 0 ) { dp++; continue; }
			context = (dp[-1]&1) + ((dp[-fullw]&1)<<1);

			bitDec(sign,ari,signs_p0[context],signs_pt[context]);
			*dp++ += sign;
		}
		dp += fullw - width;
	}
}


void findZeroTrees(image *im,int bits,int levels,int offx,int offy)
{
int *fmband,*toband,*fmp,*top;
int x,y,l,w,h,wt,ht,fullw,p;
int bitmask;

	bitmask = (1<<bits) + FLAG_ISOLATED_ZERO;

	fullw = im->width;
	for(p=0;p<im->planes;p++) {

		for(l=1;l<levels;l++) {	//** don't do very top level, cuz that would use the LL as parents

			w = (im->width) >>l;
			h = (im->height)>>l;
			wt = w>>1;
			ht = h>>1;
			fmband = im->data[p][h *offy] + w *offx;
			toband = im->data[p][ht*offy] + wt*offx;

			fmp = fmband; top = toband;
			for(y=0;y<ht;y++) {
				for(x=0;x<wt;x++) {
					if ( (*top&bitmask) == 0 ) {	// *top might be a zerotree, (if not, nothing to do)
						if ( ((fmp[0]&bitmask) + (fmp[1]&bitmask) + (fmp[fullw]&bitmask) + (fmp[fullw+1]&bitmask)) == 0 ) { // all kids zero
							// if *top is zero, it can stay zero to be a zero-tree
							// change kids of zerotree roots to children
							fmp[0] |= FLAG_CHILD_ZERO;
							fmp[1] |= FLAG_CHILD_ZERO;
							fmp[fullw  ] |= FLAG_CHILD_ZERO;
							fmp[fullw+1] |= FLAG_CHILD_ZERO;
						} else {
							*top |= FLAG_ISOLATED_ZERO; // label as an isolated zero
						}
					}
					top ++;
					fmp += 2;
				}
				top += fullw - wt;
				fmp += fullw + fullw - w;
			}
		}
	}
}


void encodeImageZT(coder * encoder,image *im,int levels)
{
int top_val,top_bitpn,bits;
int *dp,x,y,**rows;
int p,l,sizeX,sizeY;
void *sign_coder;

	if ( ! encoder->encodeBandZT ) errexit("don't call imageZT unless you mean it!");

	top_val = 0;

	for(p=0;p<im->planes;p++) {
		rows = im->data[p];

		/** global pre-pass : remove signs & find top_val **/

		sizeX = (im->width) >> levels;
		sizeY = (im->height) >> levels;
		for(y=0;y<(im->height);y++) {
			dp = rows[y];
			if ( y < sizeY ) { x = sizeX; dp += sizeX; }
			else x = 0;
			for(;x<(im->width);x++) {
				if ( isneg(*dp) ) *dp = 1 - (*dp + *dp);
				else *dp += *dp;
				if ( *dp > top_val ) top_val = *dp;
				dp++;
			}
		}
	}

	for(top_bitpn=0;(1<<(top_bitpn+1))<=top_val;top_bitpn++) ;

	cu_putExpanding_ari(top_bitpn,encoder->arith,16,8);

	for(bits = top_bitpn;bits>=1;bits--) {
		findZeroTrees(im,bits,levels,1,0);
		findZeroTrees(im,bits,levels,0,1);
		findZeroTrees(im,bits,levels,1,1);

#ifdef WRITE_ZT
		if ( bits == WRITE_ZT_PLANE ) {	/** write out a zero tree map **/
			image *zt_im;
			int r,*ptr,bitmask;
			zt_im = copyImage(im);

			for(p=0;p>im->planes;p++) {
				ptr = zt_im->data[p][0][0]; bitmask = 1<<bits;
				for(r=zt_im->plane_size;r--;) {
					if ( *ptr & bitmask ) *ptr++ = 255;
					else { 
						*ptr = ((*ptr>>(CODE_MAX_BPN+1))<<6); ptr++; 
					}
					/** 256 is on
						128	is isolated
						 64 is child
						  0 is root
					****/

					ptr[-1] -= 0x80;
				}
			}

			writeImageFile("zerotree.raw",zt_im);

			freeImage(zt_im);
		}
#endif			/** end zero-tree writing **/

		for (l = levels; l > 0; l--) {
			sizeX = (im->width) >> l;
			sizeY = (im->height) >> l;

			for(p=0;p<im->planes;p++) {
				rows = im->data[p];

				encoder->encodeBandZT(encoder,rows[0] + sizeX,	sizeX, sizeY,bits,im->width,rows); 
				encoder->encodeBandZT(encoder,rows[sizeY],		sizeX, sizeY,bits,im->width,rows); 
				encoder->encodeBandZT(encoder,rows[sizeY]+sizeX,sizeX, sizeY,bits,im->width,rows); 
			}
		}
	}

	sign_coder = initSigns(encoder->arith);			
	for(p=0;p<im->planes;p++) {
		rows = im->data[p];
		for (l = levels; l > 0; l--) {
			sizeX = (im->width) >> l;
			sizeY = (im->height) >> l;
			encodeSigns(sign_coder,rows[0] + sizeX	,	sizeX, sizeY, im->width,rows[0] + (sizeX>>1));
			encodeSigns(sign_coder,rows[sizeY]		,	sizeX, sizeY, im->width,rows[(sizeY>>1)]);
			encodeSigns(sign_coder,rows[sizeY]+sizeX,	sizeX, sizeY, im->width,rows[(sizeY>>1)]+ (sizeX>>1));
		}
	}
	freeSigns(sign_coder);
}

void decodeImageZT(coder * decoder,image *im,int levels)
{
int l,sizeX,sizeY,x,y,*dp;
int **rows;
int top_bitpn,bits,p;
void *sign_coder;

	top_bitpn = cu_getExpanding_ari(decoder->arith,16,8);

	for(bits = top_bitpn;bits>=1;bits--) {
		for (l = levels; l > 0; l--) {
			for(p=0;p<im->planes;p++) {
				rows = im->data[p];

				sizeX = (im->width) >> l;
				sizeY = (im->height) >> l;

				decoder->decodeBandZT(decoder,rows[0] + sizeX,	sizeX, sizeY,bits,im->width,rows); 
				decoder->decodeBandZT(decoder,rows[sizeY],		sizeX, sizeY,bits,im->width,rows);
				decoder->decodeBandZT(decoder,rows[sizeY]+sizeX,sizeX, sizeY,bits,im->width,rows);
			}
		}
	}

	sign_coder = initSigns(decoder->arith);
	for(p=0;p<im->planes;p++) {
		rows = im->data[p];
		for (l = levels; l > 0; l--) {
			sizeX = (im->width) >> l;
			sizeY = (im->height) >> l;

			decodeSigns(sign_coder,rows[0] + sizeX	,	sizeX, sizeY, im->width,rows[0] + (sizeX>>1));
			decodeSigns(sign_coder,rows[sizeY]		,	sizeX, sizeY, im->width,rows[(sizeY>>1)]);
			decodeSigns(sign_coder,rows[sizeY]+sizeX,	sizeX, sizeY, im->width,rows[(sizeY>>1)]+ (sizeX>>1));
		}
	}
	freeSigns(sign_coder);

		/** global post-pass : restore signs 
		*	(<> decodeSigns could do this for us, but that would require him to
		*		do an if() when he builds contexts) 
		**/
	
	for(p=0;p<im->planes;p++) {
		rows = im->data[p];
		sizeX = (im->width) >> levels;
		sizeY = (im->height) >> levels;
		for(y=0;y<im->height;y++) {
			dp = rows[y];
			if ( y < sizeY ) { x = sizeX; dp += sizeX; }
			else x = 0;
			for(;x<im->width;x++) {
				if ( *dp & 1 ) *dp++ = - ((*dp)>>1);
				else *dp++ >>= 1;
			}
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区久久| 日韩一区二区三区精品视频| 色94色欧美sute亚洲13| 欧美日韩精品一区视频| 日韩一区二区三免费高清| 国产欧美一区二区精品性| 亚洲女与黑人做爰| 日韩国产欧美在线播放| 激情图片小说一区| 91免费国产在线观看| 制服丝袜av成人在线看| 色婷婷综合久久久久中文| 精品视频一区 二区 三区| 日韩欧美成人一区| 日韩欧美另类在线| 2023国产精品自拍| 国产精品久久久久久亚洲毛片| 一区二区三区四区不卡在线| 久久99久久精品| 一本一道综合狠狠老| 日韩欧美国产综合一区| 亚洲人快播电影网| 久久精品噜噜噜成人av农村| 91网站视频在线观看| 欧美va日韩va| 亚洲在线成人精品| 国产一区二区不卡| 欧美精品粉嫩高潮一区二区| 国产精品入口麻豆原神| 人人狠狠综合久久亚洲| 99久精品国产| 久久亚洲影视婷婷| 视频一区二区欧美| 色嗨嗨av一区二区三区| 久久久久久久性| 亚洲男人都懂的| 国产一区免费电影| 欧美性受xxxx| 欧美—级在线免费片| 喷水一区二区三区| 91老司机福利 在线| 久久综合久久综合亚洲| 午夜私人影院久久久久| 99国产精品久久久久| 久久久久久久久伊人| 青青国产91久久久久久| 欧洲人成人精品| 中文字幕视频一区二区三区久| 久久97超碰国产精品超碰| 国产一区福利在线| 91官网在线观看| 中文字幕一区二区三区四区不卡| 美女看a上一区| 精品一区二区在线看| www.日韩精品| 欧美国产成人精品| 国产精品白丝jk黑袜喷水| 日韩欧美另类在线| 美女在线视频一区| 6080国产精品一区二区| 五月天久久比比资源色| 91麻豆福利精品推荐| 国产精品拍天天在线| 国产中文字幕一区| 亚洲大片免费看| 91丝袜美腿高跟国产极品老师 | 国产女同互慰高潮91漫画| 裸体歌舞表演一区二区| 欧美一区永久视频免费观看| 亚洲五码中文字幕| 欧美日韩在线不卡| 亚洲综合图片区| 99精品在线观看视频| 日本一区二区不卡视频| 国产九色精品成人porny | 成人精品电影在线观看| 国产人伦精品一区二区| 成人丝袜视频网| 中文字幕中文字幕一区| 91在线云播放| 亚洲永久精品大片| 欧美女孩性生活视频| 日韩精品一二三区| 日韩久久久精品| 韩日av一区二区| 国产情人综合久久777777| 国产**成人网毛片九色| 国产精品情趣视频| 在线观看91精品国产入口| 91视频观看免费| 国产欧美日韩精品a在线观看| 国精产品一区一区三区mba桃花| 精品久久久久久久久久久院品网 | 久久综合精品国产一区二区三区| 日本中文一区二区三区| 日韩精品影音先锋| 国产一区二区成人久久免费影院| 国产精品网站导航| 91成人看片片| 日韩成人午夜电影| 精品国产乱码久久久久久1区2区| 蜜臀91精品一区二区三区 | 日韩女同互慰一区二区| 精品一区二区三区在线观看国产| 久久色成人在线| 91色九色蝌蚪| 日韩中文字幕不卡| 久久久久9999亚洲精品| 99精品桃花视频在线观看| 亚洲va在线va天堂| 久久亚洲一区二区三区四区| av成人免费在线| 视频一区二区中文字幕| 欧美激情在线一区二区三区| 日本精品视频一区二区| 捆绑紧缚一区二区三区视频| 中文字幕二三区不卡| 欧美日韩另类国产亚洲欧美一级| 黑人巨大精品欧美黑白配亚洲| 亚洲日穴在线视频| 日韩精品一区二区三区视频| 波多野结衣中文字幕一区 | 欧美不卡一区二区三区| 成人动漫在线一区| 日韩中文字幕1| 中文成人av在线| 91精品久久久久久久91蜜桃| 成人午夜激情视频| 美女视频一区在线观看| 91精品中文字幕一区二区三区| 国产高清亚洲一区| 亚洲精品高清在线观看| 欧美va亚洲va| 欧美三级电影一区| 国产成人h网站| 三级在线观看一区二区| 国产精品国产精品国产专区不蜜| 91精品国产综合久久久蜜臀粉嫩 | 国产精品乱码人人做人人爱| 91精品国产综合久久精品性色| 不卡电影一区二区三区| 日韩影视精彩在线| 欧洲一区二区av| 另类专区欧美蜜桃臀第一页| 亚洲女爱视频在线| 久久久国产精品不卡| 在线播放91灌醉迷j高跟美女| 国产69精品久久久久毛片 | 精品久久久久久久一区二区蜜臀| 欧美优质美女网站| 成人国产亚洲欧美成人综合网| 日韩电影在线一区二区| 伊人色综合久久天天| 日本一区二区免费在线| 日韩视频一区二区三区| 欧美影院一区二区三区| 97精品超碰一区二区三区| 国产一区二区三区四| 免费不卡在线观看| 精品一区二区三区在线观看国产| 色婷婷av一区二区三区之一色屋| 国产在线精品视频| 日韩电影在线观看电影| 亚洲自拍偷拍综合| ...xxx性欧美| 欧美国产一区二区在线观看| 26uuu另类欧美| 日韩视频一区二区| 91精品国产免费久久综合| 欧美午夜不卡视频| 色综合色综合色综合| 不卡一区中文字幕| 从欧美一区二区三区| 国产精品一二三四| 国产乱码精品一品二品| 狠狠久久亚洲欧美| 国产一区二区福利视频| 国产乱子伦视频一区二区三区| 开心九九激情九九欧美日韩精美视频电影 | 亚洲色图欧洲色图婷婷| 色哟哟国产精品| 91在线观看下载| 99久久精品费精品国产一区二区| 国产一区二区三区精品欧美日韩一区二区三区| 视频一区二区不卡| 男女性色大片免费观看一区二区| 视频一区国产视频| 蜜臀av性久久久久蜜臀aⅴ流畅 | 日本精品一区二区三区高清| 日本道色综合久久| 欧洲av一区二区嗯嗯嗯啊| 欧美在线一区二区| 欧美日韩一级二级三级| 欧美久久久久久久久久| 91精品国产91久久久久久最新毛片| 欧美日韩不卡在线| 日韩一区二区三区四区| 精品1区2区在线观看| 国产午夜精品一区二区三区嫩草 | 欧美a级理论片|