VTM 压缩图像初体验记录

2023-10-10 02:10

本文主要是介绍VTM 压缩图像初体验记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

VVC编码程序入门超详细教程——VTM从源码下载到编码CU划分结果可视化_暴躁的豌豆射手的博客-CSDN博客
VTM配置并使用VTM对YUV视频帧进行编解码(基于windows系统)_B gorgeous的博客-CSDN博客
​​​​​​VTM配置并使用VTM对YUV视频帧进行编解码(基于windows系统)_B gorgeous的博客-CSDN博客

 

...其实蛮多的,我随机列几个

POC 时域播放第一帧,

TId(temporal id 时域层序号,一个帧只能参考时域层低于他的帧,不能参考更高层的帧)

27456是整张图像的比特数--总比特数,YUV各自的PSNR值

bpp的话就是这个除以图像大小

第二行Total Frames | 的Bitrate其实就是上面的27456,不过这里是以字节为单位,也就是34.32KB,换成字节再乘以8 就等于 27456

rec.yuv 是编码后的重建帧

str.bin 是编码后的码流

 

使用 ffmpeg 将 yuv 文件转换为 .jpg 文件

 ffmpeg -s 500x333 -pix_fmt yuv444p -i "C:\Program Files\VVCSoftware_VTM-master\VVCSoftware_VTM-master\test\rec.yuv" -vframes 1 "C:\Program Files\VVCSoftware_VTM-master\VVCSoftware_VTM-master\test\dec.jpg"

ffmpeg -s wxh =-pix_fmt yuv444p -i inputfile_path -vframes 1 outputfile_path

使用ffmpeg将原图转换为yuv文件,再使用ffmpeg将其还原会jpg,图像正常 

 

但是,经过vtm压缩后的yuv文件使用ffmpeg没有办法还原回原图

究其原因,在encoder_intra_vtm.cfg文件中,

 那个codec operating bit-depth本来是10位,改成8以后,这件事就解决了。。。

---------------------------

另一个(简单)方法,opencv,cv2.cvtColor(),opencv支持的色彩空间,转换色彩空间只需要一条指令调api

OpenCV: Color Space Conversions

然后新的问题出现了,opencv不支持直接读 yuv文件。。。于是找了半天,大约是按字节文件啥的把YUV格式读进来,然后作为一个数组(图像)输到opencv里去转

这件事实有些麻烦。。。没做

------------文件解释

参照一些vtm压缩blog做的,有一些是写了text.bat文件,然后同时生成了str.bin和recon.yuv

因为参数里包含了解压缩的过程

也看到blog把这两部分分开做,也就是压缩的时候,用EncoderAPP,解压的时候用DecoderAPP 

所以我的文件目录里包括了dec.yuv和rec.yuv

批处理的是用Encoder,然后生成的记录会在enc.txt里

Decoder就会产生decoder对应的文件

总的流程大概是,

1、选择压缩的cfg文件,几种压缩模式,这边是encoder_intra_vtm.cfg

str.bin就是想还原的bitstream的名称,rec.yuv就是重建的,按需更改,不是必要

 最简单的改qp,就是改QP,范围在0-51,数值越大,量化越多,比特率越小,psnr越差。

其余的修改,可能需要更多的编码知识

 还有这个,默认是10。

 在不费脑子的情况下,直接用ffmpeg将yuv转回普通图像格式的话,就把这改回8吧,10的话应该有对应的操作方式,需要进一步的学习

Notes:很多人把测试序列的cfg内容沾到这儿来,实测,不需要

2、压缩序列cfg

在per-sequence里给了一些参考的cfg

我把图像从jpg通过ffmpeg转到了yuv444p下,所以参考的是 Doc_444.cfg

 

如图,把这个复制到那个test的文件夹下,InputFile后面改成待压缩Yuv路径

后面的只用改FramesToBeEncoded(我这里是图像,所以就是1)其他不用动,这个才对应EncoderAPP属性里的内容

3、EncoderAPP 属性

 就是说不用把测试序列里的内容粘到encoder_intra_vtm里面去,粘过去的话,这个属性设置就不适用了

这篇关于VTM 压缩图像初体验记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

Node.js学习记录(二)

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

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

学习记录:js算法(二十八):删除排序链表中的重复元素、删除排序链表中的重复元素II

文章目录 删除排序链表中的重复元素我的思路解法一:循环解法二:递归 网上思路 删除排序链表中的重复元素 II我的思路网上思路 总结 删除排序链表中的重复元素 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 图一 图二 示例 1:(图一)输入:head = [1,1,2]输出:[1,2]示例 2:(图

Verybot之OpenCV应用一:安装与图像采集测试

在Verybot上安装OpenCV是很简单的,只需要执行:         sudo apt-get update         sudo apt-get install libopencv-dev         sudo apt-get install python-opencv         下面就对安装好的OpenCV进行一下测试,编写一个通过USB摄像头采

perl的学习记录——仿真regression

1 记录的背景 之前只知道有这个强大语言的存在,但一直侥幸自己应该不会用到它,所以一直没有开始学习。然而人生这么长,怎就确定自己不会用到呢? 这次要搭建一个可以自动跑完所有case并且打印每个case的pass信息到指定的文件中。从而减轻手动跑仿真,手动查看log信息的重复无效低质量的操作。下面简单记录下自己的思路并贴出自己的代码,方便自己以后使用和修正。 2 思路整理 作为一个IC d

SSM项目使用AOP技术进行日志记录

本步骤只记录完成切面所需的必要代码 本人开发中遇到的问题: 切面一直切不进去,最后发现需要在springMVC的核心配置文件中中开启注解驱动才可以,只在spring的核心配置文件中开启是不会在web项目中生效的。 之后按照下面的代码进行配置,然后前端在访问controller层中的路径时即可观察到日志已经被正常记录到数据库,代码中有部分注释,看不懂的可以参照注释。接下来进入正题 1、导入m

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位 一、背景二、定位问题三、解决方法 一、背景 flume系列之:定位flume没有关闭某个时间点生成的tmp文件的原因,并制定解决方案在博主上面这篇文章的基础上,在机器内存、cpu资源、flume agent资源都足够的情况下,flume agent又出现了tmp文件无法关闭的情况 二、