Newer
Older

Karsten Suehring
committed
/* 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-2024, ITU/ISO/IEC

Karsten Suehring
committed
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
* 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 TAppDecLib.h
\brief Decoder application class (header)
*/
#ifndef __DECAPP__
#define __DECAPP__
#pragma once
#include "Utilities/VideoIOYuv.h"
#include "CommonLib/Picture.h"
#include "DecoderLib/DecLib.h"
#include "DecAppCfg.h"
//! \ingroup DecoderApp
//! \{
// ====================================================================================================================
// Class definition
// ====================================================================================================================
/// decoder application class
class DecApp : public DecAppCfg
{
private:
static constexpr auto DEFAULT_FRAME_RATE = Fraction{ 50, 1 };

Karsten Suehring
committed
// class interface
DecLib m_cDecLib; ///< decoder class
std::unordered_map<int, VideoIOYuv> m_cVideoIOYuvReconFile; ///< reconstruction YUV class
std::unordered_map<int, VideoIOYuv> m_videoIOYuvSEIFGSFile; ///< reconstruction YUV with FGS class
std::unordered_map<int, VideoIOYuv> m_cVideoIOYuvSEICTIFile; ///< reconstruction YUV with CTI class

Karsten Suehring
committed
Jeeva Raj A
committed
bool m_ShutterFilterEnable; ///< enable Post-processing with Shutter Interval SEI
VideoIOYuv m_cTVideoIOYuvSIIPostFile; ///< post-filtered YUV class
int m_SII_BlendingRatio;
Jeeva Raj A
committed
{
SEIShutterIntervalInfo m_siiInfo;
uint32_t m_picPoc;
Jeeva Raj A
committed
std::map<uint32_t, IdrSiiInfo> m_activeSiiInfo;
Jeeva Raj A
committed

Karsten Suehring
committed
// for output control
int m_iPOCLastDisplay; ///< last POC in display order
std::ofstream m_seiMessageFileStream; ///< Used for outputing SEI messages.
Alexey Filippov
committed
std::ofstream m_oplFileStream; ///< Used to output log file for confomance testing
bool m_newCLVS[MAX_NUM_LAYER_IDS]; ///< used to record a new CLVSS
Alexey Filippov
committed
SEIAnnotatedRegions::AnnotatedRegionHeader m_arHeader; ///< AR header
std::map<uint32_t, SEIAnnotatedRegions::AnnotatedRegionObject> m_arObjects; ///< AR object pool
std::map<uint32_t, std::string> m_arLabels; ///< AR label pool

Karsten Suehring
committed
#if JVET_AI0153_OMI_SEI
SEIObjectMaskInfos::ObjectMaskInfoHeader m_omiHeader; ///< OMI header
#endif
private:
bool xIsNaluWithinTargetDecLayerIdSet( const InputNALUnit* nalu ) const; ///< check whether given Nalu is within targetDecLayerIdSet
bool xIsNaluWithinTargetOutputLayerIdSet( const InputNALUnit* nalu ) const; ///< check whether given Nalu is within targetOutputLayerIdSet

Karsten Suehring
committed
public:
DecApp();
virtual ~DecApp () {}
uint32_t decode (); ///< main decoding function
Jeeva Raj A
committed
bool getShutterFilterFlag() const { return m_ShutterFilterEnable; }
void setShutterFilterFlag(bool value) { m_ShutterFilterEnable = value; }
int getBlendingRatio() const { return m_SII_BlendingRatio; }
void setBlendingRatio(int value) { m_SII_BlendingRatio = value; }

Karsten Suehring
committed
private:
void xCreateDecLib (); ///< create internal classes
void xDestroyDecLib (); ///< destroy internal classes
void xWriteOutput ( PicList* pcListPic , uint32_t tId); ///< write YUV to file
void xFlushOutput( PicList* pcListPic, const int layerId = NOT_VALID ); ///< flush all remaining decoded pictures to file
// check if next NAL unit will be the first NAL unit from a new picture
bool isNewPicture(std::ifstream *bitstreamFile, class InputByteStream *bytestream);
// check if next NAL unit will be the first NAL unit from a new access unit
bool isNewAccessUnit(bool newPicture, std::ifstream *bitstreamFile, class InputByteStream *bytestream);
Alexey Filippov
committed
void writeLineToOutputLog(Picture * pcPic);
void xOutputAnnotatedRegions(PicList* pcListPic);
#if JVET_AI0153_OMI_SEI
void xOutputObjectMaskInfos(Picture* pcPic);
#endif

Karsten Suehring
committed
};
//! \}
#endif // __DECAPP__