- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 FPGA 中的几个并行 H.264 基线仅 I 帧编码器内核对相机图像进行编码(需要更多并行内核才能在没有外部存储器的情况下足够快地完成编码)。我使用开源 encoder .在模拟器上,我使用 352x288 yuv420 输入图像并将其切成 2 个水平半部分。
解码器在另一个嵌入式设备上,我可以正确解码分离的切片。但是,我只需要来自一个 H.264 字节流的一个视频序列(包含整个图像),而不是几个解码的视频序列。最好在 FPGA 上合并 H.264 流(而不是通过在嵌入式主机上对解码后的切片视频序列进行后处理)。
因此,输入图像数据如下所示:
.--.-----.--.--.-----.--.
|MB| |MB|MB| |MB|
| 0| ... |10|11| ... |21|
|--. '--|--' '--|
|MB| | |
|22| | |
|--' | |
| Slice | Slice |
| 0 | 1 |
'-----------'----------'
编码器的框图是这样的(只显示了一个编码器核心,没有合并):
YUV420 MacroBlocks (16*16 pixel)
| |
chroma | | luma
| |
.----------------.-------. |
| | | | |
| v v v v
reconstruct intra8x8cc intra4x4 ---> header
^ | | |
| v v |
inv.transform coretransform |
^ | | |
| | v |
dequantise | dctransform |
^ ^ | | |
| | v v |
inv.dc.transform <-'---------- quantise |
| |
v |
buffer |
| |
v |
cavlc |
| |
v |
tobytes <------------'
|
v
H.264 byte stream
来自单个核心的编码 h264 数据(用
H264Naked, 解析,参见
parse.txt 、
ref.yuv420 和
ref.264 )包含 3 个 NAL-s:在第一个中有一个序列参数集,在第二个中有一个图片参数在第三个中设置 IDR 图片的编码切片。 SPS 和 PPS header 是静态的,它们是在主机上生成的。 IDR 报头由 FPGA 上的编码器生成。目前我使用一个恒定的量化参数(即 VBR,但计划实现 CBR,稍后使用可变 QP)。
[h264 @ 0x7f5f0c00ac00] dquant out of range (-112) at 13 1B f=0/0
[h264 @ 0x7f5f0c00ac00] error while decoding MB 13 1
[h264 @ 0x7f5f0c00ac00] concealing 396 DC, 396 AC, 396 MV errors in I frame
使用 JM 引用解码器,我收到此错误(
jm_dec_error.txt):
mb_qp_delta is out of range (-112)
illegal chroma intra pred mode!
我认为问题在于解码器不知道切片并期望来自其他切片的相邻 MB 数据在编码数据中不可用。我已经检查了
standard 中的宏 block 预测语法。 (第 7.3.5.1 章),但我不知道该如何纠正(我对 H.264 知之甚少)。在编码器方面,我看到 intra4x4 和 intra8x8cc 正在使用相邻 MB 预测和来自顶部和左侧 MB 邻居的像素数据(我们在第一 MB 行中没有顶部 MB 邻居,我们在每个 MB 行的第一个 MB,在每个切片中)。
warning: Intra_8x8_Horizontal prediction mode not allowed at mb 0
illegal chroma intra pred mode!
任何帮助表示赞赏。
最佳答案
你不能像那样交错切片数据。从解码器的角度来看,每个切片都应该是一个完整且独立的解码单元,因此解码器可以使用不同的切片解码实例(例如线程)同时解析和解码多个切片。
切片也应该在扫描顺序上是连续的。因此,在您的示例中,您希望水平切割图像(在彼此顶部的两个切片中)而不是垂直切割,然后在第一个切片之后附加第二个切片 - 并修复标题以发出信号正确的框架高度。这应该正确解码。要对更多切片执行此操作,只需将单个切片切小即可。但它们应该始终按扫描顺序连续。
关于ffmpeg - 如何将多个 H.264 流合并为单个 H.264 流,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71048606/
我正在尝试使用 ldash 等选项和 http_opts ,正如 dash muxer 文档所描述的,但 FFmpeg 无法识别它们。我正在使用最新发布的 ffmpeg v4.2.2 版本。我在 ff
假设我们有许多想要与 -vcodec 副本(或等效语法)合并的视频记录。无需重新编码,不会损失质量。并且很少有记录(minor set),有另外的编解码器,参数等等。所以我们可以使用 ffprobe
有没有办法安装 ffmpeg 没有root访问权限?使用 ./configure 无法做到这一点来自 git 克隆 git://source.FFmpeg.org/fFFmpeg.git 最佳答案 是
在应用程序中直接使用 FFmpeg 与使用 Ffmpeg 命令行有什么区别? 最佳答案 没有:FFmpeg 命令行只是一个使用 FFmpeg API 的应用程序。当然,在使用该应用程序时,您仅限于已实
我正在使用以下命令对文件(下面的媒体信息)进行编码: ffmpeg -i AHomeMovie.mkv -map 0 -c copy -c:v libx264 -preset veryslow -cr
我正在制作一张圣诞贺卡,我需要将视频嵌入到右侧(边框内)的卡片中,并在左侧显示一些文本。 为简单起见,假设我有一个带有透明孔的盒子。我想在那个洞里显示视频。 我正在使用 ffmpeg-python很高
我正在使用 laravel ffmpeg 为视频创建缩略图,但是当我运行代码时,它返回给我 Call to undefined method FFMpeg\FFMpeg::fromDisk() 我不知
我为我的 nvidia 下载了 cuda 驱动程序 但它仍然不使用我的 GPU,它仍然使用 cpu。 我怎样才能让它使用GPU。 我也听说过硬件加速,但那不起作用。 它必须是 h.264 最佳答案 你
尝试剪切视频的多个部分时,我遵循此问题的解决方案 Cut multiple parts of a video with ffmpeg .但问题是,如果我剪切多次(比如大约 20 次或更多),视频和音频
所以我最近开始在我打算在商业上分发的应用程序中实现 ffmpeg。而且我很难理解整个许可过程。 我见过的最常回答的问题似乎是关于 x264,它需要 x264.org 的付费许可才能在商业上使用它(对吗
我使用 ffmpeg 更改视频文件的分辨率,转换到另一个位置后,视频持续 0 秒,但最初持续 2 分钟 我的ffmepg代码: ffmpeg -i input.mp4 -filter:v scale=
如上: FFMPEG 不支持在没有第三部分库的情况下加载外部过滤器是否有特定原因? (像弗莱0r) 我必须重新编译整个包来添加一个新的过滤器! 最佳答案 只有开发人员可以肯定地回答,但我会冒安全风险和
我收到了一个编码器,我需要用 FFMPEG 编译,我是新手,所以我不知道如何用 ffmpeg 添加/编译它。编码器是JSV,我的服务器是ubuntu 14.04。 我已经开始阅读这篇 https://
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许在 Stack Overflow 上提出有关通用计算硬件和软件的问题。您可以编辑问题,使其成为
我正在制作一个利用 ffmpeg 重新混合和转码视频文件的程序。我想使用 ffmpeg -codecs和 ffmpeg -formats (或通过 ffmpeg 可用的任何其他命令)来检查我可以在哪些
这个问题在这里已经有了答案: ffmpeg moving text drawtext (1 个回答) 3年前关闭。 我正在使用此命令使用 ffmpeg 将文本从一个地方移动到另一个地方 ffmpeg
为什么 ffmpeg/ffprobe 为流和整个文件提供不同的比特率值? 当我使用 ffprobe 分析 mp3 文件时,它会在第一行和第二行给出不同的比特率。 有谁知道,有什么区别? // File
如何在ffmpeg中使用drawtext在视频上绘制多色文本? 示例:我想突出句子中的专有名词, “XYZ公司股价上涨91%” 高亮 XYZ 白色 黄色 用绿色突出显示 91% 如果您有任何其他方法不
我想让我的不和谐机器人播放音乐,但我不断收到“找不到 FFMPEG”错误。 我的机器人主要是由 ping 制成的,所以我不会上传那部分。音乐代码应该是这个。 const Discord = requi
我需要帮助在 ffmpeg drawtext 过滤器中正确/(完全)显示德语变音符号“äüö”。我现在不能说我的无能是由于缺乏 ffmpeg 专业知识或机器配置,还是两者兼而有之。非常感谢您的意见。
我是一名优秀的程序员,十分优秀!