A Python FFI of nihui/rife-ncnn-vulkan achieved with SWIG
Project description
RIFE ncnn Vulkan Python
Introduction
rife-ncnn-vulkan is nihui's ncnn implementation of Real-Time Intermediate Flow Estimation for Video Frame Interpolation.
rife-ncnn-vulkan-python wraps rife-ncnn-vulkan project by SWIG to make it easier to integrate rife-ncnn-vulkan with existing python projects.
Downloads
Linux/Windos/Mac X86_64 binary build releases are available now.
Build
First, you have to install python, python development package (Python native development libs in Visual Studio), vulkan SDK and SWIG on your platform. And then, there are two ways to build it:
- Install source distribution from PyPI (Currently in developing, need to download models before build.)
- Use setuptools to build and install into python package directly.
- Use CMake directly (The old way)
Install from PyPI
pip install rife-ncnn-vulkan-python
Use setuptools
python setup.py install
Use CMake
Linux
git clone https://github.com/ArchieMeng/rife-ncnn-vulkan-python.git
cd rife-ncnn-vulkan-python
git submodule update --init --recursive
cmake -B build src
cd build
make
Windows
I used Visual Studio 2019 and msvc v142 to build this project for Windows.
Install visual studio and open the project directory, and build. Job done.
The only problem on Windows is that, you cannot use CMake for Windows GUI to generate the Visual Studio solution file and build it. This will make the lib crash on loading.
One way is using Visual Studio to open the project as directory, and build it from Visual Studio. And another way is build it from powershell just like what is written in the release.yml
About RIFE
RIFE (Real-Time Intermediate Flow Estimation for Video Frame Interpolation)
https://github.com/hzwer/arXiv2020-RIFE
Huang, Zhewei and Zhang, Tianyuan and Heng, Wen and Shi, Boxin and Zhou, Shuchang
https://arxiv.org/abs/2011.06294
Usages
Example Program
from rife_ncnn_vulkan_python import Rife
from PIL import Image
with Image.open("input0.png") as image0:
with Image.open("input1.png") as image1:
rife = Rife(gpuid=0) # or RIFE(0) like upstream
image = rife.process(image0, image1)
image.save("output.png")
If you encounter a crash or error, try upgrading your GPU driver:
- Intel: https://downloadcenter.intel.com/product/80939/Graphics-Drivers
- AMD: https://www.amd.com/en/support
- NVIDIA: https://www.nvidia.com/Download/index.aspx
Model
model | upstream version |
---|---|
rife | 1.2 |
rife-HD | 1.5 |
rife-UHD | 1.6 |
rife-anime | 1.8 |
rife-v2 | 2.0 |
rife-v2.3 | 2.3 |
rife-v2.4 | 2.4 |
rife-v3.0 | 3.0 |
rife-v3.1 | 3.1 |
rife-v4 | 4.0 |
rife-v4.6 | 4.6 |
Original RIFE Project
Other Open-Source Code Used
- https://github.com/Tencent/ncnn for fast neural network inference on ALL PLATFORMS
- https://github.com/webmproject/libwebp for encoding and decoding Webp images on ALL PLATFORMS
- https://github.com/nothings/stb for decoding and encoding image on Linux / MacOS
- https://github.com/tronkko/dirent for listing files in directory on Windows
- https://github.com/nihui/rife-ncnn-vulkan the original rife-ncnn-vulkan project
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file rife-ncnn-vulkan-python-1.2.1.tar.gz
.
File metadata
- Download URL: rife-ncnn-vulkan-python-1.2.1.tar.gz
- Upload date:
- Size: 22.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2e350dbc9eaefb547efeedd97227e4579dffd75db278323f8fdc77e3931b112b |
|
MD5 | 0e8694e5b4b98a1bbca951f28f7f0885 |
|
BLAKE2b-256 | 7deb95529e003ac6a7de01d10601957320ee6af1fcd6195b762269e81b730fde |