VTM3.0代码阅读:getIntraChromaCandModes函数

getIntraChromaCandModes在estIntraPredChromaQT函数中被调用,用来构建帧内色度预测时的候选模式列表,帧内色度预测就是将该列表中的模式。
色度模式列表的长度为8。
流程:
预置色度预测模式planar、ver、hor、DC、LM、LM_L、LM_T、DM;
获取色度块对应亮度块的lumaMode;
如果前4个候选中有和lumaMode相同的,修改为模式66。

void PU::getIntraChromaCandModes( const PredictionUnit &pu, unsigned modeList[NUM_CHROMA_MODE] )
{
  {
    modeList[  0 ] = PLANAR_IDX;	//预置的色度候选模式为:planar、ver、hor、DC、LM、LM_L、LM_T、DM
    modeList[  1 ] = VER_IDX;
    modeList[  2 ] = HOR_IDX;
    modeList[  3 ] = DC_IDX;
    modeList[4] = LM_CHROMA_IDX;
#if JVET_L0338_MDLM
    modeList[5] = MDLM_L_IDX;		//帧内模式号:67
    modeList[6] = MDLM_T_IDX;		//68
    modeList[7] = DM_CHROMA_IDX;	//69
#else
    modeList[5] = DM_CHROMA_IDX;	//69
#endif

#if JVET_L0053_L0272_DM
    Position topLeftPos = pu.blocks[pu.chType].lumaPos();				//取当前pu的中心位置
    Position refPos = topLeftPos.offset( pu.blocks[pu.chType].lumaSize().width >> 1, pu.blocks[pu.chType].lumaSize().height >> 1 );
					//CS::isDualITree()为true时,则此时的入口pu即色度域的pu,(因为这种情况下调用estIntraPredChromaQT函数时的ChannelType为chroma);
					//如果为false,那么调用estIntraPredChromaQT函数时的ChannelType为luma,此时的pu不区分亮度域色度域
    const PredictionUnit *lumaPU = CS::isDualITree( *pu.cs ) ? pu.cs->picture->cs->getPU( refPos, CHANNEL_TYPE_LUMA ) : &pu;
#else
    const PredictionUnit *lumaPU = CS::isDualITree( *pu.cs ) ? pu.cs->picture->cs->getPU( pu.blocks[pu.chType].lumaPos(), CHANNEL_TYPE_LUMA ) : &pu;
#endif
    const uint32_t lumaMode = lumaPU->intraDir[CHANNEL_TYPE_LUMA];		//获取色度pu对应位置处的亮度pu的帧内模式
    for( int i = 0; i < 4; i++ )		//前4个
    {
      if( lumaMode == modeList[i] )		//如果预置的色度候选模式有和lumaMode相同
      {									//则修改为反对角模式66
        modeList[i] = VDIA_IDX;
        break;
      }
    }
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值