sliceheaderbase.cpp
来自「JMVM MPEG MVC/3DAV 测试平台 国际通用标准」· C++ 代码 · 共 1,669 行 · 第 1/5 页
CPP
1,669 行
else
{
//manu.mathew@samsung : memory leak fix
if( m_pcFMO )
{
delete m_pcFMO; m_pcFMO = NULL;
}
//--
m_pcFMO = new FMO();
}
const SequenceParameterSet* pcSPS = &(getSPS());
const PictureParameterSet* pcPPS = &(getPPS());
m_pcFMO->img_.field_pic_flag = false; //interlaced TODO
m_pcFMO->pps_.num_slice_groups_minus1 = pcPPS->getNumSliceGroupsMinus1();
m_pcFMO->pps_.slice_group_map_type = pcPPS->getSliceGroupMapType();
m_pcFMO->img_.PicHeightInMapUnits = pcSPS->getFrameHeightInMbs();
m_pcFMO->img_.PicWidthInMbs = pcSPS->getFrameWidthInMbs();
m_pcFMO->img_.PicSizeInMbs = pcSPS->getFrameHeightInMbs()*pcSPS->getFrameWidthInMbs();
m_pcFMO->img_.slice_group_change_cycle = getSliceGroupChangeCycle();
m_pcFMO->pps_.num_slice_group_map_units_minus1 = pcPPS->getNumSliceGroupMapUnitsMinus1();
m_pcFMO->pps_.copy_run_length_minus1(pcPPS->getArrayRunLengthMinus1());
m_pcFMO->pps_.copy_top_left(pcPPS->getArrayTopLeft());
m_pcFMO->pps_.copy_bottom_right(pcPPS->getArrayBottomRight());
m_pcFMO->pps_.slice_group_change_direction_flag = pcPPS->getSliceGroupChangeDirection_flag();
m_pcFMO->pps_.slice_group_change_rate_minus1 = pcPPS->getSliceGroupChangeRateMinus1();
m_pcFMO->pps_.copy_slice_group_id(pcPPS->getArraySliceGroupId());
m_pcFMO->sps_.pic_height_in_map_units_minus1 =pcSPS->getFrameHeightInMbs()-1;
m_pcFMO->sps_.pic_width_in_mbs_minus1 = pcSPS->getFrameWidthInMbs()-1;
m_pcFMO->sps_.frame_mbs_only_flag = 1; // interlaced TODO
m_pcFMO->sps_.mb_adaptive_frame_field_flag = 0; //
m_pcFMO->init(&(m_pcFMO->pps_),&(m_pcFMO->sps_));
m_pcFMO->StartPicture();
return Err::m_nOK;
}
Int SliceHeaderBase::getNumMbInSlice()
{
Int SliceID =m_pcFMO->getSliceGroupId(getFirstMbInSlice());
return m_pcFMO->getNumMbInSliceGroup(SliceID);
}
//TMM_WP
ErrVal SliceHeaderBase::PredWeight::setPredWeightsAndFlags( const Int iLumaScale,
const Int iChromaScale,
const Double *pfWeight,
Double fDiscardThr )
{
const Double *pW = pfWeight;
const Int iLScale = iLumaScale;
const Int iCScale = iChromaScale;
const Int iLumW = (Int)pW[0];
const Int iCbW = (Int)pW[1];
const Int iCrW = (Int)pW[2];
RNOK( init( iLumW, iCbW, iCrW ) );
setLumaWeightFlag ( (iLumW != iLScale) );
setChromaWeightFlag( (iCbW != iCScale) || (iCrW != iCScale) );
return Err::m_nOK;
}
ErrVal SliceHeaderBase::PredWeight::getPredWeights( Double *afWeight)
{
afWeight[0] = (Double) getLumaWeight();
afWeight[1] = (Double) getChromaWeight(0);
afWeight[2] = (Double) getChromaWeight(1);
return Err::m_nOK;
}
ErrVal SliceHeaderBase::PredWeightTable::setPredWeightsAndFlags( const Int iLumaScale, const Int iChromaScale, const Double(*pafWeight)[3], Double fDiscardThr )
{
ROT( 0 == size() );
for( UInt n = 0; n < size(); n++ )
{
RNOK( get(n).setPredWeightsAndFlags( iLumaScale, iChromaScale, pafWeight[n], fDiscardThr ) );
}
return Err::m_nOK;
}
ErrVal SliceHeaderBase::copyWeightedPred(PredWeightTable& pcPredWeightTable, UInt uiLumaLogWeightDenom,
UInt uiChromaWeightDenom, ListIdx eListIdx, Bool bDecoder)
{
m_uiLumaLog2WeightDenom = uiLumaLogWeightDenom;
m_uiChromaLog2WeightDenom = uiChromaWeightDenom;
Int iLumaScale = 1 << uiLumaLogWeightDenom;
Int iChromaScale = 1 << uiChromaWeightDenom;
Double afWeights[3];
/* Disable this for now since offsets are not supported for SVC. Enabling this will result in mismatch*/
//Double afOffsets[3];
if(!bDecoder)
{
RNOK( getPredWeightTable(eListIdx).uninit() );
RNOK( getPredWeightTable(eListIdx).init( getNumRefIdxActive( eListIdx) ) );
}
for( UInt n = 0; n < pcPredWeightTable.size(); n++ )
{
RNOK( pcPredWeightTable.get(n).getPredWeights( afWeights) );
m_acPredWeightTable[eListIdx].get(n).setPredWeightsAndFlags( iLumaScale, iChromaScale, afWeights, false );
/* Disable this for now since offsets are not supported for SVC. Enabling this will result in mismatch*/
// RNOK( pcPredWeightTable.get(n).getOffsets( afOffsets) );
// m_acPredWeightTable[eListIdx].get(n).setOffsets(afOffsets);
}
return Err::m_nOK;
}
ErrVal SliceHeaderBase::PredWeight::setOffsets( const Double *pfOffsets)
{
const Double *pW = pfOffsets;
const Int iLumO = (Int)pW[0];
const Int iCbO = (Int)pW[1];
const Int iCrO = (Int)pW[2];
setLumaWeightFlag ( (iLumO != 0) );
setChromaWeightFlag( (iCbO != 0) || (iCrO != 0) );
RNOK( initOffsets( iLumO, iCbO, iCrO ) );
return Err::m_nOK;
}
ErrVal SliceHeaderBase::PredWeight::getOffsets( Double *afOffset)
{
afOffset[0] = (Double) getLumaOffset();
afOffset[1] = (Double) getChromaOffset(0);
afOffset[2] = (Double) getChromaOffset(1);
return Err::m_nOK;
}
ErrVal SliceHeaderBase::PredWeightTable::setOffsets( const Double(*pafOffsets)[3] )
{
ROT( 0 == size() );
for( UInt n = 0; n < size(); n++ )
{
RNOK( get(n).setOffsets( pafOffsets[n] ) );
}
return Err::m_nOK;
}
//TMM_WP
ErrVal
SliceHeaderBase::xReadMVCCompatible( HeaderSymbolReadIf* pcReadIf )
{
Bool bTmp;
RNOK( pcReadIf->getCode( m_uiFrameNum,
getSPS().getLog2MaxFrameNum(), "SH: frame_num" ) );
// if( m_eNalUnitType == NAL_UNIT_CODED_SLICE_IDR_SCALABLE )
if( this->getIDRFlag()) // JVT-W035
{
RNOK( pcReadIf->getUvlc( m_uiIdrPicId, "SH: idr_pic_id" ) );
}
if( getSPS().getPicOrderCntType() == 0 )
{
RNOK( pcReadIf->getCode( m_uiPicOrderCntLsb,
getSPS().getLog2MaxPicOrderCntLsb(), "SH: pic_order_cnt_lsb" ) );
if( getPPS().getPicOrderPresentFlag() /*&& true ! field_pic_flag */ )
{
RNOK( pcReadIf->getSvlc( m_iDeltaPicOrderCntBottom, "SH: delta_pic_order_cnt_bottom" ) );
}
}
if( getSPS().getPicOrderCntType() == 1 && ! getSPS().getDeltaPicOrderAlwaysZeroFlag() )
{
RNOK( pcReadIf->getSvlc( m_aiDeltaPicOrderCnt[0], "SH: delta_pic_order_cnt[0]" ) );
if( getPPS().getPicOrderPresentFlag() /*&& true ! field_pic_flag */ )
{
RNOK( pcReadIf->getSvlc( m_aiDeltaPicOrderCnt[1], "SH: delta_pic_order_cnt[1]" ) );
}
}
//JVT-Q054 Red. Picture {
if ( getPPS().getRedundantPicCntPresentFlag())
{
RNOK( pcReadIf->getUvlc( m_uiRedundantPicCnt, "SH: redundant_pic_cnt") );
}
//JVT-Q054 Red. Picture }
if( m_eSliceType == B_SLICE )
{
RNOK( pcReadIf->getFlag( m_bDirectSpatialMvPredFlag, "SH: direct_spatial_mv_pred_flag" ) );
}
if( m_eSliceType == P_SLICE || m_eSliceType == B_SLICE )
{
RNOK( pcReadIf->getFlag( m_bNumRefIdxActiveOverrideFlag, "SH: num_ref_idx_active_override_flag" ) );
if( m_bNumRefIdxActiveOverrideFlag )
{
RNOK( pcReadIf->getUvlc( m_auiNumRefIdxActive[LIST_0], "SH: num_ref_idx_l0_active_minus1" ) );
m_auiNumRefIdxActive[LIST_0]++;
if( m_eSliceType == B_SLICE )
{
RNOK( pcReadIf->getUvlc( m_auiNumRefIdxActive[LIST_1], "SH: num_ref_idx_l1_active_minus1" ) );
m_auiNumRefIdxActive[LIST_1]++;
}
}
}
#if JMVM_ONLY // JVT-W081
if( this->getAnchorPicFlag())
{
UInt i;
UInt uiNumNonAnchorRefL0 = getSPS().getSpsMVC()->getNumNonAnchorRefsForListX(this->getViewId(), LIST_0);
UInt uiNumNonAnchorRefL1 = getSPS().getSpsMVC()->getNumNonAnchorRefsForListX(this->getViewId(), LIST_1);
if( m_eSliceType == P_SLICE || m_eSliceType == B_SLICE )
{
for(i=0; i<uiNumNonAnchorRefL0; i++)
{
RNOK( pcReadIf->getSvlc( m_iGlobalDisparityL0[i][0], "SH: global_disparity_L0[i][0]" ) );
RNOK( pcReadIf->getSvlc( m_iGlobalDisparityL0[i][1], "SH: global_disparity_L0[i][1]" ) );
}
}
if( m_eSliceType == B_SLICE )
{
for(i=0; i<uiNumNonAnchorRefL1; i++)
{
RNOK( pcReadIf->getSvlc( m_iGlobalDisparityL1[i][0], "SH: global_disparity_L1[i][0]" ) );
RNOK( pcReadIf->getSvlc( m_iGlobalDisparityL1[i][1], "SH: global_disparity_L1[i][1]" ) );
}
}
}
#endif // JVT-W081
if( m_eSliceType == P_SLICE || m_eSliceType == B_SLICE )
{
RNOK( getRplrBuffer( LIST_0 ).read( pcReadIf, getNumRefIdxActive( LIST_0 ) ) );
}
if( m_eSliceType == B_SLICE )
{
RNOK( getRplrBuffer( LIST_1 ).read( pcReadIf, getNumRefIdxActive( LIST_1 ) ) );
}
RNOK( m_acPredWeightTable[LIST_0].init( 64 ) );
RNOK( m_acPredWeightTable[LIST_1].init( 64 ) );
if( ( getPPS().getWeightedPredFlag () && ( m_eSliceType == P_SLICE ) ) ||
( getPPS().getWeightedBiPredIdc() == 1 && ( m_eSliceType == B_SLICE ) ) )
{
RNOK( pcReadIf->getUvlc( m_uiLumaLog2WeightDenom, "PWT: luma_log_weight_denom" ) );
RNOK( pcReadIf->getUvlc( m_uiChromaLog2WeightDenom, "PWT: chroma_log_weight_denom" ) );
ROTR( m_uiLumaLog2WeightDenom > 7, Err::m_nInvalidParameter );
ROTR( m_uiChromaLog2WeightDenom > 7, Err::m_nInvalidParameter );
RNOK( m_acPredWeightTable[LIST_0].initDefaults( m_uiLumaLog2WeightDenom, m_uiChromaLog2WeightDenom ) );
RNOK( m_acPredWeightTable[LIST_0].read( pcReadIf, getNumRefIdxActive( LIST_0 ) ) );
if( m_eSliceType == B_SLICE )
{
RNOK( m_acPredWeightTable[LIST_1].initDefaults( m_uiLumaLog2WeightDenom, m_uiChromaLog2WeightDenom ) );
RNOK( m_acPredWeightTable[LIST_1].read( pcReadIf, getNumRefIdxActive( LIST_1) ) );
}
}
if( getNalRefIdc() )
{
if( isIdrNalUnit() )
{
RNOK( pcReadIf->getFlag( m_bNoOutputOfPriorPicsFlag, "DRPM: no_output_of_prior_pics_flag" ) );
RNOK( pcReadIf->getFlag( bTmp, "DRPM: long_term_reference_flag" ) );
ROT ( bTmp );
}
else
{
RNOK( pcReadIf->getFlag( m_bAdaptiveRefPicBufferingModeFlag, "DRPM: adaptive_ref_pic_buffering_mode_flag" ) );
if( m_bAdaptiveRefPicBufferingModeFlag )
{
RNOK( getMmcoBuffer().read( pcReadIf ) );
}
}
}
if( getPPS().getEntropyCodingModeFlag() && m_eSliceType != I_SLICE )
{
RNOK( pcReadIf->getUvlc( m_uiCabacInitIdc, "SH: cabac_init_idc" ) );
}
RNOK( pcReadIf->getSvlc( m_iSliceQpDelta, "SH: slice_qp_delta" ) );
if( getPPS().getDeblockingFilterParametersPresentFlag() )
{
RNOK( getDeblockingFilterParameter().read( pcReadIf ) );
}
//--ICU/ETRI FMO Implementation
UInt uiSliceGroupChangeCycle;
if( getPPS().getNumSliceGroupsMinus1()> 0 && getPPS().getSliceGroupMapType() >= 3 && getPPS().getSliceGroupMapType() <= 5)
{
UInt pictureSizeInMB = getSPS().getFrameHeightInMbs()*getSPS().getFrameWidthInMbs();
RNOK( pcReadIf->getCode( uiSliceGroupChangeCycle, getLog2MaxSliceGroupChangeCycle(pictureSizeInMB), "SH: slice_group_change_cycle" ) );
setSliceGroupChangeCycle(uiSliceGroupChangeCycle);
}
#if JMVM_ONLY // JVT-U052
if( m_eSliceType == P_SLICE || m_eSliceType == B_SLICE )
RNOK( pcReadIf->getCode( m_uiIcEnable, 1, "SH: ic_enable" ) );
//JVT-Z032
if ( !this->getAnchorPicFlag() && (getSPS().getSpsMVC()->getNumNonAnchorRefsForListX (getViewId(), LIST_0)
|| getSPS().getSpsMVC()->getNumNonAnchorRefsForListX (getViewId(), LIST_1) ) )
RNOK( pcReadIf->getFlag ( m_bMotionSkip, "SH: motion_skip_flag" ) );
#endif
return Err::m_nOK;
}
H264AVC_NAMESPACE_END
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?