AviSynth

AviSynth
Developer(s) AviSynth developers
Stable release 2.5.8 / December 30, 2008
Preview release 2.6 alpha 3
Written in C++
Operating system Windows
Type Digital video frameserver
License GNU GPL
Website http://www.avisynth.org

AviSynth is a frameserver program for Microsoft Windows developed by Ben Rudiak-Gould, Edwin van Eggelen, Klaus Post, Richard Berg, Ian Brabham and others. It is free software under GNU GPL license.

Contents

Scripting video editor

AviSynth acts as a non-linear video editor (without a GUI) controlled entirely by scripting. It stands as an intermediary between a digital video source, like an AVI or MPEG file, and a VFW receiving program, which is typically a media player, video editing software, or an encoder.

AviSynth communicates with any program that supports AVIs through the Video for Windows system by acting as a "fake" AVI file. It can apply a large variety of editing and processing functions (called filters) to a video stream before passing along the results as if it were a legitimate file being read. Filter capabilities include trimming, cropping, deinterlacing, inverse telecine, loading and splicing still images, doing color corrections, denoising, and many other things.

Technically, it acts as a codec for AviSynth scripts, which are text files written in the AviSynth scripting language. The scripting language can be extended through the use of plugins. A plugin list is maintained at AviSynth Filter Collection.

AviSynth filters work in several color spaces including RGB, YUY2 and YV12 (Also YV16, YV24, YV411 and Y8 in Avisynth 2.6). This is necessary to allow all kinds of video input and output. Certain functions only work on specific color spaces, requiring conversion beforehand.

For example, say the script "myAvi.avs" (just a plain text-file saved with the extension "avs") contains the following:

AviSource("myAvi.avi")
Crop(0, 0, 320, 240)
Blur(0.1)

This script file can be opened in most media players (such as Windows Media Player). The program will play the video file "myAvi.avi" trimmed down to its top-left 320 pixels by 240 pixels and blurred by a small amount. Operations occur in sequential order, so the Cropping occurs first, then the Blurring.

AviSynth scripting language

The scripting language is a programming language, containing many features familiar to programmers, including variables, distinct datatypes, conditionals, and complex expressions.

The language deals primarily with videos, as a primitive data type. A typical script loads a video as input, applies processing to it, and then "returns" that video in the same way functions return values. The returned video is the output of the script, which is seen as the video by the program running the script.

The language also has several other more standard data types, including int, float, bool and string. These can be used to perform calculations, decisions, and write text such as subtitles to the video.

The processing work is largely done by functions or filters. The programmer can pass arguments to one of many built-in functions, and a value may be returned. Also, many functions take a video stream as an argument, and make changes to this stream.

Programmers may be unaware that they are constantly passing video streams into functions, since convention suggests that the video is not explicitly passed. If no video is passed into a function, it simply takes the last video used.

Additional functions/filters are available through plugins. The use of plugins is encouraged to extend the capabilities of AviSynth. (See AviSynth Filter Collection link for a list of plugins).

"Hello World"

This example is a "Hello World" program - it simply creates a video containing the words "Hello, world!".

BlankClip()
Subtitle("Hello, world!")

The BlankClip function creates a new video, which then has a subtitle displayed on top of it. The parentheses at the end of the word are optional, since no arguments are being passed, but are given in this case to indicate it is a function and not a variable.

The Subtitle function draws the words "Hello, world!" on top of the previously-created blank video.

Although the BlankClip and Subtitle functions both accept many more arguments (for example, controlling the size and length of the video, and the positioning, font, and color of the subtitle), this example leaves them out, so the functions use built-in defaults.

If the above text is entered into a .avs file, it can be opened in Windows Media Player or any of the other programs in the list below, and a video containing the text will be displayed.

Video-processing

This example takes an actual video, applies some simple processing, and returns it to the output.

AviSource("C:\Example.avi")
ReduceBy2()
GreyScale()

The AviSource function is used to load a video from a real location. The DirectShowSource function could also be used. ReduceBy2 divides the vertical and horizontal size of the video in half, and GreyScale forces the video to greyscale colors.

Again, the above script can be entered into a .avs file and opened in a video player or editor. Assuming C:\Example.avi exists, it will play a copy of that file, except that it will be half the size and greyscale.

User defined

The AviSynth scripting language allows for users to define their own functions.

This is an example of a function that allows you to dissolve from one clip to another without damaging interlacing lines.

 clip1 = AVISource("video1.avi")
 clip2 = AVISource("video2.avi")
 interlaced_dissolve(clip1, clip2, 30)              # dissolve from clip1 to clip2 over 30 frames
 
 
 function interlaced_dissolve(clip clip1, clip clip2, int iter)  {
       clip1 = clip1.SeparateFields
       evn1  = clip1.SelectEven
       odd1  = clip1.SelectOdd
 
       clip2 = clip2.SeparateFields
       evn2  = clip2.SelectEven
       odd2  = clip2.SelectOdd
 
       evn = Dissolve(evn1, evn2, iter)
       odd = Dissolve(odd1, odd2, iter)
       Interleave(evn, odd).Weave.DoubleWeave.SelectOdd
 }

AviSynth 3.0 code rewrite

AviSynth 3.0 was a complete rewrite of AviSynth 2.x, and aimed to overcome the limitations of AviSynth 2.x. Adding improvements such as an abstracted color space model, in which new color spaces (including two with 45-bit depth) could be supported through a plug-in mechanism, better cache management for better performance, and using Ruby rather than the homegrown language employed in current versions.[1]

AviSynth 3.0 was to be available for other operating systems than Windows, instead relying on GStreamer, extending support to platforms such as Linux, Mac OS X and BSD.

Development has been stalled since August 2007.[1][2]

AviSynth for non-Windows operating systems

AviSynth 2.xx may be used under operating systems other than Windows through the use of Wine. To work on scripts VirtualDub/VirtualDubMod can be used as on Windows. To interface between AviSynth under Wine and for example FFmpeg running on a Linux host, Avs2YUV can be used. Avs2YUV is a Windows command line program that is run under Wine and renders the output of an AviSynth script to stdout that is then piped to FFmpeg. Avs2YUV also supports writing to a Named pipe.[3]

AviSynth compatible programs

Program name Comments Homepage
Adobe Premiere Versions 6.0 and later (up to and including CS4) have an AviSynth import plugin available.

Premiere AviSynth import plugin

Cinema Craft Encoder Cinema Craft Encoder is a commercial MPEG-2 encoder that supports AviSynth input.

Cinema Craft

FFmpeg FFmpeg compiled for windows can receive avisynth input

instructions

MPlayer MPlayer can play .avs files
GOM Player can play .avs files
Nero_Multimedia_Suite Nero Showtime can play avs files
TMPGEnc TMPGEnc is a free MPEG-1 and MPEG-2 encoder. TMPGEnc Plus and TMPGEnc Express are commercial versions of TMPGEnc that include enhanced functionality, as well as the removal of a 30-day restriction on MPEG-2 encoding present in TMPGEnc.

Pegasys Inc.

VirtualDub VirtualDub is a widely-used all-purpose video converter. VirtualDub
VirtualDubMod VirtualDubMod contains several AviSynth-specific features such as explicit support for AviSynth scripts, an AviSynth script editor, and more. However, it has not been updated since 2006 and contains many bugs.[4] VirtualDubMod
Windows Media Player Windows Media Player is capable of loading and playing AviSynth scripts, so it is a good choice for simple playback and testing. It may require some registry tweaks to get it working. Windows Media Home
Media Player Classic Media Player Classic is capable of loading and playing AviSynth scripts. The 32-bit version is needed. Media Player Classic
SUPER SUPER (Simplified Universal Player, Encoder and Renderer) is freeware from eRightSoft that can encode most common video formats and has full AviSynth support. SUPER
Total video converter Total video converter has an Avisynth import plugin available. Total Video Converter

In addition, several programs have now been created which accept only AviSynth scripts as input - thereby simplifying the programs themselves but giving users the full power of AviSynth for input.

There are also several batch encoding applications that tie together AviSynth with command line audio and video encoders and muxers to provide an all-in-one, modular, customizable video encoding application. MeGUI is an example of this kind of application.

Although AviSynth is meant to be easily opened in simple text editing programs, there are several powerful and friendly editors meant especially for editing AviSynth scripts. AVSEdit was a popular editor, but hasn't been updated since 2004. AvsP is the most used and most powerful editor at the moment.

See also

References

External links