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

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

?? coder_o1_sb.c

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

/*********

Order1 SB : context-code MSB position like order1+1 ,
	then code residual bits.

	(o1_sb is good on 'circles' and golf data;
	competitive with bitplane and order2)

S+P (512) Lossless :

			Lena	Zelda	Kuha	Checa(256)
Order1 	:	4.250	3.948	3.534	3.406
Order1+1:	4.207	3.911	3.517	3.310
Order1sb:	4.216	3.920	3.510	3.305

We seem to beat 1+1 on the very-compressible files, while
we lose on the less compressible files (though this is not
a uniform trend; for example we have identical performance
on Barbara at 4.678 bpp)

SB seams to always beat 1+1 slightly on non-lossless packing,
but this is a moot point because BitPlane stomps them both
for lossy; (bitplane is behind even plain order1 for lossless;
very strange)

(bitplane on the lossy and order1+1 on the deltas is the best
for lossy+delta , but that's again moot because S+P stomps
on lossy+delta).

**********/

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

extern int tune_param;

#define ORDER1_TOTMAX		10000
#define ORDER1_INC			30
#define ORDER1_RAWS			2
#define ORDER1_ALPHABET		(16 + ORDER1_RAWS)	/** # of bits **/

#define CN_MAX_PREV			4
#define CN_MAX_PARENT		4
#define CODE_CONTEXTS 		(1 + CN_MAX_PREV + (CN_MAX_PREV+1)*CN_MAX_PARENT)

#define ORDER0_TOTMAX		16000	/** totally irrelevant **/
#define ORDER0_ALPHABET		2		/** binary **/
#define ORDER0_INC			10

// #define CODER_ADAPT	/** doesn't help **/

#include "coder.h"

void coderO1_SB_encodeBand(coder *me,int *band,int w,int h,int fullw,int *parent);
void coderO1_SB_decodeBand(coder *me,int *band,int w,int h,int fullw,int *parent);

typedef struct {
	scontext * o0;
	scontext * sign_sc[3];
	scontext ** o1;
	arithInfo *ari;
} myInfo;

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

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

	c->data = d;
	d->ari = c->arith;

	if ( (d->o0 = scontextCreate(c->arith,ORDER0_ALPHABET,0,
			ORDER0_TOTMAX,ORDER0_INC,true)) == NULL )
		errexit("ozero init failed");

	for(i=0;i<3;i++) {
		if ( (d->sign_sc[i] = scontextCreate(c->arith,2,0,1000,10,true)) == NULL )
			errexit("sign ozero init failed");
	}

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

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

void coderO1_SB_free(coder *c)
{
	if ( c->data ) {
		myInfo *d; int i;

		d = c->data;
		if ( d->o0 ) scontextFree(d->o0);
		for(i=0;i<3;i++) {
			if ( d->sign_sc[i] ) scontextFree(d->sign_sc[i]);
		}
		if ( d->o1 ) {
			for(i=0;i<CODE_CONTEXTS;i++) {
				if ( d->o1[i] ) scontextFree(d->o1[i]);
			}
		}
		free(d);
		c->data = NULL;
	}
}

coder coderO1_SB = {
		"SigBit",
		coderO1_SB_init,
		coderO1_SB_free,
		coderO1_SB_encodeBand,
		coderO1_SB_decodeBand
	};

static void mcontext(int *cur_ptr,int parent,int x,int y,int width,int height,int fullw,
	int *cntx_ptr,int *sign_ptr)
{
int neighbors;

	/** cur_ptr[0] is about to be coded **/

	if ( x==0 ) {
		if ( y == 0 ) {
			neighbors = 0;
		} else {
			neighbors = (cur_ptr[-fullw] + cur_ptr[-fullw+1]) >> 1;
		}
	} else if ( y == 0 ) {
		neighbors = cur_ptr[-1];
	} else if ( x == (width-1) ) {
		neighbors = (cur_ptr[-1] + cur_ptr[-fullw] + cur_ptr[-fullw] + cur_ptr[-fullw-1]) >> 2;
	} else {
		neighbors = (cur_ptr[-1] + cur_ptr[-fullw] + cur_ptr[-fullw+1] + cur_ptr[-fullw-1]) >> 2;
	}

if ( neighbors == 0 ) *sign_ptr = 2;
else if ( isneg(neighbors) ) *sign_ptr = 1;
else *sign_ptr = 0;

parent = abs(parent);
neighbors = abs(neighbors);
parent = intlog2(parent+1);
neighbors = intlog2(neighbors);

*cntx_ptr = min(CN_MAX_PREV,neighbors) + (CN_MAX_PREV+1)*(min(CN_MAX_PARENT,parent));
}

static void encode_val(myInfo *mi,int sym,int context)
{
	if ( sym < ORDER1_RAWS ) {
		scontextEncode(mi->o1[context],sym);
	} else {
		int bits,msb;
		sym -= (ORDER1_RAWS-1); 	/** can't use zero **/
		bits = intlog2(sym);
		msb = (1<<bits);
		sym -= msb;
		scontextEncode(mi->o1[context],bits+ORDER1_RAWS);

		/** sym < msb now **/
		msb>>=1;
		for(;msb>=1;msb>>=1) {
			scontextEncode(mi->o0,(sym&msb)?1:0);
		}
	}
}

static int decode_val(myInfo *mi,int bits,int context)
{
	if ( bits < ORDER1_RAWS ) {
		return bits;
	} else {
		int msb,sym,top;
		bits -= ORDER1_RAWS;
		msb = 1<<bits;
		sym = 0;
		for(top = msb>>1;top>=1;top>>=1) {
			if ( scontextDecode(mi->o0) ) sym += top;
		}
		sym += msb + ORDER1_RAWS - 1;
		return sym;
	}
}

static void coder_scaledown(myInfo *mi)
{
int i;
	scontextHalve(mi->o0);
	for(i=0;i<3;i++) 
		scontextHalve(mi->sign_sc[i]);
	for(i=0;i<CODE_CONTEXTS;i++) 
		scontextHalve(mi->o1[i]);
}

void coderO1_SB_encodeBand(coder *me,int *band,int width,int height,int fullw,int *parent)
{
int x,y,val,cntx,sign,sign_cntx;
int *dp,*pp,*dpp,*ppp;
myInfo *mi = ((myInfo *)me->data);
scontext **sign_sc = ((myInfo *)me->data)->sign_sc;
scontext **o1 = ((myInfo *)me->data)->o1;

#ifdef CODER_ADAPT
	coder_scaledown(mi);
#endif

	dp = band;
	pp = parent;
	for(y=0;y<height;y++) {
		dpp = dp; ppp = pp;
		if ( coder_timetostop(me) ) { coder_didstop(me,y); return; }
		for(x=0;x<width;x++) {
			mcontext(dpp,*ppp,x,y,width,height,fullw,&cntx,&sign_cntx);

			val = *dpp++;	if ( x&1 ) ppp++;

			if ( val == 0 ) {
				scontextEncode(o1[cntx],0);
				continue;
			} else if ( val < 0 ) { sign = 1; val = -val;
			} else { sign = 0;
			}

			encode_val(mi,val,cntx);
			scontextEncode(sign_sc[sign_cntx],sign);
		}
		if ( y & 1 ) pp += fullw;
		dp += fullw;
	}
}

void coderO1_SB_decodeBand(coder *me,int *band,int width,int height,int fullw,int *parent)
{
int x,y,val,cntx,sign_cntx;
int *dp,*pp,*dpp,*ppp;
myInfo *mi = ((myInfo *)me->data);
scontext **sign_sc = ((myInfo *)me->data)->sign_sc;
scontext **o1 = ((myInfo *)me->data)->o1;

#ifdef CODER_ADAPT
	coder_scaledown(mi);
#endif

	dp = band;
	pp = parent;
	for(y=0;y<height;y++) {
		dpp = dp; ppp = pp;
		if ( coder_timetostopd(me,y) ) return;
		for(x=0;x<width;x++) {
			mcontext(dpp,*ppp,x,y,width,height,fullw,&cntx,&sign_cntx);

			if ( x&1 ) ppp++;

			val = scontextDecode(o1[cntx]);
			if ( val == 0 ) {
				*dpp++ = 0;
				continue;
			}
			val = decode_val(mi,val,cntx);

			if ( scontextDecode(sign_sc[sign_cntx]) ) val = -val;

			*dpp++ = val;
		}
		if ( y & 1 ) pp += fullw;
		dp += fullw;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美韩国一区二区| 精品三级在线看| 国产精品一区二区91| 日本最新不卡在线| 日韩专区在线视频| 午夜精品国产更新| 亚洲国产视频网站| 香港成人在线视频| 日韩一区欧美二区| 强制捆绑调教一区二区| 六月婷婷色综合| 青青草91视频| 国产精品一区二区久久精品爱涩 | 日本不卡免费在线视频| 调教+趴+乳夹+国产+精品| av一二三不卡影片| 欧美日韩成人高清| 国产大片一区二区| 欧美久久一二区| 成人国产免费视频| 成人午夜大片免费观看| 成人va在线观看| 99国产精品久久久| 欧美私人免费视频| 日韩三级视频中文字幕| 久久久久久久久久看片| 国产精品久久久久婷婷二区次 | 日本中文字幕一区二区视频| 美国十次了思思久久精品导航| 毛片av一区二区| 懂色av一区二区在线播放| 99精品久久99久久久久| 欧美高清视频www夜色资源网| 久久精品视频一区二区三区| 国产午夜亚洲精品理论片色戒| 国产精品成人一区二区三区夜夜夜| 最新高清无码专区| 水野朝阳av一区二区三区| 国产综合色视频| av高清久久久| 91精品欧美一区二区三区综合在| 久久免费午夜影院| 一级精品视频在线观看宜春院| 精品日韩一区二区三区| 在线91免费看| 国产色91在线| 亚洲第一福利视频在线| 久久国产尿小便嘘嘘尿| 91在线免费视频观看| 91精品国产入口在线| 国产精品的网站| 美腿丝袜亚洲一区| 色哟哟国产精品| 在线播放一区二区三区| 五月婷婷久久丁香| 粉嫩aⅴ一区二区三区四区五区| 欧美视频在线观看一区二区| 精品成人a区在线观看| 亚洲欧美国产三级| 韩国毛片一区二区三区| 在线视频国内一区二区| 久久综合色之久久综合| 亚洲成人动漫在线免费观看| 国产精品一区二区你懂的| 亚洲18女电影在线观看| 伊人性伊人情综合网| 精品一区二区免费在线观看| 在线视频国内一区二区| 国产精品午夜电影| 久久成人免费网| 欧美亚洲禁片免费| 中文字幕一区二区三区av| 久久国内精品视频| 欧美日韩dvd在线观看| 中文字幕人成不卡一区| 欧美在线观看你懂的| 一区视频在线播放| 国产sm精品调教视频网站| 欧美三级蜜桃2在线观看| 日韩欧美国产电影| 午夜精品一区在线观看| 99国产欧美另类久久久精品| 久久免费午夜影院| 九九热在线视频观看这里只有精品| 在线免费一区三区| 99免费精品视频| 色综合天天综合色综合av| 久久精品一区二区三区av| 麻豆国产精品官网| 91精品欧美福利在线观看 | 秋霞成人午夜伦在线观看| 在线观看中文字幕不卡| 自拍偷自拍亚洲精品播放| 国产成人福利片| 激情综合网av| 久久精品二区亚洲w码| 91.麻豆视频| 国产成人h网站| 在线观看精品一区| 欧美日韩精品系列| 精品少妇一区二区三区| 26uuu久久综合| 亚洲情趣在线观看| 韩国三级电影一区二区| 色综合久久久久综合体桃花网| 欧美r级在线观看| 亚洲成人高清在线| 色综合天天综合网国产成人综合天 | 麻豆视频观看网址久久| 91社区在线播放| 久久精品一区二区三区不卡| 蜜桃久久久久久| 欧美在线|欧美| 亚洲欧美日韩电影| 丰满少妇久久久久久久| 26uuu精品一区二区| 日韩中文字幕亚洲一区二区va在线| 色综合久久久久网| 国产精品人人做人人爽人人添| 麻豆久久久久久| 91精品国产综合久久久久久久| 亚洲黄网站在线观看| 99久久伊人精品| 久久久久久久电影| 久久66热偷产精品| 日韩欧美国产综合在线一区二区三区| 亚洲国产婷婷综合在线精品| 日本韩国一区二区三区视频| 国产精品动漫网站| 99在线热播精品免费| 国产精品区一区二区三| 国产成人av一区二区三区在线观看| 精品少妇一区二区三区日产乱码| 蜜臀a∨国产成人精品| 91精品国产麻豆国产自产在线| 午夜精品久久久久久久99水蜜桃 | 一区二区三区中文字幕精品精品| 国产91精品露脸国语对白| 久久日一线二线三线suv| 久久99国产精品久久99果冻传媒| 欧美精品九九99久久| 色欲综合视频天天天| 91精品国产综合久久婷婷香蕉| 婷婷激情综合网| 精品三级av在线| 国产精选一区二区三区| 国产一区不卡在线| 欧美日韩美女一区二区| 五月婷婷激情综合网| 91精品国产综合久久香蕉麻豆| 久久精品国产成人一区二区三区 | 26uuu另类欧美亚洲曰本| 国产成人免费9x9x人网站视频| 欧美激情一区在线观看| 99re这里只有精品首页| 欧美中文字幕一区| 中文字幕不卡在线观看| 99热国产精品| 亚洲电影欧美电影有声小说| 欧美丰满少妇xxxxx高潮对白| 日韩成人免费电影| 亚洲精品一区二区三区福利 | 岛国一区二区在线观看| 亚洲欧美自拍偷拍| 精品视频一区三区九区| 久久se精品一区精品二区| 国产精品18久久久久久久久 | 精品中文av资源站在线观看| 久久日韩精品一区二区五区| www.欧美色图| 三级久久三级久久久| 国产婷婷一区二区| 色视频一区二区| 久久se这里有精品| 亚洲欧美自拍偷拍| 91精品国产综合久久久久| 国产精品一区二区在线观看不卡| 亚洲伦理在线精品| 精品日本一线二线三线不卡| 成人97人人超碰人人99| 亚洲国产美女搞黄色| www久久精品| 欧美综合一区二区三区| 国产在线视频一区二区| 亚洲欧美日韩小说| 日韩三级中文字幕| 在线日韩一区二区| 国产99久久久国产精品潘金网站| 亚洲福利视频三区| 中文字幕+乱码+中文字幕一区| 欧美视频一区在线观看| 国产mv日韩mv欧美| 久久精品国产精品亚洲精品| 一区二区三区日韩欧美精品 | 国产亚洲精品bt天堂精选| 在线免费观看不卡av| 国产白丝网站精品污在线入口| 午夜不卡av免费| 亚洲色图.com| 久久九九久久九九|