diff --git a/source/Lib/DecoderLib/VLCReader.cpp b/source/Lib/DecoderLib/VLCReader.cpp index 81c41b921f15a6cc8240ceebc1310955dd00e582..f358314bfc9a4c3eaa42ae8a31d7b1ee244b2187 100644 --- a/source/Lib/DecoderLib/VLCReader.cpp +++ b/source/Lib/DecoderLib/VLCReader.cpp @@ -2310,7 +2310,7 @@ void HLSyntaxReader::parseVPS(VPS* pcVPS) } #if JVET_R0191_ASPECT3 - CHECK( pcVPS->m_numDpbParams > pcVPS->getNumMultiLayeredOlss(),"The value of vps_num_dpb_params_minus1 shall be in the range of 0 to NumMultiLayerOlss ? 1, inclusive"); + CHECK( pcVPS->m_numDpbParams > pcVPS->getNumMultiLayeredOlss(),"The value of vps_num_dpb_params_minus1 shall be in the range of 0 to NumMultiLayerOlss - 1, inclusive"); std::vector<bool> isDPBParamReferred(pcVPS->m_numDpbParams, false); #endif @@ -2384,7 +2384,7 @@ void HLSyntaxReader::parseVPS(VPS* pcVPS) #if JVET_R0191_ASPECT3 for( int i = 0; i < pcVPS->m_numDpbParams; i++ ) { - CHECK( !isDPBParamReferred[i],"Each dpb_parameters( ) syntax structure in the VPS shall be referred to by at least one value of vps_ols_dpb_params_idx[i] for i in the range of 0 to NumMultiLayerOlss ? 1, inclusive"); + CHECK( !isDPBParamReferred[i],"Each dpb_parameters( ) syntax structure in the VPS shall be referred to by at least one value of vps_ols_dpb_params_idx[i] for i in the range of 0 to NumMultiLayerOlss - 1, inclusive"); } #endif if (!pcVPS->getEachLayerIsAnOlsFlag()) @@ -2405,7 +2405,7 @@ void HLSyntaxReader::parseVPS(VPS* pcVPS) READ_UVLC(uiCode, "num_ols_hrd_params_minus1"); pcVPS->setNumOlsHrdParamsMinus1(uiCode); #if JVET_R0191_ASPECT3 - CHECK( uiCode >= pcVPS->getNumMultiLayeredOlss(),"The value of vps_num_ols_hrd_params_minus1 shall be in the range of 0 to NumMultiLayerOlss ? 1, inclusive"); + CHECK( uiCode >= pcVPS->getNumMultiLayeredOlss(),"The value of vps_num_ols_hrd_params_minus1 shall be in the range of 0 to NumMultiLayerOlss - 1, inclusive"); std::vector<bool> isHRDParamReferred( uiCode + 1, false); #else CHECK(uiCode >= pcVPS->getTotalNumOLSs(),"The value of num_ols_hrd_params_minus1 shall be in the range of 0 to TotalNumOlss - 1, inclusive"); @@ -2458,7 +2458,7 @@ void HLSyntaxReader::parseVPS(VPS* pcVPS) #if JVET_R0191_ASPECT3 for( int i = 0; i <= pcVPS->getNumOlsHrdParamsMinus1(); i++ ) { - CHECK( !isHRDParamReferred[i], "Each ols_hrd_parameters( ) syntax structure in the VPS shall be referred to by at least one value of vps_ols_hrd_idx[ i ] for i in the range of 1 to NumMultiLayerOlss ? 1, inclusive"); + CHECK( !isHRDParamReferred[i], "Each ols_hrd_parameters( ) syntax structure in the VPS shall be referred to by at least one value of vps_ols_hrd_idx[ i ] for i in the range of 1 to NumMultiLayerOlss - 1, inclusive"); } #endif } diff --git a/source/Lib/EncoderLib/EncLib.cpp b/source/Lib/EncoderLib/EncLib.cpp index f3712e73bcd3f8d7dc8397be85c34bece3a43dec..0739b1ea65629388402675cc535b1f8ae3e0b37d 100644 --- a/source/Lib/EncoderLib/EncLib.cpp +++ b/source/Lib/EncoderLib/EncLib.cpp @@ -985,10 +985,10 @@ void EncLib::xInitVPS( const SPS& sps ) m_vps->deriveOutputLayerSets(); m_vps->deriveTargetOutputLayerSet( m_vps->m_targetOlsIdx ); - // number of the DPB parameters is set equal to the number of OLS - if( !m_vps->getAllIndependentLayersFlag() ) + // number of the DPB parameters is set equal to the number of OLS containing multi layers + if( !m_vps->getEachLayerIsAnOlsFlag() ) { - m_vps->m_numDpbParams = m_vps->m_totalNumOLSs; + m_vps->m_numDpbParams = m_vps->getNumMultiLayeredOlss(); } if( m_vps->m_dpbParameters.size() != m_vps->m_numDpbParams )