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

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

?? coder_bpbf.c

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

/*****

BP Binary Fast

*****/

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

extern int tune_param;

#define	VAL_CONTEXTS		16
#define	VAL_CONTEXT_MAX		(VAL_CONTEXTS -1)
#define SHAPE_BASE			VAL_CONTEXTS
#define SHAPE(x)			(SHAPE_BASE<<(x))
#define NUM_SHAPES			2
#define NUM_CONTEXTS		(VAL_CONTEXTS<<NUM_SHAPES)

#define SIGN_CONTEXTS	9

#define TOTMAX			4000
#define INC				30

#define P0_INIT			8
#define P1_INIT			0

#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)

void coderBPBF_encodeBandBP(coder *me,int *band,int w,int h,int fullw,int *parent,int);
void coderBPBF_decodeBandBP(coder *me,int *band,int w,int h,int fullw,int *parent,int);

typedef struct {
	int signs_p0[SIGN_CONTEXTS];
	int signs_pt[SIGN_CONTEXTS];
	int stats_p0[NUM_CONTEXTS];
	int stats_pt[NUM_CONTEXTS];
} myInfo;

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

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

	c->data = d;

	for(i=0;i<NUM_CONTEXTS;i++) {
		d->stats_p0[i] = P0_INIT+1; d->stats_pt[i] = 2+P0_INIT+P1_INIT;
	}

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

}

void coderBPBF_free(coder *c)
{
	if ( c->data ) {
		myInfo *d;
		d = c->data;
		free(d);
		c->data = NULL;
	}
}

coder coderBPBF = {
		"BP Bin Fast",
		coderBPBF_init,
		coderBPBF_free,
		NULL,NULL,
		coderBPBF_encodeBandBP,
		coderBPBF_decodeBandBP
	};

/**********

lazy way to pass the state from getStats to fixStats
	and also interacts with the codeBand()

these are re-initialized at each codeBand() call, so this is
	quite re-entrant as long as we aren't multi-threaded
	(that is, no more than one call to codeBand() at a time)

*********/

static int VD,donemask,nextmask,sign_context;

static int mcontext(int *dp,int pp,int x,int y,int fullw)
{
int P,N,W;
int context;

	/** <> all these absolute values are painfully slow ***/

	VD	= abs(*dp)&donemask;	// current val already done
	P	= abs(pp)&nextmask;

	sign_context = 0;

	if ( y == 0 ) {
		N = VD;
		if ( x == 0 ) W = VD; else W = abs(dp[-1]) & nextmask;
		if ( W ) {
			if ( isneg(dp[-1]) ) sign_context += 3;
			else sign_context += 6;
		}
	} else if ( x == 0 ) {
		W = VD;
		N  = abs(dp[-fullw])	& nextmask;
		if ( N ) {
			if ( isneg(dp[-fullw]) ) sign_context += 1;
			else sign_context += 2;
		}
	} else {
		N = abs(dp[-fullw])		& nextmask;
		W = abs(dp[-1])			& nextmask;
		if ( N ) {
			if ( isneg(dp[-fullw]) ) sign_context += 1;
			else sign_context += 2;
		}
		if ( W ) {
			if ( isneg(dp[-1]) ) sign_context += 3;
			else sign_context += 6;
		}
	}

	context = min(VAL_CONTEXT_MAX, ((VD + P + N + W)>>2));

	if ( N > VD ) context += VAL_CONTEXTS; 
	if ( W > VD ) context += VAL_CONTEXTS+VAL_CONTEXTS;

return context;
}

void coderBPBF_encodeBandBP(coder *me,int *band,int width,int height,int fullw,int *parent,int bitmask)
{
int x,y,bit,context;
int *dp,*pp;
arithInfo *ari = me->arith;
int *signs_p0,*signs_pt;
int *stats_p0,*stats_pt;

	stats_p0 = ((myInfo *)me->data)->stats_p0;
	stats_pt = ((myInfo *)me->data)->stats_pt;
	signs_p0 = ((myInfo *)me->data)->signs_p0;
	signs_pt = ((myInfo *)me->data)->signs_pt;

	for(x=bitmask,nextmask=0; x<(1<<29) ;x<<=1) nextmask += x;
	donemask = nextmask - bitmask;

	dp = band;	pp = parent;
	for(y=0;y<height;y++) {	
		if ( coder_timetostop(me) ) { coder_didstop(me,y); return; }
		for(x=0;x<width;x++) {

			context = mcontext(&dp[x],pp[x>>1],x,y,fullw);

			bit = (abs(dp[x])&bitmask)?1:0;
			bitEnc(bit,ari,stats_p0[context],stats_pt[context]);

			if ( bit && !VD ) {
				bitEnc( signbit(dp[x]) ,ari,signs_p0[sign_context],signs_pt[sign_context]);
			}
		}
		if ( y&1 ) pp += fullw;
		dp += fullw;
	}
}

void coderBPBF_decodeBandBP(coder *me,int *band,int width,int height,int fullw,int *parent,int bitmask)
{
int x,y,bit,context;
int *dp,*pp;
arithInfo *ari = me->arith;
int *signs_p0,*signs_pt;
int *stats_p0,*stats_pt;

	stats_p0 = ((myInfo *)me->data)->stats_p0;
	stats_pt = ((myInfo *)me->data)->stats_pt;
	signs_p0 = ((myInfo *)me->data)->signs_p0;
	signs_pt = ((myInfo *)me->data)->signs_pt;

	for(x=bitmask,nextmask=0; x<(1<<29) ;x<<=1) nextmask += x;
	donemask = nextmask - bitmask;

	dp = band;	pp = parent;
	for(y=0;y<height;y++) {
		if ( coder_timetostopd(me,y) )return;
		for(x=0;x<width;x++) {

			context = mcontext(&dp[x],pp[x>>1],x,y,fullw);

			bitDec(bit,ari,stats_p0[context],stats_pt[context]);

			if ( bit ) {
				if ( ! VD ) {
					bitDec(bit,ari,signs_p0[sign_context],signs_pt[sign_context]);
					if ( bit ) dp[x] = - bitmask;
					else dp[x] = bitmask;
				} else {
					if ( isneg(dp[x]) ) dp[x] -= bitmask;
					else dp[x] += bitmask; 
				}
			}
		}
		if ( y&1 ) pp += fullw;
		dp += fullw;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕一区日韩精品欧美| 99久久精品国产观看| 奇米影视7777精品一区二区| 亚洲一区中文日韩| 一区二区在线观看免费| 亚洲少妇最新在线视频| 亚洲欧美一区二区久久| 亚洲精品国产第一综合99久久| 亚洲欧美视频一区| 曰韩精品一区二区| 丝袜诱惑亚洲看片| 秋霞电影网一区二区| 激情图片小说一区| 国产成人丝袜美腿| 99精品国产91久久久久久| 一本大道av一区二区在线播放| 91日韩精品一区| 欧美亚洲图片小说| 欧美一区二区视频免费观看| 日韩欧美一级精品久久| 精品国产乱码久久久久久久| 亚洲国产精品成人久久综合一区| 亚洲欧洲一区二区三区| 亚洲一卡二卡三卡四卡| 日韩国产精品大片| 韩国视频一区二区| 成人毛片视频在线观看| 在线视频中文字幕一区二区| 制服丝袜激情欧洲亚洲| 精品日韩在线一区| 国产精品视频一二三区| 一区二区三区日本| 日韩高清在线不卡| 国产精品一二三四五| 91在线视频观看| 欧美日韩不卡在线| 久久久久国产一区二区三区四区| 一区在线播放视频| 日韩国产欧美在线观看| 成人深夜视频在线观看| 欧美日韩精品一区二区三区蜜桃 | 欧洲一区二区三区免费视频| 欧美精品国产精品| 久久综合成人精品亚洲另类欧美| 亚洲欧美日韩精品久久久久| 日韩中文字幕av电影| 国产白丝网站精品污在线入口| 欧美午夜一区二区三区免费大片| 日韩精品一区二区三区中文不卡| 中文字幕一区二区不卡| 日韩国产精品91| 99精品欧美一区二区蜜桃免费| 91精品国产一区二区三区| 中文字幕不卡的av| 奇米888四色在线精品| 成人午夜电影久久影院| 欧美日本一区二区三区| 国产精品传媒视频| 卡一卡二国产精品| 色综合夜色一区| 久久久久国产精品麻豆| 午夜国产精品影院在线观看| 成人一区二区三区在线观看| 制服丝袜亚洲网站| 亚洲另类春色校园小说| 国产黑丝在线一区二区三区| 在线成人午夜影院| 亚洲精品ww久久久久久p站| 美女视频黄a大片欧美| 在线观看亚洲专区| 国产女主播视频一区二区| 麻豆一区二区三区| 欧美视频完全免费看| 国产精品第一页第二页第三页| 久久精品久久综合| 欧美日韩一区视频| 综合激情成人伊人| 国产成人综合视频| 欧美一级片在线| 亚洲一区二区欧美| 91最新地址在线播放| 国产欧美一区二区精品性| 日本不卡一二三区黄网| 精品视频1区2区| 一区二区三区中文字幕精品精品| 国产精品123| 国产日韩欧美综合在线| 寂寞少妇一区二区三区| 日韩一区二区在线观看| 五月婷婷综合激情| 欧美撒尿777hd撒尿| 亚洲无线码一区二区三区| 色综合天天综合在线视频| 亚洲丝袜另类动漫二区| 成人精品鲁一区一区二区| 欧美国产日韩a欧美在线观看 | 欧美大尺度电影在线| 日韩电影在线看| 7878成人国产在线观看| 亚洲成人av在线电影| 在线观看不卡视频| 亚洲图片欧美综合| 欧美日韩久久久一区| 亚洲一区在线免费观看| 欧美日韩综合色| 视频一区二区国产| 欧美一级一区二区| 久久成人久久鬼色| 国产欧美综合在线观看第十页| 国产精品99久久不卡二区| 日本一区二区电影| av一区二区久久| 一区二区三区欧美视频| 欧美日韩一区久久| 全国精品久久少妇| 久久亚洲二区三区| 国产丶欧美丶日本不卡视频| 国产日韩欧美一区二区三区乱码| 成人午夜私人影院| 亚洲欧洲国产日本综合| 色爱区综合激月婷婷| 天天色 色综合| 精品久久久网站| 成人一区二区三区| 亚洲老司机在线| 欧美男同性恋视频网站| 精品中文av资源站在线观看| 国产日韩欧美精品电影三级在线| www.欧美色图| 亚洲一区在线观看免费 | 亚洲一区二区三区四区在线观看| 欧美视频三区在线播放| 奇米精品一区二区三区在线观看 | 亚洲欧洲成人精品av97| 色综合一个色综合亚洲| 亚洲sss视频在线视频| 91精品国产色综合久久| 国产精品自拍在线| 一区二区视频免费在线观看| 欧美一区二区三区视频在线观看| 国产精品91一区二区| 亚洲精品v日韩精品| 欧美v日韩v国产v| 97精品久久久久中文字幕| 亚洲第一福利视频在线| 久久久久久夜精品精品免费| 97久久精品人人做人人爽50路| 视频一区二区不卡| 中文字幕巨乱亚洲| 欧美老女人在线| 成人午夜电影久久影院| 婷婷开心激情综合| 国产婷婷色一区二区三区在线| 欧美性猛交xxxxxx富婆| 国产精品一区2区| 午夜视黄欧洲亚洲| 国产精品大尺度| 精品国内片67194| 91传媒视频在线播放| 国产最新精品精品你懂的| 一区二区三区加勒比av| 国产欧美综合色| 91精品国产品国语在线不卡| 91在线视频观看| 精品写真视频在线观看| 夜夜嗨av一区二区三区中文字幕| 久久综合九色综合97_久久久| 欧美日本在线视频| 91天堂素人约啪| 成人性色生活片免费看爆迷你毛片| 天天操天天干天天综合网| 综合色天天鬼久久鬼色| 久久青草国产手机看片福利盒子| 欧美男女性生活在线直播观看| 成人av高清在线| 国产传媒日韩欧美成人| 日韩国产欧美在线播放| 一区二区在线看| 国产精品动漫网站| 26uuu国产电影一区二区| 欧美日韩国产成人在线免费| 91在线免费看| 成+人+亚洲+综合天堂| 精品系列免费在线观看| 日本大胆欧美人术艺术动态| 亚洲黄色av一区| 综合久久久久综合| 国产精品视频第一区| 久久综合色综合88| 日韩视频123| 日韩亚洲欧美综合| 777精品伊人久久久久大香线蕉| 色av成人天堂桃色av| 高清国产一区二区| 韩国一区二区三区| 紧缚奴在线一区二区三区| 奇米精品一区二区三区四区 | 高清国产一区二区| 国产乱码字幕精品高清av| 日本在线不卡视频|