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

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

?? mot_est_mb.c

?? < VC++視頻音頻開發>> 這本書的源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include "mot_util.h"
#define ABSDOUBLE(x)   (((x) > 0.0001) ? (x) : (((x) < -0.0001) ? -(x): 0.0 ))
#define ARE_EQUAL(x,y) ( (ABSDOUBLE((Float)(x)-(y))>0.1)?(0):(1) )
#define INDEX_BIG(x,y) ((x)+(y)*(vop_width))
#define INDEX_NOR(x,y) ((x)+(y)*(MB_SIZE))
static Void
RangeInSearchArea(
Int     i,										  
Int     j,										  
Int     block,									  
Int     prev_x,									  
Int     prev_y,									  
Int     vop_width,								  
Int     vop_height,								  
Int     br_x,									  
Int     br_y,									  
Int     edge,									  
Int     f_code,									  
Float   *mv_x_min,								  
Float   *mv_x_max,								  
Float   *mv_y_min,								  
Float   *mv_y_max,								  
Int     *out									  												  
)
{
	Int   dim_curr_x_max,
		dim_curr_y_max,
		dim_curr_x_min,
		dim_curr_y_min;
	Int   dim_prev_x_max,
		dim_prev_y_max,
		dim_prev_x_min,
		dim_prev_y_min;
	Int   mb_b_size,
		block_x,
		block_y;
	*out=0;
	switch (block)
	{
		case 0:									  
			block_x=0;							  
			block_y=0;							  
			mb_b_size=MB_SIZE;					  
			break;								  
		case 1:
			block_x=0;
			block_y=0;
			mb_b_size=B_SIZE;
			break;
		case 2:
			block_x=B_SIZE;
			block_y=0;
			mb_b_size=B_SIZE;
			break;
		case 3:
			block_x=0;
			block_y=B_SIZE;
			mb_b_size=B_SIZE;
			break;
		case 4:
			block_x=B_SIZE;
			block_y=B_SIZE;
			mb_b_size=B_SIZE;
			break;
		default:
			return;
	}
	
	dim_curr_x_min=(Int)(br_x+i*MB_SIZE+*mv_x_min+block_x);
	dim_curr_y_min=(Int)(br_y+j*MB_SIZE+*mv_y_min+block_y);
	dim_prev_x_min=prev_x;
	dim_prev_y_min=prev_y;
	
	
	dim_curr_x_max=(Int)(br_x+i*MB_SIZE+*mv_x_max+mb_b_size+block_x);
	
	dim_curr_y_max=(Int)(br_y+j*MB_SIZE+*mv_y_max+mb_b_size+block_y);
	dim_prev_x_max=prev_x+vop_width ;
	dim_prev_y_max=prev_y+vop_height;
	
	if (dim_curr_x_min > dim_prev_x_max)
	{
		*out=1;
	}
	else if(dim_curr_x_min < dim_prev_x_min)
	{
		*mv_x_min = *mv_x_min + ( dim_prev_x_min - dim_curr_x_min ) ;
	}
	if(!(*out))
	{
		if (dim_curr_y_min > dim_prev_y_max)
		{
			*out=1;
		}
		else if(dim_curr_y_min < dim_prev_y_min)
		{
			*mv_y_min = *mv_y_min + ( dim_prev_y_min - dim_curr_y_min ) ;
		}
	}
	
	if(!(*out))
	{
		if(dim_curr_x_max < dim_prev_x_min)
		{
			*out=1;
		}
		if ((!(*out))&&(dim_curr_x_max > dim_prev_x_max))
		{
			*mv_x_max = *mv_x_max - ( dim_curr_x_max - dim_prev_x_max) ;
		}
	}
	if(!(*out))
	{
		if(dim_curr_y_max < dim_prev_y_min)
		{
			*out=1;								  
		}
		if ((!(*out))&&(dim_curr_y_max > dim_prev_y_max))
		{
			*mv_y_max = *mv_y_max - ( dim_curr_y_max - dim_prev_y_max) ;
		}
	}
	if(*mv_x_min>*mv_x_max)
	{
		*out=1;
	}
	if ( (!(*out)) && (*mv_y_min>*mv_y_max))
	{
		*out=1;
	}
	return;
}
static Int
Obtain_Range(
Int     f_code,									  
Int     sr,										  
Int     type,									  
Float   pmv_x,									  
Float   pmv_y,									  
Float   *mv_x_min,								  
Float   *mv_x_max,								  
Float   *mv_y_min,								  
Float   *mv_y_max,								  
Int     quarter_pel								  
)
{
	Int    error;
	Float  aux_x_min, aux_y_min,
		aux_x_max, aux_y_max;
	Float  range;
	error=0;
	if ((f_code==0) && (!quarter_pel))		  
	{
		*mv_x_min=0;
		*mv_x_max=0;
		*mv_y_min=0;
		*mv_y_max=0;
	}
	else
	{
		range = sr;
		*mv_x_min=-range; *mv_x_max= range - 0.5f;
		*mv_y_min=-range; *mv_y_max= range - 0.5f;
	}
	if (type==MBM_INTER8)
	{
		aux_x_min=pmv_x - DEFAULT_8_WIN;
		aux_y_min=pmv_y - DEFAULT_8_WIN;
		aux_x_max=pmv_x + DEFAULT_8_WIN;
		aux_y_max=pmv_y + DEFAULT_8_WIN;
		if(*mv_x_min < aux_x_min)
			*mv_x_min = aux_x_min;
		if(*mv_y_min < aux_y_min)
			*mv_y_min = aux_y_min;
		if(*mv_x_max > aux_x_max)
			*mv_x_max = aux_x_max;
		if(*mv_y_max > aux_y_max)
			*mv_y_max = aux_y_max;
	}
	if (error==1)
		return(0);
	else
		return(1);
}
Void
MBMotionEstimation(
SInt    *curr,								  
SInt    *prev,									  
Int     br_x,									  
Int     br_y,									  
Int     br_width,								  
Int     i,										  
Int     j,										  
Int     prev_x,									  
Int     prev_y,									  
Int     vop_width,								  
Int     vop_height,								  
Int     enable_8x8_mv,							  
Int     edge,									  
Int     f_code,									  
Int     sr,										  
Float	hint_mv_w,                                
Float	hint_mv_h,                                
Float   *mv16_w,								  
Float   *mv16_h,								  
Float   *mv8_w,									  
Float   *mv8_h,									  
Int     *min_error,								  
SInt    *flags
)
{
	Int     x, y;
	Int     sad, sad_min=MV_MAX_ERROR;
	Int     mv_x, mv_y;
	Int     block;
	Float   pmv_x, pmv_y;
	SInt	act_block[MB_SIZE*MB_SIZE];
	Float   mv_x_min, mv_x_max,
		mv_y_min, mv_y_max;
	Int     int_mv_x_min=0, int_mv_x_max=0,
		int_mv_y_min=0, int_mv_y_max=0;
	Int     pos16, pos8;
	Int     mvm_width   = br_width/MB_SIZE;
	Int     x_curr      = i*MB_SIZE,
		y_curr      = j*MB_SIZE;
	Int     hb,vb;
	Int     out;
	Int     rel_ori_x;
	Int     rel_ori_y;
	Int     min_error16, min_error8 = 0;
	#ifndef _FULL_SEARCH_						  
	typedef struct
	{
		Int x;
		Int y;
		SInt start_nmbr;
	} DPoint;
	typedef struct
	{
		DPoint point[8];
	} Diamond;
	SInt d_type=1,stop_flag=0,pt_nmbr=0,check_pts,total_check_pts=8,mot_dirn=0;
	Int d_centre_x=0,d_centre_y=0,check_pt_x,check_pt_y;
	Diamond diamond[2]=
	{
		{
			{	{0,1,0},	{1,0,0},	{0,-1,0},	{-1,0,0}	}
		}
		,
		{
			{	{0,2,6},	{1,1,0},	{2,0,0},	{1,-1,2},
				{0,-2,2},	{-1,-1,4},	{-2,0,4},	{-1,1,6}	}
		}
	};
	#endif
	d_centre_x = (int)hint_mv_w;
	d_centre_y = (int)hint_mv_h;
	rel_ori_x=br_x-prev_x;
	rel_ori_y=br_y-prev_y;
	
	
	LoadArea(curr, x_curr,y_curr,MB_SIZE,MB_SIZE,br_width, act_block);
	
	
	Obtain_Range (f_code, sr, MBM_INTER16,		  
		0.0, 0.0, &mv_x_min, &mv_x_max,
												  
		&mv_y_min, &mv_y_max, 0);
	RangeInSearchArea (i,j,0, prev_x, prev_y, vop_width, vop_height,
		br_x, br_y, edge,f_code, &mv_x_min, &mv_x_max,
												  
		&mv_y_min, &mv_y_max,&out);
	
	if(!out)
	{
		int_mv_x_min=(int)ceil((double)mv_x_min);
		int_mv_y_min=(int)ceil((double)mv_y_min);
		int_mv_x_max=(int)floor((double)mv_x_max);
		int_mv_y_max=(int)floor((double)mv_y_max);
		flags[0]=ARE_EQUAL(int_mv_x_min,mv_x_min);
		flags[1]=ARE_EQUAL(int_mv_x_max,mv_x_max);
		flags[2]=ARE_EQUAL(int_mv_y_min,mv_y_min);
		flags[3]=ARE_EQUAL(int_mv_y_max,mv_y_max);
		sad_min=MV_MAX_ERROR;
		mv_x = mv_y = 2000;						  
		#ifdef _FULL_SEARCH_				  
		for (y=int_mv_y_min; y<=int_mv_y_max; y++)
			for (x=int_mv_x_min; x<=int_mv_x_max; x++)
		{
			if (x==0 && y==0)
					sad=SAD_Macroblock(prev+INDEX_BIG(x_curr+rel_ori_x,
					y_curr+rel_ori_y), act_block, 
					(vop_width), MV_MAX_ERROR)
					- (128 + 1);
			else
				sad=SAD_Macroblock(prev+INDEX_BIG(x_curr+x+rel_ori_x,
					y_curr+y+rel_ori_y), act_block, 
					(vop_width), sad_min);
			if (sad<sad_min)
			{
				sad_min=sad;
				mv_x=x;
				mv_y=y;
			}
			else if (sad==sad_min)
			if((ABS(x)+ABS(y)) < (ABS(mv_x)+ABS(mv_y)))
			{
				sad_min=sad;
				mv_x=x;
				mv_y=y;
			}
		}									  
		#else								  
		sad = SAD_Macroblock(prev+INDEX_BIG(x_curr+rel_ori_x,
			y_curr+rel_ori_y), act_block, (vop_width), MV_MAX_ERROR)
			- (128 + 1);
		if (sad<sad_min)
		{
			sad_min=sad;
			mv_x = mv_y = 0;
		}
		do

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆蜜桃一区二区三区| 久久久影视传媒| 日本中文字幕一区二区视频| 91 com成人网| 久久99蜜桃精品| 久久免费视频色| 不卡av免费在线观看| 怡红院av一区二区三区| 欧美午夜视频网站| 喷水一区二区三区| 国产欧美一二三区| 91福利国产成人精品照片| 亚洲二区在线视频| 日韩女优制服丝袜电影| 风间由美一区二区av101| 亚洲欧美日韩国产综合在线| 欧美日韩性生活| 国产一二精品视频| 亚洲人午夜精品天堂一二香蕉| 欧美亚一区二区| 久久99精品国产麻豆婷婷| 国产欧美一区二区三区网站| 99国产精品久久久久| 午夜精品国产更新| 国产日韩欧美精品综合| 91福利资源站| 久久精品国产网站| 国产精品美女久久久久aⅴ| 欧美日韩中文另类| 国内一区二区在线| 一区二区三区国产| 欧美成人一区二区三区| eeuss国产一区二区三区| 天天免费综合色| 中文字幕+乱码+中文字幕一区| 欧美视频一区二区在线观看| 国产在线不卡视频| 亚洲一区在线观看免费观看电影高清 | 欧美熟乱第一页| 精品一区二区三区香蕉蜜桃 | 美女视频一区二区| 综合精品久久久| 欧美电影免费观看高清完整版在线 | 精品少妇一区二区| 91蝌蚪国产九色| 久久99国产精品久久99果冻传媒 | 亚洲国产精品ⅴa在线观看| 欧美三级蜜桃2在线观看| 国产剧情一区在线| 亚洲成a人片在线观看中文| 中文欧美字幕免费| 日韩午夜精品电影| 91搞黄在线观看| 成人综合婷婷国产精品久久免费| 偷拍一区二区三区| 亚洲日本乱码在线观看| 精品av久久707| 色av成人天堂桃色av| 国产成人久久精品77777最新版本| 亚洲国产成人va在线观看天堂| 欧美激情一区二区在线| 91麻豆精品国产无毒不卡在线观看| av激情成人网| 国产一区二区主播在线| 日韩激情中文字幕| 一个色综合av| 中文字幕精品一区| 精品国产a毛片| 91精品国模一区二区三区| 91久久线看在观草草青青| 日韩一区二区三区四区| 91免费在线看| 国产成人av福利| 久久99深爱久久99精品| 婷婷成人综合网| 一区二区三区在线观看动漫| 国产精品麻豆一区二区| 欧美精品一区二区三区四区| 91精品国产91热久久久做人人| 色美美综合视频| av资源站一区| 不卡的av在线播放| 国产suv一区二区三区88区| 国模冰冰炮一区二区| 美女久久久精品| 五月天激情综合网| 亚洲小说欧美激情另类| 亚洲卡通欧美制服中文| 国产精品每日更新在线播放网址| 久久综合网色—综合色88| 日韩一区二区三区视频在线| 7777精品伊人久久久大香线蕉完整版 | 日韩高清在线一区| 亚洲一级二级在线| 亚洲精品少妇30p| 亚洲三级在线播放| 最新日韩av在线| 中文字幕在线观看不卡| 国产精品免费久久久久| 国产欧美日韩在线视频| 久久男人中文字幕资源站| 亚洲精品一区二区在线观看| 日韩欧美电影一二三| 91精品蜜臀在线一区尤物| 91精品中文字幕一区二区三区| 欧美亚洲动漫精品| 欧美三级中文字| 欧美日韩亚洲综合| 欧美精选一区二区| 欧美一区三区二区| 日韩一区二区三区在线视频| 91精品国产综合久久香蕉麻豆 | 无吗不卡中文字幕| 日韩高清一区在线| 美国三级日本三级久久99| 日韩av一级电影| 美腿丝袜亚洲一区| 韩国理伦片一区二区三区在线播放| 激情五月婷婷综合网| 国产精品一品视频| av在线播放成人| 一本大道av一区二区在线播放| 在线观看日产精品| 欧美日韩成人高清| 欧美一级片在线看| 久久久久久99久久久精品网站| 国产亚洲精品精华液| 亚洲欧美怡红院| 一区二区三区中文在线| 五月天婷婷综合| 久久国产精品72免费观看| 国产宾馆实践打屁股91| 色婷婷久久久亚洲一区二区三区 | 国产日韩精品一区二区三区| 国产精品丝袜一区| 一区二区三区自拍| 丝袜亚洲精品中文字幕一区| 蜜臀精品久久久久久蜜臀| 国产一区二区三区精品欧美日韩一区二区三区 | 精品福利一二区| 国产欧美综合在线观看第十页 | 国产精品伦理在线| 亚洲欧洲日韩综合一区二区| 亚洲乱码精品一二三四区日韩在线| 亚洲在线成人精品| 蜜桃视频在线观看一区| 国产精品亚洲专一区二区三区| eeuss鲁一区二区三区| 欧美日本韩国一区二区三区视频 | 一区二区三区自拍| 青娱乐精品在线视频| 风间由美一区二区av101| 日本韩国一区二区| 欧美成人乱码一区二区三区| **性色生活片久久毛片| 婷婷丁香久久五月婷婷| 国产aⅴ综合色| 欧美在线制服丝袜| 亚洲精品一区二区三区99| 亚洲视频免费在线观看| 日本成人在线一区| 成人高清视频在线| 欧美一区二区黄| 国产精品毛片大码女人| 日韩成人一区二区三区在线观看| 国产福利91精品一区| 欧美午夜片在线看| 国产午夜亚洲精品午夜鲁丝片| 亚洲综合一区二区| 国产精品亚洲第一| 欧美日韩一级片网站| 国产欧美一区二区精品仙草咪| 亚洲第一精品在线| 成人一区二区三区中文字幕| 欧美夫妻性生活| 国产精品视频第一区| 免费观看一级特黄欧美大片| 99精品视频在线播放观看| 欧美大片顶级少妇| 亚洲免费观看高清完整版在线观看熊 | 色88888久久久久久影院按摩| 日韩免费性生活视频播放| 亚洲男同性视频| 国产精品一区二区三区99| 精品视频在线视频| 国产精品美女久久久久aⅴ国产馆| 日韩激情一二三区| 91视频免费看| 国产日产欧美一区二区视频| 日韩专区一卡二卡| 91精彩视频在线| 中文子幕无线码一区tr| 麻豆视频观看网址久久| 欧美视频在线一区二区三区 | 99久久精品免费看| 精品国产露脸精彩对白| 天天做天天摸天天爽国产一区 | 香蕉乱码成人久久天堂爱免费| 成人深夜福利app| 久久亚洲欧美国产精品乐播|