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

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

?? coder_bitplane.c

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

coder_bitplane : send bitplanes ; this is an "EZ" coder,
	except that our calling structures ruins the embedding

old style : call be Band order ; compare to coder_bp

*****/

#include <stdio.h>
#include <stdlib.h>
#include <crblib/inc.h>
#include <crblib/arithc.h>
#include <crblib/scontext.h>
#include <crblib/codeutil.h>

extern int tune_param;

/*** some convenient debug routines:
** #define SEND_TAG()	if(0); else { arithEncode(ari,43,44,77); }
** #define GET_TAG()	if(0); else { int got; got = arithGet(ari,77); arithDecode(ari,43,44,77); if ( got != 43 ) errexit("tag failure"); }
********/

#define ORDER1_CONTEXTS		10
#define ORDER1_ALPHABET		16	//4 bits

#define ORDER1_TOTMAX		15000
#define ORDER1_INC			30

#include "coder.h"

void coderBitPlane_encodeBand(coder *me,int *band,int w,int h,int fullw,int *parent);
void coderBitPlane_decodeBand(coder *me,int *band,int w,int h,int fullw,int *parent);

typedef struct {
	scontext ** o1;
} myInfo;

void coderBitPlane_init(coder *c)
{
myInfo *d;
int i;

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

	c->data = d;

	if ( (d->o1 = newarray(void *,ORDER1_CONTEXTS)) == NULL )
		errexit("Order1_Init failed!");

	for(i=0;i<ORDER1_CONTEXTS;i++) {
		if ( (d->o1[i] = scontextCreate(c->arith,ORDER1_ALPHABET,0,
				ORDER1_TOTMAX,ORDER1_INC,true)) == NULL )
			errexit("context creation failed!");
	}
}

void coderBitPlane_free(coder *c)
{
	if ( c->data ) {
		myInfo *d;
		d = c->data;
		if ( d->o1 ) {
			int i;
			for(i=0;i<ORDER1_CONTEXTS;i++) {
				if ( d->o1[i] ) scontextFree(d->o1[i]);
			}
		}
		free(d);
		c->data = NULL;
	}
}

coder coderBitPlane = {
		"BP by Band",
		coderBitPlane_init,
		coderBitPlane_free,
		coderBitPlane_encodeBand,
		coderBitPlane_decodeBand
	};

void coderBitPlane_encodeBand(coder *me,int *band,int width,int height,int fullw,int *parent)
{
int x,y,val; //,cntx;
int *dp,*pp,*dpn;
int top_val,top_bitpn;
int context,block,par,A,B,C,D;
int bitmask,donemask,nextmask;
scontext **o1 = ((myInfo *)me->data)->o1;
arithInfo *ari = me->arith;

	dp = band;	top_val = 0;
	for(y=0;y<height;y++) {
		for(x=0;x<width;x++) {
			val = *dp++; val = abs(val);
			if ( val > top_val ) top_val = val; 
		}
		dp += fullw - width;
	}
	for(top_bitpn=0;(1<<(top_bitpn+1))<=top_val;top_bitpn++) ;

	cu_putExpanding_ari(top_bitpn,ari,8,8);
	top_val = 1<<top_bitpn;

	nextmask= (int)0xFFFFFF - (top_val+top_val-1);

	for(bitmask = top_val;bitmask>=1;bitmask>>=1) {
		donemask = nextmask;
		nextmask = donemask + bitmask;

		dp = band;	pp = parent;
		for(y=0;y<height;y+=2) {
			if ( coder_timetostop(me) ) { dbf(); coder_didstop(me,y); return; }
			dpn = dp + fullw;
			for(x=0;x<width;x+=2) {	/** x & y are the parent's location *2 **/
				par = abs(pp[x>>1]);
				A = abs(dp[x]);		B = abs(dp[x+1]);
				C = abs(dpn[x]);	D = abs(dpn[x+1]);

				context = ((A & donemask)?1:0) + ((B & donemask)?1:0) + ((C & donemask)?1:0) + ((D & donemask)?1:0);
				if (par&nextmask) context += 5;

				block = 0; // 4 bits
				if ( A & bitmask ) block += 1;
				if ( B & bitmask ) block += 2;
				if ( C & bitmask ) block += 4;
				if ( D & bitmask ) block += 8;

				scontextEncode(o1[context],block);

				/** send signs when we see the first 'on' bit **/

				if ( (A & nextmask) == bitmask ) arithBit(ari, signbit(dp[x]   ));
				if ( (B & nextmask) == bitmask ) arithBit(ari, signbit(dp[x+1] ));
				if ( (C & nextmask) == bitmask ) arithBit(ari, signbit(dpn[x]  ));
				if ( (D & nextmask) == bitmask ) arithBit(ari, signbit(dpn[x+1]));	

			}
			pp += fullw;
			dp += fullw + fullw;
		}
	}
}

void coderBitPlane_decodeBand(coder *me,int *band,int width,int height,int fullw,int *parent)
{
int x,y,val; //,cntx,sign;
int *dp,*pp,*dpn;
int top_val,top_bitpn;
int context,block,A,B,C,D;
int bitmask,donemask,nextmask;
scontext **o1 = ((myInfo *)me->data)->o1;
arithInfo *ari = me->arith;

#define SIGN_MASK (1<<30)

/**** done in mainline now
	dp = band;
	for(y=0;y<height;y++) {
		for(x=0;x<width;x++) *dp++ = 0;
		dp += fullw - width;
	}
*********/

	top_bitpn = cu_getExpanding_ari(ari,8,8);
	top_val = 1<<top_bitpn;

	nextmask= (int)0xFFFFFF - (top_val+top_val-1);

	for(bitmask = top_val;bitmask>=1;bitmask>>=1) {
		donemask = nextmask;
		nextmask = donemask + bitmask;
		dp = band;	pp = parent;
		for(y=0;y<height;y+=2) {
			if ( coder_timetostopd(me,y) ) { dbf(); goto fix_signs; }
			dpn = dp + fullw;
			for(x=0;x<width;x+=2) {

				A = dp[x];	B = dp[x+1];
				C = dpn[x];	D = dpn[x+1];
				context = ((A & donemask)?1:0) + ((B & donemask)?1:0) + ((C & donemask)?1:0) + ((D & donemask)?1:0);
				val = abs(pp[x>>1]);
				if (val&nextmask) context += 5;

				block = scontextDecode(o1[context]);

				if ( block & 1 ) { dp[x]	+= bitmask; if ( ! (A&donemask) ) dp[x] += arithGetBit(ari)?SIGN_MASK:0; }
				if ( block & 2 ) { dp[x+1]	+= bitmask; if ( ! (B&donemask) ) dp[x+1] += arithGetBit(ari)?SIGN_MASK:0; }
				if ( block & 4 ) { dpn[x]  	+= bitmask; if ( ! (C&donemask) ) dpn[x] += arithGetBit(ari)?SIGN_MASK:0; }
				if ( block & 8 ) { dpn[x+1]	+= bitmask; if ( ! (D&donemask) ) dpn[x+1] += arithGetBit(ari)?SIGN_MASK:0; }
			}
			pp += fullw;
			dp += fullw + fullw;
		}
	}

	/** signs **/		fix_signs:

	dp = band;
	for(y=0;y<height;y++) {
		for(x=0;x<width;x++) {
			if ( *dp & SIGN_MASK ) {
				*dp -= SIGN_MASK;
				*dp = - *dp;
			}
			dp++;
		}
		dp += fullw - width;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品福利在线导航| 亚洲曰韩产成在线| 国产精品丝袜久久久久久app| 久久久蜜臀国产一区二区| 中文字幕精品一区二区精品绿巨人| 国产精品精品国产色婷婷| 国产午夜亚洲精品午夜鲁丝片| 亚洲激情男女视频| 国产一区二区按摩在线观看| 91天堂素人约啪| 欧美一区二视频| 日韩视频在线你懂得| 中文字幕一区二区不卡| 日韩不卡在线观看日韩不卡视频| 粉嫩欧美一区二区三区高清影视| 欧美中文字幕一区二区三区亚洲| 欧美伊人精品成人久久综合97| 国产免费观看久久| 亚洲男同性恋视频| 国产福利电影一区二区三区| 欧美性受xxxx黑人xyx性爽| 中文字幕免费不卡| 久久超碰97中文字幕| 91免费观看在线| 国产亚洲精品超碰| 亚洲国产色一区| 色94色欧美sute亚洲线路一久| 欧美一区二区三区色| 亚洲免费三区一区二区| 黑人巨大精品欧美一区| 在线免费观看不卡av| 国产午夜一区二区三区| 日本不卡免费在线视频| 日本道色综合久久| 欧美大胆人体bbbb| 麻豆中文一区二区| 欧美日韩国产精品自在自线| 国产精品久久久久久久蜜臀| 国产在线精品一区二区三区不卡| 色诱视频网站一区| 有坂深雪av一区二区精品| 白白色 亚洲乱淫| 久久久国际精品| 国产在线精品不卡| 在线观看亚洲a| 一区二区三区精品视频| 97国产精品videossex| 国产精品入口麻豆原神| 国产成人精品免费一区二区| 久久九九久久九九| 国产不卡视频在线观看| 国产夜色精品一区二区av| 国产福利精品一区| 国产精品免费丝袜| 欧美亚洲综合网| 欧美国产成人在线| 懂色中文一区二区在线播放| 欧美一区二区三区思思人| 国产一区二区导航在线播放| 久久久久成人黄色影片| 粉嫩绯色av一区二区在线观看| 国产精品视频免费看| 99re视频精品| 日韩电影免费在线看| 精品毛片乱码1区2区3区| 国产精品亚洲综合一区在线观看| 久久久久久久综合| av欧美精品.com| 丝袜a∨在线一区二区三区不卡| 欧美日韩在线不卡| 精品一区二区在线看| 国产亚洲精品福利| 色婷婷综合视频在线观看| 日本不卡高清视频| 久久久99精品久久| 91蜜桃免费观看视频| 亚洲v日本v欧美v久久精品| 日韩一二三区视频| 国产亚洲精品7777| 麻豆精品久久久| 1024亚洲合集| 欧美成人三级在线| 91国产免费看| 国产黄色精品网站| 久久国产精品72免费观看| 自拍偷拍国产精品| 精品盗摄一区二区三区| 在线观看国产精品网站| 国产成人精品影院| 日韩国产在线观看| 一区二区三区欧美久久| 国产亚洲婷婷免费| 日韩丝袜美女视频| 欧美日韩一级片网站| av在线播放成人| 国产成人亚洲综合a∨猫咪| 蜜臀av一区二区在线观看| 亚洲欧洲精品天堂一级| 久久精品夜色噜噜亚洲aⅴ| 在线播放中文一区| 欧美日韩久久不卡| 一道本成人在线| 国产91在线|亚洲| 国产美女精品人人做人人爽 | 91亚洲永久精品| 国产综合久久久久久鬼色| 日韩电影一区二区三区四区| 亚洲第一激情av| 一区二区三区中文在线观看| 综合久久一区二区三区| 国产精品久久三区| 国产精品传媒视频| 国产精品乱码人人做人人爱| 精品精品国产高清a毛片牛牛| 欧美一区二区三区在线视频| 欧美色手机在线观看| 在线观看精品一区| 欧美军同video69gay| 欧美精品一级二级| 欧美图区在线视频| 欧美视频中文字幕| 在线视频观看一区| 欧美日韩视频在线观看一区二区三区 | 成人激情黄色小说| 狠狠色综合播放一区二区| 国产精品一区二区视频| 精品无人区卡一卡二卡三乱码免费卡| 久久国产麻豆精品| 全部av―极品视觉盛宴亚洲| 麻豆精品在线看| 麻豆国产91在线播放| 国产成人av资源| 99久久免费视频.com| 色综合天天综合网天天看片| 欧美中文字幕一区二区三区亚洲| 色综合天天综合狠狠| 欧美日韩在线三区| 欧美一区二区三区视频免费| 久久久久久久综合狠狠综合| 久久欧美中文字幕| 亚洲免费观看高清在线观看| 一区二区三区国产豹纹内裤在线| 亚洲国产精品一区二区www| 中文字幕视频一区二区三区久| 亚洲激情成人在线| 亚洲精品国久久99热| 亚洲一区在线观看视频| 免播放器亚洲一区| 九九视频精品免费| 99精品视频免费在线观看| 色天天综合久久久久综合片| 欧美一区2区视频在线观看| 日韩精品专区在线| 日韩伦理电影网| 亚洲aⅴ怡春院| 福利一区二区在线| 欧美精品粉嫩高潮一区二区| 久久久精品综合| 亚洲国产日产av| 日本中文字幕一区二区视频| 从欧美一区二区三区| 色婷婷亚洲综合| 久久久久久毛片| 亚洲一二三四区| 国产高清成人在线| 宅男在线国产精品| 久久精品夜夜夜夜久久| 日韩av一区二区三区| 国产精品亚洲一区二区三区在线| 精品视频免费在线| 精品第一国产综合精品aⅴ| 最新国产の精品合集bt伙计| 三级久久三级久久久| 色哟哟国产精品| 久久中文娱乐网| 奇米一区二区三区| 色呦呦日韩精品| 久久精品免费在线观看| 蜜臀99久久精品久久久久久软件| 狠狠网亚洲精品| 日韩手机在线导航| 一区二区三区不卡在线观看| 风间由美一区二区三区在线观看| 欧美一区二区三区不卡| 最新不卡av在线| 波多野结衣亚洲| 日韩视频一区二区在线观看| 亚洲国产一区视频| 成人免费观看av| 国产精品视频第一区| 日韩成人一区二区| 91国产视频在线观看| 中文字幕欧美一| 国产综合久久久久影院| 日韩你懂的在线播放| 亚洲小说欧美激情另类| 色久优优欧美色久优优| 亚洲视频 欧洲视频| 国产成人在线视频网站| 国产午夜精品美女毛片视频|