本文主要是介绍SDP PPS SPS分析(spsparser),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
工具下载:https://download.csdn.net/download/ScarletMeCarzy/12424529
用法是在命令行中输入:
spsparser sps.txt pps.txt output.txt
PPS:
aO48gA==
SPS:
Z00AH5pkAoAt/4C3AQEBQAAA+gAAHUw6GACckAAnJC7y40MAE5IABOSF3lwo
Output.txt:
Start dumping SPS:
-
profile_idc = 77
-
constrained_set0_flag = 0
-
constrained_set1_flag = 0
-
constrained_set2_flag = 0
-
constrained_set3_flag = 0
-
level_idc = 31
-
seq_parameter_set_id = 0
-
chroma_format_idc = 1
-
bit_depth_luma_minus8 = 0
-
bit_depth_chroma_minus8 = 0
-
seq_scaling_matrix_present_flag = 0
-
log2_max_frame_num_minus4 = 5
-
pic_order_cnt_type = 0
-
log2_max_pic_order_cnt_lsb_minus4 = 5
-
delta_pic_order_always_zero_flag = 0
-
offset_for_non_ref_pic = 0
-
offset_for_top_to_bottom_field = 0
-
num_ref_frames_in_pic_order_cnt_cycle = 0
-
num_ref_frames = 1
-
gaps_in_frame_num_value_allowed_flag = 0
-
pic_width_in_mbs_minus1 = 79
-
pic_height_in_mbs_minus1 = 44
-
frame_mbs_only_flag = 1
-
mb_adaptive_frame_field_flag = 0
-
direct_8x8_interence_flag = 1
-
frame_cropping_flag = 1
-
frame_cropping_rect_left_offset = 0
-
frame_cropping_rect_right_offset = 0
-
frame_cropping_rect_top_offset = 0
-
frame_cropping_rect_bottom_offset = 0
-
vui_parameters_present_flag = 1
Start dumping PPS:
-
pic_parameter_set_id = 0
-
seq_parameter_set_id = 0
-
entropy_coding_mode_flag = 1
-
pic_order_present_flag = 0
-
num_slice_groups_minus1 = 0
-
slice_group_map_type = 0
-
num_ref_idx_l0_active_minus1 = 0
-
num_ref_idx_l1_active_minus1 = 0
-
weighted_pref_flag = 0
-
weighted_bipred_idc = 0
-
pic_init_qp_minus26 = 0
-
pic_init_qs_minus26 = 0
-
chroma_qp_index_offset = 0
-
deblocking_filter_control_present_flag = 1
-
constrained_intra_pred_flag = 0
-
redundant_pic_cnt_present_flag = 0
-
transform_8x8_mode_flag = 0
-
pic_scaling_matrix_present_flag = 0
-
second_chroma_qp_index_offset = 0
Explaining:
Start dumping SPS:
-
77 means :main profile
-
no constrains
-
no constrains
-
no constrains
-
Set 0
-
level is 3.1 support 720p HD format,enables interface support.27648000 samples/sec
-
id
-
bit_depth_luma_minus8指定了亮度矩阵的比特深度以及亮度量化参数范围偏移量;此处取0,表示每个亮度像素用8为表示,QpBdOffset参数为0;
-
与bit_depth_luma_minus8类似,只不过是针对色度的
-
seq_scaling_matrix_present_flag = 0@int bit_depth_luma_minus8 = Ue(buf, nLen, StartBit);
-
log2_max_frame_num_minus4 = 5@frame_num 的所能达到的最大值: MaxFrameNum = 2*exp( log2_max_frame_num_minus4 + 4 )
-
@指明了变量 MaxPicOrderCntLsb 的值
-
@MaxPicOrderCntLsb=pow(2, (log2_max_pic_order_cnt_lsb_minus4 + 4)
-
@0表示delta_pic_order_cnt[0]和 delta_pic_order_cnt[1] 都在片头出现
-
@offset_for_non_ref_pic 被用来计算非参考帧或场的 POC,本句法元素的值应该在[pow(-2, 31) , pow(2, 31) – 1]。
-
@ // offset_for_top_to_bottom_field 被用来计算帧的底场的 POC, 本句法元素的值应该在[pow(-2, 31) , pow(2, 31) – 1]。
-
@num_ref_frames_in_pic_order_cnt_cycle 被用来解码POC, 本句法元素的值应该在[0,255]。
-
@num_ref_frames 指定参考帧队列可能达到的最大长度,解码器依照这个句法元素的值开辟存储区,这个存储区用于存放已解码的参考帧,H.264 规定最多可用 16 个参考帧,本句法元素的值最大为 16。值得注意的是这个长度以帧为单位,如果在场模式下,应该相应地扩展一倍。
-
@gaps_in_frame_num_value_allowed_flag 这个句法元素等于 1 时,表示允许句法元素 frame_num 可以不连续。当传输信道堵塞严重时,编码器来不及将编码后的图像全部发出,这时允许丢弃若干帧图像。
-
@pic_width_in_mbs_minus1 本句法元素加 1 后指明图像宽度,以宏块为单位: PicWidthInMbs = pic_width_in_mbs_minus1 + 1 通过这个句法元素解码器可以计算得到亮度分量以像素为单位的图像宽度: PicWidthInSamplesL = PicWidthInMbs * 16
-
@ pic_height_in_map_units_minus1 本句法元素加 1 后指明图像高度: PicHeightInMapUnits = pic_height_in_map_units_minus1 + 1
-
@frame_mbs_only_flag 本句法元素等于 0 时表示本序列中所有图像的编码模式都是帧,没有其他编码模式存在;本句法元素等于 1 时 ,表示本序列中图像的编码模式可能是帧,也可能是场或帧场自适应,某个图像具体是哪一种要由其他句法元素决定。
-
@mb_adaptive_frame_field_flag 指明本序列是否属于帧场自适应模式。mb_adaptive_frame_field_flag等于1时表明在本序列中的图像如果不是场模式就是帧场自适应模式,等于0时表示本序列中的图像如果不是场模式就是帧模式。
-
@direct_8x8_inference_flag 用于指明 B 片的直接和 skip 模式下运动矢量的预测方法。
-
@frame_cropping_flag 用于指明解码器是否要将图像裁剪后输出,如果是的话,后面紧跟着的四个句法元素分别指出左右、上下裁剪的宽度。
-
@ 指明 vui 子结构是否出现在码流中,vui 用以表征视频格式等额外信息。
-
Start dumping PPS:
-
@pic_parameter_set_id指明了在切片头中对应的某个psp.pic_parameter_set_id的值应该在0到255,包括0和255
-
@set_parameter_set_id表示激活的sps.seq_parameter_set_id应该取值在0到31之间,包括边界值.
-
@entropy_coding_mode_flag决定了在解码方法上使用的方法.
-
如果entropy_coding_mode_flag为0的话,就使用Exp-Golomb编码方法
-
如果entropy_coding_mode_flag为1的话,就使用CABAC方法.
-
@pic_order_present_flag等于1表示在切片头中图像顺序值存在,pic_order_present_flag为0表示切片头中的图像顺序值不存在
-
@num_slice_groups_minus1加上1表示一个图像中的切片组数目.当num_slice_groups_minus1为0时,图象所有的切片属于同一组.
-
@slice_group_map_type表示从切片组单到切片组的映射方法.slice_group_map_type的值可以取0到6. 0表示插值切片组.
-
@指明了参考图像列表0中的最大参考索引值,它被用来解码图像的每一个切片,列表0在num_ref_idx_active_override_flag值为0的时候被使用.当MbaffFrameFlag值为1时,num_ref_idx_l0_active_minus1是解码帧宏块的最大索引值,而2 * num_ref_idx_10_active_minus1 + 1是解码场宏块的最大索引值.num_ref_idx_l0_active_minus1的取值为0到31.
-
@num_ref_idx_l1_active_minus1与num_ref_idx_l0_active_minus1有相同的语义,只不过它是针对列表1来说的.
-
@weighted_pred_flag=0表示加权预测在P和SP切片中没有被使用
-
weighted_pred_flag=1表示加权预测在P和SP切片中有使用.
-
@weighted_bipred_idc=0表示默认的加权预测被应用到B切片中.
-
weighted_bipred_idc=1表示外部的加权预测被应用到B切片中.
-
weighted_bipred_idc=2表示内部的加权预测被应用到B切片中.
-
weighted_bipred_idc的取值为0,1,2.
-
@指出了对于每个切片来说的SliceQPY的初始值减26.初始值在切片层中当非0的slice_qp_delta被解码后时改变,在非0的mb_qp_delta值被在宏块层解码时再次被改变.pic_init_qp_minus26应该取-26到+25.
-
@pic_init_qs_minus26指出了对于SP或SI切片中的SliceQSY的被始值减26.这个初始值在切片层中当一个非0的slice_qs_delta被解码的时候被修改.pic_init_qs_minus26的取值为-26到25.
-
@chroma_qp_index_offset表示在查QPC表时,对于QPY和QSY应该加上的偏移量.chroma_qp_index_offset取值为-12到12
-
@deblocking_filter_control_present_flag=1表示在切片头处用来控制解块滤波的特征值是存在的.
-
deblocking_filter_control_present_flag=0表示在切片头处用来控制解块滤波的特征值是不存在的.
-
@constrained_intra_pred_flag=0表示在帧内预测的时候允许剩余数据和邻近宏块解码采样.
-
constrained_intra_pred_flag=1表示在受限的帧内预测,对宏块预测中使用帧内宏块预测模式只使用剩余数据和从I和SI宏块类型中的解码采样值.
-
@redundant_pic_cnt_present_flag=0表示redundant_pic_cnt在切片头中,数据分区B和数据分区C中不存在.
-
redundant_pic_cnt_present_flag=1表示redundant_pic_cnt在所有切片头中,数据分区B和数据分区C中存在.
-
@如果transform_8x8_mode_flag为1,则代表亮度宏块以及4:4:4的色度宏块会采用8x8的DCT,此时亮度宏块以及4:4:4的色度宏块的滤波边界会把宏块分割成8x8的块。
-
@0表示SPS中不存在修改scaling_list的参数。
-
@chroma_qp_index_offset表示在查QPC表时,对于QPY和QSY应该加上的偏移量.chroma_qp_index_offset取值为-12到12
这篇关于SDP PPS SPS分析(spsparser)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!