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

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

?? mbuffer.c

?? JM 11.0 KTA 2.1 Source Code
?? C
?? 第 1 頁 / 共 5 頁
字號:
}


/*!
************************************************************************
* \brief
*    returns true, if picture is short term reference picture
*
************************************************************************
*/
int is_short_ref(StorablePicture *s)
{
  return ((s->used_for_reference) && (!(s->is_long_term)));
}


/*!
************************************************************************
* \brief
*    returns true, if picture is long term reference picture
*
************************************************************************
*/
int is_long_ref(StorablePicture *s)
{
  return ((s->used_for_reference) && (s->is_long_term));
}


/*!
************************************************************************
* \brief
*    Generates a alternating field list from a given FrameStore list
*
************************************************************************
*/
static void gen_pic_list_from_frame_list(PictureStructure currStrcture, FrameStore **fs_list, int list_idx, StorablePicture **list, int *list_size, int long_term)
{
  int top_idx = 0;
  int bot_idx = 0;

  int (*is_ref)(StorablePicture *s);

  if (long_term)
    is_ref=is_long_ref;
  else
    is_ref=is_short_ref;

  if (currStrcture == TOP_FIELD)
  {
    while ((top_idx<list_idx)||(bot_idx<list_idx))
    {
      for ( ; top_idx<list_idx; top_idx++)
      {
        if(fs_list[top_idx]->is_used & 1)
        {
          if(is_ref(fs_list[top_idx]->top_field))
          {
            // short term ref pic
            list[*list_size] = fs_list[top_idx]->top_field;
            (*list_size)++;
            top_idx++;
            break;
          }
        }
      }
      for ( ; bot_idx<list_idx; bot_idx++)
      {
        if(fs_list[bot_idx]->is_used & 2)
        {
          if(is_ref(fs_list[bot_idx]->bottom_field))
          {
            // short term ref pic
            list[*list_size] = fs_list[bot_idx]->bottom_field;
            (*list_size)++;
            bot_idx++;
            break;
          }
        }
      }
    }
  }
  if (currStrcture == BOTTOM_FIELD)
  {
    while ((top_idx<list_idx)||(bot_idx<list_idx))
    {
      for ( ; bot_idx<list_idx; bot_idx++)
      {
        if(fs_list[bot_idx]->is_used & 2)
        {
          if(is_ref(fs_list[bot_idx]->bottom_field))
          {
            // short term ref pic
            list[*list_size] = fs_list[bot_idx]->bottom_field;
            (*list_size)++;
            bot_idx++;
            break;
          }
        }
      }
      for ( ; top_idx<list_idx; top_idx++)
      {
        if(fs_list[top_idx]->is_used & 1)
        {
          if(is_ref(fs_list[top_idx]->top_field))
          {
            // short term ref pic
            list[*list_size] = fs_list[top_idx]->top_field;
            (*list_size)++;
            top_idx++;
            break;
          }
        }
      }
    }
  }
}


/*!
************************************************************************
* \brief
*    Initialize listX[0] and list 1 depending on current picture type
*
************************************************************************
*/
void init_lists(int currSliceType, PictureStructure currPicStructure)
{
  int add_top = 0, add_bottom = 0;
  unsigned i;
  int j;
  int MaxFrameNum = 1 << (log2_max_frame_num_minus4 + 4);
  int diff;

  int list0idx = 0;
  int list0idx_1 = 0;
  int listltidx = 0;

  FrameStore **fs_list0;
  FrameStore **fs_list1;
  FrameStore **fs_listlt;

  StorablePicture *tmp_s;

  if (currPicStructure == FRAME)  
  {
    for (i=0; i<dpb.ref_frames_in_buffer; i++)
    {
      if (dpb.fs_ref[i]->is_used==3)
      {
        if ((dpb.fs_ref[i]->frame->used_for_reference)&&(!dpb.fs_ref[i]->frame->is_long_term))
        {
          if( dpb.fs_ref[i]->frame_num > img->frame_num )
          {
            dpb.fs_ref[i]->frame_num_wrap = dpb.fs_ref[i]->frame_num - MaxFrameNum;
          }
          else
          {
            dpb.fs_ref[i]->frame_num_wrap = dpb.fs_ref[i]->frame_num;
          }
          dpb.fs_ref[i]->frame->pic_num = dpb.fs_ref[i]->frame_num_wrap;
        }
      }
    }
    // update long_term_pic_num
    for (i=0; i<dpb.ltref_frames_in_buffer; i++)
    {
      if (dpb.fs_ltref[i]->is_used==3)
      {
        if (dpb.fs_ltref[i]->frame->is_long_term)
        {
          dpb.fs_ltref[i]->frame->long_term_pic_num = dpb.fs_ltref[i]->frame->long_term_frame_idx;
        }
      }
    }
  }
  else
  {
    if (currPicStructure == TOP_FIELD)
    {
      add_top    = 1;
      add_bottom = 0;
    }
    else
    {
      add_top    = 0;
      add_bottom = 1;
    }

    for (i=0; i<dpb.ref_frames_in_buffer; i++)
    {
      if (dpb.fs_ref[i]->is_reference)
      {
        if( dpb.fs_ref[i]->frame_num > img->frame_num )
        {
          dpb.fs_ref[i]->frame_num_wrap = dpb.fs_ref[i]->frame_num - MaxFrameNum;
        }
        else
        {
          dpb.fs_ref[i]->frame_num_wrap = dpb.fs_ref[i]->frame_num;
        }
        if (dpb.fs_ref[i]->is_reference & 1)
        {
          dpb.fs_ref[i]->top_field->pic_num = (2 * dpb.fs_ref[i]->frame_num_wrap) + add_top;
        }
        if (dpb.fs_ref[i]->is_reference & 2)
        {
          dpb.fs_ref[i]->bottom_field->pic_num = (2 * dpb.fs_ref[i]->frame_num_wrap) + add_bottom;
        }
      }
    }
    // update long_term_pic_num
    for (i=0; i<dpb.ltref_frames_in_buffer; i++)
    {
      if (dpb.fs_ltref[i]->is_long_term & 1)
      {
        dpb.fs_ltref[i]->top_field->long_term_pic_num = 2 * dpb.fs_ltref[i]->top_field->long_term_frame_idx + add_top;
      }
      if (dpb.fs_ltref[i]->is_long_term & 2)
      {
        dpb.fs_ltref[i]->bottom_field->long_term_pic_num = 2 * dpb.fs_ltref[i]->bottom_field->long_term_frame_idx + add_bottom;
      }
    }
  }



  if ((currSliceType == I_SLICE)||(currSliceType == SI_SLICE))
  {
    listXsize[0] = 0;
    listXsize[1] = 0;
    return;
  }

  if ((currSliceType == P_SLICE)||(currSliceType == SP_SLICE))
  {
    // Calculate FrameNumWrap and PicNum
    if (currPicStructure == FRAME)  
    {
      for (i=0; i<dpb.ref_frames_in_buffer; i++)
      {
        if (dpb.fs_ref[i]->is_used==3)
        {
          if ((dpb.fs_ref[i]->frame->used_for_reference)&&(!dpb.fs_ref[i]->frame->is_long_term))
          {
            listX[0][list0idx++] = dpb.fs_ref[i]->frame;
          }
        }
      }
      // order list 0 by PicNum
      qsort((void *)listX[0], list0idx, sizeof(StorablePicture*), compare_pic_by_pic_num_desc);
      listXsize[0] = list0idx;
      //      printf("listX[0] (PicNum): "); for (i=0; i<list0idx; i++){printf ("%d  ", listX[0][i]->pic_num);} printf("\n");

      // long term handling
      for (i=0; i<dpb.ltref_frames_in_buffer; i++)
      {
        if (dpb.fs_ltref[i]->is_used==3)
        {
          if (dpb.fs_ltref[i]->frame->is_long_term)
          {
            listX[0][list0idx++]=dpb.fs_ltref[i]->frame;
          }
        }
      }
      qsort((void *)&listX[0][listXsize[0]], list0idx-listXsize[0], sizeof(StorablePicture*), compare_pic_by_lt_pic_num_asc);
      listXsize[0] = list0idx;
    }
    else
    {
      fs_list0 = calloc(dpb.size, sizeof (FrameStore*));
      if (NULL==fs_list0) 
        no_mem_exit("init_lists: fs_list0");
      fs_listlt = calloc(dpb.size, sizeof (FrameStore*));
      if (NULL==fs_listlt) 
        no_mem_exit("init_lists: fs_listlt");

      for (i=0; i<dpb.ref_frames_in_buffer; i++)
      {
        if (dpb.fs_ref[i]->is_reference)
        {
          fs_list0[list0idx++] = dpb.fs_ref[i];
        }
      }

      qsort((void *)fs_list0, list0idx, sizeof(FrameStore*), compare_fs_by_frame_num_desc);

      //      printf("fs_list0 (FrameNum): "); for (i=0; i<list0idx; i++){printf ("%d  ", fs_list0[i]->frame_num_wrap);} printf("\n");

      listXsize[0] = 0;
      gen_pic_list_from_frame_list(currPicStructure, fs_list0, list0idx, listX[0], &listXsize[0], 0);

      //      printf("listX[0] (PicNum): "); for (i=0; i<listXsize[0]; i++){printf ("%d  ", listX[0][i]->pic_num);} printf("\n");

      // long term handling
      for (i=0; i<dpb.ltref_frames_in_buffer; i++)
      {
        fs_listlt[listltidx++]=dpb.fs_ltref[i];
      }

      qsort((void *)fs_listlt, listltidx, sizeof(FrameStore*), compare_fs_by_lt_pic_idx_asc);

      gen_pic_list_from_frame_list(currPicStructure, fs_listlt, listltidx, listX[0], &listXsize[0], 1);

      free(fs_list0);
      free(fs_listlt);
    }
    listXsize[1] = 0;
  }
  else
  {
    // B-Slice
    if (currPicStructure == FRAME)  
    {
      for (i=0; i<dpb.ref_frames_in_buffer; i++)
      {
        if (dpb.fs_ref[i]->is_used==3)
        {
          if ((dpb.fs_ref[i]->frame->used_for_reference)&&(!dpb.fs_ref[i]->frame->is_long_term))
          {
            if (img->framepoc > dpb.fs_ref[i]->frame->poc)
            {
              listX[0][list0idx++] = dpb.fs_ref[i]->frame;
            }
          }
        }
      }
      qsort((void *)listX[0], list0idx, sizeof(StorablePicture*), compare_pic_by_poc_desc);
      list0idx_1 = list0idx;
      for (i=0; i<dpb.ref_frames_in_buffer; i++)
      {
        if (dpb.fs_ref[i]->is_used==3)
        {
          if ((dpb.fs_ref[i]->frame->used_for_reference)&&(!dpb.fs_ref[i]->frame->is_long_term))
          {
            if (img->framepoc < dpb.fs_ref[i]->frame->poc)
            {
              listX[0][list0idx++] = dpb.fs_ref[i]->frame;
            }
          }
        }
      }
      qsort((void *)&listX[0][list0idx_1], list0idx-list0idx_1, sizeof(StorablePicture*), compare_pic_by_poc_asc);

      for (j=0; j<list0idx_1; j++)
      {
        listX[1][list0idx-list0idx_1+j]=listX[0][j];
      }
      for (j=list0idx_1; j<list0idx; j++)
      {
        listX[1][j-list0idx_1]=listX[0][j];
      }

      listXsize[0] = listXsize[1] = list0idx;

      //      printf("listX[0] currPoc=%d (Poc): ", img->framepoc); for (i=0; i<listXsize[0]; i++){printf ("%d  ", listX[0][i]->poc);} printf("\n");
      //      printf("listX[1] currPoc=%d (Poc): ", img->framepoc); for (i=0; i<listXsize[1]; i++){printf ("%d  ", listX[1][i]->poc);} printf("\n");

      // long term handling
      for (i=0; i<dpb.ltref_frames_in_buffer; i++)
      {
        if (dpb.fs_ltref[i]->is_used==3)
        {
          if (dpb.fs_ltref[i]->frame->is_long_term)
          {
            listX[0][list0idx]  =dpb.fs_ltref[i]->frame;
            listX[1][list0idx++]=dpb.fs_ltref[i]->frame;
          }
        }
      }
      qsort((void *)&listX[0][listXsize[0]], list0idx-listXsize[0], sizeof(StorablePicture*), compare_pic_by_lt_pic_num_asc);
      qsort((void *)&listX[1][listXsize[0]], list0idx-listXsize[0], sizeof(StorablePicture*), compare_pic_by_lt_pic_num_asc);
      
#ifdef SWITCHED_FILTERS
      if(input->UseHPFilter == HPF_SIFO)
      {
        listXsize[0] = list0idx_1;
        listXsize[1] = listXsize[1] - list0idx_1;
      }
      else
      {
        listXsize[0] = listXsize[1] = list0idx;
      }
#else
      listXsize[0] = listXsize[1] = list0idx;
#endif  // SWITCHED_FILTERS
    }
    else
    {
      fs_list0 = calloc(dpb.size, sizeof (FrameStore*));
      if (NULL==fs_list0) 
        no_mem_exit("init_lists: fs_list0");
      fs_list1 = calloc(dpb.size, sizeof (FrameStore*));
      if (NULL==fs_list1) 
        no_mem_exit("init_lists: fs_list1");
      fs_listlt = calloc(dpb.size, sizeof (FrameStore*));
      if (NULL==fs_listlt) 
        no_mem_exit("init_lists: fs_listlt");

      listXsize[0] = 0;
      listXsize[1] = 1;

      for (i=0; i<dpb.ref_frames_in_buffer; i++)
      {
        if (dpb.fs_ref[i]->is_used)
        {
          if (img->ThisPOC >= dpb.fs_ref[i]->poc)
          {
            fs_list0[list0idx++] = dpb.fs_ref[i];
          }
        }
      }
      qsort((void *)fs_list0, list0idx, sizeof(FrameStore*), compare_fs_by_poc_desc);
      list0idx_1 = list0idx;
      for (i=0; i<dpb.ref_frames_in_buffer; i++)
      {
        if (dpb.fs_ref[i]->is_used)
        {
          if (img->ThisPOC < dpb.fs_ref[i]->poc)
          {
            fs_list0[list0idx++] = dpb.fs_ref[i];
          }
        }
      }
      qsort((void *)&fs_list0[list0idx_1], list0idx-list0idx_1, sizeof(FrameStore*), compare_fs_by_poc_asc);

      for (j=0; j<list0idx_1; j++)
      {
        fs_list1[list0idx-list0idx_1+j]=fs_list0[j];
      }
      for (j=list0idx_1; j<list0idx; j++)
      {
        fs_list1[j-list0idx_1]=fs_list0[j];
      }

      //      printf("fs_list0 currPoc=%d (Poc): ", img->ThisPOC); for (i=0; i<list0idx; i++){printf ("%d  ", fs_list0[i]->poc);} printf("\n");
      //      printf("fs_list1 currPoc=%d (Poc): ", img->ThisPOC); for (i=0; i<list0idx; i++){printf ("%d  ", fs_list1[i]->poc);} printf("\n");

      listXsize[0] = 0;
      listXsize[1] = 0;
      gen_pic_list_from_frame_list(currPicStructure, fs_list0, list0idx, listX[0], &listXsize[0], 0);
      gen_pic_list_from_frame_list(currPicStructure, fs_list1, list0idx, listX[1], &listXsize[1], 0);

      //      printf("listX[0] currPoc=%d (Poc): ", img->framepoc); for (i=0; i<listXsize[0]; i++){printf ("%d  ", listX[0][i]->poc);} printf("\n");
      //      printf("listX[1] currPoc=%d (Poc): ", img->framepoc); for (i=0; i<listXsize[1]; i++){printf ("%d  ", listX[1][i]->poc);} printf("\n");

      // long term handling
      for (i=0; i<dpb.ltref_frames_in_buffer; i++)
      {
        fs_listlt[listltidx++]=dpb.fs_ltref[i];
      }

      qsort((void *)fs_listlt, listltidx, sizeof(FrameStore*), compare_fs_by_lt_pic_idx_asc);

      gen_pic_list_from_frame_list(currPicStructure, fs_listlt, listltidx, listX[0], &listXsize[0], 1);
      gen_pic_list_from_frame_list(currPicStructure, fs_listlt, listltidx, listX[1], &listXsize[1], 1);

      free(fs_list0);
      free(fs_list1);
      free(fs_listlt);
    }
  } 

  if ((listXsize[0] == listXsize[1]) && (listXsize[0] > 1))
  {
    // check if lists are identical, if yes swap first two elements of listX[1]
    diff=0;
    for (j = 0; j< listXsize[0]; j++)
    {
      if (listX[0][j]!=listX[1][j])
        diff=1;
    }
    if (!diff)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99精品国产.久久久久| 日韩在线观看一区二区| 在线日韩一区二区| 麻豆精品国产传媒mv男同| 中文字幕免费一区| 欧美精品在线观看一区二区| 国产精品一区二区久久不卡| 亚洲免费av高清| www国产成人| 欧美日韩激情一区| 成人av在线资源网站| 青青草97国产精品免费观看| 国产精品动漫网站| 精品免费国产二区三区 | av一区二区三区黑人| 亚洲精品一区二区三区影院| 日本高清不卡视频| 高清视频一区二区| 蜜臀av一区二区三区| 亚洲最色的网站| 中文无字幕一区二区三区 | 亚洲中国最大av网站| 久久久久国产精品麻豆ai换脸| 欧美日韩精品三区| 色综合久久久久| 粉嫩在线一区二区三区视频| 久久精品久久综合| 五月天激情小说综合| 亚洲欧美日韩电影| 国产精品视频第一区| 久久综合久久鬼色中文字| 在线综合+亚洲+欧美中文字幕| 99精品视频在线免费观看| 国产精品一区免费在线观看| 男女视频一区二区| 午夜欧美2019年伦理| 一区二区三区**美女毛片| 中文字幕不卡的av| 欧美激情一区二区三区全黄| 久久久久97国产精华液好用吗| 91精品国产综合久久婷婷香蕉| 在线这里只有精品| 色香蕉久久蜜桃| 99久久99久久久精品齐齐| 福利电影一区二区三区| 岛国精品在线观看| 成人亚洲一区二区一| 成人性生交大合| 成人手机在线视频| 成人av综合一区| 99精品久久99久久久久| 午夜婷婷国产麻豆精品| 精品国产一区二区三区四区四| 日韩小视频在线观看专区| 欧美一卡二卡在线| 日韩美女一区二区三区四区| 日韩久久久精品| 久久综合av免费| 日本一区二区免费在线| 亚洲国产高清在线观看视频| 国产精品国产三级国产普通话99 | 91黄色在线观看| 欧美综合久久久| 欧美精品xxxxbbbb| 日韩免费看的电影| 久久久久88色偷偷免费| 中文字幕电影一区| 亚洲欧美日韩一区二区三区在线观看| 亚洲男人的天堂网| 4438x亚洲最大成人网| 欧美日韩视频一区二区| 日本道精品一区二区三区| 91在线一区二区三区| 91蝌蚪国产九色| 欧美日韩久久不卡| 日韩午夜电影av| 26uuu精品一区二区在线观看| 精品久久久久久综合日本欧美| 26uuu欧美| 日本一二三不卡| 亚洲成人免费看| 久久爱另类一区二区小说| 国产福利视频一区二区三区| 91视频国产观看| 宅男噜噜噜66一区二区66| 国产精品国产三级国产aⅴ原创| 亚洲老司机在线| 老司机精品视频在线| 蜜桃免费网站一区二区三区 | 国产.欧美.日韩| 国产精品免费丝袜| 欧美午夜免费电影| 国产精品嫩草影院av蜜臀| 亚洲美女一区二区三区| 日本不卡高清视频| 成人免费黄色大片| 欧美最猛性xxxxx直播| 欧美mv日韩mv| 一区二区三区自拍| 久久成人久久鬼色| 色8久久精品久久久久久蜜| 色婷婷综合久久| 久久久久国产精品麻豆| 日韩福利电影在线| 色综合视频在线观看| 国产亚洲欧美日韩日本| 日韩激情av在线| 日韩一区二区三区av| 国产欧美一区二区三区网站| 视频一区二区国产| 欧美三级蜜桃2在线观看| 久久久久亚洲蜜桃| 日本不卡在线视频| 亚洲欧美自拍偷拍| 日本一区二区三区国色天香 | 精品国产欧美一区二区| 国产精品久久久久久久久动漫 | 成人精品免费看| 精品日产卡一卡二卡麻豆| 亚洲综合免费观看高清完整版在线| 精品一区二区三区久久| 欧美三级一区二区| 国产精品国产三级国产普通话99| 久久99精品久久久久久久久久久久 | 欧美日韩一级视频| 午夜久久久久久久久| 欧美精品一区男女天堂| 国产成人在线网站| 中文字幕不卡在线观看| 北条麻妃国产九九精品视频| 国产精品国产精品国产专区不蜜| 99视频在线观看一区三区| 亚洲精品一二三| 91精品国产高清一区二区三区| 久久99国产精品成人| 水蜜桃久久夜色精品一区的特点| 免费观看在线综合色| 菠萝蜜视频在线观看一区| 久久精品日产第一区二区三区高清版 | av高清不卡在线| 亚洲国产精品99久久久久久久久| 精品在线一区二区三区| 日韩一卡二卡三卡| 美国欧美日韩国产在线播放| 欧美日韩一区国产| 亚洲成av人影院| 精品视频在线免费看| 亚洲成国产人片在线观看| 欧美色综合影院| 一区二区三国产精华液| 欧洲国产伦久久久久久久| 亚洲黄一区二区三区| 在线视频一区二区三| 亚洲妇熟xx妇色黄| 欧美日韩视频在线一区二区| 午夜国产精品一区| 美国十次综合导航| 欧美在线一区二区| 午夜精品久久久久影视| 欧美日韩国产综合一区二区| 五月综合激情婷婷六月色窝| 欧美日韩免费高清一区色橹橹 | 日韩免费高清av| 久久69国产一区二区蜜臀| 精品国产露脸精彩对白| 国产精品99久久久久久有的能看| 久久精品亚洲乱码伦伦中文| 成人av网址在线| 夜夜嗨av一区二区三区网页| 在线综合+亚洲+欧美中文字幕| 久久精品国产网站| 久久夜色精品国产噜噜av| 国产91精品一区二区麻豆亚洲| 国产精品成人免费精品自在线观看| 99re热这里只有精品免费视频| 亚洲无人区一区| 精品少妇一区二区三区视频免付费| 国产精品77777竹菊影视小说| 亚洲精品视频在线| 宅男在线国产精品| 成人做爰69片免费看网站| 亚洲一区二区中文在线| 欧美成人综合网站| www.99精品| 男女激情视频一区| 欧美国产成人在线| 欧美日本精品一区二区三区| 黄色小说综合网站| 综合网在线视频| 欧美三级电影在线观看| 国产呦精品一区二区三区网站| 亚洲少妇屁股交4| 日韩女同互慰一区二区| 99re这里只有精品视频首页| 美女视频免费一区| 亚洲欧美日韩一区二区| 日韩美一区二区三区| 色天使色偷偷av一区二区| 美女网站色91| 亚洲精品免费在线观看|