- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 cv2
编辑图像并使用 FFMPEG 从帧创建视频。有关更多详细信息,请参阅此帖子。
这些图像是 3D RGB NumPy array
s(形状类似于 [h, w, 3]),它们存储在 Python list
中。
是的,我知道 cv2
有一个 VideoWriter
并且我以前使用过它,但这不足以满足我的需求。
简而言之,它只能使用它附带的FFMPEG
版本,该版本不支持CUDA,并且在生成视频时会占用所有CPU时间,而根本不使用任何GPU时间,输出太大了我不能' t 将许多 FFMPEG 参数传递给 VideoWrite
启动。
我下载了 FFMPEG for Windows 的预编译二进制文件,支持 CUDA here,我使用的是 Windows 10 21H1 x64,我的 GPU 是 NVIDIA Geforce GTX 1050 Ti。
无论如何,我需要弄乱所有找到的参数 here 和 there 以找到质量和压缩之间的最佳折衷,如下所示:
command = '{} -y -stream_loop {} -framerate {} -hwaccel cuda -hwaccel_output_format cuda -i {}/{}_%d.png -c:v hevc_nvenc -preset 18 -tune 1 -rc vbr -cq {} -multipass 2 -b:v {} -vf scale={}:{} {}'
os.system(command.format(FFMPEG, loops-1, fps, tmp_folder, file_name, quality, bitrate, frame_width, frame_height, outfile))
我需要完全使用我下载的二进制文件并指定尽可能多的参数以达到最佳结果。
ffmpeg-python
似乎非常适合这项工作,我什至发现
this :我可以将二进制路径作为参数传递给
run
函数
this
import ffmpeg
import io
def vidwrite(fn, images, framerate=60, vcodec='libx264'):
if not isinstance(images, np.ndarray):
images = np.asarray(images)
_,height,width,channels = images.shape
process = (
ffmpeg
.input('pipe:', format='rawvideo', pix_fmt='rgb24', s='{}x{}'.format(width, height), r=framerate)
.output(fn, pix_fmt='yuv420p', vcodec=vcodec, r=framerate)
.overwrite_output()
.run_async(pipe_stdin=True, overwrite_output=True, pipe_stderr=True)
)
for frame in images:
try:
process.stdin.write(
frame.astype(np.uint8).tobytes()
)
except Exception as e: # should probably be an exception related to process.stdin.write
for line in io.TextIOWrapper(process.stderr, encoding="utf-8"): # I didn't know how to get the stderr from the process, but this worked for me
print(line) # <-- print all the lines in the processes stderr after it has errored
process.stdin.close()
process.wait()
return # cant run anymore so end the for loop and the function execution
但是,我需要将所有这些参数以及可能更多的参数传递给进程,并且我不确定这些参数应该传递到哪里(
stream_loop
应该去哪里?
hwaccel
、
hwaccel_output_format
、
multipass
...?)。
最佳答案
如果您已经知道 FFmpeg CLI 的语法,您可以使用我的 following answer 中的 subprocess 模块。 (语法适用于 FFmpeg CLI)。
使用 ffmpeg-python
时包裹:
-i
之前)都在 input(...)
中部分。 -vf
或 -filter_complex
)链接为 filter(...).filter(...).filter(...)
output(...)
中。部分。 'b:v'
,我们必须使用像 **{'b:v': '0'}
这样的字典符号. .overwrite_output()
相当于-y
. hevc_nvenc
应用 H.265 (HEVC) 编解码器。h264_nvenc
(可能需要不同的参数)。 'bgr24'
(不是 'rgb24'
)因为 OpenCV 使用 BGR 排序。 scale
过滤器,使用 CPU 软件缩放。
scale_cuda
筛选。
scale_cuda
,我们必须使用
hwupload_cuda
将帧从 CPU 内存上传到 GPU 内存筛选。
vsync=0, hwaccel='cuda', hwaccel_output_format='cuda'
.
h264_nvenc
的 Python 代码示例编码和
scale_cuda
过滤器(编写编号的帧进行测试):
import cv2
import numpy as np
import ffmpeg
width, height, n_frames, fps = 640, 480, 50, 25 # 50 frames, resolution 640x480, and 25 fps
out_width, out_height = 320, 240 # Downscale to 320x240 (for example).
output_filename = 'output.mp4'
# Set pix_fmt to bgr24, because OpenCV uses BGR ordering (not RGB).
# vcodec='hevc_nvenc' - Select hevc_nvenc codec for NVIDIA GPU accelerated H.265 (HEVC) video encoding.
# hwupload_cuda - upload the frame from CPU memory to GPU memory before using CUDA accelerated scaling filter.
# scale_cuda - Use CUDA (GPU accelerated) scaling filter
# Use dictionary notation due to arguments with colon.
# Execute FFmpeg sub-process using stdin pipe as input.
process = (
ffmpeg
.input('pipe:', vsync=0, hwaccel='cuda', hwaccel_output_format='cuda', format='rawvideo', pix_fmt='bgr24', s=f'{width}x{height}', r=f'{fps}')
.filter('hwupload_cuda') # https://docs.nvidia.com/video-technologies/video-codec-sdk/ffmpeg-with-nvidia-gpu/
.filter('scale_cuda', w=out_width, h=out_height) # CUDA accelerated scaling filter
.filter('setsar', sar=1) # Keep the aspect ratio
.output(output_filename, vcodec='hevc_nvenc', **{'preset:v': '18', 'tune:v': '1', 'rc:v': 'vbr', 'cq:v': '19', 'b:v': '0'}, multipass=2)
.overwrite_output()
.run_async(pipe_stdin=True, overwrite_output=True)
)
# Build synthetic video frames and write them to ffmpeg input stream (for testing):
for i in range(n_frames):
# Build synthetic image for testing ("render" a video frame).
img = np.full((height, width, 3), 60, np.uint8)
cv2.putText(img, str(i+1), (width//2-100*len(str(i+1)), height//2+100), cv2.FONT_HERSHEY_DUPLEX, 10, (255, 30, 30), 20) # Blue number
# Write raw video frame to input stream of ffmpeg sub-process.
process.stdin.write(img.tobytes())
# Close and flush stdin
process.stdin.close()
# Wait for sub-process to finish
process.wait()
关于python - 如何通过 CUDA 支持将 BGR NumPy 数组直接传递给 FFMPEG,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72782178/
我正在尝试使用 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 专业知识或机器配置,还是两者兼而有之。非常感谢您的意见。
我是一名优秀的程序员,十分优秀!