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

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

?? rdopt.c

?? h264標準的VC實現
?? C
?? 第 1 頁 / 共 5 頁
字號:
          enc_picture->mv[LIST_1][bxr][by][1] = 0;
        }
        else if (pdir8==1) // backward
        {
          enc_picture->mv[LIST_0][bxr][by][0] = 0;
          enc_picture->mv[LIST_0][bxr][by][1] = 0;

          enc_picture->mv[LIST_1][bxr][by][0] = all_mv[i][j][LIST_1][bw_ref][mode8][0];
          enc_picture->mv[LIST_1][bxr][by][1] = all_mv[i][j][LIST_1][bw_ref][mode8][1];
        }
        else if (pdir8==2) // bidir
        {
          enc_picture->mv[LIST_0][bxr][by][0] = all_mv [i][j][LIST_0][ ref][mode8][0];
          enc_picture->mv[LIST_0][bxr][by][1] = all_mv [i][j][LIST_0][ ref][mode8][1];


          enc_picture->mv[LIST_1][bxr][by][0] = all_mv[i][j][LIST_1][bw_ref][mode8][0];
          enc_picture->mv[LIST_1][bxr][by][1] = all_mv[i][j][LIST_1][bw_ref][mode8][1];
        }
        else
        {
          error("invalid direction mode", 255);
        }
      }
  }

  // copy all the motion vectors into rdopt structure
  // Can simplify this by copying the MV's of the best mode (TBD)
  if(img->MbaffFrameFlag)
  {
    for(i=0;i<4;i++)
      for(j=0;j<4;j++)
        for (k=0;k<2;k++)
          for(l=0;l<img->max_num_references;l++)
            for(m=0;m<9;m++)
            {
              rdopt->all_mv [i][j][k][l][m][0]  = all_mv [i][j][k][l][m][0];
              rdopt->pred_mv[i][j][k][l][m][0]  = pred_mv[i][j][k][l][m][0];

              rdopt->all_mv [i][j][k][l][m][1]  = all_mv [i][j][k][l][m][1];
              rdopt->pred_mv[i][j][k][l][m][1]  = pred_mv[i][j][k][l][m][1];
            }
  }
}



/*!
 *************************************************************************************
 * \brief
 *    R-D Cost for a macroblock
 *************************************************************************************
 */
int RDCost_for_macroblocks (double   lambda,      // <-- lagrange multiplier
                        int      mode,        // <-- modus (0-COPY/DIRECT, 1-16x16, 2-16x8, 3-8x16, 4-8x8(+), 5-Intra4x4, 6-Intra16x16)
                        double*  min_rdcost)  // <-> minimum rate-distortion cost
{
  int         i, j, k; //, k, ****ip4;
  int         i16mode, rate=0;
  int64       distortion=0;
  double      rdcost;
  Macroblock  *currMB   = &img->mb_data[img->current_mb_nr];
  Macroblock  *prevMB   = img->current_mb_nr ? &img->mb_data[img->current_mb_nr-1] : NULL;
  int         bframe    = (img->type==B_SLICE);
  int         tmp_cc;
  int         use_of_cc =  (img->type!=I_SLICE &&  input->symbol_mode!=CABAC);
  int         cc_rate, dummy;
  int         cr_cbp=0, uv;

  //=====
  //=====  SET REFERENCE FRAMES AND BLOCK MODES
  //=====
  SetModesAndRefframeForBlocks (mode);

  //=====
  //=====  GET COEFFICIENTS, RECONSTRUCTIONS, CBP
  //=====
  if (bframe && mode==0)
  {
    int block_x=img->pix_x>>2;
    int block_y=img->pix_y>>2;
    for (i=0;i<4;i++)
      for (j=0;j<4;j++)
        if (direct_pdir[block_x+i][block_y+j]<0)
          return 0;
  }

  if (mode<P8x8)
  {
    LumaResidualCoding ();
    if(mode==0 && currMB->cbp==0 && currMB->luma_transform_size_8x8_flag==1) //for B_skip, luma_transform_size_8x8_flag=0 only
      return 0;
  }
  else if (mode==P8x8)
  {
    SetCoeffAndReconstruction8x8 (currMB);
  }
  else if (mode==I4MB)
  {
    currMB->cbp = Mode_Decision_for_Intra4x4Macroblock (lambda, &dummy);

    // Residue Color Transform
    if(img->residue_transform_flag)
    {
      for(i=0; i<2; i++)
      for(j=0; j<4; j++)
      for(k=0; k<4; k++)
        if(cbp_chroma_block[i][j][k])
          cr_cbp = 2;

      for(uv=0; uv<2; uv++)
        cr_cbp = dct_chroma_DC(uv, cr_cbp);

      currMB->cbp += (cr_cbp<<4);
    }
  }
  else if (mode==I16MB)
  {
    Intra16x16_Mode_Decision  (currMB, &i16mode);
  }
  else if(mode==I8MB){
    currMB->cbp = Mode_Decision_for_new_Intra8x8Macroblock(lambda, &dummy);

    // Residue Color Transform
    if(img->residue_transform_flag)
    {
      for(i=0; i<2; i++)
      for(j=0; j<4; j++)
      for(k=0; k<4; k++)
        if(cbp_chroma_block[i][j][k])
          cr_cbp = 2;

      for(uv=0; uv<2; uv++)
        cr_cbp = dct_chroma_DC(uv, cr_cbp);

      currMB->cbp += (cr_cbp<<4);
    }
  }

  if (input->rdopt==2 && img->type!=B_SLICE)
  {
    // We need the reconstructed prediction residue for the simulated decoders.
    compute_residue_mb (mode==I16MB?i16mode:-1);
  }

  //Rate control
  if (mode == I16MB)
  {
    for(i=0; i<16; i++)
    for(j=0; j<16; j++)
      pred[j][i] = img->mprr_2[i16mode][j][i];
  }else
  {
    for(i=0; i<16; i++)
    for(j=0; j<16; j++)
      pred[j][i] = img->mpr[i][j];
  }

  img->i16offset = 0;
  dummy = 0;
  if ((!(img->residue_transform_flag && (mode==I4MB || mode==I16MB || mode==I8MB))) && img->yuv_format!=YUV400)
    ChromaResidualCoding (&dummy);
  if (mode==I16MB)     img->i16offset = I16Offset  (currMB->cbp, i16mode);

  //=====
  //=====   GET DISTORTION
  //=====
  // LUMA
  if (input->rdopt==2 && img->type!=B_SLICE)
  {
    for (k=0; k<input->NoOfDecoders ;k++)
    {
      decode_one_mb (k, currMB);
      for (j=0; j<MB_BLOCK_SIZE; j++)
      for (i=img->opix_x; i<img->opix_x+MB_BLOCK_SIZE; i++)
      {
        distortion += img->quad [imgY_org[img->opix_y+j][i] - decs->decY[k][img->opix_y+j][i]];
      }
    }
    distortion /= input->NoOfDecoders;
  }
  else
  {
    for (j=0; j<16; j++)
    for (i=img->opix_x; i<img->opix_x+16; i++)
    {
      distortion += img->quad [imgY_org[j+img->opix_y][i] - enc_picture->imgY[img->pix_y+j][i]];
    }
  }

  if (img->yuv_format != YUV400)
  {
    // CHROMA
    for (j=0; j<img->mb_cr_size_y; j++)
    for (i=img->opix_c_x; i<img->opix_c_x+img->mb_cr_size_x; i++)
    {
      distortion += img->quad [imgUV_org[0][j+img->opix_c_y][i] - enc_picture->imgUV[0][img->pix_c_y+j][i]];
      distortion += img->quad [imgUV_org[1][j+img->opix_c_y][i] - enc_picture->imgUV[1][img->pix_c_y+j][i]];
    }
  }


  //=====   S T O R E   C O D I N G   S T A T E   =====
  //---------------------------------------------------
  store_coding_state (cs_cm);

  //=====
  //=====   GET RATE
  //=====
  //----- macroblock header -----
  if (use_of_cc)
  {
    if (currMB->mb_type!=0 || (bframe && currMB->cbp!=0))
    {
      // cod counter and macroblock mode are written ==> do not consider code counter
      tmp_cc = img->cod_counter;
      rate   = writeMBLayer (1);
      ue_linfo (tmp_cc, dummy, &cc_rate, &dummy);
      rate  -= cc_rate;
      img->cod_counter = tmp_cc;
    }
    else
    {
      // cod counter is just increased  ==> get additional rate
      ue_linfo (img->cod_counter+1, dummy, &rate,    &dummy);
      ue_linfo (img->cod_counter,   dummy, &cc_rate, &dummy);
      rate -= cc_rate;
    }
  }
  else
  {
    rate = writeMBLayer (1);
  }

  //=====   R E S T O R E   C O D I N G   S T A T E   =====
  //-------------------------------------------------------
  reset_coding_state (cs_cm);

  rdcost = (double)distortion + lambda * (double)rate;

  if (rdcost >= *min_rdcost ||
      ((img->qp + img->bitdepth_luma_qp_scale)==0 && img->lossless_qpprime_flag==1 && distortion!=0))
  {
    return 0;
  }


  if ((img->MbaffFrameFlag) && (mode ? 0: ((img->type == B_SLICE) ? !currMB->cbp:1)))  // AFF and current is skip
  {
    if (img->current_mb_nr%2) //bottom
    {
      if (prevMB->mb_type ? 0:((img->type == B_SLICE) ? !prevMB->cbp:1)) //top is skip
      {
        if (!(field_flag_inference() == currMB->mb_field)) //skip only allowed when correct inference
          return 0;
      }
    }
  }

  //=====   U P D A T E   M I N I M U M   C O S T   =====
  //-----------------------------------------------------
  *min_rdcost = rdcost;
  return 1;
}





/*!
 *************************************************************************************
 * \brief
 *    Store macroblock parameters
 *************************************************************************************
 */
void store_macroblock_parameters (int mode)
{
  int  i, j, k, ****i4p, ***i3p;
  Macroblock *currMB  = &img->mb_data[img->current_mb_nr];
  int        bframe   = (img->type==B_SLICE);

  //--- store best mode ---
  best_mode = mode;
  best_c_imode = currMB->c_ipred_mode;
  best_i16offset = img->i16offset;
  for (i=0; i<4; i++)
  {
    b8mode[i]   = currMB->b8mode[i];
    b8pdir[i]   = currMB->b8pdir[i];
  }
  // Residue Color Transform
  for (k=0, j=img->block_y; j<img->block_y+4; j++)
  for (i=img->block_x; i<img->block_x+4; i++, k++)
  {
    b4_ipredmode[k] = img->ipredmode[i][j];
    b4_intra_pred_modes[k] = currMB->intra_pred_modes[k];
  }
  for(i = k = 0; i < 4; i++)
  for(j = 0; j < 4; j++,k++)
  {
    b8_ipredmode8x8[i][j] = img->ipredmode8x8[img->block_x+i][img->block_y+j];
    //only every fourth value relevant
    b8_intra_pred_modes8x8[k] = currMB->intra_pred_modes8x8[k];
  }

  //--- reconstructed blocks ----
  for (j=0; j<16; j++)
  for (i=0; i<16; i++)
  {
    rec_mbY[j][i] = enc_picture->imgY[img->pix_y+j][img->pix_x+i];
  }

  if (img->yuv_format != YUV400)
  {
    for (j=0; j<img->mb_cr_size_y; j++)
    for (i=0; i<img->mb_cr_size_x; i++)
    {
      rec_mbU[j][i] = enc_picture->imgUV[0][img->pix_c_y+j][img->pix_c_x+i];
      rec_mbV[j][i] = enc_picture->imgUV[1][img->pix_c_y+j][img->pix_c_x+i];
    }
  }


  //--- store results of decoders ---
  if (input->rdopt==2 && img->type!=B_SLICE)
  {
    for (k=0; k<input->NoOfDecoders; k++)
    {
      for (j=img->pix_y; j<img->pix_y+16; j++)
      for (i=img->pix_x; i<img->pix_x+16; i++)
      {
        // Keep the decoded values of each MB for updating the ref frames
        decs->decY_best[k][j][i] = decs->decY[k][j][i];
      }
    }
  }

  //--- coeff, cbp, kac ---
  if (mode || bframe)
  {
    i4p=cofAC; cofAC=img->cofAC; img->cofAC=i4p;
    i3p=cofDC; cofDC=img->cofDC; img->cofDC=i3p;
    cbp     = currMB->cbp;
    cbp_blk = currMB->cbp_blk;
  }
  else
  {
    cbp_blk = cbp = 0;
  }

  //--- store transform size ---
  luma_transform_size_8x8_flag = currMB->luma_transform_size_8x8_flag;
//  NoMbPartLessThan8x8Flag  = currMB->NoMbPartLessThan8x8Flag;   //DEL-VG-29072004


  for (j=0; j<4; j++)
  for (i=0; i<4; i++)
  {
    frefframe[j][i] = enc_picture->ref_idx[LIST_0][img->block_x+i][img->block_y+j];

    if (bframe)
    {
      brefframe[j][i] = enc_picture->ref_idx[LIST_1][img->block_x+i][img->block_y+j];
    }
  }

}


/*!
 *************************************************************************************
 * \brief
 *    Set stored macroblock parameters
 *************************************************************************************
 */
void set_stored_macroblock_parameters ()
{
  int  i, j, k, ****i4p, ***i3p,l;
  Macroblock  *currMB  = &img->mb_data[img->current_mb_nr];
  int         mode     = best_mode;
  int         bframe   = (img->type==B_SLICE);
  int         **ipredmodes = img->ipredmode;

  imgpel        **imgY  = enc_picture->imgY;
  imgpel       ***imgUV = enc_picture->imgUV;

  int        list_offset   = ((img->MbaffFrameFlag)&&(currMB->mb_field))? img->current_mb_nr%2 ? 4 : 2 : 0;

  //===== reconstruction values =====
  for (j=0; j<16; j++)
  for (i=0; i<16; i++)
  {
    imgY[img->pix_y+j][img->pix_x+i] = rec_mbY[j][i];

    if(img->MbaffFrameFlag)
      rdopt->rec_mbY[j][i]       = rec_mbY[j][i];
  }

  if (img->yuv_format != YUV400)
  {
    for (j=0; j<img->mb_cr_size_y; j++)
      for (i=0; i<img->mb_cr_size_x; i++)
      {
        imgUV[0][img->pix_c_y+j][img->pix_c_x+i] = rec_mbU[j][i];
        imgUV[1][img->pix_c_y+j][img->pix_c_x+i] = rec_mbV[j][i];
        
        if(img->MbaffFrameFlag)
        {
          rdopt->rec_mbU[j][i]           = rec_mbU[j][i];
          rdopt->rec_mbV[j][i]           = rec_mbV[j]

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一二三区| 一区二区三区在线观看视频| 欧美中文字幕一区二区三区| 国产综合色在线视频区| 青青国产91久久久久久 | 免费日韩伦理电影| 亚洲国产va精品久久久不卡综合 | 91亚洲精品一区二区乱码| 国产69精品久久久久毛片| 国产高清不卡二三区| 成人av在线网站| 97久久精品人人做人人爽| 91美女视频网站| 在线观看av一区二区| 欧美剧在线免费观看网站| 91精品国产免费| 国产亚洲一区字幕| 亚洲欧美日韩中文播放| 亚洲在线免费播放| 蜜桃av一区二区| 国内精品第一页| 99国产欧美另类久久久精品 | 欧美一级夜夜爽| 久久综合久久鬼色中文字| 国产偷国产偷精品高清尤物 | 91精品午夜视频| 欧美一区二区三区视频免费播放| 日韩精品资源二区在线| 久久久久久久久免费| 中文字幕免费在线观看视频一区| 亚洲黄色性网站| 久久66热偷产精品| eeuss鲁片一区二区三区在线看| 在线国产亚洲欧美| 精品久久久久久最新网址| 国产精品久久毛片| 日韩极品在线观看| jizz一区二区| 2014亚洲片线观看视频免费| 一区二区三区四区不卡在线 | 色老汉av一区二区三区| 日韩欧美一区电影| 亚洲日本va午夜在线影院| 日本不卡一区二区| www.欧美精品一二区| 日韩精品在线一区| 偷拍一区二区三区| 99热精品国产| 国产亚洲欧美色| 丝袜美腿成人在线| 91浏览器入口在线观看| 精品国产精品一区二区夜夜嗨| 综合激情网...| 国产精品乡下勾搭老头1| 91精品国产一区二区三区蜜臀| 国产精品美女一区二区在线观看| 日韩av午夜在线观看| 色哟哟国产精品免费观看| 久久先锋影音av| 日韩精品国产精品| 欧美精选一区二区| 一区二区成人在线视频| 波多野结衣在线一区| 久久精品视频免费观看| 蜜臀av一区二区| 欧美一区二区三区精品| 视频一区中文字幕国产| 一本大道久久a久久精品综合| 久久久精品免费网站| 久久er精品视频| 7777精品伊人久久久大香线蕉完整版| 亚洲日本中文字幕区| 97超碰欧美中文字幕| 中文在线免费一区三区高中清不卡| 精品在线观看视频| 日韩欧美美女一区二区三区| 调教+趴+乳夹+国产+精品| 欧美性猛交一区二区三区精品| 亚洲精品乱码久久久久久| 91香蕉视频在线| 亚洲另类在线视频| 欧美在线免费视屏| 石原莉奈一区二区三区在线观看| 欧美三区免费完整视频在线观看| 亚洲黄色小视频| 欧美麻豆精品久久久久久| 日韩精品一区第一页| wwwwww.欧美系列| 国产精品一区在线| 亚洲视频免费看| 欧美亚洲图片小说| 人人超碰91尤物精品国产| 欧美成人女星排名| 成人免费福利片| 亚洲另类中文字| 制服丝袜激情欧洲亚洲| 国产一区二区不卡老阿姨| 欧美—级在线免费片| 91视频www| 午夜激情一区二区三区| 欧美成人福利视频| 99综合影院在线| 亚洲成人精品影院| 精品人在线二区三区| 成人激情黄色小说| 偷拍日韩校园综合在线| 久久女同精品一区二区| www.av亚洲| 久久精品国产99国产精品| 国产午夜精品理论片a级大结局| 日本韩国一区二区三区| 日韩电影免费在线观看网站| 中文字幕久久午夜不卡| 欧美日本国产视频| 国产成人高清视频| 亚洲自拍另类综合| 久久美女艺术照精彩视频福利播放| 91在线码无精品| 国产综合色精品一区二区三区| 亚洲色欲色欲www| 日韩欧美国产一区二区三区| 97成人超碰视| 国产成人丝袜美腿| 日本不卡一区二区三区| 亚洲天堂免费在线观看视频| 欧美变态口味重另类| 欧美综合欧美视频| 99免费精品视频| 激情综合网av| 日韩国产成人精品| 一二三区精品福利视频| 日本一区二区免费在线| 欧美一级一区二区| 欧美人伦禁忌dvd放荡欲情| 99视频国产精品| 丁香五精品蜜臀久久久久99网站 | 欧美精品一区二| 666欧美在线视频| 欧美私模裸体表演在线观看| av成人免费在线| 成人精品免费网站| 国产寡妇亲子伦一区二区| 亚洲国产成人精品视频| 亚洲精品成人悠悠色影视| 欧美国产在线观看| 国产日韩影视精品| 久久久久高清精品| 精品国产一二三区| 精品精品国产高清a毛片牛牛| 欧美日韩亚洲综合在线| 91福利国产成人精品照片| 91性感美女视频| 91浏览器入口在线观看| 色综合 综合色| 一本到不卡精品视频在线观看| 99国产精品久久久久久久久久久| 不卡av在线网| jlzzjlzz亚洲日本少妇| 99精品视频在线免费观看| 成人激情小说乱人伦| 成人黄色在线看| 91麻豆免费看| 欧美日韩国产电影| 8x8x8国产精品| 精品国产a毛片| 国产日韩欧美电影| 国产精品入口麻豆九色| 国产精品黄色在线观看| 一区二区三区波多野结衣在线观看| 亚洲另类一区二区| 蜜乳av一区二区| 国产91精品一区二区| 成人免费毛片app| 欧洲在线/亚洲| 制服.丝袜.亚洲.中文.综合| 日韩精品最新网址| 国产精品视频一二| 一区二区日韩电影| 久久99精品国产91久久来源| 成人午夜电影网站| 欧美午夜精品久久久久久孕妇| 91精品婷婷国产综合久久性色| 久久九九久久九九| 亚洲综合久久久| 极品少妇一区二区三区精品视频| 国产成人av电影| 欧美日韩精品一区二区三区蜜桃| 日韩欧美国产一二三区| 国产精品第一页第二页第三页| 亚洲一区欧美一区| 国产一区欧美二区| 欧美性色综合网| 国产欧美日韩另类视频免费观看| 欧美精品一区二| 欧美电影在线免费观看| 51久久夜色精品国产麻豆| 欧美一级搡bbbb搡bbbb| 国产午夜精品久久久久久久| 亚洲小少妇裸体bbw| 99riav久久精品riav|