GPU视频编解码「建议收藏」

GPU视频编解码「建议收藏」一视频编解码基础1.1识别编码流程视频编解码流程1.2YUV颜色空间YCbCr通常是YUV的同义词,Y为明度(luma),CbCr为色度(chroma),Cb为蓝色分量,Cr为红色分量。颜色空间转换公式:–      RGB转YUV•      y=[0.299,0.587,0.114]*[r,g,b]’•      u=[-0.147,-0.28…

大家好,又见面了,我是你们的朋友全栈君。

视频编解码基础

1.1识别编码流程

GPU视频编解码「建议收藏」

视频编解码流程

1.2 YUV颜色空间

YCbCr通常是YUV的同义词,Y为明度(luma),CbCr为色度(chroma),Cb为 蓝色分量,Cr为红色分量。

颜色空间转换公式:

–      RGB转YUV

•      y = [0.299,0.587,0.114] *[r,g,b]’

•      u = [-0.147,-0.289,0.436] *[r,g,b]’ + 128

•      v = [0.615,-0.515,-0.100] *[r,g,b]’ + 128

–      YUV转RGB

•      r = y + 1.371 * (v-128)

•      g = y – 0.338 * (u-128) – 0.698* (v-128)

•      b = y + 1.732 * (u-128)

 

1.3 YUV采样比例与内存布局

YUV444平面格式:各分量依次连续存储,无交叉

•       采样比例

–      人眼对颜色敏感度低于明度,因此UV分量可被亚采样

–      4:2:0 横向1/2,纵向1/2

–      4:2:2 横向1/2,纵向1/1

•       4:2:0采样下的内存布局

–      I420(IYUV):YUV分别连续存储(右图)

–      YV12:YVU分别连续存储

–      NV12(推荐格式):Y连续存储,UV交错(右图)

–      NV21:Y连续存储,VU交错

 

1.4、H264文件分析

•       帧类型

–      I帧:独立图片

–      P帧:参考前向图片

–      B帧:参考双向图片

•       帧的序号

–      流序号(streamorder):帧在流中的次序。该次序保证每帧的解码只依赖前面已出现的帧

–      显示序号(displayorder):图像正常行进的次序

•       元数据:SPS/PPS

–      包含对流正确解码所需要的元信息

–      如图像大小,采样比例

 

二:NVIDIA GPU 编解码视频

2.1 支持硬件编解码的GPU

•       服务器显卡:GRID系列

–      K1/K2/K340/K520/M60/

–      单GPU编码速度:M60 =2.6 x K340,K340 = 1.5 x K1(单GPU芯片)

•       桌面显卡:Quadro系列

–      K5000/M5000

–      单GPU编码速度:M5000 =M60 = 4 x K5000 (K1)

•       桌面显卡:GeForce系列,编码限并发2路

2.2 视频编解码 GPU API

•       NVENC: 通用的底层API

–      可灵活控制所有编码参数

–      可与CUDA/DX互操作

•       GRID: 游戏视频流化API

–      面向DX/OGL游戏整合

–      接口简单,易于使用

 

 

 

2.3 GPU 硬编码NVENC(已经集成到ffmpeg)

•       输入

–      格式:仅支持YUV平面格式,包括IYUV(I420),YV12, NV12, YUV444

–      载体:主存/CUDA设备内存/D3D9surface

•       输出

–      H264, H265(即HEVC,仅GM2xx芯片支持)

–      载体:主存

NVENC编码H264的编码参数:

•       码率

–      码流的平均每秒比特数

•       码率控制

–      CBR/VBR/CONSTQP

–      QP (体现量化步长)

•       Profile

–      编解码所使用的工具集合

•       预设

 

2.4 GPU视频硬解码NVCUVID

•       支持硬件

–      全部NV显卡,无使用限制

–      单GPU解码速度:GM2xx = 3 x GK1xx

•       输入格式

–      H264, MPEG-2

•       输出格式

–      NV12

2.5 复用和解复用

•       媒体容器格式(mp4;avi;flv;)

•       复用/解复用

•       复用/解复用工具:FFmpeg

 

三、ffmpeg

3.1、ffmpeg

ffmpeg是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。ffmpeg 中只包含了GPU的硬编码,nvenc。

3.2、Nvidia GPU解码

如果需要将GPU的硬解码加入到ffmpeg需要自己编写解码程序nvcuvid,具体编写可参考NV的视频编解码Sample,然后放到目录libavcodec下,并修改部分文件。如下要修改的文件:

•       configure,

•       libavcodec/allcodecs.c

•       libavcode.c/Makefile.c

•       libavfilter/allfilters.c

•       libavfilter/Makefile

 

四、视频测试

4.1性能测试

         GPU性能测试有编码模式有HP,HQ,HP是性能较高,但是图像质量较差,HQ 是性能较差,编码的质量好。

4.2编码质量测试

名词解释:PSNR:峰值信噪比(PSNR),一种评价图像的客观标准,PSNR值越大,就代表失真越少。

目前GPU的硬编码质量与软编码有较大差距。

测试方法:

1、  使用GPU 的sample中的nvenc编码原始的YUV视频,生成H264视频文件。

2、  使用ffmpeg软件解码H264文件生成新的YUV视频文件。

使用软件Elecard测试原始的YUV与新生成的YUV视频文件,得到平均PSNR值。
——————— 
原文:https://blog.csdn.net/Mrhiuser/article/details/50824648 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/158576.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • spring cloud面试题_javaspring面试题

    spring cloud面试题_javaspring面试题Tags:JavaEE,Spring,面试题发表时间:2014-11-2915:03:53原创作品,允许转载,转载时请务必以超链接形式标明文章原始出处、作者信息和本声明。否则将追究法律责任。比如:转自:Su的技术博客 原文地址:https://blog.verysu.com/article/119 这些Spring面试题是从尚硅谷http://www.atguigu.c…

    2022年10月14日
    0
  • 关于软连接的创建_linux设置软连接

    关于软连接的创建_linux设置软连接关于软连接的创建ln的功能是为某一个文件在另外一个位置建立一个同步的链接这个命令最常用的参数是-s,具体用法是:ln-s源文件目标文件。当在不同的目录,用到相同的文件时,可以不需要在每一个需要的目录下都放一个必须相同的文件,只要在某个固定的目录,放上该文件,然后在其它的目录下用ln命令链接(link)它就可以,不必重复的占用磁盘空间。例如:ln-s/bin/hello.sh…

    2022年9月28日
    0
  • substance painter anchor point快速教程

    substance painter anchor point快速教程这个功能方便在substancepainter里通过normal和height实时影响污迹图来做细节但是步骤有些略麻烦,下面作为笔记也作为一个小教程首先需要实时绘制的图层必须在污迹图的下面可以在图层上直接绘制右击加上anchorpoint然后需要被影响的图层或是mask里面的generation,必须开启microDetails如果你需要绘制的高度图影响细…

    2022年10月8日
    0
  • PHP7.4.3 The FastCGI process exited unexpectedly 错误代码0xffffffff 解决办法

    PHP7.4.3 The FastCGI process exited unexpectedly 错误代码0xffffffff 解决办法运行环境:Windows2016数据中心x64+IIS10+PHP7.4.3网页访问php文件显示:TheFastCGIprocessexitedunexpectedly错误代码:0xffffffff运行php-cgi.exe提示”丟失VCRUNTIME140.dll”安装MicrosoftVisualC++2015Redistributable,还是不行命令行运行…

    2022年5月16日
    36
  • ETL数据同步工具Kettle简介

    ETL数据同步工具Kettle简介很多时候,我们需要将一个系统的数据同步到另外一个系统中,两个系统的数据库可能不同,ETL数据同步工具Kettle可能轻松帮我们实现,该功能,而且还可以定时执行数据同步任务。ETL数据同步工具Kettle使用Kettle简介:Kettle是一款国外开源的ETL工具,纯java编写,可以在Window、Linux、Unix上运行,数据抽取高效稳定。Kettle中文名称叫水壶,该项目的主程序

    2022年6月28日
    44
  • Python练手项目之微信机器人、恢复被撤回的微信消息

    Python练手项目之微信机器人、恢复被撤回的微信消息一个python练习项目。基于图灵机器人的微信自动回复工具,对接itchat恢复被撤回的消息。【程序功能】1、实现微信单聊/群聊自动回复。2、恢复被撤回的微信消息(通过手机助手发送到手机微信)【GitHub项目地址】]https://github.com/Liiking/WechatTool(含:源代码及打包好的Mac和Windows桌面应用程序)【下载体验地址】哆啦猫Mac版,…

    2022年6月29日
    35

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号