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

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

?? mbuffer.c

?? the newest JM software by h.264 JVT official reference model.
?? C
?? 第 1 頁 / 共 5 頁
字號:

/*!
 ***********************************************************************
 *  \file
 *      mbuffer.c
 *
 *  \brief
 *      Frame buffer functions
 *
 *  \author
 *      Main contributors (see contributors.h for copyright, address and affiliation details)
 *      - Karsten S黨ring                 <suehring@hhi.de>
 *      - Alexis Tourapis                 <alexismt@ieee.org>
 ***********************************************************************
 */

#include <limits.h>

#include "global.h"
#include "mbuffer.h"
#include "memalloc.h"
#include "output.h"
#include "image.h"
#include "nalucommon.h"

extern void init_stats (StatParameters *stats);
static void insert_picture_in_dpb(FrameStore* fs, StorablePicture* p);
static void output_one_frame_from_dpb(void);
static int  is_used_for_reference(FrameStore* fs);
static void get_smallest_poc(int *poc,int * pos);
static int  remove_unused_frame_from_dpb(void);
static int  is_short_term_reference(FrameStore* fs);
static int  is_long_term_reference(FrameStore* fs);
void gen_field_ref_ids(StorablePicture *p);

DecodedPictureBuffer dpb;

StorablePicture **listX[6];

ColocatedParams *Co_located = NULL;

ColocatedParams *Co_located_JV[MAX_PLANE] = { NULL, NULL, NULL };  //!< Co_located to be used during 4:4:4 independent mode encoding

int listXsize[6];

#define MAX_LIST_SIZE 33

/*!
 ************************************************************************
 * \brief
 *    Print out list of pictures in DPB. Used for debug purposes.
 ************************************************************************
 */
void dump_dpb(void)
{
#if DUMP_DPB
  unsigned i;

  for (i=0; i<dpb.used_size;i++)
  {
    printf("(");
    printf("fn=%d  ", dpb.fs[i]->frame_num);
    if (dpb.fs[i]->is_used & 1)
    {
      if (dpb.fs[i]->top_field)
        printf("T: poc=%d  ", dpb.fs[i]->top_field->poc);
      else
        printf("T: poc=%d  ", dpb.fs[i]->frame->top_poc);
    }
    if (dpb.fs[i]->is_used & 2)
    {
      if (dpb.fs[i]->bottom_field)
        printf("B: poc=%d  ", dpb.fs[i]->bottom_field->poc);
      else
        printf("B: poc=%d  ", dpb.fs[i]->frame->bottom_poc);
    }
    if (dpb.fs[i]->is_used == 3)
      printf("F: poc=%d  ", dpb.fs[i]->frame->poc);
    printf("G: poc=%d)  ", dpb.fs[i]->poc);
    if (dpb.fs[i]->is_reference) printf ("ref (%d) ", dpb.fs[i]->is_reference);
    if (dpb.fs[i]->is_long_term) printf ("lt_ref (%d) ", dpb.fs[i]->is_reference);
    if (dpb.fs[i]->is_output) printf ("out  ");
    if (dpb.fs[i]->is_used == 3)
    {
      if (dpb.fs[i]->frame->non_existing) printf ("ne  ");
    }
    printf ("\n");
  }
#endif
}

/*!
 ************************************************************************
 * \brief
 *    Returns the size of the dpb depending on level and picture size
 *
 *
 ************************************************************************
 */
int getDpbSize(void)
{
  int pic_size = (active_sps->pic_width_in_mbs_minus1 + 1) * (active_sps->pic_height_in_map_units_minus1 + 1) * (active_sps->frame_mbs_only_flag?1:2) * 384;

  int size = 0;

  switch (active_sps->level_idc)
  {
  case 9:
    size = 152064;
    break;
  case 10:
    size = 152064;
    break;
  case 11:
    if (!IS_FREXT_PROFILE(active_sps->profile_idc)&&(active_sps->constrained_set3_flag == 1))
      size = 152064;
    else
      size = 345600;
    break;
  case 12:
    size = 912384;
    break;
  case 13:
    size = 912384;
    break;
  case 20:
    size = 912384;
    break;
  case 21:
    size = 1824768;
    break;
  case 22:
    size = 3110400;
    break;
  case 30:
    size = 3110400;
    break;
  case 31:
    size = 6912000;
    break;
  case 32:
    size = 7864320;
    break;
  case 40:
    size = 12582912;
    break;
  case 41:
    size = 12582912;
    break;
  case 42:
    size = 13369344;
    break;
  case 50:
    size = 42393600;
    break;
  case 51:
    size = 70778880;
    break;
  default:
    error ("undefined level", 500);
    break;
  }

  size /= pic_size;
  return imin( size, 16);
}

/*!
 ************************************************************************
 * \brief
 *    Check then number of frames marked "used for reference" and break
 *    if maximum is exceeded
 *
 ************************************************************************
 */
void check_num_ref(void)
{
  if ((int)(dpb.ltref_frames_in_buffer +  dpb.ref_frames_in_buffer ) > (imax(1,img->num_ref_frames)))
  {
    error ("Max. number of reference frames exceeded. Invalid stream.", 500);
  }
}


/*!
 ************************************************************************
 * \brief
 *    Allocate memory for decoded picture buffer and initialize with sane values.
 *
 ************************************************************************
 */
void init_dpb(void)
{
  unsigned i,j;

  if (dpb.init_done)
  {
    free_dpb();
  }

  dpb.size      = getDpbSize();

  if (dpb.size < (unsigned int)params->num_ref_frames)
  {
    error ("DPB size at specified level is smaller than the specified number of reference frames. This is not allowed.\n", 1000);
  }

  dpb.used_size = 0;
  dpb.last_picture = NULL;

  dpb.ref_frames_in_buffer = 0;
  dpb.ltref_frames_in_buffer = 0;

  dpb.fs = calloc(dpb.size, sizeof (FrameStore*));
  if (NULL==dpb.fs)
    no_mem_exit("init_dpb: dpb->fs");

  dpb.fs_ref = calloc(dpb.size, sizeof (FrameStore*));
  if (NULL==dpb.fs_ref)
    no_mem_exit("init_dpb: dpb->fs_ref");

  dpb.fs_ltref = calloc(dpb.size, sizeof (FrameStore*));
  if (NULL==dpb.fs_ltref)
    no_mem_exit("init_dpb: dpb->fs_ltref");

  for (i = 0; i < dpb.size; i++)
  {
    dpb.fs[i]       = alloc_frame_store();
    dpb.fs_ref[i]   = NULL;
    dpb.fs_ltref[i] = NULL;
  }

  for (i = 0; i < 6; i++)
  {
    listX[i] = calloc(MAX_LIST_SIZE, sizeof (StorablePicture*)); // +1 for reordering
    if (NULL==listX[i])
      no_mem_exit("init_dpb: listX[i]");
  }

  for (j = 0; j < 6; j++)
  {
    for (i = 0; i < MAX_LIST_SIZE; i++)
    {
      listX[j][i] = NULL;
    }
    listXsize[j]=0;
  }

  dpb.last_output_poc = INT_MIN;

  img->last_has_mmco_5 = 0;

  dpb.init_done = 1;
}


/*!
 ************************************************************************
 * \brief
 *    Free memory for decoded picture buffer.
 ************************************************************************
 */
void free_dpb(void)
{
  unsigned i;
  if (dpb.fs)
  {
    for (i=0; i<dpb.size; i++)
    {
      free_frame_store(dpb.fs[i]);
    }
    free (dpb.fs);
    dpb.fs=NULL;
  }
  if (dpb.fs_ref)
  {
    free (dpb.fs_ref);
  }
  if (dpb.fs_ltref)
  {
    free (dpb.fs_ltref);
  }
  dpb.last_output_poc = INT_MIN;

  for (i=0; i<6; i++)
    if (listX[i])
    {
      free (listX[i]);
      listX[i] = NULL;
    }

  dpb.init_done = 0;
}


/*!
 ************************************************************************
 * \brief
 *    Allocate memory for decoded picture buffer frame stores an initialize with sane values.
 *
 * \return
 *    the allocated FrameStore structure
 ************************************************************************
 */
FrameStore* alloc_frame_store(void)
{
  FrameStore *f;

  f = calloc (1, sizeof(FrameStore));
  if (NULL==f)
    no_mem_exit("alloc_frame_store: f");

  f->is_used      = 0;
  f->is_reference = 0;
  f->is_long_term = 0;
  f->is_orig_reference = 0;

  f->is_output = 0;

  f->frame        = NULL;;
  f->top_field    = NULL;
  f->bottom_field = NULL;

  return f;
}

void alloc_pic_motion(PicMotionParams *motion, int size_y, int size_x)
{
  if (active_sps->frame_mbs_only_flag)
  {
    get_mem3Dint64 (&(motion->ref_pic_id), 2, size_y, size_x);
    get_mem3Dint64 (&(motion->ref_id),     2, size_y, size_x);
  }
  else
  {
    get_mem3Dint64 (&(motion->ref_pic_id), 6, size_y, size_x);
    get_mem3Dint64 (&(motion->ref_id),     6, size_y, size_x);
  }

  get_mem4Dshort (&(motion->mv),         2, size_y, size_x, 2);
  get_mem3D((byte****)(&(motion->ref_idx)), 2, size_y, size_x);

  motion->mb_field = calloc (size_y * size_x, sizeof(byte));
  if (motion->mb_field == NULL)
    no_mem_exit("alloc_storable_picture: motion->mb_field");

  get_mem2D (&(motion->field_frame), size_y, size_x);
}

/*!
 ************************************************************************
 * \brief
 *    Allocate memory for a stored picture.
 *
 * \param structure
 *    picture structure
 * \param size_x
 *    horizontal luma size
 * \param size_y
 *    vertical luma size
 * \param size_x_cr
 *    horizontal chroma size
 * \param size_y_cr
 *    vertical chroma size
 *
 * \return
 *    the allocated StorablePicture structure
 ************************************************************************
 */
StorablePicture* alloc_storable_picture(PictureStructure structure, int size_x, int size_y, int size_x_cr, int size_y_cr)
{
  StorablePicture *s;
  int   nplane;
  int   dec;
  int   ndec = params->NoOfDecoders;

  //printf ("Allocating (%s) picture (x=%d, y=%d, x_cr=%d, y_cr=%d)\n", (type == FRAME)?"FRAME":(type == TOP_FIELD)?"TOP_FIELD":"BOTTOM_FIELD", size_x, size_y, size_x_cr, size_y_cr);

  s = calloc (1, sizeof(StorablePicture));
  if (NULL==s)
    no_mem_exit("alloc_storable_picture: s");

  s->imgUV      = NULL;
  s->imgY_sub   = NULL;
  s->imgUV_sub  = NULL;
  
  s->p_img_sub[0] = NULL;
  s->p_img_sub[1] = NULL;
  s->p_img_sub[2] = NULL;

  s->dec_imgY     = NULL;
  s->dec_imgUV    = NULL;
  s->mb_error_map = NULL;
  s->p_dec_img[0] = NULL;
  s->p_dec_img[1] = NULL;
  s->p_dec_img[2] = NULL;

  if ((params->rdopt == 3) && (ndec > 0))  //PPAHA_TODO: Need to verify whether both checks are necessary.
  {
    get_mem3D(&(s->mb_error_map), ndec, size_y/MB_BLOCK_SIZE, size_x/MB_BLOCK_SIZE);
    get_mem3Dpel(&(s->dec_imgY), ndec, size_y, size_x);

    // This seems somewhat inefficient. Why not allocate array as [ndec][x] where x goes from 0 to 2?
    if ((s->p_dec_img[0] = (imgpel***)calloc(ndec,sizeof(imgpel**))) == NULL)
    {
      no_mem_exit("mbuffer.c: p_dec_img[0]");
    }

    if (img->yuv_format != YUV400)
    {
      get_mem4Dpel(&(s->dec_imgUV), ndec, 2, size_y_cr, size_x_cr);
      if ((s->p_dec_img[1] = (imgpel***)calloc(ndec,sizeof(imgpel**))) == NULL)
      {
        no_mem_exit("mbuffer.c: p_dec_img[1]");
      }
      if ((s->p_dec_img[2] = (imgpel***)calloc(ndec,sizeof(imgpel**))) == NULL)
      {
        no_mem_exit("mbuffer.c: p_dec_img[2]");
      }
    }
  
    for (dec = 0; dec < ndec; dec++)
    {
      s->p_dec_img[0][dec] = s->dec_imgY[dec];
    }

    if (img->yuv_format != YUV400)
    {
      for (dec = 0; dec < ndec; dec++)
      {
        s->p_dec_img[1][dec] = s->dec_imgUV[dec][0];
        s->p_dec_img[2][dec] = s->dec_imgUV[dec][1];
      }
    }
  }

  get_mem2Dpel (&(s->imgY), size_y, size_x);
  s->p_img[0] = s->imgY;
  s->p_curr_img = s->p_img[0];

  if (img->yuv_format != YUV400)
  {
    get_mem3Dpel (&(s->imgUV), 2, size_y_cr, size_x_cr);
    s->p_img[1] = s->imgUV[0];
    s->p_img[2] = s->imgUV[1];
  }
    
  s->p_curr_img_sub = s->p_img_sub[0];

  /*
  if (params->MbInterlace)
    get_mem3Dmp    (&s->mv_info, size_y, size_x, 6);
  else
    get_mem3Dmp    (&s->mv_info, size_y, size_x, 2);
    */

  alloc_pic_motion(&s->motion, size_y / BLOCK_SIZE, size_x / BLOCK_SIZE);

  if( IS_INDEPENDENT(params) )
  {
    for( nplane=0; nplane<MAX_PLANE; nplane++ )
    {
      alloc_pic_motion(&s->JVmotion[nplane], size_y / BLOCK_SIZE, size_x / BLOCK_SIZE);
    }
  }

  s->pic_num=0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品粉嫩超白一线天av| 一个色妞综合视频在线观看| 国产精品毛片高清在线完整版| ●精品国产综合乱码久久久久| 亚洲国产一区二区a毛片| 国模娜娜一区二区三区| 色又黄又爽网站www久久| 日韩欧美国产一区在线观看| 亚洲欧美另类久久久精品2019| 国产一区999| 日韩欧美一区二区久久婷婷| 玉米视频成人免费看| 国产中文字幕精品| 欧美影院精品一区| 久久久不卡网国产精品二区| 婷婷中文字幕一区三区| 色综合久久久久综合99| 久久久久88色偷偷免费| 裸体健美xxxx欧美裸体表演| 欧美日韩亚洲高清一区二区| 亚洲精品日韩综合观看成人91| 国产黄色91视频| 欧美精品一区二| 久久激情五月激情| 欧美福利视频一区| 午夜久久久久久久久久一区二区| 99精品视频中文字幕| 国产精品久久影院| 丁香婷婷综合五月| 久久久精品影视| 国产一区二区看久久| 精品成人免费观看| 蜜臀av在线播放一区二区三区| 欧美日韩精品一区二区三区| 亚洲一区免费视频| 欧美日韩免费观看一区二区三区 | 成人18视频日本| 久久久777精品电影网影网| 国产在线精品一区二区不卡了| 欧美成人一区二区三区片免费| 天天色 色综合| 91麻豆精品国产91久久久久| 三级欧美在线一区| 51精品国自产在线| 精品一区二区三区在线观看| 欧美mv日韩mv亚洲| 国产馆精品极品| 国产精品不卡在线| 欧美午夜宅男影院| 肉丝袜脚交视频一区二区| 欧美疯狂性受xxxxx喷水图片| 全部av―极品视觉盛宴亚洲| 日韩欧美第一区| 懂色av一区二区三区免费看| 亚洲欧美一区二区三区孕妇| 欧美性生活大片视频| 免费观看一级欧美片| 国产无一区二区| 在线视频你懂得一区二区三区| 首页综合国产亚洲丝袜| 精品国产一区二区三区忘忧草 | 亚洲精品视频在线观看免费 | 国产99久久精品| 一区二区三区四区在线播放| 91精品在线一区二区| 国产高清成人在线| 亚洲欧美另类久久久精品| 777欧美精品| 丁香天五香天堂综合| 亚洲午夜久久久久久久久电影网| 欧美一级高清片| 成人av免费在线| 日韩不卡手机在线v区| 国产精品久久综合| 日韩欧美aaaaaa| 91在线你懂得| 久久国产精品露脸对白| 中文字幕一区二区三区四区 | 欧美亚洲高清一区二区三区不卡| 免费精品视频在线| 一区二区三区加勒比av| 精品国产1区2区3区| 日本精品免费观看高清观看| 久久成人免费网站| 亚洲va欧美va国产va天堂影院| 国产欧美中文在线| 日韩视频中午一区| 在线亚洲免费视频| 国产.精品.日韩.另类.中文.在线.播放| 一区av在线播放| 欧美国产一区视频在线观看| 欧美日韩精品一区二区| 成人h精品动漫一区二区三区| 首页国产欧美日韩丝袜| 中文字幕色av一区二区三区| 久久婷婷国产综合精品青草| 欧美久久久久免费| 91网上在线视频| 成人精品视频一区二区三区| 激情图片小说一区| 麻豆国产欧美日韩综合精品二区| 亚洲国产日韩av| 亚洲一区二区三区中文字幕在线| 亚洲欧洲日产国码二区| 国产欧美一区二区三区在线看蜜臀| 欧美精品色一区二区三区| 日本高清不卡在线观看| 国产99久久精品| 夫妻av一区二区| 国产一区二区毛片| 国产精品性做久久久久久| 另类中文字幕网| 麻豆免费看一区二区三区| 日日噜噜夜夜狠狠视频欧美人| 五月天久久比比资源色| 亚洲亚洲人成综合网络| 一级女性全黄久久生活片免费| 亚洲欧洲日韩在线| 亚洲狠狠丁香婷婷综合久久久| 亚洲伦在线观看| 亚洲观看高清完整版在线观看| 一区二区三区四区高清精品免费观看 | 国产农村妇女精品| 国产午夜精品久久久久久免费视 | 欧美一区二区三区系列电影| 91精品国产丝袜白色高跟鞋| 欧美一区二区高清| 久久综合精品国产一区二区三区| 欧美va在线播放| 国产亚洲欧洲997久久综合| 国产日韩欧美高清在线| 亚洲日韩欧美一区二区在线| 亚洲精品日产精品乱码不卡| 天天亚洲美女在线视频| 精品亚洲免费视频| 成人免费精品视频| 欧美色精品在线视频| 欧美电视剧免费全集观看| 亚洲国产精品高清| 亚洲国产成人91porn| 免费在线观看一区| 成人一二三区视频| 在线观看日韩一区| 久久人人爽人人爽| 亚洲天堂成人在线观看| 日韩电影在线免费| 成人综合婷婷国产精品久久蜜臀 | 亚洲综合色网站| 麻豆91精品视频| 91在线观看免费视频| 91精品免费在线观看| 中文字幕的久久| 日韩国产高清在线| 丁香六月综合激情| 欧美视频中文一区二区三区在线观看| 91精品国产综合久久香蕉的特点| 久久精品日韩一区二区三区| 亚洲高清视频在线| 国产精品综合二区| 欧美日韩在线播放一区| 久久久久久久电影| 亚洲电影中文字幕在线观看| 国产成人免费视频网站 | 日韩在线一二三区| 成人免费毛片嘿嘿连载视频| 欧美久久久久久蜜桃| 中文字幕在线不卡一区| 韩国三级电影一区二区| 日本高清不卡aⅴ免费网站| 国产色婷婷亚洲99精品小说| 亚洲成人免费电影| 91网站最新网址| 久久久久久亚洲综合| 图片区小说区国产精品视频| 91麻豆国产自产在线观看| 久久一夜天堂av一区二区三区| 亚洲午夜国产一区99re久久| 丁香网亚洲国际| 久久蜜桃av一区精品变态类天堂| 午夜视频一区在线观看| 色综合咪咪久久| 中文字幕精品三区| 狠狠久久亚洲欧美| 日韩欧美中文字幕公布| 亚洲成av人影院在线观看网| 一本色道亚洲精品aⅴ| 国产精品久久久久久久久免费樱桃| 免费av网站大全久久| 91.麻豆视频| 图片区小说区国产精品视频| 欧美日韩综合在线免费观看| 日韩毛片精品高清免费| 不卡视频在线看| 国产精品久久毛片a| 成人激情文学综合网| 国产精品水嫩水嫩| 成人黄色一级视频| 国产精品三级视频| 91色九色蝌蚪| 亚洲一区二区三区影院|