LUTDeRainbow
From Avisynth wiki
		(Difference between revisions)
		
		
| m (→Syntax and Parameters) | m (small corrections) | ||
| (5 intermediate revisions by one user not shown) | |||
| Line 1: | Line 1: | ||
| − | {{ | + | {{FilterCat4|External_filters|scripts|Restoration_filters|Rainbow & Dot Crawl Removal}} | 
| − | {{ | + | {{Filter3 | 
| | {{Author/Scintilla}}   | | {{Author/Scintilla}}   | ||
| | 10/3/08 | | 10/3/08 | ||
| − | | [http://www.aquilinestudios.org/scripts/LUTDeRainbow-20081003.avsi  | + | | [http://web.archive.org/web/20140421001939/http://www.aquilinestudios.org/scripts/LUTDeRainbow-20081003.avsi LUTDeRainbow-20081003.avsi] | 
| | Rainbow & Dot Crawl Removal | | Rainbow & Dot Crawl Removal | ||
| | | | | ||
| − | |||
| | | | | ||
| |}} | |}} | ||
| − | + | ||
| == Description == | == Description == | ||
| − | + | LUTDeRainbow, a derainbowing script by Scintilla. | |
| − | + | <br> | |
| − | + | <br> | |
| − | : | + | == Requirements == | 
| + | * AviSynth 2.5.8 or [http://sourceforge.net/projects/avisynth2/ greater] | ||
| + | * Supported color formats: [[YV12]] | ||
| + | * [[FAQ_different_types_content#How_do_I_recognize_progressive.2C_interlaced.2C_telecined.2C_hybrid_and_blended_content.3F|Progressive]] input only  | ||
| − | + | === Required Plugins === | |
| − | + | *[[MaskTools2]] | |
| <br> | <br> | ||
| − | == Syntax and Parameters == | + | |
| + | == [[Script variables|Syntax and Parameters]] == | ||
| :{{Template:FuncDef|LUTDeRainbow(clip input, float "cthresh", float "ythresh", bool "y", bool "linkUV", bool "mask")}} | :{{Template:FuncDef|LUTDeRainbow(clip input, float "cthresh", float "ythresh", bool "y", bool "linkUV", bool "mask")}} | ||
| <br> | <br> | ||
| − | ::{{ | + | ::{{Par2|input|clip| }} | 
| + | :::Input clip. | ||
| + | <br> | ||
| + | ::{{Par2|cthresh|float|10.0}} | ||
| :::This determines how close the chroma values of the pixel in the previous and next frames have to be for the pixel to be hit.    | :::This determines how close the chroma values of the pixel in the previous and next frames have to be for the pixel to be hit.    | ||
| :::Higher values (within reason) should catch more rainbows, but may introduce unwanted artifacts. Probably shouldn't be set above 20 or so. | :::Higher values (within reason) should catch more rainbows, but may introduce unwanted artifacts. Probably shouldn't be set above 20 or so. | ||
| <br> | <br> | ||
| − | ::{{ | + | ::{{Par2|ythresh|float|10.0}} | 
| :::If the y parameter is set true, then this determines how close the luma values of the pixel in the previous and next frames have to be for the pixel to be hit. Just as with cthresh. | :::If the y parameter is set true, then this determines how close the luma values of the pixel in the previous and next frames have to be for the pixel to be hit. Just as with cthresh. | ||
| <br> | <br> | ||
| − | ::{{ | + | ::{{Par2|y|bool|true}} | 
| :::Determines whether luma difference will be considered n determining which pixels to hit and which to leave alone. | :::Determines whether luma difference will be considered n determining which pixels to hit and which to leave alone. | ||
| <br> | <br> | ||
| − | ::{{ | + | ::{{Par2|linkUV|bool|true}} | 
| :::Determines whether both chroma channels are considered in determining which pixels in each channel to hit.   | :::Determines whether both chroma channels are considered in determining which pixels in each channel to hit.   | ||
| − | :::When set true, only pixels that meet the thresholds for both U and V will be hit | + | :::When set true, only pixels that meet the thresholds for both U and V will be hit. | 
| + | :::When set false, the U and V channels are masked separately (so a pixel could have its U hit but not its V, or vice versa). | ||
| <br> | <br> | ||
| − | ::{{ | + | ::{{Par2|mask|bool|false}} | 
| :::When set true, the function will return the mask (for combined U/V) instead of the image. Formerly used to find the best values of cthresh and ythresh. | :::When set true, the function will return the mask (for combined U/V) instead of the image. Formerly used to find the best values of cthresh and ythresh. | ||
| :::If linkUV=false, then this mask won't actually be used anyway (because each chroma channel will have its own mask). | :::If linkUV=false, then this mask won't actually be used anyway (because each chroma channel will have its own mask). | ||
| Line 42: | Line 49: | ||
| == Examples == | == Examples == | ||
| + | LUTDeRainbow with default settings: | ||
|   [[AviSource]]("Blah.avi") |   [[AviSource]]("Blah.avi") | ||
| − |   LUTDeRainbow() | + |   LUTDeRainbow(cthresh=10.0, ythresh=10.0, y=true, linkUV=true, mask=false) | 
| <br> | <br> | ||
| == Changelog == | == Changelog == | ||
| Line 58: | Line 66: | ||
|     6/23/05: |     6/23/05: | ||
|        - Is this thing on? |        - Is this thing on? | ||
| + | <br> | ||
| + | <br> | ||
| + | ----------------------------------------------- | ||
| + | '''Back to [[External_filters#Rainbow_.26_Dot_Crawl_Removal|External Filters]] ←''' | ||
| + | ----------------------------------------------- | ||
Latest revision as of 14:12, 6 March 2016
| Abstract | |
|---|---|
| Author | Scintilla | 
| Version | 10/3/08 | 
| Download | LUTDeRainbow-20081003.avsi | 
| Category | Rainbow & Dot Crawl Removal | 
| License | |
| Discussion | |
| Contents | 
[edit] Description
LUTDeRainbow, a derainbowing script by Scintilla.
[edit] Requirements
- AviSynth 2.5.8 or greater
- Supported color formats: YV12
- Progressive input only
[edit] Required Plugins
[edit] Syntax and Parameters
- LUTDeRainbow(clip input, float "cthresh", float "ythresh", bool "y", bool "linkUV", bool "mask")
- clip  input =   
 - Input clip.
 
 
- clip  input =   
- float  cthresh = 10.0 
 - This determines how close the chroma values of the pixel in the previous and next frames have to be for the pixel to be hit.
- Higher values (within reason) should catch more rainbows, but may introduce unwanted artifacts. Probably shouldn't be set above 20 or so.
 
 
- float  cthresh = 10.0 
- float  ythresh = 10.0 
 - If the y parameter is set true, then this determines how close the luma values of the pixel in the previous and next frames have to be for the pixel to be hit. Just as with cthresh.
 
 
- float  ythresh = 10.0 
- bool  y = true 
 - Determines whether luma difference will be considered n determining which pixels to hit and which to leave alone.
 
 
- bool  y = true 
- bool  linkUV = true 
 - Determines whether both chroma channels are considered in determining which pixels in each channel to hit.
- When set true, only pixels that meet the thresholds for both U and V will be hit.
- When set false, the U and V channels are masked separately (so a pixel could have its U hit but not its V, or vice versa).
 
 
- bool  linkUV = true 
- bool  mask = false 
 - When set true, the function will return the mask (for combined U/V) instead of the image. Formerly used to find the best values of cthresh and ythresh.
- If linkUV=false, then this mask won't actually be used anyway (because each chroma channel will have its own mask).
 
 
- bool  mask = false 
[edit] Examples
LUTDeRainbow with default settings:
AviSource("Blah.avi") LUTDeRainbow(cthresh=10.0, ythresh=10.0, y=true, linkUV=true, mask=false)
[edit] Changelog
  10/3/08: 
     - Fixed "cthresh" typos in documentation; killed repmode since I realized I wasn't using Repair anymore; finally upgraded to MaskTools 2.
  9/2/05: 
     - Suddenly realized this wouldn't work for YUY2 and made it YV12 only; 
       added linkUV option, to decide whether to use a separate mask for each chroma channel or use the same one for both.
  7/1/05: 
     - Added Y option, to take luma into account when deciding whether to use the averaged chroma; added ythresh and cthresh parameters, 
       to determine how close the chroma/luma values of a pixel have to be to be considered the same (y=true is meant to cut down on artifacts)
  6/24/05: 
     - Replaced whole mask mechanism; new mask checks to see that BOTH channels of the chroma are within the threshold from previous frame to next
  6/23/05:
     - Is this thing on?
Back to External Filters ←
