gpt4 book ai didi

ffmpeg - 寻找最快的视频编码器,将网络摄像头流式传输到 ipad

转载 作者:行者123 更新时间:2023-12-04 00:15:15 24 4
gpt4 key购买 nike

我正在寻找编码网络摄像头流的最快方法,该流将在 html5 视频标签中可见。我正在使用 Pandaboard:http://www.digikey.com/product-highlights/us/en/texas-instruments-pandaboard/686#tabs-2对于硬件。可以使用gstreamer、cvlc、ffmpeg。我将使用它来驱动机器人,因此视频流中需要的延迟最少。质量不一定很好,也不需要音频。此外,这仅适用于一个客户端,因此带宽不是问题。迄今为止最好的解决方案是使用带有 mpjpeg 的 ffmpeg 给我大约 1 秒的延迟。有更好的吗?

最佳答案

我已经被问过很多次了,所以我会尝试笼统地回答这个问题,而不仅仅是针对 mjpeg。在系统中获得非常低的延迟需要一些系统工程工作以及对组件的理解。

我能想到的一些简单的顶级调整是:

确保编解码器配置为最低延迟。编解码器(尤其是嵌入式系统编解码器)将具有低延迟配置。启用它。如果您使用的是 H.264,它是最有用的。大多数人没有意识到按照标准要求,H.264 解码器需要在显示帧之前对其进行缓冲。 Qcif 最多 16 帧,720p 最多 5 帧。第一帧的输出有很多延迟。如果您不使用 H.264,请确保您没有启用 B 图片。这增加了获取第一张图片的延迟。

由于您使用的是 mjpeg,我认为这对您不太适用。

编码器也会有一个速率控制延迟。 (称为初始化延迟或 vbv buf 大小)。将其设置为提供可接受质量的最小值。这也将减少延迟。将其视为编码器和解码器之间的比特流缓冲区。如果您使用的是 x264,那将是 vbv 缓冲区大小。

一些简单的其他配置: 使用尽可能少的 I 图片(大内期)。
我的图片很大,增加了通过网络发送的延迟。这在端到端延迟在 1 秒或更长范围内的系统中可能不是很明显,但是当您设计需要 100 毫秒或更短的端到端延迟的系统时,这和其他几个方面都会发挥作用。还要确保您使用的是低延迟音频编解码器 aac-lc(而不是 heaac)。

在您的情况下,为了降低延迟,我建议远离 mjpeg 并至少使用没有 B 图片的 mpeg4(简单配置文件)或最好是 H.264 基线配置文件(x264 提供零延迟选项)。您将获得较低延迟的简单原因是您将获得较低的比特率后编码以发送数据并且您可以进入全帧率。如果您必须坚持使用 mjpeg,那么在没有使用开源组件的编解码器和系统提供更高级功能支持的情况下,您可以获得的效果非常接近。

另一方面是将内容传输到显示单元。如果您可以使用 udp,与 tcp 相比,它将大大减少延迟,尽管根据网络条件有时可能会丢失。您提到了 html5 视频。我很好奇您如何对 html5 视频标签进行实时流式传输。

还有其他方面可以调整,我会放在高级类别中,需要系统工程师尝试各种事情

操作系统中的网络缓冲是什么?出于性能原因,操作系统还会在发送数据之前对其进行缓冲。调整它以获得性能和速度之间的良好平衡。

您使用的是 CR 还是 VBR 编码?虽然 CBR 非常适合低抖动,但如果编解码器提供,您也可以使用 capped vbr。

您的解码器可以开始解码部分帧吗?因此,您不必担心在将数据提供给解码器之前对其进行分帧。尽快将数据推送到解码器。

你能做字段编码吗?在输出第一张图片之前将帧编码时间减半。

每当切片可立即通过网络发送时,您可以使用回调进行切片编码吗?

使用了我在上述所有方法中工作过的低于 100 毫秒的延迟系统。有些功能在开源组件中可能不可用,但如果你真的需要它并且有热情,你可以继续实现它们。

编辑:
我意识到你不能为 ipad 流媒体解决方案做很多上述事情,并且由于 hls 也有限制,你可以实现的延迟。但我希望当您需要任何低延迟系统时,它会在其他情况下证明是有用的。

关于ffmpeg - 寻找最快的视频编码器,将网络摄像头流式传输到 ipad,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12020430/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com