diff --git a/source/Lib/CommonLib/Slice.cpp b/source/Lib/CommonLib/Slice.cpp index 9a4a634f8c68ff97ceaddf36b34537746feeaf07..d3be888c8f20238a3a604f8b35e5068d37e7fc98 100644 --- a/source/Lib/CommonLib/Slice.cpp +++ b/source/Lib/CommonLib/Slice.cpp @@ -57,7 +57,9 @@ Slice::Slice() , m_prevIRAPSubpicType ( NAL_UNIT_INVALID ) , m_rpl0Idx ( -1 ) , m_rpl1Idx ( -1 ) +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE , m_colourPlaneId ( 0 ) +#endif , m_eNalUnitType ( NAL_UNIT_CODED_SLICE_IDR_W_RADL ) , m_pictureHeaderInSliceHeader ( false ) , m_eSliceType ( I_SLICE ) @@ -161,7 +163,9 @@ void Slice::initSlice() m_aiNumRefIdx[i] = 0; } m_colFromL0Flag = true; +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE m_colourPlaneId = 0; +#endif m_colRefIdx = 0; m_lmcsEnabledFlag = 0; m_explicitScalingListUsed = 0; @@ -2691,7 +2695,9 @@ SPS::SPS() , m_SBT ( false ) , m_ISP ( false ) , m_chromaFormatIdc (CHROMA_420) +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE , m_separateColourPlaneFlag ( 0 ) +#endif , m_uiMaxTLayers ( 1) , m_ptlDpbHrdParamsPresentFlag (1) , m_SubLayerDpbParamsFlag (0) diff --git a/source/Lib/CommonLib/Slice.h b/source/Lib/CommonLib/Slice.h index e1271eb66f45d5e8bd3dfdf8b49a788ff73d67cb..43b5355996f4589fc67341b0bd587c84143f0111 100644 --- a/source/Lib/CommonLib/Slice.h +++ b/source/Lib/CommonLib/Slice.h @@ -1287,7 +1287,9 @@ private: bool m_SBT; bool m_ISP; ChromaFormat m_chromaFormatIdc; +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE bool m_separateColourPlaneFlag; //!< separate colour plane flag +#endif uint32_t m_uiMaxTLayers; // maximum number of temporal layers @@ -1464,8 +1466,10 @@ public: int getLayerId() const { return m_layerId; } ChromaFormat getChromaFormatIdc () const { return m_chromaFormatIdc; } void setChromaFormatIdc (ChromaFormat i) { m_chromaFormatIdc = i; } +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE void setSeparateColourPlaneFlag ( bool b ) { m_separateColourPlaneFlag = b; } bool getSeparateColourPlaneFlag () const { return m_separateColourPlaneFlag; } +#endif static int getWinUnitX (int chromaFormatIdc) { CHECK(chromaFormatIdc < 0 || chromaFormatIdc >= NUM_CHROMA_FORMAT, "Invalid chroma format parameter"); return m_winUnitX[chromaFormatIdc]; } static int getWinUnitY (int chromaFormatIdc) { CHECK(chromaFormatIdc < 0 || chromaFormatIdc >= NUM_CHROMA_FORMAT, "Invalid chroma format parameter"); return m_winUnitY[chromaFormatIdc]; } @@ -2541,7 +2545,9 @@ private: ReferencePictureList m_localRPL1; //< RPL for L1 when present in slice header int m_rpl0Idx; //< index of used RPL in the SPS or -1 for local RPL in the slice header int m_rpl1Idx; //< index of used RPL in the SPS or -1 for local RPL in the slice header +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE int m_colourPlaneId; //!< 4:4:4 colour plane ID +#endif NalUnitType m_eNalUnitType; ///< Nal unit type for the slice bool m_pictureHeaderInSliceHeader; uint32_t m_nuhLayerId; ///< Nal unit layer id @@ -2790,8 +2796,10 @@ public: bool isPocRestrictedByDRAP( int poc, bool precedingDRAPinDecodingOrder ); bool isPOCInRefPicList( const ReferencePictureList *rpl, int poc ); void checkConformanceForDRAP( uint32_t temporalId ); +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE void setColourPlaneId( int id ) { m_colourPlaneId = id; } int getColourPlaneId() const { return m_colourPlaneId; } +#endif void setLambdas( const double lambdas[MAX_NUM_COMPONENT] ) { for (int component = 0; component < MAX_NUM_COMPONENT; component++) m_lambdas[component] = lambdas[component]; } const double* getLambdas() const { return m_lambdas; } diff --git a/source/Lib/CommonLib/TypeDef.h b/source/Lib/CommonLib/TypeDef.h index 35a3f6b4aa021f22b9af424378daf67fa368657e..e0b3985b03d5b626a86ab4ec86d2aa37fca90f79 100644 --- a/source/Lib/CommonLib/TypeDef.h +++ b/source/Lib/CommonLib/TypeDef.h @@ -59,6 +59,7 @@ #define JVET_S0221_NUM_VB_CHECK 1 // JVET_S0221: Constraints on the number of virtual boundaries +#define JVET_S0052_RM_SEPARATE_COLOUR_PLANE 1 // JVET-S0052: Remove separate colour plane coding from VVC version 1 //########### place macros to be be kept below this line ############### #define JVET_S0257_DUMP_360SEI_MESSAGE 1 // Software support of 360 SEI messages diff --git a/source/Lib/DecoderLib/VLCReader.cpp b/source/Lib/DecoderLib/VLCReader.cpp index f09a3228d6c0e5b8544e7f434124123fb37ee768..292ae6e91adad6b6bf560140f0513d8abf8fc61f 100644 --- a/source/Lib/DecoderLib/VLCReader.cpp +++ b/source/Lib/DecoderLib/VLCReader.cpp @@ -1322,11 +1322,13 @@ void HLSyntaxReader::parseSPS(SPS* pcSPS) pcSPS->setGDREnabledFlag(uiCode); READ_CODE(2, uiCode, "chroma_format_idc"); pcSPS->setChromaFormatIdc( ChromaFormat(uiCode) ); +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE if( pcSPS->getChromaFormatIdc() == CHROMA_444 ) { READ_FLAG( uiCode, "separate_colour_plane_flag"); CHECK(uiCode != 0, "separate_colour_plane_flag shall be equal to 0"); pcSPS->setSeparateColourPlaneFlag( uiCode != 0 ); } +#endif READ_FLAG(uiCode, "ref_pic_resampling_enabled_flag"); pcSPS->setRprEnabledFlag(uiCode); if (uiCode) @@ -1354,7 +1356,9 @@ void HLSyntaxReader::parseSPS(SPS* pcSPS) READ_UVLC(uiCode, "sps_conf_win_top_offset"); conf.setWindowTopOffset(uiCode); READ_UVLC(uiCode, "sps_conf_win_bottom_offset"); conf.setWindowBottomOffset(uiCode); } +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE const uint32_t chromaArrayType = (int) pcSPS->getSeparateColourPlaneFlag() ? 0 : pcSPS->getChromaFormatIdc(); +#endif READ_CODE(2, uiCode, "sps_log2_ctu_size_minus5"); pcSPS->setCTUSize(1 << (uiCode + 5)); CHECK(uiCode > 2, "sps_log2_ctu_size_minus5 must be less than or equal to 2"); @@ -1632,7 +1636,11 @@ void HLSyntaxReader::parseSPS(SPS* pcSPS) READ_FLAG(uiCode, "sps_lfnst_enabled_flag"); pcSPS->setUseLFNST(uiCode != 0); #endif +#if JVET_S0052_RM_SEPARATE_COLOUR_PLANE + if (pcSPS->getChromaFormatIdc() != CHROMA_400) +#else if (chromaArrayType != CHROMA_400) +#endif { READ_FLAG(uiCode, "sps_joint_cbcr_enabled_flag"); pcSPS->setJointCbCrEnabledFlag(uiCode ? true : false); ChromaQpMappingTableParams chromaQpMappingTableParams; @@ -1868,7 +1876,11 @@ void HLSyntaxReader::parseSPS(SPS* pcSPS) } #endif READ_FLAG( uiCode, "sps_palette_enabled_flag"); pcSPS->setPLTMode ( uiCode != 0 ); +#if JVET_S0052_RM_SEPARATE_COLOUR_PLANE + if (pcSPS->getChromaFormatIdc() == CHROMA_444 && pcSPS->getLog2MaxTbSize() != 6) +#else if (chromaArrayType == CHROMA_444 && pcSPS->getLog2MaxTbSize() != 6) +#endif { READ_FLAG(uiCode, "sps_act_enabled_flag"); pcSPS->setUseColorTrans(uiCode != 0); } @@ -3339,7 +3351,9 @@ void HLSyntaxReader::parseSliceHeader (Slice* pcSlice, PicHeader* picHeader, Par CHECK(pcSlice->getPictureHeaderInSliceHeader() && pps->getWpInfoInPhFlag() == 1, "When sh_picture_header_in_slice_header_flag is equal to 1, wp_info_in_ph_flag shall be equal to 0"); CHECK(pcSlice->getPictureHeaderInSliceHeader() && pps->getQpDeltaInfoInPhFlag() == 1, "When sh_picture_header_in_slice_header_flag is equal to 1, qp_delta_info_in_ph_flag shall be equal to 0"); CHECK(pcSlice->getPictureHeaderInSliceHeader() && sps->getSubPicInfoPresentFlag() == 1, "When sps_subpic_info_present_flag is equal to 1, the value of sh_picture_header_in_slice_header_flag shall be equal to 0"); +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE CHECK(pcSlice->getPictureHeaderInSliceHeader() && sps->getSeparateColourPlaneFlag() == 1, "when separate_colour_plane_flag is equal to 1, the value of picture_header_in_slice_header_flag shall be equal to 0"); +#endif const ChromaFormat chFmt = sps->getChromaFormatIdc(); const uint32_t numValidComp=getNumberValidComponents(chFmt); @@ -3602,6 +3616,7 @@ void HLSyntaxReader::parseSliceHeader (Slice* pcSlice, PicHeader* picHeader, Par pcSlice->setExplicitScalingListUsed(pcSlice->getPictureHeaderInSliceHeader() ? picHeader->getExplicitScalingListEnabledFlag() : false); } +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE // 4:4:4 colour plane ID if( sps->getSeparateColourPlaneFlag() ) { @@ -3612,8 +3627,7 @@ void HLSyntaxReader::parseSliceHeader (Slice* pcSlice, PicHeader* picHeader, Par { pcSlice->setColourPlaneId( 0 ); } - - +#endif if( pps->getRplInfoInPhFlag() ) { pcSlice->setRPL0(picHeader->getRPL0()); diff --git a/source/Lib/EncoderLib/EncLib.cpp b/source/Lib/EncoderLib/EncLib.cpp index 56a0ed2ec5830e9b71a19422131578a03f56b909..7b60e0c3f04cf45de851e50f8d14d3dbe98aeee4 100644 --- a/source/Lib/EncoderLib/EncLib.cpp +++ b/source/Lib/EncoderLib/EncLib.cpp @@ -1722,8 +1722,12 @@ void EncLib::xInitPPS(PPS &pps, const SPS &sps) { chromaDbfOffsetNotSameAsLuma = false; } +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE const uint32_t chromaArrayType = (int)sps.getSeparateColourPlaneFlag() ? 0 : sps.getChromaFormatIdc(); if( ( chromaArrayType != CHROMA_400 ) && ( chromaQPOffsetNotZero || chromaDbfOffsetNotSameAsLuma ) ) +#else + if ((sps.getChromaFormatIdc() != CHROMA_400) && (chromaQPOffsetNotZero || chromaDbfOffsetNotSameAsLuma)) +#endif { pps.setPPSChromaToolFlag(true); } diff --git a/source/Lib/EncoderLib/VLCWriter.cpp b/source/Lib/EncoderLib/VLCWriter.cpp index 75c304a847f2f0554f83de0929f56e7c123209a7..253545e619e7f800ee230e06bd9d449c591ed653 100644 --- a/source/Lib/EncoderLib/VLCWriter.cpp +++ b/source/Lib/EncoderLib/VLCWriter.cpp @@ -788,6 +788,7 @@ void HLSWriter::codeSPS( const SPS* pcSPS ) WRITE_FLAG(pcSPS->getGDREnabledFlag(), "gdr_enabled_flag"); WRITE_CODE(int(pcSPS->getChromaFormatIdc ()), 2, "chroma_format_idc"); +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE const ChromaFormat format = pcSPS->getChromaFormatIdc(); const uint32_t separate_colour_plane_flag = pcSPS->getSeparateColourPlaneFlag(); if( format == CHROMA_444 ) @@ -797,6 +798,7 @@ void HLSWriter::codeSPS( const SPS* pcSPS ) } const uint32_t chromaArrayType = separate_colour_plane_flag ? 0 : format; +#endif WRITE_FLAG(pcSPS->getRprEnabledFlag(), "ref_pic_resampling_enabled_flag"); if (pcSPS->getRprEnabledFlag()) @@ -967,7 +969,11 @@ void HLSWriter::codeSPS( const SPS* pcSPS ) WRITE_FLAG(pcSPS->getUseLFNST() ? 1 : 0, "sps_lfnst_enabled_flag"); #endif +#if JVET_S0052_RM_SEPARATE_COLOUR_PLANE + if (pcSPS->getChromaFormatIdc() != CHROMA_400) +#else if (chromaArrayType != CHROMA_400) +#endif { WRITE_FLAG(pcSPS->getJointCbCrEnabledFlag(), "sps_joint_cbcr_enabled_flag"); const ChromaQpMappingTable& chromaQpMappingTable = pcSPS->getChromaQpMappingTable(); @@ -2179,12 +2185,13 @@ void HLSWriter::codeSliceHeader ( Slice* pcSlice ) WRITE_FLAG(pcSlice->getExplicitScalingListUsed(), "slice_explicit_scaling_list_used_flag"); } +#if !JVET_S0052_RM_SEPARATE_COLOUR_PLANE // 4:4:4 colour plane ID if( pcSlice->getSPS()->getSeparateColourPlaneFlag() ) { WRITE_CODE( pcSlice->getColourPlaneId(), 2, "colour_plane_id" ); } - +#endif if( !pcSlice->getPPS()->getRplInfoInPhFlag() && (!pcSlice->getIdrPicFlag() || pcSlice->getSPS()->getIDRRefParamListPresent())) { //Write L0 related syntax elements