diff --git a/source/Lib/CommonLib/TypeDef.h b/source/Lib/CommonLib/TypeDef.h index 8c101eb5aa6cff9fc4283b398ef5a0f13c0508e2..00064bcc848224586189b7a6588161500135daa0 100644 --- a/source/Lib/CommonLib/TypeDef.h +++ b/source/Lib/CommonLib/TypeDef.h @@ -51,6 +51,7 @@ #include <cassert> //########### place macros to be removed in next cycle below this line ############### +#define JVET_S0219_ASPECT2_CHANGE_ORDER_APS_PARAMS_TYPE 1 // JVET-S0219 aspect2: change the order to put the aps_params_type before the aps_adaptation_parameter_set_id. #define JVET_S0081_NON_REFERENCED_PIC 1 // JVET-S0081: exclude non-referenced picture to be used as prevTid0 picture diff --git a/source/Lib/DecoderLib/VLCReader.cpp b/source/Lib/DecoderLib/VLCReader.cpp index d53a40127368eead0e7810ec4b3c8e3fa4170137..32dce813f7106f67573819ac0d6a2225ddef550e 100644 --- a/source/Lib/DecoderLib/VLCReader.cpp +++ b/source/Lib/DecoderLib/VLCReader.cpp @@ -913,13 +913,19 @@ void HLSyntaxReader::parseAPS( APS* aps ) #endif uint32_t code; +#if JVET_S0219_ASPECT2_CHANGE_ORDER_APS_PARAMS_TYPE + READ_CODE(3, code, "aps_params_type"); + aps->setAPSType(ApsType(code)); READ_CODE(5, code, "adaptation_parameter_set_id"); aps->setAPSId(code); +#else + READ_CODE(5, code, "adaptation_parameter_set_id"); + aps->setAPSId(code); READ_CODE(3, code, "aps_params_type"); aps->setAPSType( ApsType(code) ); - +#endif #if JVET_R0433 uint32_t codeApsChromaPresentFlag; READ_FLAG(codeApsChromaPresentFlag, "aps_chroma_present_flag"); diff --git a/source/Lib/EncoderLib/VLCWriter.cpp b/source/Lib/EncoderLib/VLCWriter.cpp index bf9ab2d3474b8438b9c24aebc45da0bee51c7522..02d20201ac5693782ec37c1a07512b05801f2c8a 100644 --- a/source/Lib/EncoderLib/VLCWriter.cpp +++ b/source/Lib/EncoderLib/VLCWriter.cpp @@ -515,8 +515,13 @@ void HLSWriter::codeAPS( APS* pcAPS ) xTraceAPSHeader(); #endif +#if JVET_S0219_ASPECT2_CHANGE_ORDER_APS_PARAMS_TYPE + WRITE_CODE((int)pcAPS->getAPSType(), 3, "aps_params_type"); + WRITE_CODE(pcAPS->getAPSId(), 5, "adaptation_parameter_set_id"); +#else WRITE_CODE(pcAPS->getAPSId(), 5, "adaptation_parameter_set_id"); WRITE_CODE( (int)pcAPS->getAPSType(), 3, "aps_params_type" ); +#endif #if JVET_R0433 WRITE_FLAG(pcAPS->chromaPresentFlag, "aps_chroma_present_flag"); #endif