Limiter

From Avisynth wiki
(Difference between revisions)
Jump to: navigation, search
m (one more touch-up)
(Swapped "autoscale" with paramscale which is the right parameter for scaling values automaticaly inside Limiter())
 
(8 intermediate revisions by 3 users not shown)
Line 1: Line 1:
The standard known as Rec.601 or [[Wikipedia:Rec._601|CCIR-601]] (''Studio Encoding Parameters of Digital Television...'') defines standard quantization levels: for luminance, black is '''16''' and peak white is '''235'''. For chrominance, the range is '''16''' to '''240''', or 128±112. "The signal may occasionally excurse beyond" this range according to Rec.601.<sup>[http://www.itu.int/rec/R-REC-BT.601/ BT.601-7] (Annex 1, Table 3)</sup>
+
<div style="max-width:62em" >
 +
The standard known as Rec.601 or [[Wikipedia:Rec._601|CCIR-601]] (''Studio Encoding Parameters of Digital Television...'') defines standard quantization levels: for luminance, black is '''16''' and peak white is '''235'''. This is the normal luminance range. For chrominance, the range is '''16''' to '''240''', or 128±112. "The signal may occasionally excurse beyond" these ranges according to Rec.601.<sup>[http://www.itu.int/rec/R-REC-BT.601/ BT.601-7] (Annex 1, Table 3)</sup>
  
Luminance or chrominance values outside this range are [http://forum.doom9.org/showthread.php?p=1108323#post1108323 known to cause problems with some TV sets], so '''Limiter''' was created to ''clip'' them (or [[Talk:Levels#Clamping_vs._Clipping|''clamp'']] them - both terms are used) to the ranges [{{FuncArg|min_luma}}''', '''{{FuncArg|max_luma}}] and [{{FuncArg|min_chroma}}''', '''{{FuncArg|max_chroma}}], which you may specify, but by default are the Rec.601 values listed above.  
+
Luminance or chrominance values outside their ranges are [http://forum.doom9.org/showthread.php?p=1108323#post1108323 known to cause problems with some TV sets], so '''Limiter''' was created to ''clip'' them (or [[Talk:Levels#Clamping_vs._Clipping|''clamp'']] them - both terms are used) to the ranges [{{FuncArg|min_luma}}''', '''{{FuncArg|max_luma}}] and [{{FuncArg|min_chroma}}''', '''{{FuncArg|max_chroma}}], which you may specify, but by default are the Rec.601 values listed above.  
  
 
'''Limiter''' can also colorize out-of-range pixels (with {{FuncArg|show}}) to warn of a potential  problem. See the [[#Examples|example images]] below. Naturally, this option should not be enabled for final output.
 
'''Limiter''' can also colorize out-of-range pixels (with {{FuncArg|show}}) to warn of a potential  problem. See the [[#Examples|example images]] below. Naturally, this option should not be enabled for final output.
 +
 +
{{AvsPluscon}} By default all parameters are ''non''-[[Autoscale_parameter|autoscaling]] &ndash; they must be scaled to the target bit depth.<br>
 +
By using parameter ''paramscale'' the range parameters are treated to be of 8 bits range and will be scaled to the current bit depth automatically
 +
</div>
 +
 
__TOC__
 
__TOC__
  
 
== Syntax and Parameters ==
 
== Syntax and Parameters ==
 +
<div style="max-width:62em" >
 
{{Template:FuncDef
 
{{Template:FuncDef
|Limiter(clip ''clip'' [, int ''min_luma'', int ''max_luma'', int ''min_chroma'', int ''max_chroma'', string show ] )
+
|Limiter(clip ''clip'' [, int ''min_luma'', int ''max_luma'', int ''min_chroma'', int ''max_chroma'', string ''show'' ] )
 +
}}
 +
<br>{{Template:FuncDef
 +
|{{AvsPluscon}} Limiter(clip ''clip'' [, float ''min_luma'', float ''max_luma'', float ''min_chroma'', float ''max_chroma'', string ''show'', bool ''paramscale'' ] )
 
}}
 
}}
  
 
:{{Par2|clip|clip|(required)}}
 
:{{Par2|clip|clip|(required)}}
 
::Source clip. [[YUV]] only.
 
::Source clip. [[YUV]] only.
 +
::{{AvsPluscon}} also supports [[YUVA]].
  
:{{Par2|min_luma|int|16}}
+
:{{Par2|min_luma|int|16{{Template:D}}}}
::''Y'' (luma) lower clamping limit.
+
::''Y'' (luma) lower bound.
  
:{{Par2|max_luma|int|235}}
+
:{{Par2|max_luma|int|235{{Template:D}}}}
::''Y'' (luma) upper clamping limit.
+
::''Y'' (luma) upper bound.
  
 
:{{Par2|min_chroma|int|16}}
 
:{{Par2|min_chroma|int|16}}
::''U'' & ''V'' (chroma) lower clamping limit.
+
::''U'' & ''V'' (chroma) lower bound.
  
:{{Par2|max_chroma|int|240}}
+
:{{Par2|max_chroma|int|240{{Template:D}}}}
::''U'' & ''V'' (chroma) upper clamping limit.
+
::''U'' & ''V'' (chroma) upper bound.
  
 
:{{Par2|show|string|(empty)}}
 
:{{Par2|show|string|(empty)}}
Line 55: Line 66:
 
|-
 
|-
 
|
 
|
! style="text-align:left;width:12em;"|{{FuncArg|show}}="luma"
+
! style="text-align:left;width:12em;"|&nbsp;{{FuncArg|show}}="luma"
! style="text-align:left;width:12em;"|{{FuncArg|show}}="luma_grey"
+
! style="text-align:left;width:12em;"|&nbsp;{{FuncArg|show}}="luma_grey"
 
|-  
 
|-  
 
| ''Y''j < {{FuncArg|min_luma}}
 
| ''Y''j < {{FuncArg|min_luma}}
| red (pj)
+
| &nbsp;{{BoldColor|#FF0000|120|&diams;}} red (pj)
| red (pj)
+
| &nbsp;{{BoldColor|#FF0000|120|&diams;}} red (pj)
 
|-  
 
|-  
 
| ''Y''j > {{FuncArg|max_luma}}
 
| ''Y''j > {{FuncArg|max_luma}}
| green (pj)
+
| &nbsp;{{BoldColor|#00FF00|120|&diams;}} green (pj)
| green (pj)
+
| &nbsp;{{BoldColor|#00FF00|120|&diams;}} green (pj)
 
|-  
 
|-  
 
| ''Y''j < {{FuncArg|min_luma}}&nbsp;and ''Y''k&nbsp;>&nbsp;{{FuncArg|max_luma}}
 
| ''Y''j < {{FuncArg|min_luma}}&nbsp;and ''Y''k&nbsp;>&nbsp;{{FuncArg|max_luma}}
| yellow (pj and pk)
+
| &nbsp;{{BoldColor|#FFFF00|120|&diams;}} yellow (pj and pk)
| puke (pj), olive (pk)
+
| &nbsp;{{BoldColor|#555501|120|&diams;}}&nbsp;puke&nbsp;(pj) {{BoldColor|#A0A04A|120|&diams;}}&nbsp;olive&nbsp;(pk)
 
|-
 
|-
 
|
 
|
! style="text-align:left;"|{{FuncArg|show}}="chroma"
+
! style="text-align:left;"|&nbsp;{{FuncArg|show}}="chroma"
! style="text-align:left;"|{{FuncArg|show}}="chroma_grey"
+
! style="text-align:left;"|&nbsp;{{FuncArg|show}}="chroma_grey"
 
|-  
 
|-  
 
| ''U'' < {{FuncArg|min_chroma}}
 
| ''U'' < {{FuncArg|min_chroma}}
| yellow
+
| rowspan="8"|&nbsp;{{BoldColor|#FFFF00|120|&diams;}} yellow
| yellow
+
| &nbsp;{{BoldColor|#FFFF00|120|&diams;}} yellow
 
|-  
 
|-  
 
| ''U'' > {{FuncArg|max_chroma}}
 
| ''U'' > {{FuncArg|max_chroma}}
| yellow
+
| &nbsp;{{BoldColor|#0000FF|120|&diams;}} blue
| blue
+
 
|-  
 
|-  
 
| ''V'' < {{FuncArg|min_chroma}}
 
| ''V'' < {{FuncArg|min_chroma}}
| yellow
+
| &nbsp;{{BoldColor|#00FFFF|120|&diams;}} cyan
| cyan
+
 
|-  
 
|-  
 
| ''V'' > {{FuncArg|max_chroma}}
 
| ''V'' > {{FuncArg|max_chroma}}
| yellow
+
| &nbsp;{{BoldColor|#FF0000|120|&diams;}} red
| red
+
 
|-  
 
|-  
 
| ''U'' < {{FuncArg|min_chroma}}&nbsp;and ''V''&nbsp;<&nbsp;{{FuncArg|min_chroma}}
 
| ''U'' < {{FuncArg|min_chroma}}&nbsp;and ''V''&nbsp;<&nbsp;{{FuncArg|min_chroma}}
| yellow
+
| &nbsp;{{BoldColor|#00FF00|120|&diams;}} green
| green
+
 
|-  
 
|-  
 
| ''U'' > {{FuncArg|max_chroma}}&nbsp;and ''V''&nbsp;<&nbsp;{{FuncArg|min_chroma}}
 
| ''U'' > {{FuncArg|max_chroma}}&nbsp;and ''V''&nbsp;<&nbsp;{{FuncArg|min_chroma}}
| yellow
+
| &nbsp;{{BoldColor|#008080|120|&diams;}} teal
| teal
+
 
|-  
 
|-  
 
| ''U'' < {{FuncArg|min_chroma}}&nbsp;and ''V''&nbsp;>&nbsp;{{FuncArg|max_chroma}}
 
| ''U'' < {{FuncArg|min_chroma}}&nbsp;and ''V''&nbsp;>&nbsp;{{FuncArg|max_chroma}}
| yellow
+
| &nbsp;{{BoldColor|#FFA500|120|&diams;}} orange
| orange
+
 
|-  
 
|-  
 
| ''U'' > {{FuncArg|max_chroma}}&nbsp;and ''V''&nbsp;>&nbsp;{{FuncArg|max_chroma}}
 
| ''U'' > {{FuncArg|max_chroma}}&nbsp;and ''V''&nbsp;>&nbsp;{{FuncArg|max_chroma}}
| yellow
+
| &nbsp;{{BoldColor|#FF00FF|120|&diams;}} magenta
| magenta
+
 
|}
 
|}
 +
</div>
 +
 +
:{{AvsPluscon}} {{Par2|paramscale|bool|false}}
 +
:: If set, minimum/maximum luma/chroma values are treated as they were in 8 bit range (but non-integer values are allowed), limiter will autoscale them to the current bit depth of the clip.
 +
:: Conversion uses the bit-shift method for integer bit depth conversion (from 8 to 8-16 bits). For 32 bit float clips the conversion is value/255.0 for Y (luma) channel and (value-128)/255.0 for U/V chroma channels. Do not use paramscale when you want to limit 32 bit float chroma exactly to +/-0.5, give the parameters directly instead.
 +
::Default: does not scale at all, parameters are used as-is. Parameters now are of float type to handle 32 bit float values..
  
  
Line 114: Line 124:
 
  [[FFmpegSource|FFmpegSource2]]("[http://www.sintel.org/ sintel].mp4")
 
  [[FFmpegSource|FFmpegSource2]]("[http://www.sintel.org/ sintel].mp4")
 
  [[Trim]](4685, 4685)
 
  [[Trim]](4685, 4685)
[[ColorYUV]](analyze=true)
 
|-
 
|[[File:Limit_Ex01.jpg]]
 
|}
 
 
:{|
 
| style="margin:0.5em;"|
 
 
  # 2. Exaggerated luma and chroma range
 
  # 2. Exaggerated luma and chroma range
[...]
 
 
  [[Levels]](16, 1.0, 255-16, 0, 255, coring=false)
 
  [[Levels]](16, 1.0, 255-16, 0, 255, coring=false)
 
  [[Tweak]](sat=2.0, coring=false)
 
  [[Tweak]](sat=2.0, coring=false)
 +
# (''insert Limiter here'')
 
  ColorYUV(analyze=true)
 
  ColorYUV(analyze=true)
 
|-
 
|-
Line 169: Line 172:
 
|[[File:Limit_Ex06.jpg]]
 
|[[File:Limit_Ex06.jpg]]
 
|}
 
|}
 +
 +
:{|
 +
| style="margin:0.5em;"|
 +
# 7. Putting it all together
 +
[...]
 +
[[StackHorizontal]](
 +
\    Last
 +
\  , [[StackVertical]](
 +
\      [[Histogram]]("levels", 0.5).[[Crop]](Width, 0, 256, 256).[[AddBorders]](0, 0, 0, Height/2-256)
 +
\    , Histogram("color2"    ).Crop(Width, 0, 256, 256).AddBorders(0, 0, 0, Height/2-256)
 +
\    )
 +
\  , StackVertical(
 +
\      [[BicubicResize]](Width/2, Height/2).Limiter(16, 235, 16, 240, "luma_grey")
 +
\    , BicubicResize(Width/2, Height/2).Limiter(16, 235, 16, 240, "chroma_grey")
 +
\    )
 +
\ )
 +
|-
 +
|[[File:Limit_Ex07a.png|768px]]
 +
|}
 +
  
 
== Changes ==
 
== Changes ==
 
{| border="1"
 
{| border="1"
 +
|-
 +
| {{AvsPluscon}} r2724
 +
| Added support for float.
 +
Added ''paramscale''
 +
|-
 +
| {{AvsPluscon}}
 +
| Added support for 8-16bit color spaces.
 
|-  
 
|-  
 
| v2.60
 
| v2.60

Latest revision as of 13:15, 25 September 2020

The standard known as Rec.601 or CCIR-601 (Studio Encoding Parameters of Digital Television...) defines standard quantization levels: for luminance, black is 16 and peak white is 235. This is the normal luminance range. For chrominance, the range is 16 to 240, or 128±112. "The signal may occasionally excurse beyond" these ranges according to Rec.601.BT.601-7 (Annex 1, Table 3)

Luminance or chrominance values outside their ranges are known to cause problems with some TV sets, so Limiter was created to clip them (or clamp them - both terms are used) to the ranges [min_luma, max_luma] and [min_chroma, max_chroma], which you may specify, but by default are the Rec.601 values listed above.

Limiter can also colorize out-of-range pixels (with show) to warn of a potential problem. See the example images below. Naturally, this option should not be enabled for final output.

AVS+ By default all parameters are non-autoscaling – they must be scaled to the target bit depth.
By using parameter paramscale the range parameters are treated to be of 8 bits range and will be scaled to the current bit depth automatically

Contents


[edit] Syntax and Parameters

Limiter(clip clip [, int min_luma, int max_luma, int min_chroma, int max_chroma, string show ] )
AVS+ Limiter(clip clip [, float min_luma, float max_luma, float min_chroma, float max_chroma, string show, bool paramscale ] )

clip  clip = (required)
Source clip. YUV only.
AVS+ also supports YUVA.
int  min_luma = 16d
Y (luma) lower bound.
int  max_luma = 235d
Y (luma) upper bound.
int  min_chroma = 16
U & V (chroma) lower bound.
int  max_chroma = 240d
U & V (chroma) upper bound.
string  show = (empty)
Colorizes the pixels outside the specified [min_X, max_X] range.
If set, show must take one of the following values:
show Effect
"luma" colorizes out of bound luma
"luma_grey" colorizes out of bound luma, and makes the remaining pixels grey
"chroma" colorizes out of bound chroma
"chroma_grey" colorizes out of bound chroma, and makes the remaining pixels grey
The colorizing is done as follows:
  • YUY2: j,k=1,2 (chroma shared between two horizontal pixels p1 and p2: Y1UY2V)
  • YV24: j,k=1 (no chroma shared)
  • YV12: j,k=11,12,21,22 (chroma shared between 2x2 pixels Y11UY12V: Y21UY22V)
Pixel Condition Colorization
 show="luma"  show="luma_grey"
Yj < min_luma   red (pj)   red (pj)
Yj > max_luma   green (pj)   green (pj)
Yj < min_luma and Yk > max_luma   yellow (pj and pk)   puke (pj)  olive (pk)
 show="chroma"  show="chroma_grey"
U < min_chroma   yellow   yellow
U > max_chroma   blue
V < min_chroma   cyan
V > max_chroma   red
U < min_chroma and V < min_chroma   green
U > max_chroma and V < min_chroma   teal
U < min_chroma and V > max_chroma   orange
U > max_chroma and V > max_chroma   magenta
AVS+ bool  paramscale = false
If set, minimum/maximum luma/chroma values are treated as they were in 8 bit range (but non-integer values are allowed), limiter will autoscale them to the current bit depth of the clip.
Conversion uses the bit-shift method for integer bit depth conversion (from 8 to 8-16 bits). For 32 bit float clips the conversion is value/255.0 for Y (luma) channel and (value-128)/255.0 for U/V chroma channels. Do not use paramscale when you want to limit 32 bit float chroma exactly to +/-0.5, give the parameters directly instead.
Default: does not scale at all, parameters are used as-is. Parameters now are of float type to handle 32 bit float values..


[edit] Examples

# 1. Original image
FFmpegSource2("sintel.mp4")
Trim(4685, 4685)
# 2. Exaggerated luma and chroma range
Levels(16, 1.0, 255-16, 0, 255, coring=false)
Tweak(sat=2.0, coring=false)
# (insert Limiter here)
ColorYUV(analyze=true)
Limit Ex02.jpg
# 3. Limiter("luma")
[...]
Limiter(16, 235, 16, 240, "luma")
ColorYUV(analyze=true)
Limit Ex03.jpg
# 4. Limiter("luma_grey")
[...]
Limiter(16, 235, 16, 240, "luma_grey")
ColorYUV(analyze=true)
Limit Ex04.jpg
# 5. Limiter("chroma")
[...]
Limiter(16, 235, 16, 240, "chroma")
ColorYUV(analyze=true)
Limit Ex05.jpg
# 6. Limiter("chroma_grey")
[...]
Limiter(16, 235, 16, 240, "chroma_grey")
ColorYUV(analyze=true)
Limit Ex06.jpg
# 7. Putting it all together
[...]
StackHorizontal(
\    Last
\  , StackVertical(
\       Histogram("levels", 0.5).Crop(Width, 0, 256, 256).AddBorders(0, 0, 0, Height/2-256)
\     , Histogram("color2"     ).Crop(Width, 0, 256, 256).AddBorders(0, 0, 0, Height/2-256)
\    )
\  , StackVertical(
\       BicubicResize(Width/2, Height/2).Limiter(16, 235, 16, 240, "luma_grey")
\     , BicubicResize(Width/2, Height/2).Limiter(16, 235, 16, 240, "chroma_grey")
\    )
\ )
Limit Ex07a.png


[edit] Changes

AVS+ r2724 Added support for float.

Added paramscale

AVS+ Added support for 8-16bit color spaces.
v2.60 Added support for YV24.
v2.56 Added show to show out of bound luma/chroma.
Personal tools