source: 3DVCSoftware/trunk/source/Lib/TLibCommon/TypeDef.h @ 758

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

Merged HTM-9.1-dev0-MediaTek@757. (3D-HEVC HLS)

  • Property svn:eol-style set to native
File size: 44.8 KB
Line 
1/* The copyright in this software is being made available under the BSD
2 * License, included below. This software may be subject to other third party
3 * and contributor rights, including patent rights, and no such rights are
4 * granted under this license. 
5 *
6 * Copyright (c) 2010-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#define CAM_HLS_F0136_F0045_F0082         1   // JCT3V-F0136/F0045: view order index based camera parameter signaling
178                                              // JCT3V-F0082: the cp_in_slice_segment_layer_flag to be view specific and used as a condition of the presence of slice header level camera parameters
179#define CAM_HLS_F0044                     1   // JCT3V-F0044: move camera parameter from slice header extension to slice header
180
181
182// Rate Control
183#define KWU_FIX_URQ                       1
184#define KWU_RC_VIEWRC_E0227               0  ///< JCT3V-E0227, view-wise target bitrate allocation
185#define KWU_RC_MADPRED_E0227              0  ///< JCT3V-E0227, inter-view MAD prediction
186
187#endif // H_3D
188
189
190
191/////////////////////////////////////////////////////////////////////////////////////////
192///////////////////////////////////   DERIVED DEFINES /////////////////////////////////// 
193/////////////////////////////////////////////////////////////////////////////////////////
194
195///// ***** VIEW SYNTHESIS OPTIMIZAION *********
196#if H_3D_VSO                                 
197#define H_3D_VSO_DIST_INT                 1   // Allow negative synthesized view distortion change
198#define H_3D_VSO_COLOR_PLANES             1   // Compute VSO distortion on color planes
199#define H_3D_VSO_EARLY_SKIP               1   // LGE_VSO_EARLY_SKIP_A0093, A0093 modification 4
200#define H_3D_VSO_RM_ASSERTIONS            0   // Output VSO assertions
201#define H_3D_VSO_SYNTH_DIST_OUT           0   // Output of synthesized view distortion instead of depth distortion in encoder output
202#define H_3D_VSO_FIX                      0   // This fix should be enabled after verification
203#endif
204
205////   ****** neighbouring block-based disparity vector  *********
206#if H_3D_NBDV
207#define DVFROM_LEFT                       0
208#define DVFROM_ABOVE                      1
209#define IDV_CANDS                         2
210#endif
211
212///// ***** ADVANCED INTERVIEW RESIDUAL PREDICTION *********
213#if H_3D_ARP
214#define H_3D_ARP_WFNR                     3
215#endif
216
217///// ***** DEPTH INTRA MODES *********
218#if H_3D_DIM
219#define H_3D_DIM_DMM                      1   // Depth Modeling Modes
220#define H_3D_DIM_SDC                      1   // Simplified Depth Coding method
221#define H_3D_DIM_DLT                      1   // Depth Lookup Table
222
223#if H_3D_DIM_DLT
224#define DLT_DIFF_CODING_IN_PPS            1   // moving DLT syntax elements from VPS to PPS and differential coding of DLT values
225                                              // JCT3V-F0131, JCT3V-F0139
226#if DLT_DIFF_CODING_IN_PPS
227#define Log2( n ) ( log((double)n) / log(2.0) )
228#endif
229#define H_3D_DELTA_DLT                    1
230#endif
231
232#define H_3D_DIM_ENC                      1   // Depth Intra encoder optimizations, includes:
233                                              // HHI_DEPTH_INTRA_SEARCH_RAU_C0160
234                                              // LG_ZEROINTRADEPTHRESI_A0087
235#endif
236///// ***** VIEW SYNTHESIS PREDICTION *********
237#if H_3D_VSP
238#define H_3D_VSP_BLOCKSIZE                4   // Supported values: 1, 2, and 4
239#if H_3D_VSP_BLOCKSIZE == 1
240#define H_3D_VSP_CONSTRAINED              1   // Constrained VSP @ 1x1
241#else
242#define H_3D_VSP_CONSTRAINED              0
243#endif
244#endif
245
246///// ***** ILLUMATION COMPENSATION *********
247#if H_3D_IC
248#define IC_REG_COST_SHIFT                 7
249#define IC_CONST_SHIFT                    5
250#define IC_SHIFT_DIFF                     12
251#endif
252
253///// ***** FCO *********
254#if H_3D_FCO
255#define H_3D_FCO_VSP_DONBDV_E0163               1   // Adaptive depth reference for flexible coding order
256#else
257#define H_3D_FCO_VSP_DONBDV_E0163               0   // Adaptive depth reference for flexible coding order
258#endif
259
260/////////////////////////////////////////////////////////////////////////////////////////
261///////////////////////////////////   HTM-9.2 Integrations //////////////////////////////
262/////////////////////////////////////////////////////////////////////////////////////////
263
264// !!! PLEASE PUT MACROS RELATED TO HTM-9.2 INTEGRATIONS HERE !!!
265// !!! PLEASE PUT MACROS RELATED TO HTM-9.2 INTEGRATIONS HERE !!!
266// !!! PLEASE PUT MACROS RELATED TO HTM-9.2 INTEGRATIONS HERE !!!
267// !!! PLEASE PUT MACROS RELATED TO HTM-9.2 INTEGRATIONS HERE !!!
268// !!! PLEASE PUT MACROS RELATED TO HTM-9.2 INTEGRATIONS HERE !!!
269
270/////////////////////////////////////////////////////////////////////////////////////////
271///////////////////////////////////   HTM-9.1 Integrations //////////////////////////////
272/////////////////////////////////////////////////////////////////////////////////////////
273
274#define H_MV_FIX_TRACE_FILE                     1  // Fix linux compilation error related const char conversion
275
276#define H_MV_LAYER_WISE_STARTUP                 1  // Basic version of layer wise startup.
277#define H_MV_FIX_SKIP_PICTURES                  1  // Fix related to skipping pictures.
278#define H_MV_6_HRD_O0164_15                     1  // (HRD/O0164/Multilayer HRD) #15 Decision: Adopt, modified as follows: It was suggested to constrain the stalling based on the relative cpb removal times, which must be in decoding order. The "du_based_bpb_sync_flag" is not needed, in view of this. SEI in the highest layer of the layer set or (inclusive "or") VPS VUI is used to carry the parameters (at encoder discretion). SEI in higher layer and SEI in VUI do not need to repeat information available in some lower layer. Shall be after APS SEI and buffering period SEI and before all other SEI of all layers except other HRD related SEI.
279#define H_MV_6_HRD_O0217_13                     1  // (HRD/O0217/Sub-DPB based DPB operations) #13 Decision: Adopt ?Specify a separate DPB capacity for each layer ?no sharing of capacity across layers ?each layer has its own parameters (max pictures, max latency, max reordering). This proposal would specify distinct parameters for each "output layer set" and to change the definition of an operation point to be specific to an output layer set instead of a 'layer set". Decision: Adopted this aspect as well.
280#define H_MV_6_SHVC_O0098_36                    1  // (SHVC/O0098/Scaled ref layer offset) #36 Modify signalling of scaled reference layer offsets to allow signalling of any lower layer, rather than just a direct reference layer, in order to enable alignment of auxiliary pictures. In further JCT-VC and JCT-3V discussion, it was also agreed to use the same offset signalling for MV-HEVC as well as SHVC
281#define H_MV_6_GEN_0153_28                      1  //(Gen/O0153/output highest layer) #28 Add a flag in the VPS to indicate if startup process should output the highest available layer if the target output layer is not available.
282#define H_MV_6_PS_0109_25                       1  //XXX(PS/O0109/default_one_target_output_layer_idc) #25 To change default_one_target_output_layer_flag to a two-bit default_one_target_output_layer_idc, and reserve the values 2 and 3
283#define H_MV_6_O0226_37                         1  //(VUI/O0226/Mod tile WPP) #37 Modifications to the VUI indicators of tile and WPP alignment related syntax elements, from the r1.
284#define H_MV_6_RALS_O0149_11                    1  //XXX (RALS/O0149/Prop2): #11 Proposal: A new slice_reserved_flag is taken into use to indicate if a base-layer IDR picture initiates the layer-wise start-up process. Decision: Adopt (the bit should not be required to be present; if present should be the bit after the discardable_flag, and discardable_flag should be the first one of the three, and the poc reset flag is not required to be present).
285#define H_MV_6_PSEM_O0142_3                     1  // (PSEM/O0142/Conditional extension syntax) #3 Adopt JCTVC-O0142 (as a structure to be used to switch whatever extensions we define in SPS, not necessarily committing to having these extensions be separate for each extension, but the current plan unless decided otherwise is to use one flag for range extensions syntax presence and one flag for SHVC+MV-HEVC extension syntax presence)
286#define H_MV_6_FIX_GET_VIEW_ID                  1  // Fix get view id
287#define H_MV_6_LAYER_ID_32                      1  // (Gen/O0137,O0200,O0223,Layer id) #32 Add (editorial equivalent of) "The value of nuh_layer_id shall be in the range of 0 to 62. The value of 63 for nuh_layer_id is reserved for future use by ITU-T | ISO/IEC. Decoders shall ignore all data that follow the value 63 for nuh_layer_id in a NAL unit." and specify that vps_max_layers_minus1 shall not be equal to 63, but decoders shall allow that value to appear in the bitstream. Specify that the value 63 is interpreted the same as the value 62 (e.g., MaxLayersMinus1 = Min( 62, vps_max_layers_minus1) and subsequently refer to MaxLayersMinus1 instead of vps_max_layers_minus1)
288#define H_MV_6_PS_O0118_33                      1  // (PS/O0118/visual signal info in vui per layer) #33 Add visual signal information (video_format, video_full_range_flag, colour_primaries, transfer_characteristics, matrix_coeffs) per layer to the VPS VUI, from v2 version of JCTVC-O0118.
289#define H_MV_6_POC_31_35_38                     1  //XXX  Various related to POC
290                                                   // (Misc/O0062/POC LSB present) (SH changes)
291                                                   // (POC/O0117/Modify PicOrderCntVal of prevTid0Pic) #35 Modification of the PicOrderCntVal of prevTid0Pic and modification to the decoding process for reference picture set, to address problems found for cross-layer POC alignment.
292                                                   // (POC/O0211/Fix ambiguity) #38 Modify POC derivation to correct an ambiguity in the spec.
293#define H_MV_6_MISC_O0062_31                    1  // (Misc/O0062/POC LSB present) (without SH changes ) #31 The proposal's "option 3" is to add a flag in the VPS for each EL to control whether these LSBs are present or not (for IDR pictures), and when not present, the LSBs are inferred to be equal to 0. Decision: Adopted (as described herein).
294#define H_MV_6_ILDDS_ILREFPICS_27_34            1  // Various inter layer reference picture derivation
295                                                   // (ILDSD/O0225/max_tid_il_ref_pics RPL const.) #27 Change derivation of NumActiveRefLayerPics to consider max_tid_il_ref_pics.
296                                                   // (ILDSD/O0120/sub_layers_vps_max_minus1 RPL const) #34 Modify inter-layer reference picture list default construction to incorporate max temporal sub-layers per layer syntax elements in VPS extension, from r2 version of JCTVC-O0120
297#define H_MV_6_ILDDS_O0225_30                   1  // (ILDSD/O0225/signal max_tid_il_ref_pics per layer ) #30 2nd proposal of JCTVC-O0225 regarding signalling of max_tid_il_ref_pics per layer, based upon relation to SCE2 on single loop decoding. Decision: Adopted.
298#define H_MV_6_ILDSD_O0120_26                   1  // (ILDSD/O0120/sub_layers_vps_max_minus1) #26 Add syntax elements to signal max temporal sub-layers for each layer in the VPS, with a gating flag, from JCTVC- option 2.
299#define H_MV_6_PS_O0223_29                      1  // (PS/O0223/Cross layer alignment type) #29 Add a flag in VPS VUI to indicate cross layer pic type alignment.  Move cross_layer_irap_aligned_flag to VPS VUI and make presence condition on added flag
300#define H_MV_6_PS_0092_17                       1  // (PS/O0092/Sharing SPS PPS) #17 Restrict sharing of SPS and PPS across layers to avoid creating problems during sub-bitstream extraction, based on modification of proposals in JCTVC-O0059 and JCTVC-O0092, reflected in the v2 version of O0092.
301#define H_MV_6_PS_REP_FORM_18_19_20             1  //  Various Rep format
302                                                   // (PS/O0096/rep format syntax element length ) #20 Modification of length to 8 bit as decided later in trac.
303                                                   // (PS/O0179/Rep. Format) #18 Add flag in rep_format( ) syntax structure to control sending of chroma and bit depth related parameters, as proposed in the v2 version of JCTVC-O0179.
304                                                   // (PS/O0096/rep format) #20 Modify the SPS syntax for layers with nuh_layer_id > 0 to signal a reference to a rep_format index in the VPS, rather than signalling explicit representation format data in the SPS, from the v2 version of JCTVC-O0096.
305                                                   // (PS/FIX/N0092/Rep. Format) #19 Inferences.
306#define H_MV_6_PS_O0096_21                      1  // (PS/O0096/direct_dependency_type gating flag) #21 Add a gating flag in VPS extension to condition the presence of direct dependency type, with a default type signalled, from JCTVC-O0096
307#define H_MV_6_PS_O0109_22                      1  // (PS/O0109/view_id_len) #22 Modify the VPS extension syntax and semantics to replace view_id_len_minus1 with view_id_len, always signal that syntax element, add a constraint that (1<<view_id_len) >= NumViews, and modify view_id_val semantics to infer value of 0 when not present, from discussion of JCTVC-O0109
308#define H_MV_6_PS_O0109_23                      1  // (PS/O0109/profile_ref_minus1 constraint) #23 Modify the semantics of profile_ref_minus1[ i ] to replace “shall be less than i?with “shall be less than or equal to i? from discussion of JCTVC-O0109
309#define H_MV_6_PS_O0109_24                      1  // (PS/O0109/vps_vui_present_flag move) #24 Move the vps_vui_present_flag to precede vps_vui_offset, and make vps_vui_offset conditional on that flag, from JCTVC-O0109
310/////////////////////////////////////////////////////////////////////////////////////////
311///////////////////////////////////   HTM-9.0 Integrations //////////////////////////////
312/////////////////////////////////////////////////////////////////////////////////////////
313
314#if H_3D
315
316#define FIX_MISSING_MACRO_R690                  1 // Missing macro in integration to revision 690
317
318#define SEC_MPI_ENABLING_MERGE_F0150            1 // MPI flag in VPS and enabling in Merge mode
319#define ETRIKHU_MERGE_REUSE_F0093               1 // Reuse HEVC merge candidate list construction for base candidates, JCT3V-F0093
320
321#if H_3D_ARP
322#define QC_MTK_INTERVIEW_ARP_F0123_F0108        1 //JCT3V-F0123; JCT3V-F0108
323#define SHARP_ARP_REF_CHECK_F0105               1 // ARP reference picture selection and DPB check
324#define LGE_ARP_CTX_F0161                       1 //JCT3V-F0161
325#endif
326
327#if H_3D_IV_MERGE
328#define QC_DEPTH_IV_MRG_F0125                   1 // JCT3V-F0125: Depth oriented Inter-view MV candidate
329#define MTK_SPIVMP_F0110                        1 // JCT3V-F0110: Sub-PU level inter-view motion prediction
330#define MTK_F0110_FIX                           1 // Disable Sub-PU IVMP in Depth, fix some delete problems
331#define BUGFIX_F0093                            1 // bug fix for F0093 for depth IvMC pruning
332#define BUGFIX_2_F0093                          1 // bug fix for VSP inheritance
333#endif
334
335#if H_3D_VSP
336#define MTK_F0109_LG_F0120_VSP_BLOCK            1 // MTK_LG_SIMPLIFY_VSP_BLOCK_PARTITION_F0109_F0120 
337#define SHARP_VSP_BLOCK_IN_AMP_F0102            1 // VSP partitioning for AMP
338#define MTK_VSP_SIMPLIFICATION_F0111            1 // 1. Inherited VSP also use NBDV of current CU, 2. VSP cannot be inherited from above LCU rowss
339#define LGE_SHARP_VSP_INHERIT_F0104             1
340#endif
341
342#define LGE_BUGFIX_F0158                        1 //JCT3V-F0158
343#define LGE_IC_CTX_F0160                        1 //JCT3V-F0160
344#define SEC_ONLY_TEXTURE_IC_F0151               1
345
346#if H_3D_DIM
347#define SEC_DMM3_RBC_F0147                      1 // Removal of DMM3 and RBC from DMMs
348#if !SEC_DMM3_RBC_F0147
349#define H_3D_DIM_RBC                            1 // Region Boundary Chain mode
350#endif
351#define QC_DIM_DELTADC_UNIFY_F0132              1 // Unify delta DC coding in depth intra modes
352#define HHI_DIM_PREDSAMP_FIX_F0171              1
353#define LGE_PRED_RES_CODING_DLT_DOMAIN_F0159    1 //JCT3V-F0159
354#endif
355#endif
356
357
358/////////////////////////////////////////////////////////////////////////////////////////
359///////////////////////////////////   HM RELATED DEFINES ////////////////////////////////
360/////////////////////////////////////////////////////////////////////////////////////////
361
362#define FIX1071 1 ///< fix for issue #1071
363
364#define MAX_NUM_PICS_IN_SOP           1024
365
366#define MAX_NESTING_NUM_OPS         1024
367#define MAX_NESTING_NUM_LAYER       64
368
369#define MAX_VPS_NUM_HRD_PARAMETERS                1
370#define MAX_VPS_OP_SETS_PLUS1                     1024
371#if H_MV
372#if H_MV_6_LAYER_ID_32
373#define MAX_VPS_NUH_LAYER_ID_PLUS1  63
374#else
375#define MAX_VPS_NUH_LAYER_ID_PLUS1  64
376#endif
377#define MAX_NUM_SCALABILITY_TYPES   16
378#define ENC_CFG_CONSOUT_SPACE       29           
379#else
380#define MAX_VPS_NUH_RESERVED_ZERO_LAYER_ID_PLUS1  1
381#endif
382
383#define RATE_CONTROL_LAMBDA_DOMAIN                  1  ///< JCTVC-K0103, rate control by R-lambda model
384#define M0036_RC_IMPROVEMENT                        1  ///< JCTVC-M0036, improvement for R-lambda model based rate control
385#define TICKET_1090_FIX                             1
386
387#if KWU_FIX_URQ
388#if RATE_CONTROL_LAMBDA_DOMAIN
389#define RC_FIX                                      1  /// suggested fix for M0036
390#define RATE_CONTROL_INTRA                          1  ///< JCTVC-M0257, rate control for intra
391#endif
392#else
393#define RC_FIX                                      1  /// suggested fix for M0036
394#define RATE_CONTROL_INTRA                          1  ///< JCTVC-M0257, rate control for intra
395#endif
396
397
398#define MAX_CPB_CNT                     32  ///< Upper bound of (cpb_cnt_minus1 + 1)
399#if H_MV
400#if H_MV_6_LAYER_ID_32
401#define MAX_NUM_LAYER_IDS               63
402#define MAX_NUM_LAYERS                  63
403#else
404#define MAX_NUM_LAYER_IDS               64
405#define MAX_NUM_LAYERS                  64
406#endif
407#define MAX_VPS_PROFILE_TIER_LEVEL      64
408#define MAX_VPS_ADD_OUTPUT_LAYER_SETS   1024
409#define MAX_VPS_OUTPUTLAYER_SETS        ( MAX_VPS_ADD_OUTPUT_LAYER_SETS + MAX_VPS_OP_SETS_PLUS1 )
410#if H_MV_6_PS_O0118_33
411#define  MAX_NUM_VIDEO_SIGNAL_INFO      16
412#endif
413#if H_MV_6_SHVC_O0098_36
414#define MAX_NUM_SCALED_REF_LAYERS       MAX_NUM_LAYERS-1
415#endif
416#if H_MV_6_HRD_O0164_15
417#define MAX_NUM_BSP_HRD_PARAMETERS      100 ///< Maximum value is actually not specified
418#define MAX_NUM_BITSTREAM_PARTITIONS    100 ///< Maximum value is actually not specified
419#define MAX_NUM_BSP_SCHED_COMBINATION   100 ///< Maximum value is actually not specified
420#endif
421#endif
422
423#define COEF_REMAIN_BIN_REDUCTION        3 ///< indicates the level at which the VLC
424                                           ///< transitions from Golomb-Rice to TU+EG(k)
425
426#define CU_DQP_TU_CMAX 5                   ///< max number bins for truncated unary
427#define CU_DQP_EG_k 0                      ///< expgolomb order
428
429#define SBH_THRESHOLD                    4  ///< I0156: value of the fixed SBH controlling threshold
430 
431#define SEQUENCE_LEVEL_LOSSLESS           0  ///< H0530: used only for sequence or frame-level lossless coding
432
433#define DISABLING_CLIP_FOR_BIPREDME         1  ///< Ticket #175
434 
435#define C1FLAG_NUMBER               8 // maximum number of largerThan1 flag coded in one chunk :  16 in HM5
436#define C2FLAG_NUMBER               1 // maximum number of largerThan2 flag coded in one chunk:  16 in HM5
437
438#define REMOVE_SAO_LCU_ENC_CONSTRAINTS_3 1  ///< disable the encoder constraint that conditionally disable SAO for chroma for entire slice in interleaved mode
439
440#define SAO_ENCODING_CHOICE              1  ///< I0184: picture early termination
441#if SAO_ENCODING_CHOICE
442#define SAO_ENCODING_RATE                0.75
443#define SAO_ENCODING_CHOICE_CHROMA       1 ///< J0044: picture early termination Luma and Chroma are handled separately
444#if SAO_ENCODING_CHOICE_CHROMA
445#define SAO_ENCODING_RATE_CHROMA         0.5
446#endif
447#endif
448
449#define MAX_NUM_VPS                16
450#define MAX_NUM_SPS                16
451#define MAX_NUM_PPS                64
452
453
454
455#define WEIGHTED_CHROMA_DISTORTION  1   ///< F386: weighting of chroma for RDO
456#define RDOQ_CHROMA_LAMBDA          1   ///< F386: weighting of chroma for RDOQ
457#define SAO_CHROMA_LAMBDA           1   ///< F386: weighting of chroma for SAO
458
459#define MIN_SCAN_POS_CROSS          4
460
461#define FAST_BIT_EST                1   ///< G763: Table-based bit estimation for CABAC
462
463#define MLS_GRP_NUM                         64     ///< G644 : Max number of coefficient groups, max(16, 64)
464#define MLS_CG_SIZE                         4      ///< G644 : Coefficient group size of 4x4
465
466#define ADAPTIVE_QP_SELECTION               1      ///< G382: Adaptive reconstruction levels, non-normative part for adaptive QP selection
467#if ADAPTIVE_QP_SELECTION
468#define ARL_C_PRECISION                     7      ///< G382: 7-bit arithmetic precision
469#define LEVEL_RANGE                         30     ///< G382: max coefficient level in statistics collection
470#endif
471
472#define NS_HAD                               0
473
474#define HHI_RQT_INTRA_SPEEDUP             1           ///< tests one best mode with full rqt
475#define HHI_RQT_INTRA_SPEEDUP_MOD         0           ///< tests two best modes with full rqt
476
477#if HHI_RQT_INTRA_SPEEDUP_MOD && !HHI_RQT_INTRA_SPEEDUP
478#error
479#endif
480
481#define VERBOSE_RATE 0 ///< Print additional rate information in encoder
482
483#define AMVP_DECIMATION_FACTOR            4
484
485#define SCAN_SET_SIZE                     16
486#define LOG2_SCAN_SET_SIZE                4
487
488#define FAST_UDI_MAX_RDMODE_NUM               35          ///< maximum number of RD comparison in fast-UDI estimation loop
489
490#define ZERO_MVD_EST                          0           ///< Zero Mvd Estimation in normal mode
491
492#define NUM_INTRA_MODE 36
493#if !REMOVE_LM_CHROMA
494#define LM_CHROMA_IDX  35
495#endif
496
497#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.
498#define AUTO_INTER_RPS                  1           ///< Enable/disable the automatic generation of refIdc from the deltaPOC and Used by current from the config file.
499#define PRINT_RPS_INFO                  0           ///< Enable/disable the printing of bits used to send the RPS.
500                                                    // using one nearest frame as reference frame, and the other frames are high quality (POC%4==0) frames (1+X)
501                                                    // this should be done with encoder only decision
502                                                    // but because of the absence of reference frame management, the related code was hard coded currently
503
504#define RVM_VCEGAM10_M 4
505
506#define PLANAR_IDX             0
507#define VER_IDX                26                    // index for intra VERTICAL   mode
508#define HOR_IDX                10                    // index for intra HORIZONTAL mode
509#define DC_IDX                 1                     // index for intra DC mode
510#define NUM_CHROMA_MODE        5                     // total number of chroma modes
511#define DM_CHROMA_IDX          36                    // chroma mode index for derived from luma intra mode
512
513
514#define FAST_UDI_USE_MPM 1
515
516#define RDO_WITHOUT_DQP_BITS              0           ///< Disable counting dQP bits in RDO-based mode decision
517
518#define FULL_NBIT 0 ///< When enabled, compute costs using full sample bitdepth.  When disabled, compute costs as if it is 8-bit source video.
519#if FULL_NBIT
520# define DISTORTION_PRECISION_ADJUSTMENT(x) 0
521#else
522# define DISTORTION_PRECISION_ADJUSTMENT(x) (x)
523#endif
524
525#define LOG2_MAX_NUM_COLUMNS_MINUS1        7
526#define LOG2_MAX_NUM_ROWS_MINUS1           7
527#define LOG2_MAX_COLUMN_WIDTH              13
528#define LOG2_MAX_ROW_HEIGHT                13
529
530#define MATRIX_MULT                             0   // Brute force matrix multiplication instead of partial butterfly
531
532#define REG_DCT 65535
533
534#define AMP_SAD                               1           ///< dedicated SAD functions for AMP
535#define AMP_ENC_SPEEDUP                       1           ///< encoder only speed-up by AMP mode skipping
536#if AMP_ENC_SPEEDUP
537#define AMP_MRG                               1           ///< encoder only force merge for AMP partition (no motion search for AMP)
538#endif
539
540#define SCALING_LIST_OUTPUT_RESULT    0 //JCTVC-G880/JCTVC-G1016 quantization matrices
541
542#define CABAC_INIT_PRESENT_FLAG     1
543
544// ====================================================================================================================
545// Basic type redefinition
546// ====================================================================================================================
547
548typedef       void                Void;
549typedef       bool                Bool;
550
551typedef       char                Char;
552typedef       unsigned char       UChar;
553typedef       short               Short;
554typedef       unsigned short      UShort;
555typedef       int                 Int;
556typedef       unsigned int        UInt;
557typedef       double              Double;
558typedef       float               Float;
559
560// ====================================================================================================================
561// 64-bit integer type
562// ====================================================================================================================
563
564#ifdef _MSC_VER
565typedef       __int64             Int64;
566
567#if _MSC_VER <= 1200 // MS VC6
568typedef       __int64             UInt64;   // MS VC6 does not support unsigned __int64 to double conversion
569#else
570typedef       unsigned __int64    UInt64;
571#endif
572
573#else
574
575typedef       long long           Int64;
576typedef       unsigned long long  UInt64;
577
578#endif
579
580// ====================================================================================================================
581// Type definition
582// ====================================================================================================================
583
584typedef       UChar           Pxl;        ///< 8-bit pixel type
585typedef       Short           Pel;        ///< 16-bit pixel type
586typedef       Int             TCoeff;     ///< transform coefficient
587
588#if H_3D_VSO
589// ====================================================================================================================
590// Define Distortion Types
591// ====================================================================================================================
592typedef       Int64           RMDist;     ///< renderer model distortion
593
594#if H_3D_VSO_DIST_INT
595typedef       Int64            Dist;       ///< RDO distortion
596typedef       Int64            Dist64; 
597#define       RDO_DIST_MIN     MIN_INT
598#define       RDO_DIST_MAX     MAX_INT
599#else
600typedef       UInt             Dist;       ///< RDO distortion
601typedef       UInt64           Dist; 
602#define       RDO_DIST_MIN     0
603#define       RDO_DIST_MAX     MAX_UINT
604#endif
605#endif
606/// parameters for adaptive loop filter
607class TComPicSym;
608
609// Slice / Slice segment encoding modes
610enum SliceConstraint
611{
612  NO_SLICES              = 0,          ///< don't use slices / slice segments
613  FIXED_NUMBER_OF_LCU    = 1,          ///< Limit maximum number of largest coding tree blocks in a slice / slice segments
614  FIXED_NUMBER_OF_BYTES  = 2,          ///< Limit maximum number of bytes in a slice / slice segment
615  FIXED_NUMBER_OF_TILES  = 3,          ///< slices / slice segments span an integer number of tiles
616};
617
618#define NUM_DOWN_PART 4
619
620enum SAOTypeLen
621{
622  SAO_EO_LEN    = 4, 
623  SAO_BO_LEN    = 4,
624  SAO_MAX_BO_CLASSES = 32
625};
626
627enum SAOType
628{
629  SAO_EO_0 = 0, 
630  SAO_EO_1,
631  SAO_EO_2, 
632  SAO_EO_3,
633  SAO_BO,
634  MAX_NUM_SAO_TYPE
635};
636
637typedef struct _SaoQTPart
638{
639  Int         iBestType;
640  Int         iLength;
641  Int         subTypeIdx ;                 ///< indicates EO class or BO band position
642  Int         iOffset[4];
643  Int         StartCUX;
644  Int         StartCUY;
645  Int         EndCUX;
646  Int         EndCUY;
647
648  Int         PartIdx;
649  Int         PartLevel;
650  Int         PartCol;
651  Int         PartRow;
652
653  Int         DownPartsIdx[NUM_DOWN_PART];
654  Int         UpPartIdx;
655
656  Bool        bSplit;
657
658  //---- encoder only start -----//
659  Bool        bProcessed;
660  Double      dMinCost;
661  Int64       iMinDist;
662  Int         iMinRate;
663  //---- encoder only end -----//
664} SAOQTPart;
665
666typedef struct _SaoLcuParam
667{
668  Bool       mergeUpFlag;
669  Bool       mergeLeftFlag;
670  Int        typeIdx;
671  Int        subTypeIdx;                  ///< indicates EO class or BO band position
672  Int        offset[4];
673  Int        partIdx;
674  Int        partIdxTmp;
675  Int        length;
676} SaoLcuParam;
677
678struct SAOParam
679{
680  Bool       bSaoFlag[2];
681  SAOQTPart* psSaoPart[3];
682  Int        iMaxSplitLevel;
683  Bool         oneUnitFlag[3];
684  SaoLcuParam* saoLcuParam[3];
685  Int          numCuInHeight;
686  Int          numCuInWidth;
687  ~SAOParam();
688};
689
690/// parameters for deblocking filter
691typedef struct _LFCUParam
692{
693  Bool bInternalEdge;                     ///< indicates internal edge
694  Bool bLeftEdge;                         ///< indicates left edge
695  Bool bTopEdge;                          ///< indicates top edge
696} LFCUParam;
697
698// ====================================================================================================================
699// Enumeration
700// ====================================================================================================================
701
702/// supported slice type
703enum SliceType
704{
705  B_SLICE,
706  P_SLICE,
707  I_SLICE
708};
709
710/// chroma formats (according to semantics of chroma_format_idc)
711enum ChromaFormat
712{
713  CHROMA_400  = 0,
714  CHROMA_420  = 1,
715  CHROMA_422  = 2,
716  CHROMA_444  = 3
717};
718
719/// supported partition shape
720enum PartSize
721{
722  SIZE_2Nx2N,           ///< symmetric motion partition,  2Nx2N
723  SIZE_2NxN,            ///< symmetric motion partition,  2Nx N
724  SIZE_Nx2N,            ///< symmetric motion partition,   Nx2N
725  SIZE_NxN,             ///< symmetric motion partition,   Nx N
726  SIZE_2NxnU,           ///< asymmetric motion partition, 2Nx( N/2) + 2Nx(3N/2)
727  SIZE_2NxnD,           ///< asymmetric motion partition, 2Nx(3N/2) + 2Nx( N/2)
728  SIZE_nLx2N,           ///< asymmetric motion partition, ( N/2)x2N + (3N/2)x2N
729  SIZE_nRx2N,           ///< asymmetric motion partition, (3N/2)x2N + ( N/2)x2N
730  SIZE_NONE = 15
731};
732
733/// supported prediction type
734enum PredMode
735{
736  MODE_INTER,           ///< inter-prediction mode
737  MODE_INTRA,           ///< intra-prediction mode
738  MODE_NONE = 15
739};
740
741/// texture component type
742enum TextType
743{
744  TEXT_LUMA,            ///< luma
745  TEXT_CHROMA,          ///< chroma (U+V)
746  TEXT_CHROMA_U,        ///< chroma U
747  TEXT_CHROMA_V,        ///< chroma V
748  TEXT_ALL,             ///< Y+U+V
749  TEXT_NONE = 15
750};
751
752/// reference list index
753enum RefPicList
754{
755  REF_PIC_LIST_0 = 0,   ///< reference list 0
756  REF_PIC_LIST_1 = 1,   ///< reference list 1
757  REF_PIC_LIST_X = 100  ///< special mark
758};
759
760/// distortion function index
761enum DFunc
762{
763  DF_DEFAULT  = 0,
764  DF_SSE      = 1,      ///< general size SSE
765  DF_SSE4     = 2,      ///<   4xM SSE
766  DF_SSE8     = 3,      ///<   8xM SSE
767  DF_SSE16    = 4,      ///<  16xM SSE
768  DF_SSE32    = 5,      ///<  32xM SSE
769  DF_SSE64    = 6,      ///<  64xM SSE
770  DF_SSE16N   = 7,      ///< 16NxM SSE
771 
772  DF_SAD      = 8,      ///< general size SAD
773  DF_SAD4     = 9,      ///<   4xM SAD
774  DF_SAD8     = 10,     ///<   8xM SAD
775  DF_SAD16    = 11,     ///<  16xM SAD
776  DF_SAD32    = 12,     ///<  32xM SAD
777  DF_SAD64    = 13,     ///<  64xM SAD
778  DF_SAD16N   = 14,     ///< 16NxM SAD
779 
780  DF_SADS     = 15,     ///< general size SAD with step
781  DF_SADS4    = 16,     ///<   4xM SAD with step
782  DF_SADS8    = 17,     ///<   8xM SAD with step
783  DF_SADS16   = 18,     ///<  16xM SAD with step
784  DF_SADS32   = 19,     ///<  32xM SAD with step
785  DF_SADS64   = 20,     ///<  64xM SAD with step
786  DF_SADS16N  = 21,     ///< 16NxM SAD with step
787 
788  DF_HADS     = 22,     ///< general size Hadamard with step
789  DF_HADS4    = 23,     ///<   4xM HAD with step
790  DF_HADS8    = 24,     ///<   8xM HAD with step
791  DF_HADS16   = 25,     ///<  16xM HAD with step
792  DF_HADS32   = 26,     ///<  32xM HAD with step
793  DF_HADS64   = 27,     ///<  64xM HAD with step
794  DF_HADS16N  = 28,     ///< 16NxM HAD with step
795#if H_3D_VSO
796  DF_VSD      = 29,      ///< general size VSD
797  DF_VSD4     = 30,      ///<   4xM VSD
798  DF_VSD8     = 31,      ///<   8xM VSD
799  DF_VSD16    = 32,      ///<  16xM VSD
800  DF_VSD32    = 33,      ///<  32xM VSD
801  DF_VSD64    = 34,      ///<  64xM VSD
802  DF_VSD16N   = 35,      ///< 16NxM VSD
803#endif
804
805#if AMP_SAD
806  DF_SAD12    = 43,
807  DF_SAD24    = 44,
808  DF_SAD48    = 45,
809
810  DF_SADS12   = 46,
811  DF_SADS24   = 47,
812  DF_SADS48   = 48,
813
814  DF_SSE_FRAME = 50     ///< Frame-based SSE
815#else
816  DF_SSE_FRAME = 33     ///< Frame-based SSE
817#endif
818};
819
820/// index for SBAC based RD optimization
821enum CI_IDX
822{
823  CI_CURR_BEST = 0,     ///< best mode index
824  CI_NEXT_BEST,         ///< next best index
825  CI_TEMP_BEST,         ///< temporal index
826  CI_CHROMA_INTRA,      ///< chroma intra index
827  CI_QT_TRAFO_TEST,
828  CI_QT_TRAFO_ROOT,
829  CI_NUM,               ///< total number
830};
831
832/// motion vector predictor direction used in AMVP
833enum MVP_DIR
834{
835  MD_LEFT = 0,          ///< MVP of left block
836  MD_ABOVE,             ///< MVP of above block
837  MD_ABOVE_RIGHT,       ///< MVP of above right block
838  MD_BELOW_LEFT,        ///< MVP of below left block
839  MD_ABOVE_LEFT         ///< MVP of above left block
840};
841
842/// coefficient scanning type used in ACS
843enum COEFF_SCAN_TYPE
844{
845  SCAN_DIAG = 0,         ///< up-right diagonal scan
846  SCAN_HOR,              ///< horizontal first scan
847  SCAN_VER               ///< vertical first scan
848};
849
850namespace Profile
851{
852  enum Name
853  {
854    NONE = 0,
855    MAIN = 1,
856    MAIN10 = 2,
857    MAINSTILLPICTURE = 3,
858#if H_MV
859    MAINSTEREO = 4,
860    MAINMULTIVIEW = 5,
861#if H_3D
862    MAIN3D = 6, 
863#endif
864#endif
865  };
866}
867
868namespace Level
869{
870  enum Tier
871  {
872    MAIN = 0,
873    HIGH = 1,
874  };
875
876  enum Name
877  {
878    NONE     = 0,
879    LEVEL1   = 30,
880    LEVEL2   = 60,
881    LEVEL2_1 = 63,
882    LEVEL3   = 90,
883    LEVEL3_1 = 93,
884    LEVEL4   = 120,
885    LEVEL4_1 = 123,
886    LEVEL5   = 150,
887    LEVEL5_1 = 153,
888    LEVEL5_2 = 156,
889    LEVEL6   = 180,
890    LEVEL6_1 = 183,
891    LEVEL6_2 = 186,
892  };
893}
894//! \}
895
896#if H_MV
897
898#if H_MV_6_PSEM_O0142_3
899  enum PsExtensionTypes
900  {
901    PS_EX_T_MV   = 1,
902#if H_3D
903    PS_EX_T_3D   = 3,
904#endif
905    PS_EX_T_ESC  = 7,
906    PS_EX_T_MAX_NUM = 8
907  };
908#endif
909
910/// scalability types
911  enum ScalabilityType
912  {
913#if H_3D
914    DEPTH_ID = 0,   
915#endif   
916    VIEW_ORDER_INDEX  = 1,
917  };
918#endif
919#if H_3D
920  // Renderer
921  enum BlenMod
922  {
923    BLEND_NONE  = -1,
924    BLEND_AVRG  = 0,
925    BLEND_LEFT  = 1,
926    BLEND_RIGHT = 2,
927    BLEND_GEN   =  3
928  };
929
930 
931  enum
932  {
933    VIEWPOS_INVALID = -1,
934    VIEWPOS_LEFT    = 0,
935    VIEWPOS_RIGHT   = 1,
936    VIEWPOS_MERGED  = 2
937  };
938
939
940#endif
941#endif
Note: See TracBrowser for help on using the repository browser.