Convert

From Avisynth wiki
(Difference between revisions)
Jump to: navigation, search
m (add AVS+ note)
(note AVS+ differences *** WIP ***)
Line 1: Line 1:
 
<div style="max-width:62em" >
 
<div style="max-width:62em" >
 +
 +
{{BoldColor|blue|140|UNDER CONSTRUCTION - some information is incomplete or incorrect}}
 +
 
Convert between any of the color formats that AviSynth supports:
 
Convert between any of the color formats that AviSynth supports:
 
:{| class="wikitable"
 
:{| class="wikitable"
|-  
+
|-
 +
! Version
 
! Color format
 
! Color format
 
! Image format
 
! Image format
 +
! Bit depth
 
! Chroma resolution
 
! Chroma resolution
 
|-  
 
|-  
 +
|
 
| '''[[RGB24]]'''
 
| '''[[RGB24]]'''
 
| [[Interleaved|interleaved]]
 
| [[Interleaved|interleaved]]
 +
| 8
 
| 4:4:4 (full chroma)
 
| 4:4:4 (full chroma)
 
|-  
 
|-  
 +
|
 
| '''[[RGB32]]'''
 
| '''[[RGB32]]'''
 
| interleaved
 
| interleaved
 +
| 8
 +
| 4:4:4:4 (full chroma + alpha)
 +
|-
 +
|style="text-align:center"| {{AvsPluscon}}
 +
| '''[[RGB48]]'''
 +
| interleaved
 +
| 16
 
| 4:4:4 (full chroma)
 
| 4:4:4 (full chroma)
 
|-  
 
|-  
| '''[[YV24]]''' &diams;
+
|style="text-align:center"| {{AvsPluscon}}
 +
| '''[[RGB64]]'''
 +
| interleaved
 +
| 16
 +
| 4:4:4:4 (full chroma + alpha)
 +
|-
 +
|style="text-align:center"| {{AvsPluscon}}
 +
| '''[[RGBP]]'''''xx''
 
| [[Planar|planar]]
 
| [[Planar|planar]]
 +
| 8,10,12,14,16,32&nbsp;
 +
| 4:4:4 (full chroma)
 +
|-
 +
|style="text-align:center"| {{AvsPluscon}}
 +
| '''[[RGBAP]]'''''xx''
 +
| [[Planar|planar]]
 +
| 8,10,12,14,16,32&nbsp;
 +
| 4:4:4:4 (full chroma + alpha)
 +
|-
 +
|style="text-align:center"| v2.6
 +
| '''[[YV24]]'''
 +
| planar
 +
| 8
 +
| 4:4:4 (full chroma)
 +
|-
 +
|style="text-align:center"| {{AvsPluscon}}
 +
| '''[[YUV444P]]'''''xx''
 +
| planar
 +
| 8,10,12,14,16,32&nbsp;
 
| 4:4:4 (full chroma)
 
| 4:4:4 (full chroma)
 
|-  
 
|-  
| '''[[YV16]]''' &diams;
+
|style="text-align:center"| v2.6
 +
| '''[[YV16]]'''
 
| planar
 
| planar
 +
| 8
 
| 4:2:2 (chroma shared between 2 pixels)
 
| 4:2:2 (chroma shared between 2 pixels)
 
|-  
 
|-  
 +
|
 
| '''[[YUY2]]'''
 
| '''[[YUY2]]'''
 
| interleaved
 
| interleaved
 +
| 8
 
| 4:2:2 (chroma shared between 2 pixels)
 
| 4:2:2 (chroma shared between 2 pixels)
 
|-  
 
|-  
 +
|
 
| '''[[YV12]]'''
 
| '''[[YV12]]'''
 
| planar
 
| planar
 +
| 8
 
| 4:2:0 (chroma shared between 2x2 pixels)&nbsp;
 
| 4:2:0 (chroma shared between 2x2 pixels)&nbsp;
 
|-  
 
|-  
| '''[[YV411]]''' &diams;
+
|style="text-align:center"| v2.6
 +
| '''[[YV411]]'''
 
| planar
 
| planar
 +
| 8
 
| 4:1:1 (chroma shared between 4 pixels)
 
| 4:1:1 (chroma shared between 4 pixels)
 
|-  
 
|-  
| '''[[Y8]]''' &diams;
+
|style="text-align:center"| v2.6
 +
| '''[[Y8]]'''  
 
| (both)
 
| (both)
 +
| 8
 
| 4:0:0 (no chroma)
 
| 4:0:0 (no chroma)
|}
+
|}<!--
:(&diams; = not supported in AviSynth version 2.58 or below)
+
: (= AviSynth v2.6)  
 +
: ({{BoldColor|black|112|A+}} = [[AviSynth%2B|AviSynth+]]&nbsp;) -->
 +
 
 +
 
 
When the target format is the same as the source format, the original clip will be returned unchanged, except for the case of '''ConvertToYV12''' where the {{FuncArg|ChromaInPlacement}} and {{FuncArg|ChromaOutPlacement}} parameters are different.
 
When the target format is the same as the source format, the original clip will be returned unchanged, except for the case of '''ConvertToYV12''' where the {{FuncArg|ChromaInPlacement}} and {{FuncArg|ChromaOutPlacement}} parameters are different.
  
Line 56: Line 110:
 
Use '''ConvertBackToYUY2''' to convert ''back'' to YUY2 with minimal color-blurring when you have previously applied a YUY2&rarr;RGB conversion.
 
Use '''ConvertBackToYUY2''' to convert ''back'' to YUY2 with minimal color-blurring when you have previously applied a YUY2&rarr;RGB conversion.
  
{{AvsPluscon}} See also [[ConvertFormat]] for high bit depth support and [[ConvertBits]] to convert between bit depths.
+
{{AvsPluscon}} See also [[ConvertBits]] to convert between bit depths.
 
</div>
 
</div>
  
  
 
==== Syntax and Parameters ====
 
==== Syntax and Parameters ====
{{Func3Def
+
<div style="max-width:62em" >
|ConvertToRGB(clip [, string ''matrix'', bool ''interlaced'', string ''ChromaInPlacement'', string ''chromaresample''] )
+
{{FuncDef
|ConvertToRGB24(clip [, string ''matrix'', bool ''interlaced'', string ''ChromaInPlacement'', string ''chromaresample''] )
+
|ConvertToRGB(clip [, string ''matrix'', bool ''interlaced'',   <br>
|ConvertToRGB32(clip [, string ''matrix'', bool ''interlaced'', string ''ChromaInPlacement'', string ''chromaresample''] )
+
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample''] )  
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToRGB24(clip [, string ''matrix'', bool ''interlaced'',   <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample''] )
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToRGB32(clip [, string ''matrix'', bool ''interlaced'',   <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample''] )
 +
}} <br>
 +
{{FuncDef
 +
|ConvertToRGB48(clip, [ string ''matrix'', bool ''interlaced'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; string ''chromaresample'' ] ) {{AvsPluscon}}
 +
}} <br>
 +
{{FuncDef
 +
|ConvertToRGB64(clip, [ string ''matrix'', bool ''interlaced'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'' ] ) {{AvsPluscon}}
 
}}
 
}}
  
{{Func2Def
+
{{FuncDef
|ConvertToYV24(clip [, bool ''interlaced'', string ''matrix'', string ''ChromaInPlacement'', string ''chromaresample''] )
+
|ConvertToPlanarRGB(clip, [ string ''matrix'', bool ''interlaced'',   <br>
|ConvertToYV16(clip [, bool ''interlaced'', string ''matrix'', string ''ChromaInPlacement'', string ''chromaresample''] )
+
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'' ] ) {{AvsPluscon}}
 +
}} <br>
 +
{{FuncDef
 +
|ConvertToPlanarRGBA(clip, [ string ''matrix'', bool ''interlaced'',   <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'' ] ) {{AvsPluscon}}
 
}}
 
}}
  
{{Func2Def
+
{{FuncDef
|ConvertToYUY2(clip [, bool ''interlaced'', string ''matrix'', string ''ChromaInPlacement'', string ''chromaresample''] )
+
|ConvertToYV24(clip [, bool ''interlaced'', string ''matrix'',  <br>
|ConvertToYV12(clip [, bool ''interlaced'', string ''matrix'', string ''ChromaInPlacement'', string ''chromaresample'', string ''ChromaOutPlacement''] )
+
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample''] )
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToYUV444(clip, [ string ''matrix'', bool ''interlaced'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'' ] ) {{AvsPluscon}}
 +
}} <br>
 +
 
 +
{{FuncDef
 +
|ConvertToYUY2(clip [, bool ''interlaced'', string ''matrix'',   <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample''] )
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToYV16(clip [, bool ''interlaced'', string ''matrix'',   <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample''] )
 +
}} <br>
 +
{{FuncDef
 +
|ConvertToYUV422(clip, [ string ''matrix'', bool ''interlaced'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'' ] ) {{AvsPluscon}}
 
}}
 
}}
  
{{Func2Def
+
{{FuncDef
|ConvertToYV411(clip [, bool ''interlaced'', string ''matrix'', string ''ChromaInPlacement'', string ''chromaresample''] )
+
|ConvertToYV12(clip [, bool ''interlaced'', string ''matrix'',   <br>
|ConvertToY8(clip [, string ''matrix''] )
+
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaOutPlacement''] )
 +
}} <br>
 +
{{FuncDef
 +
|ConvertToYUV420(clip, [ string ''matrix'', bool ''interlaced'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaOutPlacement'' ] ) {{AvsPluscon}}
 
}}
 
}}
 +
 +
{{FuncDef
 +
|ConvertToYV411(clip [, bool ''interlaced'', string ''matrix'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample''] )
 +
}}
 +
 +
{{FuncDef
 +
|ConvertToY8(clip [, string ''matrix''] )
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToY(clip, [ string ''matrix'' ] ) {{AvsPluscon}}
 +
}}
  
 
{{FuncDef
 
{{FuncDef
 
|ConvertBackToYUY2(clip [, string ''matrix'' ] )
 
|ConvertBackToYUY2(clip [, string ''matrix'' ] )
 
}}
 
}}
<div style="max-width:62em" >
 
  
  
Line 95: Line 218:
 
:*"PC.709" : Uses Rec.709 coefficients; keep range unchanged.
 
:*"PC.709" : Uses Rec.709 coefficients; keep range unchanged.
 
:*"AVERAGE" : Uses averaged coefficients (the luma becomes the average of the RGB channels); keep range unchanged.
 
:*"AVERAGE" : Uses averaged coefficients (the luma becomes the average of the RGB channels); keep range unchanged.
 
  
 
{{Par2|interlaced|bool|false}}
 
{{Par2|interlaced|bool|false}}
Line 110: Line 232:
 
</div>
 
</div>
 
:Note, {{FuncArg|interlaced}}=true has an effect only on YV12&harr;YUY2 or YV12&harr;RGB conversions. More about that can be found [[Interlaced fieldbased|'''here''']].
 
:Note, {{FuncArg|interlaced}}=true has an effect only on YV12&harr;YUY2 or YV12&harr;RGB conversions. More about that can be found [[Interlaced fieldbased|'''here''']].
 
  
 
{{Par2|ChromaInPlacement|string|"MPEG2"}}
 
{{Par2|ChromaInPlacement|string|"MPEG2"}}
Line 128: Line 249:
 
| Like MPEG-2, but U and V channels are “co-sited” vertically: V on the top row, and U on the bottom row. For 4:1:1, chroma is located on the leftmost column.
 
| Like MPEG-2, but U and V channels are “co-sited” vertically: V on the top row, and U on the bottom row. For 4:1:1, chroma is located on the leftmost column.
 
|}
 
|}
 
  
 
{{Par2|chromaresample|string|"bicubic"}}
 
{{Par2|chromaresample|string|"bicubic"}}
Line 153: Line 273:
 
===== Sampling =====
 
===== Sampling =====
  
:[[Sampling|'''This page''']] covers the sampling methods and color formats in more detail.
+
:[[Sampling|'''[This page]''']] covers the sampling methods and color formats in more detail.
  
 
===== Color conversions =====
 
===== Color conversions =====
  
:[[Color_conversions|'''This page''']] covers the color conversions in more detail.
+
:[[Color_conversions|'''[This page]''']] covers the color conversions in more detail.
 
</div>
 
</div>
  

Revision as of 05:30, 24 April 2017

UNDER CONSTRUCTION - some information is incomplete or incorrect

Convert between any of the color formats that AviSynth supports:

Version Color format Image format Bit depth Chroma resolution
RGB24 interleaved 8 4:4:4 (full chroma)
RGB32 interleaved 8 4:4:4:4 (full chroma + alpha)
AVS+ RGB48 interleaved 16 4:4:4 (full chroma)
AVS+ RGB64 interleaved 16 4:4:4:4 (full chroma + alpha)
AVS+ RGBPxx planar 8,10,12,14,16,32  4:4:4 (full chroma)
AVS+ RGBAPxx planar 8,10,12,14,16,32  4:4:4:4 (full chroma + alpha)
v2.6 YV24 planar 8 4:4:4 (full chroma)
AVS+ YUV444Pxx planar 8,10,12,14,16,32  4:4:4 (full chroma)
v2.6 YV16 planar 8 4:2:2 (chroma shared between 2 pixels)
YUY2 interleaved 8 4:2:2 (chroma shared between 2 pixels)
YV12 planar 8 4:2:0 (chroma shared between 2x2 pixels) 
v2.6 YV411 planar 8 4:1:1 (chroma shared between 4 pixels)
v2.6 Y8 (both) 8 4:0:0 (no chroma)


When the target format is the same as the source format, the original clip will be returned unchanged, except for the case of ConvertToYV12 where the ChromaInPlacement and ChromaOutPlacement parameters are different.

There is no unique way of converting YUV to RGB or vice-versa. There are different conversion matrices in use; the two most common ones are available in AviSynth, namely Rec.601 and Rec.709, plus some others. The following should be correct in most cases (see here for more)

  • Rec.601 should be used when your source is standard definition (usually defined as smaller than 720p):
ConvertToRGB(clip) (using default "Rec601")
  • Rec.709 should be used when your source is DVD or HDTV:
ConvertToRGB(clip, matrix="Rec709")
  • The special-purpose matrices PC.601 and PC.709 keep the range unchanged,
instead of converting between 0-255 RGB and 16-235 YUV, as is the normal practice.
  • The special-purpose matrix AVERAGE is used for (rarely found) sources with unweighted luma,
where Y = (R + G + B) / 3.

Note ConvertToRGB always converts to RGB32 – unless your source is RGB24, in which case no conversion is done. If you need 24-bit RGB for some reason, use ConvertToRGB24 explicitly.

Use ConvertBackToYUY2 to convert back to YUY2 with minimal color-blurring when you have previously applied a YUY2→RGB conversion.

AVS+ See also ConvertBits to convert between bit depths.


Contents

Syntax and Parameters

ConvertToRGB(clip [, string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample] )

ConvertToRGB24(clip [, string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample] )

ConvertToRGB32(clip [, string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample] )

ConvertToRGB48(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
      string chromaresample ] ) AVS+

ConvertToRGB64(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample ] ) AVS+

ConvertToPlanarRGB(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample ] ) AVS+

ConvertToPlanarRGBA(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample ] ) AVS+

ConvertToYV24(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample] )

ConvertToYUV444(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample ] ) AVS+

ConvertToYUY2(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample] )

ConvertToYV16(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample] )

ConvertToYUV422(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample ] ) AVS+

ConvertToYV12(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample,
     string ChromaOutPlacement] )

ConvertToYUV420(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     string ChromaOutPlacement ] ) AVS+

ConvertToYV411(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample] )

ConvertToY8(clip [, string matrix] )
ConvertToY(clip, [ string matrix ] ) AVS+

ConvertBackToYUY2(clip [, string matrix ] )


string  matrix = "Rec601"

Controls the colour coefficients and scaling factors used in RGB↔YUV conversions.
  • "Rec601" : Uses Rec.601 coefficients; scale full range [0..255] RGB to TV range [16..235] YUV, and vice versa.
  • "Rec709" : Uses Rec.709 coefficients; scale full range [0..255] RGB to TV range [16..235] YUV, and vice versa.
  • "PC.601" : Uses Rec.601 coefficients; keep range unchanged.
  • "PC.709" : Uses Rec.709 coefficients; keep range unchanged.
  • "AVERAGE" : Uses averaged coefficients (the luma becomes the average of the RGB channels); keep range unchanged.

bool  interlaced = false

If true, it is assumed that clip is interlaced; by default, it is assumed to be progressive.
This option is needed because for example, the following (assuming clip is interlaced YV12):
SeparateFields(clip)
ConvertToYUY2
Weave
...is upsampled incorrectly. Instead it is better to use:
ConvertToYUY2(clip, interlaced=true)
Note, interlaced=true has an effect only on YV12↔YUY2 or YV12↔RGB conversions. More about that can be found here.

string  ChromaInPlacement = "MPEG2"
string  ChromaOutPlacement = "MPEG2"

ChromaInPlacement determines the chroma placement in the clip when converting from YV12.
ChromaOutPlacement determines the chroma placement in the clip when converting to YV12.
The placement can be one of these strings:
"MPEG2"  Subsampling used in MPEG-2 4:2:x and most other formats. Chroma samples are located on the left pixel column of the group (default).
"MPEG1" Subsampling used in MPEG-1 4:2:0. Chroma samples are located on the center of each group of 4 pixels.
"DV" Like MPEG-2, but U and V channels are “co-sited” vertically: V on the top row, and U on the bottom row. For 4:1:1, chroma is located on the leftmost column.

string  chromaresample = "bicubic"

Determines which chroma resampler is used in the conversion. Only used when the chroma resolutions of the source and target are different. All AviSynth resizers are allowed ("point", "bilinear", "bicubic", "lanczos", "lanczos4", "blackman", "spline16", "spline36", "spline64", "gauss" and "sinc"). Default is "bicubic".


Notes

Conversion paths
In v2.60 the following conversion paths occur:
  • YUV planar → RGB via YV24
  • YUV planar → YUY2 via YV16
(except for YV12 and chroma options listed above not explicitly set; in that case there is a direct conversion from YV12 to YUY2)
  • RGB → YUV planar via YV24
  • YUY2 → YUV planar via YV16
(except for YV12 and chroma options listed above not explicitly set; in that case there is a direct conversion from YUY2 to YV12)
The chroma options chromaresample, ChromaInPlacement and ChromaOutPlacement are only used in the 'planar conversion' part of the conversion path.
Suppose you have a YUY2 clip for example and you convert it to YV24. The YUY2 will be converted to YV16 first without applying the chroma options. Then YV16 will be converted to YV24 while applying chromaresample. Since YV12 is not involved, ChromaInPlacement and ChromaOutPlacement won't be used.
Sampling
[This page] covers the sampling methods and color formats in more detail.
Color conversions
[This page] covers the color conversions in more detail.


Changelog

v2.60 Added ConvertToY8, ConvertToYV411, ConvertToYV16, ConvertToYV24, ChromaInPlacement, ChromaOutPlacement, chromaresample, matrix="AVERAGE".
v2.50 Added ConvertToYV12.
Personal tools