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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 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幀過程中由于場景切換產(chǎn)生的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 */

	/* 緩沖區(qū)指針的初始化 */
#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 */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
555夜色666亚洲国产免| 欧美四级电影网| 精品一区二区三区久久久| 亚洲国产精品久久久久秋霞影院| 国产精品国产三级国产专播品爱网| 欧美一区二区三区小说| 欧美丰满少妇xxxbbb| 欧美精品免费视频| 91麻豆精品国产91久久久久| 欧美精品在线视频| 91精品国产高清一区二区三区| 色呦呦一区二区三区| 99精品久久只有精品| 91麻豆精东视频| 欧美影视一区二区三区| 欧美一区二区在线免费播放| 日韩欧美自拍偷拍| 国产亚洲婷婷免费| 17c精品麻豆一区二区免费| 亚洲欧美激情小说另类| 亚洲电影激情视频网站| 麻豆91精品视频| 国产成都精品91一区二区三| 99视频一区二区三区| 欧美性高清videossexo| 日韩免费观看高清完整版 | 欧美亚洲动漫制服丝袜| 在线亚洲+欧美+日本专区| 欧美日本一区二区| 337p日本欧洲亚洲大胆色噜噜| 久久久久久久久久久电影| 椎名由奈av一区二区三区| 亚洲国产一区二区三区青草影视| 免费成人在线影院| 懂色av一区二区三区蜜臀| 色成年激情久久综合| 欧美一区二区三区日韩| 1区2区3区欧美| 日av在线不卡| 色婷婷国产精品| 日韩一二三四区| 亚洲男人的天堂一区二区| 日韩成人一级片| 91女厕偷拍女厕偷拍高清| 日韩欧美一二区| 亚洲同性gay激情无套| 日本三级韩国三级欧美三级| 99re这里都是精品| 精品国产免费视频| 亚洲一区二区三区四区的| 国产一区二区免费视频| 欧美日本韩国一区二区三区视频| 国产蜜臀97一区二区三区| 日韩电影在线一区二区三区| 99久久国产综合精品色伊| 精品久久久久久久久久久院品网| 亚洲精品成人在线| 国产黄色成人av| 精品三级在线看| 蜜臀久久99精品久久久久久9| 在线看不卡av| 亚洲精品乱码久久久久久 | 日本韩国欧美在线| 亚洲国产精品成人综合色在线婷婷 | 久久婷婷综合激情| 午夜视频一区二区| 日本久久电影网| 国产精品久久网站| 高潮精品一区videoshd| 欧美成人综合网站| 蜜臀av亚洲一区中文字幕| 欧美日韩一区二区三区高清| 夜夜精品浪潮av一区二区三区| 国产99精品在线观看| 久久精品欧美日韩| 国产不卡在线一区| 欧美激情在线观看视频免费| 国产精华液一区二区三区| 久久奇米777| 国产成人精品免费一区二区| 久久精品欧美日韩精品| 国产露脸91国语对白| 国产亚洲一区二区三区四区| 成人一道本在线| 日韩美女精品在线| 91视频免费观看| 亚洲电影一级片| 欧美精品v国产精品v日韩精品| 午夜成人免费视频| 91精品国产色综合久久久蜜香臀| 奇米色777欧美一区二区| 91精品国产综合久久久蜜臀图片| 日韩专区在线视频| 日韩欧美电影在线| 国产精品亚洲视频| 中文乱码免费一区二区| 天堂精品中文字幕在线| 欧美大胆人体bbbb| 成人午夜伦理影院| 一区二区三区四区在线播放| 欧美性一二三区| 老司机一区二区| 欧美激情在线观看视频免费| 成人av网站在线观看免费| 亚洲黄色av一区| 日韩欧美在线1卡| 从欧美一区二区三区| 一区二区三区四区乱视频| 日韩一区二区视频在线观看| 国产乱一区二区| 综合久久久久久久| 欧美大片一区二区| 91在线国产福利| 蜜桃av一区二区三区| 亚洲欧美国产三级| 精品欧美一区二区三区精品久久| 国产福利精品导航| 日本中文在线一区| 亚洲啪啪综合av一区二区三区| 欧美肥大bbwbbw高潮| 国产91色综合久久免费分享| 亚洲成人动漫一区| 国产精品高潮呻吟久久| 日韩视频在线永久播放| 日本大香伊一区二区三区| 国产一区二区三区四区在线观看| 亚洲午夜久久久久中文字幕久| 中文字幕精品—区二区四季| 欧美一区二区三区免费| 91女神在线视频| 国产一区二区电影| 免费高清在线视频一区·| 亚洲午夜久久久久久久久电影网| 国产农村妇女精品| 精品国产乱码久久久久久蜜臀| 欧美视频一区二区| 91蜜桃免费观看视频| 成人久久视频在线观看| 国产永久精品大片wwwapp| 老司机一区二区| 日韩精品亚洲一区| 亚洲一线二线三线久久久| 欧美精品一区二区三区蜜臀| 5月丁香婷婷综合| 欧美三级视频在线观看| 丁香六月久久综合狠狠色| 精品制服美女久久| 五月天视频一区| 亚洲国产精品久久久男人的天堂| 亚洲图片你懂的| 欧美激情一区二区三区不卡| 欧美美女一区二区在线观看| 欧美综合久久久| 欧美视频日韩视频| 成人免费毛片片v| 不卡一二三区首页| 91在线视频网址| 色婷婷久久久久swag精品| 色哟哟一区二区在线观看| 色香蕉成人二区免费| 色伊人久久综合中文字幕| 色综合久久久网| 欧美私人免费视频| 欧美三级电影一区| 一本一道综合狠狠老| 国产永久精品大片wwwapp| 国产.精品.日韩.另类.中文.在线.播放| 午夜视频在线观看一区| 亚洲综合色在线| 丝袜a∨在线一区二区三区不卡| 五月天一区二区三区| 老鸭窝一区二区久久精品| 国产在线精品不卡| 91免费在线看| 91精品欧美一区二区三区综合在| 精品欧美乱码久久久久久| 久久久www成人免费无遮挡大片| 国产免费观看久久| 国产精品蜜臀av| 亚洲一线二线三线久久久| 一区二区三区四区在线播放| 亚洲综合999| 日本欧美一区二区三区| 免费美女久久99| 韩国欧美国产1区| 99国产欧美久久久精品| 欧美卡1卡2卡| 337p亚洲精品色噜噜噜| 国产欧美日韩亚州综合| 国产精品入口麻豆九色| 日本亚洲最大的色成网站www| 国产黑丝在线一区二区三区| 在线免费观看一区| 国产亲近乱来精品视频| 亚洲第一狼人社区| 成人午夜视频免费看| 欧美精品久久久久久久久老牛影院| 久久夜色精品一区| 午夜精品免费在线| caoporn国产精品|