Skip to content

Releases: AmusementClub/vs-mlrt

v15.8: Blackwell support, latest TensorRT and MIGraphX libraries

24 Jan 15:33
Compare
Choose a tag to compare

TRT

  • Upgraded to TensorRT 10.8.0, which adds support for Blackwell GPUs including RTX 50-series.
  • The release archive is split into 2GB volumes (.7z.001, .7z.002).

MIGX

  • Upgraded to MIGraphX 2.12.0 6acc1f9.

General

  • Upgraded to CUDA 12.8.0 and HIP 6.2.4.

vsmlrt.py

  • Added support for ArtCNN v1.2.0 models.
  • Add tiling_optimization_level and l2_limit_for_tiling options to the TRT backend for memory-bandwidth-limited models (docs).

Full Changelog: v15.7...v15.8

v15.7: latest TensorRT libraries, ONNX Runtime and MIGraphX interface improvements

03 Dec 11:03
Compare
Choose a tag to compare

TRT

  • Upgraded to TensorRT 10.7.0.

ORT_DML

  • Fixed blank output for the first returned frame reported by @Mr-Z-2697 in #117

MIGX

ORT_COREML

General

  • Upgraded to CUDA 12.6.3.

vsmlrt.py

  • Added support for RIFE v4.26 heavy model.

Full Changelog: v15.6...v15.7

v15.6: latest TensorRT and OpenVINO libraries

01 Nov 23:35
Compare
Choose a tag to compare

TRT

  • Upgraded to TensorRT 10.6.0.

OV

  • Upgraded to OpenVINO 2024.5.0, which adds support for Xe2 GPU and NPU 4 on Lunar Lake.

MIGX

  • Fix missing precision check.

General

  • Upgraded to CUDA 12.6.2.

vsmlrt.py

  • Added support for RIFE v4.25 lite and heavy models.

Full Changelog: v15.5...v15.6

v15.5: latest TensorRT library, CoreML backend

01 Oct 00:12
Compare
Choose a tag to compare

TRT

  • Upgraded to TensorRT 10.5.0.
  • Volta GPUs (TITAN V, V100) are no longer supported.

ORT

  • Fix MacOS CoreML support for vsort by @yuygfgg in #106.

    This pull request also added theORT_COREML backend to vsmlrt.py.

General

  • Upgraded to CUDA 12.6.1.

vsmlrt.py

  • Added support for RIFE v4.25 and v4.26 models.

  • Added automatic batch inference support via batch_size option in inference() and flexible_inference(), which may improve device utilization for inference on small inputs using some small models.

    • On the one hand, batching improves utilization by creating more work for each kernel invocation and reducing quantization inefficiency of kernel tiles in bulk parallelism. It also reduces average kernel launch and synchronization overhead per work.
    • On the other hand, however, batching causes cache misses and inserts bubbles in the pipeline that may degrade performance.

    This feature requires flexible output support starting with vs-mlrt v15 and is inspired by styler00dollar/VSGAN-tensorrt-docker@ac47012.

    Note that not all onnx models are supported.

    • Future RIFE v2 models will be fixed to support batch inference.

    benchmark:

    • NVIDIA GeForce RTX 4090
    • driver 560.94
    • Windows Server 2019
    • python 3.12.6, vapoursynth-classic R57.A10, vs-mlrt v15.4
    • input: 720x480 RGBS
    • backend: TRT(fp16=True, use_cuda_graph=True)

    Measurements: FPS / Device Memory (MB)

    model batch 1 batch 2
    realesrgan compact (stream 1) 73.01 / 708 138.68 / 950
    realesrgan compact (streams 2) 107.81 / 914 263.87 / 1347
    realesrgan compact (streams 3) 108.30 / 1128 348.23 / 1738
    realesrgan ultracompact (stream 1) 99.43 / 702 165.52 / 950
    realesrgan ultracompact (streams 2) 184.48 / 908 302.56 / 1344
    realesrgan ultracompact (streams 3) 184.69 / 1114 458.18 / 1738

Full Changelog: v15.4...v15.5

v15.4: latest TensorRT library

07 Sep 01:05
Compare
Choose a tag to compare

TRT

  • Upgraded to TensorRT 10.4.0.

General

  • Upgraded to CUDA 12.6.0.

vsmlrt.py

  • Added support for Ani4K-v2 model by @srk24 in #105
  • Added support for RIFE v4.23 and v4.24 models.
  • Add max_tactics option to the TRT backend, which can reduce engine build time by limiting the number of tactics to time.
    • By default, TensorRT will determine the number of tactics based on its own heuristic.

Batch Inference (Preview)

The latest vsmlrt.py (not in v15.4) provides experimental support for batch inference via batch_size option in inference() and flexible_inference(), which may improve device utilization for inference on small inputs using some small models.

This feature requires flexible output support starting with vs-mlrt v15 and is inspired by styler00dollar/VSGAN-tensorrt-docker@ac47012.

Note that not all onnx models are supported.

Preliminary benchmark:

  • NVIDIA GeForce RTX 4090
  • driver 560.94
  • Windows Server 2019
  • python 3.12.6, vapoursynth-classic R57.A10
  • input: 720x480 RGBS
  • backend: TRT(fp16=True, use_cuda_graph=True)

Measurements: FPS / Device Memory (MB)

model batch 1 batch 2
realesrgan compact (stream 1) 73.01 / 708 138.68 / 950
realesrgan compact (streams 2) 107.81 / 914 263.87 / 1347
realesrgan compact (streams 3) 108.30 / 1128 348.23 / 1738
realesrgan ultracompact (stream 1) 99.43 / 702 165.52 / 950
realesrgan ultracompact (streams 2) 184.48 / 908 302.56 / 1344
realesrgan ultracompact (streams 3) 184.69 / 1114 458.18 / 1738

Full Changelog: v15.3...v15.4

v15.3: MIGraphX on Windows

21 Aug 07:23
Compare
Choose a tag to compare

MIGX

  • Add experimental MIGraphX support on Windows. MIGraphX is AMD's graph optimization engine to accelerate machine learning model inference.

    Supported GPUs:

    • gfx1030: Radeon RX 6950 XT, Radeon RX 6900 XT, Radeon RX 6800 XT, Radeon RX 6800, ...
    • gfx1100: Radeon RX 7900 XTX, Radeon RX 7900 XT, ...
    • gfx1101: Radeon RX 7700 XT, ...
    • gfx1102: Radeon RX 7600

    Relevant archives include:

    The MIGraphX runtime in this release uses HIP 6.1.2 and MIGraphX 2.11 (9cf49f9).

    Note that the Windows support has not been officially announced by AMD.

Known limitation

  • The MIGX backend in the vsmlrt.py wrapper does not support device selection and will always use the default device (device_id=0).

General

vsmlrt.py

  • Added support for RIFE v4.22 (lite) models.

Full Changelog: v15.2...v15.3

v15.2: latest TensorRT library

07 Aug 06:42
Compare
Choose a tag to compare

TRT

  • Upgraded to TensorRT 10.3.0.

  • Fixed performance regression of RIFE and SAFA models starting with vs-mlrt v14.test4. This version may still be slightly slower than vs-mlrt v14.test3 under some conditions, however.

General

  • Upgraded to CUDA 12.5.1.

vsmlrt.py

  • Added support for RIFE v4.19 ~ v4.21 models.
  • Added support for ArtCNN R8F64 (chroma) models.
    • Deprecated ArtCNN C4F32 models based on developer's request, but compatibility at the vsmlrt.py level will be guaranteed.

Full Changelog: v15.1...v15.2

v15.1: latest TensorRT library

04 Jul 00:53
Compare
Choose a tag to compare

TRT

  • Upgraded to TensorRT 10.2.0.

  • Add TensorRT release package (vsmlrt-windows-x64-tensorrt). #102

    This package is a strict subset of the CUDA release package, with cuDNN, cuBLAS libraries and support for ORT_CUDA backend removed.

    It supports TRT, OV_*, ORT_CPU, ORT_DML and NCNN_VK backends.

known issue

  • Accoding to the documentation,

    There is an up to 4x performance regression for networks containing "GridSample" ops compared to TensorRT 9.2.

    This affects RIFE and SAFA models.

    vs-mlrt v14.test3 is the latest one that is not affected. This will be fixed in the next release by TensorRT 10.3.0.

General

  • Upgraded to CUDA 12.5.0.

vsmlrt.py

Full Changelog: v15...v15.1

v15: latest TensorRT library

15 Jun 02:11
Compare
Choose a tag to compare

General

plugins

  • Added parameter flexible_output_prop for flexible output:

    Traditionally, all plugins can only support onnx models with one or three output channels, due to vapoursynth's limitation.

    By using the new flexible output feature, plugins can support onnx models with arbitrary number of output planes.

    from typing import TypedDict
    
    class Output(TypedDict):
        clip: vs.VideoNode
        num_planes: int
    
    prop = "planes" # arbitrary non-empty string
    output = core.ov.Model(src, network_path, flexible_output_prop=prop) # type: Output
    
    clip = output["clip"]
    num_planes = output["num_planes"]
    
    output_planes = [
        clip.std.PropToClip(prop=f"{prop}{i}")
        for i in range(num_planes)
    ] # type: list[vs.VideoNode]

    This feature is supported by all plugins starting with vs-mlrt v15.

vsmlrt.py

  • Added support for RIFE v4.17 models.

  • Added support for ArtCNN models optimised for anime content. The chroma variants are not supported on previous versions of vs-mlrt, because they require the flexible output feature.

  • Added function flexible_inference for flexible output:

    The above sample is simplified as

    output_planes = flexible_inference(src, network_path) # type: list[vs.VideoNode]

TRT

  • Upgraded to TensorRT 10.1.0.

known issue

  • Accoding to the documentation,

    There is an up to 4x performance regression for networks containing "GridSample" ops compared to TensorRT 9.2.

    This affects RIFE and SAFA models.

    vs-mlrt v14.test3 is the latest one that is not affected.

Community contributions

Full Changelog: v14...v15

v14: latest libraries

25 Apr 01:01
Compare
Choose a tag to compare

Compared to the previous stable (v13.2) release:

General

vsmlrt.py

  • Plugin invocation order in the get_plugin_path() function is sorted to reduce memory consumption.
  • Added support for RIFE v4.7 ~ v4.16 (lite, ensemble) models.
  • Added support for SCUNet models for image denoising.

TRT

plugin and runtime libraries

  • Upgraded to TensorRT 10.0.1.
  • Maxwell and Pascal GPUs are no longer supported. Other backends still support these GPUs.
  • Reduce GPU memory usage for dynamically shaped engines when the actual tile size is smaller than the maximum tile size set during engine building.
  • Reduced engine build time.
  • Added long path support for engines on Windows.
  • cuDNN is no longer a strict runtime dependency.

vsmlrt.py

  • The cuDNN tactic is no longer enabled by default.
  • TF32 acceleration is disabled by default.
  • The maximum workspace is set to None for the total memory size of the GPU.
  • Add parameters builder_optimization_level, max_aux_streams, bf16 (#64), custom_env, custom_args, short_path and engine_folder (#90):
    • builder_optimization_level: "adjust how long TensorRT should spend searching for tactics with potentially better performance" link
    • max_aux_streams: Within-inference multi-streaming, "if enabled, TensorRT will run some layers on the auxiliary streams in parallel to the layers running on the main stream, ..., may increase the memory consumption, ..." link
    • bf16: "TensorRT supports the bfloat16 (brain float) floating point format on NVIDIA Ampere and later architectures ... Note that not all layers support bfloat16." link
    • custom_env, custom_args: custom environment variable and arguments for trtexec engine build.
    • short_path: whether to shorten engine name.
      • On Windows, this could be useful in addressing the maximum path length limitation, and is enabled by default.
    • engine_folder: used to specify custom directory for engines.

known issues

  • Accoding to the documentation, There is an up to 4x performance regression for networks containing "GridSample" ops compared to TensorRT 9.2.This affects RIFE and SAFA models.

  • trtexec may reports errors like:

    • [E] Error[9]: Skipping tactic 0xded5318b4a444b84 due to exception Cask convolution execution
    • [E] Error[2]: [virtualMemoryBuffer.cpp::nvinfer1::StdVirtualMemoryBufferImpl::resizePhysical::140] Error Code 2: OutOfMemory (no further information)

    This issue has been submitted to NVIDIA.

ORT

  • Upgraded to ONNX Runtime v1.18.0.

interface

  • The ORT_* backends now support fp16 I/O. The semantics of the fp16 flag in these backends is as follows:
    • Enabling fp16 will use a built-in quantization that converts a fp32 onnx to a fp16 onnx. If the input video is of half-precision floating-point format, the generated fp16 onnx will use fp16 input. The output format can be controlled by the output_format option (0 = fp32, 1 = fp16).
    • Disabling fp16 will not use the built-in quantization. However, if the onnx file itself uses fp16 for computation, the actual computation will be done in fp16. In this case, the input video format should match the input format of the onnx, and the output format is inferred from the onnx.

CUDA

  • Reduced execution overhead.
  • Added support for TF32 acceleration. This is disabled by default.
  • Added experimental prefer_nhwc flag to reduce the number of layout transformations when using tensor cores. This is disabled by default.

OV

  • Upgraded to OpenVINO 2024.2.0.
  • Added experimental OV_NPU backend for Intel NPUs.

MIGX

  • Added support for MIGraphX backend for AMD GPUs. Currently this backend is Linux only.

Community contributions

  • scripts/vsmlrt.py: update esrgan janai models by @hooke007 in #53
  • scripts/vsmlrt.py: add more esrgan janai models by @hooke007 in #82
  • vsmigx: allow fp16 input & output by @abihf in #86
  • scripts/vsmlrt.py: fix fp16 precision issues of RIFE v2 representations by @charlessuh in #66 (comment)

Benchmark

NVIDIA GeForce RTX 3090, 10496 shaders @ 1695 MHz, driver 552.22, Windows Server 2022, Python 3.11.9, vapoursynth-classic R57.A8

1920x1080 RGBS, TRT backend, CUDA graphs enabled, fp16

Measurements: FPS / Device Memory (MB)

model 1 stream 2 streams 3 streams
dpir color 10.99 / 1715.172 11.62 / 3048.540 11.64 / 4381.912
waifu2x upconv_7_{anime_style_art_rgb, photo} 22.38 / 2016.352 32.66 / 3734.880 32.54 / 5453.404
waifu2x cunet / cugan 12.41 / 4359.284 15.53 / 8363.392 15.47 / 12367.504
waifu2x swin_unet 3.80 / 7304.332 4.06 / 14392.408 4.06 / 21276.380
real-esrgan (v2/v3, xsx2) 16.65 / 955.480 22.53 / 1645.904 22.49 / 2336.324
scunet color 4.20 / 2847.708 4.33 / 6646.884 4.33 / 9792.736

Also check benchmarks from previous pre-releases v14.test4 (NVIDIA RTX 2080 Ti/3090/4090 GPUs) and v14.test3 (NVIDIA RTX 4090 and AMD RX 7900 XTX GPUs).


This release uses CUDA 12.4.1, cuDNN 8.9.7, TensorRT 10.0.1, ONNX Runtime v1.18.0, OpenVINO 2024.2.0 and ncnn 20220915 b16f8ca.

Full Changelog: v13.2...v14