source: 3DVCSoftware/trunk/source/App/TAppDecoder/TAppDecCfg.h @ 1413

Last change on this file since 1413 was 1413, checked in by tech, 6 years ago

Merged HTM-16.2-dev@1412

  • Property svn:eol-style set to native
File size: 6.6 KB
Line 
1/* The copyright in this software is being made available under the BSD
2 * License, included below. This software may be subject to other third party
3 * and contributor rights, including patent rights, and no such rights are
4 * granted under this license.
5 *
6 * Copyright (c) 2010-2017, ITU/ISO/IEC
7 * All rights reserved.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions are met:
11 *
12 *  * Redistributions of source code must retain the above copyright notice,
13 *    this list of conditions and the following disclaimer.
14 *  * Redistributions in binary form must reproduce the above copyright notice,
15 *    this list of conditions and the following disclaimer in the documentation
16 *    and/or other materials provided with the distribution.
17 *  * Neither the name of the ITU/ISO/IEC nor the names of its contributors may
18 *    be used to endorse or promote products derived from this software without
19 *    specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS
25 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
31 * THE POSSIBILITY OF SUCH DAMAGE.
32 */
33
34/** \file     TAppDecCfg.h
35    \brief    Decoder configuration class (header)
36*/
37
38#ifndef __TAPPDECCFG__
39#define __TAPPDECCFG__
40
41#if _MSC_VER > 1000
42#pragma once
43#endif // _MSC_VER > 1000
44
45#include "TLibCommon/CommonDef.h"
46#include <vector>
47#if NH_MV
48#include <fstream>
49#endif
50
51//! \ingroup TAppDecoder
52//! \{
53
54// ====================================================================================================================
55// Class definition
56// ====================================================================================================================
57
58/// Decoder configuration class
59class TAppDecCfg
60{
61protected:
62  std::string   m_bitstreamFileName;                    ///< input bitstream file name
63  std::string   m_reconFileName;                        ///< output reconstruction file name
64  Int           m_iSkipFrame;                           ///< counter for frames prior to the random access point to skip
65  Int           m_outputBitDepth[MAX_NUM_CHANNEL_TYPE]; ///< bit depth used for writing output
66  InputColourSpaceConversion m_outputColourSpaceConvert;
67
68  Int           m_iMaxTemporalLayer;                  ///< maximum temporal layer to be decoded
69  Int           m_decodedPictureHashSEIEnabled;       ///< Checksum(3)/CRC(2)/MD5(1)/disable(0) acting on decoded picture hash SEI message
70  Bool          m_decodedNoDisplaySEIEnabled;         ///< Enable(true)/disable(false) writing only pictures that get displayed based on the no display SEI message
71  std::string   m_colourRemapSEIFileName;             ///< output Colour Remapping file name
72  std::vector<Int> m_targetDecLayerIdSet;             ///< set of LayerIds to be included in the sub-bitstream extraction process.
73
74  Int           m_respectDefDispWindow;               ///< Only output content inside the default display window
75#if O0043_BEST_EFFORT_DECODING
76  UInt          m_forceDecodeBitDepth;                ///< if non-zero, force the bit depth at the decoder (best effort decoding)
77#endif
78  std::string   m_outputDecodedSEIMessagesFilename;   ///< filename to output decoded SEI messages to. If '-', then use stdout. If empty, do not output details.
79  Bool          m_bClipOutputVideoToRec709Range;      ///< If true, clip the output video to the Rec 709 range on saving.
80#if MCTS_ENC_CHECK
81  Bool          m_tmctsCheck;
82#endif
83
84#if NH_MV
85  std::vector<TChar*> m_pchReconFiles;                ///< array of output reconstruction file name create from output reconstruction file name
86
87  std::vector<Int> m_targetOptLayerSetInd;            ///< target output layer set indices (multiple decoding when more than one element, e.g. for additional layer sets)
88  Int           m_targetOptLayerSetIdx;               ///< current target output layer set index
89
90  Int           m_targetDecLayerSetIdx;
91  Int           m_baseLayerOutputFlag;
92  Int           m_baseLayerPicOutputFlag;
93  Int           m_auOutputFlag;
94  Int           m_maxLayerId;                         ///< maximum nuh_layer_id decoded
95  std::ifstream m_bitstreamFile;
96  Int           m_highestTid;
97  Bool          m_targetDecLayerIdSetFileEmpty;       ///< indication if target layers are given by file
98
99  Bool          m_printVpsInfo;                       ///< Output VPS information
100  Bool          m_printPicOutput;                     ///< Print information on picture output
101  Bool          m_printReceivedNalus;                 ///< Print information on received NAL units
102#if NH_3D
103  TChar*        m_pchScaleOffsetFile;                   ///< output coded scale and offset parameters
104  Bool          m_depth420OutputFlag;                   ///< output depth layers in 4:2:0
105#endif
106
107  Void xAppendToFileNameEnd( const TChar* pchInputFileName, const TChar* pchStringToAppend, TChar*& rpchOutputFileName); ///< create filenames
108#endif
109
110public:
111  TAppDecCfg()
112  : m_bitstreamFileName()
113  , m_reconFileName()
114  , m_iSkipFrame(0)
115  // m_outputBitDepth array initialised below
116  , m_outputColourSpaceConvert(IPCOLOURSPACE_UNCHANGED)
117  , m_iMaxTemporalLayer(-1)
118  , m_decodedPictureHashSEIEnabled(0)
119  , m_decodedNoDisplaySEIEnabled(false)
120  , m_colourRemapSEIFileName()
121  , m_targetDecLayerIdSet()
122  , m_respectDefDispWindow(0)
123#if O0043_BEST_EFFORT_DECODING
124  , m_forceDecodeBitDepth(0)
125#endif
126  , m_outputDecodedSEIMessagesFilename()
127  , m_bClipOutputVideoToRec709Range(false)
128#if MCTS_ENC_CHECK
129  , m_tmctsCheck(false)
130#endif
131#if NH_MV
132  , m_highestTid(-1)
133  , m_targetDecLayerIdSetFileEmpty(true)
134#endif
135  {
136    for (UInt channelTypeIndex = 0; channelTypeIndex < MAX_NUM_CHANNEL_TYPE; channelTypeIndex++)
137    {
138      m_outputBitDepth[channelTypeIndex] = 0;
139    }
140#if NH_3D
141    m_pchScaleOffsetFile = NULL;
142#endif
143  }
144
145  virtual ~TAppDecCfg() {}
146
147  Bool  parseCfg        ( Int argc, TChar* argv[] );   ///< initialize option class from configuration
148#if NH_MV
149  Int   getNumDecodings ( ) { return (Int) m_targetOptLayerSetInd.size();  }; 
150#endif
151};
152
153//! \}
154
155#endif
156
157
Note: See TracBrowser for help on using the repository browser.