source: 3DVCSoftware/branches/HTM-8.2-dev0-MediaTek/source/Lib/TLibCommon/TypeDef.h @ 716

Last change on this file since 716 was 716, checked in by mediatek-htm, 10 years ago

Bug fix for F0093, addded macro is

#define BUGFIX_F0093 1 bug fix for F0093 for depth IvMC pruning

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