- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想将 12 位图像信号转换为 HEVC 以进行有效压缩。因为我需要能够重建原始的 12 位信号,所以压缩需要是无损可逆的。目前我的数据是 16 位 PNG 文件。
我的第一次尝试是使用 ffmpeg:
ffmpeg -y -framerate 1 -i input.png -c:v libx265 -x265-params "lossless=1" output.mp4
不幸的是,输出是不可逆的。从 mp4 中提取图像时,像素值略有偏差。
ffmpeg -i output.mp4 -vframes 1 reconstructed.png
以下答案建议首先将输入转换为 YUV444 以避免 ffmpeg 的意外行为:Lossless x264 compression
到目前为止,我未能成功将我的 16 位文件转换为 YUV,将其转换为 x256 并在解码时接收到正确的重建。
是否有直接的方法将 16 位图像转换为 HEVC?
最佳答案
我找到了一个有小舍入误差的解决方案:
编码:
基于以下帖子:How to render png's as h.265 12 bit video?
使用可以使用以下编解码器参数:-x265-params lossless=1 -pix_fmt yuv444p12le
用于有损 12 bpc 编码。
通过反复试验,我意识到 12 位数据必须在每个 16 位元素的高 12 位中。您需要将输入像素放大 16 倍才能将数据放在高位。
(缩放 16 相当于将 uint16 元素左移 4)。
要放大像素,您可以使用 colorlevels
视频过滤器:-vf colorlevels=rimax=0.0625:gimax=0.0625:bimax=0.0625
以下命令对单个帧进行编码:
ffmpeg -i input.png -vf colorlevels=rimax=0.0625:gimax=0.0625:bimax=0.0625 -c:v libx265 -x265-params lossless=1 -pix_fmt yuv444p12le output.mkv
解码:
colorlevels
的解决方案,所以我使用了 curves
过滤器:-vf "curves=r='0/0 1.0/0.0625':g='0/0 1.0/0.0625':b='0/0 1.0/0.0625'"
rgb48be
。以下命令解码单个帧(并除以 16):
ffmpeg -i output.mkv -vf "curves=r='0/0 1.0/0.0625':g='0/0 1.0/0.0625':b='0/0 1.0/0.0625'" -pix_fmt rgb48be reconstructed.png
差异:input.png
和 reconstructed.png
之间的最大绝对差异是 4
级。
差异的原因可能是将 RGB 转换为 YUV 并返回时造成的舍入误差。
我使用以下 MATLAB 代码进行测试:
I = imread('peppers.png');
% Build 10 PNG images (used as input).
for i = 1:10
J = insertText(I, [size(I,2)/2-18, size(I,1)/2-36], num2str(i), 'FontSize', 72);
J = imnoise(im2double(J), 'gaussian', 0, 0.01); % Add some noise
J = uint16(round(J*4095)); % Convert to 12 bits range (range [0, 4095])
imwrite(J, sprintf('input%02d.png', i), 'fmt', 'png', 'BitDepth', 16, 'Mode', 'lossless'); % Write to PNG file
end
%Encode video file using x265 codec, and 12 bits YUV444 format.
[status, cmdout] = system('ffmpeg -y -i input%02d.png -vf colorlevels=rimax=0.0625:gimax=0.0625:bimax=0.0625 -c:v libx265 -x265-params lossless=1 -pix_fmt yuv444p12le output.mkv');
if (status ~= 0), disp(cmdout);end
% Decode output.mkv into 10 PNG image files
[status, cmdout] = system('ffmpeg -y -i output.mkv -vf "curves=r=''0/0 1.0/0.0625'':g=''0/0 1.0/0.0625'':b=''0/0 1.0/0.0625''" -pix_fmt rgb48be reconstructed%02d.png');
if (status ~= 0), disp(cmdout);end
% Compare input and output:
for i = 1:10
I = imread(sprintf('input%02d.png', i));
J = imread(sprintf('reconstructed%02d.png', i));
max_abs_diff = max(max(max(imabsdiff(I, J))));
disp(['max_abs_diff = ', num2str(max_abs_diff)]);
end
使用灰度格式:
使用灰度时,不需要将像素格式转换为 YUV。
从灰度转换为 YUV444 会将输入数据的大小乘以 3,因此最好避免转换。
以下命令对单个灰度帧进行编码:
ffmpeg -i input.png -vf "curves=all='0/0 0.0625/1.0'" -c:v libx265 -x265-params lossless=1 -pix_fmt gray12le -bsf:v hevc_metadata=video_full_range_flag=1 output.mkv
以下命令解码单个灰度帧(并除以 16):
ffmpeg -i output.mkv -vf "curves=all='0/0 1.0/0.0625'" -pix_fmt gray16be reconstructed.png
最大绝对差为 2。
关于使用 -bsf:v hevc_metadata=video_full_range_flag=1
的注意事项:
在H.265中,Y颜色 channel 的默认范围是“有限范围”。
对于 8 位,“有限范围”适用 [16, 235]。
对于 12 位,“有限范围”适用 [256, 3760]。
当使用“全范围”[0, 255] 表示 8 位或 [0, 4095] 表示 12 位时,您需要在流的元数据中指定它。
使用 FFmpeg 设置元数据的方法是使用 bitstream filter .
关于ffmpeg - 将 16 位灰度 PNG 转换为 HEVC/x265,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66155414/
我正在尝试使用 HEVC HM 引用代码来解码有损失的可扩展 HEVC 文件。但是,在没有损失的情况下,解码器似乎运行良好,但是当我尝试解码损坏的文件(在基本和/或增强数据包中遇到一些损失)时,解码器
容器中的 h.264/HEVC(mp4、mkv....)和 h.265/HEVC 附件 B 原始文件有什么不同?我的意思是关于编解码器、像素格式以及为什么 hevc 附件 B 不能包含音频流? 我研究
有没有办法解析 HEVC 比特流文件? 我希望能够创建一个新的比特流文件,其中选择了从原始比特流文件中选择的最终单位数据包。 编辑:我插入了我的代码。请找到我的比特流文件 here . #librar
我使用 HM-12.0 引用代码创建了一个基本二进制流。所以输出是一个 HEVC 编码的 bin 流(比如 input.bin)。 我有一项任务涉及读取此基本流的 header 。也就是说,我需要从
我正在研究 FFMPEG 中集成的 HEVC 解码器。我实际上是在尝试了解它的流程和工作原理。 我所说的流程是指代码中读取输入 .bin 文件的各种参数的部分。比如它在哪里读取分辨率,它在哪里决定它需
我有一个 HEVC 编码的比特流(.bin 和等效的 .mp4 文件)。我想从比特流中删除一些帧,以查看在丢失特定帧时解码器(或媒体播放器)的行为。 enter image description h
我正在尝试使用 ffmpeg 处理来自 USB 网络摄像头的流式视频数据。该过程涉及将原始数据编码为 hevc 格式。到目前为止,我能够做到。 但现在,我想以 10 秒为单位对处理后的数据进行切片并将
我使用此代码对 .hevc 视频进行编码: ffmpeg -i video.mp4 -vf "scale=650:-1" -c:v libx264 -pix_fmt yuv420p -b:v 150
我想获取 HEVC HM 解码器上的 CU/PU 级别信息。我还想获得一些统计数据,以了解解码不同类型的 CU(帧内、帧间 - 单向/双向)平均需要多少时间。 HM 编码器中现有的调试是不合适的,因为
我尝试使用 AVAssetWriter 将 H264 视频转码为 HEVC,但在 iPhone 6s 上失败了。据推测,iPhone 6s 支持 HEVC 进行转码,而不是实时视频编码。相同的代码适用
有谁知道解码 HEVC 时 Android MediaCodec 支持的分辨率是多少? 通过反复试验,我发现以下工作: 640x272 720x304 960x400 1280x528 1920x80
Win10 在很多方面都做得挺出色,例如自带的视频播放器,就一改之前不中用也不中看的作风,无论是功能还是性能都可圈可点。然而 Win10 的视频播放器也有一个硬伤,那就是在默认情况下,可能是不支持
我正在使用带有 ffmpeg(版本 2.7.2)的 HEVC 编解码器。由于我无法编写单行命令来读取/保存每个 CU 和帧的量化变换系数,我想知道是否有人可以帮助我修改 libavcodec 库中的原
我想知道适用于 iOS 的 Apple Video Encoder 是否支持 hevc (h265) 编解码器的无损压缩?如果是,它的压缩设置是什么? 最佳答案 而某些实现 have a lossle
我在解码 HEVC 时遇到问题使用 avcodec 编码的视频。 修改源代码的一行允许解码mpeg1这不是我需要的。 谢谢 #include #include #include #include
FFMPEG v2.1 及更高版本提供对 HEVC 解码的支持。我尝试了一个基本的输入 bin 流作为它的输入,是的,我得到了一个相应的 YUV 文件。 现在我的问题是,由于我只是将基本流作为输入传递
我尝试将 HEVC 4k 广播转码为 1080p H264。 HEVC 4K 到 HEVC 1080p 可以工作,但是当我尝试将 hevc 到 h264 时,我得到“没有找到支持 NVENC 的设备”
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我想将 HEVC 编码文件解码为 YUV 文件。 有什么简单的方法可以做到这一点吗?可执行文件会很好,但我会使用易于编译的源代码。 最佳答案 就这么简单(引导假定的 Linux,根据您的需要进行调整)
所以这个问题已经被问过几次了,但我认为我的 C++ 技能太缺乏,无法真正理解答案。我需要的是一种从 HEVC 编码视频开始到具有所有运动 vector 的 CSV 结束的方法。到目前为止,我已经编译并
我是一名优秀的程序员,十分优秀!