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

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

?? coder_sm.c

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

SigMap : send "significance map" then residual values

	the sigmap is a mask of five entries : "0,1,-1, positive > 1, negative < -1"
		it is order-1 context coded bases on the the parents' sigmap entry.
	if one of the later two escapes is sent, their magnitude is coded (the residual)
		with an order-1 context coder based on the parents MSB (log2 of value)
		(we use a truncated alphabet then do order-minus-1 on the rest)

	could try better ways to code residuals

-----

S+P Lena lossless : 4.255 bpp

******/

#include <stdio.h>
#include <stdlib.h>
#include <crblib/inc.h>
#include <crblib/arithc.h>
#include <crblib/scontext.h>
#include <crblib/o0coder.h>
#include <crblib/intmath.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 CNTX_CAP			10	/** I'm very surprised that this tunes so high! **/
#define SIGMAP_CONTEXTS		(CNTX_CAP+CNTX_CAP+1)
#define SIGMAP_ALPHABET		5	/** 0,1,-1,pos,neg **/

#define SIGMAP_TOTMAX		5000
#define SIGMAP_INC			30

#define ORDER0_CNTXMAX		8
#define ORDER0_CONTEXTS		(ORDER0_CNTXMAX+1)
#define ORDER0_TOTMAX		500
#define ORDER0_ALPHABET		25
#define ORDER0_ESCAPE		(ORDER0_ALPHABET-1)

#include "coder.h"

void coderSigMap_encodeBand(coder *me,int *band,int w,int h,int fullw,int *parent);
void coderSigMap_decodeBand(coder *me,int *band,int w,int h,int fullw,int *parent);

typedef struct {
	ozero ** o0;
	scontext ** o1;
} myInfo;

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

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

	c->data = d;

	if ( (d->o0 = newarray(void *,ORDER0_CONTEXTS)) == NULL )
		errexit("Order0_Init failed!");

	for(i=0;i<ORDER0_CONTEXTS;i++)
		if ( (d->o0[i] = ozeroCreateMax(c->arith,ORDER0_ALPHABET,ORDER0_TOTMAX)) == NULL )
			errexit("ozero init failed");

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

	for(i=0;i<SIGMAP_CONTEXTS;i++)
		if ( (d->o1[i] = scontextCreate(c->arith,SIGMAP_ALPHABET,0,
				SIGMAP_TOTMAX,SIGMAP_INC,true)) == NULL )
			errexit("context creation failed!");

}

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

coder coderSigMap = {
		"SigMap",
		coderSigMap_init,
		coderSigMap_free,
		coderSigMap_encodeBand,
		coderSigMap_decodeBand
	};

void coderSigMap_encodeBand(coder *me,int *band,int width,int height,int fullw,int *parent)
{
int x,y,val,cntx;
int *dp,*pp;
int par_val,par_sig;
ozero **o0 = ((myInfo *)me->data)->o0;
scontext **o1 = ((myInfo *)me->data)->o1;
arithInfo *ari = me->arith;

	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++) {
			par_sig = pp[x>>1]; par_val = abs(par_sig);
			par_sig = max(- CNTX_CAP,min(CNTX_CAP,par_sig)); par_sig += CNTX_CAP;

			val = dp[x];	
			switch(val) {
				case 0:		scontextEncode(o1[par_sig],0); break;
				case 1:		scontextEncode(o1[par_sig],1); break;
				case -1:	scontextEncode(o1[par_sig],2); break;
				default:
					if ( isneg(val) ){	scontextEncode(o1[par_sig],3); val = -val; }
					else 				scontextEncode(o1[par_sig],4);
					val -= 2;
					cntx = min(ORDER0_CNTXMAX, intlog2(par_val) );
					if ( val < ORDER0_ESCAPE ) ozeroEncode(o0[cntx],val);
					else {
						ozeroEncode(o0[cntx],ORDER0_ESCAPE);
						encode_m1(ari,val - ORDER0_ESCAPE);
					}
					break;
			}
		}
		if ( y&1 ) pp += fullw;
		dp += fullw;
	}
}

void coderSigMap_decodeBand(coder *me,int *band,int width,int height,int fullw,int *parent)
{
int x,y,val,cntx,sign;
int *dp,*pp;
int par_val,par_sig;
ozero **o0 = ((myInfo *)me->data)->o0;
scontext **o1 = ((myInfo *)me->data)->o1;
arithInfo *ari = me->arith;

	dp = band;	pp = parent;
	for(y=0;y<height;y++) {
		if ( coder_timetostopd(me,y) ) return;
		for(x=0;x<width;x++) {
			par_sig = pp[x>>1]; par_val = abs(par_sig);
			par_sig = max(- CNTX_CAP,min(CNTX_CAP,par_sig)); par_sig += CNTX_CAP;

			switch( scontextDecode(o1[par_sig]) ) {
				case 0:		dp[x] = 0; break;
				case 1:		dp[x] = 1; break;
				case 2:		dp[x] = -1; break;
				case 3:		sign = -1; goto decode_val;
				case 4:		sign = 1;
				decode_val:
					cntx = min(ORDER0_CNTXMAX, intlog2(par_val) );
					val = ozeroDecode(o0[cntx]);
					if( val == ORDER0_ESCAPE ) val += decode_m1(ari);
					dp[x] = sign * (val + 2);
					break;
				default: 	
					errexit("decoded past alphabet!");
			}
		}
		if ( y&1 ) pp += fullw;
		dp += fullw;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
奇米四色…亚洲| 欧美一区二区久久久| 欧美日韩日日骚| 国产日韩欧美一区二区三区乱码 | 日韩精品一区二区三区视频在线观看 | 一区二区国产视频| 久久机这里只有精品| 91麻豆蜜桃一区二区三区| 日韩免费高清视频| 一二三四社区欧美黄| 岛国av在线一区| 91精品国产欧美一区二区| 亚洲免费毛片网站| 成人app在线观看| 久久久精品免费网站| 日韩免费视频一区二区| 亚洲精品第1页| 处破女av一区二区| 久久久综合激的五月天| 午夜伦欧美伦电影理论片| 国产91精品入口| 精品久久久久99| 老司机免费视频一区二区三区| 在线亚洲高清视频| 自拍偷自拍亚洲精品播放| 国产999精品久久| 国产无一区二区| 精品中文字幕一区二区| 91精品久久久久久久99蜜桃| 午夜影院在线观看欧美| 欧美日韩国产片| 亚洲成精国产精品女| 欧美日韩国产免费| 亚洲成人av中文| 欧美日韩国产色站一区二区三区| 亚洲成人久久影院| 欧美绝品在线观看成人午夜影视| 亚洲高清免费一级二级三级| 欧美精品三级在线观看| 五月天中文字幕一区二区| 欧美日本在线看| 五月综合激情网| 欧美人妇做爰xxxⅹ性高电影| 亚洲国产另类av| 91麻豆精品国产综合久久久久久 | 欧美性感一区二区三区| 国产精品福利一区二区| 91福利社在线观看| 天天综合色天天综合色h| 欧美一二三四在线| 久久国产夜色精品鲁鲁99| 精品第一国产综合精品aⅴ| 国产美女一区二区三区| 国产精品久久福利| 欧美在线啊v一区| 婷婷国产v国产偷v亚洲高清| 91精品国产91热久久久做人人| 日本午夜一区二区| 国产亚洲一区字幕| 91丨porny丨国产入口| 亚洲v中文字幕| 久久婷婷久久一区二区三区| 91在线观看成人| 日韩一区二区在线观看视频播放| 国产老肥熟一区二区三区| 亚洲人成在线观看一区二区| 欧美日韩和欧美的一区二区| 国产精品99久久久久久宅男| 91麻豆精品国产自产在线 | 亚洲欧美日韩一区二区三区在线观看| 在线免费观看日本欧美| 精品一区二区在线免费观看| 亚洲色图一区二区三区| 欧美一级免费大片| 99国内精品久久| 午夜精品视频在线观看| 欧美韩国日本一区| 91.成人天堂一区| 国产91精品一区二区| 日韩电影一区二区三区| 国产精品你懂的在线欣赏| 欧美日本在线看| 91丨porny丨首页| 国产一区亚洲一区| 狠狠久久亚洲欧美| 亚洲裸体xxx| 国产亚洲欧美中文| 91精品国产综合久久精品麻豆 | 国产精品影视网| 亚洲黄色小视频| 国产婷婷一区二区| 欧美日韩久久久一区| av中文字幕亚洲| 久久爱www久久做| 亚瑟在线精品视频| 亚洲欧美一区二区不卡| 国产三区在线成人av| 欧美一区二区视频免费观看| 色诱视频网站一区| 99精品欧美一区二区三区小说 | 中文一区在线播放| 精品国产123| 日韩免费一区二区三区在线播放| 欧美日韩一卡二卡三卡 | 欧美xxx久久| 91麻豆精品久久久久蜜臀| 色av成人天堂桃色av| aaa国产一区| 成人激情校园春色| 国产不卡视频在线观看| 国产乱子伦视频一区二区三区 | 午夜在线成人av| 樱桃国产成人精品视频| 亚洲欧洲性图库| 中文字幕在线观看不卡| 国产精品妹子av| 中日韩免费视频中文字幕| 欧美激情一区三区| 国产精品系列在线| 国产精品嫩草影院com| 国产精品伦一区| 日韩美女精品在线| 一区二区三区日韩| 亚洲一区二区三区自拍| 亚洲第一精品在线| 亚洲一级不卡视频| 亚洲自拍偷拍av| 日韩电影在线观看电影| 精品综合免费视频观看| 国产精品一区二区无线| 国产成人免费在线| 99精品一区二区三区| 欧美影片第一页| 91精品国产品国语在线不卡| 久久这里只有精品6| 中文无字幕一区二区三区| 中文字幕一区二区三区蜜月| 亚洲美女精品一区| 视频精品一区二区| 国产原创一区二区三区| 一本到不卡免费一区二区| 色吊一区二区三区| 日韩一卡二卡三卡四卡| 欧美国产乱子伦 | 综合自拍亚洲综合图不卡区| 亚洲综合色区另类av| 日本成人在线一区| 国产不卡视频一区| 欧美影院一区二区三区| 久久婷婷国产综合国色天香| 91论坛在线播放| 欧美日本高清视频在线观看| 日韩美女视频在线| 国产精品国产精品国产专区不片| 亚洲sss视频在线视频| 国产成人免费在线视频| 欧美在线色视频| 成人av在线网站| 欧美日本国产视频| 中文字幕永久在线不卡| 日韩高清不卡在线| 99久久精品99国产精品| 日韩久久免费av| 亚洲一区二区三区自拍| 大白屁股一区二区视频| 91麻豆精品国产91久久久资源速度 | 在线视频你懂得一区二区三区| 26uuu亚洲综合色欧美| 亚洲自拍偷拍av| 高清shemale亚洲人妖| 91精品国产综合久久婷婷香蕉| 国产精品的网站| 国内精品国产成人国产三级粉色| 午夜精品福利视频网站| 99久久伊人精品| 久久综合一区二区| 日韩制服丝袜先锋影音| 色综合久久久久久久久久久| 国产网站一区二区| 精彩视频一区二区三区| 欧亚洲嫩模精品一区三区| 国产精品污污网站在线观看| 久久不见久久见免费视频1| 制服丝袜成人动漫| 伊人色综合久久天天人手人婷| 成人午夜av影视| 久久综合色婷婷| 免费欧美在线视频| 欧美性猛交一区二区三区精品| 欧美色图12p| 亚洲精品国产一区二区精华液| 国产91精品精华液一区二区三区| 精品久久五月天| 蜜臀av一区二区三区| 777午夜精品免费视频| 亚洲一区二区av电影| av网站一区二区三区| 欧美国产视频在线| 成人午夜精品一区二区三区| 国产日韩欧美亚洲|