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

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

?? encore.c

?? < VC++視頻音頻開發>> 這本書的源碼
?? C
字號:
#include "encore.h"
#include "vop_code.h"
#include "text_dct.h"
#include "bitstream.h"
#include "vm_common_defs.h"
#include "rate_ctl.h"
typedef struct _REFERENCE
{
	unsigned long handle;
	float framerate;
	long bitrate;
	long rc_period;
	long rc_reaction_period;
	long rc_reaction_ratio;
	long max_key_interval;
	int x_dim, y_dim;
	int prev_rounding;
	int search_range;
	int max_quantizer;
	int min_quantizer;
	long seq;
	long curr_run;       
	Vop *current;        
	Vop *reference;      
	Vop *reconstruct;    
	Vop *error;          
	struct _REFERENCE *pnext;
} REFERENCE;
FILE *ftrace = NULL;
int max_quantizer, min_quantizer;
void init_vol_config(VolConfig *vol_config);
void init_vop(Vop *vop);
Int get_fcode (Int sr);
int PutVoVolHeader(int vol_width, int vol_height, int time_increment_resolution, float frame_rate);
int YUV2YUV (int x_dim, int y_dim, void *yuv, void *y_out, void *u_out, void *v_out);
int encore(unsigned long handle, unsigned long enc_opt, void *param1, void *param2)
{
	static REFERENCE *ref = NULL;
	static VolConfig *vol_config;
	
	REFERENCE *ref_curr, *ref_last = NULL;
	int x_dim, y_dim, size, length;
	int headerbits = 0;
	Vop *curr;
	ref_curr = ref_last = ref;
	while (ref_curr != NULL)
	{
		if (ref_curr->handle == handle) break;
		ref_last = ref_curr;
		ref_curr = ref_last->pnext;
	}
	
	if (ref_curr == NULL)
	{
		if (enc_opt & ENC_OPT_RELEASE) return ENC_OK;
		ref_curr = (REFERENCE *)malloc(sizeof(REFERENCE));
		ref_curr->handle = handle;
		ref_curr->seq = 0;
		ref_curr->curr_run = 0;
		ref_curr->pnext = NULL;
		if (ref) ref_last->pnext = ref_curr;
		else ref = ref_curr;
	}
	
	if (enc_opt & ENC_OPT_INIT)
	{
#ifdef _RC_
		ftrace = fopen("trace.txt", "w");
		fflush(ftrace);
#endif
		init_fdct_enc();
		init_idct_enc();
		
		ref_curr->framerate = ((ENC_PARAM *)param1)->framerate;
		ref_curr->bitrate = ((ENC_PARAM *)param1)->bitrate;
		ref_curr->rc_period = ((ENC_PARAM *)param1)->rc_period;
		ref_curr->rc_reaction_period = ((ENC_PARAM *)param1)->rc_reaction_period;
		ref_curr->rc_reaction_ratio = ((ENC_PARAM *)param1)->rc_reaction_ratio;
		ref_curr->x_dim = ((ENC_PARAM *)param1)->x_dim;
		ref_curr->y_dim = ((ENC_PARAM *)param1)->y_dim;
		ref_curr->max_key_interval = ((ENC_PARAM *)param1)->max_key_interval;
		ref_curr->search_range = ((ENC_PARAM *)param1)->search_range;
		ref_curr->max_quantizer = ((ENC_PARAM *)param1)->max_quantizer;
		ref_curr->min_quantizer = ((ENC_PARAM *)param1)->min_quantizer;
		ref_curr->current = AllocVop(ref_curr->x_dim, ref_curr->y_dim);
		ref_curr->reference = AllocVop(ref_curr->x_dim + 2 * 16, 
			ref_curr->y_dim + 2 * 16);
		ref_curr->reconstruct = AllocVop(ref_curr->x_dim, ref_curr->y_dim);
		ref_curr->error = AllocVop(ref_curr->x_dim, ref_curr->y_dim);
		init_vop(ref_curr->current);
		init_vop(ref_curr->reference);
		init_vop(ref_curr->reconstruct);
		init_vop(ref_curr->error);
		ref_curr->reference->hor_spat_ref = -16;
		ref_curr->reference->ver_spat_ref = -16;
		SetConstantImage(ref_curr->reference->y_chan, 0);
		vol_config = (VolConfig *)malloc(sizeof(VolConfig));
		init_vol_config(vol_config);
		vol_config->frame_rate = ref_curr->framerate;
		vol_config->bit_rate = ref_curr->bitrate;
		RateCtlInit(8 , vol_config->bit_rate / vol_config->frame_rate,
			ref_curr->rc_period, ref_curr->rc_reaction_period, ref_curr->rc_reaction_ratio);
		return ENC_OK;
	}
	
	if (enc_opt & ENC_OPT_RELEASE)
	{
		if (ref_curr == ref) ref = NULL;
		else ref_last->pnext = ref_curr->pnext;
		if (ref_curr->current) FreeVop(ref_curr->current);
		if (ref_curr->reference) FreeVop(ref_curr->reference);
		if (ref_curr->reconstruct) FreeVop(ref_curr->reconstruct);
		if (ref_curr->error) FreeVop(ref_curr->error);
		free(ref_curr);
		free(vol_config);
		if (ftrace) {
			fclose(ftrace);
			ftrace = NULL;
		};
		return ENC_OK;
	}
	
	max_quantizer = ref_curr->max_quantizer;
	min_quantizer = ref_curr->min_quantizer;
	x_dim = ref_curr->x_dim;
	y_dim = ref_curr->y_dim;
	size = x_dim * y_dim;
	curr = ref_curr->current;
	curr->width = x_dim;
	curr->height = y_dim;
	curr->sr_for = ref_curr->search_range;
	curr->fcode_for = get_fcode(curr->sr_for);
	
	
	YUV2YUV(x_dim, y_dim, ((ENC_FRAME *)param1)->image,
		curr->y_chan->f, curr->u_chan->f, curr->v_chan->f);
	
	curr->rounding_type = 1 - ref_curr->prev_rounding;
	Bitstream_Init((void *)(((ENC_FRAME *)param1)->bitstream));
	if (ref_curr->seq == 0) {
		headerbits = PutVoVolHeader(x_dim, y_dim, curr->time_increment_resolution, ref_curr->framerate);
	}
	
#ifdef _RC_
	fflush(ftrace);
	fprintf(ftrace, "\nCoding frame #%d\n", ref_curr->seq);
#endif
	if (ref_curr->curr_run % ref_curr->max_key_interval == 0) {
		curr->prediction_type = I_VOP;
#ifdef _RC_
	fprintf(ftrace, "This frame is forced to be coded in INTRA.\n");
	fprintf(ftrace, "It has been %d frame since the last INTRA.\n", ref_curr->curr_run);
#endif
	}
	else curr->prediction_type = P_VOP;
	
	VopCode(curr,
		ref_curr->reference,
		ref_curr->reconstruct,
		ref_curr->error,
		1, 
		(float)ref_curr->seq/ref_curr->framerate,  
		vol_config);
	length = Bitstream_Close();
	((ENC_FRAME *)param1)->length = length;
	
	RateCtlUpdate(length * 8);
	ref_curr->prev_rounding = curr->rounding_type;
	ref_curr->seq ++;
	ref_curr->curr_run ++;
	if (curr->prediction_type == I_VOP) {
		((ENC_RESULT *)param2)->isKeyFrame = 1;
		ref_curr->curr_run = 1;
	} else 
		((ENC_RESULT *)param2)->isKeyFrame = 0;
	return ENC_OK;
}
void init_vol_config(VolConfig *vol_config)
{
	
	vol_config->M = 1;
	vol_config->frame_skip = 1;
	vol_config->quantizer = 8;
	vol_config->intra_quantizer = 8;
	vol_config->modulo_time_base[0] =0;
	vol_config->modulo_time_base[1] =0;
	vol_config->frame_rate = 30;
	vol_config->bit_rate = 800000;
}
void init_vop(Vop *vop)
{
	
	vop->quant_precision = 5;
	vop->bits_per_pixel = 8;
	vop->time_increment_resolution = 30000;
	vop->intra_acdc_pred_disable = 0;
	vop->intra_dc_vlc_thr = 0;
	vop->sr_for = 512;
	vop->fcode_for = get_fcode(512);
	vop->y_chan->type = SHORT_TYPE;
	vop->u_chan->type = SHORT_TYPE;
	vop->v_chan->type = SHORT_TYPE;
	vop->hor_spat_ref = 0;
	vop->ver_spat_ref = 0;
}
Int get_fcode (Int sr)
{
	if (sr<=16) return 1;
	else if (sr<=32) return 2;
	else if (sr<=64) return 3;
	else if (sr<=128) return 4;
	else if (sr<=256) return 5;
	else if (sr<=512) return 6;
	else if (sr<=1024) return 7;
	else return (-1);
}
int PutVoVolHeader(int vol_width, int vol_height, int time_increment_resolution, float frame_rate)
{
	int written = 0;
	int bits, fixed_vop_time_increment;
	Bitstream_PutBits(VO_START_CODE_LENGTH, VO_START_CODE);
	Bitstream_PutBits(5, 0);				
	written += VO_START_CODE_LENGTH + 5;
	Bitstream_PutBits(VOL_START_CODE_LENGTH, VOL_START_CODE);
	Bitstream_PutBits(4, 0);				
	written += VOL_START_CODE_LENGTH + 4;
	Bitstream_PutBits(1, 0);				
	Bitstream_PutBits(8, 1);				
	Bitstream_PutBits(1, 1);				
	Bitstream_PutBits(4, 2);				
	Bitstream_PutBits(3, 1);				
	written += 1 + 8 + 1 + 4 + 3;
	Bitstream_PutBits(4, 1);				
	Bitstream_PutBits(1, 0);				
	Bitstream_PutBits(2, 0);				
	Bitstream_PutBits(1, 1);				
	written += 4 + 1 + 2 + 1;
	Bitstream_PutBits(16, time_increment_resolution);
	Bitstream_PutBits(1, 1);				
	Bitstream_PutBits(1, 1);				
	bits = (int)ceil(log((double)time_increment_resolution)/log(2.0));
    if (bits<1) bits=1;
	fixed_vop_time_increment = (int)(time_increment_resolution / frame_rate + 0.1);
	Bitstream_PutBits(bits, fixed_vop_time_increment);
	Bitstream_PutBits(1, 1);				
	written += 16 + 1 + 1 + bits + 1;
	Bitstream_PutBits(13, vol_width);
	Bitstream_PutBits(1, 1);				
	Bitstream_PutBits(13, vol_height);
	Bitstream_PutBits(1, 1);				
	written += 13 + 1 + 13 + 1;
	Bitstream_PutBits(1, 0);				
	Bitstream_PutBits(1, 1);				
	Bitstream_PutBits(2, 0);				
	Bitstream_PutBits(1, 0);				
	written += 1 + 1 + 2 + 1;
	Bitstream_PutBits(1, 0);				
	Bitstream_PutBits(1, 0);				
	Bitstream_PutBits(1, 1);				
	Bitstream_PutBits(1, 1);				
	Bitstream_PutBits(1, 0);				
	Bitstream_PutBits(1, 0);				
	written += 1 + 1 + 1 + 1 + 1 + 1;
	written += Bitstream_NextStartCode();
	return(written);
}
int YUV2YUV (int x_dim, int y_dim, void *yuv, void *y_out, void *u_out, void *v_out)
{
	
	
	unsigned char *in;
	short int *out;
	long size;
	in = yuv;
	
	out = y_out;
	size = x_dim * y_dim;
	while (size --) *(out ++) = *(in ++);
	out = u_out;
	size = x_dim * y_dim / 4;
	while (size --) *(out ++) = *(in ++);
	out = v_out;
	size = x_dim * y_dim / 4;
	while (size --) *(out ++) = *(in ++);
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久综合久久综合久久综合| 亚洲免费伊人电影| 极品少妇一区二区| 日韩欧美的一区| 青青草精品视频| 制服.丝袜.亚洲.另类.中文| 亚洲成人免费影院| 3d成人h动漫网站入口| 视频一区欧美精品| 91麻豆精品国产自产在线| 午夜av一区二区三区| 欧美电影一区二区三区| 日韩福利电影在线| 日韩一区二区三区视频| 久久成人18免费观看| 精品久久久三级丝袜| 精品一区二区三区av| 久久精品亚洲精品国产欧美 | 日韩成人一级片| 91麻豆精品国产91久久久久久| 性久久久久久久| 欧美一区二区三区免费在线看| 美女视频第一区二区三区免费观看网站| 日韩午夜激情av| 久久99精品久久久久久| 国产午夜精品福利| 97久久精品人人做人人爽| 亚洲青青青在线视频| 欧美亚洲国产一区二区三区 | 亚洲精品欧美二区三区中文字幕| 91福利在线看| 午夜不卡av在线| 欧美成人vps| 成人少妇影院yyyy| 亚洲激情图片小说视频| 91精品视频网| 国产一区二区视频在线| 欧美激情艳妇裸体舞| 色爱区综合激月婷婷| 亚洲gay无套男同| 精品国产91洋老外米糕| 成人av免费网站| 亚洲高清免费一级二级三级| 日韩精品专区在线影院重磅| 风间由美一区二区三区在线观看 | 视频精品一区二区| 精品国产sm最大网站| caoporn国产精品| 亚洲国产视频直播| 精品av久久707| 色综合天天综合网天天看片| 日本中文字幕一区二区视频| 久久精品这里都是精品| 色婷婷综合久色| 另类小说色综合网站| 亚洲国产精品成人综合| 欧美日韩国产一二三| 国产乱人伦偷精品视频免下载 | 日韩av一二三| 国产精品伦一区| 欧美精品在线观看播放| 国产乱一区二区| 亚洲国产视频一区二区| 久久久五月婷婷| 欧美性猛片xxxx免费看久爱| 国产一区二区三区高清播放| 亚洲黄色av一区| 久久久国产一区二区三区四区小说| 色老汉一区二区三区| 国产在线不卡一区| 一区二区三区久久| 久久新电视剧免费观看| 欧美体内she精高潮| 国产成人在线影院 | 三级不卡在线观看| 国产精品久久久久久久久搜平片| 欧美精品一二三| 91麻豆123| 国产老女人精品毛片久久| 亚洲a一区二区| 中文字幕一区二区不卡 | 欧美日韩国产高清一区| 9人人澡人人爽人人精品| 久久成人久久爱| 亚洲图片欧美视频| 国产精品久久久久天堂| 精品国产一区久久| 欧美精品在线观看播放| 色拍拍在线精品视频8848| 国产成人精品一区二区三区四区| 婷婷久久综合九色国产成人| 亚洲人成精品久久久久| 国产日韩欧美高清| 日韩精品一区二区三区老鸭窝| 欧美亚洲禁片免费| 91色九色蝌蚪| 丁香一区二区三区| 精品一区二区免费看| 91精品国产综合久久久久久久| 精品国产麻豆免费人成网站| 国产91精品精华液一区二区三区 | 日韩一区二区三区三四区视频在线观看| 99国产欧美久久久精品| 国产成人8x视频一区二区| 久久99精品国产.久久久久久| 亚洲一区二区精品久久av| 中文字幕字幕中文在线中不卡视频| 国产亚洲欧美日韩日本| 26uuu国产在线精品一区二区| 在线成人午夜影院| 欧美日韩国产电影| 欧美天天综合网| 在线观看日韩国产| 在线区一区二视频| 91一区二区三区在线观看| 成人一区二区三区在线观看 | 青青草原综合久久大伊人精品| 亚洲成人激情av| 亚洲第一福利视频在线| 午夜久久福利影院| 同产精品九九九| 偷窥国产亚洲免费视频| 午夜成人免费电影| 丝袜美腿亚洲色图| 日韩影院免费视频| 爽好久久久欧美精品| 日精品一区二区三区| 免费亚洲电影在线| 欧美bbbbb| 久久激五月天综合精品| 国产在线精品一区在线观看麻豆| 美女爽到高潮91| 激情综合网天天干| 国产成人精品免费看| 成人深夜福利app| 99精品视频一区| 在线日韩国产精品| 欧美片在线播放| 欧美一级久久久久久久大片| 日韩欧美专区在线| 亚洲精品在线一区二区| 久久久久久久久99精品| 国产精品国产三级国产aⅴ原创 | 日本强好片久久久久久aaa| 日本不卡视频一二三区| 久久国产婷婷国产香蕉| 经典三级在线一区| 国产suv精品一区二区三区| 99re6这里只有精品视频在线观看| 91美女蜜桃在线| 欧美电影在哪看比较好| 精品国产成人在线影院| 国产精品美女久久久久aⅴ| 亚洲欧美另类久久久精品| 亚洲第一搞黄网站| 韩国三级电影一区二区| 成人精品视频网站| 在线观看日韩毛片| 欧美一区二区三区四区久久| 久久久国产午夜精品| 日韩毛片一二三区| 五月婷婷综合激情| 国产伦精品一区二区三区在线观看| 丰满少妇在线播放bd日韩电影| 色视频成人在线观看免| 日韩一区二区三区高清免费看看| 精品国产乱码久久久久久老虎 | 亚洲欧洲三级电影| 亚洲一本大道在线| 九九精品视频在线看| bt欧美亚洲午夜电影天堂| 精品视频免费在线| 精品久久久久一区| 亚洲欧美日韩国产综合在线| 五月婷婷久久丁香| 粉嫩绯色av一区二区在线观看| 欧美中文字幕亚洲一区二区va在线| 日韩欧美在线不卡| 亚洲欧美综合网| 久久精品久久精品| 色香蕉久久蜜桃| 欧美精品一区二区高清在线观看 | 亚洲一区免费在线观看| 久久99精品国产.久久久久| 91蜜桃网址入口| 精品第一国产综合精品aⅴ| 亚洲欧美一区二区三区久本道91| 日本麻豆一区二区三区视频| 懂色av中文字幕一区二区三区| 欧美色电影在线| 久久久精品一品道一区| 亚洲成av人片一区二区| 福利一区在线观看| 欧美一区二区三区四区在线观看| 亚洲国产精品二十页| 天天操天天干天天综合网| 成人午夜视频在线| 91.com在线观看| 亚洲区小说区图片区qvod| 国内精品视频666|