ffio is not just another Python wrapper of the FFmpeg executable. It directly integrates the FFmpeg C API, and is mainly designed for streaming that specifically deals with raw RGB data.
[Video] [FFIO] [Raw-RGB-Image] [FFIO] [Video]
● ------> (decoding) ------> □
◘
□ -----> (encoding) -------> ●
There are primarily two ways to utilize ffio:
- Decoding: extract images in RGB format from a provided video, either from a local file or a live stream.
- Encoding: encode provided RGB images, write them into a local video file or a live stream.
Naturally, you can chain two ffio.FFio
instances together to facilitate video transformation.
However, if you don't have to do some stuff with raw RGB images, simply
consider using ffmpeg as a more straightforward solution.
Just keep in mind, the main character in ffio are images in raw format
.
- Easy to use: You don't have to tackle the complex video processing problems concerning FFmpeg anymore. Simply follow the examples.
- Stability: Instead of forking a ffmpeg process and exchanging data via pipes, you can now interact directly with ffmpeg's C context in Python runtime.
- Hardware acceleration support: Simply turn
hw_enabled
toTrue
to enable hardware acceleration when creating ffio.Nvidia CUDA
is currently available. - Shared memory support: Interact with image data across multiple processes using shared memory, reducing redundant data copying.(Currently, tests only passed on Linux.)
- Send or recv SEI packets: easy to get access to customized SEI info. See example: encode_frames with SEI for detail.
- accelarate pix_fmt conversion via cuda: pix_fmt conversion(namely yuv->rgb and rgb->yuv) is written in cuda.statistics
- handle gdr video via
flags='showall'
: you can setflags='showall'
in decoder to get rgb frame from a gdr(as opposed to idr) video - Handle non-video data. Audio, or subtitle.
ffio depends on FFmpeg
dynamic linking libraries. So it's necessary to install FFmpeg before ffio.
We provide 3 methods to install ffio.
If you are not familiar with C, and not willing to deal with anything about C:
$ docker pull jionlp/ffio:latest
$ docker run -it jionlp/ffio:latest /bin/bash # run into the container.
$ (in docker container) python
- It takes only two lines of code to run a decoder to extract images from a video.
import ffio
decoder = ffio.FFIO("/path/to/target")
image = decoder.decode_one_frame()
Or, if you wanna build a docker by yourself from a custom GitHub branch:
You can first clone this repo via git, and then build a docker with all libs installed. You do not need to configure compilation params anymore.
$ git clone https://github.com/dongrixinyu/ffio
$ cd ffio
$ docker build -t jionlp/ffio:(your custom version) .
If you wanna run ffio in your host OS, rather than a docker container, you can:
This method is a little bit difficult if you are not familiar with gcc
, make
, cmake
and trivial concerning ffmpeg
compilation.
But if you can configure ffmpeg, python include path, dynamic library path
smoothly, just take a try.
- gcc, make, cmake tools etc.
- ffmpeg>=4.2.0 should have been installed correctly.
- Python>=3.8
- nvcc (if intend to use
hw_enabled
andpix_fmt_hw_enabled
)
-
install FFmpeg from source code - refer to Dockerfile or documents on other websites.
-
install ffio via github + pip
$ git clone https://github.com/dongrixinyu/ffio
$ cd ffio
$ ./compiler.sh [debug|release] # you should configure all kinds of paths according to your OS environment, otherwise you would encounter errors.
$ pip install -e .
Examples of how to use ffio are given in the hyperlinks:
function | description |
---|---|
decode video frames | To grab frames from an online stream or a video file suffixed by mp4 or flv , etc. |
decode video frames to shm | Decoded rgb bytes will be written to SharedMemory. |
encode video frames | To insert frames in Numpy format into a video stream |
encode video frames from shm | Encode rgb bytes from SharedMemory. |
ffio.cuda_is_available()
: returns a bool value, indicating that if cuda is available, and print info of GPU.ffio.available_gpu_memory()
: returns an int value, indicating how much GPU memory is available to use, excluding that been occupied. It is measured inM
(mega) unit. It is helpful for deciding whether to sethw_enabled
toTrue
.