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

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

?? mv-search.c

?? H.264ITU-T 標準源碼JM98 ITU推薦的免費解碼器
?? C
?? 第 1 頁 / 共 5 頁
字號:

/*!
 *************************************************************************************
 * \file mv-search.c
 *
 * \brief
 *    Motion Vector Search, unified for B and P Pictures
 *
 * \author
 *    Main contributors (see contributors.h for copyright, address and affiliation details)
 *      - Stephan Wenger                  <stewe@cs.tu-berlin.de>
 *      - Inge Lille-Langoy               <inge.lille-langoy@telenor.com>
 *      - Rickard Sjoberg                 <rickard.sjoberg@era.ericsson.se>
 *      - Stephan Wenger                  <stewe@cs.tu-berlin.de>
 *      - Jani Lainema                    <jani.lainema@nokia.com>
 *      - Detlev Marpe                    <marpe@hhi.de>
 *      - Thomas Wedi                     <wedi@tnt.uni-hannover.de>
 *      - Heiko Schwarz                   <hschwarz@hhi.de>
 *      - Alexis Michael Tourapis         <alexismt@ieee.org>
 *
 *************************************************************************************
*/

#include "contributors.h"

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

#include "global.h"

#include "image.h"
#include "mv-search.h"
#include "refbuf.h"
#include "memalloc.h"
#include "mb_access.h"
#include "fast_me.h"

#include <time.h>
#include <sys/timeb.h>

// These procedure pointers are used by motion_search() and one_eigthpel()
static pel_t *(*PelYline_11) (pel_t *, int, int, int, int);
static pel_t *(*get_line) (pel_t**, int, int, int, int);
static pel_t *(*get_line_p1) (pel_t**, int, int, int, int);
static pel_t *(*get_line_p2) (pel_t**, int, int, int, int);

// Statistics, temporary
int     max_mvd;
short*  spiral_search_x;
short*  spiral_search_y;
short*  spiral_hpel_search_x;
short*  spiral_hpel_search_y;

int*    mvbits;
int*    refbits;
unsigned int*  byte_abs;
int**** motion_cost;


void SetMotionVectorPredictor (short  pmv[2],
                               char   **refPic,
                               short  ***tmp_mv,
                               short  ref_frame,
                               int    list,
                               int    block_x,
                               int    block_y,
                               int    blockshape_x,
                               int    blockshape_y);

extern ColocatedParams *Co_located;

#ifdef _FAST_FULL_ME_

/*****
 *****  static variables for fast integer motion estimation
 *****
 */
static int  **search_setup_done;  //!< flag if all block SAD's have been calculated yet
static int  **search_center_x;    //!< absolute search center for fast full motion search
static int  **search_center_y;    //!< absolute search center for fast full motion search
static int  **pos_00;             //!< position of (0,0) vector
static distpel  *****BlockSAD;        //!< SAD for all blocksize, ref. frames and motion vectors
static int  **max_search_range;


/*!
 ***********************************************************************
 * \brief
 *    function creating arrays for fast integer motion estimation
 ***********************************************************************
 */
void
InitializeFastFullIntegerSearch ()
{
  int  i, j, k, list;
  int  search_range = input->search_range;
  int  max_pos      = (2*search_range+1) * (2*search_range+1);
  
  if ((BlockSAD = (distpel*****)malloc (2 * sizeof(distpel****))) == NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: BlockSAD");
  
  for (list=0; list<2;list++)
  {
    if ((BlockSAD[list] = (distpel****)malloc ((img->max_num_references) * sizeof(distpel***))) == NULL)
      no_mem_exit ("InitializeFastFullIntegerSearch: BlockSAD");
    for (i = 0; i < img->max_num_references; i++)
    {
      if ((BlockSAD[list][i] = (distpel***)malloc (8 * sizeof(distpel**))) == NULL)
        no_mem_exit ("InitializeFastFullIntegerSearch: BlockSAD");
      for (j = 1; j < 8; j++)
      {
        if ((BlockSAD[list][i][j] = (distpel**)malloc (16 * sizeof(distpel*))) == NULL)
          no_mem_exit ("InitializeFastFullIntegerSearch: BlockSAD");
        for (k = 0; k < 16; k++)
        {
          if ((BlockSAD[list][i][j][k] = (distpel*)malloc (max_pos * sizeof(distpel))) == NULL)
            no_mem_exit ("InitializeFastFullIntegerSearch: BlockSAD");
        }        
      }
    }
  }
  
  if ((search_setup_done = (int**)malloc (2*sizeof(int)))==NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: search_setup_done");
  if ((search_center_x = (int**)malloc (2*sizeof(int)))==NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: search_center_x");
  if ((search_center_y = (int**)malloc (2*sizeof(int)))==NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: search_center_y");
  if ((pos_00 = (int**)malloc (2*sizeof(int)))==NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: pos_00");
  if ((max_search_range = (int**)malloc (2*sizeof(int)))==NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: max_search_range");
  
  for (list=0; list<2; list++)
  {
    if ((search_setup_done[list] = (int*)malloc ((img->max_num_references)*sizeof(int)))==NULL)
      no_mem_exit ("InitializeFastFullIntegerSearch: search_setup_done");
    if ((search_center_x[list] = (int*)malloc ((img->max_num_references)*sizeof(int)))==NULL)
      no_mem_exit ("InitializeFastFullIntegerSearch: search_center_x");
    if ((search_center_y[list] = (int*)malloc ((img->max_num_references)*sizeof(int)))==NULL)
      no_mem_exit ("InitializeFastFullIntegerSearch: search_center_y");
    if ((pos_00[list] = (int*)malloc ((img->max_num_references)*sizeof(int)))==NULL)
      no_mem_exit ("InitializeFastFullIntegerSearch: pos_00");
    if ((max_search_range[list] = (int*)malloc ((img->max_num_references)*sizeof(int)))==NULL)
      no_mem_exit ("InitializeFastFullIntegerSearch: max_search_range");
  }
  
  // assign max search ranges for reference frames
  if (input->full_search == 2)
  {
    for (list=0;list<2;list++)
      for (i=0; i<img->max_num_references; i++)  
        max_search_range[list][i] = search_range;
  }
  else
  {
    for (list=0;list<2;list++)
    {
      max_search_range[list][0] = search_range;
      for (i=1; i< img->max_num_references; i++)  max_search_range[list][i] = search_range / 2;
    }
  }
  
}



/*!
 ***********************************************************************
 * \brief
 *    function for deleting the arrays for fast integer motion estimation
 ***********************************************************************
 */
void
ClearFastFullIntegerSearch ()
{
  int  i, j, k, list;
  
  for (list=0; list<2; list++)
  {
    for (i = 0; i < img->max_num_references; i++)
    {
      for (j = 1; j < 8; j++)
      {
        for (k = 0; k < 16; k++)
        {
          free (BlockSAD[list][i][j][k]);
        }
        free (BlockSAD[list][i][j]);
      }
      free (BlockSAD[list][i]);
    }
    free (BlockSAD[list]);
  }
  free (BlockSAD);
  
  for (list=0; list<2; list++)
  {
    free (search_setup_done[list]);
    free (search_center_x[list]);
    free (search_center_y[list]);
    free (pos_00[list]);
    free (max_search_range[list]);
  }
  free (search_setup_done);
  free (search_center_x);
  free (search_center_y);
  free (pos_00);
  free (max_search_range);
  
}


/*!
 ***********************************************************************
 * \brief
 *    function resetting flags for fast integer motion estimation
 *    (have to be called in start_macroblock())
 ***********************************************************************
 */
void
ResetFastFullIntegerSearch ()
{
  int i,list;
  
  for (list=0; list<2; list++)
    for (i = 0; i < img->max_num_references; i++)
      search_setup_done [list][i] = 0;
}

/*!
 ***********************************************************************
 * \brief
 *    calculation of SAD for larger blocks on the basis of 4x4 blocks
 ***********************************************************************
 */
void
SetupLargerBlocks (int list, int refindex, int max_pos)
{
#define ADD_UP_BLOCKS()   _o=*_bo; _i=*_bi; _j=*_bj; for(pos=0;pos<max_pos;pos++) _o[pos] = _i[pos] + _j[pos];
#define INCREMENT(inc)    _bo+=inc; _bi+=inc; _bj+=inc;
  
  distpel   pos, **_bo, **_bi, **_bj;
  register distpel *_o,   *_i,   *_j;
  
  //--- blocktype 6 ---
  _bo = BlockSAD[list][refindex][6];
  _bi = BlockSAD[list][refindex][7];
  _bj = _bi + 4;
  ADD_UP_BLOCKS(); INCREMENT(1);
  ADD_UP_BLOCKS(); INCREMENT(1);
  ADD_UP_BLOCKS(); INCREMENT(1);
  ADD_UP_BLOCKS(); INCREMENT(5);
  ADD_UP_BLOCKS(); INCREMENT(1);
  ADD_UP_BLOCKS(); INCREMENT(1);
  ADD_UP_BLOCKS(); INCREMENT(1);
  ADD_UP_BLOCKS();
  
  //--- blocktype 5 ---
  _bo = BlockSAD[list][refindex][5];
  _bi = BlockSAD[list][refindex][7];
  _bj = _bi + 1;
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS();
  
  //--- blocktype 4 ---
  _bo = BlockSAD[list][refindex][4];
  _bi = BlockSAD[list][refindex][6];
  _bj = _bi + 1;
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS(); INCREMENT(6);
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS();
  
  //--- blocktype 3 ---
  _bo = BlockSAD[list][refindex][3];
  _bi = BlockSAD[list][refindex][4];
  _bj = _bi + 8;
  ADD_UP_BLOCKS(); INCREMENT(2);
  ADD_UP_BLOCKS();
  
  //--- blocktype 2 ---
  _bo = BlockSAD[list][refindex][2];
  _bi = BlockSAD[list][refindex][4];
  _bj = _bi + 2;
  ADD_UP_BLOCKS(); INCREMENT(8);
  ADD_UP_BLOCKS();
  
  //--- blocktype 1 ---
  _bo = BlockSAD[list][refindex][1];
  _bi = BlockSAD[list][refindex][3];
  _bj = _bi + 2;
  ADD_UP_BLOCKS();
}


/*!
 ***********************************************************************
 * \brief
 *    Setup the fast search for an macroblock
 ***********************************************************************
 */
void SetupFastFullPelSearch (short ref, int list)  // <--  reference frame parameter, list0 or 1
{
  short   pmv[2];
  pel_t   orig_blocks[256], *orgptr=orig_blocks, *refptr;
  int     offset_x, offset_y, x, y, range_partly_outside, ref_x, ref_y, pos, abs_x, abs_y, bindex, blky;
  int     LineSadBlk0, LineSadBlk1, LineSadBlk2, LineSadBlk3;
  int     max_width, max_height;
  int     img_width, img_height;
  
  StorablePicture *ref_picture;
  pel_t   *ref_pic;
  
  distpel**   block_sad = BlockSAD[list][ref][7];
  int     search_range  = max_search_range[list][ref];
  int     max_pos       = (2*search_range+1) * (2*search_range+1);
  
  int     list_offset   = img->mb_data[img->current_mb_nr].list_offset; 
  
  int     apply_weights = ( (active_pps->weighted_pred_flag && (img->type == P_SLICE || img->type == SP_SLICE)) ||
    (active_pps->weighted_bipred_idc && (img->type == B_SLICE)));
  
  
  ref_picture     = listX[list+list_offset][ref];
  
  //===== Use weighted Reference for ME ====
  if (apply_weights && input->UseWeightedReferenceME)
    ref_pic       = ref_picture->imgY_11_w;
  else
    ref_pic       = ref_picture->imgY_11;
  
  max_width     = ref_picture->size_x - 17;
  max_height    = ref_picture->size_y - 17;
  
  img_width     = ref_picture->size_x;
  img_height    = ref_picture->size_y;
  
  //===== get search center: predictor of 16x16 block =====
  SetMotionVectorPredictor (pmv, enc_picture->ref_idx[list], enc_picture->mv[list], ref, list, 0, 0, 16, 16);
  
  search_center_x[list][ref] = pmv[0] / 4;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臀久久99精品久久久久久9| 国产亚洲一区二区三区在线观看| 国产激情精品久久久第一区二区 | 国产精品久久午夜| 777午夜精品免费视频| 欧美三级一区二区| 欧美亚洲一区二区在线观看| 97se狠狠狠综合亚洲狠狠| 处破女av一区二区| 成人做爰69片免费看网站| 成人av片在线观看| av电影一区二区| 色狠狠av一区二区三区| 欧美日韩专区在线| 欧美久久久久久蜜桃| 91麻豆精品国产91久久久久久久久 | 91久久精品午夜一区二区| 99国产精品99久久久久久| 91在线无精精品入口| 色综合久久综合中文综合网| 欧美色图天堂网| 正在播放亚洲一区| 欧美精品一区二区在线播放| 国产日韩av一区二区| 亚洲欧美综合色| 亚洲综合色婷婷| 日韩在线观看一区二区| 国产一区二区三区免费看| 成人午夜电影久久影院| 欧美在线综合视频| 欧美一级日韩不卡播放免费| 国产午夜精品在线观看| 一级日本不卡的影视| 日本视频中文字幕一区二区三区| 国产高清亚洲一区| 在线精品视频一区二区三四| 日韩欧美区一区二| 国产日韩欧美精品电影三级在线| 亚洲色图都市小说| 免费成人在线视频观看| 色先锋aa成人| 欧美一级电影网站| 亚洲人成网站影音先锋播放| 蜜桃久久久久久久| 99re热视频精品| 日韩欧美精品三级| 一区二区三区产品免费精品久久75| 青娱乐精品在线视频| 97se亚洲国产综合自在线| 精品国产乱码久久久久久夜甘婷婷 | 欧美视频一区在线| 久久精品视频在线免费观看| 亚洲成av人在线观看| 高清国产一区二区三区| 日韩一级完整毛片| 亚洲综合视频在线| 成人一区二区三区中文字幕| 日韩午夜在线播放| 亚洲综合区在线| 成人精品小蝌蚪| 日韩欧美国产三级| 五月天久久比比资源色| 在线中文字幕一区| 中文字幕日韩一区| 国产不卡视频在线播放| 精品久久国产字幕高潮| 亚洲电影一区二区三区| 99国产精品视频免费观看| 久久久综合视频| 日本 国产 欧美色综合| 欧美麻豆精品久久久久久| 亚洲欧美激情一区二区| 99亚偷拍自图区亚洲| 中文在线一区二区| 国产一区二区三区在线观看精品| 日韩三级在线免费观看| 美女诱惑一区二区| 欧美一区二区三级| 美国欧美日韩国产在线播放| 日韩欧美色综合网站| 日本午夜一本久久久综合| 欧美一区二区三区四区久久| 青青草精品视频| 欧美大片一区二区| 国内精品伊人久久久久av影院| 精品嫩草影院久久| 国内久久婷婷综合| 久久精品欧美日韩| 东方aⅴ免费观看久久av| 国产欧美一区二区精品婷婷| 日韩一级高清毛片| 美女看a上一区| 久久久高清一区二区三区| 国产mv日韩mv欧美| 国产精品电影院| 欧美日韩精品综合在线| 日韩av电影天堂| 久久精品综合网| 色综合天天性综合| 亚洲成人自拍网| 欧美变态tickling挠脚心| 国产mv日韩mv欧美| 亚洲五月六月丁香激情| 精品三级av在线| 国产成人精品影视| 伊人夜夜躁av伊人久久| 日韩午夜三级在线| 成人在线综合网| 亚洲影院理伦片| 精品国一区二区三区| 99精品视频一区二区三区| 亚洲成在线观看| 国产亚洲精品超碰| 欧美视频自拍偷拍| 国产中文一区二区三区| 亚洲欧美另类久久久精品| 3751色影院一区二区三区| 国产乱人伦偷精品视频不卡| 亚洲男人天堂av网| 日韩一区二区三区三四区视频在线观看| 国产一区二区三区综合| 亚洲永久免费视频| 欧美国产一区二区| 日韩欧美一级二级三级| 91成人免费在线| 高清av一区二区| 久久99久久久久| 丝袜美腿亚洲综合| 亚洲少妇30p| 国产欧美一区二区三区网站| 91麻豆精品国产91| 色呦呦日韩精品| 国产凹凸在线观看一区二区| 美女任你摸久久| 天堂影院一区二区| 一区二区三区精品久久久| 久久久久久久性| 日韩久久精品一区| 国产精品免费久久久久| 日韩一区二区影院| 欧美日韩在线不卡| 色视频欧美一区二区三区| 丁香六月久久综合狠狠色| 麻豆国产欧美日韩综合精品二区| 一二三四社区欧美黄| 亚洲青青青在线视频| 欧美激情在线一区二区三区| 精品国产一区二区三区四区四| 51午夜精品国产| 精品视频一区三区九区| 欧美在线|欧美| 91福利视频网站| 欧美亚洲高清一区| 在线视频欧美精品| 欧美在线视频全部完| 欧美三级韩国三级日本一级| 欧美系列亚洲系列| 欧美日韩免费高清一区色橹橹| 欧美日韩亚洲综合在线| 69久久99精品久久久久婷婷| 欧美精品 国产精品| 欧美一三区三区四区免费在线看| 3d动漫精品啪啪一区二区竹菊 | 午夜久久电影网| 亚洲成av人影院在线观看网| 天堂蜜桃一区二区三区| 三级欧美在线一区| 久久99最新地址| 国产一区二三区好的| 国产福利一区二区| 91婷婷韩国欧美一区二区| 欧美伊人久久久久久午夜久久久久| 精品1区2区3区| 精品欧美一区二区三区精品久久| 久久免费美女视频| 国产精品乱人伦| 洋洋成人永久网站入口| 免费久久精品视频| 国产精品羞羞答答xxdd| 97久久超碰国产精品电影| 欧美三级三级三级爽爽爽| 久久夜色精品一区| 亚洲欧美日韩中文播放| 日韩精品高清不卡| 国产激情一区二区三区四区 | 欧美xxxxxxxxx| 欧美经典一区二区三区| 亚洲精品菠萝久久久久久久| 日本午夜精品视频在线观看| 高清不卡在线观看av| 欧美日韩一区三区| 久久久久国产精品人| 亚洲精品欧美二区三区中文字幕| 蜜臀av在线播放一区二区三区| 国产黑丝在线一区二区三区| 欧美日韩在线播放一区| 中文字幕av在线一区二区三区| 亚洲h精品动漫在线观看| 成人久久久精品乱码一区二区三区| 欧美性猛交xxxxxxxx|