ffmpeg视频编码原理和实战-(4)H264原始码流分析

H.264是一种广泛使用的视频编码标准,它采用一种分层结构,其中最重要的一个层是NAL(网络抽象层)。在H.264编码中,原始码流(bitstream)是由多个NALU(NAL Units)组成的。了解NALU 对于解析和处理H.264视频流非常重要。

NALU(NAL 单元)

NALU 是H.264码流的基本单元,每个NALU包含一个头部和有效载荷。以下是NALU的详细结构和功能:

1. NALU 头部 (Header)

NALU的头部通常由一个字节组成,具体包括以下几个部分:

  • forbidden_​​zero_bit (1 bit):强制为0,如果设置为1,表示码流存在错误。
  • nal_ref_idc (2位) : 指示当前NALU的参考的一部分,数值越大表示的一部分最高。
  • nal_unit_type (5位):指示NALU的类型,不同类型表示不同的语法元素或数据类型。
2. NALU 类型(nal_unit_type)

NALU 类型决定了该单元包含的数据的意义。以下是一些常见的 NALU 类型:

  • 1:非关键帧(Non-IDR切片)
  • 5:关键帧(IDR切片)
  • 6:补充增强信息(SEI,Supplemental Enhancement Information)
  • 7:序列参数集(SPS,Sequence Parameter Set)
  • 8:图像参数集(PPS,Picture Parameter Set)

NALU的封装和传输

H.264 码流的目标是在 NALU 前面设置一个起始码(Start Code),通常是0x000001用来0x00000001标识一个 NALU 的开始。因此,本文对于解析码流中失败的 NALU 非常重要。

示例

下面是一个简单的示例,展示一个包含多个 NALU 的 H.264 码流:

复制代码
... 0x000001 67 ... 0x000001 68 ... 0x000001 65 ...
  • 0x000001表示起始码,用于标识一个新的NALU 的开始
  • 67是序列参数集(SPS)的NALU类型,67(十六进制)转化为二进制是0110 0111,八位NALU头部
  • 68是图像参数集(PPS)的NALU类型
  • 65是关键帧(IDR切片)的NALU类型

总结

NALU 是 H.264 编码标准中的基本单元,包含了视频数据和其他辅助信息。 每个 NALU 由一个头部和有效载荷组成,通过起始码分隔符。在处理 H.264 码流时,解析和理解 NALU 都是关键的步骤

相关推荐
REDcker2 天前
WebCodecs VideoDecoder 的 hardwareAcceleration 使用
前端·音视频·实时音视频·直播·webcodecs·videodecoder
gihigo19982 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
山河君2 天前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa
音视频牛哥2 天前
Android平台RTMP/RTSP超低延迟直播播放器开发详解——基于SmartMediaKit深度实践
android·人工智能·计算机视觉·音视频·rtmp播放器·安卓rtmp播放器·rtmp直播播放器
qq_416276422 天前
通用音频表征的对比学习
学习·音视频
美狐美颜sdk2 天前
Android全局美颜sdk实现方案详解
人工智能·音视频·美颜sdk·视频美颜sdk·美狐美颜sdk
EasyDSS2 天前
私有化部署EasyDSS视频点播能力:全链路视频技术赋能,打造企业级视听新体验
音视频·hls·m3u8·点播技术·智能转码
qq_416276422 天前
DeLoRes——一种通用的音频表征学习新方法(DeLoRes(基于 Barlow Twins 的冗余最小化方法)
学习·音视频
Q_4582838682 天前
从定位到视频:808 + 1078 在各行业的落地实践
音视频
山顶望月川2 天前
实测MiniMax-Hailuo-02:当“开工大吉“变成“无字天书“,国产AI视频模型的能与之不能
人工智能·音视频