Skip to content

Real-CUGAN super resolution plugin for VapourSynth implemented with ncnn library

License

Notifications You must be signed in to change notification settings

FLAV1N/VapourSynth-RealCUGAN-ncnn-Vulkan

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

VapourSynth-RealCUGAN-ncnn-Vulkan

Build Status

Real-CUGAN (Real Cascade U-Nets) super resolution for VapourSynth, based on realcugan-ncnn-vulkan. Some code is from vapoursynth-waifu2x-ncnn-vulkan.

Real-CUGAN is designed for anime. More information about Real-CUGAN can be found at Real-CUGAN.

Usage

core.rcnv.RealCUGAN(clip clip, [int scale, int noise, int model, 
                    int tilesize_x, int tilesize_y, int prepadding, 
                    bool tta, int syncgap, int gpu_id, int gpu_thread])

Models should be located in folder models, and folder models should be located in the same folder as dynamic link library.

Parameter description

  • clip

    • Required parameter.
    • Clip to process.
    • Only 32bit RGB is supported.
  • scale

    • Optional parameter. Default: 2.
    • Upscale ratio.
    • Value range: 2, 3, 4.
  • noise

    • Optional parameter. Default: 0.
    • Denoise level.
    • Value range: -1, 0, 1, 2, 3.
      • Higher level means stronger denoise. noise = -1 means no effect.
      • When scale = 3 or scale = 4, noise = 1 and noise = 2 are not supported.
  • model

    • Optional parameter. Default: 1.
    • Select pre-trained model.
    • Value range: 0, 1, 2.
      • model = 0: models-nose. Only support scale = 2 and noise = 0.
      • model = 1: models-se.
      • model = 2: models-pro.

    The models and their supported upscale ratio and denoise level are shown in the list below.

  • tilesize_x

    • Optional parameter. Default: 0 (when scale = 3 or 4 and tta = True, default: 100).
    • The tilesize for horizontal.
    • Value range: >= 32 or 0.
      • tilesize_x = 0 means setting automatically according to the video size.
      • When scale = 3 or 4 and tta = True, please set small value to make sure the plugin run normally.
  • tilesize_y

    • Optional parameter. Default: same as tilesize_x.
    • The tilesize for vertical.
    • Value range: >= 32 or 0.
      • tilesize_y = 0 means setting automatically according to the video size.
      • When scale = 3 or 4 and tta = True, please set small value to make sure the plugin run normally.
  • prepadding

    • Optional parameter. Default: 18 (2x scale), 14 (3x scale), 19 (4x scale).
    • Pre-padding. If don't have experience for training model, please keep it.
  • tta

    • Optional parameter. Default: False.
    • TTA switch.
    • If true, quality will be improved, but speed will be significantly slower.
  • syncgap

    • Optional parameter. Default: 2.
    • Sync Gap. Reduce the impact of image blocking. It's a trade-off between speed and quality.
    • Value range: 0, 1, 2, 3.
      • syncgap = 0: without process for sync gap (fast).
      • syncgap = 1: lossless (slow).
      • syncgap = 2: some loss for background, less loss for texture (middle).
      • syncgap = 3: more loss for background, less loss for texture (fast).

Support list

Parameters scale = 2
(model-nose)
scale = 2
(model-se)
scale = 2
(model-pro)
scale = 3
(model-se)
scale = 3
(model-pro)
scale = 4
(model-se)
noise = -1 ✔️ ✔️ ✔️ ✔️ ✔️
noise = 0 ✔️ ✔️ ✔️ ✔️ ✔️ ✔️
noise = 1 ✔️
noise = 2 ✔️
noise = 3 ✔️ ✔️ ✔️ ✔️ ✔️

Compilation

Windows

1.Install Vulkan SDK.

2.If your VapourSynth is installed in C:\Program Files\VapourSynth , you can run the following command directly. Otherwise use cmake -G "NMake Makefiles" -DVAPOURSYNTH_INCLUDE_DIR=Path/To/vapoursynth/sdk/include/vapoursynth .. in the second-to-last step.

git clone --recursive https://github.com/Kiyamou/VapourSynth-RealCUGAN-ncnn-Vulkan.git
cd VapourSynth-RealCUGAN-ncnn-Vulkan

mkdir build && cd build
cmake -G "NMake Makefiles" ..
cmake --build .

Linux

1.Install Vulkan SDK and add to path.

2.If your VapourSynth is installed in usr/local , you can run the following command directly. Otherwise use cmake -DVAPOURSYNTH_INCLUDE_DIR=Path/To/vapoursynth .. in the second-to-last step.

git clone --recursive https://github.com/Kiyamou/VapourSynth-RealCUGAN-ncnn-Vulkan.git
cd VapourSynth-RealCUGAN-ncnn-Vulkan

mkdir build && cd build
cmake ..
cmake --build .

Windows and Linux using Github Actions

1.Fork this repository.

2.Enable Github Actions on your fork: Settings tab -> Actions -> General -> Allow all actions and reusable workflows -> Save button.

3.Edit (if necessary) the file .github/workflows/CI.yml on your fork modifying the environment variables Vulkan SDK and/or VapourSynth versions:

env:
  VULKAN_SDK_VERSION: <SET_YOUR_VERSION>
  VAPOURSYNTH_VERSION: <SET_YOUR_VERSION>

4.Go to the GitHub Actions tab on your fork, select CI workflow and press the Run workflow button (if you modified the .github/workflows/CI.yml file, a workflow will be already running and no need to run a new one).

When the workflow is completed you will be able to download the artifacts generated (Windows and Linux versions) from the run.

Download Nightly Builds

GitHub Actions Artifacts ONLY can be downloaded by GitHub logged users.

Nightly builds are built automatically by GitHub Actions (GitHub's integrated CI/CD tool) every time a new commit is pushed to the master branch or a pull request is created.

To download the latest nightly build, go to the GitHub Actions tab, enter the last run of workflow CI, and download the artifacts generated (Windows and Linux versions) from the run.

Reference Code

About

Real-CUGAN super resolution plugin for VapourSynth implemented with ncnn library

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 92.2%
  • CMake 7.8%