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

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

?? fast_me.c

?? h264標準的VC實現
?? C
?? 第 1 頁 / 共 3 頁
字號:

/*!
 ************************************************************************
 *
 * \file fast_me.c
 *
 * \brief
 *   Fast integer pel motion estimation and fractional pel motion estimation
 *   algorithms are described in this file.
 *   1. get_mem_FME() and free_mem_FME() are functions for allocation and release
 *      of memories about motion estimation
 *   2. FME_BlockMotionSearch() is the function for fast integer pel motion 
 *      estimation and fractional pel motion estimation
 *   3. DefineThreshold() defined thresholds for early termination
 * \author 
 *    Main contributors: (see contributors.h for copyright, address and affiliation details)
 *    - Zhibo Chen         <chenzhibo@tsinghua.org.cn>
 *    - JianFeng Xu        <fenax@video.mdc.tsinghua.edu.cn>  
 * \date    
 *    2003.8
 ************************************************************************
 */

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

#include "global.h"

#include "memalloc.h"
#include "fast_me.h"
#include "refbuf.h"

#define Q_BITS          15

extern  int*   byte_abs;
extern  int*   mvbits;
extern  int*   spiral_search_x;
extern  int*   spiral_search_y;


static pel_t (*PelY_14) (pel_t**, int, int, int, int);
static const int quant_coef[6][4][4] = {
  {{13107, 8066,13107, 8066},{ 8066, 5243, 8066, 5243},{13107, 8066,13107, 8066},{ 8066, 5243, 8066, 5243}},
  {{11916, 7490,11916, 7490},{ 7490, 4660, 7490, 4660},{11916, 7490,11916, 7490},{ 7490, 4660, 7490, 4660}},
  {{10082, 6554,10082, 6554},{ 6554, 4194, 6554, 4194},{10082, 6554,10082, 6554},{ 6554, 4194, 6554, 4194}},
  {{ 9362, 5825, 9362, 5825},{ 5825, 3647, 5825, 3647},{ 9362, 5825, 9362, 5825},{ 5825, 3647, 5825, 3647}},
  {{ 8192, 5243, 8192, 5243},{ 5243, 3355, 5243, 3355},{ 8192, 5243, 8192, 5243},{ 5243, 3355, 5243, 3355}},
  {{ 7282, 4559, 7282, 4559},{ 4559, 2893, 4559, 2893},{ 7282, 4559, 7282, 4559},{ 4559, 2893, 4559, 2893}}
};


void DefineThreshold()
{
  AlphaSec[1] = 0.01f;
  AlphaSec[2] = 0.01f;
  AlphaSec[3] = 0.01f;
  AlphaSec[4] = 0.02f;
  AlphaSec[5] = 0.03f;
  AlphaSec[6] = 0.03f;
  AlphaSec[7] = 0.04f;

  AlphaThird[1] = 0.06f;
  AlphaThird[2] = 0.07f;
  AlphaThird[3] = 0.07f;
  AlphaThird[4] = 0.08f;
  AlphaThird[5] = 0.12f;
  AlphaThird[6] = 0.11f;
  AlphaThird[7] = 0.15f;

  DefineThresholdMB();
  return;
}

void DefineThresholdMB()
{
  int gb_qp_per    = (input->qpN-MIN_QP)/6;
  int gb_qp_rem    = (input->qpN-MIN_QP)%6;
  
  int gb_q_bits    = Q_BITS+gb_qp_per;
  int gb_qp_const,Thresh4x4;

  if (img->type == I_SLICE)
    gb_qp_const=(1<<gb_q_bits)/3;    // intra
  else
    gb_qp_const=(1<<gb_q_bits)/6;    // inter
  
  Thresh4x4 =   ((1<<gb_q_bits) - gb_qp_const)/quant_coef[gb_qp_rem][0][0];
  Quantize_step = Thresh4x4/(4*5.61f);
  Bsize[7]=(16*16)*Quantize_step;

  Bsize[6]=Bsize[7]*4;
  Bsize[5]=Bsize[7]*4;
  Bsize[4]=Bsize[5]*4;
  Bsize[3]=Bsize[4]*4;
  Bsize[2]=Bsize[4]*4;
  Bsize[1]=Bsize[2]*4;
}

/*!
 ************************************************************************
 * \brief
 *    Dynamic memory allocation of all infomation needed for Fast ME
 * \par Input:
 * \return Number of allocated bytes
 * \date 
 *    2003/3
 ************************************************************************
 */

int get_mem_mincost (int****** mv)
{
  int i, j, k, l;

  if ((*mv = (int*****)calloc(input->img_width/4,sizeof(int****))) == NULL)
    no_mem_exit ("get_mem_mv: mv");
  for (i=0; i<input->img_width/4; i++)
  {
    if (((*mv)[i] = (int****)calloc(input->img_height/4,sizeof(int***))) == NULL)
      no_mem_exit ("get_mem_mv: mv");
    for (j=0; j<input->img_height/4; j++)
    {
      if (((*mv)[i][j] = (int***)calloc(img->max_num_references, sizeof(int**))) == NULL)
        no_mem_exit ("get_mem_mv: mv");
      for (k=0; k<img->max_num_references; k++)
      {
        if (((*mv)[i][j][k] = (int**)calloc(9,sizeof(int*))) == NULL)
          no_mem_exit ("get_mem_mv: mv");
        for (l=0; l<9; l++)
          if (((*mv)[i][j][k][l] = (int*)calloc(3,sizeof(int))) == NULL)
            no_mem_exit ("get_mem_mv: mv");
      }
    }
  }

  return input->img_width/4*input->img_height/4*img->max_num_references*9*3*sizeof(int);
}
/*!
 *******************************************************************************
 * \brief
 *    Dynamic memory allocation of all infomation needed for backward prediction
 * \par Input:
 * \return Number of allocated bytes
 * \date 
 *    2003/3
 *******************************************************************************
 */
int get_mem_bwmincost (int****** mv)
{
  int i, j, k, l;


  if ((*mv = (int*****)calloc(input->img_width/4,sizeof(int****))) == NULL)
    no_mem_exit ("get_mem_mv: mv");
  for (i=0; i<input->img_width/4; i++)
  {
    if (((*mv)[i] = (int****)calloc(input->img_height/4,sizeof(int***))) == NULL)
      no_mem_exit ("get_mem_mv: mv");
    for (j=0; j<input->img_height/4; j++)
    {
      if (((*mv)[i][j] = (int***)calloc(img->max_num_references,sizeof(int**))) == NULL)
        no_mem_exit ("get_mem_mv: mv");
      for (k=0; k<img->max_num_references; k++)
      {
        if (((*mv)[i][j][k] = (int**)calloc(9,sizeof(int*))) == NULL)
          no_mem_exit ("get_mem_mv: mv");
        for (l=0; l<9; l++)
          if (((*mv)[i][j][k][l] = (int*)calloc(3,sizeof(int))) == NULL)
            no_mem_exit ("get_mem_mv: mv");
      }
    }
  }

  return input->img_width/4*input->img_height/4*img->max_num_references*9*3*sizeof(int);
}

int get_mem_FME()
{
  int memory_size = 0;
  memory_size += get_mem2Dint(&McostState, 2*input->search_range+1, 2*input->search_range+1);
  memory_size += get_mem_mincost (&(all_mincost));
  memory_size += get_mem_bwmincost(&(all_bwmincost));
  memory_size += get_mem2D(&SearchState,7,7);
  
  return memory_size;
}
/*!
 ************************************************************************
 * \brief
 *    free the memory allocated for of all infomation needed for Fast ME
 * \par Input:
 * \date 
 *    2003/3
 ************************************************************************
 */
void free_mem_mincost (int***** mv)
{
  int i, j, k, l;

  for (i=0; i<input->img_width/4; i++)
  {
    for (j=0; j<input->img_height/4; j++)
    {
      for (k=0; k<img->max_num_references; k++)
      {
        for (l=0; l<9; l++)
          free (mv[i][j][k][l]);
        free (mv[i][j][k]);
      }
      free (mv[i][j]);
    }
    free (mv[i]);
  }
  free (mv);
}

/*!
 ***********************************************************************************
 * \brief
 *    free the memory allocated for of all infomation needed for backward prediction
 * \date 
 *    2003/3
 ***********************************************************************************
 */
void free_mem_bwmincost (int***** mv)
{
  int i, j, k, l;

  for (i=0; i<input->img_width/4; i++)
  {
    for (j=0; j<input->img_height/4; j++)
    {
      for (k=0; k<img->max_num_references; k++)
      {
        for (l=0; l<9; l++)
          free (mv[i][j][k][l]);
        free (mv[i][j][k]);
      }
      free (mv[i][j]);
    }
    free (mv[i]);
  }
  free (mv);
}

void free_mem_FME()
{
  free_mem2Dint(McostState);
  free_mem_mincost (all_mincost);
  free_mem_bwmincost(all_bwmincost);

  free_mem2D(SearchState);
}


int PartCalMad(pel_t *ref_pic,pel_t** orig_pic,pel_t *(*get_ref_line)(int, pel_t*, int, int, int, int), int blocksize_y,int blocksize_x, int blocksize_x4,int mcost,int min_mcost,int cand_x,int cand_y)
{
  int y,x4;
  int height=((img->MbaffFrameFlag)&&(img->mb_data[img->current_mb_nr].mb_field))?img->height/2:img->height;
  pel_t *orig_line, *ref_line;
  for (y=0; y<blocksize_y; y++)
    {
    ref_line  = get_ref_line (blocksize_x, ref_pic, cand_y+y, cand_x, /*img->*/height, img->width);//2004.3.3
    orig_line = orig_pic [y];
    
    for (x4=0; x4<blocksize_x4; x4++)
    {
      mcost += byte_abs[ *orig_line++ - *ref_line++ ];
      mcost += byte_abs[ *orig_line++ - *ref_line++ ];
      mcost += byte_abs[ *orig_line++ - *ref_line++ ];
      mcost += byte_abs[ *orig_line++ - *ref_line++ ];
    }
    if (mcost >= min_mcost)
    {
      break;
    }
    }
    return mcost;
}

/*!
 ************************************************************************
 * \brief
 *    FastIntegerPelBlockMotionSearch: fast pixel block motion search 
 *    this algrithm is called UMHexagonS(see JVT-D016),which includes 
 *    four steps with different kinds of search patterns
 * \par Input:
 * pel_t**   orig_pic,     // <--  original picture
 * int       ref,          // <--  reference frame (0... or -1 (backward))
 * int       pic_pix_x,    // <--  absolute x-coordinate of regarded AxB block
 * int       pic_pix_y,    // <--  absolute y-coordinate of regarded AxB block
 * int       blocktype,    // <--  block type (1-16x16 ... 7-4x4)
 * int       pred_mv_x,    // <--  motion vector predictor (x) in sub-pel units
 * int       pred_mv_y,    // <--  motion vector predictor (y) in sub-pel units
 * int*      mv_x,         //  --> motion vector (x) - in pel units
 * int*      mv_y,         //  --> motion vector (y) - in pel units
 * int       search_range, // <--  1-d search range in pel units                         
 * int       min_mcost,    // <--  minimum motion cost (cost for center or huge value)
 * double    lambda        // <--  lagrangian parameter for determining motion cost
 * \par

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人精品网址| 精品一区二区三区欧美| 中文字幕免费观看一区| 欧美成人vps| 欧美精品一区二区三区蜜桃| 精品免费国产一区二区三区四区| 日韩一区二区在线观看视频播放| 6080国产精品一区二区| 91精品国产欧美一区二区18| 欧美一区二区三区在线看| 欧美人成免费网站| 欧美一区二区三区成人| 欧美一区二区性放荡片| 91麻豆精品91久久久久同性| 精品对白一区国产伦| 国产视频一区在线观看| 国产精品超碰97尤物18| 亚洲精品免费电影| 国产河南妇女毛片精品久久久| 久久亚洲影视婷婷| 欧美不卡一区二区| 久久久久久久久久久黄色| 久久久不卡影院| 亚洲欧洲性图库| 亚洲成av人片在线观看无码| 美女脱光内衣内裤视频久久影院| 极品少妇xxxx精品少妇| 大桥未久av一区二区三区中文| 91免费国产视频网站| 欧美手机在线视频| 51午夜精品国产| 国产目拍亚洲精品99久久精品| 亚洲欧美日韩精品久久久久| 视频一区视频二区在线观看| 韩国av一区二区三区在线观看| 99精品一区二区| 欧美日韩精品一区二区三区四区 | 五月天亚洲精品| 国产一区视频网站| 在线观看一区二区视频| 精品日产卡一卡二卡麻豆| 国产精品毛片大码女人| 日韩vs国产vs欧美| 成人开心网精品视频| 91麻豆精品国产自产在线观看一区 | av日韩在线网站| 日韩欧美在线1卡| 一区二区三区精品视频在线| 国产一区在线观看麻豆| 欧美性三三影院| 国产精品久久午夜| 久久99国产精品久久99果冻传媒| 在线亚洲一区二区| 久久九九久精品国产免费直播| 天天色天天爱天天射综合| 99久久99久久免费精品蜜臀| 精品国产伦一区二区三区观看体验 | 激情都市一区二区| 欧美日韩综合色| 一区二区免费在线| 国产露脸91国语对白| 欧美一区午夜视频在线观看| 亚洲黄一区二区三区| 丁香亚洲综合激情啪啪综合| 精品国产乱码久久久久久久久| 日本欧美加勒比视频| 在线观看一区二区精品视频| 亚洲天堂精品视频| 国产成人亚洲综合色影视| 欧美成人精品高清在线播放 | 欧美一区二区免费视频| 亚洲精品乱码久久久久久日本蜜臀| 国产精品一区二区三区99| 欧美一级理论性理论a| 日韩av二区在线播放| 欧美乱妇20p| 日本vs亚洲vs韩国一区三区二区| 欧美日韩一区二区电影| 偷窥国产亚洲免费视频| 欧美日韩一区二区不卡| 亚洲一区二区三区四区的| 欧美色图12p| 日本视频中文字幕一区二区三区| 91精品在线一区二区| 蜜臀精品一区二区三区在线观看 | 日韩国产精品久久| 欧美精品一级二级三级| 天天影视网天天综合色在线播放| 欧美揉bbbbb揉bbbbb| 婷婷亚洲久悠悠色悠在线播放| 884aa四虎影成人精品一区| 麻豆国产欧美一区二区三区| 精品国产凹凸成av人导航| 国产精品77777| 国产精品日产欧美久久久久| 91社区在线播放| 亚洲午夜久久久久| 欧美一区二区三区的| 国产高清成人在线| 国产精品福利在线播放| 欧美制服丝袜第一页| 蜜臀av性久久久久蜜臀aⅴ流畅| www国产精品av| 91麻豆免费看片| 视频一区中文字幕| 国产亚洲精久久久久久| 欧美在线啊v一区| 青青草国产成人av片免费| 久久久99久久精品欧美| 欧美在线高清视频| 韩国女主播一区| 亚洲精品久久久蜜桃| 欧美成人在线直播| 99久久婷婷国产综合精品电影| 日本特黄久久久高潮| 国产精品素人一区二区| 欧美丰满一区二区免费视频| 成人黄色综合网站| 日韩va亚洲va欧美va久久| 国产精品久久久久一区二区三区| 69p69国产精品| 色综合天天视频在线观看| 激情亚洲综合在线| 亚洲自拍偷拍麻豆| 亚洲国产精品高清| 欧美va亚洲va| 欧美日韩在线亚洲一区蜜芽| 波多野结衣的一区二区三区| 蜜臀av一区二区| 亚洲国产精品精华液网站| 国产无一区二区| 日韩欧美不卡在线观看视频| 91国内精品野花午夜精品| 国产不卡视频在线播放| 久久精品国产77777蜜臀| 亚洲成人高清在线| 日韩码欧中文字| 中文欧美字幕免费| 久久无码av三级| 精品国产免费人成在线观看| 7777精品伊人久久久大香线蕉的| 91福利在线免费观看| 97精品超碰一区二区三区| 国产成人无遮挡在线视频| 九一久久久久久| 久久综合综合久久综合| 亚洲国产另类精品专区| 一区二区三区视频在线看| 中文字幕日本乱码精品影院| 国产精品看片你懂得| 国产精品久久久爽爽爽麻豆色哟哟 | 亚洲电影在线免费观看| 亚洲女子a中天字幕| 日韩久久一区二区| 亚洲精品中文在线观看| 亚洲三级在线播放| 亚洲色图在线播放| 国产精品高潮久久久久无| 国产精品久久久久婷婷| 综合婷婷亚洲小说| 一区二区三区日韩欧美| 一区二区三区日韩欧美| 亚洲一区二区精品视频| 午夜精品一区在线观看| 爽爽淫人综合网网站| 日本va欧美va欧美va精品| 天天色天天操综合| 美国三级日本三级久久99 | 韩国精品主播一区二区在线观看 | 国产激情偷乱视频一区二区三区| 久久99久国产精品黄毛片色诱| 精品无码三级在线观看视频 | 国产精品看片你懂得| 一区二区在线免费观看| 香蕉av福利精品导航| 看国产成人h片视频| 丰满放荡岳乱妇91ww| 欧美中文字幕一区二区三区| 欧美一区二区三区男人的天堂| 久久久五月婷婷| 自拍偷拍国产精品| 日韩不卡一二三区| 大美女一区二区三区| 色中色一区二区| 日韩欧美的一区二区| 日韩一区有码在线| 美女国产一区二区| 91一区二区在线| 精品美女一区二区| 亚洲精品伦理在线| 激情久久久久久久久久久久久久久久| 成人性色生活片| 欧美精品18+| 国产精品天干天干在观线| 舔着乳尖日韩一区| 99久久伊人精品| 精品国产一区久久| 亚洲网友自拍偷拍| bt7086福利一区国产| 精品少妇一区二区三区免费观看|