音视频参数介绍

news/2024/5/20 1:54:56/文章来源:https://blog.csdn.net/cristianoxm/article/details/135025759

一、视频参数概念

  1. 单个视频帧:可以简单地理解成为一张图片

单个视频帧主要的参数概念:

  • 分辨率:

分辨率是指图像或显示器上像素的数量,通常用横向像素数乘以纵向像素数表示。例如,1920x1080 表示宽度为1920像素,高度为1080像素的分辨率分辨率越高,图像就越清晰,但也需要更多的计算和存储资源

  • 像素:

像素是图像的最小单位,是图像中能够单独控制的点。每个像素包含有关颜色和亮度的信息。图像分辨率是通过像素的数量来描述的,更高的分辨率通常意味着图像中包含更多的像素,因此能够呈现更丰富的细节。

  • dpi(Dots Per Inch)

DPI是指每英寸内的像素密度,用于描述打印机、扫描仪或显示器的输出或输入质量。较高的DPI值表示图像或文档具有更高的分辨率,因此更清晰,但也需要更多的打印或存储资源。

  • 色彩空间模型

色彩空间模型是一种描述颜色的系统,定义了颜色如何在数字图像中表示。常见的色彩空间模型包括:

  • RGB(红绿蓝): 使用红、绿、蓝三个颜色通道来表示颜色。
  • YUV(亮度-色度): 使用亮度(Y)和色度(U、V)分量表示颜色。
  • CMYK(青、品红、黄、黑): 用于印刷颜色,包含青、品红、黄、黑四个颜色通道。
  1. 多个视频帧:多个视频帧指的是一系列连续的单个视频帧,这些帧按照一定的顺序排列,形成了视频序列。视频是通过将这些帧以一定的帧率播放而呈现的

多个视频帧的主要参数概念:

  • 帧率(frames per second):

帧率是指每秒播放的视频帧数量,通常用帧数每秒(fps,frames per second)表示。帧率决定了视频的流畅度,更高的帧率通常意味着更流畅的动画效果。常见的帧率包括 24fps、30fps、60fps 等。不同的应用场景可能需要不同的帧率,例如电影通常采用 24fps,而视频游戏通常采用较高的帧率以提供更好的用户体验

  • 播放时间戳(PTS,Presentation Timestamp):

播放时间戳是视频帧在播放时的时间戳,用于确定视频帧在整个视频序列中的播放顺序和时间位置。PTS 表示视频帧何时应该被显示。PTS 的单位通常是毫秒(ms),表示视频帧在视频开始播放后多少毫秒时应该被显示。正确的 PTS 顺序确保了视频帧的正确显示顺序。

  • 码率(Bitrate):

码率是指视频文件中每秒传输的比特数,通常以每秒的比特数或千比特数(bps,kbps,mbps)表示。码率直接影响到视频的质量和文件大小。高码率通常意味着更高的视频质量,但也需要更大的存储空间和更高的带宽进行传输。低码率则可能导致视频压缩和失真。码率实际上是为了限制数据量大小,在直播等流媒体中一般要设置最大码率以限制视频大小,防止客户端宽带不足而卡顿

  • 注意:高帧率和高码率不相关:

高帧率可能导致更多的图像变化,特别是在快速运动的情况下,这可能需要更高的码率来维持图像质量。 高帧率通常需要更高的码率以应对更多的图像变化,以防止动态场景中出现模糊或失真。高码率并不一定需要高帧率。 一段视频可以以较高的码率传输,以保持图像质量,但帧率仍然可以是标准的 24fps 或 30fps

  1. I帧,P帧,B帧,GOP

I帧(关键帧),P帧(预测帧)和B帧(双向预测帧)是视频压缩中常用的三种帧类型,它们共同构成了视频序列的编码结构。这些帧在视频压缩和解压缩中扮演着不同的角色,有助于实现高效的视频存储和传输。

  • I帧(关键帧) I-frame (Key Frame):

I帧是视频序列中的关键帧,它是完整的图像帧,不依赖于其他帧。每个 GOP(Group of Pictures,一组图像)的开始通常是一个I帧。I帧存储了整个图像的信息,是视频解码的起点,也是视频编辑和切割的关键点。由于独立性,I帧对于随机访问和视频编辑是非常重要的。 I帧基本出现在视频画面突变的位置。

  • P帧(预测帧)P-frame (Predictive Frame):

P帧是通过对前向参考帧进行运动估计和补偿得到的帧,只存储图像中发生变化的部分。P帧依赖于前一个I帧或P帧。P帧在压缩中起到了减小文件大小的作用,因为它只存储了相对于前一帧变化的内容。虽然P帧本身不能独立显示,但与前一帧结合后能够还原图像。

  • B帧(双向预测帧)B-frame (Bidirectional Predictive Frame):

B帧是通过对前后两个关键帧或预测帧进行运动估计和补偿得到的帧,同时存储了图像前后两帧之间的变化。B帧通常相对于前后的I帧或P帧都有差异B帧在视频压缩中进一步提高了压缩比,因为它同时利用了前后两帧的信息。然而,由于其依赖于前后两帧,解码时需要确保这两帧已经被解码(所以在直播流的场景下,一般是不生成B帧的,有利于直播的流畅)

  • GOP(Group of Pictures,一组完整的视频帧)

这些帧类型共同构成了视频压缩的基本单元,称为GOP。通过合理使用I帧、P帧和B帧的组合,视频编码器可以实现更高的压缩比,从而降低视频文件的大小,并在有限的带宽条件下更有效地传输视频。
在这里插入图片描述
直播中设置gop和帧率的1-2倍的好处就是,画面不容易花屏,当直播中断后,重新拉取流也能更快的重新播放(因为第一秒必定是I帧,可以减少P帧的计算时间

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

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

相关文章

智能部署之巅:Amazon SageMaker引领机器学习革新

本篇文章授权活动官方亚马逊云科技文章转发、改写权,包括不限于在 亚马逊云科技开发者社区, 知乎,自媒体平台,第三方开发者媒体等亚马逊云科技官方渠道。 (全球TMT2023年12月6日讯)亚马逊云科技在2023 re:Invent全球大…

LeetCode day24

LeetCode day24 今天主打一个快乐happy(▽ʃ♡ƪ),主要是今天写哈夫曼树被经典文件读取坑麻了(为啥绝对路径能读取,相对不行。罢了) 一个中等题,但是咋感觉很小学捏。。。 2177. 找到和为给定整数的三个连续整数 相…

Centos7部署SVN

文章目录 (1)SVN概述(2)SVN与Samba共享(3)安装SVN(4)SVN搭建实例(5)pc连接svn服务器(6)svn图标所代表含义 (1)…

在WPF窗口中增加水印效果

** 原理: ** 以Canvas作为水印显示载体,在Canvas中创建若干个TextBlock控件用来显示水印文案,如下图所示 然后以每一个TextBlock的左上角为中心旋转-30,最终效果会是如图红线所示: 为了达到第一行旋转后刚好与窗口…

分类预测 | Matlab实现DBO-SVM蜣螂算法优化支持向量机的数据分类预测【23年新算法】

分类预测 | Matlab实现DBO-SVM蜣螂算法优化支持向量机的数据分类预测【23年新算法】 目录 分类预测 | Matlab实现DBO-SVM蜣螂算法优化支持向量机的数据分类预测【23年新算法】分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现DBO-SVM蜣螂算法优化支持向量机的…

华为HCIP认证H12-831题库

501、【拖拽题】在BCP/MPLS VPN场景中,如果PE设备收到到达同一目的网络的多条路由时,将按照一定的顺序选择最优路由。请将以下内容按照比较顺序进行排序。 答题格式为: 如 11 22 33 44 答案:【11】【22】【33】【44】 解析&#x…

Linux出击之网络环境设置

Linux中如果想要设置静态IP,这就需要我们进行自己去设置。 首先想知道是否有网络,我们就可以查看我们的网卡信息呀,ping 外网地址试试。 比如, ping www.baidu.com ip addr show, 这两个命令都可以让我们对网络有一个了解。 …

WIFI直连(Wi-Fi P2P)

一、概述 Wifi peer-to-peer(也称Wifi-Direct)是Wifi联盟推出的一项基于原来WIfi技术的可以让设备与设备间直接连接的技术,使用户不需要借助局域网或者AP(Access Point)就可以进行一对一或一对多通信。这种技术的应用…

使用ffmpeg命令进行视频格式转换

1 ffmpeg介绍 FFmpeg 是一个非常强大和灵活的开源工具集,用于处理音频和视频文件。它提供了一系列的工具和库,可以用于录制、转换、流式传输和播放音频和视频。 FFmpeg 主要特点如下: 格式支持广泛:FFmpeg 支持几乎所有的音频和视…

30、卷积 - 参数 stride 的作用

在卷积运算中,还有一个参数叫做 stride,它对卷积的运算以及运算结果影响也很大。 还是先看卷积动图,从图上你能猜到 stride 参数在哪吗? 在卷积操作中,stride 指的是卷积核在滑动过程中每次跳过的像素数量。 stride 决定了卷积核在输入图像上移动的速度。例如,如果 str…

第四章 Django 模板系统

第一章 Django 基本使用 第二章 Django URL路由系统 第三章 Django 视图系统 第四章 Django 模板系统 第五章 Django 数据模型系统(基本使用) 第六章 Django 数据模型系统(多表操作) 第七章 Django 用户认证与会话技术 第八章 Django CSRF防护 文章目录 模板系统模板是什么变量…

STM32在CTF中的应用和快速解题

题目给的是bin文件,基本上就是需要我们手动修复的固件逆向。 如果给的是hex文件,我们可能需要使用MKD进行动态调试 主要还是以做题为目的 详细的可以去看文档:https://pdf1.alldatasheet.com/datasheet-pdf/view/201596/STMICROELECTRONIC…

CentOS 7 源码部署 Nginx

文章目录 1. 概述2. 部署示例2.1 下载和解压 Nginx 源码2.2 安装编译依赖包2.3 编译和安装2.4 启动 Nginx2.5 配置防火墙2.6 设置 Nginx 为系统服务2.7 配置访问 3. 扩展知识 1. 概述 Nginx 是一款高性能的开源 Web 服务器软件,广泛应用于互联网领域。本篇博客将介…

【Flink系列七】TableAPI和FlinkSQL初体验

Apache Flink 有两种关系型 API 来做流批统一处理:Table API 和 SQL Table API 是用于 Scala 和 Java 语言的查询API,它可以用一种非常直观的方式来组合使用选取、过滤、join 等关系型算子。 Flink SQL 是基于 Apache Calcite 来实现的标准 SQL。无论输…

2024年网络安全(黑客)——自学

1.网络安全是什么 网络安全可以基于攻击和防御视角来分类,我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术,而“蓝队”、“安全运营”、“安全运维”则研究防御技术。 2.网络安全市场 一、是市场需求量高; 二、则是发展相对成熟…

深度学习在人体动作识别领域的应用:开源工具、数据集资源及趋动云GPU算力不可或缺

人体动作识别检测是一种通过使用计算机视觉和深度学习技术,对人体姿态和动作进行实时监测和分析的技术。该技术旨在从图像或视频中提取有关人体姿态、动作和行为的信息,以便更深入地识别和理解人的活动。 人体动作识别检测的基本步骤包括: 数…

使用kibana查看es数据

前提 已安装好es还有kibana,启动es及kibana 修改kibana配置文件 在kibana文件中配置es的地址及索引,我的kibana安装在mac端了 修改配置文件 /usr/local/opt/kibana/config/kibana.yml 重启kibana 配置kibana 下面查询数据 例如查询 traceId 为192…

【TES720D-KIT】基于国内某厂商FMQL20S400全国产化ARM开发套件(核心板+底板)

板卡概述 TES720D-KIT是专门针对我司TES720D(基于国内某厂商FMQL20S400的全国产化ARM核心板)的一套开发套件,它包含1个TES720D核心板,加上一个TES720D-EXT扩展底板。 FMQL20S400是国内某厂商电子研制的全可编程融合芯片&#xf…

案例044:基于微信小程序的消防隐患在线举报系统

文末获取源码 开发语言:Java 框架:SSM JDK版本:JDK1.8 数据库:mysql 5.7 开发软件:eclipse/myeclipse/idea Maven包:Maven3.5.4 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序…

Python将已标注的两张图片进行上下拼接并修改、合并其对应的Labelme标注文件(v2.0)

Python将已标注的两张图片进行上下拼接并修改、合并其对应的Labelme标注文件(v2.0) 前言前提条件相关介绍实验环境上下拼接图片并修改、合并其对应的Labelme标注文件代码实现输出结果 前言 此版代码,相较于Python将已标注的两张图片进行上下拼…