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

Last change on this file 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
RevLine 
[5]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
[1313]4 * granted under this license.
[5]5 *
[1413]6 * Copyright (c) 2010-2017, ITU/ISO/IEC
[5]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.
[56]17 *  * Neither the name of the ITU/ISO/IEC nor the names of its contributors may
[5]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 */
[2]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
[56]45#include "TLibCommon/CommonDef.h"
[608]46#include <vector>
[1321]47#if NH_MV
48#include <fstream>
49#endif
[1313]50
[56]51//! \ingroup TAppDecoder
52//! \{
53
[2]54// ====================================================================================================================
55// Class definition
56// ====================================================================================================================
57
58/// Decoder configuration class
59class TAppDecCfg
60{
61protected:
[1386]62  std::string   m_bitstreamFileName;                    ///< input bitstream file name
63  std::string   m_reconFileName;                        ///< output reconstruction file name
[1313]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;
[2]67
[56]68  Int           m_iMaxTemporalLayer;                  ///< maximum temporal layer to be decoded
[608]69  Int           m_decodedPictureHashSEIEnabled;       ///< Checksum(3)/CRC(2)/MD5(1)/disable(0) acting on decoded picture hash SEI message
[1313]70  Bool          m_decodedNoDisplaySEIEnabled;         ///< Enable(true)/disable(false) writing only pictures that get displayed based on the no display SEI message
[1386]71  std::string   m_colourRemapSEIFileName;             ///< output Colour Remapping file name
[608]72  std::vector<Int> m_targetDecLayerIdSet;             ///< set of LayerIds to be included in the sub-bitstream extraction process.
73
[1313]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.
[1413]80#if MCTS_ENC_CHECK
81  Bool          m_tmctsCheck;
82#endif
83
[1313]84#if NH_MV
[1386]85  std::vector<TChar*> m_pchReconFiles;                ///< array of output reconstruction file name create from output reconstruction file name
[1321]86
[1386]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
[1321]90  Int           m_targetDecLayerSetIdx;
[1356]91  Int           m_baseLayerOutputFlag;
92  Int           m_baseLayerPicOutputFlag;
93  Int           m_auOutputFlag;
[1386]94  Int           m_maxLayerId;                         ///< maximum nuh_layer_id decoded
[1356]95  std::ifstream m_bitstreamFile;
[1321]96  Int           m_highestTid;
97  Bool          m_targetDecLayerIdSetFileEmpty;       ///< indication if target layers are given by file
98
[1386]99  Bool          m_printVpsInfo;                       ///< Output VPS information
[1321]100  Bool          m_printPicOutput;                     ///< Print information on picture output
101  Bool          m_printReceivedNalus;                 ///< Print information on received NAL units
102#if NH_3D
[1386]103  TChar*        m_pchScaleOffsetFile;                   ///< output coded scale and offset parameters
[1321]104  Bool          m_depth420OutputFlag;                   ///< output depth layers in 4:2:0
105#endif
106
[1386]107  Void xAppendToFileNameEnd( const TChar* pchInputFileName, const TChar* pchStringToAppend, TChar*& rpchOutputFileName); ///< create filenames
[608]108#endif
[1313]109
[2]110public:
[608]111  TAppDecCfg()
[1386]112  : m_bitstreamFileName()
113  , m_reconFileName()
[608]114  , m_iSkipFrame(0)
[1386]115  // m_outputBitDepth array initialised below
[1313]116  , m_outputColourSpaceConvert(IPCOLOURSPACE_UNCHANGED)
[608]117  , m_iMaxTemporalLayer(-1)
118  , m_decodedPictureHashSEIEnabled(0)
[1313]119  , m_decodedNoDisplaySEIEnabled(false)
[1386]120  , m_colourRemapSEIFileName()
121  , m_targetDecLayerIdSet()
[608]122  , m_respectDefDispWindow(0)
[1313]123#if O0043_BEST_EFFORT_DECODING
124  , m_forceDecodeBitDepth(0)
125#endif
[1386]126  , m_outputDecodedSEIMessagesFilename()
127  , m_bClipOutputVideoToRec709Range(false)
[1413]128#if MCTS_ENC_CHECK
129  , m_tmctsCheck(false)
130#endif
[1321]131#if NH_MV
132  , m_highestTid(-1)
133  , m_targetDecLayerIdSetFileEmpty(true)
134#endif
[1313]135  {
136    for (UInt channelTypeIndex = 0; channelTypeIndex < MAX_NUM_CHANNEL_TYPE; channelTypeIndex++)
137    {
138      m_outputBitDepth[channelTypeIndex] = 0;
139    }
[1356]140#if NH_3D
141    m_pchScaleOffsetFile = NULL;
142#endif
[1313]143  }
144
[2]145  virtual ~TAppDecCfg() {}
[1313]146
[1386]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
[2]151};
152
[56]153//! \}
154
[2]155#endif
156
157
Note: See TracBrowser for help on using the repository browser.