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

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

?? coder_bpb.c

?? 用C++語言實現的基于小波分析的源代碼,實現了小波分析的諸多算法
?? C
?? 第 1 頁 / 共 2 頁
字號:
				X3 = abs( sister_x[ x + fullw*y ] ) & nextmask;
				X4 = abs( sister_y[ y + fullw*x ] ) & nextmask;
				break;
			case 3:
				X3 = abs( sister_x[ y + fullw*x ] ) & nextmask;
				X4 = abs( sister_y[ y + fullw*x ] ) & nextmask;
				break;
		}
	} else {

		/** more vertical correlation (than horizontal) **/

		if ( y > 1 ) 			X1 = abs(dp[-fullw-fullw]) & nextmask; else X1 = VD;	//NN
		X2 = S;
		if ( y > parent_step ) 			X3 = abs(pp[-fullw])	& nextmask; else X3 = VD;		//PN
		if ( y < (height - parent_step) )	X4 = abs(pp[fullw]) 	& nextmask; else X4 = VD;		//PS
	}

	shapes = 0;
	if ( N > VD ) shapes += SHAPE(0);
	if ( W > VD ) shapes += SHAPE(1);

#ifdef BIG_SHAPE_CNTX
#ifdef XX_SHAPES
	if ( X1 > VD ) shapes += SHAPE(2);
	if ( X2 > VD ) shapes += SHAPE(3);
#else
	if ( S > VD ) shapes += SHAPE(2);
	if ( E > VD ) shapes += SHAPE(3);
#endif
#ifdef FIFTH_SHAPE
	if ( (X3+X4+P) > 3*VD ) shapes += SHAPE(4);
#endif
#endif

#ifdef NO_XX
	X3 = X4 = 0;
#endif

	s1 = &stats1[ min(VAL_CONTEXT_MAX, ((C1A * VD + C1B * P + C1C * N + C1D * W + C1E * NW + C1F * NE + C1G * X1 + C1H * X2 + C1I * X3 + C1J * X4)>>8)) + shapes ];
	s2 = &stats2[ min(VAL_CONTEXT_MAX, ((C2A * VD + C2B * P + C2C * N + C2D * W + C2E * NW + C2F * NE + C2G * X1 + C2H * X2 + C2I * X3 + C2J * X4)>>8)) + shapes ];
	s3 = &stats3[ min(VAL_CONTEXT_MAX, ((C3A * VD + C3B * P + C3C * N + C3D * W + C3E * NW + C3F * NE + C3G * X1 + C3H * X2 + C3I * X3 + C3J * X4)>>8)) + shapes ];
	s4 = &stats4[ min(VAL_CONTEXT_MAX, ((C4A * VD + C4B * P + C4C * N + C4D * W + C4E * NW + C4F * NE + C4G * X1 + C4H * X2 + C4I * X3 + C4J * X4)>>8)) + shapes ];

	/** weighting 
	*
	*	find the best two, then weight them by 2^(-entropy) 
	**/

#ifdef LOCAL_LENS
	len1 = intentropy(s1->p0,s1->pt);
	len2 = intentropy(s2->p0,s2->pt);
	len3 = intentropy(s3->p0,s3->pt);
	len4 = intentropy(s4->p0,s4->pt);
#endif
#ifdef ADD_CUR_WEIGHTS
	len1 += LOEweight(s1->p0,s1->pt);
	len2 += LOEweight(s2->p0,s2->pt);
	len3 += LOEweight(s3->p0,s3->pt);
	len4 += LOEweight(s4->p0,s4->pt);
#endif

	lena = len1; sa = s1;
	if ( len2 < lena ) { lena = len2; sa = s2; }
	if ( len3 < lena ) { lena = len3; sa = s3; }
	if ( len4 < lena ) { lena = len4; sa = s4; }

	lenb = INT_MAX;
	if ( len1 < lenb && sa != s1 ) { lenb = len1; sb = s1; }
	if ( len2 < lenb && sa != s2 ) { lenb = len2; sb = s2; }
	if ( len3 < lenb && sa != s3 ) { lenb = len3; sb = s3; }
	if ( len4 < lenb && sa != s4 ) { lenb = len4; sb = s4; }

#ifdef LOG
	     if ( sa == s1 ) nbest1++;
	else if ( sa == s2 ) nbest2++;
	else if ( sa == s3 ) nbest3++;
	else if ( sa == s4 ) nbest4++;
#endif

	if ( lena == lenb ) {
		p0 = (sa->p0 + sb->p0)>>1;
		pt = (sa->pt + sb->pt)>>1;
	} else if ( lenb < lena ) {
		diff = 1 + ((lena-lenb+8)>>4);
		if ( diff >= 18 ) {
			p0 = sb->p0;
			pt = sb->pt;
		} else {
			p0 = (((sb->p0)<<diff) + (sa->p0))/((1<<diff) + 1);
			pt = (((sb->pt)<<diff) + (sa->pt))/((1<<diff) + 1);
		}
	} else {
		diff = 1 + ((lenb-lena+8)>>4);
		if ( lenb-lena >= 18 ) {
			p0 = sa->p0;
			pt = sa->pt;
		} else {
			p0 = (((sa->p0)<<diff) + (sb->p0))/((1<<diff) + 1);
			pt = (((sa->pt)<<diff) + (sb->pt))/((1<<diff) + 1);
		}
	}
}

static void fixStats(bool bit)
{

	/** track the weights as the actual coded len from that model **/

#ifndef LOCAL_LENS
#ifdef SCALEDOWN_LENS
	len1 -= len1>>SCALEDOWN_SHIFT;
	len2 -= len2>>SCALEDOWN_SHIFT;
	len3 -= len3>>SCALEDOWN_SHIFT;
	len4 -= len4>>SCALEDOWN_SHIFT;
#endif

	if ( bit ) {
		len1 += log2x16( s1->pt ) - log2x16( s1->pt - s1->p0 );
		len2 += log2x16( s2->pt ) - log2x16( s2->pt - s2->p0 );
		len3 += log2x16( s3->pt ) - log2x16( s3->pt - s3->p0 );
		len4 += log2x16( s4->pt ) - log2x16( s4->pt - s4->p0 );

		if ( len1 > 40000 ) {	/** for safety **/
			len1 >>= 1; len2 >>= 1; len3 >>= 1; len4 >>= 1;
		}
	} else {
		len1 += log2x16( s1->pt ) - log2x16( s1->p0 );
		len2 += log2x16( s2->pt ) - log2x16( s2->p0 );
		len3 += log2x16( s3->pt ) - log2x16( s3->p0 );
		len4 += log2x16( s4->pt ) - log2x16( s4->p0 );
	}
#endif

	bitModel(bit,s1->p0,s1->pt);
	bitModel(bit,s2->p0,s2->pt);
	bitModel(bit,s3->p0,s3->pt);
	bitModel(bit,s4->p0,s4->pt);

}

static void codeBand_init(coder *me,subband_leaf *sb)
{
myInfo *d;
int i;

	d = (myInfo *)me->data;

	if ( sb->cntx1 && sb->cntx1shift == 0 && sb->cntx2 && sb->cntx2shift == 0 ) {
		sister_x = sb->cntx1->band;
		sister_y = sb->cntx2->band;
		sister_trans = 0;
		if ( sb->cntx1->transposed != sb->transposed ) sister_trans |= 1;
		if ( sb->cntx2->transposed != sb->transposed ) sister_trans |= 2;
	} else {
		sister_x = sister_y = NULL;
	}

	len1=len2=len3=len4=0;
	stats1 = d->stats1;
	stats2 = d->stats2;
	stats3 = d->stats3;
	stats4 = d->stats4;

	parent = sb->parent->band;
	parent_step = (sb->width) / (sb->parent->width);
	if ( parent_step == 0 ) errexit("BP_bin can't handle parent bigger than band");
	parent_mask = parent_step - 1;
	parent_shift = 0;
	for(i=parent_step;i>1;i>>=1) parent_shift++;
}

void coderBPbin_encodeSubbandBP(coder *me,subband_leaf *sb,int bitmask)
{
int *band,width,height,fullw;
int x,y,bit;
int *dp,*pp,*dpn;
arithInfo *ari = me->arith;
binContext *signs = ((myInfo *)me->data)->signs;

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

	band = sb->band; width = sb->width; height = sb->height; fullw = sb->rowpad + width;

	codeBand_init(me,sb);

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

			getStats(&dp[x],&pp[x>>parent_shift],x,y,width,height,fullw);

			bit = (abs(dp[x])&bitmask)?1:0;
			arithEncBit(ari,p0,pt,bit);

			fixStats(bit);

			if ( bit & !VD ) {
				int context;
				/** code the sign **/
				context = 0;
				if ( x < (width-1) )	AddSignContext(context,dp[x+1],donemask); else AddSignContext(context,0,0);
				if ( x > 0 )			AddSignContext(context,dp[x-1],nextmask); else AddSignContext(context,0,0);
				if ( y < (height-1) )	AddSignContext(context,dp[x+fullw],donemask); else AddSignContext(context,0,0);
				if ( y > 0 )			AddSignContext(context,dp[x-fullw],nextmask); else AddSignContext(context,0,0);
#ifdef BIG_SIGN_CONTEXT
				if ( y > 0 && x > 0 )	AddSignContext(context,dp[x-fullw-1],nextmask); else AddSignContext(context,0,0);
				if ( y > 0 && x < (width-1) )	AddSignContext(context,dp[x-fullw+1],nextmask); else AddSignContext(context,0,0);
#endif
				bitEnc( (isneg(dp[x])?1:0) ,ari,signs[context].p0,signs[context].pt);
			}
			
		}
		if ( (y & parent_mask) == parent_mask ) pp += fullw;
		dp += fullw;
	}


#ifdef LOG
printf("nbest : 1 = %d , 2 = %d , 3 = %d , 4 = %d \n",nbest1,nbest2,nbest3,nbest4);
#endif
}

void coderBPbin_decodeSubbandBP(coder *me,subband_leaf *sb,int bitmask)
{
int *band,width,height,fullw;
int x,y,bit;
int *dp,*pp,*dpn;
arithInfo *ari = me->arith;
binContext *signs = ((myInfo *)me->data)->signs;

	band = sb->band; width = sb->width; height = sb->height; fullw = sb->rowpad + width;

	codeBand_init(me,sb);

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

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

			getStats(&dp[x],&pp[x>>parent_shift],x,y,width,height,fullw);

			bit = arithDecBit(ari,p0,pt);

			fixStats(bit);

			if ( bit ) {
				if ( isneg(dp[x]) ) dp[x] -= bitmask;
				else dp[x] += bitmask; 
				if ( ! VD ) {
					int context;
					/** code the sign **/
					context = 0;
					if ( x < (width-1) )	AddSignContext(context,dp[x+1],donemask); else AddSignContext(context,0,0);
					if ( x > 0 )			AddSignContext(context,dp[x-1],nextmask); else AddSignContext(context,0,0);
					if ( y < (height-1) )	AddSignContext(context,dp[x+fullw],donemask); else AddSignContext(context,0,0);
					if ( y > 0 )			AddSignContext(context,dp[x-fullw],nextmask); else AddSignContext(context,0,0);
#ifdef BIG_SIGN_CONTEXT
					if ( y > 0 && x > 0 )	AddSignContext(context,dp[x-fullw-1],nextmask); else AddSignContext(context,0,0);
					if ( y > 0 && x < (width-1) )	AddSignContext(context,dp[x-fullw+1],nextmask); else AddSignContext(context,0,0);
#endif
					bitDec(bit,ari,signs[context].p0,signs[context].pt);
					if ( bit ) dp[x] = - dp[x];
				}
			}
		}
		if ( (y & parent_mask) == parent_mask ) pp += fullw;
		dp += fullw;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av电影在线观看一区| 日韩国产精品91| 91精品国产黑色紧身裤美女| 亚洲第一激情av| 亚洲精品老司机| 亚洲男同性视频| 中文字幕在线不卡一区二区三区| 精品国产一区二区三区久久久蜜月| 国产精品亚洲午夜一区二区三区| 老司机一区二区| 另类人妖一区二区av| 美脚の诱脚舐め脚责91| 欧美激情一区在线观看| 欧美视频自拍偷拍| 欧美日韩免费一区二区三区 | 成人免费视频视频在线观看免费| 精品一区二区三区蜜桃| 久久国内精品视频| 国产麻豆9l精品三级站| 国产精品69久久久久水密桃| 亚洲制服丝袜av| 久久久久久久久免费| 精品国产a毛片| 欧美性色欧美a在线播放| 一本色道久久综合亚洲精品按摩| 久久99九九99精品| 国产激情偷乱视频一区二区三区| 一区二区三区中文字幕电影| 午夜精品久久久久影视| 日本午夜精品一区二区三区电影 | 国产精品乱人伦中文| 自拍偷拍国产亚洲| 久久久777精品电影网影网 | 日本乱人伦一区| 欧美久久久一区| 久久久久久电影| 亚洲欧洲日产国码二区| 图片区小说区区亚洲影院| 九一九一国产精品| 91影院在线观看| 成人免费高清在线| 欧美日韩精品欧美日韩精品一综合| 777午夜精品免费视频| 久久精品人人做人人爽人人| 亚洲精品国产高清久久伦理二区| 日本一二三不卡| 亚洲一区中文在线| 亚洲日本免费电影| 中文字幕一区二| 国产精品污www在线观看| 欧美tk—视频vk| 日韩精品最新网址| 综合av第一页| 久久99国产精品麻豆| 色婷婷狠狠综合| 久久午夜羞羞影院免费观看| 亚洲影院久久精品| 亚洲成av人影院在线观看网| 亚洲一区二区视频| 国产99精品在线观看| 成人h动漫精品一区二区| 91精品视频网| 精品入口麻豆88视频| 欧美xxxx在线观看| 国产亚洲婷婷免费| 男人的天堂久久精品| 日本韩国一区二区三区视频| 久久麻豆一区二区| 国产精品久久一卡二卡| 国内一区二区在线| 欧美一区二区在线观看| 337p粉嫩大胆色噜噜噜噜亚洲 | 久久影音资源网| 亚洲精品福利视频网站| 亚洲18女电影在线观看| 日本在线不卡视频| 欧美日韩综合一区| 依依成人精品视频| 免费成人在线观看视频| 国产黑丝在线一区二区三区| 99久久伊人网影院| 国产三级精品视频| 亚洲精品国产一区二区三区四区在线 | 久久99日本精品| 亚洲第一综合色| 蜜臀精品久久久久久蜜臀| 色欧美日韩亚洲| 亚洲情趣在线观看| 久草中文综合在线| 日韩一级大片在线| 国产精品乱码妇女bbbb| 亚洲一区二区三区四区五区黄| 成人性色生活片| 国产精品国产三级国产有无不卡 | 欧美日韩一区二区三区免费看 | 国产成人精品www牛牛影视| 成人手机电影网| 国产三级欧美三级| 国产成人av一区二区三区在线观看| av不卡免费电影| 中文字幕制服丝袜一区二区三区| 国产成人精品在线看| 欧美三级在线看| 国产精品乱码一区二三区小蝌蚪| 亚洲综合精品久久| 欧美三级日本三级少妇99| 亚洲r级在线视频| 成人在线视频一区二区| 国产精品初高中害羞小美女文| 99精品偷自拍| 亚洲成人av一区| 91麻豆精品国产91久久久| 国产精品二三区| 欧美色中文字幕| 中文字幕亚洲成人| 在线精品视频一区二区| 日韩 欧美一区二区三区| 精品噜噜噜噜久久久久久久久试看| 国产一区二区在线电影| 91精品视频网| 亚洲线精品一区二区三区八戒| 日韩一级大片在线| 不卡电影一区二区三区| 亚洲国产aⅴ成人精品无吗| 日韩一卡二卡三卡国产欧美| 亚洲图片欧美综合| 亚洲亚洲精品在线观看| 美女视频一区在线观看| 国产91精品在线观看| 久久精品国产精品亚洲精品| 国产在线国偷精品免费看| 亚洲精品免费播放| 91亚洲午夜精品久久久久久| 久久久精品2019中文字幕之3| 成人免费观看av| 日韩二区三区四区| 欧美电影影音先锋| 在线观看日韩精品| 中文字幕一区二区三区四区| 国产精品嫩草99a| 精品视频在线免费看| 国产精品美女久久久久久2018| 国产性天天综合网| 污片在线观看一区二区| 成人激情小说网站| 首页亚洲欧美制服丝腿| 亚洲色图视频免费播放| 久久在线观看免费| 国产精品久久免费看| 国产精品久久久久久亚洲伦| 日韩精彩视频在线观看| 日本一区二区三区四区| 久久精品国产成人一区二区三区| 欧美日本在线播放| 亚洲综合激情网| 成人影视亚洲图片在线| 日韩av网站在线观看| 99国产一区二区三精品乱码| 国产乱子伦视频一区二区三区 | 日韩黄色在线观看| 国产日韩精品一区二区三区| 国产在线一区二区综合免费视频| 亚洲线精品一区二区三区八戒| 欧美男人的天堂一二区| 99久久伊人精品| 成人午夜看片网址| 国产成人精品免费一区二区| 麻豆精品在线视频| 中文文精品字幕一区二区| 日韩成人一级片| 激情偷乱视频一区二区三区| 国产风韵犹存在线视精品| 国产精品美日韩| 亚洲美女偷拍久久| 精品国产成人系列| 亚洲精品在线免费播放| 亚洲精品一区二区三区精华液| 韩国一区二区视频| 樱桃视频在线观看一区| 亚洲猫色日本管| 亚洲女同一区二区| 精品国产一区二区三区不卡| 色诱视频网站一区| 国内精品写真在线观看| 国产一区二区三区最好精华液| 另类小说综合欧美亚洲| 黑人精品欧美一区二区蜜桃| 亚洲免费成人av| 亚洲超碰97人人做人人爱| 天堂蜜桃一区二区三区 | 亚洲综合色婷婷| 精品欧美乱码久久久久久1区2区| 99国产一区二区三精品乱码| 六月丁香综合在线视频| 国产成人激情av| 久久精品国产澳门| 国产丶欧美丶日本不卡视频| av高清不卡在线| 欧美日韩亚洲综合在线 | 久久久久久久久久久久久夜|