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

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

?? mbuffer.c

?? 一個簡單的視頻會議VC++MFC工程文件
?? C
?? 第 1 頁 / 共 5 頁
字號:
          dpb.fs_ref[i]->is_long_term |= 1;
          if (dpb.fs_ref[i]->is_long_term == 3)
          {
            dpb.fs_ref[i]->frame->is_long_term = 1;
            dpb.fs_ref[i]->frame->long_term_frame_idx = dpb.fs_ref[i]->frame->long_term_pic_num = long_term_frame_idx;
          }
          return;
        }
      }
      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 == picNumX))
        {
          if ((dpb.fs_ref[i]->is_long_term) && (dpb.fs_ref[i]->long_term_frame_idx != long_term_frame_idx))
          {
              printf ("Warning: assigning long_term_frame_idx different from other field\n");
          }

          dpb.fs_ref[i]->long_term_frame_idx = dpb.fs_ref[i]->bottom_field->long_term_frame_idx 
                                             = long_term_frame_idx;
          dpb.fs_ref[i]->bottom_field->long_term_pic_num = 2 * long_term_frame_idx + add_top;
          dpb.fs_ref[i]->bottom_field->is_long_term = 1;
          dpb.fs_ref[i]->is_long_term |= 2;
          if (dpb.fs_ref[i]->is_long_term == 3)
          {
            dpb.fs_ref[i]->frame->is_long_term = 1;
            dpb.fs_ref[i]->frame->long_term_frame_idx = dpb.fs_ref[i]->frame->long_term_pic_num = long_term_frame_idx;
          }
          return;
        }
      }
    }
    printf ("Warning: reference field for long term marking not found\n");
  }
}


/*!
 ************************************************************************
 * \brief
 *    Assign a long term frame index to a short term picture
 ************************************************************************
 */
static void mm_assign_long_term_frame_idx(StorablePicture* p, int difference_of_pic_nums_minus1, int long_term_frame_idx)
{
  int picNumX;

  picNumX = get_pic_num_x(p, difference_of_pic_nums_minus1);

  // remove frames/fields with same long_term_frame_idx
  if (p->structure == FRAME)
  {
    unmark_long_term_frame_for_reference_by_frame_idx(long_term_frame_idx);
  }
  else
  {
    unsigned i;
    PictureStructure structure = FRAME;

    for (i=0; i<dpb.ref_frames_in_buffer; i++)
    {
      if (dpb.fs_ref[i]->is_reference & 1)
      {
        if (dpb.fs_ref[i]->top_field->pic_num == picNumX)
        {
          structure = TOP_FIELD;
          break;
        }
      }
      if (dpb.fs_ref[i]->is_reference & 2)
      {
        if (dpb.fs_ref[i]->bottom_field->pic_num == picNumX)
        {
          structure = BOTTOM_FIELD;
          break;
        }
      }
    }
    if (structure==FRAME)
    {
      error ("field for long term marking not found",200);
    }
    
    unmark_long_term_field_for_reference_by_frame_idx(structure, long_term_frame_idx, 0, 0);
  }

  mark_pic_long_term(p, long_term_frame_idx, picNumX);
}

/*!
 ************************************************************************
 * \brief
 *    Set new max long_term_frame_idx
 ************************************************************************
 */
void mm_update_max_long_term_frame_idx(int max_long_term_frame_idx_plus1)
{
  unsigned i;

  dpb.max_long_term_pic_idx = max_long_term_frame_idx_plus1 - 1;

  // check for invalid frames
  for (i=0; i<dpb.ltref_frames_in_buffer; i++)
  {
    if (dpb.fs_ltref[i]->long_term_frame_idx > dpb.max_long_term_pic_idx)
    {
      unmark_for_long_term_reference(dpb.fs_ltref[i]);
    }
  }
}


/*!
 ************************************************************************
 * \brief
 *    Mark all long term reference pictures unused for reference
 ************************************************************************
 */
static void mm_unmark_all_long_term_for_reference ()
{
  mm_update_max_long_term_frame_idx(0);
}

/*!
 ************************************************************************
 * \brief
 *    Mark all short term reference pictures unused for reference
 ************************************************************************
 */
static void mm_unmark_all_short_term_for_reference ()
{
  unsigned int i;
  for (i=0; i<dpb.ref_frames_in_buffer; i++)
  {
    unmark_for_reference(dpb.fs_ref[i]);
  }
  update_ref_list();
}


/*!
 ************************************************************************
 * \brief
 *    Mark the current picture used for long term reference
 ************************************************************************
 */
static void mm_mark_current_picture_long_term(StorablePicture *p, int long_term_frame_idx)
{
  // remove long term pictures with same long_term_frame_idx
  if (p->structure == FRAME)
  {
    unmark_long_term_frame_for_reference_by_frame_idx(long_term_frame_idx);
  }
  else
  {
    unmark_long_term_field_for_reference_by_frame_idx(p->structure, long_term_frame_idx, 1, p->pic_num);
  }

  p->is_long_term = 1;
  p->long_term_frame_idx = long_term_frame_idx;
}


/*!
 ************************************************************************
 * \brief
 *    Perform Adaptive memory control decoded reference picture marking process
 ************************************************************************
 */
static void adaptive_memory_management(StorablePicture* p)
{
  DecRefPicMarking_t *tmp_drpm;

  img->last_has_mmco_5 = 0;

  assert (!img->currentPicture->idr_flag);
  assert (img->adaptive_ref_pic_buffering_flag);

  while (img->dec_ref_pic_marking_buffer)
  {
    tmp_drpm = img->dec_ref_pic_marking_buffer;
    switch (tmp_drpm->memory_management_control_operation)
    {
      case 0:
        if (tmp_drpm->Next != NULL)
        {
          error ("memory_management_control_operation = 0 not last operation in buffer", 500);
        }
        break;
      case 1:
        mm_unmark_short_term_for_reference(p, tmp_drpm->difference_of_pic_nums_minus1);
        update_ref_list();
        break;
      case 2:
        mm_unmark_long_term_for_reference(p, tmp_drpm->long_term_pic_num);
        update_ltref_list();
        break;
      case 3:
        mm_assign_long_term_frame_idx(p, tmp_drpm->difference_of_pic_nums_minus1, tmp_drpm->long_term_frame_idx);
        update_ref_list();
        update_ltref_list();
        break;
      case 4:
        mm_update_max_long_term_frame_idx (tmp_drpm->max_long_term_frame_idx_plus1);
        update_ltref_list();
        break;
      case 5:
        mm_unmark_all_short_term_for_reference();
        mm_unmark_all_long_term_for_reference();
       img->last_has_mmco_5 = 1;
        break;
      case 6:
        mm_mark_current_picture_long_term(p, tmp_drpm->long_term_frame_idx);
        break;
      default:
        error ("invalid memory_management_control_operation in buffer", 500);
    }
    img->dec_ref_pic_marking_buffer = tmp_drpm->Next;
    free (tmp_drpm);
  }
  if ( img->last_has_mmco_5 )
  {
    img->frame_num = p->pic_num = 0;
    p->poc = 0;
    img->ThisPOC=0;
    
    switch (p->structure)
    {
    case TOP_FIELD:
      {
        img->toppoc=0;
        break;
      }
    case BOTTOM_FIELD:
      {
        img->bottompoc=0;
        break;
      }
    case FRAME:
      {
        img->framepoc=0;
        break;
      }
    }
    flush_dpb();
  }
}


/*!
 ************************************************************************
 * \brief
 *    Store a picture in DPB. This includes cheking for space in DPB and 
 *    flushing frames.
 *    If we received a frame, we need to check for a new store, if we
 *    got a field, check if it's the second field of an already allocated
 *    store.
 *
 * \param p
 *    Picture to be stored
 *
 ************************************************************************
 */
void store_picture_in_dpb(StorablePicture* p)
{
  unsigned i;
  int poc, pos;
  // diagnostics
  //printf ("Storing (%s) non-ref pic with frame_num #%d\n", (p->type == FRAME)?"FRAME":(p->type == TOP_FIELD)?"TOP_FIELD":"BOTTOM_FIELD", img->frame_num);
  // if frame, check for new store, 
  assert (p!=NULL);

  p->used_for_reference = (img->nal_reference_idc != 0);

  img->last_has_mmco_5=0;
  img->last_pic_bottom_field = (img->structure == BOTTOM_FIELD);

  if (img->currentPicture->idr_flag)
    idr_memory_management(p);
  else
  {
    // adaptive memory management
    if (p->used_for_reference && (img->adaptive_ref_pic_buffering_flag))
      adaptive_memory_management(p);
  }

  if ((p->structure==TOP_FIELD)||(p->structure==BOTTOM_FIELD))
  {
    // check for frame store with same pic_number
    if (dpb.last_picture)
    {
      if ((int)dpb.last_picture->frame_num == p->pic_num)
      {
        if (((p->structure==TOP_FIELD)&&(dpb.last_picture->is_used==2))||((p->structure==BOTTOM_FIELD)&&(dpb.last_picture->is_used==1)))
        {
          if ((p->used_for_reference && (dpb.last_picture->is_orig_reference!=0))||
              (!p->used_for_reference && (dpb.last_picture->is_orig_reference==0)))
          {
            insert_picture_in_dpb(dpb.last_picture, p);
            update_ref_list();
            update_ltref_list();
            dump_dpb();
            dpb.last_picture = NULL;
            return;
          }
        }
      }
    }
  }

  // this is a frame or a field which has no stored complementatry field

  // sliding window, if necessary
  if ((!img->currentPicture->idr_flag)&&(p->used_for_reference && (!img->adaptive_ref_pic_buffering_flag)))
  {
    sliding_window_memory_management(p);
  } 

  // first try to remove unused frames
  if (dpb.used_size==dpb.size)
  {
    remove_unused_frame_from_dpb();
  }
  
  // then output frames until one can be removed
  while (dpb.used_size==dpb.size)
  {
    // non-reference frames may be output directly
    if (!p->used_for_reference)
    {
      get_smallest_poc(&poc, &pos);
      if ((-1==pos) || (p->poc < poc))
      {
        direct_output(p, p_dec);
        return;
      }
    }
    // flush a frame
    output_one_frame_from_dpb();
  }
  
  // check for duplicate frame number in short term reference buffer
  if ((p->used_for_reference)&&(!p->is_long_term))
  {
    for (i=0; i<dpb.ref_frames_in_buffer; i++)
    {
      if (dpb.fs_ref[i]->frame_num == img->frame_num)
      {
        error("duplicate frame_num im short-term reference picture buffer", 500);
      }
    }

  }
  // store at end of buffer
//  printf ("store frame/field at pos %d\n",dpb.used_size);
  insert_picture_in_dpb(dpb.fs[dpb.used_size],p);
  
  if (p->structure != FRAME)
  {
    dpb.last_picture = dpb.fs[dpb.used_size];
  }
  else
  {
    dpb.last_picture = NULL;
  }

  dpb.used_size++;

  update_ref_list();
  update_ltref_list();
  dump_dpb();
}


/*!
 ************************************************************************
 * \brief
 *    Insert the frame picture into the if the top field has already
 *    been stored for the coding decision
 *
 * \param p
 *    StorablePicture to be inserted
 *
 ************************************************************************
 */
void replace_top_pic_with_frame(StorablePicture* p)
{
  FrameStore* fs = NULL;
  unsigned i, found;

  assert (p!=NULL);
  assert (p->structure==FRAME);

  p->used_for_reference = (img->nal_reference_idc != 0);
  // upsample a reference picture
  if (p->used_for_reference)
  {
    UnifiedOneForthPix(p);
  }

  found=0;

  for (i=0;i<dpb.used_size;i++)
  {
    if((dpb.fs[i]->frame_num == img->frame_num)&&(dpb.fs[i]->is_used==1))
    {
      found=1;
      fs = dpb.fs[i];
      break;
    }
  }

  if (!found)
  {
    error("replace_top_pic_with_frame: error storing reference frame (top field not found)",500);
  }

  free_storable_picture(fs->top_field);
  fs->top_field=NULL;
  fs->frame=p;
  fs->is_used = 3;
  if (p->used_for_reference)
  {
    fs->is_reference = 3;
    if (p->is_long_term)
    {
      fs->is_long_term = 3;
    }
  }
  // generate field views
  dpb_split_field(fs);
  update_ref_list();
  update_ltref_list();
}


/*!
 ************************************************************************
 * \brief
 *    Insert the picture into the DPB. A free DPB position is necessary
 *    for frames, .
 *
 * \param fs
 *    FrameStore into which the picture will be inserted
 * \param p
 *    StorablePicture to be inserted
 *
 ************************************************************************
 */
static void insert_picture_in_dpb(FrameStore* fs, StorablePicture* p)
{
//  printf ("insert (%s) pic with frame_num #%d, poc %d\n", (p->structure == FRAME)?"FRAME":(p->structure == TOP_FIELD)?"TOP_FIELD":"BOTTOM_FIELD", img->frame_num, p->poc);
  assert (p!=NULL);
  assert (fs!=NULL);

  // upsample a reference picture
  if (p->used_for_reference)
  {
    UnifiedOneForthPix(p

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品99999| 国产一区二区h| 在线观看网站黄不卡| 中文字幕亚洲精品在线观看| 福利一区二区在线| 国产精品美女久久久久久久 | 人人精品人人爱| 91精品在线观看入口| 午夜欧美大尺度福利影院在线看| 欧美综合在线视频| 亚洲美女区一区| 在线观看日韩电影| 五月激情综合网| 91麻豆精品久久久久蜜臀| 午夜精品久久久久| 欧美日韩一区久久| 午夜精品久久久久| 91精品国产综合久久小美女| 美女网站一区二区| 精品久久久久久亚洲综合网| 狠狠色综合播放一区二区| 久久久久亚洲蜜桃| 国产精品亚洲成人| 国产精品久久久久永久免费观看| 成年人国产精品| 亚洲一区二区三区四区五区黄 | 亚洲精品写真福利| 欧美午夜不卡在线观看免费| 婷婷国产在线综合| 精品区一区二区| 国产91精品一区二区| 亚洲色图制服丝袜| 欧美军同video69gay| 一区二区三区欧美久久| 欧美日韩一二区| 极品少妇xxxx精品少妇| 91黄色免费版| 欧美精品三级日韩久久| 欧美精品一区二区三区很污很色的 | 久久久国产午夜精品| caoporen国产精品视频| 亚洲自拍与偷拍| 精品国产污污免费网站入口 | 丝袜美腿一区二区三区| 精品国产一区二区三区不卡 | 一级做a爱片久久| 国产精品美女久久久久久2018| 精品一区二区影视| 精品久久人人做人人爰| 日韩avvvv在线播放| 成年人国产精品| 国产亚洲成aⅴ人片在线观看| 色欧美片视频在线观看在线视频| 免费观看在线色综合| 久久久国产午夜精品 | 午夜在线电影亚洲一区| 久久色.com| 色老汉一区二区三区| 老司机午夜精品99久久| 1000精品久久久久久久久| 国产喂奶挤奶一区二区三区| 欧美性色黄大片| 成人高清免费在线播放| 开心九九激情九九欧美日韩精美视频电影 | 国产精品进线69影院| 一二三区精品福利视频| 国产视频一区在线播放| 欧美精选在线播放| 91在线一区二区| 久久精品国产99国产精品| 亚洲成a人片在线不卡一二三区 | 色天使色偷偷av一区二区| 国产综合一区二区| 午夜视频一区二区| 亚洲伦理在线精品| 久久人人97超碰com| 欧美成人一区二区三区在线观看| 欧美性色欧美a在线播放| 国产成人精品在线看| 婷婷开心久久网| 亚洲一区av在线| 国产偷v国产偷v亚洲高清| 久久亚洲影视婷婷| 91成人网在线| 成人av在线观| 懂色av一区二区三区免费观看| 美女国产一区二区三区| 一区二区三区在线观看欧美| 1024成人网色www| 国产午夜精品久久| 欧美一区二区视频在线观看2020| 欧美日韩亚洲综合一区二区三区| 99这里都是精品| 懂色av一区二区三区免费观看 | 成人禁用看黄a在线| 国产成人av一区| 国产aⅴ综合色| 国产成人精品免费网站| 成熟亚洲日本毛茸茸凸凹| 国产a久久麻豆| 波多野结衣91| 91成人免费在线视频| 欧美日韩专区在线| 欧美精品在线观看播放| 欧美二区乱c少妇| 欧美一级搡bbbb搡bbbb| 91精品国产色综合久久久蜜香臀| 日韩一区二区中文字幕| 欧美精品一区二区精品网| 精品日韩欧美一区二区| 国产视频视频一区| 亚洲欧美在线另类| 亚洲午夜免费福利视频| 天天综合天天做天天综合| 日本 国产 欧美色综合| 国产激情一区二区三区| 成人av免费在线观看| 91国产丝袜在线播放| 91精品国产综合久久久蜜臀图片| 欧美日韩成人综合天天影院| 日韩区在线观看| 欧美激情在线一区二区| 亚洲日本va午夜在线电影| 成人福利电影精品一区二区在线观看| 亚洲欧美日韩久久精品| 亚洲精品伦理在线| 日韩电影免费一区| 国产91精品一区二区麻豆亚洲| 色综合天天综合网天天看片| 欧美一二三四区在线| 日本一区二区成人在线| 亚洲成人一区二区在线观看| 国产做a爰片久久毛片| 色综合久久综合| 日韩亚洲欧美成人一区| 久久久久久久久一| 一区二区三区四区不卡在线| 韩国v欧美v亚洲v日本v| 91麻豆精品一区二区三区| 欧美一区二区视频在线观看2020| 国产精品天天摸av网| 日韩精品一卡二卡三卡四卡无卡| 国产精品白丝jk黑袜喷水| 91成人免费电影| 欧美mv和日韩mv的网站| 亚洲国产精品高清| 男人的j进女人的j一区| 日本久久一区二区| 久久夜色精品一区| 五月婷婷色综合| 成人午夜碰碰视频| 精品国产免费视频| 亚洲一区二区成人在线观看| 日韩精品一区二区三区三区免费| 亚洲五码中文字幕| 免费观看一级特黄欧美大片| 91网站视频在线观看| 久久影院电视剧免费观看| 亚洲国产日韩一级| 成人av在线资源网| 久久美女艺术照精彩视频福利播放| 亚洲精品你懂的| 暴力调教一区二区三区| 精品成人一区二区| 日本免费新一区视频| 欧美视频中文一区二区三区在线观看 | 色综合天天视频在线观看| 久久久亚洲精品石原莉奈| 免费高清不卡av| 欧美伦理影视网| 一区二区三区中文字幕电影| 丁香婷婷深情五月亚洲| 久久中文娱乐网| 精品一二三四区| 欧美一级生活片| 日本成人在线网站| 911精品国产一区二区在线| 一区二区三区四区视频精品免费 | 久久99精品国产麻豆不卡| 欧美精品一卡二卡| 亚洲va在线va天堂| 欧美午夜片在线观看| 国产欧美一区二区精品性色超碰 | 欧美男同性恋视频网站| 午夜激情久久久| 不卡电影免费在线播放一区| 亚洲精品一区在线观看| 美美哒免费高清在线观看视频一区二区| 国产.精品.日韩.另类.中文.在线.播放| 国产麻豆9l精品三级站| 色狠狠色噜噜噜综合网| 天堂蜜桃一区二区三区| 久久亚洲一区二区三区四区| 成人不卡免费av| 亚洲成人av电影| 久久久青草青青国产亚洲免观| 91视视频在线观看入口直接观看www| 亚洲综合在线免费观看| 91精品国产一区二区三区| 福利一区二区在线观看|