HM修改QDCT/QDST系数经验

1、修改的位置:在预测阶段的量化之后反量化之前这个时候。
以HM 12.0为例,在TEncSearch.cpp::xIntraCodingLumaBlk()函数中

// 变换(连同量化一起)
	m_pcTrQuant->transformNxN     ( pcCU, piResi, uiStride, pcCoeff, 
#if ADAPTIVE_QP_SELECTION
		pcArlCoeff, 
#endif
		uiWidth, uiHeight, uiAbsSum, TEXT_LUMA, uiAbsPartIdx,useTransformSkip );


	// ==================================================== 20210524添加
	// 在这里修改QDCT/QDST系数
	// ====================================================


	//--- set coded block flag ---
	pcCU->setCbfSubParts          ( ( uiAbsSum ? 1 : 0 ) << uiTrDepth, TEXT_LUMA, uiAbsPartIdx, uiFullDepth );
	//--- inverse transform ---
	// uiAbsSum表示变换系数的绝对值之和
	if( uiAbsSum )
	{
		Int scalingListType = 0 + g_eTTable[(Int)TEXT_LUMA];
		assert(scalingListType < 6);
		// 反变换
		m_pcTrQuant->invtransformNxN( pcCU->getCUTransquantBypass(uiAbsPartIdx), TEXT_LUMA,pcCU->getLumaIntraDir( uiAbsPartIdx ), piResi, uiStride, pcCoeff, uiWidth, uiHeight, scalingListType, useTransformSkip );
	}
	else
	{
		Pel* pResi = piResi;
		memset( pcCoeff, 0, sizeof( TCoeff ) * uiWidth * uiHeight );
		for( UInt uiY = 0; uiY < uiHeight; uiY++ )
		{
			memset( pResi, 0, sizeof( Pel ) * uiWidth );
			pResi += uiStride;
		}
	}

2、修改完QDCT/QDST系数之后,要把uiAbsSum也一起更新。uiAbsSum是变换系数的绝对值之和。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值