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

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

?? encoder.c

?? 用MPEG-4對YUV視頻文件編碼壓縮成divx視頻文件
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*****************************************************************************
 *
 *  XVID MPEG-4 VIDEO CODEC
 *  -  Encoder main module  -
 *
 *  This program is an implementation of a part of one or more MPEG-4
 *  Video tools as specified in ISO/IEC 14496-2 standard.  Those intending
 *  to use this software module in hardware or software products are
 *  advised that its use may infringe existing patents or copyrights, and
 *  any such use would be at such party's own risk.  The original
 *  developer of this software module and his/her company, and subsequent
 *  editors and their companies, will have no liability for use of this
 *  software or modifications or derivatives thereof.
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
 *
 ****************************************************************************/

/*****************************************************************************
 * 
 *  History
 *
 *	20.06.2002 bframe patch
 *  08.05.2002 fix some problem in DEBUG mode;
 *             MinChen <chenm001@163.com>
 *  14.04.2002 added FrameCodeB()
 *
 *  $Id: encoder.c,v 1.51 2002/06/30 10:46:29 suxen_drol Exp $
 *
 ****************************************************************************/

#include <stdlib.h>
#include <stdio.h>
#include <math.h>
#include <string.h>

#include "encoder.h"
/*#include "prediction/mbprediction.h"*/
#include "global.h"
#include "utils/timer.h"
#include "image/image.h"
#include "user_macro.h"
#include "motion/motion.h"
#include "bitstream/cbp.h"
#include "utils/mbfunctions.h"
#include "bitstream/bitstream.h"
#include "bitstream/mbcoding.h"
#include "utils/ratecontrol.h"
#include "bitstream/mbcoding.h"
/*#include "quant/adapt_quant.h"*/
/*
#include "quant/quant_matrix.h"
*/
#include "utils/mem_align.h"
#include "motion/sad.h"
/*****************************************************************************
 * Local macros
 ****************************************************************************/

#define ENC_CHECK(X) if(!(X)) return XVID_ERR_FORMAT
#define SWAP(A,B)    { void * tmp = A; A = B; B = tmp; }

/*****************************************************************************
 * Local function prototypes
 ****************************************************************************/
FILE *pEncLogFile=NULL;/*用于輸出記錄文件的指針 */
/*extern FILE * encodelog;*/

/*static int FrameCodeI(Encoder * pEnc,
					  Bitstream * bs,
					  uint32_t * pBits,int* head,BOOL scence_change,int *mad);*//*modify add head---*/
static int FrameCodeI(Encoder * pEnc,
					  Bitstream * bs,
					  uint32_t * pBits,int* head,int *mad);/*modify del scence_change---*/

/*增加scence_change 表示在編P幀過程中由于場景切換產生的I幀TURE 為有場景切換*/
/*static int FrameCodeP(Encoder * pEnc,
					  Bitstream * bs,
					  uint32_t * pBits,
					  bool force_inter,
					  bool vol_header,int* head_vector,int* mad);*/
static int FrameCodeP(Encoder * pEnc,
					  Bitstream * bs,
					  uint32_t * pBits,
					  int* head_vector,int* mad);

/*****************************************************************************
 * Local data
 ****************************************************************************/

static int DQtab[4] = {
	-1, -2, 1, 2
};

static int iDQtab[5] = {
	1, 0, NO_CHANGE, 2, 3
};


static void __inline
image_null(IMAGE * image)
{
	image->y = image->u = image->v = NULL;
}

/*
  Calculate mad value of I frame.
  For P frame, use sad vaule that comes from motion estimation to calculate mad value.
  Add by fyh 2002.12.23
*/
int compute_MAD(Encoder * pEnc)
{	int mad=0;
    uint32_t x,y;
	for (y = 0; y < pEnc->mbParam.mb_height; y++)
		for (x = 0; x < pEnc->mbParam.mb_width; x++)
		{
			mad+=dev16((uint8_t *)(pEnc->current->image.y + y*16 + y*16*pEnc->mbParam.edged_width),pEnc->mbParam.edged_width);
	
		}
	mad/=pEnc->mbParam.mb_height*pEnc->mbParam.mb_width;
	return mad;

}
/*****************************************************************************
 * Encoder creation
 *
 * This function creates an Encoder instance, it allocates all necessary
 * image buffers (reference, current and bframes) and initialize the internal
 * xvid encoder paremeters according to the XVID_ENC_PARAM input parameter.
 *
 * The code seems to be very long but is very basic, mainly memory allocation
 * and cleaning code.
 *
 * Returned values :
 *    - XVID_ERR_OK     - no errors
 *    - XVID_ERR_MEMORY - the libc could not allocate memory, the function
 *                        cleans the structure before exiting.
 *                        pParam->handle is also set to NULL.
 *
 ****************************************************************************/
int
encoder_create(XVID_ENC_PARAM * pParam)
{
	Encoder *pEnc;
	int i;

	/* decide P frame type by use amvfast . Add by fyh */
	first_P_gop=1;
	first_P_seq=1;

	pParam->handle = NULL;

	ENC_CHECK(pParam);

	ENC_CHECK(pParam->width > 0 && pParam->width <= 1920);
	ENC_CHECK(pParam->height > 0 && pParam->height <= 1280);
	ENC_CHECK(!(pParam->width % 2));
	ENC_CHECK(!(pParam->height % 2));

	/* Fps */

	if (pParam->fincr <= 0 || pParam->fbase <= 0) {
		pParam->fincr = 1;
		pParam->fbase = 25;
	}

	/*
	 * Simplify the "fincr/fbase" fraction
	 * (neccessary, since windows supplies us with huge numbers)
	 */

	i = pParam->fincr;
	while (i > 1) {
		if (pParam->fincr % i == 0 && pParam->fbase % i == 0) {
			pParam->fincr /= i;
			pParam->fbase /= i;
			i = pParam->fincr;
			continue;
		}
		i--;
	}

	if (pParam->fbase > 65535) {
		float div = (float) pParam->fbase / 65535;

		pParam->fbase = (int) (pParam->fbase / div);
		pParam->fincr = (int) (pParam->fincr / div);
	}

	/* Bitrate allocator defaults */

	if (pParam->rc_bitrate <= 0)
		pParam->rc_bitrate = 900000;

	if (pParam->rc_reaction_delay_factor <= 0)
		pParam->rc_reaction_delay_factor = 16;

	if (pParam->rc_averaging_period <= 0)
		pParam->rc_averaging_period = 100;

	if (pParam->rc_buffer <= 0)
		pParam->rc_buffer = 100;

	/* Max and min quantizers */

	if ((pParam->min_quantizer <= 0) || (pParam->min_quantizer > 31))
		pParam->min_quantizer = 1;

	if ((pParam->max_quantizer <= 0) || (pParam->max_quantizer > 31))
		pParam->max_quantizer = 31;

	if (pParam->max_quantizer < pParam->min_quantizer)
		pParam->max_quantizer = pParam->min_quantizer;

	/* 1 keyframe each 10 seconds */

	if (pParam->max_key_interval == 0)
		pParam->max_key_interval = pParam->sequence_time* pParam->fincr / pParam->fbase;


	pEnc = (Encoder *) xvid_malloc(sizeof(Encoder), CACHE_LINE);
	if (pEnc == NULL)
		return XVID_ERR_MEMORY;

	/* Zero the Encoder Structure */

	memset(pEnc, 0, sizeof(Encoder));

	/* Fill members of Encoder structure */

	pEnc->mbParam.width = pParam->width;
	pEnc->mbParam.height = pParam->height;

	pEnc->mbParam.mb_width = (pEnc->mbParam.width + 15) / 16;
	pEnc->mbParam.mb_height = (pEnc->mbParam.height + 15) / 16;

	pEnc->mbParam.edged_width = 16 * pEnc->mbParam.mb_width + 2 * EDGE_SIZE;
	pEnc->mbParam.edged_height = 16 * pEnc->mbParam.mb_height + 2 * EDGE_SIZE;

	pEnc->mbParam.fbase = pParam->fbase;
	pEnc->mbParam.fincr = pParam->fincr;

	pEnc->mbParam.m_quant_type = H263_QUANT;

	pEnc->sStat.fMvPrevSigma = -1;

	/* Fill rate control parameters */

	pEnc->bitrate = pParam->rc_bitrate;
	pEnc->rc_type=pParam->rc_type;
	pEnc->iFrameNum = 0;
	pEnc->iMaxKeyInterval = pParam->max_key_interval;

	/* try to allocate frame memory */

	pEnc->current = xvid_malloc(sizeof(FRAMEINFO), CACHE_LINE);
	pEnc->reference = xvid_malloc(sizeof(FRAMEINFO), CACHE_LINE);

	if (pEnc->current == NULL || pEnc->reference == NULL)
		goto xvid_err_memory1;

	/* try to allocate mb memory */

	pEnc->current->mbs =
		xvid_malloc(sizeof(MACROBLOCK) * pEnc->mbParam.mb_width *
					pEnc->mbParam.mb_height, CACHE_LINE);
	pEnc->reference->mbs =
		xvid_malloc(sizeof(MACROBLOCK) * pEnc->mbParam.mb_width *
					pEnc->mbParam.mb_height, CACHE_LINE);

	if (pEnc->current->mbs == NULL || pEnc->reference->mbs == NULL)
		goto xvid_err_memory2;

	/* try to allocate image memory */

	/* 緩沖區指針的初始化 */
#ifdef _DEBUG_PSNR
	image_null(&pEnc->sOriginal);
#endif
	image_null(&pEnc->current->image);
	image_null(&pEnc->reference->image);
	image_null(&pEnc->vInterH);
	image_null(&pEnc->vInterV);
/*	image_null(&pEnc->vInterVf);*//* no use */
	image_null(&pEnc->vInterHV);
/*	image_null(&pEnc->vInterHVf);*//* no use */

#ifdef _DEBUG_PSNR
	if (image_create
		(&pEnc->sOriginal, pEnc->mbParam.edged_width,
		 pEnc->mbParam.edged_height) < 0)
		goto xvid_err_memory3;
#endif

	if (image_create
		(&pEnc->current->image, pEnc->mbParam.edged_width,
		 pEnc->mbParam.edged_height) < 0)
		goto xvid_err_memory3;
	if (image_create
		(&pEnc->reference->image, pEnc->mbParam.edged_width,
		 pEnc->mbParam.edged_height) < 0)
		goto xvid_err_memory3;
	if (image_create
		(&pEnc->vInterH, pEnc->mbParam.edged_width,
		 pEnc->mbParam.edged_height) < 0)
		goto xvid_err_memory3;
	if (image_create
		(&pEnc->vInterV, pEnc->mbParam.edged_width,
		 pEnc->mbParam.edged_height) < 0)
		goto xvid_err_memory3;
/*	if (image_create
		(&pEnc->vInterVf, pEnc->mbParam.edged_width,
		 pEnc->mbParam.edged_height) < 0)
		goto xvid_err_memory3;*/
	if (image_create
		(&pEnc->vInterHV, pEnc->mbParam.edged_width,
		 pEnc->mbParam.edged_height) < 0)
		goto xvid_err_memory3;
/*	if (image_create
		(&pEnc->vInterHVf, pEnc->mbParam.edged_width,
		 pEnc->mbParam.edged_height) < 0)
		goto xvid_err_memory3;*/



	pParam->handle = (void *) pEnc;
	pEncLogFile=(FILE *)pParam->pFile;
	if (pParam->rc_bitrate) {
		if(pParam->rc_type)
			RCInitialization(&pEnc->rc,pParam->rc_bitrate,pParam->fbase/pParam->fincr,
			pParam->sequence_time);/*初始化位率控制	*/
		else
			RateControlInit(&pEnc->rate_control, pParam->rc_bitrate,
						pParam->rc_reaction_delay_factor,
						pParam->rc_averaging_period, pParam->rc_buffer,
						pParam->fbase * 1000 / pParam->fincr,
						pParam->max_quantizer, pParam->min_quantizer);
		
		
	 }

	init_timer();

	return XVID_ERR_OK;


  xvid_err_memory3:
#ifdef _DEBUG_PSNR
	image_destroy(&pEnc->sOriginal, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
#endif

	image_destroy(&pEnc->current->image, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
	image_destroy(&pEnc->reference->image, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
	image_destroy(&pEnc->vInterH, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
	image_destroy(&pEnc->vInterV, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
/*	image_destroy(&pEnc->vInterVf, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);*/
	image_destroy(&pEnc->vInterHV, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
/*	image_destroy(&pEnc->vInterHVf, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);*/

  xvid_err_memory2:
	xvid_free(pEnc->current->mbs);
	xvid_free(pEnc->reference->mbs);

  xvid_err_memory1:
	xvid_free(pEnc->current);
	xvid_free(pEnc->reference);
	xvid_free(pEnc);

	pParam->handle = NULL;

	return XVID_ERR_MEMORY;
}

/*****************************************************************************
 * Encoder destruction
 *
 * This function destroy the entire encoder structure created by a previous
 * successful encoder_create call.
 *
 * Returned values (for now only one returned value) :
 *    - XVID_ERR_OK     - no errors
 *
 ****************************************************************************/

int
encoder_destroy(Encoder * pEnc)
{
	ENC_CHECK(pEnc);

	/* All images, reference, current etc ... */


	image_destroy(&pEnc->current->image, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
	image_destroy(&pEnc->reference->image, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
	image_destroy(&pEnc->vInterH, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
	image_destroy(&pEnc->vInterV, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
/*	image_destroy(&pEnc->vInterVf, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);*/
	image_destroy(&pEnc->vInterHV, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
/*	image_destroy(&pEnc->vInterHVf, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);*/
#ifdef _DEBUG_PSNR
	image_destroy(&pEnc->sOriginal, pEnc->mbParam.edged_width,
				  pEnc->mbParam.edged_height);
#endif

	/* Encoder structure */

	xvid_free(pEnc->current->mbs);
	xvid_free(pEnc->current);

	xvid_free(pEnc->reference->mbs);
	xvid_free(pEnc->reference);

	xvid_free(pEnc);

	return XVID_ERR_OK;
}

/*****************************************************************************
 * "original" IP frame encoder entry point
 *
 * Returned values :
 *    - XVID_ERR_OK     - no errors
 ****************************************************************************/
/*
int
encoder_encode(Encoder * pEnc,
			   XVID_ENC_FRAME * pFrame,
			   XVID_ENC_STATS * pResult)
*/
int
encoder_encode(Encoder * pEnc,/* point to global Encoder structure */
			   XVID_ENC_FRAME * pFrame/* point to global XVID_ENC_FRAME structure */
			   )
{
	Bitstream bs;/* Bitstream structure  */
	uint32_t bits;/* bit streams length */
/*	uint16_t write_vol_header = 0;*/

	int head_vector=0;/* header information and vector encoding bits number */
	int frametype;/* encoding frame type(I or P) */
	int mad=0;/* use mad value to measure encoding complexity */
	BOOL IsOverFlow;/* bit streams overflow flag */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久欧美中文字幕| 日韩国产欧美视频| 成人免费观看男女羞羞视频| 国产日韩欧美a| 成人一二三区视频| 国产精品日日摸夜夜摸av| 成人动漫视频在线| 亚洲国产视频直播| 欧美成人一区二区三区片免费| 毛片av一区二区| 久久久亚洲国产美女国产盗摄| 国产九九视频一区二区三区| 国产精品成人免费在线| 在线免费不卡电影| 看电视剧不卡顿的网站| 日本一区二区动态图| 91碰在线视频| 男人的天堂亚洲一区| 国产精品少妇自拍| 欧美男人的天堂一二区| 丰满亚洲少妇av| 亚洲最新视频在线播放| 精品国产伦一区二区三区观看方式| 国产91在线看| 婷婷亚洲久悠悠色悠在线播放| 日韩一二三区视频| 99久久综合精品| 日本欧美大码aⅴ在线播放| 久久久久高清精品| 欧美日韩一区二区不卡| 精品在线一区二区| 亚洲精品视频一区二区| 精品噜噜噜噜久久久久久久久试看| 处破女av一区二区| 欧美96一区二区免费视频| 1区2区3区精品视频| 日韩午夜在线播放| 欧美在线观看视频一区二区三区| 国产一区久久久| 亚洲国产日韩a在线播放性色| 久久久久综合网| 欧美精品aⅴ在线视频| 91网页版在线| 国产精品一区二区你懂的| 午夜欧美电影在线观看| 中文字幕一区二区三区蜜月| 欧美一区二区三区四区五区 | 天使萌一区二区三区免费观看| 久久久精品黄色| 日韩精品一区二区三区老鸭窝| 91啦中文在线观看| 懂色av中文字幕一区二区三区| 蜜桃一区二区三区在线观看| 亚洲视频香蕉人妖| 国产精品日日摸夜夜摸av| 久久麻豆一区二区| 精品成人一区二区三区| 不卡的av电影| 国产精品免费视频观看| 亚洲主播在线播放| 欧美精品在线观看一区二区| 97超碰欧美中文字幕| 国产精品99久久不卡二区| 天天操天天色综合| 香蕉成人伊视频在线观看| 最好看的中文字幕久久| 久久久综合激的五月天| 日韩一级视频免费观看在线| 91精品国产乱| 91精选在线观看| 欧美高清一级片在线| 欧美私模裸体表演在线观看| 91美女视频网站| 93久久精品日日躁夜夜躁欧美| 国产成人日日夜夜| 国产盗摄一区二区| 国产精品一二三四区| 国产精品一区三区| 成人性色生活片免费看爆迷你毛片| 韩国精品久久久| 国产一区二区成人久久免费影院| 亚洲18影院在线观看| 国产精品理论在线观看| 欧美日韩午夜在线| 国产一区二区三区黄视频| 一个色妞综合视频在线观看| 奇米在线7777在线精品| 一本大道久久a久久综合| 日本在线不卡视频| 国产日韩v精品一区二区| 在线亚洲人成电影网站色www| 全国精品久久少妇| 亚洲综合免费观看高清完整版| 日韩一区二区在线观看视频播放| 成人黄色777网| 久久66热re国产| 免费看欧美女人艹b| 午夜精品久久久久久久久久久| 欧美片在线播放| 91在线精品秘密一区二区| 另类综合日韩欧美亚洲| 亚洲国产精品影院| 一区二区三区四区视频精品免费| 久久你懂得1024| 久久综合九色欧美综合狠狠| 538在线一区二区精品国产| 欧美日韩在线免费视频| 欧美日韩精品系列| 欧美午夜精品免费| 欧美精品日韩一区| 日韩免费观看2025年上映的电影| 欧美精品自拍偷拍| 国产欧美va欧美不卡在线| 亚洲欧洲在线观看av| 亚洲欧洲精品一区二区精品久久久 | av欧美精品.com| 91小宝寻花一区二区三区| 欧美绝品在线观看成人午夜影视| 欧美一区二区私人影院日本| 亚洲国产精品传媒在线观看| 亚洲一区在线观看免费观看电影高清| 性做久久久久久免费观看| 国产一区二区0| 色成年激情久久综合| 欧美色成人综合| 欧美一区二区在线不卡| 亚洲三级视频在线观看| 日本不卡一二三区黄网| 99精品视频在线播放观看| 欧美一级二级在线观看| 久久色成人在线| 日韩免费一区二区| 成人性生交大片免费看中文网站| 欧美bbbbb| 色婷婷av一区二区三区软件| 精品久久久久久综合日本欧美| 亚洲国产精品国自产拍av| 亚洲一区二区三区精品在线| 日韩精品一二三| 久久久久免费观看| 成人欧美一区二区三区小说| 日韩精品一区第一页| kk眼镜猥琐国模调教系列一区二区| 91精品国产黑色紧身裤美女| 亚洲另类春色校园小说| 国产成人亚洲综合a∨婷婷图片| 欧美精品在线视频| 亚洲欧美中日韩| 麻豆精品新av中文字幕| 国产日韩精品一区二区三区 | 日本麻豆一区二区三区视频| 国产精选一区二区三区| 欧美精品自拍偷拍| 亚洲大片在线观看| 91久久精品一区二区三| 欧美韩国日本综合| 国产精品综合二区| 久久这里只有精品6| 激情综合网最新| 911精品国产一区二区在线| 亚洲欧美一区二区三区孕妇| 国产精品一区免费视频| 在线精品亚洲一区二区不卡| 国产精品超碰97尤物18| 成人国产精品免费观看动漫| 精品国产乱码91久久久久久网站| 视频在线观看国产精品| 欧美一区二区三区成人| 日韩国产精品91| 日韩视频永久免费| 国产在线精品一区二区不卡了| 精品日韩在线观看| 国产一区二区h| 中文字幕不卡的av| 91麻豆高清视频| 一区二区日韩电影| 欧美日韩国产区一| 伦理电影国产精品| 久久久久久一二三区| 风间由美一区二区三区在线观看 | 欧美裸体一区二区三区| 午夜精品久久久久久久久 | 久久伊人中文字幕| 国产成人免费高清| 亚洲视频每日更新| 91.成人天堂一区| 麻豆精品视频在线观看| 久久嫩草精品久久久精品一| 高清国产一区二区| 亚洲伦理在线精品| 欧美一级理论片| 国产麻豆视频一区二区| 亚洲欧美激情插| 在线播放欧美女士性生活| 黄页网站大全一区二区| 欧美高清在线精品一区| 精品视频一区三区九区| 日本成人在线不卡视频| 国产婷婷一区二区| 在线免费观看不卡av|