This project has been moved here. Check the new repo for the latest updates.
Welcome to CAINAPP 2.0!
CAIN is a very fast interpolation network that doesn't use much vram (Ex: 5GB with fp16 for 8k)!
Cainapp is a gui for cain with some new things like fp16, saving frames on other threads and more! Look at the code!
Unlike previously, Cainapp now runs on CUDA. Fortunately, it runs on the driver-based version, so the only requirements are
- A NVidia GPU that has recently been updated
However, we cannot guarantee that you will have the best experience with lower specced hardware, so we at least suggest getting a GPU with over 2GB of VRAM for at least a decent experience.
-
Download Python 3.9 📥 (https://www.python.org/ftp/python/3.9.2/python-3.9.2-amd64.exe)
-
Install Python 3.9, and remember to select "Add to PATH"
-
In cmd run
pip3 install pyqt5
pip3 install qdarkstyle
pip3 install --pre torch torchvision torchaudio -f https://download.pytorch.org/whl/nightly/cu111/torch_nightly.html
this can need much time ⌚pip3 install tqdm
pip3 install opencv-python
-
Download Ffmpeg 📥 (https://www.gyan.dev/ffmpeg/builds/ffmpeg-git-full.7z)
Extract it and put 📦 ffmpeg.exe (located in the
bin
folder) in the cainapp folder📁 -
Download the model and put it into the cainapp folder📁
-
In cmd, run
cd path/to/cainapp/
thenpython3 main.py
-
Download Python 3.7 📥 (https://www.python.org/ftp/python/3.7.9/python-3.7.9-amd64.exe)
pip3 install pyqt5
pip3 install qdarkstyle
pip install torch==1.2.0+cu92 torchvision==0.4.0+cu92 -f https://download.pytorch.org/whl/torch_stable.html
pip3 install tqdm
pip3 install opencv-python
-
Download Ffmpeg 📥 (https://www.gyan.dev/ffmpeg/builds/ffmpeg-git-full.7z)
Extract it and put 📦 ffmpeg.exe in the cainapp folder📁
-
Download the model and put it into the cainapp folder📁
-
In cmd, run
cd path/to/cainapp/
thenpython3 main.py
-
Select old pytorch model in ai tab
-
Install git
sudo apt install git
-
Clone cainapp
git clone https://github.com/Hubert482/cainapp.git
-
Install python 3 pip
sudo apt install python3-pip
-
In terminal run
pip3 install pyqt5
pip3 install qdarkstyle
pip3 install torch==1.8.1+cu111 torchvision==0.9.1+cu111 torchaudio===0.8.1 -f https://download.pytorch.org/whl/torch_stable.html
this can need much time ⌚pip3 install tqdm
pip3 install opencv-python-headless
sudo apt install ffmpeg
-
Download the model and put it into the cainapp folder📁
-
In terminal, run
cd cainapp/
thenpython3 main.py
Just as a precaution, this code is completely untested on Debian. If you have any feedback, let us know!
-
Install Conda
-
Install the Python version for the non-Kepler GPU first. This will most likely be 3.9.
conda create -n (name) python=3.9
-
Install the Python version for the other GPU. For Kepler, this will be 3.7.
conda create -n (name) python=3.7
-
Continue following the set of instructions for your system, starting from after "install python"
When you wish to switch between the versions you can type in conda deactivate
and it will disable any current Python versions active in a command prompt. Using conda activate (name)
will enable the Python version specified by its nickname.
This process is also used if you have applications that run on different python versions. An example would be cainapp, which requires Python 3.9, and UVR, which requires Python 3.7.
Optional:
How to install tensorRT and torch2trt:
-
install tensorRT: https://docs.nvidia.com/deeplearning/tensorrt/install-guide/index.html
-
git clone https://github.com/Hubert482/torch2trt/ cd torch2trt python3 setup.py install
Converting a model to tensorRT:
-
Download the model converter
git clone https://github.com/Hubert482/cain-tools.git
cd cain-tools
-
Convert your model!
python3 conv_model.py --width {width of model} --height {height of model} --input "{input model path}"
-
Copy
converted.pth
to the cainapp folder and run!If you have some problems with it dm me on discord
hubert#0069
Basically the same as in "how to install" but you need to install 2 more things and do some arranging
pip3 install discord.py
pip3 install requests
Put your token in a file called token.txt
in the main cain directory
Take your model file from before, copy it to a folder named models
, and rename it to stable.pth.
In line 144 of 1.py, set TensorRT=True
if you are using TRT. Otherwse, leave it as False
And run python3 1.py
Sadly, Discord limits the file size to 8MB, so bitrate isn't high and video length is limited. Audio bitrate is also only 69kbps
It's simple to train with colab. However, it tends to not like being connected to the google-provided GPU, so the code listed below is stolen from Hv#3868.
To keep colab connected,
function ConnectButton(){
console.log("Connect pushed");
document.querySelector("#top-toolbar > colab-connect-button").shadowRoot.querySelector("#connect").click()
}
setInterval(ConnectButton,60000);
^ enter this on console (not cell) and keep colab on foreground.
It's not really good to train in colab, due to its limitation. It takes exponentially longer the more videos you have in your training input folder. However, you could subscribe to https://cloud.google.com/gcp, and watch some youtube tutorials how to utilise its resources to colab.
https://drive.google.com/drive/folders/1Pljrfv9xjXPU2fiwvSx-D3nvh7XvOx0I
If you wish to support the project, you can donate to Hubert's patreon here! Hubert's dogecoin and dgb wallets are also listed in the code.
Congratulations! You've read this until the end! We hope that you will have a good experience using cainapp. If you have any questions, and/or want to use the bot without hosting it yourself, join the discord server!
@inproceedings{choi2020cain,
author = {Choi, Myungsub and Kim, Heewon and Han, Bohyung and Xu, Ning and Lee, Kyoung Mu},
title = {Channel Attention Is All You Need for Video Frame Interpolation},
booktitle = {AAAI},
year = {2020}
}