Convert

From Avisynth wiki
(Difference between revisions)
Jump to: navigation, search
m (Options: further clarification)
(Update ConvertToXXXX, 3.7.3 change log, mention param1,param2,param3, Add YUVA versions, PC601,PC709 related additions, link to avs+ docs)
 
(33 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{Template:Func10Def|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''])|ConvertToYUY2(clip [, bool ''interlaced''] [, string ''matrix''] [, string ''ChromaInPlacement''] [, string ''chromaresample''])|ConvertBackToYUY2(clip [, string ''matrix'']|ConvertToY8(clip [, string ''matrix''])|ConvertToYV411(clip [, bool ''interlaced''] [, string ''matrix''] [, string ''ChromaInPlacement''] [, string ''chromaresample''])|ConvertToYV12(clip [, bool ''interlaced''] [, string ''matrix''] [, string ''ChromaInPlacement''] [, string ''chromaresample''] [, string ''ChromaOutPlacement''])|ConvertToYV16(clip [, bool ''interlaced''] [, string ''matrix''] [, string ''ChromaInPlacement''] [, string ''chromaresample''])|ConvertToYV24(clip [, bool ''interlaced''] [, string ''matrix''] [, string ''ChromaInPlacement''] [, string ''chromaresample'']))}}
+
<div style="max-width:62em" >
 +
<div {{BlueBox2|40|0|3px solid purple}} >
 +
{{AvsPlusFullname}}<br>
 +
Up-to-date documentation: [https://avisynthplus.readthedocs.io/en/latest/avisynthdoc/corefilters/convert.html https://avisynthplus.readthedocs.io]
 +
</div>
  
== Colorformats ==
+
Convert between any of the color formats that AviSynth supports:
 
+
:{| class="wikitable"
The following formats can be converted to and from.
+
|-
 
+
! Color format&nbsp;
{| border="1"
+
! Image format&nbsp;
 +
! Bit depth&nbsp;
 +
! Sample ratio&nbsp;
 +
!style="text-align:left"| &nbsp;Description
 
|-  
 
|-  
! colorformats
+
| '''[[RGB24]]'''
! planar/interleaved
+
| [[Interleaved|interleaved]]
! chroma resolution
+
| 8
 +
| 4:4:4
 +
| (full chroma)
 
|-  
 
|-  
! [[RGB]]
+
| '''[[RGB32]]'''
 
| interleaved
 
| interleaved
| full chroma - 4:4:4
+
| 8
 +
| 4:4:4:4
 +
| (full chroma + alpha)
 +
|-  
 +
| '''[[YV24]]''' &diams;
 +
| planar
 +
| 8
 +
| 4:4:4
 +
| (full chroma)
 +
|-
 +
| '''[[YV16]]''' &diams;
 +
| planar
 +
| 8
 +
| 4:2:2
 +
| (chroma shared between 2 pixels)
 
|-  
 
|-  
! [[RGB24]]
+
| '''[[YUY2]]'''
 
| interleaved
 
| interleaved
| full chroma - 4:4:4
+
| 8
 +
| 4:2:2
 +
| (chroma shared between 2 pixels)
 
|-  
 
|-  
! [[RGB32]]
+
| '''[[YV12]]'''
 +
| planar
 +
| 8
 +
| 4:2:0
 +
| (chroma shared between 2x2 pixels)&nbsp;
 +
|-
 +
| '''[[YV411]]''' &diams;
 +
| planar
 +
| 8
 +
| 4:1:1
 +
| (chroma shared between 4 pixels)
 +
|-
 +
| '''[[Y8]]''' &diams;
 +
| (both)
 +
| 8
 +
| 4:0:0
 +
| (no chroma)
 +
|-
 +
!colspan="5" style="text-align:left; font-weight:normal;"|&nbsp; (&diams; = not supported in AviSynth version 2.58 or below)
 +
|}
 +
 
 +
{{AvsPluscon}} supports all of the above, plus:
 +
:{| class="wikitable"
 +
|-
 +
! Color format&nbsp;
 +
! Image format&nbsp;
 +
! Bit depth&nbsp;
 +
! Sample ratio&nbsp;
 +
!style="text-align:left"| &nbsp;Description
 +
|-
 +
| '''[[Avisynthplus_color_formats|RGB48]]'''
 
| interleaved
 
| interleaved
| full chroma - 4:4:4
+
| 16
 +
| 4:4:4
 +
| (full chroma)
 
|-  
 
|-  
! [[YUY2]]
+
| '''[[Avisynthplus_color_formats|RGB64]]'''
 
| interleaved
 
| interleaved
| chroma shared between 2 pixels - 4:2:2
+
| 16
 +
| 4:4:4:4
 +
| (full chroma + alpha)
 +
|-  
 +
| '''[[Avisynthplus_color_formats|RGBPxx]]'''
 +
| [[Planar|planar]]
 +
| 8-16, 32 *&nbsp;
 +
| 4:4:4
 +
| (full chroma)
 
|-  
 
|-  
! [[Y8]]
+
| '''[[Avisynthplus_color_formats|RGBAPxx]]'''
| planar/interleaved
+
| [[Planar|planar]]
| no chroma - 4:0:0
+
| 8-16, 32 *&nbsp;
 +
| 4:4:4:4
 +
| (full chroma + alpha)
 
|-  
 
|-  
! [[YV411]]
+
| '''[[Avisynthplus_color_formats|YUV444Pxx]]'''
 
| planar
 
| planar
| chroma shared between 4 pixels - 4:1:1
+
| 8-16, 32 *&nbsp;
 +
| 4:4:4
 +
| (full chroma)
 
|-  
 
|-  
! [[YV12]]
+
| '''[[Avisynthplus_color_formats|YUVA444Pxx]]'''
 
| planar
 
| planar
| chroma shared between 2x2 pixels - 4:2:0
+
| 8-16, 32 *&nbsp;
 +
| 4:4:4:4
 +
| (full chroma + alpha)
 
|-  
 
|-  
! [[YV16]]
+
| '''[[Avisynthplus_color_formats|YUV422Pxx]]'''
 
| planar
 
| planar
| chroma shared between 2 pixels - 4:2:2
+
| 8-16, 32 *&nbsp;
 +
| 4:2:2
 +
| (chroma shared between 2 pixels)
 
|-  
 
|-  
! [[YV24]]
+
| '''[[Avisynthplus_color_formats|YUVA422Pxx]]'''
 
| planar
 
| planar
| full chroma - 4:4:4
+
| 8-16, 32 *&nbsp;
 +
| 4:2:2:4
 +
| (chroma shared between 2 pixels + alpha)
 +
|-  
 +
| '''[[Avisynthplus_color_formats|YUV420Pxx]]'''
 +
| planar
 +
| 8-16, 32 *&nbsp;
 +
| 4:2:0
 +
| (chroma shared between 2x2 pixels)&nbsp;
 +
|-
 +
| '''[[Avisynthplus_color_formats|YUVA420Pxx]]'''
 +
| planar
 +
| 8-16, 32 *&nbsp;
 +
| 4:2:0:4
 +
| (chroma shared between 2x2 pixels + alpha)&nbsp;
 +
|-
 +
| '''[[Avisynthplus_color_formats|Y10..Y32]]'''
 +
| (both)
 +
| 10-16, 32 *&nbsp;
 +
| 4:0:0
 +
| (no chroma)
 +
|-
 +
!colspan="5" style="text-align:left; font-weight:normal;"|&nbsp; '''*''' 8-16 = ''8,10,12,14,16 bit integer;''&nbsp; 32 = ''32 bit float''
 
|}
 
|}
  
== Options ==
 
  
''matrix'': Default "Rec601". Does not apply to YUV-to-YUV or RGB-to-RGB conversions.
+
When the target format is the same as the source format, the original clip will be returned unchanged, except for the case of '''ConvertToYV12''' or '''ConvertToYV16''' (and high bit depth variants) where the {{FuncArg|ChromaInPlacement}} and {{FuncArg|ChromaOutPlacement}} parameters are different, or the target placement is different from the source chroma placement read from _ChromaLocation frame property.
*"Rec601" : Uses Rec.601 coefficients; scale full range [0..255] RGB to TV range [16..235] YUV, and TV range YUV to full range RGB.
+
*"Rec709" : Uses Rec.709 coefficients; scale full range [0..255] RGB to TV range [16..235] YUV, and TV range YUV to full range RGB.
+
*"PC.601" : Uses Rec.601 coefficients, keep source luma range.
+
*"PC.709" : Uses Rec.709 coefficients, keep source luma range.
+
*"AVERAGE" : Uses averaged coefficients, keep source luma range. (So the luma becomes the average of the RGB channels.)
+
  
''interlaced'': Default false. Use interlaced layout for YV12 conversions.
+
{{BlueBox}}
 +
There is no unique way of [[Color_conversions|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 [[Colorimetry#How_can_I_see_if_the_correct_standard_is_used_upon_playback.3F|'''here''']] for more)
 +
*Rec.601 should be used when your source is standard definition (usually defined as smaller than [[Wikipedia:720p|720p]]):
 +
:<code>ConvertToRGB(clip)</code> (using default "Rec601")
 +
*Rec.709 should be used when your source is DVD or HDTV:
 +
:<code>ConvertToRGB(clip, matrix="Rec709")</code>
 +
*The special-purpose matrices ''PC.601'' and ''PC.709'' keep the ''range'' unchanged,
 +
:instead of converting between 0{{D}}-255{{D}}&nbsp;RGB and 16{{D}}-235{{D}}&nbsp;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.
 +
{{End_BlueBox}}
  
''ChromaInPlacement'' (added in v2.60): This determines the chroma placement when converting from YV12. It can be "[[MPEG2]]" (default), "[[MPEG1]]" and "DV".  
+
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.
  
''chromaresample'' (added in v2.60): This determines which resizer is used in the conversion. It is used when the chroma resolution of the source and target is different. It can be all resamplers ("point", "bilinear", "bicubic", "lanczos", "lanczos4", "blackman", "spline16", "spline36", "spline64", "gauss" and "sinc"), default is "bicubic".
+
Use '''ConvertBackToYUY2''' to convert ''back'' to YUY2 with minimal color-blurring when you have previously applied a YUY2&rarr;RGB conversion.
  
''ChromaOutPlacement'' (added in v2.60): This determines the chroma placement when converting to YV12. It can be "[[MPEG2]]" (default), "[[MPEG1]]" and "DV".  
+
{{AvsPluscon}} See also [[ConvertBits]] to convert between bit depths and/or between full-limited range.
 +
</div>
  
AviSynth prior to v2.5 can deal internally with two color formats, RGB and YUY2. Starting from v2.50 AviSynth can also deal with a third color format, YV12. These six filters convert between them. If the video is already in the specified format, it will be passed through unchanged. (RGB is assumed throughout this doc to mean RGBA.) ConvertToRGB converts to RGB32 unless your clip is RGB24. If you need 24-bit RGB for some reason, use ConvertToRGB24 explicitly and ConvertToRGB32 to do the reverse.
+
__TOC__
  
In v2.60 the following additional formats are supported: Y8 greyscale (it is both planar and interleaved since it contains no chroma; 4:0:0), YV411 (planar; YUV 4:1:1), YV16 (a planar version of YUY2; 4:2:2) and YV24 (planar; YUV 4:4:4).
+
==== Syntax and Parameters ====
 +
<div style="max-width:62em" >
 +
===== ''RGB interleaved'' ===== __NOEDITSECTION__
 +
{{FuncDef
 +
|ConvertToRGB(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;float param1, float param2, float param3 {{AvsPluscon}} ] )
 +
}}<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>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 {{AvsPluscon}} ] )  
 +
}}<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>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 {{AvsPluscon}} ] )
 +
}} <br>
 +
{{FuncDef
 +
|ConvertToRGB48(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;float param1, float param2, float param3 ] ) {{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'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 ] ) {{AvsPluscon}}
 +
}}
  
Syntax and operation of ConvertToRGB24 are identical to ConvertToRGB, except that the output format is 24-bit; if the source is RGB32, the alpha channel will be stripped.
+
===== ''RGB planar'' ===== __NOEDITSECTION__
 +
{{FuncDef
 +
|ConvertToPlanarRGB(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;float param1, float param2, float param3 ] ) {{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'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 ] ) {{AvsPluscon}}
 +
}}
  
Since v2.51/v2.52 an optional interlaced parameter is added (interlaced=false is the default operation). When set to false it is assumed that clip is progressive, when set to true it is assumed that clip is interlaced. This option is added because for example (assuming clip is interlaced YV12):
+
===== ''YUV444'' ===== __NOEDITSECTION__
 +
{{FuncDef
 +
|ConvertToYV24(clip [, bool ''interlaced'', string ''matrix'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 {{AvsPluscon}} ] )  
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToYUV444(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;float param1, float param2, float param3 ] ) {{AvsPluscon}}
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToYUVA444(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;float param1, float param2, float param3 ] ) {{AvsPluscon}}
 +
}}
  
[[SeparateFields]](clip)
+
===== ''YUV422'' ===== __NOEDITSECTION__
  ConvertToYUY2()
+
{{FuncDef
  [[Weave]]()
+
|ConvertToYV16(clip [, bool ''interlaced'', string ''matrix'',  <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}} <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 {{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>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 {{AvsPluscon}} ] )
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToYUV422(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'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 ] ) {{AvsPluscon}}
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToYUVA422(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'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 ] ) {{AvsPluscon}}
 +
}}
  
is upsampled incorrectly. Instead it is better use:
+
{{FuncDef
 +
|ConvertBackToYUY2(clip [, string ''matrix'' ] )
 +
}}
  
  ConvertToYUY2(clip, interlaced=true)
+
===== ''YUV420'' ===== __NOEDITSECTION__
 +
{{FuncDef
 +
|ConvertToYV12(clip [, bool ''interlaced'', string ''matrix'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaOutPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 {{AvsPluscon}} ] )
 +
}} <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'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 ] ) {{AvsPluscon}}
 +
}} <br>
 +
{{FuncDef
 +
|ConvertToYUVA420(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'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 ] )  {{AvsPluscon}}
 +
}}
  
Note, the ''interlaced''=true setting only does something if the conversion YV12 <-> YUY2/RGB is requested, otherwise it's simply ignored. More about it can be found [[Interlaced fieldbased|here]].
+
===== ''YUV411'' ===== __NOEDITSECTION__
 +
{{FuncDef
 +
|ConvertToYV411(clip [, bool ''interlaced'', string ''matrix'',  <br>  
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3  {{AvsPluscon}}] )
 +
}} <br>
 +
|ConvertToYUV411(clip [, bool ''interlaced'', string ''matrix'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''ChromaInPlacement'',  <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;string ''chromaresample'', <br>
 +
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;float param1, float param2, float param3 ] )  {{AvsPluscon}}
 +
}}
  
When the target format is the same as the source format, the original clip will be returned. Except for the following situation: When both formats are YV12, the source clip will be processed when ''ChromaInPlacement'' and ''ChromaOutPlacement'' differ. So this can be used to change the chroma placement in a YV12 clip.
+
===== ''Y-only'' ===== __NOEDITSECTION__
 +
{{FuncDef
 +
|ConvertToY8(clip [, string ''matrix''] )
 +
}}<br>
 +
{{FuncDef
 +
|ConvertToY(clip, [ string ''matrix'' ] ) {{AvsPluscon}}
 +
}}
  
== Examples ==
+
==== Parameter Details ====
 +
{{HiddenH5|Matrix}}
 +
{{Par2|matrix|string|"Rec601"}}
 +
:Controls the colour coefficients and scaling factors used in RGB&harr;YUV conversions.
 +
:*"Rec601"&nbsp; : Uses Rec.601 coefficients; scale full range [0{{D}}..255{{D}}] RGB &harr; TV range [16{{D}}..235{{D}}] YUV.
 +
:*"Rec709"&nbsp; : Uses Rec.709 (HD) coefficients; scale full range RGB &harr; TV range YUV.
 +
:*"Rec2020" : Uses Rec.2020 (UHD) coefficients; scale full range RGB &harr; TV range YUV. {{AvsPluscon}}
 +
:*"PC.2020" : Uses Rec.2020 (UHD) coefficients; keep range unchanged. {{AvsPluscon}}
 +
:*"PC.601"&nbsp; : Uses Rec.601 coefficients; keep range unchanged.
 +
:*"PC.709"&nbsp; : Uses Rec.709 (HD) coefficients; keep range unchanged.
 +
:*"Average"&nbsp; : Uses averaged coefficients (the luma becomes the average of the RGB channels); keep range unchanged.
  
Contrary to what one might expect, there is no unique way of converting YUV to RGB. In AviSynth the two most common ones are implemented: Rec.601 and Rec.709 (named after their official specifications). Although it will not be correct in all cases, the following should be correct in most cases:
+
{{AvsPluscon}}
 +
:New syntax: more matrix string constants with separate full/limited range markers
 +
:"matrixname:full_or_limited" where
 +
:"matrixname" can be (internal _Matrix integer constant in parenthesys)
 +
::* "rgb" (0 - AVS_MATRIX_RGB)
 +
::* "709" (1 - AVS_MATRIX_BT709)
 +
::* "unspec" (2 - AVS_MATRIX_UNSPECIFIED)
 +
::* "170m" (6 - AVS_MATRIX_ST170_M)
 +
::* "240m" (7 - AVS_MATRIX_ST240_M)
 +
::* "470bg" (5 - AVS_MATRIX_BT470_BG)
 +
::* "601" (5 - AVS_MATRIX_BT470_BG)
 +
::* "fcc" (4 - AVS_MATRIX_BT470_M)
 +
::* "bt470m" (4 - AVS_MATRIX_BT470_M)
 +
::* "ycgco" (8 - AVS_MATRIX_YCGCO      not supported)
 +
::* "2020ncl" (9 - AVS_MATRIX_BT2020_NCL)
 +
::* "2020" (9 - AVS_MATRIX_BT2020_NCL)
 +
::* "2020cl" (10 - AVS_MATRIX_BT2020_CL  same as 2020ncl)
 +
::* "chromacl" (13 - AVS_MATRIX_CHROMATICITY_DERIVED_CL  not supported)
 +
::* "chromancl" (12 - AVS_MATRIX_CHROMATICITY_DERIVED_NCL not supported)
 +
::* "ictcp" (14 - AVS_MATRIX_ICTCP      not supported)
  
The first one (Rec.601) should be used when your source is DivX/XviD or some analogue capture:
+
:: The above "matrix" parameters can be followed by a "full" or "f" and "limited" or "l" or "auto" marker after a ":"<p>e.g. "709:l" means the same as the old "Rec709"</p>
 +
:: When there is no limited-ness marker, or is set to "auto" then value of _ColorRange frame property is used
  
ConvertToRGB(clip)
+
: Note: old-style "matrix" parameters are kept, their name indicate the full/limited, except "PC.601" and "PC.709".
  
The second one (Rec.709) should be used when your source is DVD or HDTV:
+
: For memo and the similar new string
 +
:*  "rec601" same as        "470bg:l"
 +
:*  "rec709"                "709:l"
 +
:*  "pc.601" and "pc601"    "470bg:f" but only if source has _ColorRange = 0 (full)
 +
:*  "pc.709" and "pc709"    "709:f" but only if source has _ColorRange = 0 (full) 
 +
:*  "average"                - kept for compatibility, really it has no standard _Matrix equivalent
 +
:*  "rec2020"                "2020cl:l"
 +
:*  "pc.2020" and "pc2020"  "2020cl:f" but only if source has _ColorRange = 0 (full)
  
ConvertToRGB(clip, matrix="rec709")
 
  
In v2.56, the reverse is also available, that is
 
  
  ConvertToYUY2(clip, matrix="rec709") or ConvertToYV12(clip, matrix="rec709")
+
{{HiddenH5|Interlaced}}
 +
{{Par2|interlaced|bool|false}}
 +
:If true, it is assumed that {{FuncArg|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):
 +
<div {{BoxWidthIndent|28|2}} >
 +
  [[SeparateFields]](clip)
 +
ConvertToYUY2
 +
[[Weave]]
 +
</div>
 +
:...is upsampled incorrectly. Instead it is better to use:
 +
<div {{BoxWidthIndent|28|2}} >
 +
ConvertToYUY2(clip, interlaced=true)
 +
</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''']].
  
In v2.56, ''matrix''="pc.601" (and ''matrix''="pc.709") enables you to do the RGB <-> YUV conversion while keeping the luma range, thus RGB [0,255] <-> YUV [0,255] (instead of the usual/default RGB [0,255] <-> YUV [16,235]).
+
{{HiddenH5|Chroma placement}}
 +
{{Par2|ChromaInPlacement|string|"MPEG2"}}
 +
{{Par2|ChromaOutPlacement|string|"MPEG2"}}
 +
:{{FuncArg|ChromaInPlacement}} determines the chroma placement in the clip when converting ''from'' YV12 (4:2:0) or YV16 (4:2:2) {{AvsPluscon}}.
 +
:{{FuncArg|ChromaOutPlacement}} determines the chroma placement in the clip when converting ''to'' YV12 (4:2:0) or YV16 (4:2:2) {{AvsPluscon}}.
 +
:The placement can be one of these strings:
 +
:{|class="wikitable" width="600"
 +
|-
 +
|"MPEG2"&nbsp; ( {{AvsPluscon}} synonyms: "left")
 +
|Subsampling used in MPEG-2 4:2:''x'' and most other formats. Chroma samples are located on the left pixel column of the group&nbsp;(default).
 +
|-
 +
|"MPEG1" ( {{AvsPluscon}} synonyms: "jpeg", "center")
 +
|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.
 +
|-
 +
|"top_left"&nbsp; {{AvsPluscon}}
 +
|Subsampling used in UHD 4:2:0. Chroma samples are located on the top left pixel column of the group&nbsp;.
 +
|-
 +
|"bottom_left"&nbsp; {{AvsPluscon}}
 +
|4:2:0 only
 +
|-
 +
|"bottom"&nbsp; {{AvsPluscon}}
 +
|4:2:0 only
 +
|-
 +
|}
  
All [[VirtualDub]] filters (loaded with [[Plugins|LoadVirtualdubPlugin]]) support ''only'' [[RGB32]] input.
+
{{HiddenH5|Chroma resample}}
 +
{{Par2|chromaresample|string|"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 [[Resize|resizers]] are allowed ("point", "bilinear", "bicubic", "lanczos", "lanczos4", "blackman", "spline16", "spline36", "spline64", "gauss", "sinc", "sinpow", "sinclin2" and "userdefined2"). Default is "bicubic". Latter three is for {{AvsPluscon}}.
  
If you try to use any of these filters with RGB input, you will get an error. Putting ConvertToYUY2 just before the offending filter should resolve the problem. All AviSynth filters support YUY2 input.
 
  
Conversion back and forth is not lossless, so use as few conversions as possible. If multiple conversions are necessary, use ConvertBackToYUY2() to convert back to YUY2, when you applied a YUY2->RGB conversion prior to that in your script. This will reduce color-blurring, but there are still some precision lost.
+
{{HiddenH5|Chroma resampler parameters}}
 +
{{Par2|param1|float|default depends on resampler type}}
 +
{{Par2|param2|float|default depends on resampler type}}
 +
{{Par2|param3|float|default depends on resampler type}}
  
In most cases, the ConvertToRGB filter should not be necessary. If AviSynth's output is in YUY2 format and an application expects RGB, the system will use the installed YUY2 codec to make the conversion. However, if there's no installed YUY2 codec, or if (as is the case with ATI's YUY2 codec) the codec converts from YUY2 to RGB incorrectly, you can use Avisynth's built-in filter to convert instead.
+
:These 'float' type parameters can be the additional parameters for the chroma resamplers. Some resizer algorithms would need and can be fine tuned with up to 3 parameters. Their default values depend on the selected chromaresample resizer kernel,
  
== Conversion paths ==
 
  
* The ''ChromaInPlacement'', ''chromaresample'' and ''ChromaOutPlacement'' options are only used in the 'planar conversion part' of the conversion path, and they process the chroma of the clip.
+
==== Notes ====
 +
<div style="max-width:62em" >
 +
===== Frame properties {{AvsPluscon}} =====
  
In v2.60 the following conversion paths occur
+
In Avisynth v3.7.1. frame property (_ChromaLocation) support appears in selected filters (e.g. ConvertToYUV422).
 +
Property can be read and/or set.
 +
A frame property can replace default behaviour of location parameters and is set (or deleted) upon finishing conversion.
 +
Since a format without subsampling such as 4:4:4 (YV24) does not have chroma location, the property is deleted automatically when converting to 4:4:4 or RGB.
  
* YUV planar -> RGB via YV24
+
: "ChromaInLocation" rules:
* YUV planar -> YUY2 via YV16 (except for YV12 and parameters ''ChromaInPlacement''/''chromaresample''/''ChromaOutPlacement'' not explicitly set", in that case there is a direct conversion from YV12 to YUY2)
+
::* if source has _ChromaLocation frame property it will be used else the default is "mpeg2" ("left")
* RGB -> YUV planar via YV24
+
::* if parameter is "auto" or not given at all, ChromaInLocation will be set to the above mentioned default value
* YUY2 -> YUV planar via YV16 (except for YV12 and parameters ''ChromaInPlacement''/''chromaresample''/''ChromaOutPlacement'' not explicitly set", in that case there is a direct conversion from YUY2 to YV12)
+
::* if parameter is explicitely given, it will be used
  
Suppose you have a YUY2 clip for example and you convert it to YV24. The YUY2 will be converted to YV16 first without applying ''ChromaInPlacement'', ''chromaresample'' and ''ChromaOutPlacement''. Then YV16 will be converted to YV24 while applying ''chromaresample''. ''ChromaInPlacement'' and ''ChromaOutPlacement'' won't be used since YV12 is not involved.
+
: "ChromaOutLocation" rules:
 +
::* default is "mpeg2" ("left")
 +
::* if parameter is "auto" or not given at all, ChromaOutLocation will be set to the above mentioned default value
 +
::* if parameter is explicitely given, it will be used
  
== Sampling ==
+
: Accepted values for "ChromaInLocation" and "ChromaOutLocation" (when source/target is a chroma subsampled format)
 +
: (full list):
 +
::* "left" or "mpeg2"
 +
::* "center" or "jpeg" or "mpeg1"
 +
::* "top_left"
 +
::* "dv"
 +
::* "top"
 +
::* "bottom_left"
 +
::* "bottom"
  
[[Sampling|This page]] covers the sampling methods and color formats in more detail.
+
: _ChromaLocation constants - as seen in propShow()
 +
 
 +
::* AVS_CHROMA_LEFT        = 0
 +
::* AVS_CHROMA_CENTER      = 1
 +
::* AVS_CHROMA_TOP_LEFT    = 2 (4:2:0 only)
 +
::* AVS_CHROMA_TOP        = 3 (4:2:0 only)
 +
::* AVS_CHROMA_BOTTOM_LEFT = 4 (4:2:0 only)
 +
::* AVS_CHROMA_BOTTOM      = 5 (4:2:0 only)
 +
::* AVS_CHROMA_DV          = 6  Special to Avisynth
  
== Color conversions ==
+
===== Conversion paths =====
  
[[Color_conversions|This page]] covers the color conversions, "YUV <-> RGB", in more detail.
+
:In v2.60 the following conversion paths occur:
 +
:* YUV planar &rarr; RGB via YV24
 +
:* YUV planar &rarr; 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 &rarr; YUV planar via YV24
 +
:* YUY2 &rarr; 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)
  
== Changelog ==
+
: The chroma options {{FuncArg|chromaresample}}, {{FuncArg|ChromaInPlacement}} and {{FuncArg|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 {{FuncArg|chromaresample}}. Since YV12 is not involved, {{FuncArg|ChromaInPlacement}} and {{FuncArg|ChromaOutPlacement}} won't be used.
 +
 
 +
===== Sampling =====
 +
 
 +
:[[Sampling|'''[This page]''']] covers the sampling methods and color formats in more detail.
 +
 
 +
===== Color conversions =====
 +
 
 +
:[[Color_conversions|'''[This page]''']] covers the color conversions in more detail.
 +
</div>
 +
 
 +
==== Changelog ====
 +
<div style="max-width:62em" >
 
{| border="1"
 
{| border="1"
 +
|-
 +
| v3.7.3
 +
| Added "sinpow", "sinclin2" and "userdefined2" to chromaresampler options<br>Add "param1", "param2" and "param3" to ConvertToXXXX where 'chromaresample' exists (b,c,s,taps and p parameters can be set, depending on the resizer.)<br>Add ConvertToYUVA420, ConvertToYUVA422, ConvertToYUVA444
 +
|-
 +
| v3.7.1
 +
| Added ChromaOutPlacement to 4:2:2 related functions<br>Added new matrix constants, optional new syntax<br>Added new chroma location constants<br>Added _ChromaLocation frame property
 
|-  
 
|-  
 
| v2.60
 
| v2.60
Line 141: Line 495:
 
| Added ConvertToYV12.
 
| Added ConvertToYV12.
 
|}
 
|}
 +
</div>
  
  
 
[[Category:Internal filters]]
 
[[Category:Internal filters]]
 +
[[Category:Colourspace_Conversion]]

Latest revision as of 13:04, 19 December 2024

AviSynth+
Up-to-date documentation: https://avisynthplus.readthedocs.io

Convert between any of the color formats that AviSynth supports:

Color format  Image format  Bit depth  Sample ratio   Description
RGB24 interleaved 8 4:4:4 (full chroma)
RGB32 interleaved 8 4:4:4:4 (full chroma + alpha)
YV24 planar 8 4:4:4 (full chroma)
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) 
YV411 planar 8 4:1:1 (chroma shared between 4 pixels)
Y8 (both) 8 4:0:0 (no chroma)
  (♦ = not supported in AviSynth version 2.58 or below)

AVS+ supports all of the above, plus:

Color format  Image format  Bit depth  Sample ratio   Description
RGB48 interleaved 16 4:4:4 (full chroma)
RGB64 interleaved 16 4:4:4:4 (full chroma + alpha)
RGBPxx planar 8-16, 32 *  4:4:4 (full chroma)
RGBAPxx planar 8-16, 32 *  4:4:4:4 (full chroma + alpha)
YUV444Pxx planar 8-16, 32 *  4:4:4 (full chroma)
YUVA444Pxx planar 8-16, 32 *  4:4:4:4 (full chroma + alpha)
YUV422Pxx planar 8-16, 32 *  4:2:2 (chroma shared between 2 pixels)
YUVA422Pxx planar 8-16, 32 *  4:2:2:4 (chroma shared between 2 pixels + alpha)
YUV420Pxx planar 8-16, 32 *  4:2:0 (chroma shared between 2x2 pixels) 
YUVA420Pxx planar 8-16, 32 *  4:2:0:4 (chroma shared between 2x2 pixels + alpha) 
Y10..Y32 (both) 10-16, 32 *  4:0:0 (no chroma)
  * 8-16 = 8,10,12,14,16 bit integer;  32 = 32 bit float


When the target format is the same as the source format, the original clip will be returned unchanged, except for the case of ConvertToYV12 or ConvertToYV16 (and high bit depth variants) where the ChromaInPlacement and ChromaOutPlacement parameters are different, or the target placement is different from the source chroma placement read from _ChromaLocation frame property.

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 0d-255d RGB and 16d-235d 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 and/or between full-limited range.

Contents


Syntax and Parameters

RGB interleaved

ConvertToRGB(clip [, string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 AVS+ ] )

ConvertToRGB24(clip [, string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 AVS+ ] )

ConvertToRGB32(clip [, string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 AVS+ ] )

ConvertToRGB48(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 ] ) AVS+

ConvertToRGB64(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 ] ) AVS+

RGB planar

ConvertToPlanarRGB(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 ] ) AVS+

ConvertToPlanarRGBA(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 ] ) AVS+

YUV444

ConvertToYV24(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 AVS+ ] )

ConvertToYUV444(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 ] ) AVS+

ConvertToYUVA444(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 ] ) AVS+

YUV422

ConvertToYV16(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample,
     string ChromaOutPlacement, AVS+
     float param1, float param2, float param3 AVS+ ] )

ConvertToYUY2(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 AVS+ ] )

ConvertToYUV422(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     string ChromaOutPlacement,
     float param1, float param2, float param3 ] ) AVS+

ConvertToYUVA422(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     string ChromaOutPlacement,
     float param1, float param2, float param3 ] ) AVS+

ConvertBackToYUY2(clip [, string matrix ] )

YUV420

ConvertToYV12(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample,
     string ChromaOutPlacement,
     float param1, float param2, float param3 AVS+ ] )

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

ConvertToYUVA420(clip, [ string matrix, bool interlaced,
     string ChromaInPlacement,
     string chromaresample,
     string ChromaOutPlacement,
     float param1, float param2, float param3 ] ) AVS+

YUV411

ConvertToYV411(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 AVS+] )

|ConvertToYUV411(clip [, bool interlaced, string matrix,
     string ChromaInPlacement,
     string chromaresample,
     float param1, float param2, float param3 ] ) AVS+ }}

Y-only

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

Parameter Details

Matrix

string  matrix = "Rec601"

Controls the colour coefficients and scaling factors used in RGB↔YUV conversions.
  • "Rec601"  : Uses Rec.601 coefficients; scale full range [0d..255d] RGB ↔ TV range [16d..235d] YUV.
  • "Rec709"  : Uses Rec.709 (HD) coefficients; scale full range RGB ↔ TV range YUV.
  • "Rec2020" : Uses Rec.2020 (UHD) coefficients; scale full range RGB ↔ TV range YUV. AVS+
  • "PC.2020" : Uses Rec.2020 (UHD) coefficients; keep range unchanged. AVS+
  • "PC.601"  : Uses Rec.601 coefficients; keep range unchanged.
  • "PC.709"  : Uses Rec.709 (HD) coefficients; keep range unchanged.
  • "Average"  : Uses averaged coefficients (the luma becomes the average of the RGB channels); keep range unchanged.

AVS+

New syntax: more matrix string constants with separate full/limited range markers
"matrixname:full_or_limited" where
"matrixname" can be (internal _Matrix integer constant in parenthesys)
  • "rgb" (0 - AVS_MATRIX_RGB)
  • "709" (1 - AVS_MATRIX_BT709)
  • "unspec" (2 - AVS_MATRIX_UNSPECIFIED)
  • "170m" (6 - AVS_MATRIX_ST170_M)
  • "240m" (7 - AVS_MATRIX_ST240_M)
  • "470bg" (5 - AVS_MATRIX_BT470_BG)
  • "601" (5 - AVS_MATRIX_BT470_BG)
  • "fcc" (4 - AVS_MATRIX_BT470_M)
  • "bt470m" (4 - AVS_MATRIX_BT470_M)
  • "ycgco" (8 - AVS_MATRIX_YCGCO not supported)
  • "2020ncl" (9 - AVS_MATRIX_BT2020_NCL)
  • "2020" (9 - AVS_MATRIX_BT2020_NCL)
  • "2020cl" (10 - AVS_MATRIX_BT2020_CL same as 2020ncl)
  • "chromacl" (13 - AVS_MATRIX_CHROMATICITY_DERIVED_CL not supported)
  • "chromancl" (12 - AVS_MATRIX_CHROMATICITY_DERIVED_NCL not supported)
  • "ictcp" (14 - AVS_MATRIX_ICTCP not supported)
The above "matrix" parameters can be followed by a "full" or "f" and "limited" or "l" or "auto" marker after a ":"

e.g. "709:l" means the same as the old "Rec709"

When there is no limited-ness marker, or is set to "auto" then value of _ColorRange frame property is used
Note: old-style "matrix" parameters are kept, their name indicate the full/limited, except "PC.601" and "PC.709".
For memo and the similar new string
  • "rec601" same as "470bg:l"
  • "rec709" "709:l"
  • "pc.601" and "pc601" "470bg:f" but only if source has _ColorRange = 0 (full)
  • "pc.709" and "pc709" "709:f" but only if source has _ColorRange = 0 (full)
  • "average" - kept for compatibility, really it has no standard _Matrix equivalent
  • "rec2020" "2020cl:l"
  • "pc.2020" and "pc2020" "2020cl:f" but only if source has _ColorRange = 0 (full)


Interlaced

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.
Chroma placement

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

ChromaInPlacement determines the chroma placement in the clip when converting from YV12 (4:2:0) or YV16 (4:2:2) AVS+.
ChromaOutPlacement determines the chroma placement in the clip when converting to YV12 (4:2:0) or YV16 (4:2:2) AVS+.
The placement can be one of these strings:
"MPEG2"  ( AVS+ synonyms: "left") 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" ( AVS+ synonyms: "jpeg", "center") 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.
"top_left"  AVS+ Subsampling used in UHD 4:2:0. Chroma samples are located on the top left pixel column of the group .
"bottom_left"  AVS+ 4:2:0 only
"bottom"  AVS+ 4:2:0 only
Chroma resample

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", "sinc", "sinpow", "sinclin2" and "userdefined2"). Default is "bicubic". Latter three is for AVS+.


Chroma resampler parameters

float  param1 = default depends on resampler type
float  param2 = default depends on resampler type
float  param3 = default depends on resampler type

These 'float' type parameters can be the additional parameters for the chroma resamplers. Some resizer algorithms would need and can be fine tuned with up to 3 parameters. Their default values depend on the selected chromaresample resizer kernel,


Notes

Frame properties AVS+

In Avisynth v3.7.1. frame property (_ChromaLocation) support appears in selected filters (e.g. ConvertToYUV422). Property can be read and/or set. A frame property can replace default behaviour of location parameters and is set (or deleted) upon finishing conversion. Since a format without subsampling such as 4:4:4 (YV24) does not have chroma location, the property is deleted automatically when converting to 4:4:4 or RGB.

"ChromaInLocation" rules:
  • if source has _ChromaLocation frame property it will be used else the default is "mpeg2" ("left")
  • if parameter is "auto" or not given at all, ChromaInLocation will be set to the above mentioned default value
  • if parameter is explicitely given, it will be used
"ChromaOutLocation" rules:
  • default is "mpeg2" ("left")
  • if parameter is "auto" or not given at all, ChromaOutLocation will be set to the above mentioned default value
  • if parameter is explicitely given, it will be used
Accepted values for "ChromaInLocation" and "ChromaOutLocation" (when source/target is a chroma subsampled format)
(full list):
  • "left" or "mpeg2"
  • "center" or "jpeg" or "mpeg1"
  • "top_left"
  • "dv"
  • "top"
  • "bottom_left"
  • "bottom"
_ChromaLocation constants - as seen in propShow()
  • AVS_CHROMA_LEFT = 0
  • AVS_CHROMA_CENTER = 1
  • AVS_CHROMA_TOP_LEFT = 2 (4:2:0 only)
  • AVS_CHROMA_TOP = 3 (4:2:0 only)
  • AVS_CHROMA_BOTTOM_LEFT = 4 (4:2:0 only)
  • AVS_CHROMA_BOTTOM = 5 (4:2:0 only)
  • AVS_CHROMA_DV = 6 Special to Avisynth
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

v3.7.3 Added "sinpow", "sinclin2" and "userdefined2" to chromaresampler options
Add "param1", "param2" and "param3" to ConvertToXXXX where 'chromaresample' exists (b,c,s,taps and p parameters can be set, depending on the resizer.)
Add ConvertToYUVA420, ConvertToYUVA422, ConvertToYUVA444
v3.7.1 Added ChromaOutPlacement to 4:2:2 related functions
Added new matrix constants, optional new syntax
Added new chroma location constants
Added _ChromaLocation frame property
v2.60 Added ConvertToY8, ConvertToYV411, ConvertToYV16, ConvertToYV24, ChromaInPlacement, ChromaOutPlacement, chromaresample, matrix="AVERAGE".
v2.50 Added ConvertToYV12.
Personal tools