这个是维护去方块滤波参数的结构体:
/// parameters for deblocking filter
typedef struct _LFCUParam
{
Bool bInternalEdge; ///< indicates internal edge
Bool bLeftEdge; ///< indicates left edge
Bool bTopEdge; ///< indicates top edge
} LFCUParam;
//! 该函数的功能是根据当前PU的位置、当前PU的邻块的存在性对其边界是否进行相应滤波进行判断
Void TComLoopFilter::xSetLoopfilterParam( TComDataCU* pcCU, UInt uiAbsZorderIdx )
{
UInt uiX = pcCU->getCUPelX() + g_auiRasterToPelX[ g_auiZscanToRaster[ uiAbsZorderIdx ] ];
UInt uiY = pcCU->getCUPelY() + g_auiRasterToPelY[ g_auiZscanToRaster[ uiAbsZorderIdx ] ];
TComDataCU* pcTempCU;
UInt uiTempPartIdx;
m_stLFCUParam.bInternalEdge = ! pcCU->getSlice()->getDeblockingFilterDisable(); //!< 标记边界是否进行去方块滤波
if ( (uiX == 0) || pcCU->getSlice()->getDeblockingFilterDisable() )
{
m_stLFCUParam.bLeftEdge = false;
}
else
{
m_stLFCUParam.bLeftEdge = true;
}
if ( m_stLFCUParam.bLeftEdge )
{
pcTempCU = pcCU->getPULeft( uiTempPartIdx, uiAbsZorderIdx, !pcCU->getSlice()->getLFCrossSliceBoundaryFlag(), false, !m_bLFCrossTileBoundary);
if ( pcTempCU ) //!< 只有在左邻PU存在的情况下才进行垂直边界的滤波
{
m_stLFCUParam.bLeftEdge = true;
}
else
{
m_stLFCUParam.bLeftEdge = false;
}
}
if ( (uiY == 0 ) || pcCU->getSlice()->getDeblockingFilterDisable() )
{
m_stLFCUParam.bTopEdge = false;
}
else
{
m_stLFCUParam.bTopEdge = true;
}
if ( m_stLFCUParam.bTopEdge )
{
#if LINEBUF_CLEANUP
pcTempCU = pcCU->getPUAbove( uiTempPartIdx, uiAbsZorderIdx, !pcCU->getSlice()->getLFCrossSliceBoundaryFlag(), false , false, !m_bLFCrossTileBoundary);
#else
pcTempCU = pcCU->getPUAbove( uiTempPartIdx, uiAbsZorderIdx, !pcCU->getSlice()->getLFCrossSliceBoundaryFlag(), false , false, false, !m_bLFCrossTileBoundary);
#endif
if ( pcTempCU ) //!< 只有在上邻PU存在的情况下才进行水平边界的滤波
{
m_stLFCUParam.bTopEdge = true;
}
else
{
m_stLFCUParam.bTopEdge = false;
}
}
}