24 fixed(1, rbsp_stop_one_bit, 1);
26 fixed(1, rbsp_alignment_zero_bit, 0);
32 int expected_nal_unit_type)
36 fixed(1, forbidden_zero_bit, 0);
37 flag(nuh_reserved_zero_bit);
39 u(6, nuh_layer_id, 0, 55);
41 if (expected_nal_unit_type >= 0)
42 u(5, nal_unit_type, expected_nal_unit_type, expected_nal_unit_type);
46 u(3, nuh_temporal_id_plus1, 1, 7);
54 fixed(1, byte_alignment_bit_equal_to_one, 1);
56 fixed(1, byte_alignment_bit_equal_to_zero, 0);
64 int err,
i, num_additional_bits_used;
66 flag(gci_present_flag);
67 if (current->gci_present_flag) {
69 flag(gci_intra_only_constraint_flag);
70 flag(gci_all_layers_independent_constraint_flag);
71 flag(gci_one_au_only_constraint_flag);
74 u(4, gci_sixteen_minus_max_bitdepth_constraint_idc, 0, 8);
75 ub(2, gci_three_minus_max_chroma_format_constraint_idc);
78 flag(gci_no_mixed_nalu_types_in_pic_constraint_flag);
79 flag(gci_no_trail_constraint_flag);
80 flag(gci_no_stsa_constraint_flag);
81 flag(gci_no_rasl_constraint_flag);
82 flag(gci_no_radl_constraint_flag);
83 flag(gci_no_idr_constraint_flag);
84 flag(gci_no_cra_constraint_flag);
85 flag(gci_no_gdr_constraint_flag);
86 flag(gci_no_aps_constraint_flag);
87 flag(gci_no_idr_rpl_constraint_flag);
90 flag(gci_one_tile_per_pic_constraint_flag);
91 flag(gci_pic_header_in_slice_header_constraint_flag);
92 flag(gci_one_slice_per_pic_constraint_flag);
93 flag(gci_no_rectangular_slice_constraint_flag);
94 flag(gci_one_slice_per_subpic_constraint_flag);
95 flag(gci_no_subpic_info_constraint_flag);
98 ub(2, gci_three_minus_max_log2_ctu_size_constraint_idc);
99 flag(gci_no_partition_constraints_override_constraint_flag);
100 flag(gci_no_mtt_constraint_flag);
101 flag(gci_no_qtbtt_dual_tree_intra_constraint_flag);
104 flag(gci_no_palette_constraint_flag);
105 flag(gci_no_ibc_constraint_flag);
106 flag(gci_no_isp_constraint_flag);
107 flag(gci_no_mrl_constraint_flag);
108 flag(gci_no_mip_constraint_flag);
109 flag(gci_no_cclm_constraint_flag);
112 flag(gci_no_ref_pic_resampling_constraint_flag);
113 flag(gci_no_res_change_in_clvs_constraint_flag);
114 flag(gci_no_weighted_prediction_constraint_flag);
115 flag(gci_no_ref_wraparound_constraint_flag);
116 flag(gci_no_temporal_mvp_constraint_flag);
117 flag(gci_no_sbtmvp_constraint_flag);
118 flag(gci_no_amvr_constraint_flag);
119 flag(gci_no_bdof_constraint_flag);
120 flag(gci_no_smvd_constraint_flag);
121 flag(gci_no_dmvr_constraint_flag);
122 flag(gci_no_mmvd_constraint_flag);
123 flag(gci_no_affine_motion_constraint_flag);
124 flag(gci_no_prof_constraint_flag);
125 flag(gci_no_bcw_constraint_flag);
126 flag(gci_no_ciip_constraint_flag);
127 flag(gci_no_gpm_constraint_flag);
130 flag(gci_no_luma_transform_size_64_constraint_flag);
131 flag(gci_no_transform_skip_constraint_flag);
132 flag(gci_no_bdpcm_constraint_flag);
133 flag(gci_no_mts_constraint_flag);
134 flag(gci_no_lfnst_constraint_flag);
135 flag(gci_no_joint_cbcr_constraint_flag);
136 flag(gci_no_sbt_constraint_flag);
137 flag(gci_no_act_constraint_flag);
138 flag(gci_no_explicit_scaling_list_constraint_flag);
139 flag(gci_no_dep_quant_constraint_flag);
140 flag(gci_no_sign_data_hiding_constraint_flag);
141 flag(gci_no_cu_qp_delta_constraint_flag);
142 flag(gci_no_chroma_qp_offset_constraint_flag);
145 flag(gci_no_sao_constraint_flag);
146 flag(gci_no_alf_constraint_flag);
147 flag(gci_no_ccalf_constraint_flag);
148 flag(gci_no_lmcs_constraint_flag);
149 flag(gci_no_ladf_constraint_flag);
150 flag(gci_no_virtual_boundaries_constraint_flag);
151 ub(8, gci_num_additional_bits);
152 if (current->gci_num_additional_bits > 5) {
153 flag(gci_all_rap_pictures_constraint_flag);
154 flag(gci_no_extended_precision_processing_constraint_flag);
155 flag(gci_no_ts_residual_coding_rice_constraint_flag);
156 flag(gci_no_rrc_rice_extension_constraint_flag);
157 flag(gci_no_persistent_rice_adaptation_constraint_flag);
158 flag(gci_no_reverse_last_sig_coeff_constraint_flag);
159 num_additional_bits_used = 6;
161 infer(gci_all_rap_pictures_constraint_flag, 0);
162 infer(gci_no_extended_precision_processing_constraint_flag, 0);
163 infer(gci_no_ts_residual_coding_rice_constraint_flag, 0);
164 infer(gci_no_rrc_rice_extension_constraint_flag, 0);
165 infer(gci_no_persistent_rice_adaptation_constraint_flag, 0);
166 infer(gci_no_reverse_last_sig_coeff_constraint_flag, 0);
167 num_additional_bits_used = 0;
170 for (
i = 0;
i < current->gci_num_additional_bits - num_additional_bits_used;
i++)
171 flags(gci_reserved_bit[
i], 1,
i);
174 fixed(1, gci_alignment_zero_bit, 0);
181 int profile_tier_present_flag,
182 int max_num_sub_layers_minus1)
186 if (profile_tier_present_flag) {
187 ub(7, general_profile_idc);
188 flag(general_tier_flag);
190 ub(8, general_level_idc);
191 flag(ptl_frame_only_constraint_flag);
192 flag(ptl_multilayer_enabled_flag);
193 if (profile_tier_present_flag) {
198 for (
i = max_num_sub_layers_minus1 - 1;
i >= 0;
i--)
199 flags(ptl_sublayer_level_present_flag[
i], 1,
i);
201 flag(ptl_reserved_zero_bit);
202 for (
i = max_num_sub_layers_minus1 - 1;
i >= 0;
i--)
203 if (current->ptl_sublayer_level_present_flag[
i])
204 ubs(8, sublayer_level_idc[
i], 1,
i);
205 if (profile_tier_present_flag) {
206 ub(8, ptl_num_sub_profiles);
207 for (
i = 0;
i < current->ptl_num_sub_profiles;
i++)
208 ubs(32, general_sub_profile_idc[
i], 1,
i);
217 infer(vui_progressive_source_flag, 0);
218 infer(vui_interlaced_source_flag, 0);
220 infer(vui_non_packed_constraint_flag, 0);
221 infer(vui_non_projected_constraint_flag, 0);
223 infer(vui_aspect_ratio_constant_flag, 0);
224 infer(vui_aspect_ratio_idc, 0);
226 infer(vui_overscan_info_present_flag, 0);
228 infer(vui_colour_primaries, 2);
229 infer(vui_transfer_characteristics, 2);
230 infer(vui_matrix_coeffs, 2);
231 infer(vui_full_range_flag, 0);
233 infer(vui_chroma_sample_loc_type_frame, 6);
234 infer(vui_chroma_sample_loc_type_top_field, 6);
235 infer(vui_chroma_sample_loc_type_bottom_field, 6);
241 uint8_t chroma_format_idc)
245 flag(vui_progressive_source_flag);
246 flag(vui_interlaced_source_flag);
247 flag(vui_non_packed_constraint_flag);
248 flag(vui_non_projected_constraint_flag);
249 flag(vui_aspect_ratio_info_present_flag);
250 if (current->vui_aspect_ratio_info_present_flag) {
251 flag(vui_aspect_ratio_constant_flag);
252 ub(8, vui_aspect_ratio_idc);
253 if (current->vui_aspect_ratio_idc == 255) {
254 ub(16, vui_sar_width);
255 ub(16, vui_sar_height);
258 infer(vui_aspect_ratio_constant_flag, 0);
259 infer(vui_aspect_ratio_idc, 0);
261 flag(vui_overscan_info_present_flag);
262 if (current->vui_overscan_info_present_flag)
263 flag(vui_overscan_appropriate_flag);
264 flag(vui_colour_description_present_flag);
265 if (current->vui_colour_description_present_flag) {
266 ub(8, vui_colour_primaries);
268 current->vui_colour_primaries);
269 ub(8, vui_transfer_characteristics);
271 "vui_transfer_characteristics == %d \n",
272 current->vui_transfer_characteristics);
273 ub(8, vui_matrix_coeffs);
275 current->vui_matrix_coeffs);
276 flag(vui_full_range_flag);
278 infer(vui_colour_primaries, 2);
279 infer(vui_transfer_characteristics, 2);
280 infer(vui_matrix_coeffs, 2);
281 infer(vui_full_range_flag, 0);
283 flag(vui_chroma_loc_info_present_flag);
284 if (chroma_format_idc != 1 && current->vui_chroma_loc_info_present_flag) {
286 "vui_chroma_loc_info_present_flag can't not be true",
290 if (current->vui_chroma_loc_info_present_flag) {
291 if (current->vui_progressive_source_flag &&
292 !current->vui_interlaced_source_flag) {
293 ue(vui_chroma_sample_loc_type_frame, 0, 6);
295 ue(vui_chroma_sample_loc_type_top_field, 0, 6);
296 ue(vui_chroma_sample_loc_type_bottom_field, 0, 6);
299 if (chroma_format_idc == 1) {
300 infer(vui_chroma_sample_loc_type_frame, 6);
301 infer(vui_chroma_sample_loc_type_top_field,
302 current->vui_chroma_sample_loc_type_frame);
303 infer(vui_chroma_sample_loc_type_bottom_field,
304 current->vui_chroma_sample_loc_type_frame);
312 uint32_t payload_size,
int cur_pos)
315 size_t byte_length, k;
329 if (!payload_zero_bits)
331 payload_zero_bits =
ff_ctz(payload_zero_bits);
332 current->bit_length =
bits_left - payload_zero_bits - 1;
333 allocate(current->data, (current->bit_length + 7) / 8);
336 byte_length = (current->bit_length + 7) / 8;
337 for (k = 0; k < byte_length; k++) {
338 int length =
FFMIN(current->bit_length - k * 8, 8);
339 xu(length, reserved_payload_extension_data, current->data[k],
347 H266RawVUI *current, uint16_t vui_payload_size,
348 uint8_t chroma_format_idc)
351 int start_position, current_position;
357 if (current_position < 8 * vui_payload_size) {
359 vui_payload_size, current_position));
360 fixed(1, vui_payload_bit_equal_to_one, 1);
362 fixed(1, vui_payload_bit_equal_to_zero, 0);
378 current->bit_length = k;
381 allocate(current->data, (current->bit_length + 7) / 8);
382 for (k = 0; k < current->bit_length; k++) {
384 current->data[k / 8] |=
bit << (7 - k % 8);
388 for (k = 0; k < current->bit_length; k++)
396 uint8_t max_sublayers_minus1,
397 uint8_t sublayer_info_flag)
400 for (
i = (sublayer_info_flag ? 0 : max_sublayers_minus1);
401 i <= max_sublayers_minus1;
i++) {
403 ues(dpb_max_num_reorder_pics[
i],
404 0, current->dpb_max_dec_pic_buffering_minus1[
i], 1,
i);
405 ues(dpb_max_latency_increase_plus1[
i], 0, UINT32_MAX - 1, 1,
i);
413 uint8_t list_idx, uint8_t rpls_idx,
417 int err,
i, j, general_layer_idx = -1, num_direct_ref_layers = 0;
422 "VPS id %d not available.\n",
sps->sps_video_parameter_set_id);
426 for (
i = 0;
i <=
vps->vps_max_layers_minus1;
i++) {
427 if (
sps->nal_unit_header.nuh_layer_id ==
vps->vps_layer_id[
i]) {
428 general_layer_idx =
i;
432 if (general_layer_idx < 0) {
434 sps->nal_unit_header.nuh_layer_id);
438 for (j = 0; j <=
vps->vps_max_layers_minus1; j++) {
439 if (
vps->vps_direct_ref_layer_flag[general_layer_idx][j])
440 num_direct_ref_layers++;
444 if (
sps->sps_long_term_ref_pics_flag &&
445 rpls_idx < sps->sps_num_ref_pic_lists[list_idx] &&
446 current->num_ref_entries > 0)
447 flag(ltrp_in_header_flag);
448 if (
sps->sps_long_term_ref_pics_flag &&
449 rpls_idx ==
sps->sps_num_ref_pic_lists[list_idx])
450 infer(ltrp_in_header_flag, 1);
451 for (
i = 0, j = 0;
i < current->num_ref_entries;
i++) {
452 if (
sps->sps_inter_layer_prediction_enabled_flag)
453 flags(inter_layer_ref_pic_flag[
i], 1,
i);
455 infer(inter_layer_ref_pic_flag[
i], 0);
457 if (!current->inter_layer_ref_pic_flag[
i]) {
458 if (
sps->sps_long_term_ref_pics_flag)
459 flags(st_ref_pic_flag[
i], 1,
i);
461 infer(st_ref_pic_flag[
i], 1);
462 if (current->st_ref_pic_flag[
i]) {
463 int abs_delta_poc_st;
465 if ((
sps->sps_weighted_pred_flag ||
466 sps->sps_weighted_bipred_flag) &&
i != 0)
467 abs_delta_poc_st = current->abs_delta_poc_st[
i];
469 abs_delta_poc_st = current->abs_delta_poc_st[
i] + 1;
470 if (abs_delta_poc_st > 0)
471 flags(strp_entry_sign_flag[
i], 1,
i);
473 if (!current->ltrp_in_header_flag) {
474 uint8_t
bits =
sps->sps_log2_max_pic_order_cnt_lsb_minus4 + 4;
475 ubs(
bits, rpls_poc_lsb_lt[j], 1, j);
480 if (num_direct_ref_layers == 0) {
482 "num_direct_ref_layers needs > 0.\n");
485 ues(ilrp_idx[
i], 0, num_direct_ref_layers - 1, 1,
i);
495 int err,
i, j, num_ltrp_entries;
496 for (
i = 0;
i < 2;
i++) {
497 if (
sps->sps_num_ref_pic_lists[
i] > 0 &&
498 (
i == 0 || (
i == 1 &&
pps->pps_rpl1_idx_present_flag))) {
501 if (
sps->sps_num_ref_pic_lists[
i] == 0) {
502 infer(rpl_sps_flag[
i], 0);
504 if (!
pps->pps_rpl1_idx_present_flag &&
i == 1)
505 infer(rpl_sps_flag[1], current->rpl_sps_flag[0]);
508 if (current->rpl_sps_flag[
i]) {
509 if (
sps->sps_num_ref_pic_lists[
i] > 1 &&
510 (
i == 0 || (
i == 1 &&
pps->pps_rpl1_idx_present_flag))) {
512 us(
bits, rpl_idx[
i], 0,
sps->sps_num_ref_pic_lists[
i] - 1, 1,
i);
513 }
else if (
sps->sps_num_ref_pic_lists[
i] == 1) {
515 }
else if (
i == 1 && !
pps->pps_rpl1_idx_present_flag) {
516 infer(rpl_idx[1], current->rpl_idx[0]);
520 "can't infer the rpl_idx[i]\n");
523 memcpy(¤t->rpl_ref_list[
i],
524 &
sps->sps_ref_pic_list_struct[
i][current->rpl_idx[
i]],
525 sizeof(current->rpl_ref_list[
i]));
528 i,
sps->sps_num_ref_pic_lists[
i],
531 ref_list = ¤t->rpl_ref_list[
i];
533 num_ltrp_entries = 0;
542 for (j = 0; j < num_ltrp_entries; j++) {
544 ubs(
sps->sps_log2_max_pic_order_cnt_lsb_minus4 + 4,
545 poc_lsb_lt[
i][j], 2,
i, j);
547 flags(delta_poc_msb_cycle_present_flag[
i][j], 2,
i, j);
548 if (current->delta_poc_msb_cycle_present_flag[
i][j]) {
550 1 << (32 -
sps->sps_log2_max_pic_order_cnt_lsb_minus4 - 4);
551 ues(delta_poc_msb_cycle_lt[
i][j], 0,
max, 2,
i, j);
563 ub(32, num_units_in_tick);
565 flag(general_nal_hrd_params_present_flag);
566 flag(general_vcl_hrd_params_present_flag);
568 if (current->general_nal_hrd_params_present_flag ||
569 current->general_vcl_hrd_params_present_flag) {
570 flag(general_same_pic_timing_in_all_ols_flag);
571 flag(general_du_hrd_params_present_flag);
572 if (current->general_du_hrd_params_present_flag)
573 ub(8, tick_divisor_minus2);
574 ub(4, bit_rate_scale);
575 ub(4, cpb_size_scale);
576 if (current->general_du_hrd_params_present_flag)
577 ub(4, cpb_size_du_scale);
578 ue(hrd_cpb_cnt_minus1, 0, 31);
581 infer(general_du_hrd_params_present_flag, 0);
593 for (
i = 0;
i <= general->hrd_cpb_cnt_minus1;
i++) {
594 ues(bit_rate_value_minus1[sublayer_id][
i], 0, UINT32_MAX - 1, 2,
596 ues(cpb_size_value_minus1[sublayer_id][
i], 0, UINT32_MAX - 1, 2,
598 if (general->general_du_hrd_params_present_flag) {
599 ues(cpb_size_du_value_minus1[sublayer_id][
i],
600 0, UINT32_MAX - 1, 2, sublayer_id,
i);
601 ues(bit_rate_du_value_minus1[sublayer_id][
i],
602 0, UINT32_MAX - 1, 2, sublayer_id,
i);
604 flags(cbr_flag[sublayer_id][
i], 2, sublayer_id,
i);
611 uint8_t first_sublayer, uint8_t max_sublayers_minus1,
615 for (
i = first_sublayer;
i <= max_sublayers_minus1;
i++) {
616 flags(fixed_pic_rate_general_flag[
i], 1,
i);
617 if (!current->fixed_pic_rate_general_flag[
i])
618 flags(fixed_pic_rate_within_cvs_flag[
i], 1,
i);
620 infer(fixed_pic_rate_within_cvs_flag[
i], 1);
621 if (current->fixed_pic_rate_within_cvs_flag[
i]) {
622 ues(elemental_duration_in_tc_minus1[
i], 0, 2047, 1,
i);
623 infer(low_delay_hrd_flag[
i], 0);
624 }
else if ((general->general_nal_hrd_params_present_flag ||
625 general->general_vcl_hrd_params_present_flag) &&
626 general->hrd_cpb_cnt_minus1 == 0) {
627 flags(low_delay_hrd_flag[
i], 1,
i);
629 infer(low_delay_hrd_flag[
i], 0);
631 if (general->general_nal_hrd_params_present_flag)
633 ¤t->nal_sub_layer_hrd_parameters,
635 if (general->general_vcl_hrd_params_present_flag)
637 ¤t->nal_sub_layer_hrd_parameters,
648 HEADER(
"Operating point information");
653 flag(opi_ols_info_present_flag);
654 flag(opi_htid_info_present_flag);
656 if(current->opi_ols_info_present_flag)
659 if(current->opi_htid_info_present_flag)
660 ub(3, opi_htid_plus1);
662 flag(opi_extension_flag);
663 if (current->opi_extension_flag)
675 HEADER(
"Decoding capability information");
680 ub(4, dci_reserved_zero_4bits);
681 ub(4, dci_num_ptls_minus1);
682 for (
i = 0;
i <= current->dci_num_ptls_minus1;
i++)
684 current->dci_profile_tier_level +
i, 1, 0));
686 flag(dci_extension_flag);
687 if (current->dci_extension_flag)
698 uint16_t total_num_olss = 0;
699 uint8_t ols_mode_idc = 0;
700 uint16_t num_multi_layer_olss = 0;
705 HEADER(
"Video Parameter Set");
711 ub(6, vps_max_layers_minus1);
712 u(3, vps_max_sublayers_minus1, 0, 6);
713 if (current->vps_max_layers_minus1 > 0
714 && current->vps_max_sublayers_minus1 > 0)
715 flag(vps_default_ptl_dpb_hrd_max_tid_flag);
717 infer(vps_default_ptl_dpb_hrd_max_tid_flag, 1);
719 if (current->vps_max_layers_minus1 > 0)
720 flag(vps_all_independent_layers_flag);
722 infer(vps_all_independent_layers_flag, 1);
724 for (
i = 0;
i <= current->vps_max_layers_minus1;
i++) {
725 ubs(6, vps_layer_id[
i], 1,
i);
726 if (
i > 0 && current->vps_layer_id[
i] <= current->vps_layer_id[
i - 1]) {
728 "vps_layer_id[%d](%d) should > vps_layer_id[%d](%d).\n",
729 i, current->vps_layer_id[
i],
i - 1,
730 current->vps_layer_id[
i - 1]);
733 if (
i > 0 && !current->vps_all_independent_layers_flag) {
734 flags(vps_independent_layer_flag[
i], 1,
i);
735 if (!current->vps_independent_layer_flag[
i]) {
736 flags(vps_max_tid_ref_present_flag[
i], 1,
i);
737 for (j = 0; j <
i; j++) {
738 flags(vps_direct_ref_layer_flag[
i][j], 2,
i, j);
739 if (current->vps_max_tid_ref_present_flag[
i] &&
740 current->vps_direct_ref_layer_flag[
i][j]) {
741 ubs(3, vps_max_tid_il_ref_pics_plus1[
i][j], 2,
i, j);
743 infer(vps_max_tid_il_ref_pics_plus1[
i][j],
744 current->vps_max_sublayers_minus1 + 1);
748 for (j = 0; j <
i; j++) {
749 infer(vps_direct_ref_layer_flag[
i][j], 0);
753 infer(vps_independent_layer_flag[
i], 1);
754 for (j = 0; j <
i; j++) {
755 infer(vps_direct_ref_layer_flag[
i][j], 0);
760 if (current->vps_max_layers_minus1 > 0) {
761 if (current->vps_all_independent_layers_flag)
762 flag(vps_each_layer_is_an_ols_flag);
764 infer(vps_each_layer_is_an_ols_flag, 0);
765 if (!current->vps_each_layer_is_an_ols_flag) {
766 if (!current->vps_all_independent_layers_flag)
767 ub(2, vps_ols_mode_idc);
769 infer(vps_ols_mode_idc, 2);
770 if (current->vps_ols_mode_idc == 2) {
771 ub(8, vps_num_output_layer_sets_minus2);
772 for (
i = 1;
i <= current->vps_num_output_layer_sets_minus2 + 1;
774 for (j = 0; j <= current->vps_max_layers_minus1; j++)
775 flags(vps_ols_output_layer_flag[
i][j], 2,
i, j);
777 ols_mode_idc = current->vps_ols_mode_idc;
781 if (ols_mode_idc == 4 || ols_mode_idc == 0 || ols_mode_idc == 1)
782 total_num_olss = current->vps_max_layers_minus1 + 1;
783 else if (ols_mode_idc == 2)
784 total_num_olss = current->vps_num_output_layer_sets_minus2 + 2;
787 "ols_mode_idc == 3, patch welcome");
788 u(8, vps_num_ptls_minus1, 0, total_num_olss - 1);
790 infer(vps_each_layer_is_an_ols_flag, 1);
791 infer(vps_num_ptls_minus1, 0);
794 for (
i = 0;
i <= current->vps_num_ptls_minus1;
i++) {
796 flags(vps_pt_present_flag[
i], 1,
i);
798 infer(vps_pt_present_flag[
i], 1);
800 if (!current->vps_default_ptl_dpb_hrd_max_tid_flag)
801 us(3, vps_ptl_max_tid[
i], 0, current->vps_max_sublayers_minus1, 1,
i);
803 infer(vps_ptl_max_tid[
i], current->vps_max_sublayers_minus1);
806 fixed(1, vps_ptl_alignment_zero_bit, 0);
817 for (
i = 0;
i <= current->vps_max_layers_minus1;
i++) {
818 for (j = 0; j <= current->vps_max_layers_minus1; j++) {
819 dependency_flag[
i][j] = current->vps_direct_ref_layer_flag[
i][j];
820 for (k = 0; k <
i; k++) {
821 if (current->vps_direct_ref_layer_flag[
i][k] &&
822 dependency_flag[k][j])
823 dependency_flag[
i][j] = 1;
827 for (
i = 0;
i <= current->vps_max_layers_minus1;
i++) {
829 for (j = 0,
r = 0; j <= current->vps_max_layers_minus1; j++) {
830 if (dependency_flag[
i][j])
831 reference_layer_idx[
i][
r++] = j;
833 num_ref_layers[
i] =
r;
837 num_output_layers_in_ols[0] = 1;
838 num_sub_layers_in_layer_in_ols[0][0] =
839 current->vps_ptl_max_tid[current->vps_ols_ptl_idx[0]] + 1;
840 for (
i = 1;
i < total_num_olss;
i++) {
841 if (ols_mode_idc == 4 || ols_mode_idc == 0) {
842 num_output_layers_in_ols[
i] = 1;
843 if (current->vps_each_layer_is_an_ols_flag) {
844 num_sub_layers_in_layer_in_ols[
i][0] =
845 current->vps_ptl_max_tid[current->vps_ols_ptl_idx[
i]] + 1;
847 num_sub_layers_in_layer_in_ols[
i][
i] =
848 current->vps_ptl_max_tid[current->vps_ols_ptl_idx[
i]] + 1;
849 for (k =
i - 1; k >= 0; k--) {
850 num_sub_layers_in_layer_in_ols[
i][k] = 0;
851 for (m = k + 1; m <=
i; m++) {
852 uint8_t max_sublayer_needed =
853 FFMIN(num_sub_layers_in_layer_in_ols[
i][m],
854 current->vps_max_tid_il_ref_pics_plus1[m][k]);
855 if (current->vps_direct_ref_layer_flag[m][k] &&
856 num_sub_layers_in_layer_in_ols[
i][k] < max_sublayer_needed)
857 num_sub_layers_in_layer_in_ols[
i][k] = max_sublayer_needed;
861 }
else if (current->vps_ols_mode_idc == 1) {
862 num_output_layers_in_ols[
i] =
i + 1;
863 for (j = 0; j < num_output_layers_in_ols[
i]; j++) {
864 num_sub_layers_in_layer_in_ols[
i][j] =
865 current->vps_ptl_max_tid[current->vps_ols_ptl_idx[
i]] + 1;
867 }
else if (current->vps_ols_mode_idc == 2) {
868 uint8_t highest_included_layer = 0;
869 for (j = 0; j <= current->vps_max_layers_minus1; j++) {
870 layer_included_in_ols_flag[
i][j] = 0;
871 num_sub_layers_in_layer_in_ols[
i][j] = 0;
873 for (k = 0, j = 0; k <= current->vps_max_layers_minus1; k++) {
874 if (current->vps_ols_output_layer_flag[
i][k]) {
875 layer_included_in_ols_flag[
i][k] = 1;
876 highest_included_layer = k;
877 output_layer_idx[
i][j] = k;
878 num_sub_layers_in_layer_in_ols[
i][k] =
879 current->vps_ptl_max_tid[current->
880 vps_ols_ptl_idx[
i]] + 1;
884 num_output_layers_in_ols[
i] = j;
885 for (j = 0; j < num_output_layers_in_ols[
i]; j++) {
886 int idx = output_layer_idx[
i][j];
887 for (k = 0; k < num_ref_layers[idx]; k++) {
888 if (!layer_included_in_ols_flag[
i][reference_layer_idx[idx][k]])
889 layer_included_in_ols_flag[
i][reference_layer_idx[idx][k]] = 1;
892 for (k = highest_included_layer - 1; k >= 0; k--) {
893 if (layer_included_in_ols_flag[
i][k] &&
894 !current->vps_ols_output_layer_flag[
i][k]) {
895 for (m = k + 1; m <= highest_included_layer; m++) {
896 uint8_t max_sublayer_needed =
897 FFMIN(num_sub_layers_in_layer_in_ols[
i][m],
898 current->vps_max_tid_il_ref_pics_plus1[m][k]);
899 if (current->vps_direct_ref_layer_flag[m][k] &&
900 layer_included_in_ols_flag[
i][m] &&
901 num_sub_layers_in_layer_in_ols[
i][k] <
903 num_sub_layers_in_layer_in_ols[
i][k] =
909 if (!num_output_layers_in_ols[
i])
912 for (
i = 1;
i < total_num_olss;
i++) {
913 int num_layers_in_ols = 0;
914 if (current->vps_each_layer_is_an_ols_flag) {
915 num_layers_in_ols = 1;
916 }
else if (current->vps_ols_mode_idc == 0 ||
917 current->vps_ols_mode_idc == 1) {
918 num_layers_in_ols =
i + 1;
919 }
else if (current->vps_ols_mode_idc == 2) {
920 for (k = 0, j = 0; k <= current->vps_max_layers_minus1; k++)
921 if (layer_included_in_ols_flag[
i][k])
923 num_layers_in_ols = j;
925 if (num_layers_in_ols > 1) {
926 num_multi_layer_olss++;
929 if (!current->vps_each_layer_is_an_ols_flag && num_multi_layer_olss == 0)
933 for (
i = 0;
i <= current->vps_num_ptls_minus1;
i++) {
935 current->vps_profile_tier_level +
i,
936 current->vps_pt_present_flag[
i],
937 current->vps_ptl_max_tid[
i]));
939 for (
i = 0;
i < total_num_olss;
i++) {
940 if (current->vps_num_ptls_minus1 > 0 &&
941 current->vps_num_ptls_minus1 + 1 != total_num_olss) {
942 us(8, vps_ols_ptl_idx[
i], 0, current->vps_num_ptls_minus1, 1,
i);
943 }
else if (current->vps_num_ptls_minus1 == 0) {
944 infer(vps_ols_ptl_idx[
i], 0);
950 if (!current->vps_each_layer_is_an_ols_flag) {
951 uint16_t vps_num_dpb_params;
952 ue(vps_num_dpb_params_minus1, 0, num_multi_layer_olss - 1);
953 if (current->vps_each_layer_is_an_ols_flag)
954 vps_num_dpb_params = 0;
956 vps_num_dpb_params = current->vps_num_dpb_params_minus1 + 1;
958 if (current->vps_max_sublayers_minus1 > 0)
959 flag(vps_sublayer_dpb_params_present_flag);
961 infer(vps_sublayer_dpb_params_present_flag, 0);
963 for (
i = 0;
i < vps_num_dpb_params;
i++) {
964 if (!current->vps_default_ptl_dpb_hrd_max_tid_flag)
965 us(3, vps_dpb_max_tid[
i], 0, current->vps_max_sublayers_minus1,
968 infer(vps_dpb_max_tid[
i], current->vps_max_sublayers_minus1);
970 current->vps_dpb_max_tid[
i],
972 vps_sublayer_dpb_params_present_flag));
974 for (
i = 0;
i < num_multi_layer_olss;
i++) {
975 ues(vps_ols_dpb_pic_width[
i], 0, UINT16_MAX, 1,
i);
976 ues(vps_ols_dpb_pic_height[
i], 0, UINT16_MAX, 1,
i);
977 ubs(2, vps_ols_dpb_chroma_format[
i], 1,
i);
978 ues(vps_ols_dpb_bitdepth_minus8[
i], 0, 8, 1,
i);
979 if (vps_num_dpb_params > 1
980 && vps_num_dpb_params != num_multi_layer_olss)
981 ues(vps_ols_dpb_params_idx[
i], 0, vps_num_dpb_params - 1, 1,
i);
982 else if (vps_num_dpb_params == 1)
983 infer(vps_ols_dpb_params_idx[
i], 0);
985 infer(vps_ols_dpb_params_idx[
i],
i);
987 flag(vps_timing_hrd_params_present_flag);
988 if (current->vps_timing_hrd_params_present_flag) {
991 vps_general_timing_hrd_parameters));
992 if (current->vps_max_sublayers_minus1 > 0)
993 flag(vps_sublayer_cpb_params_present_flag);
995 infer(vps_sublayer_cpb_params_present_flag, 0);
996 ue(vps_num_ols_timing_hrd_params_minus1, 0,
997 num_multi_layer_olss - 1);
998 for (
i = 0;
i <= current->vps_num_ols_timing_hrd_params_minus1;
i++) {
999 uint8_t first_sublayer;
1000 if (!current->vps_default_ptl_dpb_hrd_max_tid_flag)
1001 us(3, vps_hrd_max_tid[
i], 0,
1002 current->vps_max_sublayers_minus1, 1,
i);
1004 infer(vps_hrd_max_tid[
i],
1005 current->vps_max_sublayers_minus1);
1006 first_sublayer = current->vps_sublayer_cpb_params_present_flag ?
1007 0 : current->vps_hrd_max_tid[
i];
1009 (
ctx, rw, ¤t->vps_ols_timing_hrd_parameters,
1010 first_sublayer, current->vps_max_sublayers_minus1,
1011 ¤t->vps_general_timing_hrd_parameters));
1014 if (current->vps_num_ols_timing_hrd_params_minus1 > 0 &&
1015 current->vps_num_ols_timing_hrd_params_minus1 + 1 !=
1016 num_multi_layer_olss) {
1017 for (
i = 0;
i < num_multi_layer_olss;
i++) {
1018 ues(vps_ols_timing_hrd_idx[
i], 0,
1019 current->vps_num_ols_timing_hrd_params_minus1, 1,
i);
1021 }
else if (current->vps_num_ols_timing_hrd_params_minus1 == 0) {
1022 for (
i = 0;
i < num_multi_layer_olss;
i++)
1023 infer(vps_ols_timing_hrd_idx[
i], 0);
1025 for (
i = 0;
i < num_multi_layer_olss;
i++)
1026 infer(vps_ols_timing_hrd_idx[
i],
i);
1031 flag(vps_extension_flag);
1032 if (current->vps_extension_flag)
1044 flag(sps_extended_precision_flag);
1045 if (current->sps_transform_skip_enabled_flag)
1046 flag(sps_ts_residual_coding_rice_present_in_sh_flag);
1048 infer(sps_ts_residual_coding_rice_present_in_sh_flag, 0);
1049 flag(sps_rrc_rice_extension_flag);
1050 flag(sps_persistent_rice_adaptation_enabled_flag);
1051 flag(sps_reverse_last_sig_coeff_enabled_flag);
1060 int err,
i, j, max_width_minus1, max_height_minus1;
1061 unsigned int ctb_log2_size_y, min_cb_log2_size_y,
1062 min_qt_log2_size_intra_y, min_qt_log2_size_inter_y,
1063 ctb_size_y, max_num_merge_cand, tmp_width_val, tmp_height_val;
1064 uint8_t qp_bd_offset, sub_width_c, sub_height_c;
1066 static const uint8_t h266_sub_width_c[] = {
1069 static const uint8_t h266_sub_height_c[] = {
1073 HEADER(
"Sequence Parameter Set");
1078 ub(4, sps_seq_parameter_set_id);
1079 ub(4, sps_video_parameter_set_id);
1080 if (current->sps_video_parameter_set_id == 0 && !h266->
vps[0]) {
1084 vps->vps_max_layers_minus1 = 0;
1085 vps->vps_independent_layer_flag[0] = 1;
1086 vps->vps_layer_id[0] = current->nal_unit_header.nuh_layer_id;
1091 u(2, sps_chroma_format_idc, 0, 3);
1092 sub_width_c = h266_sub_width_c[current->sps_chroma_format_idc];
1093 sub_height_c = h266_sub_height_c[current->sps_chroma_format_idc];
1095 u(2, sps_log2_ctu_size_minus5, 0, 3);
1096 ctb_log2_size_y = current->sps_log2_ctu_size_minus5 + 5;
1097 ctb_size_y = 1 << ctb_log2_size_y;
1099 flag(sps_ptl_dpb_hrd_params_present_flag);
1100 if (current->sps_ptl_dpb_hrd_params_present_flag) {
1102 1, current->sps_max_sublayers_minus1));
1104 flag(sps_gdr_enabled_flag);
1105 flag(sps_ref_pic_resampling_enabled_flag);
1106 if (current->sps_ref_pic_resampling_enabled_flag)
1107 flag(sps_res_change_in_clvs_allowed_flag);
1109 infer(sps_res_change_in_clvs_allowed_flag, 0);
1114 flag(sps_conformance_window_flag);
1115 if (current->sps_conformance_window_flag) {
1116 uint16_t
width = current->sps_pic_width_max_in_luma_samples / sub_width_c;
1117 uint16_t
height = current->sps_pic_height_max_in_luma_samples / sub_height_c;
1118 ue(sps_conf_win_left_offset, 0,
width);
1119 ue(sps_conf_win_right_offset, 0,
width - current->sps_conf_win_left_offset);
1120 ue(sps_conf_win_top_offset, 0,
height);
1121 ue(sps_conf_win_bottom_offset, 0,
height - current->sps_conf_win_top_offset);
1123 infer(sps_conf_win_left_offset, 0);
1124 infer(sps_conf_win_right_offset, 0);
1125 infer(sps_conf_win_top_offset, 0);
1126 infer(sps_conf_win_bottom_offset, 0);
1129 tmp_width_val =
AV_CEIL_RSHIFT(current->sps_pic_width_max_in_luma_samples,
1131 tmp_height_val =
AV_CEIL_RSHIFT(current->sps_pic_height_max_in_luma_samples,
1133 max_width_minus1 = tmp_width_val - 1;
1134 max_height_minus1 = tmp_height_val - 1;
1136 flag(sps_subpic_info_present_flag);
1137 if (current->sps_subpic_info_present_flag) {
1139 if (current->sps_num_subpics_minus1 > 0) {
1140 flag(sps_independent_subpics_flag);
1141 flag(sps_subpic_same_size_flag);
1144 if (current->sps_num_subpics_minus1 > 0) {
1147 infer(sps_subpic_ctu_top_left_x[0], 0);
1148 infer(sps_subpic_ctu_top_left_y[0], 0);
1149 if (current->sps_pic_width_max_in_luma_samples > ctb_size_y)
1150 us(wlen, sps_subpic_width_minus1[0], 0, max_width_minus1, 1, 0);
1152 infer(sps_subpic_width_minus1[0], max_width_minus1);
1153 if (current->sps_pic_height_max_in_luma_samples > ctb_size_y)
1154 us(hlen, sps_subpic_height_minus1[0], 0, max_height_minus1, 1, 0);
1156 infer(sps_subpic_height_minus1[0], max_height_minus1);
1157 if (!current->sps_independent_subpics_flag) {
1158 flags(sps_subpic_treated_as_pic_flag[0], 1, 0);
1159 flags(sps_loop_filter_across_subpic_enabled_flag[0], 1, 0);
1161 infer(sps_subpic_treated_as_pic_flag[0], 1);
1162 infer(sps_loop_filter_across_subpic_enabled_flag[0], 1);
1164 for (
i = 1;
i <= current->sps_num_subpics_minus1;
i++) {
1165 if (!current->sps_subpic_same_size_flag) {
1166 const int win_right_edge =
1167 current->sps_pic_width_max_in_luma_samples -
1168 current->sps_conf_win_right_offset * sub_width_c;
1169 const int win_bottom_edge =
1170 current->sps_pic_height_max_in_luma_samples -
1171 current->sps_conf_win_bottom_offset * sub_height_c;
1172 const int win_left_edge =
1173 current->sps_conf_win_left_offset * sub_width_c;
1174 const int win_top_edge =
1175 current->sps_conf_win_top_offset * sub_height_c;
1176 const int win_left_edge_ctus =
1178 const int win_right_edge_ctus =
1180 const int win_top_edge_ctus =
1182 const int win_bottom_edge_ctus =
1184 const int min_width =
1185 FFMAX(win_left_edge_ctus - current->sps_subpic_ctu_top_left_x[
i], 0);
1186 const int min_height =
1187 FFMAX(win_top_edge_ctus - current->sps_subpic_ctu_top_left_y[
i], 0);
1189 if (current->sps_pic_width_max_in_luma_samples > ctb_size_y)
1190 us(wlen, sps_subpic_ctu_top_left_x[
i], 0, win_right_edge_ctus - 1, 1,
i);
1192 infer(sps_subpic_ctu_top_left_x[
i], 0);
1194 if (current->sps_pic_height_max_in_luma_samples > ctb_size_y)
1195 us(hlen, sps_subpic_ctu_top_left_y[
i], 0, win_bottom_edge_ctus - 1, 1,
i);
1197 infer(sps_subpic_ctu_top_left_y[
i], 0);
1199 max_width_minus1 = tmp_width_val - current->sps_subpic_ctu_top_left_x[
i] - 1;
1200 max_height_minus1 = tmp_height_val - current->sps_subpic_ctu_top_left_y[
i] - 1;
1202 if (i < current->sps_num_subpics_minus1 &&
1203 current->sps_pic_width_max_in_luma_samples > ctb_size_y) {
1204 us(wlen, sps_subpic_width_minus1[
i], min_width, max_width_minus1, 1,
i);
1206 infer(sps_subpic_width_minus1[
i], max_width_minus1);
1209 if (i < current->sps_num_subpics_minus1 &&
1210 current->sps_pic_height_max_in_luma_samples > ctb_size_y) {
1211 us(hlen, sps_subpic_height_minus1[
i], min_height, max_height_minus1, 1,
i);
1213 infer(sps_subpic_height_minus1[
i], max_height_minus1);
1216 int num_subpic_cols = tmp_width_val /
1217 (current->sps_subpic_width_minus1[0] + 1);
1218 if (tmp_width_val % (current->sps_subpic_width_minus1[0] + 1) ||
1219 tmp_height_val % (current->sps_subpic_width_minus1[0] + 1) ||
1220 current->sps_num_subpics_minus1 !=
1221 (num_subpic_cols * tmp_height_val /
1222 (current->sps_subpic_height_minus1[0] + 1) - 1))
1224 infer(sps_subpic_ctu_top_left_x[
i],
1225 (
i % num_subpic_cols) *
1226 (current->sps_subpic_width_minus1[0] + 1));
1227 infer(sps_subpic_ctu_top_left_y[
i],
1228 (
i / num_subpic_cols) *
1229 (current->sps_subpic_height_minus1[0] + 1));
1230 infer(sps_subpic_width_minus1[
i],
1231 current->sps_subpic_width_minus1[0]);
1232 infer(sps_subpic_height_minus1[
i],
1233 current->sps_subpic_height_minus1[0]);
1235 if (!current->sps_independent_subpics_flag) {
1236 flags(sps_subpic_treated_as_pic_flag[
i], 1,
i);
1237 flags(sps_loop_filter_across_subpic_enabled_flag[
i], 1,
i);
1239 infer(sps_subpic_treated_as_pic_flag[
i], 1);
1240 infer(sps_loop_filter_across_subpic_enabled_flag[
i], 0);
1244 infer(sps_subpic_ctu_top_left_x[0], 0);
1245 infer(sps_subpic_ctu_top_left_y[0], 0);
1246 infer(sps_subpic_width_minus1[0], max_width_minus1);
1247 infer(sps_subpic_height_minus1[0], max_height_minus1);
1249 ue(sps_subpic_id_len_minus1, 0, 15);
1250 if ((1 << (current->sps_subpic_id_len_minus1 + 1)) <
1251 current->sps_num_subpics_minus1 + 1) {
1253 "sps_subpic_id_len_minus1(%d) is too small\n",
1254 current->sps_subpic_id_len_minus1);
1257 flag(sps_subpic_id_mapping_explicitly_signalled_flag);
1258 if (current->sps_subpic_id_mapping_explicitly_signalled_flag) {
1259 flag(sps_subpic_id_mapping_present_flag);
1260 if (current->sps_subpic_id_mapping_present_flag) {
1261 for (
i = 0;
i <= current->sps_num_subpics_minus1;
i++) {
1262 ubs(current->sps_subpic_id_len_minus1 + 1,
1263 sps_subpic_id[
i], 1,
i);
1268 infer(sps_num_subpics_minus1, 0);
1269 infer(sps_independent_subpics_flag, 1);
1270 infer(sps_subpic_same_size_flag, 0);
1271 infer(sps_subpic_id_mapping_explicitly_signalled_flag, 0);
1272 infer(sps_subpic_ctu_top_left_x[0], 0);
1273 infer(sps_subpic_ctu_top_left_y[0], 0);
1274 infer(sps_subpic_width_minus1[0], max_width_minus1);
1275 infer(sps_subpic_height_minus1[0], max_height_minus1);
1279 ue(sps_bitdepth_minus8, 0, 8);
1280 qp_bd_offset = 6 * current->sps_bitdepth_minus8;
1282 flag(sps_entropy_coding_sync_enabled_flag);
1283 flag(sps_entry_point_offsets_present_flag);
1285 u(4, sps_log2_max_pic_order_cnt_lsb_minus4, 0, 12);
1286 flag(sps_poc_msb_cycle_flag);
1287 if (current->sps_poc_msb_cycle_flag)
1288 ue(sps_poc_msb_cycle_len_minus1,
1289 0, 32 - current->sps_log2_max_pic_order_cnt_lsb_minus4 - 5);
1291 u(2, sps_num_extra_ph_bytes, 0, 2);
1292 for (
i = 0;
i < (current->sps_num_extra_ph_bytes * 8);
i++) {
1293 flags(sps_extra_ph_bit_present_flag[
i], 1,
i);
1296 u(2, sps_num_extra_sh_bytes, 0, 2);
1297 for (
i = 0;
i < (current->sps_num_extra_sh_bytes * 8);
i++) {
1298 flags(sps_extra_sh_bit_present_flag[
i], 1,
i);
1301 if (current->sps_ptl_dpb_hrd_params_present_flag) {
1302 if (current->sps_max_sublayers_minus1 > 0)
1303 flag(sps_sublayer_dpb_params_flag);
1305 infer(sps_sublayer_dpb_params_flag, 0);
1307 current->sps_max_sublayers_minus1,
1308 current->sps_sublayer_dpb_params_flag));
1311 ue(sps_log2_min_luma_coding_block_size_minus2,
1312 0,
FFMIN(4, current->sps_log2_ctu_size_minus5 + 3));
1313 min_cb_log2_size_y =
1314 current->sps_log2_min_luma_coding_block_size_minus2 + 2;
1316 flag(sps_partition_constraints_override_enabled_flag);
1318 ue(sps_log2_diff_min_qt_min_cb_intra_slice_luma,
1319 0,
FFMIN(6, ctb_log2_size_y) - min_cb_log2_size_y);
1320 min_qt_log2_size_intra_y =
1321 current->sps_log2_diff_min_qt_min_cb_intra_slice_luma +
1324 ue(sps_max_mtt_hierarchy_depth_intra_slice_luma,
1325 0, 2 * (ctb_log2_size_y - min_cb_log2_size_y));
1327 if (current->sps_max_mtt_hierarchy_depth_intra_slice_luma != 0) {
1328 ue(sps_log2_diff_max_bt_min_qt_intra_slice_luma,
1329 0, ctb_log2_size_y - min_qt_log2_size_intra_y);
1330 ue(sps_log2_diff_max_tt_min_qt_intra_slice_luma,
1331 0,
FFMIN(6, ctb_log2_size_y) - min_qt_log2_size_intra_y);
1333 infer(sps_log2_diff_max_bt_min_qt_intra_slice_luma, 0);
1334 infer(sps_log2_diff_max_tt_min_qt_intra_slice_luma, 0);
1337 if (current->sps_chroma_format_idc != 0) {
1338 flag(sps_qtbtt_dual_tree_intra_flag);
1340 infer(sps_qtbtt_dual_tree_intra_flag, 0);
1343 if (current->sps_qtbtt_dual_tree_intra_flag) {
1344 ue(sps_log2_diff_min_qt_min_cb_intra_slice_chroma,
1345 0,
FFMIN(6, ctb_log2_size_y) - min_cb_log2_size_y);
1346 ue(sps_max_mtt_hierarchy_depth_intra_slice_chroma,
1347 0, 2 * (ctb_log2_size_y - min_cb_log2_size_y));
1348 if (current->sps_max_mtt_hierarchy_depth_intra_slice_chroma != 0) {
1349 unsigned int min_qt_log2_size_intra_c =
1350 current->sps_log2_diff_min_qt_min_cb_intra_slice_chroma +
1352 ue(sps_log2_diff_max_bt_min_qt_intra_slice_chroma,
1353 0,
FFMIN(6, ctb_log2_size_y) - min_qt_log2_size_intra_c);
1354 ue(sps_log2_diff_max_tt_min_qt_intra_slice_chroma,
1355 0,
FFMIN(6, ctb_log2_size_y) - min_qt_log2_size_intra_c);
1358 infer(sps_log2_diff_min_qt_min_cb_intra_slice_chroma, 0);
1359 infer(sps_max_mtt_hierarchy_depth_intra_slice_chroma, 0);
1361 if (current->sps_max_mtt_hierarchy_depth_intra_slice_chroma == 0) {
1362 infer(sps_log2_diff_max_bt_min_qt_intra_slice_chroma, 0);
1363 infer(sps_log2_diff_max_tt_min_qt_intra_slice_chroma, 0);
1366 ue(sps_log2_diff_min_qt_min_cb_inter_slice,
1367 0,
FFMIN(6, ctb_log2_size_y) - min_cb_log2_size_y);
1368 min_qt_log2_size_inter_y =
1369 current->sps_log2_diff_min_qt_min_cb_inter_slice + min_cb_log2_size_y;
1371 ue(sps_max_mtt_hierarchy_depth_inter_slice,
1372 0, 2 * (ctb_log2_size_y - min_cb_log2_size_y));
1373 if (current->sps_max_mtt_hierarchy_depth_inter_slice != 0) {
1374 ue(sps_log2_diff_max_bt_min_qt_inter_slice,
1375 0, ctb_log2_size_y - min_qt_log2_size_inter_y);
1376 ue(sps_log2_diff_max_tt_min_qt_inter_slice,
1377 0,
FFMIN(6, ctb_log2_size_y) - min_qt_log2_size_inter_y);
1379 infer(sps_log2_diff_max_bt_min_qt_inter_slice, 0);
1380 infer(sps_log2_diff_max_tt_min_qt_inter_slice, 0);
1383 if (ctb_size_y > 32)
1384 flag(sps_max_luma_transform_size_64_flag);
1386 infer(sps_max_luma_transform_size_64_flag, 0);
1388 flag(sps_transform_skip_enabled_flag);
1389 if (current->sps_transform_skip_enabled_flag) {
1390 ue(sps_log2_transform_skip_max_size_minus2, 0, 3);
1391 flag(sps_bdpcm_enabled_flag);
1394 flag(sps_mts_enabled_flag);
1395 if (current->sps_mts_enabled_flag) {
1396 flag(sps_explicit_mts_intra_enabled_flag);
1397 flag(sps_explicit_mts_inter_enabled_flag);
1399 infer(sps_explicit_mts_intra_enabled_flag, 0);
1400 infer(sps_explicit_mts_inter_enabled_flag, 0);
1403 flag(sps_lfnst_enabled_flag);
1405 if (current->sps_chroma_format_idc != 0) {
1406 uint8_t num_qp_tables;
1407 flag(sps_joint_cbcr_enabled_flag);
1408 flag(sps_same_qp_table_for_chroma_flag);
1409 num_qp_tables = current->sps_same_qp_table_for_chroma_flag ?
1410 1 : (current->sps_joint_cbcr_enabled_flag ? 3 : 2);
1411 for (
i = 0;
i < num_qp_tables;
i++) {
1412 ses(sps_qp_table_start_minus26[
i], -26 - qp_bd_offset, 36, 1,
i);
1413 ues(sps_num_points_in_qp_table_minus1[
i],
1414 0, 36 - current->sps_qp_table_start_minus26[
i], 1,
i);
1415 for (j = 0; j <= current->sps_num_points_in_qp_table_minus1[
i]; j++) {
1417 ues(sps_delta_qp_in_val_minus1[
i][j], 0,
max, 2,
i, j);
1418 ues(sps_delta_qp_diff_val[
i][j], 0,
max, 2,
i, j);
1422 infer(sps_joint_cbcr_enabled_flag, 0);
1423 infer(sps_same_qp_table_for_chroma_flag, 0);
1426 flag(sps_sao_enabled_flag);
1427 flag(sps_alf_enabled_flag);
1428 if (current->sps_alf_enabled_flag && current->sps_chroma_format_idc)
1429 flag(sps_ccalf_enabled_flag);
1431 infer(sps_ccalf_enabled_flag, 0);
1432 flag(sps_lmcs_enabled_flag);
1433 flag(sps_weighted_pred_flag);
1434 flag(sps_weighted_bipred_flag);
1435 flag(sps_long_term_ref_pics_flag);
1436 if (current->sps_video_parameter_set_id > 0)
1437 flag(sps_inter_layer_prediction_enabled_flag);
1439 infer(sps_inter_layer_prediction_enabled_flag, 0);
1440 flag(sps_idr_rpl_present_flag);
1441 flag(sps_rpl1_same_as_rpl0_flag);
1443 for (
i = 0;
i < (current->sps_rpl1_same_as_rpl0_flag ? 1 : 2);
i++) {
1445 for (j = 0; j < current->sps_num_ref_pic_lists[
i]; j++)
1448 sps_ref_pic_list_struct[
i][j],
i,
1452 if (current->sps_rpl1_same_as_rpl0_flag) {
1453 current->sps_num_ref_pic_lists[1] = current->sps_num_ref_pic_lists[0];
1454 for (j = 0; j < current->sps_num_ref_pic_lists[0]; j++)
1455 memcpy(¤t->sps_ref_pic_list_struct[1][j],
1456 ¤t->sps_ref_pic_list_struct[0][j],
1457 sizeof(current->sps_ref_pic_list_struct[0][j]));
1460 flag(sps_ref_wraparound_enabled_flag);
1462 flag(sps_temporal_mvp_enabled_flag);
1463 if (current->sps_temporal_mvp_enabled_flag)
1464 flag(sps_sbtmvp_enabled_flag);
1466 infer(sps_sbtmvp_enabled_flag, 0);
1468 flag(sps_amvr_enabled_flag);
1469 flag(sps_bdof_enabled_flag);
1470 if (current->sps_bdof_enabled_flag)
1471 flag(sps_bdof_control_present_in_ph_flag);
1473 infer(sps_bdof_control_present_in_ph_flag, 0);
1475 flag(sps_smvd_enabled_flag);
1476 flag(sps_dmvr_enabled_flag);
1477 if (current->sps_dmvr_enabled_flag)
1478 flag(sps_dmvr_control_present_in_ph_flag);
1480 infer(sps_dmvr_control_present_in_ph_flag, 0);
1482 flag(sps_mmvd_enabled_flag);
1483 if (current->sps_mmvd_enabled_flag)
1484 flag(sps_mmvd_fullpel_only_enabled_flag);
1486 infer(sps_mmvd_fullpel_only_enabled_flag, 0);
1488 ue(sps_six_minus_max_num_merge_cand, 0, 5);
1489 max_num_merge_cand = 6 - current->sps_six_minus_max_num_merge_cand;
1491 flag(sps_sbt_enabled_flag);
1493 flag(sps_affine_enabled_flag);
1494 if (current->sps_affine_enabled_flag) {
1495 ue(sps_five_minus_max_num_subblock_merge_cand,
1496 0, 5 - current->sps_sbtmvp_enabled_flag);
1497 flag(sps_6param_affine_enabled_flag);
1498 if (current->sps_amvr_enabled_flag)
1499 flag(sps_affine_amvr_enabled_flag);
1501 infer(sps_affine_amvr_enabled_flag, 0);
1502 flag(sps_affine_prof_enabled_flag);
1503 if (current->sps_affine_prof_enabled_flag)
1504 flag(sps_prof_control_present_in_ph_flag);
1506 infer(sps_prof_control_present_in_ph_flag, 0);
1508 infer(sps_6param_affine_enabled_flag, 0);
1509 infer(sps_affine_amvr_enabled_flag, 0);
1510 infer(sps_affine_prof_enabled_flag, 0);
1511 infer(sps_prof_control_present_in_ph_flag, 0);
1514 flag(sps_bcw_enabled_flag);
1515 flag(sps_ciip_enabled_flag);
1517 if (max_num_merge_cand >= 2) {
1518 flag(sps_gpm_enabled_flag);
1519 if (current->sps_gpm_enabled_flag && max_num_merge_cand >= 3)
1520 ue(sps_max_num_merge_cand_minus_max_num_gpm_cand,
1521 0, max_num_merge_cand - 2);
1523 infer(sps_gpm_enabled_flag, 0);
1526 ue(sps_log2_parallel_merge_level_minus2, 0, ctb_log2_size_y - 2);
1528 flag(sps_isp_enabled_flag);
1529 flag(sps_mrl_enabled_flag);
1530 flag(sps_mip_enabled_flag);
1532 if (current->sps_chroma_format_idc != 0)
1533 flag(sps_cclm_enabled_flag);
1535 infer(sps_cclm_enabled_flag, 0);
1536 if (current->sps_chroma_format_idc == 1) {
1537 flag(sps_chroma_horizontal_collocated_flag);
1538 flag(sps_chroma_vertical_collocated_flag);
1540 infer(sps_chroma_horizontal_collocated_flag, 1);
1541 infer(sps_chroma_vertical_collocated_flag, 1);
1544 flag(sps_palette_enabled_flag);
1545 if (current->sps_chroma_format_idc == 3 &&
1546 !current->sps_max_luma_transform_size_64_flag)
1547 flag(sps_act_enabled_flag);
1549 infer(sps_act_enabled_flag, 0);
1550 if (current->sps_transform_skip_enabled_flag ||
1551 current->sps_palette_enabled_flag)
1552 ue(sps_min_qp_prime_ts, 0, 8);
1554 flag(sps_ibc_enabled_flag);
1555 if (current->sps_ibc_enabled_flag)
1556 ue(sps_six_minus_max_num_ibc_merge_cand, 0, 5);
1558 flag(sps_ladf_enabled_flag);
1559 if (current->sps_ladf_enabled_flag) {
1560 ub(2, sps_num_ladf_intervals_minus2);
1561 se(sps_ladf_lowest_interval_qp_offset, -63, 63);
1562 for (
i = 0;
i < current->sps_num_ladf_intervals_minus2 + 1;
i++) {
1563 ses(sps_ladf_qp_offset[
i], -63, 63, 1,
i);
1564 ues(sps_ladf_delta_threshold_minus1[
i],
1565 0, (2 << (8 + current->sps_bitdepth_minus8)) - 3, 1,
i);
1569 flag(sps_explicit_scaling_list_enabled_flag);
1570 if (current->sps_lfnst_enabled_flag &&
1571 current->sps_explicit_scaling_list_enabled_flag)
1572 flag(sps_scaling_matrix_for_lfnst_disabled_flag);
1574 if (current->sps_act_enabled_flag &&
1575 current->sps_explicit_scaling_list_enabled_flag)
1576 flag(sps_scaling_matrix_for_alternative_colour_space_disabled_flag);
1578 infer(sps_scaling_matrix_for_alternative_colour_space_disabled_flag, 0);
1579 if (current->sps_scaling_matrix_for_alternative_colour_space_disabled_flag)
1580 flag(sps_scaling_matrix_designated_colour_space_flag);
1582 flag(sps_dep_quant_enabled_flag);
1583 flag(sps_sign_data_hiding_enabled_flag);
1585 flag(sps_virtual_boundaries_enabled_flag);
1586 if (current->sps_virtual_boundaries_enabled_flag) {
1587 flag(sps_virtual_boundaries_present_flag);
1588 if (current->sps_virtual_boundaries_present_flag) {
1589 ue(sps_num_ver_virtual_boundaries,
1590 0, current->sps_pic_width_max_in_luma_samples <= 8 ? 0 :
VVC_MAX_VBS);
1591 for (
i = 0;
i < current->sps_num_ver_virtual_boundaries;
i++)
1592 ues(sps_virtual_boundary_pos_x_minus1[
i],
1593 0, (current->sps_pic_width_max_in_luma_samples + 7) / 8 - 2,
1595 ue(sps_num_hor_virtual_boundaries,
1596 0, current->sps_pic_height_max_in_luma_samples <= 8 ? 0 :
VVC_MAX_VBS);
1597 for (
i = 0;
i < current->sps_num_hor_virtual_boundaries;
i++)
1598 ues(sps_virtual_boundary_pos_y_minus1[
i],
1599 0, (current->sps_pic_height_max_in_luma_samples + 7) /
1603 infer(sps_virtual_boundaries_present_flag, 0);
1604 infer(sps_num_ver_virtual_boundaries, 0);
1605 infer(sps_num_hor_virtual_boundaries, 0);
1608 if (current->sps_ptl_dpb_hrd_params_present_flag) {
1609 flag(sps_timing_hrd_params_present_flag);
1610 if (current->sps_timing_hrd_params_present_flag) {
1611 uint8_t first_sublayer;
1613 ¤t->sps_general_timing_hrd_parameters));
1614 if (current->sps_max_sublayers_minus1 > 0)
1615 flag(sps_sublayer_cpb_params_present_flag);
1617 infer(sps_sublayer_cpb_params_present_flag, 0);
1618 first_sublayer = current->sps_sublayer_cpb_params_present_flag ?
1619 0 : current->sps_max_sublayers_minus1;
1621 ¤t->sps_ols_timing_hrd_parameters, first_sublayer,
1622 current->sps_max_sublayers_minus1,
1623 ¤t->sps_general_timing_hrd_parameters));
1627 flag(sps_field_seq_flag);
1628 flag(sps_vui_parameters_present_flag);
1629 if (current->sps_vui_parameters_present_flag) {
1630 ue(sps_vui_payload_size_minus1, 0, 1023);
1632 fixed(1, sps_vui_alignment_zero_bit, 0);
1634 current->sps_vui_payload_size_minus1 + 1,
1635 current->sps_chroma_format_idc));
1640 flag(sps_extension_flag);
1641 if (current->sps_extension_flag) {
1642 flag(sps_range_extension_flag);
1643 ub(7, sps_extension_7bits);
1645 if (current->sps_range_extension_flag) {
1646 if (current->sps_bitdepth_minus8 <= 10 - 8)
1650 infer(sps_extended_precision_flag, 0);
1651 infer(sps_ts_residual_coding_rice_present_in_sh_flag, 0);
1652 infer(sps_rrc_rice_extension_flag, 0);
1653 infer(sps_persistent_rice_adaptation_enabled_flag, 0);
1654 infer(sps_reverse_last_sig_coeff_enabled_flag, 0);
1657 infer(sps_range_extension_flag, 0);
1658 infer(sps_extension_7bits, 0);
1659 infer(sps_extended_precision_flag, 0);
1660 infer(sps_ts_residual_coding_rice_present_in_sh_flag, 0);
1661 infer(sps_rrc_rice_extension_flag, 0);
1662 infer(sps_persistent_rice_adaptation_enabled_flag, 0);
1663 infer(sps_reverse_last_sig_coeff_enabled_flag, 0);
1666 if (current->sps_extension_7bits)
1680 unsigned int min_cb_size_y, divisor, ctb_size_y,
1681 pic_width_in_ctbs_y, pic_height_in_ctbs_y;
1682 uint8_t sub_width_c, sub_height_c, qp_bd_offset;
1684 static const uint8_t h266_sub_width_c[] = {
1687 static const uint8_t h266_sub_height_c[] = {
1691 HEADER(
"Picture Parameter Set");
1696 ub(6, pps_pic_parameter_set_id);
1697 ub(4, pps_seq_parameter_set_id);
1698 sps = h266->
sps[current->pps_seq_parameter_set_id];
1701 current->pps_seq_parameter_set_id);
1705 flag(pps_mixed_nalu_types_in_pic_flag);
1706 ue(pps_pic_width_in_luma_samples,
1707 1,
sps->sps_pic_width_max_in_luma_samples);
1708 ue(pps_pic_height_in_luma_samples,
1709 1,
sps->sps_pic_height_max_in_luma_samples);
1711 min_cb_size_y = 1 << (
sps->sps_log2_min_luma_coding_block_size_minus2 + 2);
1712 divisor =
FFMAX(min_cb_size_y, 8);
1713 if (current->pps_pic_width_in_luma_samples % divisor ||
1714 current->pps_pic_height_in_luma_samples % divisor) {
1716 "Invalid dimensions: %ux%u not divisible "
1717 "by %u, MinCbSizeY = %u.\n",
1718 current->pps_pic_width_in_luma_samples,
1719 current->pps_pic_height_in_luma_samples, divisor, min_cb_size_y);
1722 if (!
sps->sps_res_change_in_clvs_allowed_flag &&
1723 (current->pps_pic_width_in_luma_samples !=
1724 sps->sps_pic_width_max_in_luma_samples ||
1725 current->pps_pic_height_in_luma_samples !=
1726 sps->sps_pic_height_max_in_luma_samples)) {
1728 "Resolution change is not allowed, "
1729 "in max resolution (%ux%u) mismatched with pps(%ux%u).\n",
1730 sps->sps_pic_width_max_in_luma_samples,
1731 sps->sps_pic_height_max_in_luma_samples,
1732 current->pps_pic_width_in_luma_samples,
1733 current->pps_pic_height_in_luma_samples);
1737 ctb_size_y = 1 << (
sps->sps_log2_ctu_size_minus5 + 5);
1738 if (
sps->sps_ref_wraparound_enabled_flag) {
1739 if ((ctb_size_y / min_cb_size_y + 1) >
1740 (current->pps_pic_width_in_luma_samples / min_cb_size_y - 1)) {
1742 "Invalid width(%u), ctb_size_y = %u, min_cb_size_y = %u.\n",
1743 current->pps_pic_width_in_luma_samples,
1744 ctb_size_y, min_cb_size_y);
1749 flag(pps_conformance_window_flag);
1750 if (current->pps_pic_width_in_luma_samples ==
1751 sps->sps_pic_width_max_in_luma_samples &&
1752 current->pps_pic_height_in_luma_samples ==
1753 sps->sps_pic_height_max_in_luma_samples &&
1754 current->pps_conformance_window_flag) {
1756 "Conformance window flag should not true.\n");
1760 sub_width_c = h266_sub_width_c[
sps->sps_chroma_format_idc];
1761 sub_height_c = h266_sub_height_c[
sps->sps_chroma_format_idc];
1762 if (current->pps_conformance_window_flag) {
1763 ue(pps_conf_win_left_offset, 0, current->pps_pic_width_in_luma_samples);
1764 ue(pps_conf_win_right_offset,
1765 0, current->pps_pic_width_in_luma_samples);
1766 ue(pps_conf_win_top_offset, 0, current->pps_pic_height_in_luma_samples);
1767 ue(pps_conf_win_bottom_offset,
1768 0, current->pps_pic_height_in_luma_samples);
1770 (current->pps_conf_win_left_offset +
1771 current->pps_conf_win_right_offset) >=
1772 current->pps_pic_width_in_luma_samples ||
1774 (current->pps_conf_win_top_offset +
1775 current->pps_conf_win_bottom_offset) >=
1776 current->pps_pic_height_in_luma_samples) {
1778 "Invalid pps conformance window: (%u, %u, %u, %u), "
1779 "resolution is %ux%u, sub wxh is %ux%u.\n",
1780 current->pps_conf_win_left_offset,
1781 current->pps_conf_win_right_offset,
1782 current->pps_conf_win_top_offset,
1783 current->pps_conf_win_bottom_offset,
1784 current->pps_pic_width_in_luma_samples,
1785 current->pps_pic_height_in_luma_samples,
1786 sub_width_c, sub_height_c);
1790 if (current->pps_pic_width_in_luma_samples ==
1791 sps->sps_pic_width_max_in_luma_samples &&
1792 current->pps_pic_height_in_luma_samples ==
1793 sps->sps_pic_height_max_in_luma_samples) {
1794 infer(pps_conf_win_left_offset,
sps->sps_conf_win_left_offset);
1795 infer(pps_conf_win_right_offset,
sps->sps_conf_win_right_offset);
1796 infer(pps_conf_win_top_offset,
sps->sps_conf_win_top_offset);
1797 infer(pps_conf_win_bottom_offset,
sps->sps_conf_win_bottom_offset);
1799 infer(pps_conf_win_left_offset, 0);
1800 infer(pps_conf_win_right_offset, 0);
1801 infer(pps_conf_win_top_offset, 0);
1802 infer(pps_conf_win_bottom_offset, 0);
1807 flag(pps_scaling_window_explicit_signalling_flag);
1808 if (!
sps->sps_ref_pic_resampling_enabled_flag &&
1809 current->pps_scaling_window_explicit_signalling_flag) {
1811 "Invalid data: sps_ref_pic_resampling_enabled_flag is false, "
1812 "but pps_scaling_window_explicit_signalling_flag is true.\n");
1815 if (current->pps_scaling_window_explicit_signalling_flag) {
1816 se(pps_scaling_win_left_offset,
1817 -current->pps_pic_width_in_luma_samples * 15 / sub_width_c,
1818 current->pps_pic_width_in_luma_samples / sub_width_c);
1819 se(pps_scaling_win_right_offset,
1820 -current->pps_pic_width_in_luma_samples * 15 / sub_width_c,
1821 current->pps_pic_width_in_luma_samples / sub_width_c);
1822 se(pps_scaling_win_top_offset,
1823 -current->pps_pic_height_in_luma_samples * 15 / sub_height_c,
1824 current->pps_pic_height_in_luma_samples / sub_height_c);
1825 se(pps_scaling_win_bottom_offset,
1826 -current->pps_pic_height_in_luma_samples * 15 / sub_height_c,
1827 current->pps_pic_height_in_luma_samples / sub_height_c);
1829 infer(pps_scaling_win_left_offset, current->pps_conf_win_left_offset);
1830 infer(pps_scaling_win_right_offset, current->pps_conf_win_right_offset);
1831 infer(pps_scaling_win_top_offset, current->pps_conf_win_top_offset);
1832 infer(pps_scaling_win_bottom_offset, current->pps_conf_win_bottom_offset);
1835 flag(pps_output_flag_present_flag);
1836 flag(pps_no_pic_partition_flag);
1837 flag(pps_subpic_id_mapping_present_flag);
1839 if (current->pps_subpic_id_mapping_present_flag) {
1840 if (!current->pps_no_pic_partition_flag) {
1841 ue(pps_num_subpics_minus1,
1842 sps->sps_num_subpics_minus1,
sps->sps_num_subpics_minus1);
1844 infer(pps_num_subpics_minus1, 0);
1846 ue(pps_subpic_id_len_minus1,
sps->sps_subpic_id_len_minus1,
1847 sps->sps_subpic_id_len_minus1);
1848 for (
i = 0;
i <= current->pps_num_subpics_minus1;
i++) {
1849 ubs(
sps->sps_subpic_id_len_minus1 + 1, pps_subpic_id[
i], 1,
i);
1853 for (
i = 0;
i <=
sps->sps_num_subpics_minus1;
i++) {
1854 if (
sps->sps_subpic_id_mapping_explicitly_signalled_flag)
1855 current->sub_pic_id_val[
i] = current->pps_subpic_id_mapping_present_flag
1856 ? current->pps_subpic_id[
i]
1857 :
sps->sps_subpic_id[
i];
1859 current->sub_pic_id_val[
i] =
i;
1863 (current->pps_pic_width_in_luma_samples, (
sps->sps_log2_ctu_size_minus5 + 5));
1865 current->pps_pic_height_in_luma_samples,(
sps->sps_log2_ctu_size_minus5 + 5));
1866 if (!current->pps_no_pic_partition_flag) {
1867 unsigned int exp_tile_width = 0, exp_tile_height = 0;
1868 unsigned int unified_size, remaining_size;
1870 u(2, pps_log2_ctu_size_minus5,
1871 sps->sps_log2_ctu_size_minus5,
sps->sps_log2_ctu_size_minus5);
1872 ue(pps_num_exp_tile_columns_minus1,
1874 ue(pps_num_exp_tile_rows_minus1,
1877 for (
i = 0;
i <= current->pps_num_exp_tile_columns_minus1;
i++) {
1878 ues(pps_tile_column_width_minus1[
i],
1879 0, pic_width_in_ctbs_y - exp_tile_width - 1, 1,
i);
1880 exp_tile_width += current->pps_tile_column_width_minus1[
i] + 1;
1882 for (
i = 0;
i <= current->pps_num_exp_tile_rows_minus1;
i++) {
1883 ues(pps_tile_row_height_minus1[
i],
1884 0, pic_height_in_ctbs_y - exp_tile_height - 1, 1,
i);
1885 exp_tile_height += current->pps_tile_row_height_minus1[
i] + 1;
1888 remaining_size = pic_width_in_ctbs_y;
1889 for (
i = 0;
i <= current->pps_num_exp_tile_columns_minus1;
i++) {
1890 if (current->pps_tile_column_width_minus1[
i] >= remaining_size) {
1892 "Tile column width(%d) exceeds picture width\n",
i);
1895 current->col_width_val[
i] = current->pps_tile_column_width_minus1[
i] + 1;
1896 remaining_size -= (current->pps_tile_column_width_minus1[
i] + 1);
1898 unified_size = current->pps_tile_column_width_minus1[
i - 1] + 1;
1899 while (remaining_size > 0) {
1902 "Exceeded maximum tile columns (%d) (remaining size: %u)\n",
1906 unified_size =
FFMIN(remaining_size, unified_size);
1907 current->col_width_val[
i] = unified_size;
1908 remaining_size -= unified_size;
1911 current->num_tile_columns =
i;
1913 remaining_size = pic_height_in_ctbs_y;
1914 for (
i = 0;
i <= current->pps_num_exp_tile_rows_minus1;
i++) {
1915 if (current->pps_tile_row_height_minus1[
i] >= remaining_size) {
1917 "Tile row height(%d) exceeds picture height\n",
i);
1920 current->row_height_val[
i] = current->pps_tile_row_height_minus1[
i] + 1;
1921 remaining_size -= (current->pps_tile_row_height_minus1[
i] + 1);
1923 unified_size = current->pps_tile_row_height_minus1[
i - 1] + 1;
1925 while (remaining_size > 0) {
1928 "Exceeded maximum tile rows (%d) (remaining size: %u)\n",
1932 unified_size =
FFMIN(remaining_size, unified_size);
1933 current->row_height_val[
i] = unified_size;
1934 remaining_size -= unified_size;
1937 current->num_tile_rows=
i;
1939 current->num_tiles_in_pic = current->num_tile_columns *
1940 current->num_tile_rows;
1943 "NumTilesInPic(%d) > than VVC_MAX_TILES_PER_AU(%d)\n",
1948 if (current->num_tiles_in_pic > 1) {
1949 flag(pps_loop_filter_across_tiles_enabled_flag);
1950 flag(pps_rect_slice_flag);
1952 infer(pps_loop_filter_across_tiles_enabled_flag, 0);
1953 infer(pps_rect_slice_flag, 1);
1955 if (current->pps_rect_slice_flag)
1956 flag(pps_single_slice_per_subpic_flag);
1958 infer(pps_single_slice_per_subpic_flag, 1);
1959 if (current->pps_rect_slice_flag &&
1960 !current->pps_single_slice_per_subpic_flag) {
1961 int j, num_slices = 0;
1962 uint16_t tile_idx = 0, tile_x, tile_y, ctu_x, ctu_y;
1966 if (current->pps_num_slices_in_pic_minus1 > 1)
1967 flag(pps_tile_idx_delta_present_flag);
1969 infer(pps_tile_idx_delta_present_flag, 0);
1970 for (
i = 0;
i < current->pps_num_slices_in_pic_minus1;
i++) {
1971 current->slice_top_left_tile_idx[
i] = tile_idx;
1972 tile_x = tile_idx % current->num_tile_columns;
1973 tile_y = tile_idx / current->num_tile_columns;
1974 if (tile_x != current->num_tile_columns - 1) {
1975 ues(pps_slice_width_in_tiles_minus1[
i],
1976 0, current->num_tile_columns - 1, 1,
i);
1978 infer(pps_slice_width_in_tiles_minus1[
i], 0);
1980 if (tile_y != current->num_tile_rows - 1 &&
1981 (current->pps_tile_idx_delta_present_flag || tile_x == 0)) {
1982 ues(pps_slice_height_in_tiles_minus1[
i],
1983 0, current->num_tile_rows - 1, 1,
i);
1985 if (tile_y == current->num_tile_rows - 1)
1986 infer(pps_slice_height_in_tiles_minus1[
i], 0);
1988 infer(pps_slice_height_in_tiles_minus1[
i],
1989 current->pps_slice_height_in_tiles_minus1[
i - 1]);
1993 for (j = 0; j < tile_x; j++) {
1994 ctu_x += current->col_width_val[j];
1996 for (j = 0; j < tile_y; j++) {
1997 ctu_y += current->row_height_val[j];
1999 if (current->pps_slice_width_in_tiles_minus1[
i] == 0 &&
2000 current->pps_slice_height_in_tiles_minus1[
i] == 0 &&
2001 current->row_height_val[tile_y] > 1) {
2002 int uniform_slice_height, remaining_height_in_ctbs_y;
2003 remaining_height_in_ctbs_y =
2004 current->row_height_val[tile_y];
2005 ues(pps_num_exp_slices_in_tile[
i],
2006 0, current->row_height_val[tile_y] - 1, 1,
i);
2007 if (current->pps_num_exp_slices_in_tile[
i] == 0) {
2008 current->num_slices_in_tile[
i] = 1;
2009 current->slice_height_in_ctus[
i] = current->row_height_val[tile_y];
2010 slice_top_left_ctu_x[
i] = ctu_x;
2011 slice_top_left_ctu_y[
i] = ctu_y;
2013 uint16_t slice_height_in_ctus;
2014 for (j = 0; j < current->pps_num_exp_slices_in_tile[
i];
2016 ues(pps_exp_slice_height_in_ctus_minus1[
i][j], 0,
2017 remaining_height_in_ctbs_y - 1, 2,
2019 slice_height_in_ctus =
2021 pps_exp_slice_height_in_ctus_minus1[
i][j] + 1;
2023 current->slice_height_in_ctus[
i + j] =
2024 slice_height_in_ctus;
2025 slice_top_left_ctu_x[
i + j] = ctu_x;
2026 slice_top_left_ctu_y[
i + j] = ctu_y;
2027 ctu_y += slice_height_in_ctus;
2029 remaining_height_in_ctbs_y -= slice_height_in_ctus;
2031 uniform_slice_height = 1 +
2032 (j == 0 ? current->row_height_val[tile_y] - 1:
2033 current->pps_exp_slice_height_in_ctus_minus1[
i][j-1]);
2034 while (remaining_height_in_ctbs_y > uniform_slice_height) {
2035 current->slice_height_in_ctus[
i + j] =
2036 uniform_slice_height;
2037 slice_top_left_ctu_x[
i + j] = ctu_x;
2038 slice_top_left_ctu_y[
i + j] = ctu_y;
2039 ctu_y += uniform_slice_height;
2041 remaining_height_in_ctbs_y -= uniform_slice_height;
2044 if (remaining_height_in_ctbs_y > 0) {
2045 current->slice_height_in_ctus[
i + j] =
2046 remaining_height_in_ctbs_y;
2047 slice_top_left_ctu_x[
i + j] = ctu_x;
2048 slice_top_left_ctu_y[
i + j] = ctu_y;
2051 current->num_slices_in_tile[
i] = j;
2053 for (
int k = 0; k < current->num_slices_in_tile[
i]; k++)
2054 current->slice_top_left_tile_idx[
i + k] = tile_idx;
2055 i += current->num_slices_in_tile[
i] - 1;
2058 infer(pps_num_exp_slices_in_tile[
i], 0);
2059 if (current->pps_slice_width_in_tiles_minus1[
i] == 0 &&
2060 current->pps_slice_height_in_tiles_minus1[
i] == 0)
2061 current->num_slices_in_tile[
i] = 1;
2064 j <= current->pps_slice_height_in_tiles_minus1[
i];
2067 current->row_height_val[tile_y + j];
2069 current->slice_height_in_ctus[
i] =
height;
2071 slice_top_left_ctu_x[
i] = ctu_x;
2072 slice_top_left_ctu_y[
i] = ctu_y;
2074 if (i < current->pps_num_slices_in_pic_minus1) {
2075 if (current->pps_tile_idx_delta_present_flag) {
2080 ses(pps_tile_idx_delta_val[
i],
2081 -tile_idx, current->num_tiles_in_pic - 1 - tile_idx, 1,
i);
2082 if (current->pps_tile_idx_delta_val[
i] == 0) {
2084 "pps_tile_idx_delta_val[i] shall not be equal to 0.\n");
2086 tile_idx += current->pps_tile_idx_delta_val[
i];
2088 infer(pps_tile_idx_delta_val[
i], 0);
2090 current->pps_slice_width_in_tiles_minus1[
i] + 1;
2091 if (tile_idx % current->num_tile_columns == 0) {
2093 current->pps_slice_height_in_tiles_minus1[
i] *
2094 current->num_tile_columns;
2099 if (
i == current->pps_num_slices_in_pic_minus1) {
2102 current->slice_top_left_tile_idx[
i] = tile_idx;
2103 current->num_slices_in_tile[
i] = 1;
2104 tile_x = tile_idx % current->num_tile_columns;
2105 tile_y = tile_idx / current->num_tile_columns;
2106 if (tile_y >= current->num_tile_rows)
2109 ctu_x = 0, ctu_y = 0;
2110 for (j = 0; j < tile_x; j++) {
2111 ctu_x += current->col_width_val[j];
2113 for (j = 0; j < tile_y; j++) {
2114 ctu_y += current->row_height_val[j];
2116 slice_top_left_ctu_x[
i] = ctu_x;
2117 slice_top_left_ctu_y[
i] = ctu_y;
2119 current->pps_slice_width_in_tiles_minus1[
i] =
2120 current->num_tile_columns - tile_x - 1;
2121 current->pps_slice_height_in_tiles_minus1[
i] =
2122 current->num_tile_rows - tile_y - 1;
2124 for (j = 0; j <= current->pps_slice_height_in_tiles_minus1[
i];
2127 current->row_height_val[tile_y + j];
2129 current->slice_height_in_ctus[
i] =
height;
2131 infer(pps_num_exp_slices_in_tile[
i], 0);
2134 for (
i = 0;
i <=
sps->sps_num_subpics_minus1;
i++) {
2135 current->num_slices_in_subpic[
i] = 0;
2136 for (j = 0; j <= current->pps_num_slices_in_pic_minus1; j++) {
2137 uint16_t pos_x = 0, pos_y = 0;
2138 pos_x = slice_top_left_ctu_x[j];
2139 pos_y = slice_top_left_ctu_y[j];
2140 if ((pos_x >=
sps->sps_subpic_ctu_top_left_x[
i]) &&
2142 sps->sps_subpic_ctu_top_left_x[
i] +
2143 sps->sps_subpic_width_minus1[
i] + 1) &&
2144 (pos_y >=
sps->sps_subpic_ctu_top_left_y[
i]) &&
2145 (pos_y < sps->sps_subpic_ctu_top_left_y[
i] +
2146 sps->sps_subpic_height_minus1[
i] + 1)) {
2147 current->num_slices_in_subpic[
i]++;
2150 num_slices += current->num_slices_in_subpic[
i];
2152 if (current->pps_num_slices_in_pic_minus1 + 1 != num_slices)
2155 if (current->pps_no_pic_partition_flag)
2156 infer(pps_num_slices_in_pic_minus1, 0);
2157 else if (current->pps_single_slice_per_subpic_flag) {
2158 for (
i = 0;
i <=
sps->sps_num_subpics_minus1;
i++)
2159 current->num_slices_in_subpic[
i] = 1;
2160 infer(pps_num_slices_in_pic_minus1,
2161 sps->sps_num_subpics_minus1);
2165 if (!current->pps_rect_slice_flag ||
2166 current->pps_single_slice_per_subpic_flag ||
2167 current->pps_num_slices_in_pic_minus1 > 0)
2168 flag(pps_loop_filter_across_slices_enabled_flag);
2170 infer(pps_loop_filter_across_slices_enabled_flag, 0);
2172 infer(pps_num_exp_tile_columns_minus1, 0);
2173 infer(pps_tile_column_width_minus1[0], pic_width_in_ctbs_y - 1);
2174 infer(pps_num_exp_tile_rows_minus1, 0);
2175 infer(pps_tile_row_height_minus1[0], pic_height_in_ctbs_y - 1);
2176 current->col_width_val[0] = pic_width_in_ctbs_y;
2177 current->row_height_val[0] = pic_height_in_ctbs_y;
2178 current->num_tile_columns = 1;
2179 current->num_tile_rows = 1;
2180 current->num_tiles_in_pic = 1;
2183 flag(pps_cabac_init_present_flag);
2184 for (
i = 0;
i < 2;
i++)
2185 ues(pps_num_ref_idx_default_active_minus1[
i], 0, 14, 1,
i);
2186 flag(pps_rpl1_idx_present_flag);
2187 flag(pps_weighted_pred_flag);
2188 flag(pps_weighted_bipred_flag);
2189 flag(pps_ref_wraparound_enabled_flag);
2190 if (current->pps_ref_wraparound_enabled_flag) {
2191 ue(pps_pic_width_minus_wraparound_offset,
2192 0, (current->pps_pic_width_in_luma_samples / min_cb_size_y)
2193 - (ctb_size_y / min_cb_size_y) - 2);
2196 qp_bd_offset = 6 *
sps->sps_bitdepth_minus8;
2197 se(pps_init_qp_minus26, -(26 + qp_bd_offset), 37);
2198 flag(pps_cu_qp_delta_enabled_flag);
2199 flag(pps_chroma_tool_offsets_present_flag);
2200 if (current->pps_chroma_tool_offsets_present_flag) {
2201 se(pps_cb_qp_offset, -12, 12);
2202 se(pps_cr_qp_offset, -12, 12);
2203 flag(pps_joint_cbcr_qp_offset_present_flag);
2204 if (current->pps_joint_cbcr_qp_offset_present_flag)
2205 se(pps_joint_cbcr_qp_offset_value, -12, 12);
2207 infer(pps_joint_cbcr_qp_offset_value, 0);
2208 flag(pps_slice_chroma_qp_offsets_present_flag);
2209 flag(pps_cu_chroma_qp_offset_list_enabled_flag);
2210 if (current->pps_cu_chroma_qp_offset_list_enabled_flag) {
2211 ue(pps_chroma_qp_offset_list_len_minus1, 0, 5);
2212 for (
i = 0;
i <= current->pps_chroma_qp_offset_list_len_minus1;
i++) {
2213 ses(pps_cb_qp_offset_list[
i], -12, 12, 1,
i);
2214 ses(pps_cr_qp_offset_list[
i], -12, 12, 1,
i);
2215 if (current->pps_joint_cbcr_qp_offset_present_flag)
2216 ses(pps_joint_cbcr_qp_offset_list[
i], -12, 12, 1,
i);
2218 infer(pps_joint_cbcr_qp_offset_list[
i], 0);
2222 infer(pps_cb_qp_offset, 0);
2223 infer(pps_cr_qp_offset, 0);
2224 infer(pps_joint_cbcr_qp_offset_present_flag, 0);
2225 infer(pps_joint_cbcr_qp_offset_value, 0);
2226 infer(pps_slice_chroma_qp_offsets_present_flag, 0);
2227 infer(pps_cu_chroma_qp_offset_list_enabled_flag, 0);
2229 flag(pps_deblocking_filter_control_present_flag);
2230 if (current->pps_deblocking_filter_control_present_flag) {
2231 flag(pps_deblocking_filter_override_enabled_flag);
2232 flag(pps_deblocking_filter_disabled_flag);
2233 if (!current->pps_no_pic_partition_flag &&
2234 current->pps_deblocking_filter_override_enabled_flag)
2235 flag(pps_dbf_info_in_ph_flag);
2237 infer(pps_dbf_info_in_ph_flag, 0);
2238 if (!current->pps_deblocking_filter_disabled_flag) {
2239 se(pps_luma_beta_offset_div2, -12, 12);
2240 se(pps_luma_tc_offset_div2, -12, 12);
2241 if (current->pps_chroma_tool_offsets_present_flag) {
2242 se(pps_cb_beta_offset_div2, -12, 12);
2243 se(pps_cb_tc_offset_div2, -12, 12);
2244 se(pps_cr_beta_offset_div2, -12, 12);
2245 se(pps_cr_tc_offset_div2, -12, 12);
2247 infer(pps_cb_beta_offset_div2,
2248 current->pps_luma_beta_offset_div2);
2249 infer(pps_cb_tc_offset_div2, current->pps_luma_tc_offset_div2);
2250 infer(pps_cr_beta_offset_div2,
2251 current->pps_luma_beta_offset_div2);
2252 infer(pps_cr_tc_offset_div2, current->pps_luma_tc_offset_div2);
2255 infer(pps_luma_beta_offset_div2, 0);
2256 infer(pps_luma_tc_offset_div2, 0);
2257 infer(pps_cb_beta_offset_div2, 0);
2258 infer(pps_cb_tc_offset_div2, 0);
2259 infer(pps_cr_beta_offset_div2, 0);
2260 infer(pps_cr_tc_offset_div2, 0);
2263 infer(pps_deblocking_filter_override_enabled_flag, 0);
2264 infer(pps_deblocking_filter_disabled_flag, 0);
2265 infer(pps_dbf_info_in_ph_flag, 0);
2266 infer(pps_luma_beta_offset_div2, 0);
2267 infer(pps_luma_tc_offset_div2, 0);
2268 infer(pps_cb_beta_offset_div2, 0);
2269 infer(pps_cb_tc_offset_div2, 0);
2270 infer(pps_cr_beta_offset_div2, 0);
2271 infer(pps_cr_tc_offset_div2, 0);
2274 if (!current->pps_no_pic_partition_flag) {
2275 flag(pps_rpl_info_in_ph_flag);
2276 flag(pps_sao_info_in_ph_flag);
2277 flag(pps_alf_info_in_ph_flag);
2278 if ((current->pps_weighted_pred_flag ||
2279 current->pps_weighted_bipred_flag) &&
2280 current->pps_rpl_info_in_ph_flag)
2281 flag(pps_wp_info_in_ph_flag);
2282 flag(pps_qp_delta_info_in_ph_flag);
2284 flag(pps_picture_header_extension_present_flag);
2285 flag(pps_slice_header_extension_present_flag);
2287 flag(pps_extension_flag);
2288 if (current->pps_extension_flag)
2300 flag(alf_luma_filter_signal_flag);
2302 if (current->aps_chroma_present_flag) {
2303 flag(alf_chroma_filter_signal_flag);
2304 flag(alf_cc_cb_filter_signal_flag);
2305 flag(alf_cc_cr_filter_signal_flag);
2307 infer(alf_chroma_filter_signal_flag, 0);
2308 infer(alf_cc_cb_filter_signal_flag, 0);
2309 infer(alf_cc_cr_filter_signal_flag, 0);
2312 if (current->alf_luma_filter_signal_flag) {
2313 flag(alf_luma_clip_flag);
2315 if (current->alf_luma_num_filters_signalled_minus1 > 0) {
2316 unsigned int bits =
av_ceil_log2(current->alf_luma_num_filters_signalled_minus1 + 1);
2318 us(
bits, alf_luma_coeff_delta_idx[filt_idx],
2319 0, current->alf_luma_num_filters_signalled_minus1,
2322 for (
int sf_idx = 0; sf_idx <= current->alf_luma_num_filters_signalled_minus1; sf_idx++)
2323 for (j = 0; j < 12; j++) {
2324 ues(alf_luma_coeff_abs[sf_idx][j], 0, 128, 2, sf_idx, j);
2325 if (current->alf_luma_coeff_abs[sf_idx][j])
2326 ubs(1, alf_luma_coeff_sign[sf_idx][j], 2, sf_idx, j);
2328 infer(alf_luma_coeff_sign[sf_idx][j], 0);
2331 infer(alf_luma_clip_flag, 0);
2332 infer(alf_luma_num_filters_signalled_minus1, 0);
2334 for (
int sf_idx = 0; sf_idx <= current->alf_luma_num_filters_signalled_minus1; sf_idx++) {
2335 for (j = 0; j < 12; j++) {
2336 if (current->alf_luma_clip_flag)
2337 ubs(2, alf_luma_clip_idx[sf_idx][j], 2, sf_idx, j);
2339 infer(alf_luma_clip_idx[sf_idx][j], 0);
2343 if (current->alf_chroma_filter_signal_flag) {
2344 flag(alf_chroma_clip_flag);
2345 ue(alf_chroma_num_alt_filters_minus1, 0, 7);
2347 infer(alf_chroma_clip_flag, 0);
2348 infer(alf_chroma_num_alt_filters_minus1, 0);
2350 for (
int alt_idx = 0; alt_idx <= current->alf_chroma_num_alt_filters_minus1; alt_idx++) {
2351 for (j = 0; j < 6; j++) {
2352 if (current->alf_chroma_filter_signal_flag)
2353 ues(alf_chroma_coeff_abs[alt_idx][j], 0, 128, 2, alt_idx, j);
2355 infer(alf_chroma_coeff_abs[alt_idx][j], 0);
2356 if (current->alf_chroma_coeff_abs[alt_idx][j] > 0)
2357 ubs(1, alf_chroma_coeff_sign[alt_idx][j], 2, alt_idx, j);
2359 infer(alf_chroma_coeff_sign[alt_idx][j], 0);
2361 for (j = 0; j < 6; j++) {
2362 if (current->alf_chroma_clip_flag)
2363 ubs(2, alf_chroma_clip_idx[alt_idx][j], 2, alt_idx, j);
2365 infer(alf_chroma_clip_idx[alt_idx][j], 0);
2369 if (current->alf_cc_cb_filter_signal_flag)
2370 ue(alf_cc_cb_filters_signalled_minus1, 0, 3);
2372 infer(alf_cc_cb_filters_signalled_minus1, 0);
2373 for (k = 0; k <= current->alf_cc_cb_filters_signalled_minus1; k++) {
2374 for (j = 0; j < 7; j++) {
2375 if (current->alf_cc_cb_filter_signal_flag)
2376 ubs(3, alf_cc_cb_mapped_coeff_abs[k][j], 2, k, j);
2378 infer(alf_cc_cb_mapped_coeff_abs[k][j], 0);
2379 if (current->alf_cc_cb_mapped_coeff_abs[k][j])
2380 ubs(1, alf_cc_cb_coeff_sign[k][j], 2, k, j);
2382 infer(alf_cc_cb_coeff_sign[k][j], 0);
2386 if (current->alf_cc_cr_filter_signal_flag)
2387 ue(alf_cc_cr_filters_signalled_minus1, 0, 3);
2389 infer(alf_cc_cr_filters_signalled_minus1, 0);
2390 for (k = 0; k < current->alf_cc_cr_filters_signalled_minus1 + 1; k++) {
2391 for (j = 0; j < 7; j++) {
2392 if (current->alf_cc_cr_filter_signal_flag)
2393 ubs(3, alf_cc_cr_mapped_coeff_abs[k][j], 2, k, j);
2395 infer(alf_cc_cr_mapped_coeff_abs[k][j], 0);
2396 if (current->alf_cc_cr_mapped_coeff_abs[k][j])
2397 ubs(1, alf_cc_cr_coeff_sign[k][j], 2, k, j);
2399 infer(alf_cc_cr_coeff_sign[k][j], 0);
2409 int err,
i, lmcs_max_bin_idx;
2411 ue(lmcs_min_bin_idx, 0, 15);
2412 ue(lmcs_delta_max_bin_idx, 0, 15);
2413 ue(lmcs_delta_cw_prec_minus1, 0, 14);
2415 lmcs_max_bin_idx = 15 - current->lmcs_delta_max_bin_idx;
2417 if (lmcs_max_bin_idx < current->lmcs_min_bin_idx)
2420 for (
i = current->lmcs_min_bin_idx;
i <= lmcs_max_bin_idx;
i++) {
2421 ubs(current->lmcs_delta_cw_prec_minus1 + 1, lmcs_delta_abs_cw[
i], 1,
i);
2422 if (current->lmcs_delta_abs_cw[
i] > 0)
2423 flags(lmcs_delta_sign_cw_flag[
i], 1,
i);
2425 infer(lmcs_delta_sign_cw_flag[
i], 0);
2428 if (current->aps_chroma_present_flag) {
2429 ub(3, lmcs_delta_abs_crs);
2430 if (current->lmcs_delta_abs_crs > 0)
2431 flag(lmcs_delta_sign_crs_flag);
2433 infer(lmcs_delta_sign_crs_flag, 0);
2435 infer(lmcs_delta_abs_crs, 0);
2436 infer(lmcs_delta_sign_crs_flag, 0);
2446 static const uint8_t diag_scan_order[64][2] = {
2447 { 0, 0, }, { 0, 1, }, { 1, 0, }, { 0, 2, }, { 1, 1, }, { 2, 0, }, { 0, 3, }, { 1, 2, },
2448 { 2, 1, }, { 3, 0, }, { 0, 4, }, { 1, 3, }, { 2, 2, }, { 3, 1, }, { 4, 0, }, { 0, 5, },
2449 { 1, 4, }, { 2, 3, }, { 3, 2, }, { 4, 1, }, { 5, 0, }, { 0, 6, }, { 1, 5, }, { 2, 4, },
2450 { 3, 3, }, { 4, 2, }, { 5, 1, }, { 6, 0, }, { 0, 7, }, { 1, 6, }, { 2, 5, }, { 3, 4, },
2451 { 4, 3, }, { 5, 2, }, { 6, 1, }, { 7, 0, }, { 1, 7, }, { 2, 6, }, { 3, 5, }, { 4, 4, },
2452 { 5, 3, }, { 6, 2, }, { 7, 1, }, { 2, 7, }, { 3, 6, }, { 4, 5, }, { 5, 4, }, { 6, 3, },
2453 { 7, 2, }, { 3, 7, }, { 4, 6, }, { 5, 5, }, { 6, 4, }, { 7, 3, }, { 4, 7, }, { 5, 6, },
2454 { 6, 5, }, { 7, 4, }, { 5, 7, }, { 6, 6, }, { 7, 5, }, { 6, 7, }, { 7, 6, }, { 7, 7, }, };
2457 for (
int id = 0;
id < 28;
id ++) {
2458 if (current->aps_chroma_present_flag ||
id % 3 == 2 ||
id == 27) {
2459 flags(scaling_list_copy_mode_flag[
id], 1,
id);
2460 if (!current->scaling_list_copy_mode_flag[
id])
2461 flags(scaling_list_pred_mode_flag[
id], 1,
id);
2463 infer(scaling_list_pred_mode_flag[
id], 0);
2464 if ((current->scaling_list_copy_mode_flag[
id] ||
2465 current->scaling_list_pred_mode_flag[
id]) &&
2466 id != 0 &&
id != 2 &&
id != 8) {
2467 int max_id_delta = (
id < 2) ?
id : ((
id < 8) ? (
id - 2) : (
id - 8));
2468 ues(scaling_list_pred_id_delta[
id], 0, max_id_delta, 1,
id);
2470 if (!current->scaling_list_copy_mode_flag[
id]) {
2471 int matrix_size =
id < 2 ? 2 : (
id < 8 ? 4 : 8);
2474 ses(scaling_list_dc_coef[idx], -128, 127, 1, idx);
2476 for (
int i = 0;
i < matrix_size * matrix_size;
i++) {
2477 int x = diag_scan_order[
i][0];
2478 int y = diag_scan_order[
i][1];
2479 if (!(
id > 25 && x >= 4 && y >= 4))
2480 ses(scaling_list_delta_coef[
id][
i], -128, 127, 2,
id,
i);
2482 }
else if (
id > 13) {
2484 infer(scaling_list_dc_coef[idx], 0);
2487 infer(scaling_list_copy_mode_flag[
id], 1);
2488 infer(scaling_list_pred_mode_flag[
id], 0);
2502 HEADER(
"Prefix Adaptation parameter set");
2504 HEADER(
"Suffix Adaptation parameter set");
2510 ub(3, aps_params_type);
2516 u(5, aps_adaptation_parameter_set_id, 0, aps_id_max);
2517 flag(aps_chroma_present_flag);
2524 flag(aps_extension_flag);
2525 if (current->aps_extension_flag)
2537 HEADER(
"Access Unit Delimiter");
2542 flag(aud_irap_or_gdr_flag);
2543 u(3, aud_pic_type, 0, 2);
2553 uint8_t num_ref_idx_active[2],
2557 ue(luma_log2_weight_denom, 0, 7);
2558 if (
sps->sps_chroma_format_idc != 0) {
2559 se(delta_chroma_log2_weight_denom,
2560 -current->luma_log2_weight_denom,
2561 7 - current->luma_log2_weight_denom);
2563 infer(delta_chroma_log2_weight_denom, 0);
2565 if (
pps->pps_wp_info_in_ph_flag) {
2566 ue(num_l0_weights, 0,
2567 FFMIN(15, ref_lists->rpl_ref_list[0].num_ref_entries));
2568 infer(num_weights_l0, current->num_l0_weights);
2570 infer(num_weights_l0, num_ref_idx_active[0]);
2572 for (
i = 0;
i < current->num_weights_l0;
i++) {
2573 flags(luma_weight_l0_flag[
i], 1,
i);
2575 if (
sps->sps_chroma_format_idc != 0) {
2576 for (
i = 0;
i < current->num_weights_l0;
i++)
2577 flags(chroma_weight_l0_flag[
i], 1,
i);
2579 for (
i = 0;
i < current->num_weights_l0;
i++) {
2580 if (current->luma_weight_l0_flag[
i]) {
2581 ses(delta_luma_weight_l0[
i], -128, 127, 1,
i);
2582 ses(luma_offset_l0[
i], -128, 127, 1,
i);
2584 infer(delta_luma_weight_l0[
i], 0);
2585 infer(luma_offset_l0[
i], 0);
2587 if (current->chroma_weight_l0_flag[
i]) {
2588 for (j = 0; j < 2; j++) {
2589 ses(delta_chroma_weight_l0[
i][j], -128, 127, 2,
i, j);
2590 ses(delta_chroma_offset_l0[
i][j], -4 * 128, 4 * 127, 2,
i, j);
2595 if (
pps->pps_weighted_bipred_flag &&
2596 ref_lists->rpl_ref_list[1].num_ref_entries > 0) {
2597 if (
pps->pps_wp_info_in_ph_flag) {
2598 ue(num_l1_weights, 0,
2599 FFMIN(15, ref_lists->rpl_ref_list[1].num_ref_entries));
2600 infer(num_weights_l1, current->num_l1_weights);
2602 infer(num_weights_l1, num_ref_idx_active[1]);
2605 infer(num_weights_l1, 0);
2608 for (
i = 0;
i < current->num_weights_l1;
i++)
2609 flags(luma_weight_l1_flag[
i], 1,
i);
2610 if (
sps->sps_chroma_format_idc != 0) {
2611 for (
i = 0;
i < current->num_weights_l1;
i++)
2612 flags(chroma_weight_l1_flag[
i], 1,
i);
2614 for (
i = 0;
i < current->num_weights_l1;
i++) {
2615 if (current->luma_weight_l1_flag[
i]) {
2616 ses(delta_luma_weight_l1[
i], -128, 127, 1,
i);
2617 ses(luma_offset_l1[
i], -128, 127, 1,
i);
2619 infer(delta_luma_weight_l1[
i], 0);
2620 infer(luma_offset_l1[
i], 0);
2622 if (current->chroma_weight_l1_flag[
i]) {
2623 for (j = 0; j < 2; j++) {
2624 ses(delta_chroma_weight_l1[
i][j], -128, 127, 2,
i, j);
2625 ses(delta_chroma_offset_l1[
i][j], -4 * 128, 4 * 127, 2,
i, j);
2639 unsigned int ctb_log2_size_y, min_cb_log2_size_y,
2640 min_qt_log2_size_intra_y, min_qt_log2_size_inter_y;
2641 uint8_t qp_bd_offset;
2643 flag(ph_gdr_or_irap_pic_flag);
2644 flag(ph_non_ref_pic_flag);
2645 if (current->ph_gdr_or_irap_pic_flag)
2646 flag(ph_gdr_pic_flag);
2648 infer(ph_gdr_pic_flag, 0);
2649 flag(ph_inter_slice_allowed_flag);
2650 if (current->ph_inter_slice_allowed_flag)
2651 flag(ph_intra_slice_allowed_flag);
2653 infer(ph_intra_slice_allowed_flag, 1);
2655 pps = h266->
pps[current->ph_pic_parameter_set_id];
2658 current->ph_pic_parameter_set_id);
2661 sps = h266->
sps[
pps->pps_seq_parameter_set_id];
2664 pps->pps_seq_parameter_set_id);
2667 vps = h266->
vps[
sps->sps_video_parameter_set_id];
2670 sps->sps_video_parameter_set_id);
2674 ub(
sps->sps_log2_max_pic_order_cnt_lsb_minus4 + 4, ph_pic_order_cnt_lsb);
2675 if (current->ph_gdr_pic_flag)
2676 ue(ph_recovery_poc_cnt, 0,
2677 1 << (
sps->sps_log2_max_pic_order_cnt_lsb_minus4 + 4));
2679 for (
i = 0;
i <
sps->sps_num_extra_ph_bytes * 8;
i++) {
2680 if (
sps->sps_extra_ph_bit_present_flag[
i])
2683 if (
sps->sps_poc_msb_cycle_flag) {
2684 flag(ph_poc_msb_cycle_present_flag);
2685 if (current->ph_poc_msb_cycle_present_flag)
2686 ub(
sps->sps_poc_msb_cycle_len_minus1 + 1, ph_poc_msb_cycle_val);
2688 if (
sps->sps_alf_enabled_flag &&
pps->pps_alf_info_in_ph_flag) {
2689 flag(ph_alf_enabled_flag);
2690 if (current->ph_alf_enabled_flag) {
2692 ub(3, ph_num_alf_aps_ids_luma);
2693 for (
i = 0;
i < current->ph_num_alf_aps_ids_luma;
i++)
2694 ubs(3, ph_alf_aps_id_luma[
i], 1,
i);
2696 if (
sps->sps_chroma_format_idc != 0) {
2697 flag(ph_alf_cb_enabled_flag);
2698 flag(ph_alf_cr_enabled_flag);
2700 infer(ph_alf_cb_enabled_flag, 0);
2701 infer(ph_alf_cr_enabled_flag, 0);
2704 if (current->ph_alf_cb_enabled_flag
2705 || current->ph_alf_cr_enabled_flag) {
2706 ub(3, ph_alf_aps_id_chroma);
2709 if (
sps->sps_ccalf_enabled_flag) {
2710 flag(ph_alf_cc_cb_enabled_flag);
2711 if (current->ph_alf_cc_cb_enabled_flag)
2712 ub(3, ph_alf_cc_cb_aps_id);
2713 flag(ph_alf_cc_cr_enabled_flag);
2714 if (current->ph_alf_cc_cr_enabled_flag)
2715 ub(3, ph_alf_cc_cr_aps_id);
2719 infer(ph_alf_enabled_flag, 0);
2721 if (
sps->sps_lmcs_enabled_flag) {
2722 flag(ph_lmcs_enabled_flag);
2723 if (current->ph_lmcs_enabled_flag) {
2724 ub(2, ph_lmcs_aps_id);
2725 if (
sps->sps_chroma_format_idc != 0)
2726 flag(ph_chroma_residual_scale_flag);
2728 infer(ph_chroma_residual_scale_flag, 0);
2731 infer(ph_lmcs_enabled_flag, 0);
2732 infer(ph_chroma_residual_scale_flag, 0);
2735 if (
sps->sps_explicit_scaling_list_enabled_flag) {
2736 flag(ph_explicit_scaling_list_enabled_flag);
2737 if (current->ph_explicit_scaling_list_enabled_flag) {
2739 ub(3, ph_scaling_list_aps_id);
2742 infer(ph_explicit_scaling_list_enabled_flag, 0);
2744 if (
sps->sps_virtual_boundaries_enabled_flag &&
2745 !
sps->sps_virtual_boundaries_present_flag) {
2746 flag(ph_virtual_boundaries_present_flag);
2747 if (current->ph_virtual_boundaries_present_flag) {
2748 ue(ph_num_ver_virtual_boundaries,
2750 for (
i = 0;
i < current->ph_num_ver_virtual_boundaries;
i++) {
2751 ues(ph_virtual_boundary_pos_x_minus1[
i],
2752 0, (
pps->pps_pic_width_in_luma_samples + 7) / 8 - 2, 1,
i);
2754 ue(ph_num_hor_virtual_boundaries,
2756 for (
i = 0;
i < current->ph_num_hor_virtual_boundaries;
i++) {
2757 ues(ph_virtual_boundary_pos_y_minus1[
i],
2758 0, (
pps->pps_pic_height_in_luma_samples + 7) / 8 - 2, 1,
i);
2761 infer(ph_num_ver_virtual_boundaries, 0);
2762 infer(ph_num_hor_virtual_boundaries, 0);
2765 if (
pps->pps_output_flag_present_flag && !current->ph_non_ref_pic_flag)
2766 flag(ph_pic_output_flag);
2768 infer(ph_pic_output_flag, 1);
2769 if (
pps->pps_rpl_info_in_ph_flag) {
2771 (
ctx, rw,
sps,
pps, ¤t->ph_ref_pic_lists));
2773 if (
sps->sps_partition_constraints_override_enabled_flag)
2774 flag(ph_partition_constraints_override_flag);
2776 infer(ph_partition_constraints_override_flag, 0);
2778 ctb_log2_size_y =
sps->sps_log2_ctu_size_minus5 + 5;
2779 min_cb_log2_size_y =
sps->sps_log2_min_luma_coding_block_size_minus2 + 2;
2780 if (current->ph_intra_slice_allowed_flag) {
2781 if (current->ph_partition_constraints_override_flag) {
2782 ue(ph_log2_diff_min_qt_min_cb_intra_slice_luma,
2783 0,
FFMIN(6, ctb_log2_size_y) - min_cb_log2_size_y);
2784 ue(ph_max_mtt_hierarchy_depth_intra_slice_luma,
2785 0, 2 * (ctb_log2_size_y - min_cb_log2_size_y));
2786 if (current->ph_max_mtt_hierarchy_depth_intra_slice_luma != 0) {
2787 min_qt_log2_size_intra_y =
2788 current->ph_log2_diff_min_qt_min_cb_intra_slice_luma +
2790 ue(ph_log2_diff_max_bt_min_qt_intra_slice_luma,
2791 0, (
sps->sps_qtbtt_dual_tree_intra_flag ?
2792 FFMIN(6, ctb_log2_size_y) :
2793 ctb_log2_size_y) - min_qt_log2_size_intra_y);
2794 ue(ph_log2_diff_max_tt_min_qt_intra_slice_luma,
2795 0,
FFMIN(6, ctb_log2_size_y) - min_qt_log2_size_intra_y);
2797 infer(ph_log2_diff_max_bt_min_qt_intra_slice_luma,
2798 sps->sps_log2_diff_max_bt_min_qt_intra_slice_luma);
2799 infer(ph_log2_diff_max_tt_min_qt_intra_slice_luma,
2800 sps->sps_log2_diff_max_tt_min_qt_intra_slice_luma);
2802 if (
sps->sps_qtbtt_dual_tree_intra_flag) {
2803 ue(ph_log2_diff_min_qt_min_cb_intra_slice_chroma,
2804 0,
FFMIN(6, ctb_log2_size_y) - min_cb_log2_size_y);
2805 ue(ph_max_mtt_hierarchy_depth_intra_slice_chroma,
2806 0, 2 * (ctb_log2_size_y - min_cb_log2_size_y));
2807 if (
sps->sps_max_mtt_hierarchy_depth_intra_slice_chroma != 0) {
2808 unsigned int min_qt_log2_size_intra_c =
2809 current->ph_log2_diff_min_qt_min_cb_intra_slice_chroma +
2811 ue(ph_log2_diff_max_bt_min_qt_intra_slice_chroma,
2812 0,
FFMIN(6, ctb_log2_size_y) - min_qt_log2_size_intra_c);
2813 ue(ph_log2_diff_max_tt_min_qt_intra_slice_chroma,
2814 0,
FFMIN(6, ctb_log2_size_y) - min_qt_log2_size_intra_c);
2816 infer(ph_log2_diff_max_bt_min_qt_intra_slice_chroma,
2817 sps->sps_log2_diff_max_bt_min_qt_intra_slice_chroma);
2818 infer(ph_log2_diff_max_tt_min_qt_intra_slice_chroma,
2819 sps->sps_log2_diff_max_tt_min_qt_intra_slice_chroma);
2823 infer(ph_log2_diff_min_qt_min_cb_intra_slice_luma,
2824 sps->sps_log2_diff_min_qt_min_cb_intra_slice_luma);
2825 infer(ph_max_mtt_hierarchy_depth_intra_slice_luma,
2826 sps->sps_max_mtt_hierarchy_depth_intra_slice_luma);
2827 infer(ph_log2_diff_max_bt_min_qt_intra_slice_luma,
2828 sps->sps_log2_diff_max_bt_min_qt_intra_slice_luma);
2829 infer(ph_log2_diff_max_tt_min_qt_intra_slice_luma,
2830 sps->sps_log2_diff_max_tt_min_qt_intra_slice_luma);
2831 infer(ph_log2_diff_min_qt_min_cb_intra_slice_chroma,
2832 sps->sps_log2_diff_min_qt_min_cb_intra_slice_chroma);
2833 infer(ph_max_mtt_hierarchy_depth_intra_slice_chroma,
2834 sps->sps_max_mtt_hierarchy_depth_intra_slice_chroma);
2835 infer(ph_log2_diff_max_bt_min_qt_intra_slice_chroma,
2836 sps->sps_log2_diff_max_bt_min_qt_intra_slice_chroma);
2837 infer(ph_log2_diff_max_tt_min_qt_intra_slice_chroma,
2838 sps->sps_log2_diff_max_tt_min_qt_intra_slice_chroma);
2841 min_qt_log2_size_intra_y =
2842 current->ph_log2_diff_min_qt_min_cb_intra_slice_luma +
2844 if (
pps->pps_cu_qp_delta_enabled_flag)
2845 ue(ph_cu_qp_delta_subdiv_intra_slice, 0,
2846 2 * (ctb_log2_size_y - min_qt_log2_size_intra_y +
2847 current->ph_max_mtt_hierarchy_depth_intra_slice_luma));
2849 infer(ph_cu_qp_delta_subdiv_intra_slice, 0);
2851 if (
pps->pps_cu_chroma_qp_offset_list_enabled_flag)
2852 ue(ph_cu_chroma_qp_offset_subdiv_intra_slice, 0,
2853 2 * (ctb_log2_size_y - min_qt_log2_size_intra_y +
2854 current->ph_max_mtt_hierarchy_depth_intra_slice_luma));
2856 infer(ph_cu_chroma_qp_offset_subdiv_intra_slice, 0);
2858 if (current->ph_inter_slice_allowed_flag) {
2859 if (current->ph_partition_constraints_override_flag) {
2860 ue(ph_log2_diff_min_qt_min_cb_inter_slice,
2861 0,
FFMIN(6, ctb_log2_size_y) - min_cb_log2_size_y);
2862 min_qt_log2_size_inter_y =
2863 current->ph_log2_diff_min_qt_min_cb_inter_slice +
2865 ue(ph_max_mtt_hierarchy_depth_inter_slice, 0,
2866 2 * (ctb_log2_size_y - min_cb_log2_size_y));
2867 if (current->ph_max_mtt_hierarchy_depth_inter_slice != 0) {
2868 ue(ph_log2_diff_max_bt_min_qt_inter_slice,
2869 0, ctb_log2_size_y - min_qt_log2_size_inter_y);
2870 ue(ph_log2_diff_max_tt_min_qt_inter_slice,
2871 0,
FFMIN(6, ctb_log2_size_y) - min_qt_log2_size_inter_y);
2874 infer(ph_log2_diff_min_qt_min_cb_inter_slice,
2875 sps->sps_log2_diff_min_qt_min_cb_inter_slice);
2876 min_qt_log2_size_inter_y =
2877 current->ph_log2_diff_min_qt_min_cb_inter_slice +
2879 infer(ph_max_mtt_hierarchy_depth_inter_slice,
2880 sps->sps_max_mtt_hierarchy_depth_inter_slice);
2881 infer(ph_log2_diff_max_bt_min_qt_inter_slice,
2882 sps->sps_log2_diff_max_bt_min_qt_inter_slice);
2883 infer(ph_log2_diff_max_tt_min_qt_inter_slice,
2884 sps->sps_log2_diff_max_tt_min_qt_inter_slice);
2887 if (
pps->pps_cu_qp_delta_enabled_flag)
2888 ue(ph_cu_qp_delta_subdiv_inter_slice, 0,
2889 2 * (ctb_log2_size_y - min_qt_log2_size_inter_y +
2890 current->ph_max_mtt_hierarchy_depth_inter_slice));
2892 infer(ph_cu_qp_delta_subdiv_inter_slice, 0);
2894 if (
pps->pps_cu_chroma_qp_offset_list_enabled_flag)
2895 ue(ph_cu_chroma_qp_offset_subdiv_inter_slice, 0,
2896 2 * (ctb_log2_size_y - min_qt_log2_size_inter_y +
2897 current->ph_max_mtt_hierarchy_depth_inter_slice));
2899 infer(ph_cu_chroma_qp_offset_subdiv_inter_slice, 0);
2900 if (
sps->sps_temporal_mvp_enabled_flag) {
2901 flag(ph_temporal_mvp_enabled_flag);
2902 if (current->ph_temporal_mvp_enabled_flag &&
2903 pps->pps_rpl_info_in_ph_flag) {
2904 if (current->ph_ref_pic_lists.rpl_ref_list[1].num_ref_entries > 0)
2905 flag(ph_collocated_from_l0_flag);
2907 infer(ph_collocated_from_l0_flag, 1);
2908 if ((current->ph_collocated_from_l0_flag &&
2909 current->ph_ref_pic_lists.rpl_ref_list[0].num_ref_entries > 1)
2910 || (!current->ph_collocated_from_l0_flag &&
2911 current->ph_ref_pic_lists.rpl_ref_list[1].num_ref_entries > 1)) {
2913 current->ph_collocated_from_l0_flag ? 0 : 1;
2914 ue(ph_collocated_ref_idx, 0,
2915 current->ph_ref_pic_lists.rpl_ref_list[idx].
2916 num_ref_entries - 1);
2918 infer(ph_collocated_ref_idx, 0);
2922 if (
sps->sps_mmvd_fullpel_only_enabled_flag)
2923 flag(ph_mmvd_fullpel_only_flag);
2925 infer(ph_mmvd_fullpel_only_flag, 0);
2926 if (!
pps->pps_rpl_info_in_ph_flag ||
2927 current->ph_ref_pic_lists.rpl_ref_list[1].num_ref_entries > 0) {
2928 flag(ph_mvd_l1_zero_flag);
2929 if (
sps->sps_bdof_control_present_in_ph_flag) {
2930 flag(ph_bdof_disabled_flag);
2932 if (!
sps->sps_bdof_control_present_in_ph_flag)
2933 infer(ph_bdof_disabled_flag,
2934 1 -
sps->sps_bdof_enabled_flag);
2936 infer(ph_bdof_disabled_flag, 1);
2938 if (
sps->sps_dmvr_control_present_in_ph_flag) {
2939 flag(ph_dmvr_disabled_flag);
2941 if (!
sps->sps_dmvr_control_present_in_ph_flag)
2942 infer(ph_dmvr_disabled_flag,
2943 1 -
sps->sps_dmvr_enabled_flag);
2945 infer(ph_dmvr_disabled_flag, 1);
2948 infer(ph_mvd_l1_zero_flag, 1);
2950 if (
sps->sps_prof_control_present_in_ph_flag)
2951 flag(ph_prof_disabled_flag);
2953 infer(ph_prof_disabled_flag, !
sps->sps_affine_prof_enabled_flag);
2954 if ((
pps->pps_weighted_pred_flag ||
2955 pps->pps_weighted_bipred_flag) &&
pps->pps_wp_info_in_ph_flag) {
2959 uint8_t num_ref_idx_active[2] = { 0, 0 };
2961 (
ctx, rw,
sps,
pps, ¤t->ph_ref_pic_lists,
2962 num_ref_idx_active, ¤t->ph_pred_weight_table));
2966 qp_bd_offset = 6 *
sps->sps_bitdepth_minus8;
2967 if (
pps->pps_qp_delta_info_in_ph_flag)
2968 se(ph_qp_delta, -qp_bd_offset - (26 +
pps->pps_init_qp_minus26),
2969 63 - (26 +
pps->pps_init_qp_minus26));
2971 if (
sps->sps_joint_cbcr_enabled_flag)
2972 flag(ph_joint_cbcr_sign_flag);
2974 infer(ph_joint_cbcr_sign_flag, 0);
2975 if (
sps->sps_sao_enabled_flag &&
pps->pps_sao_info_in_ph_flag) {
2976 flag(ph_sao_luma_enabled_flag);
2977 if (
sps->sps_chroma_format_idc != 0)
2978 flag(ph_sao_chroma_enabled_flag);
2980 infer(ph_sao_chroma_enabled_flag, 0);
2982 infer(ph_sao_luma_enabled_flag, 0);
2983 infer(ph_sao_chroma_enabled_flag, 0);
2986 if (
pps->pps_dbf_info_in_ph_flag)
2987 flag(ph_deblocking_params_present_flag);
2989 infer(ph_deblocking_params_present_flag, 0);
2991 if (current->ph_deblocking_params_present_flag) {
2992 if (!
pps->pps_deblocking_filter_disabled_flag) {
2993 flag(ph_deblocking_filter_disabled_flag);
2994 if (!current->ph_deblocking_filter_disabled_flag) {
2995 se(ph_luma_beta_offset_div2, -12, 12);
2996 se(ph_luma_tc_offset_div2, -12, 12);
2997 if (
pps->pps_chroma_tool_offsets_present_flag) {
2998 se(ph_cb_beta_offset_div2, -12, 12);
2999 se(ph_cb_tc_offset_div2, -12, 12);
3000 se(ph_cr_beta_offset_div2, -12, 12);
3001 se(ph_cr_tc_offset_div2, -12, 12);
3003 infer(ph_cb_beta_offset_div2,
3004 current->ph_luma_beta_offset_div2);
3005 infer(ph_cb_tc_offset_div2,
3006 current->ph_luma_tc_offset_div2);
3007 infer(ph_cr_beta_offset_div2,
3008 current->ph_luma_beta_offset_div2);
3009 infer(ph_cr_tc_offset_div2,
3010 current->ph_luma_tc_offset_div2);
3014 infer(ph_deblocking_filter_disabled_flag, 0);
3017 infer(ph_deblocking_filter_disabled_flag,
pps->pps_deblocking_filter_disabled_flag);
3018 if (!current->ph_deblocking_filter_disabled_flag) {
3019 infer(ph_luma_beta_offset_div2,
pps->pps_luma_beta_offset_div2);
3020 infer(ph_luma_tc_offset_div2,
pps->pps_luma_tc_offset_div2);
3021 infer(ph_cb_beta_offset_div2,
pps->pps_cb_beta_offset_div2);
3022 infer(ph_cb_tc_offset_div2,
pps->pps_cb_tc_offset_div2);
3023 infer(ph_cr_beta_offset_div2,
pps->pps_cr_beta_offset_div2);
3024 infer(ph_cr_tc_offset_div2,
pps->pps_cr_tc_offset_div2);
3028 if (
pps->pps_picture_header_extension_present_flag) {
3029 ue(ph_extension_length, 0, 256);
3030 for (
i = 0;
i < current->ph_extension_length;
i++)
3031 us(8, ph_extension_data_byte[
i], 0x00, 0xff, 1,
i);
3042 HEADER(
"Picture Header");
3059 uint8_t nal_unit_type, qp_bd_offset;
3060 uint16_t num_slices_in_subpic;
3066 flag(sh_picture_header_in_slice_header_flag);
3067 if (current->sh_picture_header_in_slice_header_flag) {
3070 ph = ¤t->sh_picture_header;
3075 "Picture header not available.\n");
3080 pps = h266->
pps[
ph->ph_pic_parameter_set_id];
3083 ph->ph_pic_parameter_set_id);
3086 sps = h266->
sps[
pps->pps_seq_parameter_set_id];
3089 pps->pps_seq_parameter_set_id);
3093 if (
sps->sps_subpic_info_present_flag) {
3094 ub(
sps->sps_subpic_id_len_minus1 + 1, sh_subpic_id);
3095 for (
i = 0;
i <=
sps->sps_num_subpics_minus1;
i++) {
3096 if (
pps->sub_pic_id_val[
i] == current->sh_subpic_id) {
3097 current->curr_subpic_idx =
i;
3101 if (
i >
sps->sps_num_subpics_minus1) {
3106 current->curr_subpic_idx = 0;
3109 num_slices_in_subpic =
pps->num_slices_in_subpic[current->curr_subpic_idx];
3111 if ((
pps->pps_rect_slice_flag && num_slices_in_subpic > 1) ||
3112 (!
pps->pps_rect_slice_flag &&
pps->num_tiles_in_pic > 1)) {
3114 if (!
pps->pps_rect_slice_flag) {
3116 max =
pps->num_tiles_in_pic - 1;
3119 max = num_slices_in_subpic - 1;
3126 for (
i = 0;
i <
sps->sps_num_extra_sh_bytes * 8;
i++) {
3127 if (
sps->sps_extra_sh_bit_present_flag[
i])
3131 if (!
pps->pps_rect_slice_flag &&
3132 pps->num_tiles_in_pic - current->sh_slice_address > 1)
3133 ue(sh_num_tiles_in_slice_minus1, 0,
pps->num_tiles_in_pic - 1);
3135 infer(sh_num_tiles_in_slice_minus1, 0);
3137 if (
ph->ph_inter_slice_allowed_flag)
3138 ue(sh_slice_type, 0, 2);
3140 infer(sh_slice_type, 2);
3142 nal_unit_type = current->nal_unit_header.nal_unit_type;
3145 flag(sh_no_output_of_prior_pics_flag);
3147 if (
sps->sps_alf_enabled_flag) {
3148 if (!
pps->pps_alf_info_in_ph_flag) {
3149 flag(sh_alf_enabled_flag);
3150 if (current->sh_alf_enabled_flag) {
3151 ub(3, sh_num_alf_aps_ids_luma);
3152 for (
i = 0;
i < current->sh_num_alf_aps_ids_luma;
i++)
3153 ubs(3, sh_alf_aps_id_luma[
i], 1,
i);
3155 if (
sps->sps_chroma_format_idc != 0) {
3156 flag(sh_alf_cb_enabled_flag);
3157 flag(sh_alf_cr_enabled_flag);
3159 if (current->sh_alf_cb_enabled_flag ||
3160 current->sh_alf_cr_enabled_flag) {
3161 ub(3, sh_alf_aps_id_chroma);
3164 if (
sps->sps_ccalf_enabled_flag) {
3165 flag(sh_alf_cc_cb_enabled_flag);
3166 if (current->sh_alf_cc_cb_enabled_flag)
3167 ub(3, sh_alf_cc_cb_aps_id);
3169 flag(sh_alf_cc_cr_enabled_flag);
3170 if (current->sh_alf_cc_cr_enabled_flag)
3171 ub(3, sh_alf_cc_cr_aps_id);
3175 infer(sh_alf_enabled_flag,
ph->ph_alf_enabled_flag);
3176 if (current->sh_alf_enabled_flag) {
3177 infer(sh_num_alf_aps_ids_luma,
ph->ph_num_alf_aps_ids_luma);
3178 for (
i = 0;
i < current->sh_num_alf_aps_ids_luma;
i++)
3179 infer(sh_alf_aps_id_luma[
i],
ph->ph_alf_aps_id_luma[
i]);
3181 infer(sh_alf_cb_enabled_flag,
ph->ph_alf_cb_enabled_flag);
3182 infer(sh_alf_cr_enabled_flag,
ph->ph_alf_cr_enabled_flag);
3183 if (current->sh_alf_cb_enabled_flag ||current->sh_alf_cr_enabled_flag)
3184 infer(sh_alf_aps_id_chroma,
ph->ph_alf_aps_id_chroma);
3186 if (
sps->sps_ccalf_enabled_flag) {
3187 infer(sh_alf_cc_cb_enabled_flag,
ph->ph_alf_cc_cb_enabled_flag);
3188 if (current->sh_alf_cc_cb_enabled_flag)
3189 infer(sh_alf_cc_cb_aps_id,
ph->ph_alf_cc_cb_aps_id);
3191 infer(sh_alf_cc_cr_enabled_flag,
ph->ph_alf_cc_cr_enabled_flag);
3192 if (current->sh_alf_cc_cr_enabled_flag)
3193 infer(sh_alf_cc_cr_aps_id,
ph->ph_alf_cc_cr_aps_id);
3199 if (current->sh_picture_header_in_slice_header_flag) {
3200 infer(sh_lmcs_used_flag,
ph->ph_lmcs_enabled_flag);
3201 infer(sh_explicit_scaling_list_used_flag,
3202 ph->ph_explicit_scaling_list_enabled_flag);
3204 if (
ph->ph_lmcs_enabled_flag)
3205 flag(sh_lmcs_used_flag);
3207 infer(sh_lmcs_used_flag, 0);
3209 if (
ph->ph_explicit_scaling_list_enabled_flag)
3210 flag(sh_explicit_scaling_list_used_flag);
3212 infer(sh_explicit_scaling_list_used_flag, 0);
3215 if (!
pps->pps_rpl_info_in_ph_flag &&
3219 (
ctx, rw,
sps,
pps, ¤t->sh_ref_pic_lists));
3228 flag(sh_num_ref_idx_active_override_flag);
3229 if (current->sh_num_ref_idx_active_override_flag) {
3233 ues(sh_num_ref_idx_active_minus1[
i], 0, 14, 1,
i);
3235 infer(sh_num_ref_idx_active_minus1[
i], 0);
3238 infer(sh_num_ref_idx_active_override_flag, 1);
3241 for (
i = 0;
i < 2;
i++) {
3244 if (current->sh_num_ref_idx_active_override_flag) {
3245 current->num_ref_idx_active[
i] = current->sh_num_ref_idx_active_minus1[
i] + 1;
3247 current->num_ref_idx_active[
i] =
3249 pps->pps_num_ref_idx_default_active_minus1[
i] + 1);
3252 current->num_ref_idx_active[
i] = 0;
3257 if (
pps->pps_cabac_init_present_flag)
3258 flag(sh_cabac_init_flag);
3260 infer(sh_cabac_init_flag, 0);
3261 if (
ph->ph_temporal_mvp_enabled_flag) {
3262 if (!
pps->pps_rpl_info_in_ph_flag) {
3264 flag(sh_collocated_from_l0_flag);
3266 infer(sh_collocated_from_l0_flag, 1);
3267 if ((current->sh_collocated_from_l0_flag &&
3268 current->num_ref_idx_active[0] > 1) ||
3269 (!current->sh_collocated_from_l0_flag &&
3270 current->num_ref_idx_active[1] > 1)) {
3271 unsigned int idx = current->sh_collocated_from_l0_flag ? 0 : 1;
3272 ue(sh_collocated_ref_idx, 0, current->num_ref_idx_active[idx] - 1);
3274 infer(sh_collocated_ref_idx, 0);
3278 infer(sh_collocated_from_l0_flag,
ph->ph_collocated_from_l0_flag);
3280 infer(sh_collocated_from_l0_flag, 1);
3281 infer(sh_collocated_ref_idx,
ph->ph_collocated_ref_idx);
3284 if (!
pps->pps_wp_info_in_ph_flag &&
3285 ((
pps->pps_weighted_pred_flag &&
3287 (
pps->pps_weighted_bipred_flag &&
3290 current->num_ref_idx_active,
3291 ¤t->sh_pred_weight_table));
3294 qp_bd_offset = 6 *
sps->sps_bitdepth_minus8;
3295 if (!
pps->pps_qp_delta_info_in_ph_flag)
3296 se(sh_qp_delta, -qp_bd_offset - (26 +
pps->pps_init_qp_minus26),
3297 63 - (26 +
pps->pps_init_qp_minus26));
3298 if (
pps->pps_slice_chroma_qp_offsets_present_flag) {
3301 se(sh_cb_qp_offset, -12, 12);
3302 off =
pps->pps_cb_qp_offset + current->sh_cb_qp_offset;
3303 if (off < -12 || off > 12) {
3305 "pps_cb_qp_offset + sh_cb_qp_offset (%d) not in range [-12, 12].\n",
3310 se(sh_cr_qp_offset, -12, 12);
3311 off =
pps->pps_cr_qp_offset + current->sh_cr_qp_offset;
3312 if (off < -12 || off > 12) {
3314 "pps_cr_qp_offset + sh_cr_qp_offset (%d) not in range [-12, 12].\n",
3319 if (
sps->sps_joint_cbcr_enabled_flag) {
3320 se(sh_joint_cbcr_qp_offset, -12, 12);
3322 pps->pps_joint_cbcr_qp_offset_value +
3323 current->sh_joint_cbcr_qp_offset;
3324 if (off < -12 || off > 12) {
3326 "pps_joint_cbcr_qp_offset_value + sh_joint_cbcr_qp_offset (%d)"
3327 "not in range [-12, 12]. \n", off);
3331 infer(sh_joint_cbcr_qp_offset, 0);
3334 infer(sh_cb_qp_offset, 0);
3335 infer(sh_cr_qp_offset, 0);
3336 infer(sh_joint_cbcr_qp_offset, 0);
3338 if (
pps->pps_cu_chroma_qp_offset_list_enabled_flag)
3339 flag(sh_cu_chroma_qp_offset_enabled_flag);
3341 infer(sh_cu_chroma_qp_offset_enabled_flag, 0);
3342 if (
sps->sps_sao_enabled_flag && !
pps->pps_sao_info_in_ph_flag) {
3343 flag(sh_sao_luma_used_flag);
3344 if (
sps->sps_chroma_format_idc != 0)
3345 flag(sh_sao_chroma_used_flag);
3347 infer(sh_sao_chroma_used_flag,
ph->ph_sao_chroma_enabled_flag);
3349 infer(sh_sao_luma_used_flag,
ph->ph_sao_luma_enabled_flag);
3350 infer(sh_sao_chroma_used_flag,
ph->ph_sao_chroma_enabled_flag);
3353 if (
pps->pps_deblocking_filter_override_enabled_flag &&
3354 !
pps->pps_dbf_info_in_ph_flag)
3355 flag(sh_deblocking_params_present_flag);
3357 infer(sh_deblocking_params_present_flag, 0);
3358 if (current->sh_deblocking_params_present_flag) {
3359 if (!
pps->pps_deblocking_filter_disabled_flag)
3360 flag(sh_deblocking_filter_disabled_flag);
3362 infer(sh_deblocking_filter_disabled_flag, 0);
3363 if (!current->sh_deblocking_filter_disabled_flag) {
3364 se(sh_luma_beta_offset_div2, -12, 12);
3365 se(sh_luma_tc_offset_div2, -12, 12);
3366 if (
pps->pps_chroma_tool_offsets_present_flag) {
3367 se(sh_cb_beta_offset_div2, -12, 12);
3368 se(sh_cb_tc_offset_div2, -12, 12);
3369 se(sh_cr_beta_offset_div2, -12, 12);
3370 se(sh_cr_tc_offset_div2, -12, 12);
3372 infer(sh_cb_beta_offset_div2,
3373 current->sh_luma_beta_offset_div2);
3374 infer(sh_cb_tc_offset_div2, current->sh_luma_tc_offset_div2);
3375 infer(sh_cr_beta_offset_div2,
3376 current->sh_luma_beta_offset_div2);
3377 infer(sh_cr_tc_offset_div2, current->sh_luma_tc_offset_div2);
3381 infer(sh_deblocking_filter_disabled_flag,
ph->ph_deblocking_filter_disabled_flag);
3382 if (!current->sh_deblocking_filter_disabled_flag) {
3383 infer(sh_luma_beta_offset_div2,
ph->ph_luma_beta_offset_div2);
3384 infer(sh_luma_tc_offset_div2,
ph->ph_luma_tc_offset_div2);
3385 infer(sh_cb_beta_offset_div2,
ph->ph_cb_beta_offset_div2);
3386 infer(sh_cb_tc_offset_div2,
ph->ph_cb_tc_offset_div2);
3387 infer(sh_cr_beta_offset_div2,
ph->ph_cr_beta_offset_div2);
3388 infer(sh_cr_tc_offset_div2,
ph->ph_cr_tc_offset_div2);
3392 if (
sps->sps_dep_quant_enabled_flag)
3393 flag(sh_dep_quant_used_flag);
3395 infer(sh_dep_quant_used_flag, 0);
3397 if (
sps->sps_sign_data_hiding_enabled_flag &&
3398 !current->sh_dep_quant_used_flag)
3399 flag(sh_sign_data_hiding_used_flag);
3401 infer(sh_sign_data_hiding_used_flag, 0);
3403 if (
sps->sps_transform_skip_enabled_flag &&
3404 !current->sh_dep_quant_used_flag &&
3405 !current->sh_sign_data_hiding_used_flag)
3406 flag(sh_ts_residual_coding_disabled_flag);
3408 infer(sh_ts_residual_coding_disabled_flag, 0);
3410 if (!current->sh_ts_residual_coding_disabled_flag &&
3411 sps->sps_ts_residual_coding_rice_present_in_sh_flag)
3412 ub(3, sh_ts_residual_coding_rice_idx_minus1);
3414 infer(sh_ts_residual_coding_rice_idx_minus1, 0);
3416 if (
sps->sps_reverse_last_sig_coeff_enabled_flag)
3417 flag(sh_reverse_last_sig_coeff_flag);
3419 infer(sh_reverse_last_sig_coeff_flag, 0);
3421 if (
pps->pps_slice_header_extension_present_flag) {
3422 ue(sh_slice_header_extension_length, 0, 256);
3423 for (
i = 0;
i < current->sh_slice_header_extension_length;
i++)
3424 us(8, sh_slice_header_extension_data_byte[
i], 0x00, 0xff, 1,
i);
3427 current->num_entry_points = 0;
3428 if (
sps->sps_entry_point_offsets_present_flag) {
3429 uint8_t entropy_sync =
sps->sps_entropy_coding_sync_enabled_flag;
3431 if (
pps->pps_rect_slice_flag) {
3433 int slice_idx = current->sh_slice_address;
3434 for (
i = 0;
i < current->curr_subpic_idx;
i++) {
3435 slice_idx +=
pps->num_slices_in_subpic[
i];
3438 if (
pps->pps_single_slice_per_subpic_flag) {
3439 const int width_in_ctus =
sps->sps_subpic_width_minus1[slice_idx] + 1;
3440 const int subpic_l =
sps->sps_subpic_ctu_top_left_x[slice_idx];
3441 const int subpic_r = subpic_l + width_in_ctus;
3443 int ctb_x = 0, tile_x = 0;
3444 for (; ctb_x < subpic_l && tile_x <
pps->num_tile_columns; tile_x++)
3445 ctb_x +=
pps->col_width_val[tile_x];
3448 for (; ctb_x < subpic_r && tile_x <
pps->num_tile_columns; tile_x++) {
3449 ctb_x +=
pps->col_width_val[tile_x];
3454 height =
sps->sps_subpic_height_minus1[slice_idx] + 1;
3456 const int height_in_ctus =
sps->sps_subpic_height_minus1[slice_idx] + 1;
3457 const int subpic_t =
sps->sps_subpic_ctu_top_left_y[slice_idx];
3458 const int subpic_b = subpic_t + height_in_ctus;
3460 int ctb_y = 0, tile_y = 0, height_in_tiles;
3461 for (; ctb_y < subpic_t && tile_y <
pps->num_tile_rows; tile_y++)
3462 ctb_y +=
pps->row_height_val[tile_y];
3464 height_in_tiles = 0;
3465 for (; ctb_y < subpic_b && tile_y <
pps->num_tile_rows; tile_y++) {
3466 ctb_y +=
pps->row_height_val[tile_y];
3470 height = height_in_tiles;
3474 pps->pps_slice_width_in_tiles_minus1[slice_idx] + 1;
3477 height =
pps->slice_height_in_ctus[slice_idx];
3479 height =
pps->pps_slice_height_in_tiles_minus1[slice_idx] + 1;
3482 current->num_entry_points = width_in_tiles *
height;
3486 for (tile_idx = current->sh_slice_address;
3488 current->sh_slice_address +
3489 current->sh_num_tiles_in_slice_minus1; tile_idx++) {
3490 tile_y = tile_idx /
pps->num_tile_rows;
3492 current->num_entry_points += (entropy_sync ?
height : 1);
3495 current->num_entry_points--;
3498 "%" PRIu32
".\n", current->num_entry_points);
3501 if (current->num_entry_points > 0) {
3502 ue(sh_entry_offset_len_minus1, 0, 31);
3503 for (
i = 0;
i < current->num_entry_points;
i++) {
3504 ubs(current->sh_entry_offset_len_minus1 + 1,
3505 sh_entry_point_offset_minus1[
i], 1,
i);
3520 HEADER(
"Prefix Supplemental Enhancement Information");
3522 HEADER(
"Suffix Supplemental Enhancement Information");