/* 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-2014, ITU/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 ITU/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 TAppDecTop.h \brief Decoder application class (header) */ #ifndef __TAPPDECTOP__ #define __TAPPDECTOP__ #if _MSC_VER > 1000 #pragma once #endif // _MSC_VER > 1000 #include "TLibVideoIO/TVideoIOYuv.h" #include "TLibCommon/TComList.h" #include "TLibCommon/TComPicYuv.h" #include "TLibDecoder/TDecTop.h" #include "TAppDecCfg.h" //! \ingroup TAppDecoder //! \{ // ==================================================================================================================== // Class definition // ==================================================================================================================== #if ALIGNED_BUMPING struct DpbStatus; #endif /// decoder application class class TAppDecTop : public TAppDecCfg { private: // class interface #if SVC_EXTENSION TDecTop m_acTDecTop [MAX_LAYERS]; ///< decoder class [WARNING] suppose to use MAX_NUM_LAYER_IDS but decoder crashes, pending for further investigation TDecTop* m_apcTDecTop [MAX_NUM_LAYER_IDS]; ///< decoder point class TVideoIOYuv m_acTVideoIOYuvReconFile [MAX_NUM_LAYER_IDS]; ///< reconstruction YUV class #else TDecTop m_cTDecTop; ///< decoder class TVideoIOYuv m_cTVideoIOYuvReconFile; ///< reconstruction YUV class #endif // for output control #if SVC_EXTENSION #if CONFORMANCE_BITSTREAM_MODE TVideoIOYuv m_confReconFile[63]; ///< decode YUV files #endif Int m_aiPOCLastDisplay [MAX_LAYERS]; ///< last POC in display order #else Int m_iPOCLastDisplay; ///< last POC in display order #endif std::ofstream m_seiMessageFileStream; ///< Used for outputing SEI messages. public: TAppDecTop(); virtual ~TAppDecTop() {} Void create (); ///< create internal members Void destroy (); ///< destroy internal members Void decode (); ///< main decoding function protected: Void xCreateDecLib (); ///< create internal classes Void xDestroyDecLib (); ///< destroy internal classes Void xInitDecLib (); ///< initialize decoder class #if SVC_EXTENSION Void xWriteOutput ( TComList* pcListPic, UInt layerId, UInt tId ); ///< write YUV to file Void xFlushOutput ( TComList* pcListPic, UInt layerId ); ///< flush all remaining decoded pictures to file #else Void xWriteOutput ( TComList* pcListPic , UInt tId); ///< write YUV to file Void xFlushOutput ( TComList* pcListPic ); ///< flush all remaining decoded pictures to file #endif Bool isNaluWithinTargetDecLayerIdSet ( InputNALUnit* nalu ); ///< check whether given Nalu is within targetDecLayerIdSet #if ALIGNED_BUMPING Void checkOutputBeforeDecoding(Int layerIdx); Void checkOutputAfterDecoding(); Void flushAllPictures(Bool outputPictures); Void flushAllPictures(Int layerId, Bool outputPictures); Void xOutputAndMarkPic( TComPic *pic, const Char *reconFile, const Int layerId, Int &pocLastDisplay, DpbStatus &dpbStatus); #if POC_RESET_IDC_DECODER Void outputAllPictures(Int layerId, Bool notOutputCurrAu); #endif Void xFindDPBStatus( std::vector &listOfPocs , std::vector *listOfPocsInEachLayer , std::vector *listOfPocsPositionInEachLayer , DpbStatus &dpbStatus #if POC_RESET_IDC_DECODER , Bool notOutputCurrAu = true #endif ); Bool ifInvokeBumpingBeforeDecoding( const DpbStatus &dpbStatus, const DpbStatus &dpbLimit, const Int layerIdx, const Int subDpbIdx ); Bool ifInvokeBumpingAfterDecoding ( const DpbStatus &dpbStatus, const DpbStatus &dpbLimit ); Void bumpingProcess(std::vector &listOfPocs, std::vector *listOfPocsInEachLayer, std::vector *listOfPocsPositionInEachLayer, DpbStatus &dpbStatus); Void emptyUnusedPicturesNotNeededForOutput(); Void markAllPicturesAsErased(); Void markAllPicturesAsErased(Int layerIdx); TComVPS* findDpbParametersFromVps(std::vector const &listOfPocs, std::vector const *listOfPocsInEachLayer, std::vector const *listOfPocsPositionInEachLayer, DpbStatus &maxDpbLimit); #endif }; #if ALIGNED_BUMPING struct DpbStatus { // Number of AUs and pictures Int m_numAUsNotDisplayed; Int m_numPicsNotDisplayedInLayer[MAX_LAYERS]; Int m_numPicsInSubDpb[MAX_LAYERS]; // Pictures marked as used_for_reference or needed for output in the sub-DPB #if FIX_ALIGN_BUMPING Int m_layerIdToSubDpbIdMap[MAX_VPS_LAYER_IDX_PLUS1]; Int m_targetDecLayerIdList[MAX_LAYERS]; #endif Bool m_maxLatencyIncrease; Int m_maxLatencyPictures; Int m_numSubDpbs; Int m_numLayers; DpbStatus() { init(); } Void init() { m_numAUsNotDisplayed = 0; m_maxLatencyIncrease = false; m_maxLatencyPictures = 0; ::memset( m_numPicsInSubDpb, 0, sizeof(m_numPicsInSubDpb) ); ::memset(m_numPicsNotDisplayedInLayer, 0, sizeof(m_numPicsNotDisplayedInLayer) ); m_numSubDpbs = -1; m_numLayers = -1; #if FIX_ALIGN_BUMPING ::memset( m_targetDecLayerIdList, 0, sizeof(m_targetDecLayerIdList) ); for(Int i = 0; i < MAX_VPS_LAYER_IDX_PLUS1; i++) { m_layerIdToSubDpbIdMap[i] = -1; } #endif } }; #endif //! \} #endif