亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
99久久久久久99| 99精品热视频| 五月天丁香久久| 亚洲国产日韩精品| 一区二区三区蜜桃| 亚洲成人在线网站| 日韩中文字幕亚洲一区二区va在线| 亚欧色一区w666天堂| 日韩电影一区二区三区四区| 丝袜美腿一区二区三区| 麻豆精品一区二区三区| 狠狠色综合播放一区二区| 国产自产2019最新不卡| 国产精品中文字幕日韩精品| 成人午夜电影网站| 色婷婷久久久久swag精品 | 91网站视频在线观看| 99re热这里只有精品视频| 在线中文字幕不卡| 日韩欧美一区二区不卡| 国产亚洲综合av| 亚洲一区二区在线视频| 蜜臀久久99精品久久久久久9| 激情文学综合丁香| 日本大香伊一区二区三区| 欧美日韩在线一区二区| 欧美成人一区二区三区片免费| 国产亚洲视频系列| 亚洲高清免费观看高清完整版在线观看| 亚洲va欧美va人人爽午夜| 国产成人综合自拍| 欧美日韩高清影院| 中文字幕成人网| 日日夜夜精品视频免费| 成人国产精品视频| 91精品福利在线一区二区三区| 国产日产欧美一区| 青青国产91久久久久久| 成a人片亚洲日本久久| 日韩一区二区三区电影 | 亚洲第一在线综合网站| 国产高清不卡二三区| 在线观看91精品国产入口| 久久亚区不卡日本| 丝袜国产日韩另类美女| 色综合久久久久网| 中文字幕巨乱亚洲| 精品一区二区三区香蕉蜜桃| 欧美三级欧美一级| 亚洲精品视频免费观看| 国产91综合网| 2014亚洲片线观看视频免费| 亚洲3atv精品一区二区三区| 一本色道**综合亚洲精品蜜桃冫| 2023国产精华国产精品| 青青草伊人久久| 欧美日韩国产一区二区三区地区| 亚洲日本丝袜连裤袜办公室| 国产裸体歌舞团一区二区| 日韩精品一区二区三区在线观看| 亚洲123区在线观看| 色婷婷久久综合| 亚洲九九爱视频| 色综合欧美在线| 亚洲人吸女人奶水| 91麻豆精东视频| 亚洲欧美综合在线精品| 99久久精品免费看| 国产精品国产自产拍高清av王其| 国产精品一区二区在线播放| 久久久www成人免费毛片麻豆| 狠狠色伊人亚洲综合成人| 欧美一区二区性放荡片| 免费在线观看一区| 欧美精品一区二区三区很污很色的| 日韩专区一卡二卡| 日韩欧美精品三级| 国产九色精品成人porny| 亚洲精品一线二线三线| 国产在线精品一区二区三区不卡 | 精品午夜久久福利影院| 91精品国产色综合久久不卡蜜臀| 日产欧产美韩系列久久99| 欧美第一区第二区| 国产一区视频网站| 国产精品久久久久久一区二区三区| 成人免费视频一区| 亚洲欧美另类图片小说| 欧美放荡的少妇| 精品一区二区久久| 国产精品女同互慰在线看| 日本道精品一区二区三区| 蜜桃一区二区三区在线| 久久久亚洲国产美女国产盗摄 | 国产精品天美传媒沈樵| 91免费视频网| 免费不卡在线观看| 欧美国产激情二区三区| 在线观看区一区二| 日产国产欧美视频一区精品| 久久久久久久免费视频了| 99视频精品在线| 日韩电影免费在线观看网站| 久久亚洲春色中文字幕久久久| 99视频精品免费视频| 天天综合网天天综合色| 国产偷国产偷精品高清尤物| 色狠狠综合天天综合综合| 日本91福利区| 亚洲男人都懂的| www激情久久| 欧美亚洲自拍偷拍| 国产精品资源网| 亚洲高清久久久| 中文字幕永久在线不卡| 日韩亚洲欧美高清| 91麻豆蜜桃一区二区三区| 久久国产尿小便嘘嘘尿| 一区二区三区在线播放| 久久精品人人做人人爽97| 欧美猛男男办公室激情| 99视频精品免费视频| 国内精品嫩模私拍在线| 亚洲v日本v欧美v久久精品| 中文字幕精品一区| 欧美tk—视频vk| 欧美日本韩国一区| 91小视频免费观看| 福利视频网站一区二区三区| 免费欧美高清视频| 亚洲国产成人精品视频| 亚洲色图视频网| 日本一区二区成人在线| 精品国产自在久精品国产| 精品视频在线免费| yourporn久久国产精品| 国产不卡视频在线播放| 九九**精品视频免费播放| 亚洲va天堂va国产va久| 亚洲精品国产品国语在线app| 国产午夜精品美女毛片视频| 精品免费国产二区三区| 3d动漫精品啪啪| 欧美男女性生活在线直播观看| 日本久久一区二区三区| 成人sese在线| 99精品视频中文字幕| 成人av网在线| thepron国产精品| 成人三级在线视频| 97se亚洲国产综合自在线不卡| 国产成人精品免费| 国产999精品久久久久久| 懂色av噜噜一区二区三区av| 成人av电影免费在线播放| 国产成a人亚洲| 99久久精品国产精品久久| 成人黄色a**站在线观看| 成人动漫一区二区在线| 色香色香欲天天天影视综合网| 91麻豆国产自产在线观看| 色视频成人在线观看免| 色av成人天堂桃色av| 欧美色大人视频| 91精品在线一区二区| 欧美精品一区二区蜜臀亚洲| 国产清纯白嫩初高生在线观看91 | 蜜桃视频一区二区| 国内精品第一页| 99这里只有久久精品视频| 色哟哟日韩精品| 777精品伊人久久久久大香线蕉| 777xxx欧美| 欧美国产激情二区三区 | 久久精品国产亚洲aⅴ| 国产麻豆精品在线观看| 91成人在线精品| 日韩精品中午字幕| 亚洲欧美影音先锋| 亚洲h在线观看| 国产盗摄女厕一区二区三区 | 一区二区高清在线| 蜜臀va亚洲va欧美va天堂 | 国产精品香蕉一区二区三区| 成人app网站| 欧美精品久久一区二区三区| 2024国产精品视频| 亚洲伊人色欲综合网| 国产一区二区电影| 欧美在线视频日韩| 精品三级在线看| 亚洲尤物视频在线| 国产不卡视频在线观看| 67194成人在线观看| 欧美国产成人精品| 男人的j进女人的j一区| gogo大胆日本视频一区| 欧美一区二区三区四区高清| 综合欧美一区二区三区| 狠狠色狠狠色合久久伊人|