source: 3DVCSoftware/branches/HTM-16.0-MV-draft-5/source/Lib/TLibCommon/TComRom.h

Last change on this file was 1390, checked in by tech, 9 years ago

Removed 3D.

  • Property svn:eol-style set to native
File size: 12.7 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-2015, 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/** \file     TComRom.h
34    \brief    global variables & functions (header)
35*/
36#ifndef __TCOMROM__
37#define __TCOMROM__
38#include "CommonDef.h"
39#include<stdio.h>
40#include<iostream>
41//! \ingroup TLibCommon
42//! \{
43// ====================================================================================================================
44// Initialize / destroy functions
45// ====================================================================================================================
46Void         initROM();
47Void         destroyROM();
48// ====================================================================================================================
49// Data structure related table & variable
50// ====================================================================================================================
51// flexible conversion from relative to absolute index
52extern       UInt   g_auiZscanToRaster[ MAX_NUM_PART_IDXS_IN_CTU_WIDTH*MAX_NUM_PART_IDXS_IN_CTU_WIDTH ];
53extern       UInt   g_auiRasterToZscan[ MAX_NUM_PART_IDXS_IN_CTU_WIDTH*MAX_NUM_PART_IDXS_IN_CTU_WIDTH ];
54extern       UInt*  g_scanOrder[SCAN_NUMBER_OF_GROUP_TYPES][SCAN_NUMBER_OF_TYPES][ MAX_CU_DEPTH ][ MAX_CU_DEPTH ];
55Void         initZscanToRaster ( Int iMaxDepth, Int iDepth, UInt uiStartVal, UInt*& rpuiCurrIdx );
56Void         initRasterToZscan ( UInt uiMaxCUWidth, UInt uiMaxCUHeight, UInt uiMaxDepth         );
57// conversion of partition index to picture pel position
58extern       UInt   g_auiRasterToPelX[ MAX_NUM_PART_IDXS_IN_CTU_WIDTH*MAX_NUM_PART_IDXS_IN_CTU_WIDTH ];
59extern       UInt   g_auiRasterToPelY[ MAX_NUM_PART_IDXS_IN_CTU_WIDTH*MAX_NUM_PART_IDXS_IN_CTU_WIDTH ];
60Void         initRasterToPelXY ( UInt uiMaxCUWidth, UInt uiMaxCUHeight, UInt uiMaxDepth );
61extern const UInt g_auiPUOffset[NUMBER_OF_PART_SIZES];
62extern const Int g_quantScales[SCALING_LIST_REM_NUM];             // Q(QP%6)
63extern const Int g_invQuantScales[SCALING_LIST_REM_NUM];          // IQ(QP%6)
64#if RExt__HIGH_PRECISION_FORWARD_TRANSFORM
65static const Int g_transformMatrixShift[TRANSFORM_NUMBER_OF_DIRECTIONS] = { 14, 6 };
66#else
67static const Int g_transformMatrixShift[TRANSFORM_NUMBER_OF_DIRECTIONS] = {  6, 6 };
68#endif
69extern const TMatrixCoeff g_aiT4 [TRANSFORM_NUMBER_OF_DIRECTIONS][4][4];
70extern const TMatrixCoeff g_aiT8 [TRANSFORM_NUMBER_OF_DIRECTIONS][8][8];
71extern const TMatrixCoeff g_aiT16[TRANSFORM_NUMBER_OF_DIRECTIONS][16][16];
72extern const TMatrixCoeff g_aiT32[TRANSFORM_NUMBER_OF_DIRECTIONS][32][32];
73// ====================================================================================================================
74// Luma QP to Chroma QP mapping
75// ====================================================================================================================
76static const Int chromaQPMappingTableSize = 58;
77extern const UChar  g_aucChromaScale[NUM_CHROMA_FORMAT][chromaQPMappingTableSize];
78// ====================================================================================================================
79// Scanning order & context mapping table
80// ====================================================================================================================
81extern const UInt   ctxIndMap4x4[4*4];
82extern const UInt   g_uiGroupIdx[ MAX_TU_SIZE ];
83extern const UInt   g_uiMinInGroup[ LAST_SIGNIFICANT_GROUPS ];
84// ====================================================================================================================
85// Intra prediction table
86// ====================================================================================================================
87extern const UChar  g_aucIntraModeNumFast_UseMPM[MAX_CU_DEPTH];
88extern const UChar  g_aucIntraModeNumFast_NotUseMPM[MAX_CU_DEPTH];
89extern const UChar  g_chroma422IntraAngleMappingTable[NUM_INTRA_MODE];
90// ====================================================================================================================
91// Mode-Dependent DST Matrices
92// ====================================================================================================================
93extern const TMatrixCoeff g_as_DST_MAT_4 [TRANSFORM_NUMBER_OF_DIRECTIONS][4][4];
94#if NH_MV_HLS_PTL_LIMITS
95class TComGeneralTierAndLevelLimits
96{
97public:
98  TComGeneralTierAndLevelLimits::TComGeneralTierAndLevelLimits
99  ( Int maxLumaPs, 
100    Int maxCPBMainTier, 
101    Int maxCPBHighTier, 
102    Int maxSliceSegmentsPerPicture, 
103    Int maxTileRows, 
104    Int maxTileCols )
105  : m_maxLumaPs                 ( maxLumaPs                     ),
106    m_maxCPBMainTier            ( maxCPBMainTier                ),
107    m_maxCPBHighTier            ( maxCPBHighTier                ),
108    m_maxSliceSegmentsPerPicture( maxSliceSegmentsPerPicture    ),
109    m_maxTileRows               ( maxTileRows                   ),
110    m_maxTileCols               ( maxTileCols                   );
111  {};
112  Int getMaxLumaPs                 ( ) { return m_maxLumaPs                 ; };
113  Int getMaxCPBMainTier            ( ) { return m_maxCPBMainTier            ; };
114  Int getMaxCPBHighTier            ( ) { return m_maxCPBHighTier            ; };
115  Int getMaxSliceSegmentsPerPicture( ) { return m_maxSliceSegmentsPerPicture; };
116  Int getMaxTileRows               ( ) { return m_maxTileRows               ; };
117  Int getMaxTileCols               ( ) { return m_maxTileCols               ; };
118private:
119  const Int m_maxLumaPs;
120  const Int m_maxCPBMainTier; 
121  const Int m_maxCPBHighTier;
122  const Int m_maxSliceSegmentsPerPicture; 
123  const Int m_maxTileRows; 
124  const Int m_maxTileCols; 
125};
126extern std::map< Level::Name, TComGeneralTierAndLevelLimits > g_generalTierAndLevelLimits;   
127#endif
128// ====================================================================================================================
129// Misc.
130// ====================================================================================================================
131extern       SChar   g_aucConvertToBit  [ MAX_CU_SIZE+1 ];   // from width to log2(width)-2
132#if NH_MV
133// Change later
134#ifndef ENC_DEC_TRACE
135#define ENC_DEC_TRACE 0
136#endif
137#endif
138#if ENC_DEC_TRACE
139extern FILE*  g_hTrace;
140extern Bool   g_bJustDoIt;
141extern const Bool g_bEncDecTraceEnable;
142extern const Bool g_bEncDecTraceDisable;
143extern Bool   g_HLSTraceEnable;
144extern UInt64 g_nSymbolCounter;
145#define COUNTER_START    1
146#define COUNTER_END      0 //( UInt64(1) << 63 )
147#define DTRACE_CABAC_F(x)     if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%f", x );
148#define DTRACE_CABAC_V(x)     if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%d", x );
149#define DTRACE_CABAC_VL(x)    if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%lld", x );
150#define DTRACE_CABAC_T(x)     if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%s", x );
151#define DTRACE_CABAC_X(x)     if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%x", x );
152#define DTRACE_CABAC_R( x,y ) if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, x,    y );
153#define DTRACE_CABAC_N        if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "\n"    );
154#if NH_MV_ENC_DEC_TRAC
155 extern Bool   g_traceCU; 
156 extern Bool   g_tracePU ; 
157 extern Bool   g_traceTU; 
158 extern Bool   g_disableHLSTrace;       // USE g_HLSTraceEnable to toggle HLS trace. Not this one!
159 extern Bool   g_disableNumbering;      // Don't print numbers to trace file
160 extern UInt64 g_stopAtCounter;         // Counter to set breakpoint.
161 extern Bool   g_traceCopyBack;         // Output samples on copy back 
162 extern Bool   g_decTraceDispDer;       // Trace derived disparity vectors (decoder only)
163 extern Bool   g_decTraceMvFromMerge;   // Trace motion vectors obtained from merge (decoder only)
164 extern Bool   g_decTracePicOutput;     // Trace output of pictures
165 extern Bool   g_startStopTrace;             // Stop at position
166 extern Bool   g_outputPos;             // Output position
167 extern Bool   g_traceCameraParameters; // Trace camera parameters
168 extern Bool   g_encNumberOfWrittenBits;// Trace number of written bits
169 extern Bool   g_traceEncFracBits;      // Trace fractional bits
170 extern Bool   g_traceIntraSearchCost;  // Trace intra mode cost
171 extern Bool   g_traceRDCost;         
172 extern Bool   g_traceModeCheck; 
173 extern Bool   g_traceSAOCost; 
174 extern UInt   g_indent; 
175extern Bool   g_traceMotionInfoBeforUniPred; 
176 extern Bool   g_traceMergeCandListConst; 
177 extern Bool   g_traceSubPBMotion; 
178 extern Bool   g_traceBitsRead;
179#define DTRACE_CU(x,y)             writeToTraceFile( x,y, g_traceCU );
180#define DTRACE_PU(x,y)             writeToTraceFile( x,y, g_tracePU );
181#define DTRACE_TU(x,y)             writeToTraceFile( x,y, g_traceTU );
182#define DTRACE_CU_S(x)             writeToTraceFile( x,   g_traceCU );
183#define DTRACE_PU_S(x)             writeToTraceFile( x,   g_tracePU );
184#define DTRACE_TU_S(x)             writeToTraceFile( x,   g_traceTU );
185#define D_DEC_INDENT( b )            decIndent        ( b );
186#define D_PRINT_INC_INDENT( b, str ) prinStrIncIndent( b, str );
187#define D_PRINT_INDENT( b, str )     printStrIndent   ( b, str);
188 Void           tracePSHeader   ( const TChar* psName, Int layerId ); 
189 Void           writeToTraceFile( const TChar* symbolName, Int val, Bool doIt );
190 Void           writeToTraceFile( const TChar* symbolName, Bool doIt );
191 UInt64         incSymbolCounter();         
192 Void           stopAtPos       ( Int poc, Int layerId, Int cuPelX, Int cuPelY, Int cuWidth, Int cuHeight );           
193 Void           printStr         ( std::string str );
194 Void           printStrIndent   ( Bool b, std::string str );
195 Void           prinStrIncIndent ( Bool b, std::string str );
196 Void           decIndent        ( Bool b );
197 template <typename T>
198 std::string n2s ( T Number )
199 {
200   std::ostringstream ss;
201   ss << Number;
202   return ss.str();
203 };
204#endif
205#else
206#define DTRACE_CABAC_F(x)
207#define DTRACE_CABAC_V(x)
208#define DTRACE_CABAC_VL(x)
209#define DTRACE_CABAC_T(x)
210#define DTRACE_CABAC_X(x)
211#define DTRACE_CABAC_R( x,y )
212#define DTRACE_CABAC_N
213#if NH_MV
214#define DTRACE_CU(x,y) ;             
215#define DTRACE_PU(x,y) ;           
216#define DTRACE_TU(x,y) ;           
217#define DTRACE_CU_S(x) ;           
218#define DTRACE_PU_S(x) ;           
219#define DTRACE_TU_S(x) ;           
220#define D_DEC_INDENT( b ) ;
221#define D_PRINT_INC_INDENT( b, str );
222#define D_PRINT_INDENT( b, str );
223#endif
224#endif
225const TChar* nalUnitTypeToString(NalUnitType type);
226
227extern const TChar *MatrixType[SCALING_LIST_SIZE_NUM][SCALING_LIST_NUM];
228extern const TChar *MatrixType_DC[SCALING_LIST_SIZE_NUM][SCALING_LIST_NUM];
229extern const Int g_quantTSDefault4x4[4*4];
230extern const Int g_quantIntraDefault8x8[8*8];
231extern const Int g_quantInterDefault8x8[8*8];
232extern const UInt g_scalingListSize [SCALING_LIST_SIZE_NUM];
233extern const UInt g_scalingListSizeX[SCALING_LIST_SIZE_NUM];
234//! \}
235#endif  //__TCOMROM__
Note: See TracBrowser for help on using the repository browser.