Skip to content

mysteryx93/AviSynthShader

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

AviSynth Shader v1.6.6

Download here >>

This plugin allows running HLSL pixel shaders within AviSynth. This gives access to various HLSL filters that haven't been programmed in AviSynth.

by Etienne Charland

This implementation allows running several shaders in a row. Shader() returns a clip containing commands, and each subsequent to Shader() adds a line to that command chain clip. You must call ExecuteShader() to execute the chain of commands. You must also call ConvertToShader() before and ConvertFromShader() at the end.

The following example will run Diff1 and Diff2 on the clip before returning a Merge of both results. (these shader names are fictive, you have to use real shaders!)

ConvertToShader(1)
Input
Shader("Diff1.cso", Output=2)
Shader("Diff2.cso", Output=3)
Shader("Merge.cso", Clip1=2, Clip2=3, Output=1)
ShaderExecute(last, Input, Clip1Precision=1, Precision=3, OutputPrecision=1)
ConvertFromShader(1)

It is recommended to use AviSynth MT so that the CPU can work on other threads while waiting for results from the GPU.
With AviSynth 2.6, ConvertToShader, ConvertFromShader and Shader support MT=1 while ExecuteShader supports MT=2.
With AviSynth+, all filters run as MT=1 and automatically configure their mode. If you run 8 threads, it will alternate all threads between 2 engines for optimal performance.

Shader.avsi functions

Common Parameter

MatrixIn/MatrixOut: The input and output color matrix (601, 709, Pc601, Pc709). This can be used for color matrix conversion. Default="709" for both
FormatOut: The output format. Default = same as input.
Convert: Whether to call ConvertToShader and ConvertFromShader within the shader. Default=true
ConvertYuv: Whether do YUV-RGB color conversion. Default=true unless Convert=true and source is RGB
lsb_in, lsb_out: Whether the input, result of Upscale and output are to be converted to/from DitherTools' Stack16 format. Default=false
fKernel, fWidth, fHeight, fB, fC: Allows downscaling the output before reading back from GPU. See ResizeShader.
PlanarIn, PlanarOut: Whether to transfer frame data as 3 individual planes to reduce bandwidth at the expense of extra processing. Generally, PlanarIn brings no performance benefit while PlanarOut brings a nice performance boost. PlanarIn may bring an advantage with larger frames. Default for SuperRes and SuperResXBR: PlanarIn=false, PlanarOut=true. Default for SuperXBR: PlanarIn=true, PlanarOut=true. Default for ResizeShader: PlanarIn=true, PlanarOut=false.
Engines: In Avisynth+ with MT_NICE_FILTER, sets the number of DirectX engines that will be shared amongst all threads. Set to 2 if running a single shader function for increased performance. Default=1. Ignored in AviSynth 2.6 running with MT_MULTI_INSTANCE.
Arguments fKernel, fWidth, fHeight, fB, fC are the same as ResizeShader and allows downscaling the output before reading back from GPU

SuperResXBR(Input, Passes, Str, Soft, XbrStr, XbrSharp, Factor, MatrixIn, MatrixOut, FormatOut, Convert, ConvertYuv, lsb_in, lsb_out, fKernel, fWidth, fHeight, fB, fC, PlanarIn, PlanarUpscale, PlanarOut)

Enhances upscaling quality, combining Super-xBR and SuperRes to run in the same command chain, reducing memory transfers and increasing performance.

Arguments Passes, Str, Soft are the same as SuperRes.
Arguments XbrStr, XbrSharp, Factor are the same as SuperXBR.

SuperRes(Input, Passes, Str, Soft, Upscale, MatrixIn, MatrixOut, FormatOut, Convert, ConvertYuv, lsb_in, lsb_upscale, lsb_out, fKernel, fWidth, fHeight, fB, fC, PlanarIn, PlanarUpscale, PlanarOut)

Enhances upscaling quality.

Arguments:
Passes: How many SuperRes passes to run. Default=1.
Str: How agressively we want to run SuperRes, between 0 and 1. Default=1.
Soft: How much smoothness we want to add, between 0 and 1. Default=0.
Upscale: An upscaling command that must contain offset-correction. Ex: """nnedi3_rpow2(2, cshift="Spline16Resize")"""
lsb_upscale: Whether the result of Upscale is to be converted from DitherTools' Stack16 format. Default=false
PlanarUpscale: Whether to read the result of Upscale as planar data. Default=true (slight performance gain)

SuperXBR(Input, Str, Sharp, Factor, MatrixIn, MatrixOut, FormatOut, Convert, lsb_in, lsb_out, fKernel, fWidth, fHeight, fB, fC, PlanarIn, PlanarOut)

Doubles the size of the image. Produces a sharp result, but with severe ringing.

Arguments:
Str: Value between 0 and 5 specifying the strength. Default=1.
Sharp: Value between 0 and 1.5 specifying the weight. Default=1.
Factor: Upscales the image by a factor of 2, 4, 8 or 16 in one call. Default=2.

ResizeShader(Input, Width, Height, Kernel, B, C, MatrixIn, MatrixOut, FormatOut, Convert, ConvertYuv, lsb_in, lsb_out, PlanarIn, PlanarOut)

Downscales the image in high quality.

Arguments:
Width: The width to resize to.
Height: The height to resize to.
Str: The algorithm strength to apply between 0 and 1. Default=.5
Soft: If true, the result will be softer. Default=false
Kernel: The resize algorithm to use: SSim, Bicubic or ColorMatrix. ColorMatrix performs matrix conversion without resizing. Default=Bicubic.
B, C: When using SSim, B sets the Strength (0 to 1, default=.5) and C sets whether to use a soft algorithm (0 or 1, default=0)
B, C: When using Bicubic, sets the B and C values. Default is B=1/3, C=1/3.
When used as a downscaler in other functions, default is fB=0, fC=.75 (useful for downscaling)

Shiandow provides many other HLSL shaders available here that can be integrated into AviSynth.
https://github.com/zachsaw/MPDN_Extensions/tree/master/Extensions/RenderScripts

Shader.dll functions

ConvertToShader(Input, Precision, lsb, Planar, Opt)

Converts a clip into a wider frame containing UINT16 or half-float data. Clips must be converted in such a way before running any shader.

16-bit-per-channel half-float data isn't natively supported by AviSynth. It is stored in a RGB32 container with a Width that is twice larger. When using Clip.Width, you must divine by 2 to get the accurate width.

Arguments:
Precision: 0 to convert to Y8, 1 to convert into BYTE, 2 to convert into UINT16, 3 to convert into half-float. Default=1
lsb: Whether to convert from DitherTools' Stack16 format. Only YV12 and YV24 are supported. Default=false
Planar: True to convert into YV24 planar data to reduce memory transers. If you assign such a clip to Clip1, the shader will receive the 3 planes as Clip1, Clip2 and Clip3. Default=false
Opt: Optimization path. In Avisynth 2.6, 0 for only C++, 1 for SSE2, 2 for AVX(only used with Precision=3), -1 to auto-detect. In Avisynth+, -1 to use the Avisynth+ code path, other values to use legacy code paths. Default=-1

ConvertFromShader(Input, Precision, Format, lsb)

Convert a half-float clip into a standard clip.

Arguments:
Precision: 0 to convert int Y8, 1 to convert into BYTE, 2 to convert into UINT16, 3 to convert into half-float. Default=1
Format: The video format to convert to. Valid formats are YV12, YV24 and RGB32. Default=YV12.
lsb: Whether to convert to DitherTools' Stack16 format. Only YV12 and YV24 are supported. Default=false
Opt: Optimization path. In Avisynth 2.6, 0 for only C++, 1 for SSE2, 2 for AVX(only used with Precision=3), -1 to auto-detect. In Avisynth+, -1 to use the Avisynth+ code path, other values to use legacy code paths. Default=-1

Shader(Input, Path, EntryPoint, ShaderModel, Param1-Param9, Clip1-Clip9, Output, Width, Height, Precision, Defines)

Runs a HLSL pixel shader on specified clip. You can either run a compiled .cso file or compile a .hlsl file.

Arguments:
Input: The first input clip.
Path: The path to the HLSL pixel shader file to run. If not specified, Clip1 will be copied to Output.
EntryPoint: If compiling HLSL source code, specified the code entry point.
ShaderModel: If compiling HLSL source code, specified the shader model. Usually PS_2_0 or PS_3_0
Param0-Param8: Sets each of the shader parameters.
Ex: "float4 p4 : register(c4);" will be set with Param4="1,1,1,1f"
End each value with 'f'(float), 'i'(int) or 'b'(bool) to specify its type.
Param0 corresponds to c0, Param1 corresponds to c1, etc.
If setting float or int, you can set a vector or 2, 3 or 4 elements by separating the values with ','.
If not specified, Param0 = Width,Height and Param1 = 1/Width, 1/Height by default.
Clip1-Clip9: The index of the clips to set into this shader. Input clips are defined when calling ExecuteShader. Clip1 sets 's0' within the shader, while clip2-clip9 set 's1' to 's8'. The order is important.
Default for clip1 is 1, for clip2-clip9 is 0 which means no source clip.
Output: The clip index where to write the output of this shader, between 1 and 9. Default is 1 which means it will be the output of ExecuteShader. If set to another value, you can use it as the input of another shader. The last shader in the chain must have output=1.
Width, Height: The size of the output texture. Default = same as input texture.
Precision: While processing precision is set with ExecuteShader, this allows processing certain shaders with a different precision. Defines: List of pre-compilation constants to set for HLSL files, separated by ';'. Ex: "Kb=0.114;Kr=0.299;"

ExecuteShader(cmd, Clip1-Clip9, Clip1Precision-Clip9Precision, Precision, OutputPrecision, PlanarOut)

Executes the chain of commands on specified input clips.

Arguments:
cmd: A clip containing the commands returned by calling Shader.
Clip1-Clip9: The clips on which to run the shaders.
Clip1Precision-Clip9Precision: 1 if input clips is BYTE, 2 if UINT16, 3 if half-float. Default=1 or the value of the previous clip
Precision: 1 to execute with 8-bit precision, 2 to execute with 16-bit precision, 3 to execute with half-float precision. Default=3
OutputPrecision: 1 to get an output clip with BYTE, 2 for UINT16, 3 for half-float. Default=1
PlanarOut: True to transfer data from the GPU back to the CPU as planar data to reduce memory transfers. Reading back from the GPU is a serious bottleneck and this generally gives a nice performance boost. Default=true

Also from Etienne

Natural Grounding Player, provides a nice Media Encoder to upscale videos from SD to HD using AviSynthShader
Force of Life Training, getting closer to my real work
and some far-out stuff you probably don't want to know about