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

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

?? mbuffer.c

?? the newest JM software by h.264 JVT official reference model.
?? C
?? 第 1 頁 / 共 5 頁
字號:
    {
      if (listX[0][j]!=listX[1][j])
        diff=1;
    }
    if (!diff)
    {
      tmp_s = listX[1][0];
      listX[1][0]=listX[1][1];
      listX[1][1]=tmp_s;
    }
  }

  // set max size
  listXsize[0] = imin (listXsize[0], img->num_ref_idx_l0_active);
  listXsize[1] = imin (listXsize[1], img->num_ref_idx_l1_active);

  // set the unused list entries to NULL
  for (i=listXsize[0]; i< (MAX_LIST_SIZE) ; i++)
  {
    listX[0][i] = NULL;
  }
  for (i=listXsize[1]; i< (MAX_LIST_SIZE) ; i++)
  {
    listX[1][i] = NULL;
  }
}

/*!
 ************************************************************************
 * \brief
 *    Initialize listX[2..5] from lists 0 and 1
 *    listX[2]: list0 for current_field==top
 *    listX[3]: list1 for current_field==top
 *    listX[4]: list0 for current_field==bottom
 *    listX[5]: list1 for current_field==bottom
 *
 ************************************************************************
 */
void init_mbaff_lists(void)
{
  unsigned j;
  int i;

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

  for (i=0; i<listXsize[0]; i++)
  {
    listX[2][2*i]  =listX[0][i]->top_field;
    listX[2][2*i+1]=listX[0][i]->bottom_field;
    listX[4][2*i]  =listX[0][i]->bottom_field;
    listX[4][2*i+1]=listX[0][i]->top_field;
  }
  listXsize[2]=listXsize[4]=listXsize[0] * 2;

  for (i=0; i<listXsize[1]; i++)
  {
    listX[3][2*i]  =listX[1][i]->top_field;
    listX[3][2*i+1]=listX[1][i]->bottom_field;
    listX[5][2*i]  =listX[1][i]->bottom_field;
    listX[5][2*i+1]=listX[1][i]->top_field;
  }
  listXsize[3]=listXsize[5]=listXsize[1] * 2;
}

 /*!
 ************************************************************************
 * \brief
 *    Returns short term pic with given picNum
 *
 ************************************************************************
 */
static StorablePicture*  get_short_term_pic(int picNum)
{
  unsigned i;

  for (i=0; i<dpb.ref_frames_in_buffer; i++)
  {
    if (img->structure==FRAME)
    {
      if (dpb.fs_ref[i]->is_reference == 3)
        if ((!dpb.fs_ref[i]->frame->is_long_term)&&(dpb.fs_ref[i]->frame->pic_num == picNum))
          return dpb.fs_ref[i]->frame;
    }
    else
    {
      if (dpb.fs_ref[i]->is_reference & 1)
        if ((!dpb.fs_ref[i]->top_field->is_long_term)&&(dpb.fs_ref[i]->top_field->pic_num == picNum))
          return dpb.fs_ref[i]->top_field;
      if (dpb.fs_ref[i]->is_reference & 2)
        if ((!dpb.fs_ref[i]->bottom_field->is_long_term)&&(dpb.fs_ref[i]->bottom_field->pic_num == picNum))
          return dpb.fs_ref[i]->bottom_field;
    }
  }
  return NULL;
}

/*!
 ************************************************************************
 * \brief
 *    Returns short term pic with given LongtermPicNum
 *
 ************************************************************************
 */
static StorablePicture*  get_long_term_pic(int LongtermPicNum)
{
  unsigned i;

  for (i=0; i<dpb.ltref_frames_in_buffer; i++)
  {
    if (img->structure==FRAME)
    {
      if (dpb.fs_ltref[i]->is_reference == 3)
        if ((dpb.fs_ltref[i]->frame->is_long_term)&&(dpb.fs_ltref[i]->frame->long_term_pic_num == LongtermPicNum))
          return dpb.fs_ltref[i]->frame;
    }
    else
    {
      if (dpb.fs_ltref[i]->is_reference & 1)
        if ((dpb.fs_ltref[i]->top_field->is_long_term)&&(dpb.fs_ltref[i]->top_field->long_term_pic_num == LongtermPicNum))
          return dpb.fs_ltref[i]->top_field;
      if (dpb.fs_ltref[i]->is_reference & 2)
        if ((dpb.fs_ltref[i]->bottom_field->is_long_term)&&(dpb.fs_ltref[i]->bottom_field->long_term_pic_num == LongtermPicNum))
          return dpb.fs_ltref[i]->bottom_field;
    }
  }
  return NULL;
}

/*!
 ************************************************************************
 * \brief
 *    Reordering process for short-term reference pictures
 *
 ************************************************************************
 */
static void reorder_short_term(StorablePicture **RefPicListX, int num_ref_idx_lX_active_minus1, int picNumLX, int *refIdxLX)
{
  int cIdx, nIdx;

  StorablePicture *picLX;

  picLX = get_short_term_pic(picNumLX);

  for( cIdx = num_ref_idx_lX_active_minus1+1; cIdx > *refIdxLX; cIdx-- )
    RefPicListX[ cIdx ] = RefPicListX[ cIdx - 1];

  RefPicListX[ (*refIdxLX)++ ] = picLX;

  nIdx = *refIdxLX;

  for( cIdx = *refIdxLX; cIdx <= num_ref_idx_lX_active_minus1+1; cIdx++ )
    if (RefPicListX[ cIdx ])
      if( (RefPicListX[ cIdx ]->is_long_term ) ||  (RefPicListX[ cIdx ]->pic_num != picNumLX ))
        RefPicListX[ nIdx++ ] = RefPicListX[ cIdx ];

}


/*!
 ************************************************************************
 * \brief
 *    Reordering process for short-term reference pictures
 *
 ************************************************************************
 */
static void reorder_long_term(StorablePicture **RefPicListX, int num_ref_idx_lX_active_minus1, int LongTermPicNum, int *refIdxLX)
{
  int cIdx, nIdx;

  StorablePicture *picLX;

  picLX = get_long_term_pic(LongTermPicNum);

  for( cIdx = num_ref_idx_lX_active_minus1+1; cIdx > *refIdxLX; cIdx-- )
    RefPicListX[ cIdx ] = RefPicListX[ cIdx - 1];

  RefPicListX[ (*refIdxLX)++ ] = picLX;

  nIdx = *refIdxLX;

  for( cIdx = *refIdxLX; cIdx <= num_ref_idx_lX_active_minus1+1; cIdx++ )
    if( (!RefPicListX[ cIdx ]->is_long_term ) ||  (RefPicListX[ cIdx ]->long_term_pic_num != LongTermPicNum ))
      RefPicListX[ nIdx++ ] = RefPicListX[ cIdx ];
}


/*!
 ************************************************************************
 * \brief
 *    Reordering process for reference picture lists
 *
 ************************************************************************
 */
void reorder_ref_pic_list(StorablePicture **list, int *list_size, int num_ref_idx_lX_active_minus1, int *reordering_of_pic_nums_idc, int *abs_diff_pic_num_minus1, int *long_term_pic_idx)
{
  int i;

  int maxPicNum, currPicNum, picNumLXNoWrap, picNumLXPred, picNumLX;
  int refIdxLX = 0;

  if (img->structure==FRAME)
  {
    maxPicNum  = max_frame_num;
    currPicNum = img->frame_num;
  }
  else
  {
    maxPicNum  = 2 * max_frame_num;
    currPicNum = 2 * img->frame_num + 1;
  }

  picNumLXPred = currPicNum;

  for (i=0; reordering_of_pic_nums_idc[i]!=3; i++)
  {
    if (reordering_of_pic_nums_idc[i]>3)
      error ("Invalid remapping_of_pic_nums_idc command", 500);

    if (reordering_of_pic_nums_idc[i] < 2)
    {
      if (reordering_of_pic_nums_idc[i] == 0)
      {
        if( picNumLXPred - ( abs_diff_pic_num_minus1[i] + 1 ) < 0 )
          picNumLXNoWrap = picNumLXPred - ( abs_diff_pic_num_minus1[i] + 1 ) + maxPicNum;
        else
          picNumLXNoWrap = picNumLXPred - ( abs_diff_pic_num_minus1[i] + 1 );
      }
      else // (reordering_of_pic_nums_idc[i] == 1)
      {
        if( picNumLXPred + ( abs_diff_pic_num_minus1[i] + 1 )  >=  maxPicNum )
          picNumLXNoWrap = picNumLXPred + ( abs_diff_pic_num_minus1[i] + 1 ) - maxPicNum;
        else
          picNumLXNoWrap = picNumLXPred + ( abs_diff_pic_num_minus1[i] + 1 );
      }
      picNumLXPred = picNumLXNoWrap;

      if( picNumLXNoWrap > currPicNum )
        picNumLX = picNumLXNoWrap - maxPicNum;
      else
        picNumLX = picNumLXNoWrap;

      reorder_short_term(list, num_ref_idx_lX_active_minus1, picNumLX, &refIdxLX);
    }
    else //(reordering_of_pic_nums_idc[i] == 2)
    {
      reorder_long_term(list, num_ref_idx_lX_active_minus1, long_term_pic_idx[i], &refIdxLX);
    }

  }
  // that's a definition
  *list_size = num_ref_idx_lX_active_minus1 + 1;
}



/*!
 ************************************************************************
 * \brief
 *    Update the list of frame stores that contain reference frames/fields
 *
 ************************************************************************
 */
void update_ref_list(void)
{
  unsigned i, j;
  for (i=0, j=0; i<dpb.used_size; i++)
  {
    if (is_short_term_reference(dpb.fs[i]))
    {
      dpb.fs_ref[j++]=dpb.fs[i];
    }
  }

  dpb.ref_frames_in_buffer = j;

  while (j<dpb.size)
  {
    dpb.fs_ref[j++]=NULL;
  }
}


/*!
 ************************************************************************
 * \brief
 *    Update the list of frame stores that contain long-term reference
 *    frames/fields
 *
 ************************************************************************
 */
void update_ltref_list(void)
{
  unsigned i, j;
  for (i=0, j=0; i<dpb.used_size; i++)
  {
    if (is_long_term_reference(dpb.fs[i]))
    {
      dpb.fs_ltref[j++]=dpb.fs[i];
    }
  }

  dpb.ltref_frames_in_buffer=j;

  while (j<dpb.size)
  {
    dpb.fs_ltref[j++]=NULL;
  }
}

/*!
 ************************************************************************
 * \brief
 *    Perform Memory management for idr pictures
 *
 ************************************************************************
 */
static void idr_memory_management(StorablePicture* p)
{
  unsigned i;

  assert (img->currentPicture->idr_flag);

  if (img->no_output_of_prior_pics_flag)
  {
    // free all stored pictures
    for (i=0; i<dpb.used_size; i++)
    {
      // reset all reference settings
      free_frame_store(dpb.fs[i]);
      dpb.fs[i] = alloc_frame_store();
    }
    for (i=0; i<dpb.ref_frames_in_buffer; i++)
    {
      dpb.fs_ref[i]=NULL;
    }
    for (i=0; i<dpb.ltref_frames_in_buffer; i++)
    {
      dpb.fs_ltref[i]=NULL;
    }
    dpb.used_size=0;
  }
  else
  {
    flush_dpb();
  }
  dpb.last_picture = NULL;

  update_ref_list();
  update_ltref_list();
  dpb.last_output_poc = INT_MIN;

  if (img->long_term_reference_flag)
  {
    dpb.max_long_term_pic_idx = 0;
    p->is_long_term           = 1;
    p->long_term_frame_idx    = 0;
  }
  else
  {
    dpb.max_long_term_pic_idx = -1;
    p->is_long_term           = 0;
  }
}

/*!
 ************************************************************************
 * \brief
 *    Perform Sliding window decoded reference picture marking process
 *
 ************************************************************************
 */
static void sliding_window_memory_management(StorablePicture* p)
{
  unsigned i;

  assert (!img->currentPicture->idr_flag);
  // if this is a reference pic with sliding sliding window, unmark first ref frame
  if (dpb.ref_frames_in_buffer==active_sps->num_ref_frames - dpb.ltref_frames_in_buffer)
  {
    for (i=0; i<dpb.used_size;i++)
    {
      if (dpb.fs[i]->is_reference  && (!(dpb.fs[i]->is_long_term)))
      {
        unmark_for_reference(dpb.fs[i]);
        update_ref_list();
        break;
      }
    }
  }

  p->is_long_term = 0;
}

/*!
 ************************************************************************
 * \brief
 *    Calculate picNumX
 ************************************************************************
 */
static int get_pic_num_x (StorablePicture *p, int difference_of_pic_nums_minus1)
{
  int currPicNum;

  if (p->structure == FRAME)
    currPicNum = p->frame_num;
  else
    currPicNum = 2 * p->frame_num + 1;

  return currPicNum - (difference_of_pic_nums_minus1 + 1);
}


/*!
 ************************************************************************
 * \brief
 *    Adaptive Memory Management: Mark short term picture unused
 ************************************************************************
 */
static void mm_unmark_short_term_for_reference(StorablePicture *p, int difference_of_pic_nums_minus1)
{
  int picNumX;

  unsigned i;

  picNumX = get_pic_num_x(p, difference_of_pic_nums_minus1);

  for (i=0; i<dpb.ref_frames_in_buffer; i++)
  {
    if (p->structure == FRAME)
    {
      if ((dpb.fs_ref[i]->is_reference==3) && (dpb.fs_ref[i]->is_long_term==0))
      {
        if (dpb.fs_ref[i]->frame->pic_num == picNumX)
        {
          unmark_for_reference(dpb.fs_ref[i]);
          return;
        }
      }
    }
    else
    {
      if ((dpb.fs_ref[i]->is_reference & 1) && (!(dpb.fs_ref[i]->is_long_term & 1)))
      {
        if (dpb.fs_ref[i]->top_field->pic_num == picNumX)
        {
          dpb.fs_ref[i]->top_field->used_for_reference = 0;
          dpb.fs_ref[i]->is_reference &= 2;
          if (dpb.fs_ref[i]->is_used == 3)
          {
            dpb.fs_ref[i]->frame->used_for_reference = 0;
          }
          return;
        }
      }
      if ((dpb.fs_ref[i]->is_reference & 2) && (!(dpb.fs_ref[i]->is_long_term & 2)))
      {
        if (dpb.fs_ref[i]->bottom_field->pic_num == picNumX)
        {
          dpb.fs_ref[i]->bottom_field->used_for_reference = 0;
          dpb.fs_ref[i]->is_reference &= 1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看日韩国产| 国产一区二区三区精品视频| 国产欧美日韩亚州综合| 精品久久国产老人久久综合| 欧美一区二区视频在线观看2020| 91在线精品一区二区| 99久久精品国产网站| 日韩精品专区在线影院重磅| 欧美精品18+| 欧美精品乱码久久久久久| 欧美日韩一区精品| 欧美性生活影院| 欧美日本视频在线| 欧美福利电影网| 日韩精品一区二区三区视频播放| 色拍拍在线精品视频8848| 亚洲精品一区二区精华| 国产精品免费视频一区| 中文字幕亚洲视频| 亚洲一区欧美一区| 午夜精品福利一区二区蜜股av| 欧美久久久久中文字幕| 欧美日韩亚洲国产综合| 欧美一区二区美女| 日韩欧美在线影院| 国产午夜精品久久| 国产精品色婷婷久久58| 亚洲欧洲日韩在线| 亚洲特级片在线| 亚洲国产视频a| 黄色资源网久久资源365| 成人av综合一区| 欧美精品久久一区二区三区| 日韩欧美三级在线| 欧美国产精品中文字幕| 亚洲精品欧美在线| 亚洲成人资源网| 亚洲成av人影院| 国产精品一区久久久久| thepron国产精品| 欧洲一区二区三区免费视频| 91精品婷婷国产综合久久性色| 26uuu色噜噜精品一区二区| 一区二区三区四区在线免费观看 | 久久99精品国产91久久来源| 成人精品国产免费网站| 色婷婷久久久亚洲一区二区三区 | 日韩精品一区二区三区在线观看| 久久夜色精品一区| 日产国产欧美视频一区精品| 99麻豆久久久国产精品免费优播| 精品美女在线播放| 日韩电影在线观看网站| 91黄色免费看| 中文字幕一区二区三区在线不卡| 国产综合色视频| 欧美一级日韩不卡播放免费| 亚洲免费三区一区二区| 国产麻豆一精品一av一免费 | 国产校园另类小说区| 天天综合色天天| 欧美亚男人的天堂| 成人欧美一区二区三区1314| 国产成人av电影免费在线观看| 日韩一区二区在线免费观看| 亚洲夂夂婷婷色拍ww47| 99v久久综合狠狠综合久久| 久久久.com| 国产91精品一区二区麻豆亚洲| 精品久久久久久最新网址| 男女男精品网站| 日韩精品一区国产麻豆| 亚洲在线观看免费| 在线欧美小视频| 亚洲一区二区三区视频在线 | 国产91色综合久久免费分享| 这里只有精品电影| 日本中文字幕不卡| 欧美大胆人体bbbb| 激情六月婷婷综合| 国产日本欧洲亚洲| 99视频精品全部免费在线| 18欧美乱大交hd1984| av高清久久久| 亚洲愉拍自拍另类高清精品| 91丨porny丨户外露出| 中文字幕一区二区三区乱码在线 | 色综合天天在线| 亚洲精品免费在线| 欧美三区在线观看| 奇米影视7777精品一区二区| 日韩西西人体444www| 国产精品影视在线观看| 国产精品夫妻自拍| 欧美日韩一区国产| 精品影视av免费| 中文字幕五月欧美| 欧美剧情片在线观看| 国产在线看一区| 中文字幕视频一区| 欧美精品久久久久久久久老牛影院| 日韩精品免费视频人成| 国产午夜精品久久久久久久 | 成人免费一区二区三区在线观看 | 国产欧美精品国产国产专区| 99国产精品视频免费观看| 五月婷婷欧美视频| 久久久久久久免费视频了| 在线视频一区二区免费| 另类成人小视频在线| 亚洲少妇最新在线视频| 欧美tk—视频vk| 91传媒视频在线播放| 精品在线亚洲视频| 亚洲国产精品自拍| 久久免费看少妇高潮| 精品视频在线看| 国产成人鲁色资源国产91色综| 亚洲第一成人在线| 国产精品久久午夜| 日韩精品一区二区三区四区| 色先锋资源久久综合| 国产v日产∨综合v精品视频| 图片区小说区区亚洲影院| 亚洲色图欧洲色图婷婷| 久久一区二区视频| 欧美一区二区三区四区视频| 色婷婷av一区| 99精品视频在线观看免费| 国产一区二区三区精品欧美日韩一区二区三区 | 国产精品久久久久久亚洲伦| 日韩一级精品视频在线观看| 日本福利一区二区| 成人午夜激情在线| 国产乱子轮精品视频| 蜜桃视频一区二区三区| 一区二区三区蜜桃| 中文字幕一区二区三区四区不卡| 精品国产免费一区二区三区香蕉| 欧美日韩国产高清一区二区三区| 99v久久综合狠狠综合久久| 国产成人精品免费看| 精品在线观看视频| 婷婷中文字幕一区三区| 亚洲综合网站在线观看| 久久久高清一区二区三区| 欧美一级国产精品| 色老汉一区二区三区| 99精品欧美一区| 丁香婷婷综合网| 精品一区二区三区在线播放视频 | 国产精品久久久一区麻豆最新章节| 日韩亚洲欧美成人一区| 欧美日韩一区 二区 三区 久久精品| 色先锋aa成人| 欧美日本在线播放| 欧美精品久久天天躁| 欧美一区三区二区| 精品国产91久久久久久久妲己 | 日韩欧美一级片| 日韩亚洲电影在线| 精品剧情在线观看| 久久精品亚洲乱码伦伦中文| 亚洲国产精品二十页| 国产精品麻豆视频| 亚洲色图视频网| 亚洲成人av一区二区三区| 亚洲bt欧美bt精品777| 亚洲免费电影在线| 日韩在线播放一区二区| 蜜桃视频在线一区| 成熟亚洲日本毛茸茸凸凹| 99精品久久只有精品| 欧美视频精品在线观看| 欧美精品xxxxbbbb| 精品国产免费人成在线观看| 国产欧美精品一区二区色综合 | 视频一区二区中文字幕| 国产综合色产在线精品| 成人免费观看av| 欧美日韩亚洲不卡| 久久综合九色综合97_久久久| 久久综合成人精品亚洲另类欧美| 久久一二三国产| 国产精品国产三级国产三级人妇 | 成人精品视频一区| 欧美性xxxxxxxx| 久久久精品免费免费| 亚洲一区二区三区小说| 国产在线麻豆精品观看| 在线观看日韩av先锋影音电影院| 日韩一级二级三级精品视频| 亚洲丝袜自拍清纯另类| 久久99热这里只有精品| 91蝌蚪porny| 精品福利在线导航| 五月激情六月综合| 成人高清av在线| 日韩免费视频一区二区| 亚洲一区欧美一区|