gpt4 book ai didi

ffmpeg - 使用 FFMPEG 对数据流进行下采样/过滤

转载 作者:行者123 更新时间:2023-12-04 23:19:41 28 4
gpt4 key购买 nike

我们有一个 .ts包含(以及其他流)视频流和符合 MISB 0604 的 KLV 数据流的输入文件。 ffprobe 的输出这些流是:

Stream #0:0[0x111]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(progressive), 1280x720 [SAR 1:1 DAR 16:9], 29.97 fps, 29.97 tbr, 90k tbn, 59.94 tbc
...
Stream #0:2[0x1001]: Data: klv (KLVA / 0x41564C4B)
我们希望将视频的每第 N 帧提取为 .tiff .我们还需要将这些帧中的每一个与来自 MISB 0604 兼容数据流的相应 KLV 数据包相关联。
以下选择过滤器并按相应比率调整原始 FPS 的命令确实会导致将预期帧保存为 TIFF(在这种情况下,原始视频有 1187 帧,我希望从选择过滤器中获得 12 帧)。
ffmpeg -y -i 2205Z.ts -map 0:0 -vf "select='not(mod(n,100))'",fps=30000/1001/100 -compression_algo raw -pix_fmt rgb24 %05d.tif
但是,我似乎无法让任何过滤器处理数据流。例如使用 filter:d不会抛出错误,但似乎也没有实际过滤。我的问题是 ffmpeg可以用来保存对应于上面对视频流执行的下采样操作的“下采样”数据流吗?

最佳答案

使用最近的 git master build,运行ffmpeg -i 2205Z.ts -map 0:2 -bsf "noise=drop=mod(n\,100)" -f segment -segment_format data -segment_time 0.01 %d.bin噪声 bsf 使用表达式删除,而不是选择,即 select=EXPR === drop=not(EXPR) .
添加 -loglevel verbose查看有关保留哪些数据包的详细信息,格式如下:

[noise @ 000001cd418a68c0] Stream #2 packet 1099 pts 3420417 - amount 0 drop 1
[noise @ 000001cd418a68c0] Stream #2 packet 1100 pts 3423419 - amount 0 drop 0
[noise @ 000001cd418a68c0] Stream #2 packet 1101 pts 3426423 - amount 0 drop 1

关于ffmpeg - 使用 FFMPEG 对数据流进行下采样/过滤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69133743/

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