VVC/H.266 VTM10.0 代码阅读记录 (1. nal_unit_type 与 帧类型)

2023-10-30 22:59

本文主要是介绍VVC/H.266 VTM10.0 代码阅读记录 (1. nal_unit_type 与 帧类型),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

从2019年12月后,由于先后两段实习,没有认真跟过最新的标准和代码,感觉落下挺多东西。
接下来的一段时间,没有了秋招和paper的压力,下定决心重新整理和学习一下视频编解码的东西,包括VVC、AVS3和X264,有时间再看一下AV1。
在此系列,记录一下VVC的学习心得以及VTM10.0的代码阅读记录(可能会比较乱,博客主要是当成草稿纸使用)。

在之前发的博客里面,总结过 NALU提取 和 non-VCLU解码 两部分代码和内容。

VVC/H.266代码阅读(VTM8.0)(一. NALU提取)
VVC/H.266代码阅读(VTM8.0)(二. non-VCLU解码)

但是,现在回顾博客,针对 nal_unit_type 和 帧类型 这块,并没有学习记录也没有理解透彻,现在根据 draft 记录一下这部分的学习内容。
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

nal_unit_type 指定了 NALU 的类型。应遵循以下规则:

① 对于一个 subpicture 的所有 VCL NAL,nal_unit_type 应该是相同的。
② PPS 里面有一个 pps_mixed_nalu_types_in_pic_flag。该值等于0时,指定引用PPS的每个图片有一个或多个VCL NAL单位,并且引用PPS的每个图片的VCL NAL单位具有相同的nal_unit_type值。该值等于1时,指定引用PPS的每个图片有一个以上的VCL NAL单元,并且VCL NAL单元不具有相同的nal_unit_type值。
③ 如果 pps_mixed_nalu_types_in_pic_flag 等于0, 一幅图像的所有 VCL NAL 单元的 nal_unit_type应当相同的。如果 pps_mixed_nalu_types_in_pic_flag 等于1: ① 图片最少有两个 subpictures。 ② 图片的 VCL NAL 单元应该有两个或更多不同的nal_unit_type 值。③ 图片中没有 nal_unit_type 等于 GDR_NUT 的 VCL NAL 单元。④ 当图片的一个 VCL NAL 单位有nal_unit_type 等于 nalUnitTypeA (IDR_W_RADL, IDR_N_LP或CRA_NUT),图片的其他 VCL NAL 单位 nal_unit_type 都等于 nalUnitTypeA 或 TRAIL_NUT。
④ IRAP 或 GDR AU 中的所有图片的 nal_unit_type 的值应该是相同的。

下表就是 nal_unit_type 对应的 NALU的类型。下面的叙述不区分 picture 和 subpicture,一律用 帧/图像 来统一描述。

在这里插入图片描述

  • 0 - 3,7 - 10 对应的是VCLU,负责高效的视频内容表示。

  • 12 - 25 对应的是non-VCLU,是一些参数集或者信息内容。

  • 0 - 1 后置图像,2 - 3 前置图像,7 - 10 IRAP 帧内随机接入点图像。

  • 0 Trail 是后置接入图像,解码顺序和显示顺序都在 IRAP 和 GDR 帧之后。Trail 图像可以参考相关联的 IRAP 和 GDR 图像以及他们的相关联的后置图像,不可以参考其前置图像或者相关联的非后置图像。

如下图的B33、B34、B35就是I28的后置图像,其解码顺序和显示顺序都在I28 (CRA图像是IRAP图像的一种) 之后。
在这里插入图片描述

  • 1 STSA 是分布时域子层接入图像。在 STSA 图像编码时,STSA 图像能够从同一层的下一层向上切换到包含 STSA 图像的子层。STSA 图像保证 STSA图像自己、同一子层中跟随在此 STSA 之后图像(解码顺序)不参考同层子层超前 STSA 的图像。

① 如下图中的P2就是STSA图像。在P2后,可以从TS0上切换到TS1层,也就说可以保证 “在 STSA 图像编码时,STSA 图像能够从同一层的下一层向上切换到包含 STSA 图像的子层。” 但是,并不可以继续切换到TS2层,因为后面的P3需要参考P1,而P1在P2之前解码,可能是被丢弃。至于可以从TS0切换到TS1,是因为P2无需参考TS1的任何图像,只用参考TS0的图像,而且P2也不用参考在解码顺序中跟随在P2后面的任何TS1子层的图像。
② 此外,其实在P6后,允许TS0直接切换到TS1,乃至更高层TS2。这是因为按照后续参考逻辑来看,TS1乃至TS2层的后续图像都可以找到肯定可以解码的参考图像。在HEVC中,这种图像叫做 STA 图像(时域子层接入图像),但是VVC目前没看到有这个图像的定义。
③ STSA 图像是一种特殊的 Trail 图像。
在这里插入图片描述

  • 2 RADL 是可解码随机接入前置图像。RADL 图像不需要参考任何解码顺序在 IRAP之前的图像。
  • 3 RASL 是跳过随机接入前置图像。RASL 图像需要参考解码器中可能不存在的图像,所以解码器只能跳过这部分图像继续解码处理。

① 前置图像就是指解码顺序在 IRAP 之前,显示顺序在 IRAP 图像之后的图像。
② 如下图的B29和B31就是RADL图像,如果在 I28 (CRA) 随机接入,B29 和 B31 是在 I28 (CRA) 之后进行解码的,但是 B29只参考 I28,B31参考 I28 和 B29,都是可以正常解码的。
③ 如下图的B30就是RASLT图像,B30还需要参考P24,这可能不存在于解码器中,所以B30只能被跳过。
在这里插入图片描述

  • 7 - 8 IDR 即时解码刷新图像,不使用帧间预测,可以是比特流中的首帧或后续帧。在解码顺序上,IDR帧 是 CVS(coded video sequence) 的首帧。IDR帧有两种类型,分别是 IDR_N_LP (8) 和 IDR_W_RADL (7) ,二者都不允许有 RASL 帧。而 IDR_N_LP 不能有前置帧,而 IDR_W_RADL 可以有前置的 RADL 帧。

  • 9 CRA 纯随机接入图像。处于比特流 GOP的第一帧,而且引领开放式GOP,在解码过程中允许参考其他GOP中的图像数据。CRA图像是和相应前置图像有关联的图像。CRA图像的前置图像被允许参考CRA前面的已解码图像。

  • 10 GDR 渐近解码刷新图像,是与IDR相关的一个概念,这是一种特别帧,每个GDR包含一个I-Slice,几个连续的GDR帧可以起到一个I帧相同的作用,但由于GDR帧的大小与P帧接近,因此可以起到平滑码率的作用,减少超大I帧对网络的冲击,减少传输延迟,同时也能起到阻隔错误的作用。GDR是通过P帧内包括I块组的方法来实现渐近刷新。
    在这里插入图片描述

  • 12 OPI 操作点信息,提供解码器的操作点信息。
    在这里插入图片描述

  • 13 DCI 解码能力信息。
    在这里插入图片描述

  • 后面的比较常规,不再赘述。

这篇关于VVC/H.266 VTM10.0 代码阅读记录 (1. nal_unit_type 与 帧类型)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。