source: 3DVCSoftware/branches/HTM-10.0rc1-dev0/source/Lib/TLibCommon/TypeDef.h @ 840

Last change on this file since 840 was 840, checked in by tech, 10 years ago

Further fixes.

  • Property svn:eol-style set to native
File size: 36.0 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-2014, 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     TypeDef.h
35    \brief    Define basic types, new types and enumerations
36*/
37
38#ifndef _TYPEDEF__
39#define _TYPEDEF__
40
41//! \ingroup TLibCommon
42//! \{
43/////////////////////////////////////////////////////////////////////////////////////////
44///////////////////////////////// EXTENSION SELECTION /////////////////////////////////// 
45/////////////////////////////////////////////////////////////////////////////////////////
46
47/* HEVC_EXT might be defined by compiler/makefile options.
48   
49   Linux makefiles support the following settings:   
50   make             -> HEVC_EXT not defined   
51   make HEVC_EXT=0  -> H_MV=0 H_3D=0   --> plain HM
52   make HEVC_EXT=1  -> H_MV=1 H_3D=0   --> MV only
53   make HEVC_EXT=2  -> H_MV=1 H_3D=1   --> full 3D
54*/
55
56#ifndef HEVC_EXT
57#define HEVC_EXT                    2
58#endif
59
60#if ( HEVC_EXT < 0 )||( HEVC_EXT > 2 )
61#error HEVC_EXT must be in the range of 0 to 2, inclusive.
62#endif
63
64#define H_MV          ( HEVC_EXT != 0)
65#define H_3D          ( HEVC_EXT == 2)
66
67
68/////////////////////////////////////////////////////////////////////////////////////////
69///////////////////////////////////   MAJOR DEFINES   /////////////////////////////////// 
70/////////////////////////////////////////////////////////////////////////////////////////
71
72#if H_MV
73#define H_MV_ENC_DEC_TRAC                 1  //< CU/PU level tracking
74#endif
75
76#if H_3D
77#define H_3D_QTLPC                        1   // OL_QTLIMIT_PREDCODING_B0068 //JCT3V-B0068
78                                              // HHI_QTLPC_RAU_OFF_C0160     // JCT3V-C0160 change 2: quadtree limitation and predictive coding switched off in random access units
79
80#define H_3D_VSO                          1   // VSO, View synthesis optimization, includes:
81                                              // HHI_VSO
82                                              // HHI_VSO_LS_TABLE_M23714 enable table base Lagrange multiplier optimization
83                                              // SAIT_VSO_EST_A0033, JCT3V-A0033 modification 3
84                                              // LGE_WVSO_A0119
85#define H_3D_NBDV                         1   // Neighboring block disparity derivation
86                                              // QC_JCT3V-A0097
87                                              // LGE_DVMCP_A0126
88                                              // LGE_DVMCP_MEM_REDUCTION_B0135     
89                                              // QC_SIMPLE_NBDV_B0047
90                                              // FIX_LGE_DVMCP_B0133
91                                              // QC_NBDV_LDB_FIX_C0055
92                                              // MTK_SAIT_TEMPORAL_FIRST_ORDER_C0141_C0097
93                                              // MTK_SIMPLIFY_DVTC_C0135           
94                                              // QC_CU_NBDV_D0181
95                                              // SEC_DEFAULT_DV_D0112
96                                              // MTK_DVMCP_FIX_E0172       fix the mismatch between software and WD for DV derivation from DVMCP blocks, issue 2 in JCT3V-E0172
97                                              // SEC_SIMPLIFIED_NBDV_E0142 Simplified NBDV, JCT3V-E0142 and JCT3V-E0190
98                                              // MTK_NBDV_TN_FIX_E0172     fix the issue of DV derivation from the temporal neighboring blocks, issue 7 in JCT3V-E0172
99                                              // MTK_TEXTURE_MRGCAND_BUGFIX_E0182  Bug fix for TEXTURE MERGING CANDIDATE     , JCT3V-E0182
100#define H_3D_ARP                          1   // Advanced residual prediction (ARP), JCT3V-D0177
101                                              // QC_MTK_INTERVIEW_ARP_F0123_F0108 JCT3V-F0123; JCT3V-F0108
102                                              // SHARP_ARP_REF_CHECK_F0105        ARP reference picture selection and DPB check
103                                              // LGE_ARP_CTX_F0161                JCT3V-F0161
104#define H_3D_IC                           1   // Illumination Compensation, JCT3V-B0045, JCT3V-C0046, JCT3V-D0060
105                                              // Unifying rounding offset, for IC part, JCT3V-D0135
106                                              // Full Pel Interpolation for Depth, HHI_FULL_PEL_DEPTH_MAP_MV_ACC
107                                              // SHARP_ILLUCOMP_REFINE_E0046
108                                              // MTK_CLIPPING_ALIGN_IC_E0168       // To support simplify bi-prediction PU with identical motion checking, JCT3V-E0168
109                                              // LGE_IC_CTX_F0160 //JCT3V-F0160
110                                              // SEC_ONLY_TEXTURE_IC_F0151
111
112#if H_3D_NBDV
113#define H_3D_NBDV_REF                     1   // Depth oriented neighboring block disparity derivation
114                                              // MTK_D0156
115                                              // MERL_D0166: Reference view selection in NBDV & Bi-VSP
116                                              // MERL_C0152: Basic VSP
117                                              // NBDV_DEFAULT_VIEWIDX_BUGFIX Bug fix for invalid default view index for NBDV
118                                              // NTT_DoNBDV_VECTOR_CLIP_E0141 disparity vector clipping in DoNBDV, JCT3V-E0141 and JCT3V-E0209
119#endif
120
121#define H_3D_VSP                          1   // View synthesis prediction
122                                              // MERL_C0152: Basic VSP
123                                              // MERL_D0166: Reference view selection in NBDV & Bi-VSP
124                                              // MTK_D0105, LG_D0139: No VSP for depth
125                                              // QC_D0191: Clean up
126                                              // LG_D0092: Multiple VSP candidate allowed
127                                              // MTK_VSP_FIX_ALIGN_WD_E0172
128                                              // NTT_VSP_ADAPTIVE_SPLIT_E0207 adaptive sub-PU partitioning in VSP, JCT3V-E0207
129                                              // NTT_VSP_DC_BUGFIX_E0208 bugfix for sub-PU based DC in VSP, JCT3V-E0208
130                                              // NTT_VSP_COMMON_E0207_E0208 common part of JCT3V-E0207 and JCT3V-E0208
131                                              // MTK_F0109_LG_F0120_VSP_BLOCK MTK_LG_SIMPLIFY_VSP_BLOCK_PARTITION_F0109_F0120 
132                                              // SHARP_VSP_BLOCK_IN_AMP_F0102 VSP partitioning for AMP
133                                              // MTK_VSP_SIMPLIFICATION_F0111 1. Inherited VSP also use NBDV of current CU, 2. VSP cannot be inherited from above LCU rowss
134                                              // LGE_SHARP_VSP_INHERIT_F0104
135
136#define H_3D_IV_MERGE                     1   // Inter-view motion merge candidate
137                                              // HHI_INTER_VIEW_MOTION_PRED
138                                              // SAIT_IMPROV_MOTION_PRED_M24829, improved inter-view motion vector prediction
139                                              // QC_MRG_CANS_B0048             , JCT3V-B0048, B0086, B0069
140                                              // OL_DISMV_POS_B0069            , different pos for disparity MV candidate, B0069
141                                              // MTK_INTERVIEW_MERGE_A0049     , second part
142                                              // QC_AMVP_MRG_UNIFY_IVCAN_C0051     
143                                              // TEXTURE MERGING CANDIDATE     , JCT3V-C0137
144                                              // QC_INRIA_MTK_MRG_E0126
145                                              // ETRIKHU_MERGE_REUSE_F0093 QC_DEPTH_IV_MRG_F0125, JCT3V-F0125: Depth oriented Inter-view MV candidate
146                                              // EC_MPI_ENABLING_MERGE_F0150, MPI flag in VPS and enabling in Merge mode
147#define H_3D_TMVP                         1   // QC_TMVP_C0047
148                                              // Sony_M23639
149
150#define H_3D_DIM                          1   // DIM, Depth intra modes, includes:
151                                              // HHI_DMM_WEDGE_INTRA
152                                              // HHI_DMM_PRED_TEX
153                                              // FIX_WEDGE_NOFLOAT_D0036
154                                              // LGE_EDGE_INTRA_A0070
155                                              // LGE_DMM3_SIMP_C0044
156                                              // QC_DC_PREDICTOR_D0183
157                                              // HHI_DELTADC_DLT_D0035
158                                              // PKU_QC_DEPTH_INTRA_UNI_D0195
159                                              // RWTH_SDC_DLT_B0036
160                                              // INTEL_SDC64_D0193
161                                              // RWTH_SDC_CTX_SIMPL_D0032
162                                              // LGE_CONCATENATE_D0141
163                                              // FIX_SDC_ENC_RD_WVSO_D0163
164                                              // MTK_SAMPLE_BASED_SDC_D0110
165                                              // SEC_DMM2_E0146_HHIFIX Removal of DMM2 from DMMs
166                                              // ZJU_DEPTH_INTRA_MODE_E0204 Simplified Binarization for depth_intra_mode
167                                              // KWU_SDC_SIMPLE_DC_E0117 Simplified DC calculation for SDC
168                                              // SCU_HS_DMM4_REMOVE_DIV_E0242 DMM4 Division Removal
169                                              // LGE_SDC_REMOVE_DC_E0158 Removal of DC mode from SDC
170                                              // LGE_PKU_DMM3_OVERLAP_E0159_HHIFIX 1   Removal of overlap between DMM3 and DMM1
171                                              // LGE_PRED_RES_CODING_DLT_DOMAIN_F0159 JCT3V-F0159
172                                              // HHI_DIM_PREDSAMP_FIX_F0171
173                                              // SEC_DMM3_RBC_F0147 Removal of DMM3 and RBC from DMMs
174                                              // QC_DIM_DELTADC_UNIFY_F0132 Unify delta DC coding in depth intra modes
175
176#define H_3D_INTER_SDC                    1   // INTER SDC, Inter simplified depth coding
177                                              // LGE_INTER_SDC_E0156  Enable inter SDC for depth coding
178#define H_3D_SPIVMP                       1   // H_3D_SPIVMP    // JCT3V-F0110: Sub-PU level inter-view motion prediction
179#define H_3D_FCO                          0   // Flexible coding order for 3D
180
181
182
183// OTHERS
184                                              // MTK_SONY_PROGRESSIVE_MV_COMPRESSION_E0170 // Progressive MV Compression, JCT3V-E0170
185#define H_3D_REN_MAX_DEV_OUT              0   // Output maximal possible shift deviation
186#define H_3D_FAST_TEXTURE_ENCODING        1   // Fast merge mode decision and early CU determination for texture component of dependent view, JCT3V-E0173
187                                              // MTK_FAST_TEXTURE_ENCODING_E0173
188#if H_3D_DIM
189#define H_3D_FAST_DEPTH_INTRA             1   // Fast DMM and RBC Mode Selection
190                                              // SCU_HS_FAST_DEPTH_INTRA_E0238_HHIFIX
191#endif
192
193// Rate Control
194#define KWU_FIX_URQ                       1
195#define KWU_RC_VIEWRC_E0227               0  ///< JCT3V-E0227, view-wise target bitrate allocation
196#define KWU_RC_MADPRED_E0227              0  ///< JCT3V-E0227, inter-view MAD prediction
197
198#endif // H_3D
199
200
201
202/////////////////////////////////////////////////////////////////////////////////////////
203///////////////////////////////////   DERIVED DEFINES /////////////////////////////////// 
204/////////////////////////////////////////////////////////////////////////////////////////
205
206///// ***** VIEW SYNTHESIS OPTIMIZAION *********
207#if H_3D_VSO                                 
208#define H_3D_VSO_DIST_INT                 1   // Allow negative synthesized view distortion change
209#define H_3D_VSO_COLOR_PLANES             1   // Compute VSO distortion on color planes
210#define H_3D_VSO_EARLY_SKIP               1   // LGE_VSO_EARLY_SKIP_A0093, A0093 modification 4
211#define H_3D_VSO_RM_ASSERTIONS            0   // Output VSO assertions
212#define H_3D_VSO_SYNTH_DIST_OUT           0   // Output of synthesized view distortion instead of depth distortion in encoder output
213#define H_3D_VSO_FIX                      0   // This fix should be enabled after verification
214#endif
215
216////   ****** NEIGHBOURING BLOCK-BASED DISPARITY VECTOR  *********
217#if H_3D_NBDV
218#define DVFROM_LEFT                       0
219#define DVFROM_ABOVE                      1
220#define IDV_CANDS                         2
221#endif
222
223///// ***** ADVANCED INTERVIEW RESIDUAL PREDICTION *********
224#if H_3D_ARP
225#define H_3D_ARP_WFNR                     3
226#endif
227
228///// ***** DEPTH INTRA MODES *********
229#if H_3D_DIM
230#define H_3D_DIM_DMM                      1   // Depth Modeling Modes
231#define H_3D_DIM_SDC                      1   // Simplified Depth Coding method
232#define H_3D_DIM_DLT                      1   // Depth Lookup Table
233
234#if H_3D_DIM_DLT
235#define H_3D_DELTA_DLT                    1
236#endif
237#define H_3D_DIM_ENC                      1   // Depth Intra encoder optimizations, includes:
238                                              // HHI_DEPTH_INTRA_SEARCH_RAU_C0160
239                                              // LG_ZEROINTRADEPTHRESI_A0087
240#endif
241///// ***** VIEW SYNTHESIS PREDICTION *********
242#if H_3D_VSP
243#define H_3D_VSP_BLOCKSIZE                4   // Supported values: 1, 2, and 4
244#if H_3D_VSP_BLOCKSIZE == 1
245#define H_3D_VSP_CONSTRAINED              1   // Constrained VSP @ 1x1
246#else
247#define H_3D_VSP_CONSTRAINED              0
248#endif
249#endif
250
251
252///// ***** ILLUMATION COMPENSATION *********
253#if H_3D_IC
254#define IC_REG_COST_SHIFT                 7
255#define IC_CONST_SHIFT                    5
256#define IC_SHIFT_DIFF                     12
257#endif
258
259
260///// ***** FCO *********
261#if H_3D_FCO
262#define H_3D_FCO_VSP_DONBDV_E0163               1   // Adaptive depth reference for flexible coding order
263#else
264#define H_3D_FCO_VSP_DONBDV_E0163               0   // Adaptive depth reference for flexible coding order
265#endif
266
267#if H_3D
268#define PPS_FIX_DEPTH                           1
269#endif
270
271
272/////////////////////////////////////////////////////////////////////////////////////////
273///////////////////////////////////   HTM-10.0 Integrations //////////////////////////////
274/////////////////////////////////////////////////////////////////////////////////////////
275#if H_3D
276#if  H_3D_QTLPC
277#define MTK_TEX_DEP_PAR_G0055             1   // Texture-partition-dependent depth partition. JCT3V-G0055
278#endif
279
280#define MTK_DDD_G0063                     1   // Disparity derived depth coding
281
282#if H_3D_VSP
283#define MTK_RBIP_VSP_G0069                1   // Restricted bi-prediction for VSP
284#define NTT_STORE_SPDV_VSP_G0148          1   // Storing Sub-PU based DV for VSP
285#endif
286
287#define H_3D_DBBP                         1   // DBBP: Depth-based Block Partitioning and Merging
288
289#if H_3D_DBBP
290#define DBBP_INVALID_SHORT                (-4)
291#define RWTH_DBBP_PACK_MODE               SIZE_2NxN
292#endif
293
294#if H_3D_DIM
295#define QC_PKU_SDC_SPLIT_G0123            1   // Intra SDC Split
296#if QC_PKU_SDC_SPLIT_G0123
297#define HS_TSINGHUA_SDC_SPLIT_G0111       1
298#endif
299#define SCU_HS_DEPTH_DC_PRED_G0143        1
300#define QC_GENERIC_SDC_G0122              1  // Generalize SDC to all depth intra modes
301#if H_3D_DIM_SDC && H_3D_INTER_SDC
302#define QC_SDC_UNIFY_G0130                1  // Unify intra SDC and inter SDC
303#define QC_SDC_UNIFY_G0130_FIX            1  // Fix bug of G0130
304#define QC_SDC_UNIFY_G0130_FIX2           1  // Fix bug of G0130
305#endif
306#define SEC_INTER_SDC_G0101               1  // Improved inter SDC with multiple DC candidates
307#endif
308
309#define KHU_SIMP_SPIVMP_G0147             1  // Simplification on Sub-PU level temporal interview motion prediction
310
311#if H_3D_SPIVMP
312#define QC_SPIVMP_MPI_G0119               1 // Sub-PU level MPI merge candidate
313#endif
314
315#define QC_DEPTH_MERGE_SIMP_G0127         1 // Remove DV candidate and shifting candidate for depth coding
316#define SEC_IC_ARP_SIG_G0072              1   // Disabling IC when ARP is enabled, option 1 in JCT3V-G0072, part 2 in JCT3V-G0121
317#define SCU_HS_VSD_BUGFIX_IMPROV_G0163    1
318#define SEC_SPIVMP_MCP_SIZE_G0077         1  // Apply SPIVMP only to 2Nx2N partition, JCT3V-G0077
319#define SEC_DEPTH_DV_DERIVAITON_G0074     1  // Simplification of DV derivation for depth, JCT3V-G0074
320#define MTK_ARP_REF_SELECTION_G0053       1   // ARP Reference picture selection in JCT3V-G0053
321#define MTK_ARP_FLAG_CABAC_SIMP_G0061     1   // Use 2 context for ARP flag referring to only left neighbor block in JCT3V-G0061
322#define MTK_IC_FLAG_CABAC_SIMP_G0061      1   // Use only 1 context for IC flag in JCT3V-G0061
323#define MTK_NBDV_IVREF_FIX_G0067          1   // Disable IvMC, VSP when IVREF is not available, JCT3V-G0067
324#endif
325
326/////////////////////////////////////////////////////////////////////////////////////////
327///////////////////////////////////   HTM-10.1 Integrations //////////////////////////////
328/////////////////////////////////////////////////////////////////////////////////////////
329
330#define UPDATE_HM13                       1
331/////////////////////////////////////////////////////////////////////////////////////////
332///////////////////////////////////   HM RELATED DEFINES ////////////////////////////////
333/////////////////////////////////////////////////////////////////////////////////////////
334#define BUGFIX_INTRAPERIOD 1
335#define SAO_ENCODE_ALLOW_USE_PREDEBLOCK 1
336
337#define FIX1172 1 ///< fix ticket #1172
338
339#define MAX_NUM_PICS_IN_SOP           1024
340
341#define MAX_NESTING_NUM_OPS         1024
342#define MAX_NESTING_NUM_LAYER       64
343
344#define MAX_VPS_NUM_HRD_PARAMETERS                1
345#define MAX_VPS_OP_SETS_PLUS1                     1024
346#if H_MV
347#define MAX_VPS_NUH_LAYER_ID_PLUS1  63
348#define MAX_NUM_SCALABILITY_TYPES   16
349#define ENC_CFG_CONSOUT_SPACE       29           
350#else
351#define MAX_VPS_NUH_RESERVED_ZERO_LAYER_ID_PLUS1  1
352#endif
353
354
355#define MAX_CPB_CNT                     32  ///< Upper bound of (cpb_cnt_minus1 + 1)
356#if H_MV
357#define MAX_NUM_LAYER_IDS               63
358#define MAX_NUM_LAYERS                  63
359#define MAX_VPS_PROFILE_TIER_LEVEL      64
360#define MAX_VPS_ADD_OUTPUT_LAYER_SETS   1024
361#define MAX_VPS_OUTPUTLAYER_SETS        ( MAX_VPS_ADD_OUTPUT_LAYER_SETS + MAX_VPS_OP_SETS_PLUS1 )
362#define  MAX_NUM_VIDEO_SIGNAL_INFO      16
363#define MAX_NUM_SCALED_REF_LAYERS       MAX_NUM_LAYERS-1
364#define MAX_NUM_BSP_HRD_PARAMETERS      100 ///< Maximum value is actually not specified
365#define MAX_NUM_BITSTREAM_PARTITIONS    100 ///< Maximum value is actually not specified
366#define MAX_NUM_BSP_SCHED_COMBINATION   100 ///< Maximum value is actually not specified
367#else
368#define MAX_NUM_LAYER_IDS                64
369#endif
370
371#define COEF_REMAIN_BIN_REDUCTION        3 ///< indicates the level at which the VLC
372                                           ///< transitions from Golomb-Rice to TU+EG(k)
373
374#define CU_DQP_TU_CMAX 5                   ///< max number bins for truncated unary
375#define CU_DQP_EG_k 0                      ///< expgolomb order
376
377#define SBH_THRESHOLD                    4  ///< I0156: value of the fixed SBH controlling threshold
378 
379#define SEQUENCE_LEVEL_LOSSLESS           0  ///< H0530: used only for sequence or frame-level lossless coding
380
381#define DISABLING_CLIP_FOR_BIPREDME         1  ///< Ticket #175
382 
383#define C1FLAG_NUMBER               8 // maximum number of largerThan1 flag coded in one chunk :  16 in HM5
384#define C2FLAG_NUMBER               1 // maximum number of largerThan2 flag coded in one chunk:  16 in HM5
385#define SAO_ENCODING_CHOICE              1  ///< I0184: picture early termination
386#if SAO_ENCODING_CHOICE
387#define SAO_ENCODING_RATE                0.75
388#define SAO_ENCODING_CHOICE_CHROMA       1 ///< J0044: picture early termination Luma and Chroma are handled separately
389#if SAO_ENCODING_CHOICE_CHROMA
390#define SAO_ENCODING_RATE_CHROMA         0.5
391#endif
392#endif
393
394#define MAX_NUM_VPS                16
395#define MAX_NUM_SPS                16
396#define MAX_NUM_PPS                64
397
398#define RDOQ_CHROMA_LAMBDA          1   ///< F386: weighting of chroma for RDOQ
399
400#define MIN_SCAN_POS_CROSS          4
401
402#define FAST_BIT_EST                1   ///< G763: Table-based bit estimation for CABAC
403
404#define MLS_GRP_NUM                         64     ///< G644 : Max number of coefficient groups, max(16, 64)
405#define MLS_CG_SIZE                         4      ///< G644 : Coefficient group size of 4x4
406
407#define ADAPTIVE_QP_SELECTION               1      ///< G382: Adaptive reconstruction levels, non-normative part for adaptive QP selection
408#if ADAPTIVE_QP_SELECTION
409#define ARL_C_PRECISION                     7      ///< G382: 7-bit arithmetic precision
410#define LEVEL_RANGE                         30     ///< G382: max coefficient level in statistics collection
411#endif
412
413#define HHI_RQT_INTRA_SPEEDUP             1           ///< tests one best mode with full rqt
414#define HHI_RQT_INTRA_SPEEDUP_MOD         0           ///< tests two best modes with full rqt
415
416#if HHI_RQT_INTRA_SPEEDUP_MOD && !HHI_RQT_INTRA_SPEEDUP
417#error
418#endif
419
420#define VERBOSE_RATE 0 ///< Print additional rate information in encoder
421
422#define AMVP_DECIMATION_FACTOR            4
423
424#define SCAN_SET_SIZE                     16
425#define LOG2_SCAN_SET_SIZE                4
426
427#define FAST_UDI_MAX_RDMODE_NUM               35          ///< maximum number of RD comparison in fast-UDI estimation loop
428
429#define ZERO_MVD_EST                          0           ///< Zero Mvd Estimation in normal mode
430
431#define NUM_INTRA_MODE 36
432#if !REMOVE_LM_CHROMA
433#define LM_CHROMA_IDX  35
434#endif
435
436#define WRITE_BACK                      1           ///< Enable/disable the encoder to replace the deltaPOC and Used by current from the config file with the values derived by the refIdc parameter.
437#define AUTO_INTER_RPS                  1           ///< Enable/disable the automatic generation of refIdc from the deltaPOC and Used by current from the config file.
438#define PRINT_RPS_INFO                  0           ///< Enable/disable the printing of bits used to send the RPS.
439                                                    // using one nearest frame as reference frame, and the other frames are high quality (POC%4==0) frames (1+X)
440                                                    // this should be done with encoder only decision
441                                                    // but because of the absence of reference frame management, the related code was hard coded currently
442
443#define RVM_VCEGAM10_M 4
444
445#define PLANAR_IDX             0
446#define VER_IDX                26                    // index for intra VERTICAL   mode
447#define HOR_IDX                10                    // index for intra HORIZONTAL mode
448#define DC_IDX                 1                     // index for intra DC mode
449#define NUM_CHROMA_MODE        5                     // total number of chroma modes
450#define DM_CHROMA_IDX          36                    // chroma mode index for derived from luma intra mode
451
452
453#define FAST_UDI_USE_MPM 1
454
455#define RDO_WITHOUT_DQP_BITS              0           ///< Disable counting dQP bits in RDO-based mode decision
456
457#define FULL_NBIT 0 ///< When enabled, compute costs using full sample bitdepth.  When disabled, compute costs as if it is 8-bit source video.
458#if FULL_NBIT
459# define DISTORTION_PRECISION_ADJUSTMENT(x) 0
460#else
461# define DISTORTION_PRECISION_ADJUSTMENT(x) (x)
462#endif
463
464#define LOG2_MAX_NUM_COLUMNS_MINUS1        7
465#define LOG2_MAX_NUM_ROWS_MINUS1           7
466#define LOG2_MAX_COLUMN_WIDTH              13
467#define LOG2_MAX_ROW_HEIGHT                13
468
469#define MATRIX_MULT                             0   // Brute force matrix multiplication instead of partial butterfly
470
471#define REG_DCT 65535
472
473#define AMP_SAD                               1           ///< dedicated SAD functions for AMP
474#define AMP_ENC_SPEEDUP                       1           ///< encoder only speed-up by AMP mode skipping
475#if AMP_ENC_SPEEDUP
476#define AMP_MRG                               1           ///< encoder only force merge for AMP partition (no motion search for AMP)
477#endif
478
479#define CABAC_INIT_PRESENT_FLAG     1
480
481// ====================================================================================================================
482// Basic type redefinition
483// ====================================================================================================================
484
485typedef       void                Void;
486typedef       bool                Bool;
487
488#ifdef __arm__
489typedef       signed char         Char;
490#else
491typedef       char                Char;
492#endif
493typedef       unsigned char       UChar;
494typedef       short               Short;
495typedef       unsigned short      UShort;
496typedef       int                 Int;
497typedef       unsigned int        UInt;
498typedef       double              Double;
499typedef       float               Float;
500
501// ====================================================================================================================
502// 64-bit integer type
503// ====================================================================================================================
504
505#ifdef _MSC_VER
506typedef       __int64             Int64;
507
508#if _MSC_VER <= 1200 // MS VC6
509typedef       __int64             UInt64;   // MS VC6 does not support unsigned __int64 to double conversion
510#else
511typedef       unsigned __int64    UInt64;
512#endif
513
514#else
515
516typedef       long long           Int64;
517typedef       unsigned long long  UInt64;
518
519#endif
520
521// ====================================================================================================================
522// Type definition
523// ====================================================================================================================
524
525typedef       UChar           Pxl;        ///< 8-bit pixel type
526typedef       Short           Pel;        ///< 16-bit pixel type
527typedef       Int             TCoeff;     ///< transform coefficient
528
529#if H_3D_VSO
530// ====================================================================================================================
531// Define Distortion Types
532// ====================================================================================================================
533typedef       Int64           RMDist;     ///< renderer model distortion
534
535#if H_3D_VSO_DIST_INT
536typedef       Int64            Dist;       ///< RDO distortion
537typedef       Int64            Dist64; 
538#define       RDO_DIST_MIN     MIN_INT
539#define       RDO_DIST_MAX     MAX_INT
540#else
541typedef       UInt             Dist;       ///< RDO distortion
542typedef       UInt64           Dist; 
543#define       RDO_DIST_MIN     0
544#define       RDO_DIST_MAX     MAX_UINT
545#endif
546#endif
547/// parameters for adaptive loop filter
548class TComPicSym;
549
550// Slice / Slice segment encoding modes
551enum SliceConstraint
552{
553  NO_SLICES              = 0,          ///< don't use slices / slice segments
554  FIXED_NUMBER_OF_LCU    = 1,          ///< Limit maximum number of largest coding tree blocks in a slice / slice segments
555  FIXED_NUMBER_OF_BYTES  = 2,          ///< Limit maximum number of bytes in a slice / slice segment
556  FIXED_NUMBER_OF_TILES  = 3,          ///< slices / slice segments span an integer number of tiles
557};
558
559enum SAOComponentIdx
560{
561  SAO_Y =0,
562  SAO_Cb,
563  SAO_Cr,
564  NUM_SAO_COMPONENTS
565};
566
567enum SAOMode //mode
568{
569  SAO_MODE_OFF = 0,
570  SAO_MODE_NEW,
571  SAO_MODE_MERGE,
572  NUM_SAO_MODES
573};
574
575enum SAOModeMergeTypes
576{
577  SAO_MERGE_LEFT =0,
578  SAO_MERGE_ABOVE,
579  NUM_SAO_MERGE_TYPES
580};
581
582
583enum SAOModeNewTypes
584{
585  SAO_TYPE_START_EO =0,
586  SAO_TYPE_EO_0 = SAO_TYPE_START_EO,
587  SAO_TYPE_EO_90,
588  SAO_TYPE_EO_135,
589  SAO_TYPE_EO_45,
590
591  SAO_TYPE_START_BO,
592  SAO_TYPE_BO = SAO_TYPE_START_BO,
593
594  NUM_SAO_NEW_TYPES
595};
596#define NUM_SAO_EO_TYPES_LOG2 2
597
598enum SAOEOClasses
599{
600  SAO_CLASS_EO_FULL_VALLEY = 0,
601  SAO_CLASS_EO_HALF_VALLEY = 1,
602  SAO_CLASS_EO_PLAIN       = 2,
603  SAO_CLASS_EO_HALF_PEAK   = 3,
604  SAO_CLASS_EO_FULL_PEAK   = 4,
605  NUM_SAO_EO_CLASSES,
606};
607
608
609#define NUM_SAO_BO_CLASSES_LOG2  5
610enum SAOBOClasses
611{
612  //SAO_CLASS_BO_BAND0 = 0,
613  //SAO_CLASS_BO_BAND1,
614  //SAO_CLASS_BO_BAND2,
615  //...
616  //SAO_CLASS_BO_BAND31,
617
618  NUM_SAO_BO_CLASSES = (1<<NUM_SAO_BO_CLASSES_LOG2),
619};
620#define MAX_NUM_SAO_CLASSES  32  //(NUM_SAO_EO_GROUPS > NUM_SAO_BO_GROUPS)?NUM_SAO_EO_GROUPS:NUM_SAO_BO_GROUPS
621
622struct SAOOffset
623{
624  Int modeIdc; //NEW, MERGE, OFF
625  Int typeIdc; //NEW: EO_0, EO_90, EO_135, EO_45, BO. MERGE: left, above
626  Int typeAuxInfo; //BO: starting band index
627  Int offset[MAX_NUM_SAO_CLASSES];
628
629  SAOOffset();
630  ~SAOOffset();
631  Void reset();
632
633  const SAOOffset& operator= (const SAOOffset& src);
634};
635
636struct SAOBlkParam
637{
638
639  SAOBlkParam();
640  ~SAOBlkParam();
641  Void reset();
642  const SAOBlkParam& operator= (const SAOBlkParam& src);
643  SAOOffset& operator[](Int compIdx){ return offsetParam[compIdx];}
644private:
645  SAOOffset offsetParam[NUM_SAO_COMPONENTS];
646
647};
648
649/// parameters for deblocking filter
650typedef struct _LFCUParam
651{
652  Bool bInternalEdge;                     ///< indicates internal edge
653  Bool bLeftEdge;                         ///< indicates left edge
654  Bool bTopEdge;                          ///< indicates top edge
655} LFCUParam;
656
657// ====================================================================================================================
658// Enumeration
659// ====================================================================================================================
660
661/// supported slice type
662enum SliceType
663{
664  B_SLICE,
665  P_SLICE,
666  I_SLICE
667};
668
669/// chroma formats (according to semantics of chroma_format_idc)
670enum ChromaFormat
671{
672  CHROMA_400  = 0,
673  CHROMA_420  = 1,
674  CHROMA_422  = 2,
675  CHROMA_444  = 3
676};
677
678/// supported partition shape
679enum PartSize
680{
681  SIZE_2Nx2N,           ///< symmetric motion partition,  2Nx2N
682  SIZE_2NxN,            ///< symmetric motion partition,  2Nx N
683  SIZE_Nx2N,            ///< symmetric motion partition,   Nx2N
684  SIZE_NxN,             ///< symmetric motion partition,   Nx N
685  SIZE_2NxnU,           ///< asymmetric motion partition, 2Nx( N/2) + 2Nx(3N/2)
686  SIZE_2NxnD,           ///< asymmetric motion partition, 2Nx(3N/2) + 2Nx( N/2)
687  SIZE_nLx2N,           ///< asymmetric motion partition, ( N/2)x2N + (3N/2)x2N
688  SIZE_nRx2N,           ///< asymmetric motion partition, (3N/2)x2N + ( N/2)x2N
689  SIZE_NONE = 15
690};
691
692/// supported prediction type
693enum PredMode
694{
695  MODE_INTER,           ///< inter-prediction mode
696  MODE_INTRA,           ///< intra-prediction mode
697  MODE_NONE = 15
698};
699
700/// texture component type
701enum TextType
702{
703  TEXT_LUMA,            ///< luma
704  TEXT_CHROMA,          ///< chroma (U+V)
705  TEXT_CHROMA_U,        ///< chroma U
706  TEXT_CHROMA_V,        ///< chroma V
707  TEXT_ALL,             ///< Y+U+V
708  TEXT_NONE = 15
709};
710
711/// reference list index
712enum RefPicList
713{
714  REF_PIC_LIST_0 = 0,   ///< reference list 0
715  REF_PIC_LIST_1 = 1,   ///< reference list 1
716  REF_PIC_LIST_X = 100  ///< special mark
717};
718
719/// distortion function index
720enum DFunc
721{
722  DF_DEFAULT  = 0,
723  DF_SSE      = 1,      ///< general size SSE
724  DF_SSE4     = 2,      ///<   4xM SSE
725  DF_SSE8     = 3,      ///<   8xM SSE
726  DF_SSE16    = 4,      ///<  16xM SSE
727  DF_SSE32    = 5,      ///<  32xM SSE
728  DF_SSE64    = 6,      ///<  64xM SSE
729  DF_SSE16N   = 7,      ///< 16NxM SSE
730 
731  DF_SAD      = 8,      ///< general size SAD
732  DF_SAD4     = 9,      ///<   4xM SAD
733  DF_SAD8     = 10,     ///<   8xM SAD
734  DF_SAD16    = 11,     ///<  16xM SAD
735  DF_SAD32    = 12,     ///<  32xM SAD
736  DF_SAD64    = 13,     ///<  64xM SAD
737  DF_SAD16N   = 14,     ///< 16NxM SAD
738 
739  DF_SADS     = 15,     ///< general size SAD with step
740  DF_SADS4    = 16,     ///<   4xM SAD with step
741  DF_SADS8    = 17,     ///<   8xM SAD with step
742  DF_SADS16   = 18,     ///<  16xM SAD with step
743  DF_SADS32   = 19,     ///<  32xM SAD with step
744  DF_SADS64   = 20,     ///<  64xM SAD with step
745  DF_SADS16N  = 21,     ///< 16NxM SAD with step
746 
747  DF_HADS     = 22,     ///< general size Hadamard with step
748  DF_HADS4    = 23,     ///<   4xM HAD with step
749  DF_HADS8    = 24,     ///<   8xM HAD with step
750  DF_HADS16   = 25,     ///<  16xM HAD with step
751  DF_HADS32   = 26,     ///<  32xM HAD with step
752  DF_HADS64   = 27,     ///<  64xM HAD with step
753  DF_HADS16N  = 28,     ///< 16NxM HAD with step
754#if H_3D_VSO
755  DF_VSD      = 29,      ///< general size VSD
756  DF_VSD4     = 30,      ///<   4xM VSD
757  DF_VSD8     = 31,      ///<   8xM VSD
758  DF_VSD16    = 32,      ///<  16xM VSD
759  DF_VSD32    = 33,      ///<  32xM VSD
760  DF_VSD64    = 34,      ///<  64xM VSD
761  DF_VSD16N   = 35,      ///< 16NxM VSD
762#endif
763
764#if AMP_SAD
765  DF_SAD12    = 43,
766  DF_SAD24    = 44,
767  DF_SAD48    = 45,
768
769  DF_SADS12   = 46,
770  DF_SADS24   = 47,
771  DF_SADS48   = 48,
772
773  DF_SSE_FRAME = 50     ///< Frame-based SSE
774#else
775  DF_SSE_FRAME = 33     ///< Frame-based SSE
776#endif
777};
778
779/// index for SBAC based RD optimization
780enum CI_IDX
781{
782  CI_CURR_BEST = 0,     ///< best mode index
783  CI_NEXT_BEST,         ///< next best index
784  CI_TEMP_BEST,         ///< temporal index
785  CI_CHROMA_INTRA,      ///< chroma intra index
786  CI_QT_TRAFO_TEST,
787  CI_QT_TRAFO_ROOT,
788  CI_NUM,               ///< total number
789};
790
791/// motion vector predictor direction used in AMVP
792enum MVP_DIR
793{
794  MD_LEFT = 0,          ///< MVP of left block
795  MD_ABOVE,             ///< MVP of above block
796  MD_ABOVE_RIGHT,       ///< MVP of above right block
797  MD_BELOW_LEFT,        ///< MVP of below left block
798  MD_ABOVE_LEFT         ///< MVP of above left block
799};
800
801/// coefficient scanning type used in ACS
802enum COEFF_SCAN_TYPE
803{
804  SCAN_DIAG = 0,         ///< up-right diagonal scan
805  SCAN_HOR,              ///< horizontal first scan
806  SCAN_VER               ///< vertical first scan
807};
808
809namespace Profile
810{
811  enum Name
812  {
813    NONE = 0,
814    MAIN = 1,
815    MAIN10 = 2,
816    MAINSTILLPICTURE = 3,
817#if H_MV
818    MAINSTEREO = 4,
819    MAINMULTIVIEW = 5,
820#if H_3D
821    MAIN3D = 6, 
822#endif
823#endif
824  };
825}
826
827namespace Level
828{
829  enum Tier
830  {
831    MAIN = 0,
832    HIGH = 1,
833  };
834
835  enum Name
836  {
837    NONE     = 0,
838    LEVEL1   = 30,
839    LEVEL2   = 60,
840    LEVEL2_1 = 63,
841    LEVEL3   = 90,
842    LEVEL3_1 = 93,
843    LEVEL4   = 120,
844    LEVEL4_1 = 123,
845    LEVEL5   = 150,
846    LEVEL5_1 = 153,
847    LEVEL5_2 = 156,
848    LEVEL6   = 180,
849    LEVEL6_1 = 183,
850    LEVEL6_2 = 186,
851  };
852}
853//! \}
854
855#if H_MV
856
857  enum PsExtensionTypes
858  {
859    PS_EX_T_MV   = 1,
860#if H_3D
861    PS_EX_T_3D   = 3,
862#endif
863    PS_EX_T_ESC  = 7,
864    PS_EX_T_MAX_NUM = 8
865  };
866
867/// scalability types
868  enum ScalabilityType
869  {
870#if H_3D
871    DEPTH_ID = 0,   
872#endif   
873    VIEW_ORDER_INDEX  = 1,
874  };
875#endif
876#if H_3D
877  // Renderer
878  enum BlenMod
879  {
880    BLEND_NONE  = -1,
881    BLEND_AVRG  = 0,
882    BLEND_LEFT  = 1,
883    BLEND_RIGHT = 2,
884    BLEND_GEN   =  3
885  };
886
887 
888  enum
889  {
890    VIEWPOS_INVALID = -1,
891    VIEWPOS_LEFT    = 0,
892    VIEWPOS_RIGHT   = 1,
893    VIEWPOS_MERGED  = 2
894  };
895
896#define Log2( n ) ( log((double)n) / log(2.0) ) // Ed.(GT): This is very very bad and should be fixed to used integer arithmetics ( see gCeilLog2 ) moreover it should not be defined in the tool macro section!
897#endif
898#endif
Note: See TracBrowser for help on using the repository browser.