【音视频学习】四、深入解析视频技术中的YUV数据存储方式:从原理到实践

文章目录

  • 引言
  • 1. YUV 基础:为什么它比 RGB 更适合视频?
    • 1.1 YUV 与 RGB 的核心区别
    • 1.2 YUV色度下采样简介
  • 2. YUV 的三大存储方式
    • 方式一:平面格式(Planar)
    • 方式二:半平面格式(Semi-Planar )
    • 方式三:打包格式(Packed YUV)
    • 三种存储方式对比:
  • 3. 如何选择合适的 YUV 格式?
  • 4. 总结

引言

在数字视频的世界里,YUV 是一种比 RGB 更高效的颜色表示方法,尤其在视频编码、传输和存储中占据核心地位。然而,YUV 数据的存储方式多种多样,不同的排列格式(如 I420、NV12、YUYV)直接影响着视频处理的性能、兼容性和内存效率。
本文将系统地介绍:

  • YUV 的核心概念与优势
  • YUV 数据的三大存储方式:平面、半平面与打包格式
  • 主流格式(I420、NV12、YUYV)的内存布局与访问方法

1. YUV 基础:为什么它比 RGB 更适合视频?

1.1 YUV 与 RGB 的核心区别

  • RGB:直接存储红、绿、蓝三原色,每个像素独立保存三个分量。

    • 优点:直观,适合显示渲染。
    • 缺点:数据冗余,压缩效率低(如 RGB24 每像素占 3 字节)。
  • YUV:将图像分离为 亮度(Y) 和 色度(U/V),利用人眼对亮度敏感、对色度不敏感的特性,通过色度下采样大幅减少数据量。

    • 优点:节省带宽(如 YUV420 比 RGB24 小 50%),更适合视频编码。

1.2 YUV色度下采样简介

格式 采样方式 色度分辨率 压缩率 典型应用
4:4:4 无下采样,YUV全分辨率 与Y相同(100%) 1:1 电影制作、专业调色
4:2:2 水平方向色度减半,垂直方向全保留 水平50%,垂直100% 2:1 广播级视频、ProRes
4:2:0 水平+垂直方向色度均减半 水平50%,垂直50% 4:1 H.264/H.265、流媒体
4:1:1 水平方向色度降为1/4,垂直全保留 水平25%,垂直100% 3:1 部分DV摄像机

:YUV420 是视频编码的主流选择,在画质和压缩率之间取得平衡。

2. YUV 的三大存储方式

YUV 数据在内存中的排列方式主要分为三类,每种方式各有优劣。以下以YUV420格式为主说明:

方式一:平面格式(Planar)

  • 特点

    • 1、Y、U、V 三个分量完全分离,存储在独立的内存区域。
    • 2、色度下采样:U 和 V 的分辨率通常是 Y 的 1/2 或 1/4(如 YUV420)。
    • 3、适用场景:软件编码(FFmpeg/x264)、跨平台兼容。
  • 代表格式I420、YV12

    格式 存储顺序 示例应用
    I420(YUV420P) YYYYYYYY UU VV H.264 视频编码
    YV12 YYYYYYYY VV UU 部分旧编解码器
  • 存储结构

    [Y1 Y2 Y3 ...]   (所有Y分量连续存储)
    [U1 U2 ...]      (所有U分量连续存储)
    [V1 V2 ...]      (所有V分量连续存储)
    
  • 内存布局示例(I420,4×4 图像):

    Y 分量:[Y1 Y2 Y3 Y4 Y5 Y6 Y7 Y8 Y9 Y10 Y11 Y12 Y13 Y14 Y15 Y16](16字节)
    U 分量:[U1 U2 U3 U4](4字节,水平/垂直各降采样2倍)
    V 分量:[V1 V2 V3 V4](4字节)
    总大小:16 + 4 + 4 = 24 字节(对比RGB24需要 16×3=48 字节)
    
  • 示意图如下
    在这里插入图片描述

  • 访问方式(C 代码)

    uint8_t *y_plane = frame;          // Y 分量起始地址
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/93055.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/93055.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端项目组成

一、前端项目常见模块及功能(以 Vue/React 通用结构为例) 前端项目的模块本质是「按功能拆分的代码文件/文件夹」,就像盖房子的「砖、梁、窗」各司其职:模块类型功能说明(大白话)举个例子pages(…

聚观早报 | 猿编程推动中美青少年AI实践;华为Pura 80数字版售价公布;iPhone 17 Air电池曝光

聚观早报每日整理最值得关注的行业重点事件,帮助大家及时了解最新行业动态,每日读报,就读聚观365资讯简报。整理丨肖羽7月24日消息猿编程推动中美青少年AI实践华为Pura 80数字版售价公布iPhone 17 Air电池曝光亚马逊收购AI初创公司Bee蜂巢半固…

unittest 案例执行顺序详解

unittest 案例执行顺序详解在 unittest 框架中,测试用例的执行顺序有默认规则,也可通过自定义方式调整。以下是具体说明:一、默认执行顺序规则unittest 对测试用例的执行顺序遵循 “按测试方法名的 ASCII 码排序” 原则,具体逻辑如…

【web大前端】001_前端开发入门:创建你的第一个网页

前端开发入门:创建你的第一个网页 在当今数字化时代,网页已经成为人们获取信息和交流的重要平台。对于想要学习编程的人来说,前端开发往往是一个不错的起点。本文将带你通过简单的两步,创建属于你的第一个网页程序。 点击这里去…

HTTP性能优化终极指南:从协议原理到企业级实践

前言:为什么性能优化是Web开发的生命线?根据Google研究数据,当页面加载时间从1秒增加到3秒时,跳出率提升32%;当达到5秒时,转化率下降90%。本文将通过七层优化体系,带您掌握HTTP性能优化的核心技…

Python 数据分析(二):Matplotlib 绘图

目录 1. 简介2. 绘图 2.1 折线图 2.1.1 单线2.1.2 多线2.1.3 子图 2.2 散点图2.3 直方图2.4 条形图 2.4.1 纵置2.4.2 横置2.4.3 多条 2.5 饼图 1. 简介 Matplotlib 是 Python 提供的一个绘图库,通过该库我们可以很容易的绘制出折线图、直方图、散点图、饼图等丰…

Scrapy分布式爬虫数据统计全栈方案:构建企业级监控分析系统

引言:数据统计在分布式爬虫中的战略价值在分布式爬虫系统中,​​数据统计与分析​​是系统优化的核心驱动力。根据2023年爬虫工程调查报告:实施专业统计方案的爬虫系统性能提升​​40%以上​​数据驱动的优化策略可减少​​70%​​的资源浪费…

计划任务(at和cron命令介绍及操作)

简介计划任务主要做一些周期性的任务,目前最主要的是定期备份数据分类at:一次性调度执行cron:循环调度执行at简介at 是一个用于安排一次性任务的命令行工具,适合在指定时间点执行单次任务语法at 时间 选项若要提交,通过…

[2025CVPR:图象合成、生成方向]WF-VAE:通过小波驱动的能量流增强视频 VAE 的潜在视频扩散模型

论文概述​ 这篇论文提出了一种名为WF-VAE(Wavelet Flow VAE)​的新型视频变分自编码器(Video VAE),旨在解决潜在视频扩散模型(LVDM)中的关键瓶颈问题,包括高计算成本和潜在空间不连续性。WF-VAE利用小波变换(Wavelet Transform)来分解视频信号,并通过能量流路径优…

Map接口-实现类HashMap

目录 一、什么是Map? 二、实现类HashMap 1.关键特点 无序、key唯一、value允许重复、key和value允许为null。 2.数据结构 2.1 JDK 1.7 2.2 JDK 1.8 2.3 关键参数 2.4 关键计算 3.扩容方式 3.1 初始化 3.2 扩容 4.常见方法 4.1 根据key存入value 4.2 …

深入解析Hadoop如何实现数据可靠性:三副本策略、校验和验证与Pipeline复制

Hadoop数据可靠性的重要性在大数据时代,数据可靠性已成为企业数字化转型的生命线。根据IDC预测,到2025年全球数据总量将增长至175ZB,其中企业数据占比超过60%。面对如此庞大的数据规模,任何数据丢失或损坏都可能造成数百万美元的经…

15.6 DeepSpeed+Transformers实战:LLaMA-7B训练效率提升210%,显存直降73%

DeepSpeedTransformers实战:LLaMA-7B训练效率提升210%的底层逻辑与实操指南 当LLaMA-7B的训练显存需求达到78GB时,单卡A100(80GB)几乎濒临溢出,更不用说普通GPU集群。而DeepSpeed与Hugging Face Transformers的深度集成,通过"ZeRO三阶段优化+混合精度+梯度检查点&q…

Nginx + PM2 实现Express API + React 前端 本地测试服务器搭建

一、工具准备 openSSL:需要针对https请求头 生成对应的 自签名证书。 Nginx:服务器搭建工具 nodeJS: Express API运行环境 PM2: node进程管理器。用于替代npm命令管理 启动命令。 二、openSSL 本地自签名证书生成。 创建服务器空文件夹&#xff08…

OTG原理讲解

文章目录一、什么是 OTG(USB On-The-Go)?✅ OTG 的定义:二、传统 USB 与 OTG 的区别三、OTG 的核心机制:**通过 ID 引脚判断角色**1. 对于 Micro-USB OTG:2. 电路如何感知 ID 引脚?四、OTG 电路…

数据结构系列之红黑树

前言 红黑树是比较重要的一颗树了,map和set的底层就是红黑树,一定要牢牢记住。 一、什么是红黑树 首先:红黑树仍然是一颗搜索二叉树,但他引入了颜色这一概念,每个结点多一个存储位来存储颜色,它通过维护下…

在OpenMP中,#pragma omp的使用

在OpenMP中,#pragma omp for 和 #pragma omp parallel for(或 #pragma omp parallel num_threads(N))有本质区别,主要体现在 并行区域的创建 和 工作分配方式 上。以下是详细对比:1. #pragma omp for 作用 仅分配循环迭…

停止“玩具式”试探:深入拆解ChatGPT Agent的技术栈与实战避坑指南

摘要: 当许多人还在用ChatGPT写周报、生成样板代码时,其底层的Agent化能力已经预示着一场深刻的开发范式变革。这不再是简单的“AI辅助”,而是“人机协同”的雏形。本文旨在穿透表面的功能宣传,从技术栈层面拆解Agent模式的实现基…

element-plus安装以及使用

element-plus时为vue.js 3开发的组件库。 在引入前需要做如下准备 安装node.js https://blog.csdn.net/zlpzlpzyd/article/details/147704723 安装vue的脚手架vue-cli https://blog.csdn.net/zlpzlpzyd/article/details/149647351 安装element-plus github地址 https://git…

学习随想录-- web3学习入门计划

#60 转方向 web3 golang 以太坊应用 这是课表部分(Golang以太坊方向) Sheet b站up学习计划 第一阶段:基础能力构建(1-2 个月) 学习目标 掌握 Golang 核心语法与以太坊底层基础概念,建立开发知识框架。…

【RAG优化】PDF复杂表格解析问题分析

在构建检索增强生成(RAG)应用时,PDF文档无疑是最重要、也最普遍的知识来源之一。然而,PDF中潜藏着RAG系统的难点问题——复杂表格。这些表格富含高密度的结构化信息,对回答精准问题至关重要,但其复杂的视觉布局(多层表头、合并单元格、跨页表格等)常常让标准的文本提取…