source: SHVCSoftware/branches/SHM-dev/source/App/TAppDecoder/TAppDecCfg.h @ 1606

Last change on this file since 1606 was 1549, checked in by seregin, 9 years ago

port rev 4732, update copyright notice to include 2016

  • Property svn:eol-style set to native
File size: 6.8 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-2016, 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
48//! \ingroup TAppDecoder
49//! \{
50
51// ====================================================================================================================
52// Class definition
53// ====================================================================================================================
54
55/// Decoder configuration class
56class TAppDecCfg
57{
58protected:
59  std::string   m_bitstreamFileName;                    ///< input bitstream file name
60#if SVC_EXTENSION
61  std::string   m_reconFileName[MAX_LAYERS];            ///< output reconstruction file name
62#else
63  std::string   m_reconFileName;                        ///< output reconstruction file name
64#endif
65  Int           m_iSkipFrame;                           ///< counter for frames prior to the random access point to skip
66#if SVC_EXTENSION
67  Int           m_outputBitDepth[MAX_LAYERS][MAX_NUM_CHANNEL_TYPE]; ///< bit depth used for writing output
68#else
69  Int           m_outputBitDepth[MAX_NUM_CHANNEL_TYPE]; ///< bit depth used for writing output
70#endif
71  InputColourSpaceConversion m_outputColourSpaceConvert;
72
73  Int           m_iMaxTemporalLayer;                  ///< maximum temporal layer to be decoded
74  Int           m_decodedPictureHashSEIEnabled;       ///< Checksum(3)/CRC(2)/MD5(1)/disable(0) acting on decoded picture hash SEI message
75  Bool          m_decodedNoDisplaySEIEnabled;         ///< Enable(true)/disable(false) writing only pictures that get displayed based on the no display SEI message
76  std::string   m_colourRemapSEIFileName;             ///< output Colour Remapping file name
77  std::vector<Int> m_targetDecLayerIdSet;             ///< set of LayerIds to be included in the sub-bitstream extraction process.
78  Int           m_respectDefDispWindow;               ///< Only output content inside the default display window
79#if O0043_BEST_EFFORT_DECODING
80  UInt          m_forceDecodeBitDepth;                ///< if non-zero, force the bit depth at the decoder (best effort decoding)
81#endif
82  std::string   m_outputDecodedSEIMessagesFilename;   ///< filename to output decoded SEI messages to. If '-', then use stdout. If empty, do not output details.
83  Bool          m_bClipOutputVideoToRec709Range;      ///< If true, clip the output video to the Rec 709 range on saving.
84
85#if SVC_EXTENSION
86#if AVC_BASE
87  std::string   m_reconFileNameBL;                     ///< input BL reconstruction file name
88#endif
89  CommonDecoderParams             m_commonDecoderParams;
90#if CONFORMANCE_BITSTREAM_MODE
91  Bool          m_confModeFlag;
92  std::string   m_confPrefix;
93  std::string   m_metadataFileName;
94  Bool          m_metadataFileRefresh;
95  std::string   m_decodedYuvLayerFileName[63];
96  Bool          m_decodedYuvLayerRefresh[63];
97#endif
98#endif
99
100public:
101  TAppDecCfg()
102  : m_bitstreamFileName()
103#if !SVC_EXTENSION
104  , m_reconFileName()
105#endif
106  , m_iSkipFrame(0)
107  // m_outputBitDepth array initialised below
108  , m_outputColourSpaceConvert(IPCOLOURSPACE_UNCHANGED)
109  , m_iMaxTemporalLayer(-1)
110  , m_decodedPictureHashSEIEnabled(0)
111  , m_decodedNoDisplaySEIEnabled(false)
112  , m_colourRemapSEIFileName()
113  , m_targetDecLayerIdSet()
114  , m_respectDefDispWindow(0)
115#if O0043_BEST_EFFORT_DECODING
116  , m_forceDecodeBitDepth(0)
117#endif
118  , m_outputDecodedSEIMessagesFilename()
119  , m_bClipOutputVideoToRec709Range(false)
120  {
121#if SVC_EXTENSION
122    for( Int layerId = 0; layerId < MAX_LAYERS; layerId++ )
123    {
124      for( UInt channelTypeIndex = 0; channelTypeIndex < MAX_NUM_CHANNEL_TYPE; channelTypeIndex++ )
125      {
126        m_outputBitDepth[layerId][channelTypeIndex] = 0;
127      }
128    }
129#else
130    for (UInt channelTypeIndex = 0; channelTypeIndex < MAX_NUM_CHANNEL_TYPE; channelTypeIndex++)
131    {
132      m_outputBitDepth[channelTypeIndex] = 0;
133    }
134#endif
135  }
136
137  virtual ~TAppDecCfg() {}
138
139  Bool  parseCfg        ( Int argc, TChar* argv[] );   ///< initialize option class from configuration
140
141#if SVC_EXTENSION
142  CommonDecoderParams* getCommonDecoderParams() {return &m_commonDecoderParams;}
143
144#if CONFORMANCE_BITSTREAM_MODE
145  Bool        getConfModeFlag() const        { return m_confModeFlag;       }
146  std::string getConfPrefix() const          { return m_confPrefix;         }
147  std::string getMetadataFileName() const    { return m_metadataFileName;   }
148  Bool        getMetadataFileRefresh() const {return m_metadataFileRefresh; }
149
150  std::string getDecodedYuvLayerFileName(Int layerId) const        { return m_decodedYuvLayerFileName[layerId]; }
151  Bool        getDecodedYuvLayerRefresh(const Int layerId) const   { return m_decodedYuvLayerRefresh[layerId];  }
152
153  Void setMetadataFileRefresh(const Bool x)                        { m_metadataFileRefresh = x;              }
154  Void setDecodedYuvLayerFileName(Int layerId, std::string x)      { m_decodedYuvLayerFileName[layerId] = x; }
155  Void setDecodedYuvLayerRefresh(const Int layerId, const Bool x)  { m_decodedYuvLayerRefresh[layerId] = x;  }
156#endif
157#endif
158
159};
160
161//! \}
162
163#endif
164
165
Note: See TracBrowser for help on using the repository browser.