From d1b00c1e8c38832863f608d333697705197f3c9a Mon Sep 17 00:00:00 2001 From: Karsten Suehring <karsten.suehring@hhi.fraunhofer.de> Date: Wed, 21 Oct 2020 17:10:35 +0200 Subject: [PATCH] remove macro JVET_S0113_S0195_GCI --- source/App/EncoderApp/EncApp.cpp | 8 -------- source/App/EncoderApp/EncAppCfg.cpp | 4 ---- source/App/EncoderApp/EncAppCfg.h | 4 ---- source/Lib/CommonLib/Slice.h | 13 ------------- source/Lib/CommonLib/TypeDef.h | 1 - source/Lib/DecoderLib/DecLib.cpp | 7 ------- source/Lib/DecoderLib/VLCReader.cpp | 16 ---------------- source/Lib/EncoderLib/EncCfg.h | 9 --------- source/Lib/EncoderLib/EncLib.cpp | 4 ---- source/Lib/EncoderLib/VLCWriter.cpp | 6 ------ 10 files changed, 72 deletions(-) diff --git a/source/App/EncoderApp/EncApp.cpp b/source/App/EncoderApp/EncApp.cpp index 151fec1f7..1bcee0058 100644 --- a/source/App/EncoderApp/EncApp.cpp +++ b/source/App/EncoderApp/EncApp.cpp @@ -264,7 +264,6 @@ void EncApp::xInitLibCfg() m_cEncLib.setOneTilePerPicConstraintFlag(m_oneTilePerPicConstraintFlag); m_cEncLib.setPicHeaderInSliceHeaderConstraintFlag(m_picHeaderInSliceHeaderConstraintFlag); m_cEncLib.setOneSlicePerPicConstraintFlag(m_oneSlicePerPicConstraintFlag); -#if JVET_S0113_S0195_GCI m_cEncLib.setNoIdrRplConstraintFlag(m_noIdrRplConstraintFlag); CHECK(m_noIdrRplConstraintFlag&& m_idrRefParamList, "IDR RPL shall be deactivated when gci_no_idr_rpl_constraint_flag equal to 1"); @@ -276,9 +275,6 @@ void EncApp::xInitLibCfg() m_cEncLib.setNoSubpicInfoConstraintFlag(m_noSubpicInfoConstraintFlag); CHECK(m_noSubpicInfoConstraintFlag&& m_subPicInfoPresentFlag, "Subpicture information shall not present when gci_no_subpic_info_constraint_flag equal to 1"); -#else - m_cEncLib.setOneSubpicPerPicConstraintFlag(m_oneSubpicPerPicConstraintFlag); -#endif m_cEncLib.setOnePictureOnlyConstraintFlag(m_onePictureOnlyConstraintFlag); m_cEncLib.setIntraOnlyConstraintFlag(m_intraOnlyConstraintFlag); m_cEncLib.setNoIdrConstraintFlag(m_noIdrConstraintFlag); @@ -453,14 +449,10 @@ void EncApp::xInitLibCfg() m_cEncLib.setOneTilePerPicConstraintFlag(false); m_cEncLib.setPicHeaderInSliceHeaderConstraintFlag(false); m_cEncLib.setOneSlicePerPicConstraintFlag(false); -#if JVET_S0113_S0195_GCI m_cEncLib.setNoIdrRplConstraintFlag(false); m_cEncLib.setNoRectSliceConstraintFlag(false); m_cEncLib.setOneSlicePerSubpicConstraintFlag(false); m_cEncLib.setNoSubpicInfoConstraintFlag(false); -#else - m_cEncLib.setOneSubpicPerPicConstraintFlag(false); -#endif m_cEncLib.setOnePictureOnlyConstraintFlag(false); m_cEncLib.setIntraOnlyConstraintFlag(false); m_cEncLib.setMaxBitDepthConstraintIdc(16); diff --git a/source/App/EncoderApp/EncAppCfg.cpp b/source/App/EncoderApp/EncAppCfg.cpp index 740b86c66..eda02433c 100644 --- a/source/App/EncoderApp/EncAppCfg.cpp +++ b/source/App/EncoderApp/EncAppCfg.cpp @@ -796,14 +796,10 @@ bool EncAppCfg::parseCfg( int argc, char* argv[] ) ("OneTilePerPicConstraintFlag", m_oneTilePerPicConstraintFlag, false, "Indicate that each picture shall contain only one tile") ("PicHeaderInSliceHeaderConstraintFlag", m_picHeaderInSliceHeaderConstraintFlag, false, "Indicate that picture header is present in slice header") ("OneSlicePerPicConstraintFlag", m_oneSlicePerPicConstraintFlag, false, "Indicate that each picture shall contain only one slice") -#if JVET_S0113_S0195_GCI ("NoIdrRplConstraintFlag", m_noIdrRplConstraintFlag, false, "Indicate that RPL is not present in SH of IDR slices") ("NoRectSliceConstraintFlag", m_noRectSliceConstraintFlag, false, "Indicate that rectagular slice is deactivated") ("OneSlicePerSubpicConstraintFlag", m_oneSlicePerSubpicConstraintFlag, false, "Indicate that each subpicture shall contain only one slice") ("NoSubpicInfoConstraintFlag", m_noSubpicInfoConstraintFlag, false, "Indicate that subpicture information is not present") -#else - ("OneSubpicPerPicConstraintFlag", m_oneSubpicPerPicConstraintFlag, false, "Indicate that each picture shall contain only one subpicture") -#endif ("MaxLog2CtuSizeConstraintIdc", m_maxLog2CtuSizeConstraintIdc, 8, "Indicate that Log2CtuSize shall be in the range of 0 to m_maxLog2CtuSizeConstraintIdc") ("NoPartitionConstraintsOverrideConstraintFlag", m_noPartitionConstraintsOverrideConstraintFlag, false, "Indicate that Partition Override is deactivated") ("MttConstraintFlag", m_noMttConstraintFlag, false, "Indicate that Mtt is deactivated") diff --git a/source/App/EncoderApp/EncAppCfg.h b/source/App/EncoderApp/EncAppCfg.h index cf876d36a..e0197f24e 100644 --- a/source/App/EncoderApp/EncAppCfg.h +++ b/source/App/EncoderApp/EncAppCfg.h @@ -210,14 +210,10 @@ protected: bool m_oneTilePerPicConstraintFlag; bool m_picHeaderInSliceHeaderConstraintFlag; bool m_oneSlicePerPicConstraintFlag; -#if JVET_S0113_S0195_GCI bool m_noIdrRplConstraintFlag; bool m_noRectSliceConstraintFlag; bool m_oneSlicePerSubpicConstraintFlag; bool m_noSubpicInfoConstraintFlag; -#else - bool m_oneSubpicPerPicConstraintFlag; -#endif // coding structure int m_iIntraPeriod; ///< period of I-slice (random access period) int m_iDecodingRefreshType; ///< random access type diff --git a/source/Lib/CommonLib/Slice.h b/source/Lib/CommonLib/Slice.h index 6e152285f..aa5a4f0ba 100644 --- a/source/Lib/CommonLib/Slice.h +++ b/source/Lib/CommonLib/Slice.h @@ -243,14 +243,10 @@ class ConstraintInfo bool m_oneTilePerPicConstraintFlag; bool m_picHeaderInSliceHeaderConstraintFlag; bool m_oneSlicePerPicConstraintFlag; -#if JVET_S0113_S0195_GCI bool m_noIdrRplConstraintFlag; bool m_noRectSliceConstraintFlag; bool m_oneSlicePerSubpicConstraintFlag; bool m_noSubpicInfoConstraintFlag; -#else - bool m_oneSubpicPerPicConstraintFlag; -#endif bool m_intraOnlyConstraintFlag; uint32_t m_maxBitDepthConstraintIdc; int m_maxChromaFormatConstraintIdc; @@ -321,14 +317,10 @@ public: , m_oneTilePerPicConstraintFlag(false) , m_picHeaderInSliceHeaderConstraintFlag(false) , m_oneSlicePerPicConstraintFlag(false) -#if JVET_S0113_S0195_GCI , m_noIdrRplConstraintFlag(false) , m_noRectSliceConstraintFlag(false) , m_oneSlicePerSubpicConstraintFlag(false) , m_noSubpicInfoConstraintFlag(false) -#else - , m_oneSubpicPerPicConstraintFlag(false) -#endif , m_intraOnlyConstraintFlag (false) , m_maxBitDepthConstraintIdc ( 16) , m_maxChromaFormatConstraintIdc(CHROMA_444) @@ -417,7 +409,6 @@ public: bool getOneSlicePerPicConstraintFlag() const { return m_oneSlicePerPicConstraintFlag; } void setOneSlicePerPicConstraintFlag(bool b) { m_oneSlicePerPicConstraintFlag = b; } -#if JVET_S0113_S0195_GCI bool getNoIdrRplConstraintFlag() const { return m_noIdrRplConstraintFlag; } void setNoIdrRplConstraintFlag(bool b) { m_noIdrRplConstraintFlag = b; } @@ -429,10 +420,6 @@ public: bool getNoSubpicInfoConstraintFlag() const { return m_noSubpicInfoConstraintFlag; } void setNoSubpicInfoConstraintFlag(bool b) { m_noSubpicInfoConstraintFlag = b; } -#else - bool getOneSubpicPerPicConstraintFlag() const { return m_oneSubpicPerPicConstraintFlag; } - void setOneSubpicPerPicConstraintFlag(bool b) { m_oneSubpicPerPicConstraintFlag = b; } -#endif bool getIntraOnlyConstraintFlag() const { return m_intraOnlyConstraintFlag; } void setIntraOnlyConstraintFlag(bool b) { m_intraOnlyConstraintFlag = b; } diff --git a/source/Lib/CommonLib/TypeDef.h b/source/Lib/CommonLib/TypeDef.h index 90a406c03..79aa68e3d 100644 --- a/source/Lib/CommonLib/TypeDef.h +++ b/source/Lib/CommonLib/TypeDef.h @@ -120,7 +120,6 @@ // Remove all constraints that require GCI fields to be equal to a value that imposes a constraint -#define JVET_S0113_S0195_GCI 1 // JVET-S0113: no_rectangular_slice_constraint_flag to constrain pps_rect_slice_flag // one_slice_per_subpicture_constraint_flag to constrain pps_single_slice_per_subpic_flag // JVET-S0195: replace one_subpic_per_pic_constraint_flag with no_subpic_info_constraint_flag and its semantics // add no_idr_rpl_constraint_flag diff --git a/source/Lib/DecoderLib/DecLib.cpp b/source/Lib/DecoderLib/DecLib.cpp index 1de161df5..e5eb2840c 100644 --- a/source/Lib/DecoderLib/DecLib.cpp +++ b/source/Lib/DecoderLib/DecLib.cpp @@ -1826,7 +1826,6 @@ void DecLib::xCheckParameterSetConstraints(const int layerId) } #endif -#if JVET_S0113_S0195_GCI if (sps->getProfileTierLevel()->getConstraintInfo()->getNoIdrRplConstraintFlag()) { CHECK(sps->getIDRRefParamListPresent(), "When gci_no_idr_rpl_constraint_flag equal to 1 , the value of sps_idr_rpl_present_flag shall be equal to 0") @@ -1851,12 +1850,6 @@ void DecLib::xCheckParameterSetConstraints(const int layerId) { CHECK(sps->getSubPicInfoPresentFlag(), "When gci_no_subpic_info_constraint_flag is equal to 1, the value of sps_subpic_info_present_flag shall be equal to 0") } -#else - if (sps->getProfileTierLevel()->getConstraintInfo()->getOneSubpicPerPicConstraintFlag()) - { - CHECK(sps->getNumSubPics() != 1, "When one_subpic_per_pic_constraint_flag is equal to 1, the value of sps_num_subpics_minus1 shall be equal to 0") - } -#endif if (sps->getProfileTierLevel()->getConstraintInfo()->getNoMttConstraintFlag()) { CHECK((sps->getMaxMTTHierarchyDepth() || sps->getMaxMTTHierarchyDepthI() || sps->getMaxMTTHierarchyDepthIChroma()), "When gci_no_mtt_constraint_flag is equal to 1, the values of sps_max_mtt_hierarchy_depth_intra_slice_luma, sps_max_mtt_hierarchy_depth_inter_slice and sps_max_mtt_hierarchy_depth_intra_slice_chroma shall be equal to 0"); diff --git a/source/Lib/DecoderLib/VLCReader.cpp b/source/Lib/DecoderLib/VLCReader.cpp index 4ea01ba16..7ceb3e85d 100644 --- a/source/Lib/DecoderLib/VLCReader.cpp +++ b/source/Lib/DecoderLib/VLCReader.cpp @@ -1384,23 +1384,15 @@ void HLSyntaxReader::parseSPS(SPS* pcSPS) READ_FLAG( uiCode, "sps_subpic_info_present_flag" ); pcSPS->setSubPicInfoPresentFlag(uiCode); -#if JVET_S0113_S0195_GCI if (pcSPS->getProfileTierLevel()->getConstraintInfo()->getNoSubpicInfoConstraintFlag()) { CHECK(uiCode != 0, "When gci_no_subpic_info_constraint_flag is equal to 1, the value of sps_subpic_info_present_flag shall be equal to 0"); } -#endif if (pcSPS->getSubPicInfoPresentFlag()) { READ_UVLC(uiCode, "sps_num_subpics_minus1"); pcSPS->setNumSubPics(uiCode + 1); CHECK(uiCode > (pcSPS->getMaxPicWidthInLumaSamples() / (1 << pcSPS->getCTUSize())) * (pcSPS->getMaxPicHeightInLumaSamples() / (1 << pcSPS->getCTUSize())) - 1, "Invalid sps_num_subpics_minus1 value"); -#if !JVET_S0113_S0195_GCI - if (pcSPS->getProfileTierLevel()->getConstraintInfo()->getOneSubpicPerPicConstraintFlag()) - { - CHECK(uiCode != 0, "When one_subpic_per_pic_constraint_flag is equal to 1, each picture shall contain only one subpicture"); - } -#endif if( pcSPS->getNumSubPics() == 1 ) { pcSPS->setSubPicCtuTopLeftX( 0, 0 ); @@ -1734,12 +1726,10 @@ void HLSyntaxReader::parseSPS(SPS* pcSPS) pcSPS->setInterLayerPresentFlag(0); } READ_FLAG( uiCode, "sps_idr_rpl_present_flag" ); pcSPS->setIDRRefParamListPresent( (bool) uiCode ); -#if JVET_S0113_S0195_GCI if (pcSPS->getProfileTierLevel()->getConstraintInfo()->getNoIdrRplConstraintFlag()) { CHECK(uiCode != 0, "When gci_no_idr_rpl_constraint_flag equal to 1 , the value of sps_idr_rpl_present_flag shall be equal to 0"); } -#endif READ_FLAG(uiCode, "sps_rpl1_same_as_rpl0_flag"); pcSPS->setRPL1CopyFromRPL0Flag(uiCode); @@ -4496,19 +4486,13 @@ void HLSyntaxReader::parseConstraintInfo(ConstraintInfo *cinfo) READ_FLAG(symbol, "gci_no_ref_pic_resampling_constraint_flag"); cinfo->setNoRprConstraintFlag(symbol ? true : false); #endif READ_FLAG(symbol, "no_res_change_in_clvs_constraint_flag" ); cinfo->setNoResChangeInClvsConstraintFlag(symbol ? true : false); -#if JVET_S0113_S0195_GCI READ_FLAG(symbol, "gci_no_idr_rpl_constraint_flag" ); cinfo->setNoIdrRplConstraintFlag(symbol ? true : false); -#endif READ_FLAG(symbol, "one_tile_per_pic_constraint_flag" ); cinfo->setOneTilePerPicConstraintFlag(symbol ? true : false); READ_FLAG(symbol, "pic_header_in_slice_header_constraint_flag"); cinfo->setPicHeaderInSliceHeaderConstraintFlag(symbol ? true : false); READ_FLAG(symbol, "one_slice_per_pic_constraint_flag" ); cinfo->setOneSlicePerPicConstraintFlag(symbol ? true : false); -#if JVET_S0113_S0195_GCI READ_FLAG(symbol, "gci_no_rectangular_slice_constraint_flag" ); cinfo->setNoRectSliceConstraintFlag(symbol ? true : false); READ_FLAG(symbol, "gci_one_slice_per_subpic_constraint_flag" ); cinfo->setOneSlicePerSubpicConstraintFlag(symbol ? true : false); READ_FLAG(symbol, "gci_no_subpic_info_constraint_flag" ); cinfo->setNoSubpicInfoConstraintFlag(symbol ? true : false); -#else - READ_FLAG(symbol, "one_subpic_per_pic_constraint_flag" ); cinfo->setOneSubpicPerPicConstraintFlag(symbol ? true : false); -#endif READ_FLAG(symbol, "gci_no_mtt_constraint_flag" ); cinfo->setNoMttConstraintFlag(symbol > 0 ? true : false); READ_FLAG(symbol, "no_qtbtt_dual_tree_intra_constraint_flag" ); cinfo->setNoQtbttDualTreeIntraConstraintFlag(symbol > 0 ? true : false); READ_CODE(2, symbol, "gci_three_minus_max_log2_ctu_size_constraint_idc" ); cinfo->setMaxLog2CtuSizeConstraintIdc(((3-symbol)+5)); diff --git a/source/Lib/EncoderLib/EncCfg.h b/source/Lib/EncoderLib/EncCfg.h index 873a6a6fb..f691e4d41 100644 --- a/source/Lib/EncoderLib/EncCfg.h +++ b/source/Lib/EncoderLib/EncCfg.h @@ -250,14 +250,10 @@ protected: bool m_oneTilePerPicConstraintFlag; bool m_picHeaderInSliceHeaderConstraintFlag; bool m_oneSlicePerPicConstraintFlag; -#if JVET_S0113_S0195_GCI bool m_noIdrRplConstraintFlag; bool m_noRectSliceConstraintFlag; bool m_oneSlicePerSubpicConstraintFlag; bool m_noSubpicInfoConstraintFlag; -#else - bool m_oneSubpicPerPicConstraintFlag; -#endif bool m_intraOnlyConstraintFlag; //====== Coding Structure ======== @@ -1864,7 +1860,6 @@ public: bool getOneSlicePerPicConstraintFlag() const { return m_oneSlicePerPicConstraintFlag; } void setOneSlicePerPicConstraintFlag(bool b) { m_oneSlicePerPicConstraintFlag = b; } -#if JVET_S0113_S0195_GCI bool getNoIdrRplConstraintFlag() const { return m_noIdrRplConstraintFlag; } void setNoIdrRplConstraintFlag(bool b) { m_noIdrRplConstraintFlag = b; } @@ -1876,10 +1871,6 @@ public: bool getNoSubpicInfoConstraintFlag() const { return m_noSubpicInfoConstraintFlag; } void setNoSubpicInfoConstraintFlag(bool b) { m_noSubpicInfoConstraintFlag = b; } -#else - bool getOneSubpicPerPicConstraintFlag() const { return m_oneSubpicPerPicConstraintFlag; } - void setOneSubpicPerPicConstraintFlag(bool b) { m_oneSubpicPerPicConstraintFlag = b; } -#endif void setSummaryOutFilename(const std::string &s) { m_summaryOutFilename = s; } const std::string& getSummaryOutFilename() const { return m_summaryOutFilename; } diff --git a/source/Lib/EncoderLib/EncLib.cpp b/source/Lib/EncoderLib/EncLib.cpp index 5ec799dce..d71af285c 100644 --- a/source/Lib/EncoderLib/EncLib.cpp +++ b/source/Lib/EncoderLib/EncLib.cpp @@ -1174,14 +1174,10 @@ void EncLib::xInitSPS( SPS& sps ) cinfo->setOneTilePerPicConstraintFlag(m_oneTilePerPicConstraintFlag); cinfo->setPicHeaderInSliceHeaderConstraintFlag(m_picHeaderInSliceHeaderConstraintFlag); cinfo->setOneSlicePerPicConstraintFlag(m_oneSlicePerPicConstraintFlag); -#if JVET_S0113_S0195_GCI cinfo->setNoIdrRplConstraintFlag(m_noIdrRplConstraintFlag); cinfo->setNoRectSliceConstraintFlag(m_noRectSliceConstraintFlag); cinfo->setOneSlicePerSubpicConstraintFlag(m_oneSlicePerSubpicConstraintFlag); cinfo->setNoSubpicInfoConstraintFlag(m_noSubpicInfoConstraintFlag); -#else - cinfo->setOneSubpicPerPicConstraintFlag(m_oneSubpicPerPicConstraintFlag); -#endif cinfo->setOnePictureOnlyConstraintFlag(m_onePictureOnlyConstraintFlag); cinfo->setIntraOnlyConstraintFlag (m_intraOnlyConstraintFlag); cinfo->setMaxBitDepthConstraintIdc (m_maxBitDepthConstraintIdc); diff --git a/source/Lib/EncoderLib/VLCWriter.cpp b/source/Lib/EncoderLib/VLCWriter.cpp index ef993e1f5..cfb063877 100644 --- a/source/Lib/EncoderLib/VLCWriter.cpp +++ b/source/Lib/EncoderLib/VLCWriter.cpp @@ -2651,19 +2651,13 @@ void HLSWriter::codeConstraintInfo ( const ConstraintInfo* cinfo ) WRITE_FLAG(cinfo->getNoRprConstraintFlag(), "gci_no_ref_pic_resampling_constraint_flag"); #endif WRITE_FLAG(cinfo->getNoResChangeInClvsConstraintFlag(), "no_res_change_in_clvs_constraint_flag"); -#if JVET_S0113_S0195_GCI WRITE_FLAG(cinfo->getNoIdrRplConstraintFlag(), "gci_no_idr_rpl_constraint_flag"); -#endif WRITE_FLAG(cinfo->getOneTilePerPicConstraintFlag(), "one_tile_per_pic_constraint_flag"); WRITE_FLAG(cinfo->getPicHeaderInSliceHeaderConstraintFlag(), "pic_header_in_slice_header_constraint_flag"); WRITE_FLAG(cinfo->getOneSlicePerPicConstraintFlag(), "one_slice_per_pic_constraint_flag"); -#if JVET_S0113_S0195_GCI WRITE_FLAG(cinfo->getNoRectSliceConstraintFlag(), "gci_no_rectangular_slice_constraint_flag"); WRITE_FLAG(cinfo->getOneSlicePerSubpicConstraintFlag(), "gci_one_slice_per_subpic_constraint_flag"); WRITE_FLAG(cinfo->getNoSubpicInfoConstraintFlag(), "gci_no_subpic_info_constraint_flag"); -#else - WRITE_FLAG(cinfo->getOneSubpicPerPicConstraintFlag(), "one_subpic_per_pic_constraint_flag"); -#endif WRITE_FLAG(cinfo->getNoMttConstraintFlag() ? 1 : 0, "gci_no_mtt_constraint_flag"); WRITE_FLAG(cinfo->getNoQtbttDualTreeIntraConstraintFlag() ? 1 : 0, "no_qtbtt_dual_tree_intra_constraint_flag"); WRITE_CODE(3-(cinfo->getMaxLog2CtuSizeConstraintIdc()-5), 2, "gci_three_minus_max_log2_ctu_size_constraint_idc" ); -- GitLab