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

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

?? mv-search.c

?? jm_frext22.ZIP的壓縮文件,主要用于嵌入式系統(tǒng)圖象的編解碼的開發(fā).
?? 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-Lang鴜               <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>
 *
 *************************************************************************************
*/

#include "contributors.h"

#include <math.h>
#include <stdlib.h>
#include <assert.h>
#include <limits.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  (*PelY_14)     (pel_t**, int, int, int, int);
static pel_t *(*PelYline_11) (pel_t *, int, int, int, int);

// Statistics, temporary
int     max_mvd;
int*    spiral_search_x;
int*    spiral_search_y;
int*    mvbits;
int*    refbits;
int*    byte_abs;
int**** motion_cost;


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

#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 int  *****BlockSAD;        //!< SAD for all blocksize, ref. frames and motion vectors
static int  **max_search_range;

extern ColocatedParams *Co_located;

/*!
 ***********************************************************************
 * \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 = (int*****)malloc (2 * sizeof(int****))) == NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: BlockSAD");

  for (list=0; list<2;list++)
  {
    if ((BlockSAD[list] = (int****)malloc ((img->max_num_references+1) * sizeof(int***))) == NULL)
      no_mem_exit ("InitializeFastFullIntegerSearch: BlockSAD");
    for (i = 0; i <= img->max_num_references; i++)
    {
      if ((BlockSAD[list][i] = (int***)malloc (8 * sizeof(int**))) == NULL)
        no_mem_exit ("InitializeFastFullIntegerSearch: BlockSAD");
      for (j = 1; j < 8; j++)
      {
        if ((BlockSAD[list][i][j] = (int**)malloc (16 * sizeof(int*))) == NULL)
          no_mem_exit ("InitializeFastFullIntegerSearch: BlockSAD");
        for (k = 0; k < 16; k++)
        {
          if ((BlockSAD[list][i][j][k] = (int*)malloc (max_pos * sizeof(int))) == 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+1)*sizeof(int)))==NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: search_setup_done");
  if ((search_center_x[list] = (int*)malloc ((img->max_num_references+1)*sizeof(int)))==NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: search_center_x");
  if ((search_center_y[list] = (int*)malloc ((img->max_num_references+1)*sizeof(int)))==NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: search_center_y");
  if ((pos_00[list] = (int*)malloc ((img->max_num_references+1)*sizeof(int)))==NULL)
    no_mem_exit ("InitializeFastFullIntegerSearch: pos_00");
  if ((max_search_range[list] = (int*)malloc ((img->max_num_references+1)*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] = max_search_range[list][img->max_num_references] = 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;

  int    pos, **_bo, **_bi, **_bj;
  register int *_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 (int ref, int list)  // <--  reference frame parameter, list0 or 1
{
  int     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;

  int**   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->MbaffFrameFlag)&&(img->mb_data[img->current_mb_nr].mb_field))? img->current_mb_nr%2 ? 4 : 2 : 0;

  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];

  if (apply_weights)
    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, enc_picture->mv, ref, list, 0, 0, 16, 16);
  search_center_x[list][ref] = pmv[0] / 4;
  search_center_y[list][ref] = pmv[1] / 4;

  if (!input->rdopt)
  {
    //--- correct center so that (0,0) vector is inside ---
    search_center_x[list][ref] = max(-search_range, min(search_range, search_center_x[list][ref]));
    search_center_y[list][ref] = max(-search_range, min(search_range, search_center_y[list][ref]));
  }

  search_center_x[list][ref] += img->opix_x;
  search_center_y[list][ref] += img->opix_y;

  offset_x = search_center_x[list][ref];

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品人人爽人人爽| 欧美色欧美亚洲另类二区| 日韩三级.com| 美女一区二区三区在线观看| 欧美丰满美乳xxx高潮www| 三级精品在线观看| 欧美一区二区三区免费观看视频| 男人的天堂久久精品| 精品sm在线观看| 不卡电影免费在线播放一区| 亚洲青青青在线视频| 欧美性xxxxxxxx| 亚洲宅男天堂在线观看无病毒| 色综合久久久久综合| 亚洲成人av电影在线| 日韩一级片网址| 国产精品一区二区久激情瑜伽| 国产亚洲精久久久久久| 色综合天天视频在线观看| 午夜日韩在线电影| 国产视频一区二区在线观看| 成人av资源站| 亚洲777理论| 久久久久久免费| 色婷婷久久久综合中文字幕| 丝袜诱惑制服诱惑色一区在线观看 | 国产欧美日韩在线观看| 91小视频免费观看| 美腿丝袜亚洲三区| 中文字幕一区二区三区四区| 欧美精选午夜久久久乱码6080| 极品美女销魂一区二区三区免费| 亚洲视频免费在线| 欧美大白屁股肥臀xxxxxx| 97国产精品videossex| 看片的网站亚洲| 亚洲精品免费看| 国产欧美精品一区二区色综合朱莉| 91在线视频播放| 麻豆久久久久久久| 一区二区免费在线播放| 国产夜色精品一区二区av| 欧美色偷偷大香| 粉嫩绯色av一区二区在线观看| 亚洲午夜国产一区99re久久| 亚洲国产高清不卡| 日韩欧美视频一区| 欧美四级电影网| 91丨九色porny丨蝌蚪| 国产麻豆精品久久一二三| 亚洲主播在线播放| 国产精品无遮挡| 精品国产一区久久| 91精品国产欧美日韩| 一本大道av伊人久久综合| 国产sm精品调教视频网站| 麻豆91免费观看| 丝袜诱惑制服诱惑色一区在线观看| 国产精品的网站| 精品av综合导航| 91精品国产黑色紧身裤美女| 欧美系列在线观看| 色综合色综合色综合| 成人美女在线视频| 国产传媒欧美日韩成人| 加勒比av一区二区| 美女视频黄免费的久久 | 亚洲色图一区二区三区| 日韩欧美亚洲国产精品字幕久久久 | 亚洲成人黄色影院| 一区二区视频免费在线观看| 综合久久国产九一剧情麻豆| 国产欧美一区二区精品久导航| 欧美肥大bbwbbw高潮| 在线精品亚洲一区二区不卡| 大陆成人av片| 成人午夜免费视频| 成人av动漫在线| 成人av电影免费在线播放| 国产精品99久久久久久久女警 | 91精品国产色综合久久不卡电影| 欧美日本国产一区| 欧美一区二区三区喷汁尤物| 日韩一区二区免费在线电影| 日韩女优制服丝袜电影| xnxx国产精品| 国产欧美精品一区二区色综合朱莉 | 亚洲成人免费在线| 亚洲第一主播视频| 五月天视频一区| 美国精品在线观看| 国产一区二区三区不卡在线观看| 激情五月激情综合网| 国产麻豆精品在线| 色综合网色综合| 在线一区二区视频| 911精品国产一区二区在线| 3d成人h动漫网站入口| 精品成人一区二区三区| 综合久久给合久久狠狠狠97色 | 久久精品国内一区二区三区| 久久激情综合网| 丁香另类激情小说| 欧美专区日韩专区| 精品欧美久久久| 日韩一区日韩二区| 午夜一区二区三区在线观看| 久久不见久久见免费视频1| 国产成人在线视频网站| 日本精品一区二区三区高清| 91精品国产综合久久久久久漫画| 久久色.com| 一区二区三区在线看| 裸体健美xxxx欧美裸体表演| 国产一区在线精品| 在线中文字幕不卡| 国产亚洲制服色| 一区二区三区四区国产精品| 亚洲国产乱码最新视频| 精品综合久久久久久8888| 播五月开心婷婷综合| 欧美伦理视频网站| 日本一区二区三区四区在线视频 | 3atv在线一区二区三区| 日本一区二区综合亚洲| 亚洲成人av在线电影| 国产麻豆精品一区二区| 欧美日韩国产综合久久| 欧美国产激情二区三区| 日韩成人一级片| 国产ts人妖一区二区| 欧美一级艳片视频免费观看| 国产精品嫩草影院com| 日韩国产欧美视频| 91亚洲国产成人精品一区二区三| 欧美一级片在线| 日韩理论片网站| 免费观看在线综合色| 91一区在线观看| 亚洲国产成人在线| 美国十次综合导航| 91精品久久久久久蜜臀| 亚洲日本在线视频观看| 国产美女精品一区二区三区| 欧美午夜理伦三级在线观看| 欧美—级在线免费片| 国内成人精品2018免费看| 3atv一区二区三区| 首页国产欧美日韩丝袜| 欧美在线免费观看亚洲| 国产精品乱人伦中文| 韩国一区二区在线观看| 欧美一区二区视频在线观看| 亚洲国产精品嫩草影院| 欧美自拍丝袜亚洲| 一卡二卡三卡日韩欧美| 91小视频在线免费看| 亚洲免费观看高清完整版在线观看 | 久国产精品韩国三级视频| 欧美色图在线观看| 亚洲一区二区三区视频在线播放| zzijzzij亚洲日本少妇熟睡| 国产女同互慰高潮91漫画| 国产一区二区在线电影| 欧美成va人片在线观看| 奇米综合一区二区三区精品视频 | 天天色天天操综合| 欧美高清视频一二三区 | 91精品国产色综合久久不卡蜜臀 | 精品国产a毛片| 免费黄网站欧美| 欧美电影免费观看高清完整版在 | 国产资源在线一区| 精品福利在线导航| 国产激情一区二区三区四区| 精品国产在天天线2019| 国产精品一二一区| 国产精品久久久久久久久久久免费看 | 国产日韩欧美高清| 丁香网亚洲国际| 亚洲欧洲日产国产综合网| 不卡免费追剧大全电视剧网站| 中文字幕亚洲电影| 在线观看日产精品| 日韩和欧美一区二区三区| 日韩一区二区三区视频在线| 九九视频精品免费| 久久精品人人做人人爽人人| 99久久精品免费看国产免费软件| 亚洲欧美偷拍三级| 欧美精品亚洲一区二区在线播放| 免费高清在线一区| 中文字幕欧美日韩一区| 91免费视频网| 亚洲国产视频直播| 日韩免费观看高清完整版| 国产一区二区毛片| 亚洲少妇最新在线视频| 欧美猛男超大videosgay| 狠狠色狠狠色综合系列|