1 /*****************************************************************************
2 * set.h: quantization init
3 *****************************************************************************
4 * Copyright (C) 2003-2011 x264 project
6 * Authors: Loren Merritt <lorenm@u.washington.edu>
7 * Laurent Aimar <fenrir@via.ecp.fr>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111, USA.
23 * This program is also available under a commercial proprietary license.
24 * For more information, contact us at licensing@x264.com.
25 *****************************************************************************/
32 PROFILE_BASELINE = 66,
34 PROFILE_EXTENDED = 88,
37 PROFILE_HIGH422 = 122,
38 PROFILE_HIGH444 = 144,
39 PROFILE_HIGH444_PREDICTIVE = 244,
62 int b_constraint_set0;
63 int b_constraint_set1;
64 int b_constraint_set2;
65 int b_constraint_set3;
67 int i_log2_max_frame_num;
71 int i_log2_max_poc_lsb;
73 int b_delta_pic_order_always_zero;
74 int i_offset_for_non_ref_pic;
75 int i_offset_for_top_to_bottom_field;
76 int i_num_ref_frames_in_poc_cycle;
77 int i_offset_for_ref_frame[256];
80 int b_gaps_in_frame_num_value_allowed;
84 int b_mb_adaptive_frame_field;
85 int b_direct8x8_inference;
99 int b_aspect_ratio_info_present;
103 int b_overscan_info_present;
106 int b_signal_type_present;
109 int b_color_description_present;
114 int b_chroma_loc_info_present;
115 int i_chroma_loc_top;
116 int i_chroma_loc_bottom;
118 int b_timing_info_present;
119 uint32_t i_num_units_in_tick;
120 uint32_t i_time_scale;
121 int b_fixed_frame_rate;
123 int b_nal_hrd_parameters_present;
124 int b_vcl_hrd_parameters_present;
129 int i_bit_rate_scale;
130 int i_cpb_size_scale;
131 int i_bit_rate_value;
132 int i_cpb_size_value;
133 int i_bit_rate_unscaled;
134 int i_cpb_size_unscaled;
137 int i_initial_cpb_removal_delay_length;
138 int i_cpb_removal_delay_length;
139 int i_dpb_output_delay_length;
140 int i_time_offset_length;
143 int b_pic_struct_present;
144 int b_bitstream_restriction;
145 int b_motion_vectors_over_pic_boundaries;
146 int i_max_bytes_per_pic_denom;
147 int i_max_bits_per_mb_denom;
148 int i_log2_max_mv_length_horizontal;
149 int i_log2_max_mv_length_vertical;
150 int i_num_reorder_frames;
151 int i_max_dec_frame_buffering;
153 /* FIXME to complete */
156 int b_qpprime_y_zero_transform_bypass;
168 int i_num_slice_groups;
170 int i_num_ref_idx_l0_default_active;
171 int i_num_ref_idx_l1_default_active;
174 int b_weighted_bipred;
179 int i_chroma_qp_index_offset;
181 int b_deblocking_filter_control;
182 int b_constrained_intra_pred;
183 int b_redundant_pic_cnt;
185 int b_transform_8x8_mode;
188 const uint8_t *scaling_list[6]; /* could be 8, but we don't allow separate Cb/Cr lists */
192 /* default quant matrices */
193 static const uint8_t x264_cqm_jvt4i[16] =
200 static const uint8_t x264_cqm_jvt4p[16] =
207 static const uint8_t x264_cqm_jvt8i[64] =
209 6,10,13,16,18,23,25,27,
210 10,11,16,18,23,25,27,29,
211 13,16,18,23,25,27,29,31,
212 16,18,23,25,27,29,31,33,
213 18,23,25,27,29,31,33,36,
214 23,25,27,29,31,33,36,38,
215 25,27,29,31,33,36,38,40,
216 27,29,31,33,36,38,40,42
218 static const uint8_t x264_cqm_jvt8p[64] =
220 9,13,15,17,19,21,22,24,
221 13,13,17,19,21,22,24,25,
222 15,17,19,21,22,24,25,27,
223 17,19,21,22,24,25,27,28,
224 19,21,22,24,25,27,28,30,
225 21,22,24,25,27,28,30,32,
226 22,24,25,27,28,30,32,33,
227 24,25,27,28,30,32,33,35
229 static const uint8_t x264_cqm_flat16[64] =
231 16,16,16,16,16,16,16,16,
232 16,16,16,16,16,16,16,16,
233 16,16,16,16,16,16,16,16,
234 16,16,16,16,16,16,16,16,
235 16,16,16,16,16,16,16,16,
236 16,16,16,16,16,16,16,16,
237 16,16,16,16,16,16,16,16,
238 16,16,16,16,16,16,16,16
240 static const uint8_t * const x264_cqm_jvt[6] =
242 x264_cqm_jvt4i, x264_cqm_jvt4p,
243 x264_cqm_jvt4i, x264_cqm_jvt4p,
244 x264_cqm_jvt8i, x264_cqm_jvt8p
247 int x264_cqm_init( x264_t *h );
248 void x264_cqm_delete( x264_t *h );
249 int x264_cqm_parse_file( x264_t *h, const char *filename );