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

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

?? mp4evops.c

?? Linux下的基于intel的ipp庫的MPEG4編碼程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/******************************************************************************
//               INTEL CORPORATION PROPRIETARY INFORMATION
//  This software is supplied under the terms of a license agreement or
//  nondisclosure agreement with Intel Corporation and may not be copied
//  or disclosed except in accordance with the terms of that agreement.
//        Copyright (c) 2003 Intel Corporation. All Rights Reserved.
//
//  Description:    VOP or frame encoding functions of MPEG-4 video encoder
//                  sample code for Intel(R) Integrated Performance Primitives.
//  Functions List:
//		encode_pvop_mpeg4()
//		encode_ivop_mpeg4()
//		encode_mpeg4()
******************************************************************************/

#include "sampmp4.h"

/******************************************************************************
// Name:		encode_pvop_mpeg4
// Desicription:
//      Encode the PVOP data in non-ER mode
//
//	Input Arguments:
//      stream_buf  - Pointer to the output video bitstream
//      enc_state   - Pointer to the general state struct of MPEG-4 encoder
//      vop_infor   - Pointer to the vop information struct of MPEG-4 encoder
//
//	Output Arguments:
//      stream_buf  - Pointer to the updated output video bitstream after
//                    compression
//      enc_state   - Pointer to the updated general state struct of MPEG-4
//                    encoder
//      vop_infor   - Pointer to the updated vop information struct of MPEG-4
//                    encoder
//
//	Returns:
//      SAMPLE_STATUS_NOERR      If succeeds
//      SAMPLE_STATUS_ERR        If encoding fails
//  Note:
//      Motion estimation based on macroblocks are performed in this function.
******************************************************************************/
sample_status encode_pvop_mpeg4(sample_bitstream  *stream_buf,
                                mp4_enc_state     *enc_state,
                                mp4_enc_vop_infor *vop_infor)
{
	Ipp16u      *src_sum_mb;
	Ipp8u       *y_plane;
    Ipp8u		*src_cur_mb, *src_ref_mb, *src_ref_rec_mb, *src_ref_ori_mb;

    Ipp8u		transp_curmb_buf[4 + 4];
    Ipp8u*      transp_curmb = (Ipp8u*)SAMPLE_ALIGN4(transp_curmb_buf);
	Ipp8u		tmp_cur_mb_buf[64 * 6 + 8];
	Ipp8u*      tmp_cur_mb = (Ipp8u*)SAMPLE_ALIGN8(tmp_cur_mb_buf);    
    Ipp8u*      type_cur_mb;

    int			mbx_indx, mby_indx, i, j, y_step;
	int			mad = 0;
    IppiRect    ref_rect;

    IppMotionVector *mv_cur_mb, mv_pred;
    IppMotionVector *mv_left_mb, *mv_top_mb, *mv_top_right_mb;
	sample_status    ret_code;
    
	/* initialize high-level encoder state */
	ret_code = init_vop_infor_enc_mpeg4(enc_state, vop_infor);
	if (SAMPLE_STATUS_NOERR != ret_code ) {
		return ret_code;
	}
    
    /* for rectangular shape, all four blocks in one macroblock are not
    // transparent */
	for(i = 0; i < 4; i++) {
		transp_curmb[i]   = IPP_VIDEO_OPAQUE;
	}
    
	ref_rect.x	= - SAMPLE_VIDEO_MB_SIZE;
	ref_rect.y	= - SAMPLE_VIDEO_MB_SIZE;
	ref_rect.height	= enc_state->frame_dimension.height + 2 * SAMPLE_VIDEO_MB_SIZE;
	ref_rect.width	= enc_state->frame_dimension.width  + 2 * SAMPLE_VIDEO_MB_SIZE;

    /* forward reference plane */
    y_step  = enc_state->frame_step_set.y_step;
	y_plane = enc_state->fwd_ref_frame.y_ptr - 16 - 16 * y_step;

    /* compute summation plane based on blocks of 4 * 4 pixels in forward
    // reference plane */
    /* y_plane and enc_state->ysum_plane must be 8 bytes aligned */
    ret_code = ippiSumNorm_VOP_MPEG4_8u16u(
        y_plane,
        &ref_rect,
        enc_state->ysum_plane,
        5,
        y_step);
    
    if (ippStsNoErr != ret_code) {
        return SAMPLE_STATUS_ERR;
    }

    mv_cur_mb       = enc_state->mv_plane;
    type_cur_mb     = enc_state->mb_type_plane;
    src_sum_mb      = enc_state->ysum_plane + 16 + 16 * y_step;
    src_cur_mb      = enc_state->cur_frame.y_ptr;
    src_ref_ori_mb  = enc_state->fwd_ref_frame.y_ptr;
    src_ref_rec_mb  = enc_state->fwd_ref_rec_frame.y_ptr;
    src_ref_mb      = (enc_state->use_src_me == 1) ? src_ref_ori_mb : NULL;
    
	for(mby_indx = 0; mby_indx < enc_state->mb_per_col; mby_indx++) {

		for(mbx_indx = 0; mbx_indx < enc_state->mb_per_row; mbx_indx++) {

            /* locate three neighbourhood macroblocks for candidate predictors
            // Please refer to subclause 7.6.5 of ISO/IEC 14496-2:2001(E) */
			mv_left_mb      = mv_cur_mb	- 4;
			mv_top_mb       = mv_cur_mb	- 4 * (enc_state->mb_per_row + 2);
			mv_top_right_mb	= mv_top_mb	+ 4;

            /* form the motion vector predictor by a median filtering of three
            // candidate predictors for the first block in one macroblock */
            /* mv_cur_mb, mv_left_mb, mv_top_mb, mv_top_right_mb must be
            // 4 bytes aligned */
			ret_code = ippiFindMVpred_MPEG4(
                mv_cur_mb,
                mv_left_mb,
                mv_top_mb,
                mv_top_right_mb,
                vop_infor->tranp_buf,
                vop_infor->tranp_buf + 4,
                vop_infor->tranp_buf + 8,
                transp_curmb,
                &mv_pred,
                NULL,
                0);
            if (ippStsNoErr != ret_code) {
                return ret_code;
            }

            /* copy the macroblock in the plane to a contiguous 16*16 buffer */
			for(i = 0; i < 16; i++) {
                for (j = 0; j < 16; j++) {
                    tmp_cur_mb[i * 16 + j] = src_cur_mb[y_step * i + j];
                }
			}
			
            /* perform 16x16 size block match with Successive Elimination
            // Algorithm */
            /* src_ref_mb, src_ref_rec_mb, src_sum_mb, tmp_cur_mb must be
            // 8 bytes aligned */            
            ret_code = ippiMotionEstimation_16x16_SEA(
                src_ref_mb,
                src_ref_rec_mb, 				
                src_sum_mb,
                tmp_cur_mb,
                &ref_rect,
                &vop_infor->cur_point,
                &mv_pred,
                mv_cur_mb,
                type_cur_mb,
                &mad,
                y_step,
                enc_state->rounding,
                enc_state->search_range,
                5);
            
            if (ippStsNoErr != ret_code) {
                return SAMPLE_STATUS_ERR;
            }
            
            /* update pointers for next macroblock in the same row */
            src_sum_mb	    += SAMPLE_VIDEO_MB_SIZE;
			src_cur_mb      += SAMPLE_VIDEO_MB_SIZE;
            src_ref_rec_mb  += SAMPLE_VIDEO_MB_SIZE;            
            if (src_ref_mb) {
                src_ref_mb  += SAMPLE_VIDEO_MB_SIZE;
            }

            vop_infor->tranp_buf += 4;
			if (0 == mby_indx) {
				for(i=0;i<4;i++){
					vop_infor->tranp_buf[i] = IPP_VIDEO_OPAQUE;
				}
			}

			vop_infor->cur_point.x += 16;
			vop_infor->ref_point.x += 16;

            mv_cur_mb += 4;
            type_cur_mb ++;

        } /* loop for each low */
        
        /* update pointers for first macroblock in the next row */
        src_sum_mb     += 16 * y_step - 16 * enc_state->mb_per_row;
        src_cur_mb     += 16 * y_step - 16 * enc_state->mb_per_row;
        src_ref_rec_mb += 16 * y_step - 16 * enc_state->mb_per_row;
        if (src_ref_mb) {
            src_ref_mb += 16 * y_step - 16 * enc_state->mb_per_row;
        }
        
        vop_infor->tranp_buf = enc_state->tranp_buf;

		vop_infor->cur_point.x = 0;
		vop_infor->ref_point.x = 0;
		vop_infor->cur_point.y += 16;
		vop_infor->ref_point.y += 16;

		mv_cur_mb += 2 * 4;        
    } /* loop for each column */

    /* dump vop header information into output stream */
	ret_code = create_vop_header_mpeg4 (stream_buf, enc_state, vop_infor);
	if (SAMPLE_STATUS_NOERR != ret_code) {
		return ret_code;
	}

	/* begin texture encoding */
	for(i=0; i< (enc_state->mb_per_row + 2) * 4; i++ ) {
		vop_infor->tranp_buf[i]   = IPP_VIDEO_TRANSPARENT;
	}
    
    vop_infor->cur_point.x = 0;
	vop_infor->ref_point.x = 0;
	vop_infor->cur_point.y = 0;
	vop_infor->ref_point.y = 0;

    mv_cur_mb   = enc_state->mv_plane;
    type_cur_mb = enc_state->mb_type_plane;

    /**************************************************************************
    // begin the encoding of PVOP, MB by MB. notes the pointers should be set
    // or reset at the beginning and ending per Row
    **************************************************************************/
	for(mby_indx = 0; mby_indx < enc_state -> mb_per_col; mby_indx ++){

		for(mbx_indx = 0; mbx_indx < enc_state -> mb_per_row ; mbx_indx ++) {

			vop_infor->mb_type = *type_cur_mb;
            
            if ((IPP_VIDEO_INTRA == vop_infor->mb_type)
                || (IPP_VIDEO_INTRA_Q == vop_infor->mb_type)) {
                ret_code = encode_intra_mb_mpeg4(stream_buf, enc_state, vop_infor);
                if (SAMPLE_STATUS_NOERR != ret_code) {
                    return ret_code;
                }
            } else {
                ret_code = encode_inter_mb_mpeg4(stream_buf, enc_state, vop_infor, mv_cur_mb, transp_curmb);
                if (SAMPLE_STATUS_NOERR != ret_code) {
                    return ret_code;
                }
            }
            /* update for the next macroblck in the same row */
            vop_infor->mb_indx ++;

            vop_infor->cur_mb.y_ptr  += SAMPLE_VIDEO_MB_SIZE;
			vop_infor->cur_mb.cb_ptr += SAMPLE_VIDEO_BLOCK_SIZE;
			vop_infor->cur_mb.cr_ptr += SAMPLE_VIDEO_BLOCK_SIZE;

			vop_infor->fwd_ref_mb.y_ptr  += SAMPLE_VIDEO_MB_SIZE;
			vop_infor->fwd_ref_mb.cb_ptr += SAMPLE_VIDEO_BLOCK_SIZE;
			vop_infor->fwd_ref_mb.cr_ptr += SAMPLE_VIDEO_BLOCK_SIZE;
					   			
			vop_infor->rec_mb.y_ptr  += SAMPLE_VIDEO_MB_SIZE;
			vop_infor->rec_mb.cb_ptr += SAMPLE_VIDEO_BLOCK_SIZE;
			vop_infor->rec_mb.cr_ptr += SAMPLE_VIDEO_BLOCK_SIZE;

			vop_infor->fwd_ref_rec_mb.y_ptr  += SAMPLE_VIDEO_MB_SIZE;
			vop_infor->fwd_ref_rec_mb.cb_ptr += SAMPLE_VIDEO_BLOCK_SIZE;
			vop_infor->fwd_ref_rec_mb.cr_ptr += SAMPLE_VIDEO_BLOCK_SIZE;

            vop_infor->coef_buf_row.y_ptr  += SAMPLE_VIDEO_MB_SIZE;
            vop_infor->coef_buf_row.cb_ptr += SAMPLE_VIDEO_BLOCK_SIZE;
            vop_infor->coef_buf_row.cr_ptr += SAMPLE_VIDEO_BLOCK_SIZE;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99热精品一区二区| 另类的小说在线视频另类成人小视频在线| 亚洲女同ⅹxx女同tv| 日韩国产精品久久久久久亚洲| 成人免费看片app下载| 欧美日韩中文字幕一区| 欧美激情综合五月色丁香| 天天综合日日夜夜精品| 99国产精品久久久久久久久久久| 日韩亚洲欧美成人一区| 亚洲一区二区三区国产| 99re在线精品| 国产女主播视频一区二区| 免费观看久久久4p| 欧美中文字幕久久| 综合久久一区二区三区| 国产黄人亚洲片| xf在线a精品一区二区视频网站| 日韩高清一级片| 欧美蜜桃一区二区三区 | av中文字幕一区| 国产三级三级三级精品8ⅰ区| 久久66热偷产精品| 欧美一级欧美三级| 免费三级欧美电影| 欧美一区二区久久久| 亚洲伦理在线精品| 97久久精品人人澡人人爽| 国产精品美女www爽爽爽| 成人综合婷婷国产精品久久蜜臀| 日本一区二区在线不卡| 成人激情开心网| 国产精品白丝在线| 一本色道久久综合亚洲aⅴ蜜桃| 综合久久久久综合| 91麻豆123| 亚洲一线二线三线视频| 色天天综合久久久久综合片| 一区二区三区不卡在线观看| 91国偷自产一区二区使用方法| 亚洲美女视频在线观看| 欧美色图一区二区三区| 日本不卡1234视频| 日韩无一区二区| 激情图片小说一区| 国产精品伦理一区二区| 91天堂素人约啪| 亚洲成人av一区二区| 日韩一区二区三区观看| 高清不卡在线观看| 亚洲精品亚洲人成人网| 欧美色网站导航| 久久av老司机精品网站导航| 欧美国产在线观看| 在线精品观看国产| 精品一区二区免费在线观看| 国产精品久久久久婷婷二区次 | 国产精品亚洲а∨天堂免在线| 国产精品不卡一区| 日韩三级视频在线观看| 成+人+亚洲+综合天堂| 亚洲五月六月丁香激情| 久久久综合激的五月天| 91精品福利在线| 久久99在线观看| 一区二区在线观看av| 精品三级av在线| 色域天天综合网| 国产一区欧美日韩| 亚洲一区二区三区自拍| 久久久91精品国产一区二区精品| 91久久精品午夜一区二区| 国内精品嫩模私拍在线| 一区二区在线免费观看| 国产日韩在线不卡| 欧美精品久久一区| 91视频在线看| 国产精品91xxx| 偷偷要91色婷婷| 综合欧美亚洲日本| 久久久久久99久久久精品网站| 欧美日韩精品一区二区三区蜜桃| 国产69精品久久久久777| 免费观看久久久4p| 亚洲国产日韩av| 日韩美女久久久| 国产午夜亚洲精品午夜鲁丝片| 678五月天丁香亚洲综合网| 91在线视频在线| 丁香六月综合激情| 狠狠色狠狠色综合系列| 人禽交欧美网站| 亚洲高清久久久| 18涩涩午夜精品.www| 国产调教视频一区| 欧美mv日韩mv国产网站| 欧美一区二区三区播放老司机| 欧美日韩在线不卡| 91福利视频久久久久| 97精品超碰一区二区三区| 国产宾馆实践打屁股91| 国产一本一道久久香蕉| 日本欧美韩国一区三区| 日韩和欧美一区二区三区| 亚洲国产综合91精品麻豆| 一区二区三区在线视频观看| 亚洲视频每日更新| 亚洲私人黄色宅男| 1024亚洲合集| 亚洲欧美一区二区久久| 樱桃视频在线观看一区| 一区二区在线电影| 亚洲国产综合91精品麻豆| 亚洲福利一区二区| 青青草视频一区| 老司机精品视频线观看86| 韩国女主播成人在线观看| 国精产品一区一区三区mba桃花| 国产一区美女在线| 国产999精品久久| 97精品国产97久久久久久久久久久久| 成人免费黄色在线| 91丨九色porny丨蝌蚪| 欧美在线三级电影| 3atv一区二区三区| 欧美成人艳星乳罩| 欧美国产综合色视频| 亚洲欧洲日本在线| 亚洲va欧美va人人爽| 理论电影国产精品| 成人激情校园春色| 在线视频观看一区| 91精品国产综合久久婷婷香蕉| 日韩色在线观看| 国产精品视频免费看| 亚洲一级二级在线| 精品一区二区三区香蕉蜜桃| 国产jizzjizz一区二区| 色欧美日韩亚洲| 精品乱码亚洲一区二区不卡| 国产精品久久久久久久久免费丝袜 | 欧美午夜片在线看| 精品粉嫩超白一线天av| 自拍偷拍欧美激情| 日本在线不卡视频一二三区| 国产精品亚洲一区二区三区妖精| 91蜜桃婷婷狠狠久久综合9色| 欧美三级视频在线播放| 久久奇米777| 亚洲图片一区二区| 国产精品一区二区男女羞羞无遮挡 | 精品久久99ma| 亚洲免费伊人电影| 国产一区二区导航在线播放| 99精品黄色片免费大全| 欧美成人aa大片| 亚洲欧美日韩中文字幕一区二区三区 | 日韩午夜激情视频| 亚洲欧美一区二区视频| 美女免费视频一区二区| 色国产精品一区在线观看| 久久久噜噜噜久久中文字幕色伊伊| 一区二区三区在线看| 国产成人精品一区二区三区网站观看| 欧美性欧美巨大黑白大战| 国产午夜亚洲精品不卡| 日韩中文字幕91| 91行情网站电视在线观看高清版| 国产日韩影视精品| 蜜桃传媒麻豆第一区在线观看| 色综合久久99| 国产欧美日韩精品a在线观看| 日韩成人dvd| 欧美专区亚洲专区| 1024成人网色www| 国产**成人网毛片九色 | 国产在线国偷精品免费看| 欧美日韩精品久久久| 亚洲人成精品久久久久久| 高清不卡一区二区在线| 久久蜜臀中文字幕| 免费看精品久久片| 欧美麻豆精品久久久久久| 一区二区三区美女| 91精品1区2区| 一区二区免费视频| 色婷婷精品大在线视频| 亚洲女同ⅹxx女同tv| 99国产精品国产精品久久| 国产精品网站在线观看| 国产不卡视频在线播放| 久久精品亚洲一区二区三区浴池| 麻豆精品一二三| 欧美r级电影在线观看| 精品在线播放免费| 精品国产一区二区亚洲人成毛片 | 色悠悠久久综合| 亚洲精品日日夜夜| 欧美日韩综合不卡| 日日摸夜夜添夜夜添精品视频|