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

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

?? fast_me.c

?? 一個簡單的視頻會議VC++MFC工程文件
?? 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(img->width/4,sizeof(int****))) == NULL)
    no_mem_exit ("get_mem_mv: mv");
  for (i=0; i<img->width/4; i++)
  {
    if (((*mv)[i] = (int****)calloc(img->height/4,sizeof(int***))) == NULL)
      no_mem_exit ("get_mem_mv: mv");
    for (j=0; j<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 img->width/4*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(img->width/4,sizeof(int****))) == NULL)
    no_mem_exit ("get_mem_mv: mv");
  for (i=0; i<img->width/4; i++)
  {
    if (((*mv)[i] = (int****)calloc(img->height/4,sizeof(int***))) == NULL)
      no_mem_exit ("get_mem_mv: mv");
    for (j=0; j<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 img->width/4*img->height/4*img->max_num_references*9*3*sizeof(int);
}

int get_mem_FME()
{
  int memory_size = 0;
  if (NULL==(flag_intra = calloc ((img->width>>4)+1,sizeof(int)))) no_mem_exit("get_mem_FME: flag_intra");

  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<img->width/4; i++)
  {
    for (j=0; j<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<img->width/4; i++)
  {
    for (j=0; j<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);

  free (flag_intra);
}


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                         

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精选免费视频| 麻豆精品在线观看| 91久久精品国产91性色tv| 18涩涩午夜精品.www| 色综合久久综合网欧美综合网| 国产精品久久久久久久久久久免费看 | 蜜桃免费网站一区二区三区| 91精品午夜视频| 国产麻豆91精品| 国产精品久久福利| 一本一本大道香蕉久在线精品| 亚洲与欧洲av电影| 日韩免费观看高清完整版在线观看| 蜜臀久久久99精品久久久久久| 精品国产1区2区3区| 国产精品一卡二卡在线观看| 国产精品大尺度| 欧美日韩情趣电影| 国产盗摄精品一区二区三区在线| 国产精品不卡一区二区三区| 欧美影院午夜播放| 国产一区二区三区四区五区美女| 国产精品福利av| 欧美人妖巨大在线| 成人免费黄色在线| 亚洲成人av一区二区| 久久久www成人免费无遮挡大片| av激情综合网| 蜜桃视频第一区免费观看| 国产精品久久午夜夜伦鲁鲁| 5858s免费视频成人| 福利一区二区在线观看| 五月天一区二区| 欧美激情在线免费观看| 欧美一区二区三区性视频| 成人性生交大片免费看视频在线 | 成人av网在线| 日韩va亚洲va欧美va久久| 国产精品全国免费观看高清| 5858s免费视频成人| www.激情成人| 国产呦精品一区二区三区网站| 一区二区欧美国产| 国产精品嫩草影院av蜜臀| 欧美一区二区精品久久911| 99久久99精品久久久久久| 美洲天堂一区二卡三卡四卡视频| 亚洲欧美另类小说视频| 久久久国产午夜精品| 666欧美在线视频| 91免费视频网址| 国产不卡视频在线观看| 免费日韩伦理电影| 亚洲成av人片一区二区梦乃| 亚洲色图色小说| 国产精品久久毛片| 欧美激情在线观看视频免费| 精品理论电影在线| 9191成人精品久久| 欧美性三三影院| 色婷婷综合在线| gogo大胆日本视频一区| 成人性色生活片免费看爆迷你毛片| 黑人巨大精品欧美黑白配亚洲| 首页欧美精品中文字幕| 亚洲成av人片在线| 亚洲一区二区三区自拍| 亚洲人亚洲人成电影网站色| 国产精品免费丝袜| 国产欧美精品一区| 欧美激情一区二区三区蜜桃视频| 欧美精品一区二区蜜臀亚洲| 欧美成人精品福利| 精品伦理精品一区| 久久久久综合网| 精品国产百合女同互慰| 精品成人佐山爱一区二区| 欧美zozozo| 久久亚洲捆绑美女| 国产亚洲欧美日韩在线一区| 久久久久久久久久久久电影 | 国产在线播精品第三| 青青草国产成人av片免费| 另类小说综合欧美亚洲| 久久99日本精品| 国产精品69毛片高清亚洲| 国产91色综合久久免费分享| 成人免费视频caoporn| 91日韩在线专区| 欧美人动与zoxxxx乱| 日韩一区二区三免费高清| 久久伊99综合婷婷久久伊| 久久久久国色av免费看影院| 日本一二三不卡| 亚洲激情图片小说视频| 亚州成人在线电影| 精品一区二区综合| 国产成人啪午夜精品网站男同| www.综合网.com| 欧美日韩电影在线| 精品国产百合女同互慰| 中文字幕一区二区三区视频| 亚洲一区二区在线观看视频| 蜜臀久久久久久久| 成人av电影免费观看| 欧美亚洲国产怡红院影院| 日韩欧美国产高清| 亚洲视频综合在线| 日韩va欧美va亚洲va久久| 国产98色在线|日韩| 色偷偷成人一区二区三区91| 日韩一区二区不卡| 中文字幕中文字幕一区| 亚洲第一福利一区| 国产成人啪免费观看软件| 欧美日韩亚洲综合一区二区三区 | 91精品国产手机| 国产精品无码永久免费888| 洋洋成人永久网站入口| 激情欧美一区二区| 欧美亚洲综合另类| 国产欧美日韩视频一区二区| 视频在线观看国产精品| 成人激情午夜影院| 91精品在线麻豆| 亚洲伦在线观看| 国产一区二区精品久久| 欧美精品在线视频| 国产精品视频免费看| 久久精品国产99久久6| 91国产视频在线观看| 久久久美女毛片| 午夜精品影院在线观看| 不卡免费追剧大全电视剧网站| 欧美一区二区高清| 亚洲午夜久久久久久久久电影网| 国产精品18久久久久久久网站| 欧美日韩一区二区不卡| 亚洲欧美视频在线观看视频| 国产一区二区在线看| 3d成人动漫网站| 一区二区三区高清不卡| 成人午夜视频网站| 久久精品水蜜桃av综合天堂| 日本大胆欧美人术艺术动态 | 久草在线在线精品观看| 欧美午夜寂寞影院| 日韩美女视频19| 不卡视频一二三四| 欧美国产日韩亚洲一区| 久久99久久99小草精品免视看| 欧美日本一区二区在线观看| 亚洲视频在线观看三级| 波多野结衣的一区二区三区| 精品国产乱码久久久久久老虎| 日韩中文字幕不卡| 在线这里只有精品| 亚洲一区二区精品久久av| 色偷偷一区二区三区| 亚洲品质自拍视频| 91视频在线观看免费| 国产精品夫妻自拍| 91麻豆国产福利精品| 亚洲欧美激情小说另类| 97se亚洲国产综合自在线观| 国产精品国产三级国产a| www.色精品| 亚洲天堂精品在线观看| 色综合久久九月婷婷色综合| 亚洲欧美国产三级| 91美女福利视频| 亚洲综合色自拍一区| 欧美日韩亚洲不卡| 热久久一区二区| 精品日韩av一区二区| 国内精品久久久久影院色| 久久日韩粉嫩一区二区三区| 国产福利不卡视频| 亚洲国产精品99久久久久久久久| av在线播放不卡| 一区二区三区在线视频观看| 欧美日韩综合在线| 麻豆一区二区三区| 久久精品免费在线观看| av福利精品导航| 亚洲精品乱码久久久久久| 在线精品视频一区二区| 麻豆专区一区二区三区四区五区| 亚洲精品在线观看网站| www.欧美色图| 午夜视频一区在线观看| 久久一区二区三区四区| 91在线丨porny丨国产| 亚洲高清视频在线| 精品成人佐山爱一区二区| 波多野洁衣一区| 天天色图综合网| 国产欧美日韩久久| 欧美三区免费完整视频在线观看| 美女高潮久久久|