SDP PPS SPS分析(spsparser)

2023-11-02 06:48
文章标签 分析 sps pps sdp spsparser

本文主要是介绍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: 

  1.   profile_idc = 77 

  1.   constrained_set0_flag = 0 

  1.   constrained_set1_flag = 0 

  1.   constrained_set2_flag = 0 

  1.   constrained_set3_flag = 0  

  1.   level_idc = 31 

  1.   seq_parameter_set_id = 0 

  1.   chroma_format_idc = 1 

  1.   bit_depth_luma_minus8 = 0 

  1.   bit_depth_chroma_minus8 = 0 

  1.   seq_scaling_matrix_present_flag = 0 

  1.   log2_max_frame_num_minus4 = 5 

  1.   pic_order_cnt_type = 0 

  1.   log2_max_pic_order_cnt_lsb_minus4 = 5 

  1.   delta_pic_order_always_zero_flag = 0 

  1.   offset_for_non_ref_pic = 0 

  1.   offset_for_top_to_bottom_field = 0 

  1.   num_ref_frames_in_pic_order_cnt_cycle = 0 

  1.   num_ref_frames = 1 

  1.   gaps_in_frame_num_value_allowed_flag = 0 

  1.   pic_width_in_mbs_minus1 = 79 

  1.   pic_height_in_mbs_minus1 = 44 

  1.   frame_mbs_only_flag = 1 

  1.   mb_adaptive_frame_field_flag = 0 

  1.   direct_8x8_interence_flag = 1 

  1.   frame_cropping_flag = 1 

  1.   frame_cropping_rect_left_offset = 0 

  1.   frame_cropping_rect_right_offset = 0 

  1.   frame_cropping_rect_top_offset = 0 

  1.   frame_cropping_rect_bottom_offset = 0 

  1.   vui_parameters_present_flag = 1 

 

Start dumping PPS: 

  1.   pic_parameter_set_id = 0 

  1.   seq_parameter_set_id = 0 

  1.   entropy_coding_mode_flag = 1 

  1.   pic_order_present_flag = 0 

  1.   num_slice_groups_minus1 = 0 

  1.   slice_group_map_type = 0 

  1.   num_ref_idx_l0_active_minus1 = 0 

  1.   num_ref_idx_l1_active_minus1 = 0 

  1.   weighted_pref_flag = 0 

  1.   weighted_bipred_idc = 0 

  1.   pic_init_qp_minus26 = 0 

  1.   pic_init_qs_minus26 = 0 

  1.   chroma_qp_index_offset = 0 

  1.   deblocking_filter_control_present_flag = 1 

  1.   constrained_intra_pred_flag = 0 

  1.   redundant_pic_cnt_present_flag = 0 

  1.   transform_8x8_mode_flag = 0 

  1.   pic_scaling_matrix_present_flag = 0 

  1.   second_chroma_qp_index_offset = 0 

 

Explaining: 

Start dumping SPS: 

  1. 77 means :main profile 

  1. no constrains 

  1. no constrains 

  1. no constrains 

  1. Set 0 

  1. level is 3.1 support 720p HD format,enables interface support.27648000 samples/sec 

  1. id 

 

  1.  bit_depth_luma_minus8指定了亮度矩阵的比特深度以及亮度量化参数范围偏移量;此处取0,表示每个亮度像素用8为表示,QpBdOffset参数为0; 

  1. 与bit_depth_luma_minus8类似,只不过是针对色度的 

  1.   seq_scaling_matrix_present_flag = 0@int bit_depth_luma_minus8 = Ue(buf, nLen, StartBit); 

  1.   log2_max_frame_num_minus4 = 5@frame_num 的所能达到的最大值: MaxFrameNum = 2*exp( log2_max_frame_num_minus4 + 4 )  

  1. @指明了变量  MaxPicOrderCntLsb 的值 

  1. @MaxPicOrderCntLsb=pow(2, (log2_max_pic_order_cnt_lsb_minus4 + 4) 

  1. @0表示delta_pic_order_cnt[0]和 delta_pic_order_cnt[1] 都在片头出现 

  1. @offset_for_non_ref_pic   被用来计算非参考帧或场的 POC,本句法元素的值应该在[pow(-2, 31)  , pow(2, 31)  – 1]。   

  1. @ // offset_for_top_to_bottom_field  被用来计算帧的底场的 POC,  本句法元素的值应该在[pow(-2, 31)  , pow(2, 31)  – 1]。   

  1. @num_ref_frames_in_pic_order_cnt_cycle  被用来解码POC, 本句法元素的值应该在[0,255]。 

  1. @num_ref_frames   指定参考帧队列可能达到的最大长度,解码器依照这个句法元素的值开辟存储区,这个存储区用于存放已解码的参考帧,H.264 规定最多可用 16 个参考帧,本句法元素的值最大为 16。值得注意的是这个长度以帧为单位,如果在场模式下,应该相应地扩展一倍。  

  1. @gaps_in_frame_num_value_allowed_flag  这个句法元素等于 1 时,表示允许句法元素 frame_num 可以不连续。当传输信道堵塞严重时,编码器来不及将编码后的图像全部发出,这时允许丢弃若干帧图像。  

  1. @pic_width_in_mbs_minus1  本句法元素加 1 后指明图像宽度,以宏块为单位: PicWidthInMbs = pic_width_in_mbs_minus1 + 1 通过这个句法元素解码器可以计算得到亮度分量以像素为单位的图像宽度: PicWidthInSamplesL = PicWidthInMbs * 16  

  1. @ pic_height_in_map_units_minus1   本句法元素加 1 后指明图像高度: PicHeightInMapUnits = pic_height_in_map_units_minus1 + 1   

  1. @frame_mbs_only_flag   本句法元素等于 0 时表示本序列中所有图像的编码模式都是帧,没有其他编码模式存在;本句法元素等于 1 时  ,表示本序列中图像的编码模式可能是帧,也可能是场或帧场自适应,某个图像具体是哪一种要由其他句法元素决定。 

  1. @mb_adaptive_frame_field_flag   指明本序列是否属于帧场自适应模式。mb_adaptive_frame_field_flag等于1时表明在本序列中的图像如果不是场模式就是帧场自适应模式,等于0时表示本序列中的图像如果不是场模式就是帧模式。 

  1. @direct_8x8_inference_flag    用于指明 B 片的直接和 skip 模式下运动矢量的预测方法。 

  1. @frame_cropping_flag   用于指明解码器是否要将图像裁剪后输出,如果是的话,后面紧跟着的四个句法元素分别指出左右、上下裁剪的宽度。   

  1. @ 指明 vui 子结构是否出现在码流中,vui 用以表征视频格式等额外信息。  

 

 

 

  1. Start dumping PPS: 

  1. @pic_parameter_set_id指明了在切片头中对应的某个psp.pic_parameter_set_id的值应该在0到255,包括0和255 

  1. @set_parameter_set_id表示激活的sps.seq_parameter_set_id应该取值在0到31之间,包括边界值. 

  1. @entropy_coding_mode_flag决定了在解码方法上使用的方法. 

  1. 如果entropy_coding_mode_flag为0的话,就使用Exp-Golomb编码方法 

  1. 如果entropy_coding_mode_flag为1的话,就使用CABAC方法. 

  1. @pic_order_present_flag等于1表示在切片头中图像顺序值存在,pic_order_present_flag为0表示切片头中的图像顺序值不存在 

  1. @num_slice_groups_minus1加上1表示一个图像中的切片组数目.当num_slice_groups_minus1为0时,图象所有的切片属于同一组. 

  1. @slice_group_map_type表示从切片组单到切片组的映射方法.slice_group_map_type的值可以取0到6.   0表示插值切片组. 

  1. @指明了参考图像列表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. 

  1. @num_ref_idx_l1_active_minus1与num_ref_idx_l0_active_minus1有相同的语义,只不过它是针对列表1来说的. 

  1. @weighted_pred_flag=0表示加权预测在P和SP切片中没有被使用 

  1. weighted_pred_flag=1表示加权预测在P和SP切片中有使用. 

  1. @weighted_bipred_idc=0表示默认的加权预测被应用到B切片中. 

  1. weighted_bipred_idc=1表示外部的加权预测被应用到B切片中. 

  1. weighted_bipred_idc=2表示内部的加权预测被应用到B切片中. 

  1. weighted_bipred_idc的取值为0,1,2. 

  1. @指出了对于每个切片来说的SliceQPY的初始值减26.初始值在切片层中当非0的slice_qp_delta被解码后时改变,在非0的mb_qp_delta值被在宏块层解码时再次被改变.pic_init_qp_minus26应该取-26到+25. 

  1. @pic_init_qs_minus26指出了对于SP或SI切片中的SliceQSY的被始值减26.这个初始值在切片层中当一个非0的slice_qs_delta被解码的时候被修改.pic_init_qs_minus26的取值为-26到25. 

  1. @chroma_qp_index_offset表示在查QPC表时,对于QPY和QSY应该加上的偏移量.chroma_qp_index_offset取值为-12到12 

  1. @deblocking_filter_control_present_flag=1表示在切片头处用来控制解块滤波的特征值是存在的. 

  1. deblocking_filter_control_present_flag=0表示在切片头处用来控制解块滤波的特征值是不存在的. 

  1. @constrained_intra_pred_flag=0表示在帧内预测的时候允许剩余数据和邻近宏块解码采样. 

  1. constrained_intra_pred_flag=1表示在受限的帧内预测,对宏块预测中使用帧内宏块预测模式只使用剩余数据和从I和SI宏块类型中的解码采样值. 

  1. @redundant_pic_cnt_present_flag=0表示redundant_pic_cnt在切片头中,数据分区B和数据分区C中不存在. 

  1. redundant_pic_cnt_present_flag=1表示redundant_pic_cnt在所有切片头中,数据分区B和数据分区C中存在. 

  1. @如果transform_8x8_mode_flag为1,则代表亮度宏块以及4:4:4的色度宏块会采用8x8的DCT,此时亮度宏块以及4:4:4的色度宏块的滤波边界会把宏块分割成8x8的块。 

  1. @0表示SPS中不存在修改scaling_list的参数。 

  1. @chroma_qp_index_offset表示在查QPC表时,对于QPY和QSY应该加上的偏移量.chroma_qp_index_offset取值为-12到12 

 

 

这篇关于SDP PPS SPS分析(spsparser)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/328844

相关文章

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1