1 /*****************************************************************************
3 *****************************************************************************
4 * Copyright (C) 2003-2008 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.
22 *****************************************************************************/
29 PROFILE_BASELINE = 66,
31 PROFILE_EXTENDED = 88,
34 PROFILE_HIGH422 = 122,
35 PROFILE_HIGH444 = 144,
36 PROFILE_HIGH444_PREDICTIVE = 244,
59 int b_constraint_set0;
60 int b_constraint_set1;
61 int b_constraint_set2;
62 int b_constraint_set3;
64 int i_log2_max_frame_num;
68 int i_log2_max_poc_lsb;
70 int b_delta_pic_order_always_zero;
71 int i_offset_for_non_ref_pic;
72 int i_offset_for_top_to_bottom_field;
73 int i_num_ref_frames_in_poc_cycle;
74 int i_offset_for_ref_frame[256];
77 int b_gaps_in_frame_num_value_allowed;
81 int b_mb_adaptive_frame_field;
82 int b_direct8x8_inference;
96 int b_aspect_ratio_info_present;
100 int b_overscan_info_present;
103 int b_signal_type_present;
106 int b_color_description_present;
111 int b_chroma_loc_info_present;
112 int i_chroma_loc_top;
113 int i_chroma_loc_bottom;
115 int b_timing_info_present;
116 uint32_t i_num_units_in_tick;
117 uint32_t i_time_scale;
118 int b_fixed_frame_rate;
120 int b_nal_hrd_parameters_present;
121 int b_vcl_hrd_parameters_present;
126 int i_bit_rate_scale;
127 int i_cpb_size_scale;
128 int i_bit_rate_value;
129 int i_cpb_size_value;
130 int i_bit_rate_unscaled;
131 int i_cpb_size_unscaled;
134 int i_initial_cpb_removal_delay_length;
135 int i_cpb_removal_delay_length;
136 int i_dpb_output_delay_length;
137 int i_time_offset_length;
140 int b_pic_struct_present;
141 int b_bitstream_restriction;
142 int b_motion_vectors_over_pic_boundaries;
143 int i_max_bytes_per_pic_denom;
144 int i_max_bits_per_mb_denom;
145 int i_log2_max_mv_length_horizontal;
146 int i_log2_max_mv_length_vertical;
147 int i_num_reorder_frames;
148 int i_max_dec_frame_buffering;
150 /* FIXME to complete */
153 int b_qpprime_y_zero_transform_bypass;
165 int i_num_slice_groups;
167 int i_num_ref_idx_l0_default_active;
168 int i_num_ref_idx_l1_default_active;
171 int b_weighted_bipred;
176 int i_chroma_qp_index_offset;
178 int b_deblocking_filter_control;
179 int b_constrained_intra_pred;
180 int b_redundant_pic_cnt;
182 int b_transform_8x8_mode;
185 const uint8_t *scaling_list[6]; /* could be 8, but we don't allow separate Cb/Cr lists */
189 /* default quant matrices */
190 static const uint8_t x264_cqm_jvt4i[16] =
197 static const uint8_t x264_cqm_jvt4p[16] =
204 static const uint8_t x264_cqm_jvt8i[64] =
206 6,10,13,16,18,23,25,27,
207 10,11,16,18,23,25,27,29,
208 13,16,18,23,25,27,29,31,
209 16,18,23,25,27,29,31,33,
210 18,23,25,27,29,31,33,36,
211 23,25,27,29,31,33,36,38,
212 25,27,29,31,33,36,38,40,
213 27,29,31,33,36,38,40,42
215 static const uint8_t x264_cqm_jvt8p[64] =
217 9,13,15,17,19,21,22,24,
218 13,13,17,19,21,22,24,25,
219 15,17,19,21,22,24,25,27,
220 17,19,21,22,24,25,27,28,
221 19,21,22,24,25,27,28,30,
222 21,22,24,25,27,28,30,32,
223 22,24,25,27,28,30,32,33,
224 24,25,27,28,30,32,33,35
226 static const uint8_t x264_cqm_flat16[64] =
228 16,16,16,16,16,16,16,16,
229 16,16,16,16,16,16,16,16,
230 16,16,16,16,16,16,16,16,
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
237 static const uint8_t * const x264_cqm_jvt[6] =
239 x264_cqm_jvt4i, x264_cqm_jvt4p,
240 x264_cqm_jvt4i, x264_cqm_jvt4p,
241 x264_cqm_jvt8i, x264_cqm_jvt8p
244 int x264_cqm_init( x264_t *h );
245 void x264_cqm_delete( x264_t *h );
246 int x264_cqm_parse_file( x264_t *h, const char *filename );