1 | #======== Legend for comments ===================== |
---|
2 | # (m) specification per layer/dimension/layerset possible |
---|
3 | # (c) cyclic repetition of values, if not given for all layers/dimensions/layersets. (e.g. 5 layers and 1 2 3 -> 1 2 3 1 2 ) |
---|
4 | |
---|
5 | #======== File I/O ===================== |
---|
6 | |
---|
7 | InputFile_0 : newspapercc_4.yuv |
---|
8 | InputFile_1 : newspapercc_2.yuv |
---|
9 | InputFile_2 : newspapercc_6.yuv |
---|
10 | |
---|
11 | BitstreamFile : stream.bit |
---|
12 | |
---|
13 | ReconFile_0 : rec_4.yuv |
---|
14 | ReconFile_1 : rec_2.yuv |
---|
15 | ReconFile_2 : rec_6.yuv |
---|
16 | |
---|
17 | NumberOfLayers : 3 # Number of layers |
---|
18 | |
---|
19 | #======== VPS ============================ |
---|
20 | ScalabilityMask : 2 # Scalability Mask ( 2: View Scalability, 3: View + Depth Scalability ) |
---|
21 | DimensionIdLen : 3 # Number of bits to store Ids, per scalability dimension, (m) |
---|
22 | ViewOrderIndex : 0 1 2 # ViewOrderIndex, per layer (m) |
---|
23 | LayerIdInNuh : 0 # Layer Id in NAL unit header, (0: no explicit signalling, otherwise per layer ) (m) |
---|
24 | SplittingFlag : 0 # Splitting Flag |
---|
25 | ViewId : 1 0 2 # ViewId, per ViewOrderIndex (m) |
---|
26 | |
---|
27 | #======== VPS / Layer sets ================ |
---|
28 | VpsNumLayerSets : 4 # Number of layer sets |
---|
29 | LayerIdsInSet_0 : 0 # Indices in VPS of layers in layer set 0 |
---|
30 | LayerIdsInSet_1 : 0 1 # Indices in VPS of layers in layer set 1 |
---|
31 | LayerIdsInSet_2 : 0 2 # Indices in VPS of layers in layer set 2 |
---|
32 | LayerIdsInSet_3 : 0 1 2 # Indices in VPS of layers in layer set 3 |
---|
33 | |
---|
34 | #======== VPS / Output layer sets ================ |
---|
35 | DefaultTargetOutputLayerIdc : 0 # Specifies output layers of layer sets, 0: output all layers, 1: output highest layer, 2: specified by LayerIdsInDefOutputLayerSet |
---|
36 | |
---|
37 | OutputLayerSetIdx : 1 2 # Indices of layer sets used to derive additional output layer sets |
---|
38 | LayerIdsInAddOutputLayerSet_0 : 1 # Indices in VPS of output layers in additional output layer set 0 |
---|
39 | LayerIdsInAddOutputLayerSet_1 : 2 # Indices in VPS of output layers in additional output layer set 1 |
---|
40 | |
---|
41 | #======== VPS / PTLI ================ |
---|
42 | Profile : main main 3d-main # Profile indication in VpsProfileTierLevel, per VpsProfileTierLevel syntax structure (m) |
---|
43 | Level : none none none # Level indication in VpsProfileTierLevel, per VpsProfileTierLevel syntax structure (m) |
---|
44 | Tier : main main main # Tier indication in VpsProfileTierLevel, per VpsProfileTierLevel syntax structure (m) |
---|
45 | InblFlag : 0 0 0 # Inbl indication in VpsProfileTierLevel, per VpsProfileTierLevel syntax structure (m) |
---|
46 | |
---|
47 | ProfileTierLevelIdx_0 : 1 # VpsProfileTierLevel indices of layers in output layer set 0 (m) (should be -1, when layer is not necessary) |
---|
48 | ProfileTierLevelIdx_1 : 1 2 # VpsProfileTierLevel indices of layers in output layer set 1 (m) (should be -1, when layer is not necessary) |
---|
49 | ProfileTierLevelIdx_2 : 1 2 # VpsProfileTierLevel indices of layers in output layer set 2 (m) (should be -1, when layer is not necessary) |
---|
50 | ProfileTierLevelIdx_3 : 1 2 2 # VpsProfileTierLevel indices of layers in output layer set 3 (m) (should be -1, when layer is not necessary) |
---|
51 | ProfileTierLevelIdx_4 : 1 2 # VpsProfileTierLevel indices of layers in output layer set 4 (m) (should be -1, when layer is not necessary) |
---|
52 | ProfileTierLevelIdx_5 : 1 2 # VpsProfileTierLevel indices of layers in output layer set 5 (m) (should be -1, when layer is not necessary) |
---|
53 | |
---|
54 | #======== VPS / Dependencies ================ |
---|
55 | DirectRefLayers_1 : 0 # Indices in VPS of direct reference layers |
---|
56 | DirectRefLayers_2 : 0 # Indices in VPS of direct reference layers |
---|
57 | |
---|
58 | DependencyTypes_1 : 2 # Dependency types of direct reference layers, 0: Sample 1: Motion 2: Sample+Motion 6: Sample+Motion+Quadtree |
---|
59 | DependencyTypes_2 : 2 # Dependency types of direct reference layers, 0: Sample 1: Motion 2: Sample+Motion 6: Sample+Motion+Quadtree |
---|
60 | |
---|
61 | #========== Camera parameters ========== |
---|
62 | CameraParameterFile : cam_pars.txt # camera parameter file |
---|
63 | CodedCamParsPrecision : 5 # precision used for coding of camera parameters (in units of 2^(-x) luma samples) |
---|
64 | |
---|
65 | #======== Unit definition ================ |
---|
66 | MaxCUWidth : 64 # Maximum coding unit width in pixel |
---|
67 | MaxCUHeight : 64 # Maximum coding unit height in pixel |
---|
68 | MaxPartitionDepth : 4 # Maximum coding unit depth |
---|
69 | QuadtreeTULog2MaxSize : 5 # Log2 of maximum transform size for |
---|
70 | # quadtree-based TU coding (2...6) |
---|
71 | QuadtreeTULog2MinSize : 2 # Log2 of minimum transform size for |
---|
72 | # quadtree-based TU coding (2...6) |
---|
73 | QuadtreeTUMaxDepthInter : 3 |
---|
74 | QuadtreeTUMaxDepthIntra : 3 |
---|
75 | |
---|
76 | #======== Coding Structure ============= |
---|
77 | IntraPeriod : 1 # Period of I-Frame ( -1 = only first) |
---|
78 | DecodingRefreshType : 1 # Random Accesss 0:none, 1:CRA, 2:IDR, 3:Recovery Point SEI |
---|
79 | GOPSize : 1 # GOP Size (number of B slice = GOPSize-1) |
---|
80 | Frame1 : B 1 1 0 0 0.442 0 0 0 4 0 0 0 0 |
---|
81 | FrameI_l1: I 0 0 0 0 0.442 0 0 0 0 0 0 0 0 |
---|
82 | Frame1_l1 : B 1 1 0 0 0.442 0 0 0 4 0 0 0 0 |
---|
83 | FrameI_l2 : I 0 0 0 0 0.442 0 0 0 0 0 0 0 0 |
---|
84 | Frame1_l2 : B 1 1 0 0 0.442 0 0 0 4 0 0 0 0 |
---|
85 | |
---|
86 | #=========== Motion Search ============= |
---|
87 | FastSearch : 1 # 0:Full search 1:TZ search |
---|
88 | SearchRange : 64 # (0: Search range is a Full frame) |
---|
89 | BipredSearchRange : 4 # Search range for bi-prediction refinement |
---|
90 | HadamardME : 1 # Use of hadamard measure for fractional ME |
---|
91 | FEN : 1 # Fast encoder decision |
---|
92 | FDM : 1 # Fast Decision for Merge RD cost |
---|
93 | |
---|
94 | #======== Quantization ============= |
---|
95 | |
---|
96 | MaxDeltaQP : 0 # CU-based multi-QP optimization |
---|
97 | MaxCuDQPDepth : 0 # Max depth of a minimum CuDQP for sub-LCU-level delta QP |
---|
98 | DeltaQpRD : 0 # Slice-based multi-QP optimization |
---|
99 | RDOQ : 1 # RDOQ |
---|
100 | RDOQTS : 1 # RDOQ for transform skip |
---|
101 | SliceChromaQPOffsetPeriodicity: 0 # Used in conjunction with Slice Cb/Cr QpOffsetIntraOrPeriodic. Use 0 (default) to disable periodic nature. |
---|
102 | SliceCbQpOffsetIntraOrPeriodic: 0 # Chroma Cb QP Offset at slice level for I slice or for periodic inter slices as defined by SliceChromaQPOffsetPeriodicity. Replaces offset in the GOP table. |
---|
103 | SliceCrQpOffsetIntraOrPeriodic: 0 # Chroma Cr QP Offset at slice level for I slice or for periodic inter slices as defined by SliceChromaQPOffsetPeriodicity. Replaces offset in the GOP table. |
---|
104 | |
---|
105 | #=========== Deblock Filter ============ |
---|
106 | |
---|
107 | LoopFilterOffsetInPPS : 1 # Dbl params: 0=varying params in SliceHeader, param = base_param + GOP_offset_param; 1 (default) =constant params in PPS, param = base_param) |
---|
108 | LoopFilterDisable : 0 # Disable deblocking filter (0=Filter, 1=No Filter) (mc) |
---|
109 | LoopFilterBetaOffset_div2 : 0 # base_param: -6 ~ 6 |
---|
110 | LoopFilterTcOffset_div2 : 0 # base_param: -6 ~ 6 |
---|
111 | DeblockingFilterMetric : 0 # blockiness metric (automatically configures deblocking parameters in bitstream). Applies slice-level loop filter offsets (LoopFilterOffsetInPPS and LoopFilterDisable must be 0) |
---|
112 | |
---|
113 | #=========== Misc. ============ |
---|
114 | InternalBitDepth : 8 # codec operating bit-depth |
---|
115 | |
---|
116 | #=========== Coding Tools ================= |
---|
117 | SAO : 1 # Sample adaptive offset (0: OFF, 1: ON) (mc) |
---|
118 | AMP : 1 # Asymmetric motion partitions (0: OFF, 1: ON) |
---|
119 | TransformSkip : 1 # Transform skipping (0: OFF, 1: ON) |
---|
120 | TransformSkipFast : 1 # Fast Transform skipping (0: OFF, 1: ON) |
---|
121 | SAOLcuBoundary : 0 # SAOLcuBoundary using non-deblocked pixels (0: OFF, 1: ON) |
---|
122 | |
---|
123 | #============ Slices ================ |
---|
124 | SliceMode : 0 # 0: Disable all slice options. |
---|
125 | # 1: Enforce maximum number of LCU in an slice, |
---|
126 | # 2: Enforce maximum number of bytes in an 'slice' |
---|
127 | # 3: Enforce maximum number of tiles in a slice |
---|
128 | SliceArgument : 1500 # Argument for 'SliceMode'. |
---|
129 | # If SliceMode==1 it represents max. SliceGranularity-sized blocks per slice. |
---|
130 | # If SliceMode==2 it represents max. bytes per slice. |
---|
131 | # If SliceMode==3 it represents max. tiles per slice. |
---|
132 | |
---|
133 | LFCrossSliceBoundaryFlag : 1 # In-loop filtering, including ALF and DB, is across or not across slice boundary. |
---|
134 | # 0:not across, 1: across |
---|
135 | |
---|
136 | #============ PCM ================ |
---|
137 | PCMEnabledFlag : 0 # 0: No PCM mode |
---|
138 | PCMLog2MaxSize : 5 # Log2 of maximum PCM block size. |
---|
139 | PCMLog2MinSize : 3 # Log2 of minimum PCM block size. |
---|
140 | PCMInputBitDepthFlag : 1 # 0: PCM bit-depth is internal bit-depth. 1: PCM bit-depth is input bit-depth. |
---|
141 | PCMFilterDisableFlag : 0 # 0: Enable loop filtering on I_PCM samples. 1: Disable loop filtering on I_PCM samples. |
---|
142 | |
---|
143 | #============ Tiles ================ |
---|
144 | TileUniformSpacing : 0 # 0: the column boundaries are indicated by TileColumnWidth array, the row boundaries are indicated by TileRowHeight array |
---|
145 | # 1: the column and row boundaries are distributed uniformly |
---|
146 | NumTileColumnsMinus1 : 0 # Number of tile columns in a picture minus 1 |
---|
147 | TileColumnWidthArray : 2 3 # Array containing tile column width values in units of CTU (from left to right in picture) |
---|
148 | NumTileRowsMinus1 : 0 # Number of tile rows in a picture minus 1 |
---|
149 | TileRowHeightArray : 2 # Array containing tile row height values in units of CTU (from top to bottom in picture) |
---|
150 | |
---|
151 | LFCrossTileBoundaryFlag : 1 # In-loop filtering is across or not across tile boundary. |
---|
152 | # 0:not across, 1: across |
---|
153 | |
---|
154 | #============ WaveFront ================ |
---|
155 | WaveFrontSynchro : 0 # 0: No WaveFront synchronisation (WaveFrontSubstreams must be 1 in this case). |
---|
156 | # >0: WaveFront synchronises with the LCU above and to the right by this many LCUs. |
---|
157 | |
---|
158 | #=========== Quantization Matrix ================= |
---|
159 | ScalingList : 0 # ScalingList 0 : off, 1 : default, 2 : file read |
---|
160 | ScalingListFile : scaling_list.txt # Scaling List file name. If file is not exist, use Default Matrix. |
---|
161 | |
---|
162 | #============ Lossless ================ |
---|
163 | TransquantBypassEnableFlag: 0 # Value of PPS flag. |
---|
164 | CUTransquantBypassFlagForce: 0 # Constant lossless-value signaling per CU, if TransquantBypassEnableFlag is 1. |
---|
165 | |
---|
166 | #============ Rate Control ====================== |
---|
167 | RateControl : 0 # Rate control: enable rate control |
---|
168 | TargetBitrate : 1000000 # Rate control: target bitrate, in bps |
---|
169 | KeepHierarchicalBit : 1 # Rate control: keep hierarchical bit allocation in rate control algorithm |
---|
170 | LCULevelRateControl : 1 # Rate control: 1: LCU level RC; 0: picture level RC |
---|
171 | RCLCUSeparateModel : 1 # Rate control: use LCU level separate R-lambda model |
---|
172 | InitialQP : 0 # Rate control: initial QP |
---|
173 | RCForceIntraQP : 0 # Rate control: force intra QP to be equal to initial QP |
---|
174 | |
---|
175 | ### DO NOT ADD ANYTHING BELOW THIS LINE ### |
---|
176 | ### DO NOT DELETE THE EMPTY LINE BELOW ### |
---|