/* The copyright in this software is being made available under the BSD * License, included below. This software may be subject to other third party * and contributor rights, including patent rights, and no such rights are * granted under this license. * * Copyright (c) 2010-2011, ISO/IEC * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * * Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * Neither the name of the ISO/IEC nor the names of its contributors may * be used to endorse or promote products derived from this software without * specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. */ /** \file TComPic.h \brief picture class (header) */ #ifndef __TCOMPIC__ #define __TCOMPIC__ // Include files #include "CommonDef.h" #include "TComPicSym.h" #include "TComPicYuv.h" #include "TComBitStream.h" #include "TComMVDRefData.h" class SEImessages; // ==================================================================================================================== // Class definition // ==================================================================================================================== /// picture class (symbol + YUV buffers) class TComPic { private: TComPicSym* m_apcPicSym; // Symbol TComPicYuv* m_apcPicYuv[2]; // Texture, 0:org / 1:rec #if POZNAN_CU_SYNTH || POZNAN_CU_SKIP || POZNAN_TEXTURE_TU_DELTA_QP_ACCORDING_TO_DEPTH TComPicYuv* m_apcPicYuvAvail; // Availability Map - Does the given pixel can be synthesised in receiver #endif #if POZNAN_CU_SYNTH TComPicYuv* m_apcPicYuvSynth; // Sythesied image #if POZNAN_TEXTURE_TU_DELTA_QP_ACCORDING_TO_DEPTH TComPicYuv* m_apcPicYuvSynthDepth; // Sythesied depth image #endif #endif #if DEPTH_MAP_GENERATION TComPicYuv* m_pcPredDepthMap; // estimated depth map #endif #if HHI_INTER_VIEW_MOTION_PRED TComPicYuv* m_pcOrgDepthMap; // original depth map #endif #if HHI_INTER_VIEW_RESIDUAL_PRED TComPicYuv* m_pcResidual; // residual buffer (coded or inter-view predicted residual) #endif TComPicYuv* m_pcPicYuvPred; // Prediction TComPicYuv* m_pcPicYuvResi; // Residual #if PARALLEL_MERGED_DEBLK TComPicYuv* m_pcPicYuvDeblkBuf; #endif Bool m_bReconstructed; UInt m_uiCurrSliceIdx; // Index of current slice SEImessages* m_SEIs; ///< Any SEI messages that have been received. If !NULL we own the object. SliceType m_eSliceType; double m_dQP; Bool m_bReferenced; UInt m_uiColDir; Int m_aiRefPOCList[2][MAX_NUM_REF]; Int m_aiRefViewIdxList[2][MAX_NUM_REF]; Int m_aiNumRefIdx[2]; // for multiple reference of current slice Int m_iViewIdx; Int** m_aaiCodedScale; Int** m_aaiCodedOffset; #if HHI_VSO TComMVDRefData m_cReferenceInfo; #endif #if HHI_INTERVIEW_SKIP TComPicYuv* m_pcUsedPelsMap; #endif #if POZNAN_TEXTURE_TU_DELTA_QP_PARAM_IN_CFG_FOR_ENC Double m_dTextureCuDeltaQpOffset; Double m_dTextureCuDeltaQpMul; Int m_iTextureCuDeltaQpTopBottomRow; #endif public: TComPic(); virtual ~TComPic(); Void create( Int iWidth, Int iHeight, UInt uiMaxWidth, UInt uiMaxHeight, UInt uiMaxDepth ); Void destroy(); TComPicSym* getPicSym() { return m_apcPicSym; } TComSlice* getSlice(Int i) { return m_apcPicSym->getSlice(i); } TComSlice* getCurrSlice() { return m_apcPicSym->getSlice(m_uiCurrSliceIdx); } TComSPS* getSPS() { return m_apcPicSym->getSlice(m_uiCurrSliceIdx)->getSPS(); } Int getPOC() { return m_apcPicSym->getSlice(m_uiCurrSliceIdx)->getPOC(); } #if 0 Bool getDRBFlag() { return m_apcPicSym->getSlice(m_uiCurrSliceIdx)->getDRBFlag(); } Int getERBIndex() { return m_apcPicSym->getSlice(m_uiCurrSliceIdx)->getERBIndex(); } #endif TComDataCU*& getCU( UInt uiCUAddr ) { return m_apcPicSym->getCU( uiCUAddr ); } SliceType getSliceType() { return m_eSliceType ;} double getQP() { return m_dQP ;} Bool getReferenced() { return m_bReferenced ;} TComPicYuv* getPicYuvOrg() { return m_apcPicYuv[0]; } TComPicYuv* getPicYuvRec() { return m_apcPicYuv[1]; } #if POZNAN_CU_SYNTH || POZNAN_CU_SKIP || POZNAN_TEXTURE_TU_DELTA_QP_ACCORDING_TO_DEPTH TComPicYuv* getPicYuvAvail() { return m_apcPicYuvAvail; } //Owieczka - returns available map from other pic image #endif #if POZNAN_CU_SYNTH TComPicYuv* getPicYuvSynth() { return m_apcPicYuvSynth; } //Owieczka - returns synth form other pic in image #if POZNAN_TEXTURE_TU_DELTA_QP_ACCORDING_TO_DEPTH TComPicYuv* getPicYuvSynthDepth() { return m_apcPicYuvSynthDepth; }; // Sythesied depth image #endif #endif #if DEPTH_MAP_GENERATION TComPicYuv* getPredDepthMap() { return m_pcPredDepthMap; } #endif #if HHI_INTER_VIEW_MOTION_PRED TComPicYuv* getOrgDepthMap() { return m_pcOrgDepthMap; } #endif #if HHI_INTER_VIEW_RESIDUAL_PRED TComPicYuv* getResidual() { return m_pcResidual; } #endif #if HHI_INTERVIEW_SKIP TComPicYuv* getUsedPelsMap() { return m_pcUsedPelsMap; } #endif TComPicYuv* getPicYuvPred() { return m_pcPicYuvPred; } TComPicYuv* getPicYuvResi() { return m_pcPicYuvResi; } Void setPicYuvPred( TComPicYuv* pcPicYuv ) { m_pcPicYuvPred = pcPicYuv; } Void setPicYuvResi( TComPicYuv* pcPicYuv ) { m_pcPicYuvResi = pcPicYuv; } Void setQP( double dQP ) { m_dQP = dQP; } Void setSliceType( SliceType eSliceType ) { m_eSliceType = eSliceType; } Void setReferenced( Bool bReferenced ) { m_bReferenced = bReferenced; } Void setColDir( UInt uiColDir ) { m_uiColDir = uiColDir; } UInt getColDir() { return m_uiColDir; } Void setRefPOC( Int i, RefPicList e, Int iRefIdx ) { m_aiRefPOCList[e][iRefIdx] = i; } Int getRefPOC( RefPicList e, Int iRefIdx ) { return m_aiRefPOCList[e][iRefIdx]; } Void setRefViewIdx( Int i, RefPicList e, Int iRefIdx ) { m_aiRefViewIdxList[e][iRefIdx] = i; } Int getRefViewIdx( RefPicList e, Int iRefIdx ) { return m_aiRefViewIdxList[e][iRefIdx]; } Int getNumRefs( RefPicList e ) { return m_aiNumRefIdx[e]; } Void setNumRefs( Int i, RefPicList e ) { m_aiNumRefIdx[e] = i; } Void setViewIdx( Int i ) { m_iViewIdx = i; } Int getViewIdx() { return m_iViewIdx; } Void setScaleOffset( Int** pS, Int** pO ) { m_aaiCodedScale = pS; m_aaiCodedOffset = pO; } Int** getCodedScale () { return m_aaiCodedScale; } Int** getCodedOffset() { return m_aaiCodedOffset; } #if HHI_VSO TComMVDRefData* getMVDReferenceInfo() { return &m_cReferenceInfo; } #endif UInt getNumCUsInFrame() { return m_apcPicSym->getNumberOfCUsInFrame(); } UInt getNumPartInWidth() { return m_apcPicSym->getNumPartInWidth(); } UInt getNumPartInHeight() { return m_apcPicSym->getNumPartInHeight(); } UInt getNumPartInCU() { return m_apcPicSym->getNumPartition(); } UInt getFrameWidthInCU() { return m_apcPicSym->getFrameWidthInCU(); } UInt getFrameHeightInCU() { return m_apcPicSym->getFrameHeightInCU(); } UInt getMinCUWidth() { return m_apcPicSym->getMinCUWidth(); } UInt getMinCUHeight() { return m_apcPicSym->getMinCUHeight(); } UInt getParPelX(UChar uhPartIdx) { return getParPelX(uhPartIdx); } UInt getParPelY(UChar uhPartIdx) { return getParPelX(uhPartIdx); } Int getStride() { return m_apcPicYuv[1]->getStride(); } Int getCStride() { return m_apcPicYuv[1]->getCStride(); } Void setReconMark (Bool b) { m_bReconstructed = b; } Bool getReconMark () { return m_bReconstructed; } #if AMVP_BUFFERCOMPRESS Void compressMotion(); #endif UInt getCurrSliceIdx() { return m_uiCurrSliceIdx; } Void setCurrSliceIdx(UInt i) { m_uiCurrSliceIdx = i; } UInt getNumAllocatedSlice() {return m_apcPicSym->getNumAllocatedSlice();} Void allocateNewSlice() {m_apcPicSym->allocateNewSlice(); } Void clearSliceBuffer() {m_apcPicSym->clearSliceBuffer(); } Void addOriginalBuffer (); #if POZNAN_CU_SYNTH || POZNAN_CU_SKIP || POZNAN_TEXTURE_TU_DELTA_QP_ACCORDING_TO_DEPTH Void addAvailabilityBuffer (); #endif #if POZNAN_CU_SYNTH Void addSynthesisBuffer (); #if POZNAN_TEXTURE_TU_DELTA_QP_ACCORDING_TO_DEPTH Void addSynthesisDepthBuffer (); #endif #endif #if PARALLEL_MERGED_DEBLK Void addDeblockBuffer (); #endif #if DEPTH_MAP_GENERATION Void addPrdDepthMapBuffer (); #endif #if HHI_INTER_VIEW_MOTION_PRED Void addOrgDepthMapBuffer (); #endif #if HHI_INTER_VIEW_RESIDUAL_PRED Void addResidualBuffer (); #endif #if HHI_INTERVIEW_SKIP Void addUsedPelsMapBuffer (); #endif Void removeOriginalBuffer (); #if POZNAN_CU_SYNTH Void removeSynthesisBuffer (); #if POZNAN_TEXTURE_TU_DELTA_QP_ACCORDING_TO_DEPTH Void removeSynthesisDepthBuffer (); #endif #endif #if POZNAN_CU_SYNTH || POZNAN_CU_SKIP || POZNAN_TEXTURE_TU_DELTA_QP_ACCORDING_TO_DEPTH Void removeAvailabilityBuffer(); #endif #if PARALLEL_MERGED_DEBLK Void removeDeblockBuffer (); #endif #if DEPTH_MAP_GENERATION Void removePrdDepthMapBuffer (); #endif #if HHI_INTER_VIEW_MOTION_PRED Void removeOrgDepthMapBuffer (); #endif #if HHI_INTER_VIEW_RESIDUAL_PRED Void removeResidualBuffer (); #endif #if HHI_INTERVIEW_SKIP Void removeUsedPelsMapBuffer (); #endif #if POZNAN_CU_SYNTH || POZNAN_CU_SKIP Void checkSynthesisAvailability( TComDataCU*& rpcBestCU, UInt iCuAddr, UInt uiAbsZorderIdx, UInt uiPartDepth, Bool *&rpbCUSynthesied); #endif #if PARALLEL_MERGED_DEBLK TComPicYuv* getPicYuvDeblkBuf() { return m_pcPicYuvDeblkBuf; } #endif /** transfer ownership of @seis to @this picture */ void setSEIs(SEImessages* seis) { m_SEIs = seis; } /** * return the current list of SEI messages associated with this picture. * Pointer is valid until @this->destroy() is called */ SEImessages* getSEIs() { return m_SEIs; } /** * return the current list of SEI messages associated with this picture. * Pointer is valid until @this->destroy() is called */ const SEImessages* getSEIs() const { return m_SEIs; } #if POZNAN_TEXTURE_TU_DELTA_QP_PARAM_IN_CFG_FOR_ENC Double getTextureCuDeltaQpOffset( ) { return m_dTextureCuDeltaQpOffset;} Double getTextureCuDeltaQpMul( ) { return m_dTextureCuDeltaQpMul;} Int getTextureCuDeltaQpTopBottomRow( ){ return m_iTextureCuDeltaQpTopBottomRow;} Void setTextureCuDeltaQpOffset ( Double dTextureCuDeltaQpOffset ){ m_dTextureCuDeltaQpOffset = dTextureCuDeltaQpOffset; } Void setTextureCuDeltaQpMul ( Double dTextureCuDeltaQpMul ){ m_dTextureCuDeltaQpMul = dTextureCuDeltaQpMul; } Void setTextureCuDeltaQpTopBottomRow( Int iTextureCuDeltaQpTopBottomRow ){ m_iTextureCuDeltaQpTopBottomRow = iTextureCuDeltaQpTopBottomRow; } #endif };// END CLASS DEFINITION TComPic #endif // __TCOMPIC__