source: 3DVCSoftware/branches/HTM-5.1-dev1-Samsung/source/Lib/TLibCommon/TComRom.h @ 1288

Last change on this file since 1288 was 266, checked in by samsung-htm, 12 years ago

Integration of C0096, Removal of DMM2.
Commit carried out by Gerhard on behalf of Ilsoon using the Samsung account.

  • Property svn:eol-style set to native
File size: 15.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-2012, 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     TComRom.h
35    \brief    global variables & functions (header)
36*/
37
38#ifndef __TCOMROM__
39#define __TCOMROM__
40
41#include "CommonDef.h"
42
43#include<stdio.h>
44#include<iostream>
45
46#if HHI_DMM_WEDGE_INTRA || HHI_DMM_PRED_TEX
47#include "TComWedgelet.h"
48#endif
49
50//! \ingroup TLibCommon
51//! \{
52
53// ====================================================================================================================
54// Macros
55// ====================================================================================================================
56
57#define     MAX_CU_DEPTH            7                           // log2(LCUSize)
58#define     MAX_CU_SIZE             (1<<(MAX_CU_DEPTH))         // maximum allowable size of CU
59#define     MIN_PU_SIZE             4
60#define     MAX_NUM_SPU_W           (MAX_CU_SIZE/MIN_PU_SIZE)   // maximum number of SPU in horizontal line
61
62// ====================================================================================================================
63// Initialize / destroy functions
64// ====================================================================================================================
65
66Void         initROM();
67Void         destroyROM();
68Void         initFrameScanXY( UInt* pBuff, UInt* pBuffX, UInt* pBuffY, Int iWidth, Int iHeight );
69Void         initSigLastScan(UInt* pBuffZ, UInt* pBuffH, UInt* pBuffV, UInt* pBuffD, Int iWidth, Int iHeight, Int iDepth);
70Void         initNonSquareSigLastScan(UInt* pBuffZ, UInt uiWidth, UInt uiHeight);
71// ====================================================================================================================
72// Data structure related table & variable
73// ====================================================================================================================
74
75// flexible conversion from relative to absolute index
76extern       UInt   g_auiZscanToRaster[ MAX_NUM_SPU_W*MAX_NUM_SPU_W ];
77extern       UInt   g_auiRasterToZscan[ MAX_NUM_SPU_W*MAX_NUM_SPU_W ];
78extern       UInt   g_motionRefer[ MAX_NUM_SPU_W*MAX_NUM_SPU_W ];
79
80Void         initZscanToRaster ( Int iMaxDepth, Int iDepth, UInt uiStartVal, UInt*& rpuiCurrIdx );
81Void         initRasterToZscan ( UInt uiMaxCUWidth, UInt uiMaxCUHeight, UInt uiMaxDepth         );
82
83Void          initMotionReferIdx ( UInt uiMaxCUWidth, UInt uiMaxCUHeight, UInt uiMaxDepth );
84
85// conversion of partition index to picture pel position
86extern       UInt   g_auiRasterToPelX[ MAX_NUM_SPU_W*MAX_NUM_SPU_W ];
87extern       UInt   g_auiRasterToPelY[ MAX_NUM_SPU_W*MAX_NUM_SPU_W ];
88
89Void         initRasterToPelXY ( UInt uiMaxCUWidth, UInt uiMaxCUHeight, UInt uiMaxDepth );
90
91// global variable (LCU width/height, max. CU depth)
92extern       UInt g_uiMaxCUWidth;
93extern       UInt g_uiMaxCUHeight;
94extern       UInt g_uiMaxCUDepth;
95extern       UInt g_uiAddCUDepth;
96
97extern       UInt g_auiPUOffset[8];
98
99#define QUANT_IQUANT_SHIFT    20 // Q(QP%6) * IQ(QP%6) = 2^20
100#define QUANT_SHIFT           14 // Q(4) = 2^14
101#define SCALE_BITS            15 // Inherited from TMuC, pressumably for fractional bit estimates in RDOQ
102#define MAX_TR_DYNAMIC_RANGE  15 // Maximum transform dynamic range (excluding sign bit)
103
104#define SHIFT_INV_1ST          7 // Shift after first inverse transform stage
105#define SHIFT_INV_2ND         12 // Shift after second inverse transform stage
106
107extern Int g_quantScales[6];             // Q(QP%6) 
108extern Int g_invQuantScales[6];          // IQ(QP%6)
109extern const short g_aiT4[4][4];
110extern const short g_aiT8[8][8];
111extern const short g_aiT16[16][16];
112extern const short g_aiT32[32][32];
113
114// ====================================================================================================================
115// Luma QP to Chroma QP mapping
116// ====================================================================================================================
117
118extern const UChar  g_aucChromaScale      [52];
119
120// ====================================================================================================================
121// Scanning order & context mapping table
122// ====================================================================================================================
123
124extern       UInt*  g_auiFrameScanXY[ MAX_CU_DEPTH  ];    // raster index     from scanning index
125extern       UInt*  g_auiFrameScanX [ MAX_CU_DEPTH  ];    // raster index (x) from scanning index
126extern       UInt*  g_auiFrameScanY [ MAX_CU_DEPTH  ];    // raster index (y) from scanning index
127extern       UInt*  g_auiSigLastScan[4][ MAX_CU_DEPTH ];  // raster index from scanning index (zigzag, hor, ver, diag)
128extern UInt *g_sigScanNSQT[ 4 ]; // scan for non-square partitions
129extern UInt g_sigCGScanNSQT[ 4 ][ 16 ]; // coarse-grain scan for non-square partitions
130
131extern       UInt*  g_auiNonSquareSigLastScan[ 4 ];      // raster index from scanning index (zigzag)
132
133extern const UInt   g_uiGroupIdx[ 32 ];
134extern const UInt   g_uiMinInGroup[ 10 ];
135extern const UInt   g_uiLastCtx[ 28 ];
136
137#if EIGHT_BITS_RICE_CODE
138extern const UInt   g_auiGoRiceRange[5];                  //!< maximum value coded with Rice codes
139extern const UInt   g_auiGoRicePrefixLen[5];              //!< prefix length for each maximum value
140extern const UInt   g_aauiGoRiceUpdate[5][24];            //!< parameter update rules for Rice codes
141#else
142extern const UInt   g_auiGoRiceRange[4];                  //!< maximum value coded with Rice codes
143extern const UInt   g_auiGoRicePrefixLen[4];              //!< prefix length for each maximum value
144extern const UInt   g_aauiGoRiceUpdate[4][16];            //!< parameter update rules for Rice codes
145#endif
146 
147#if MULTILEVEL_SIGMAP_EXT
148extern const UInt   g_sigLastScan8x8[ 4 ][ 4 ];           //!< coefficient group scan order for 8x8 TUs
149extern       UInt   g_sigLastScanCG32x32[ 64 ];
150#endif
151
152// ====================================================================================================================
153// ADI table
154// ====================================================================================================================
155
156extern const UChar  g_aucIntraModeNumFast[7];
157
158// ====================================================================================================================
159// Angular Intra table
160// ====================================================================================================================
161
162extern const UChar g_aucIntraModeNumAng[7];
163extern const UChar g_aucIntraModeBitsAng[7];
164extern const UChar g_aucAngIntraModeOrder[NUM_INTRA_MODE];
165
166// ====================================================================================================================
167// Bit-depth
168// ====================================================================================================================
169
170extern       UInt g_uiBitDepth;
171extern       UInt g_uiBitIncrement;
172extern       UInt g_uiIBDI_MAX;
173extern       UInt g_uiBASE_MAX;
174extern       UInt g_uiPCMBitDepthLuma;
175extern       UInt g_uiPCMBitDepthChroma;
176
177// ====================================================================================================================
178// Texture type to integer mapping
179// ====================================================================================================================
180
181extern const UChar g_aucConvertTxtTypeToIdx[4];
182
183// ====================================================================================================================
184// Depth model modes
185// ====================================================================================================================
186#if HHI_DMM_WEDGE_INTRA || HHI_DMM_PRED_TEX
187extern       Int             g_iDeltaDCsQuantOffset;
188extern const WedgeResolution g_aeWedgeResolutionList[5];
189extern const UChar           g_aucWedgeFullBitsListIdx[7];
190#if LGE_DMM3_SIMP_C0044
191extern const UChar           g_aucWedgeTexPredBitsListIdx[7];
192#endif
193extern const UChar           g_aucIntraSizeIdxToWedgeSize[7];
194
195extern       std::vector< std::vector<TComWedgelet> >  g_aacWedgeLists;
196extern       std::vector< std::vector<TComWedgeRef> >  g_aacWedgeRefLists;
197
198#if HHIQC_DMMFASTSEARCH_B0039
199extern       std::vector< std::vector< std::vector<UInt> > > g_aauiWdgLstM3;
200extern       std::vector< std::vector<TComWedgeNode> >       g_aacWedgeNodeLists;
201#endif
202
203#if RWTH_SDC_DLT_B0036
204#if SAIT_SDC_C0096
205#define RWTH_SDC_NUM_PRED_MODES 3
206#else
207#define RWTH_SDC_NUM_PRED_MODES 4
208#endif
209extern      UInt g_auiSDCPredModes[RWTH_SDC_NUM_PRED_MODES];
210#endif
211
212Void initWedgeLists();
213Void createWedgeList( UInt uiWidth, UInt uiHeight, std::vector<TComWedgelet> &racWedgeList, std::vector<TComWedgeRef> &racWedgeRefList, WedgeResolution eWedgeRes );
214Void addWedgeletToList( TComWedgelet cWedgelet, std::vector<TComWedgelet> &racWedgeList, std::vector<TComWedgeRef> &racWedgeRefList );
215
216#if DEFAULT_DC
217__inline Void mapDMMtoIntraMode(  UInt& dirMode ) { dirMode = (dirMode >= NUM_INTRA_MODE) ? DC_IDX : dirMode; }
218__inline Void mapDMMtoIntraMode(   Int& dirMode ) { dirMode = (dirMode >= NUM_INTRA_MODE) ? DC_IDX : dirMode; }
219#else
220__inline Void mapDMMtoIntraMode(  UInt& dirMode ) { dirMode = (dirMode >= NUM_INTRA_MODE) ? PLANAR_IDX : dirMode; }
221__inline Void mapDMMtoIntraMode(   Int& dirMode ) { dirMode = (dirMode >= NUM_INTRA_MODE) ? PLANAR_IDX : dirMode; }
222#endif
223#endif
224
225#if LGE_EDGE_INTRA_A0070
226__inline Void mapEdgeIntratoDC( UChar& curDir ) { curDir = (curDir >= EDGE_INTRA_IDX) ? DC_IDX : curDir; }
227__inline Void mapEdgeIntratoDC(  UInt& curDir ) { curDir = (curDir >= EDGE_INTRA_IDX) ? DC_IDX : curDir; }
228__inline Void mapEdgeIntratoDC(   Int& curDir ) { curDir = (curDir >= EDGE_INTRA_IDX) ? DC_IDX : curDir; }
229#endif
230
231// ==========================================
232// Mode-Dependent DST Matrices
233extern const short g_as_DST_MAT_4 [4][4];
234#if HHI_DMM_WEDGE_INTRA || HHI_DMM_PRED_TEX
235extern const UChar g_aucDCTDSTMode_Vert[NUM_INTRA_MODE+NUM_DMM_MODE];
236extern const UChar g_aucDCTDSTMode_Hor [NUM_INTRA_MODE+NUM_DMM_MODE];
237#else
238extern const UChar g_aucDCTDSTMode_Vert[NUM_INTRA_MODE];
239extern const UChar g_aucDCTDSTMode_Hor[NUM_INTRA_MODE];
240#endif
241// ==========================================
242
243// ====================================================================================================================
244// Misc.
245// ====================================================================================================================
246
247extern       Char   g_aucConvertToBit  [ MAX_CU_SIZE+1 ];   // from width to log2(width)-2
248
249#define ENC_DEC_TRACE 0
250
251
252#if ENC_DEC_TRACE
253extern FILE*  g_hTrace;
254extern Bool   g_bJustDoIt;
255extern const Bool g_bEncDecTraceEnable;
256extern const Bool g_bEncDecTraceDisable;
257extern UInt64 g_nSymbolCounter;
258
259#define COUNTER_START    1
260#define COUNTER_END      0 //( UInt64(1) << 63 )
261
262#define DTRACE_CABAC_F(x)     if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%f", x );
263#define DTRACE_CABAC_V(x)     if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%d", x );
264#define DTRACE_CABAC_VL(x)    if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%lld", x );
265#define DTRACE_CABAC_T(x)     if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%s", x );
266#define DTRACE_CABAC_X(x)     if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "%x", x );
267#define DTRACE_CABAC_R( x,y ) if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, x,    y );
268#define DTRACE_CABAC_N        if ( ( g_nSymbolCounter >= COUNTER_START && g_nSymbolCounter <= COUNTER_END )|| g_bJustDoIt ) fprintf( g_hTrace, "\n"    );
269
270#else
271
272#define DTRACE_CABAC_F(x)
273#define DTRACE_CABAC_V(x)
274#define DTRACE_CABAC_VL(x)
275#define DTRACE_CABAC_T(x)
276#define DTRACE_CABAC_X(x)
277#define DTRACE_CABAC_R( x,y )
278#define DTRACE_CABAC_N
279
280#endif
281
282
283#define SCALING_LIST_NUM 6         ///< list number for quantization matrix
284#define SCALING_LIST_NUM_32x32 2   ///< list number for quantization matrix 32x32
285#define SCALING_LIST_REM_NUM 6     ///< remainder of QP/6
286#define SCALING_LIST_START_VALUE 8 ///< start value for dpcm mode
287#define MAX_MATRIX_COEF_NUM 64     ///< max coefficient number for quantization matrix
288#define MAX_MATRIX_SIZE_NUM 8      ///< max size number for quantization matrix
289#if SCALING_LIST
290#define SCALING_LIST_DC 16         ///< default DC value
291#endif
292enum ScalingListDIR
293{
294  SCALING_LIST_SQT = 0,
295  SCALING_LIST_VER,
296  SCALING_LIST_HOR,
297  SCALING_LIST_DIR_NUM
298};
299enum ScalingListSize
300{
301  SCALING_LIST_4x4 = 0,
302  SCALING_LIST_8x8,
303  SCALING_LIST_16x16,
304  SCALING_LIST_32x32,
305  SCALING_LIST_SIZE_NUM
306};
307static const char MatrixType[4][6][20] =
308{
309  {
310  "INTRA4X4_LUMA",
311  "INTRA4X4_CHROMAU",
312  "INTRA4X4_CHROMAV",
313  "INTER4X4_LUMA",
314  "INTER4X4_CHROMAU",
315  "INTER4X4_CHROMAV"
316  },
317  {
318  "INTRA8X8_LUMA",
319  "INTRA8X8_CHROMAU", 
320  "INTRA8X8_CHROMAV", 
321  "INTER8X8_LUMA",
322  "INTER8X8_CHROMAU", 
323  "INTER8X8_CHROMAV" 
324  },
325  {
326  "INTRA16X16_LUMA",
327  "INTRA16X16_CHROMAU", 
328  "INTRA16X16_CHROMAV", 
329  "INTER16X16_LUMA",
330  "INTER16X16_CHROMAU", 
331  "INTER16X16_CHROMAV" 
332  },
333  {
334  "INTRA32X32_LUMA",
335  "INTER32X32_LUMA",
336  },
337};
338#if SCALING_LIST
339static const char MatrixType_DC[4][12][22] =
340{
341  {
342  },
343  {
344  },
345  {
346  "INTRA16X16_LUMA_DC",
347  "INTRA16X16_CHROMAU_DC", 
348  "INTRA16X16_CHROMAV_DC", 
349  "INTER16X16_LUMA_DC",
350  "INTER16X16_CHROMAU_DC", 
351  "INTER16X16_CHROMAV_DC" 
352  },
353  {
354  "INTRA32X32_LUMA_DC",
355  "INTER32X32_LUMA_DC",
356  },
357};
358#endif
359extern Int g_quantIntraDefault4x4[16];
360extern Int g_quantIntraDefault8x8[64];
361extern Int g_quantIntraDefault16x16[256];
362extern Int g_quantIntraDefault32x32[1024];
363extern Int g_quantInterDefault4x4[16];
364extern Int g_quantInterDefault8x8[64];
365extern Int g_quantInterDefault16x16[256];
366extern Int g_quantInterDefault32x32[1024];
367extern UInt g_scalingListSize [SCALING_LIST_SIZE_NUM];
368extern UInt g_scalingListSizeX[SCALING_LIST_SIZE_NUM];
369extern UInt g_scalingListNum  [SCALING_LIST_SIZE_NUM];
370extern Int  g_eTTable[4];
371//! \}
372
373#endif  //__TCOMROM__
374
Note: See TracBrowser for help on using the repository browser.