亚洲欧美第一页_禁久久精品乱码_粉嫩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传媒视频在线播放| 精品国产制服丝袜高跟| 麻豆国产精品一区二区三区 | 成人高清免费观看| 国产亲近乱来精品视频| 99国产精品99久久久久久| 亚洲欧美福利一区二区| 欧美丰满美乳xxx高潮www| 秋霞国产午夜精品免费视频| 久久夜色精品国产噜噜av| 成人免费va视频| 亚洲激情欧美激情| 日韩一区二区三区观看| 国产成人av电影在线| 亚洲激情自拍视频| 欧美一区二区三区日韩| 成人黄色国产精品网站大全在线免费观看 | 精品日韩欧美在线| 夫妻av一区二区| 亚洲午夜久久久久久久久久久| 91精品国产麻豆国产自产在线 | 91精品国产综合久久国产大片| 国内外精品视频| 亚洲免费观看高清在线观看| 欧美一级日韩一级| 成人免费视频视频| 秋霞国产午夜精品免费视频| 国产精品美女一区二区三区 | 成人性生交大合| 视频一区二区国产| 国产精品美女久久久久久久久| 制服丝袜亚洲色图| 99久久99久久综合| 久久激五月天综合精品| 一区二区三区精品| 久久精品日产第一区二区三区高清版 | av在线播放成人| 日本成人在线视频网站| 亚洲欧美综合在线精品| 精品国产乱码久久久久久牛牛| 91福利小视频| 成人看片黄a免费看在线| 日本成人中文字幕| 亚洲综合无码一区二区| 日本一区二区三区久久久久久久久不| 欧美日韩国产免费| 北条麻妃一区二区三区| 国产一区二区女| 日韩国产成人精品| 一级中文字幕一区二区| 国产精品美女久久福利网站| 精品日韩在线观看| 91精品国产91久久久久久一区二区 | 裸体在线国模精品偷拍| 亚洲最大的成人av| 国产精品乱人伦中文| www激情久久| 精品国产百合女同互慰| 91精品国产乱码| 在线不卡一区二区| 欧美视频完全免费看| 色综合久久综合网| 精品一区二区三区免费观看| 天天综合色天天综合| 亚洲丰满少妇videoshd| 亚洲激情图片小说视频| 亚洲精品日韩一| 亚洲免费伊人电影| 亚洲日本va在线观看| 亚洲欧洲性图库| 国产精品萝li| 亚洲色图清纯唯美| 中文字幕第一页久久| 久久综合久久综合久久| 久久久激情视频| 中文字幕不卡的av| 欧美国产1区2区| 国产精品电影一区二区| 最近日韩中文字幕| 一卡二卡三卡日韩欧美| 亚洲高清三级视频| 欧美aaaaa成人免费观看视频| 日韩中文字幕麻豆| 三级欧美韩日大片在线看| 美女脱光内衣内裤视频久久网站| 奇米777欧美一区二区| 激情六月婷婷久久| 国产suv一区二区三区88区| 成人黄色免费短视频| 91在线码无精品| 欧美体内she精高潮| 91.麻豆视频| 日韩一区二区精品在线观看| 精品成人免费观看| 国产精品免费丝袜| 亚洲综合小说图片| 蜜臂av日日欢夜夜爽一区| 国产麻豆视频一区二区| 99在线精品观看| 欧美午夜一区二区三区| 91精品国产色综合久久不卡蜜臀| 精品国产1区二区| 亚洲视频中文字幕| 日韩av一区二区在线影视| 色网综合在线观看| 在线不卡的av| 精品欧美乱码久久久久久1区2区| 中文字幕乱码亚洲精品一区| 亚洲精品国产a| 韩国v欧美v日本v亚洲v| 色视频成人在线观看免| 51精品视频一区二区三区| 国产亚洲欧美激情| 一区二区在线观看免费| 精品一区二区在线免费观看| 91尤物视频在线观看| 欧美一区二区视频在线观看| 欧美日韩国产三级| 亚洲影视在线播放| 日产欧产美韩系列久久99| 国产凹凸在线观看一区二区| 精品视频全国免费看| 久久综合久久综合亚洲| 亚洲电影在线免费观看| 国产一区二区三区免费看| 欧美亚一区二区| 欧美极品少妇xxxxⅹ高跟鞋| 日本亚洲天堂网| 色呦呦日韩精品| 久久久精品国产免费观看同学| 五月天一区二区| 91蝌蚪porny成人天涯| 日韩精品中文字幕一区| 亚洲综合图片区| 不卡欧美aaaaa| 精品国产乱子伦一区| 亚洲成a人片在线观看中文| 国产99久久久久久免费看农村| 91精品在线免费观看| 亚洲女与黑人做爰| 国产成人免费视频精品含羞草妖精| 91精品蜜臀在线一区尤物| 亚洲精品国产成人久久av盗摄| 美日韩一区二区| 国产色91在线| 国产精品77777| 欧美日韩国产电影| 国产精品国产a| 国产精一区二区三区| 91精品国产综合久久香蕉的特点| 亚洲日本一区二区| 粉嫩av亚洲一区二区图片| 久久男人中文字幕资源站| 日韩成人精品在线观看| 欧美日韩性生活| 亚洲aaa精品| 欧美精品久久一区二区三区| 亚洲国产日韩av| 欧美视频在线播放| 亚洲一级二级在线| 欧美日韩国产高清一区二区| 亚洲国产精品久久久男人的天堂| 91免费国产在线| 亚洲免费观看高清在线观看| 91丨九色porny丨蝌蚪| 亚洲人午夜精品天堂一二香蕉| 91麻豆国产香蕉久久精品| 综合色中文字幕| 色av一区二区| 亚洲丶国产丶欧美一区二区三区| 欧美午夜一区二区三区免费大片| 亚洲成人综合在线| 欧美老女人第四色| 日本不卡免费在线视频| 精品久久久久久无| 国产精品99久久久| 国产精品久久99| 一本到不卡免费一区二区| 亚洲国产中文字幕在线视频综合 | av电影天堂一区二区在线| 欧美高清在线一区二区| 91麻豆国产精品久久| 亚洲成av人片在www色猫咪| 日韩欧美色电影| 国产一本一道久久香蕉| 亚洲欧美自拍偷拍| 91原创在线视频| 日本午夜一区二区| 久久久精品国产免费观看同学| 91在线看国产| 日韩精品亚洲一区二区三区免费| 精品久久久久久久久久久久久久久久久| 国产一区二区在线观看免费| 中文字幕中文字幕在线一区 | 美腿丝袜亚洲综合| 国产精品人成在线观看免费| 欧美性xxxxxxxx| 国产综合色视频| 亚洲精品乱码久久久久久黑人|