[FFmpeg-devel] [PATCH 2/2] libavfi/dnn: add LibTorch as one of DNN backend
Soft Works
softworkz at hotmail.com
Tue May 24 18:29:12 EEST 2022
> -----Original Message-----
> From: ffmpeg-devel <ffmpeg-devel-bounces at ffmpeg.org> On Behalf Of Jean-
> Baptiste Kempf
> Sent: Tuesday, May 24, 2022 4:52 PM
> To: ffmpeg-devel <ffmpeg-devel at ffmpeg.org>
> Subject: Re: [FFmpeg-devel] [PATCH 2/2] libavfi/dnn: add LibTorch as one
> of DNN backend
>
> Hello,
>
> On Tue, 24 May 2022, at 16:03, Fu, Ting wrote:
> > I am trying to add this backend since we got some users who have
> > interest in doing PyTorch model(BasicVSR model) inference with FFmpeg.
>
> I think you are missing my point here.
> We already have 3 backends (TF, Native, OpenVino) in FFmpeg.
> Those are not to support different hardware, but different tastes for
> users, who prefer one API to another one.
It's not just about taste. Many models can only work with a specific
backend and converting is often between difficult and impossible.
> Where does it end? How many of those backends will we get? 10?
From my pov, the best solution not only for this but also for other
use cases would be - as suggested a while ago - a plug-in model
for filters.
> What's the value to do that development inside ffmpeg?
That's connected to my question about 1-way or 2-way interaction
with those APIs.
When it's just about feeding video frames into such APIs, then
there wouldn't be much reason for having this integrated into
ffmpeg.
But as soon as you want to make modifications to video frames,
how could it be implemented otherwise? I mean, none of those
APIs are capable to do video processing like ffmpeg can do.
In any case, there needs to be some way to interact with those
APIs and at both sides, at a certain point, you need to have
uncompressed images to work with, and when that memory could
be shared between ffmpeg and the AI API, it saves memory
and you get rid of encoding/decoding and load/save for
sharing the image between ffmpeg and the AI api.
Also, that kind of integration allows processing with
lower latency, which is crucial when working with
live video.
I've never used it like this, but I'm sure I will.
Kind regards,
softworkz
More information about the ffmpeg-devel
mailing list