Caf source
From Avisynth wiki
(Difference between revisions)
Raffriff42 (Talk | contribs) (source, from pastebin.com) |
Raffriff42 (Talk | contribs) m (formatting) |
||
Line 1: | Line 1: | ||
− | + | source: http://pastebin.com/raw.php?i=Mt2M4CBB | |
− | /* Chromatic Aberration Fixer (original: http://pastebin.com/wEAp3tuM) | + | /* Chromatic Aberration Fixer (original: http://pastebin.com/wEAp3tuM) |
− | rx/ry adjust how much to resize the red plane; bx/by is the same, but for blue. | + | rx/ry adjust how much to resize the red plane; bx/by is the same, but for blue. |
− | warp adjusts warpsharp strength on red/blue planes. | + | warp adjusts warpsharp strength on red/blue planes. |
− | clamp sets whether the chroma (after converting back to yv12) should be limited by the original chroma; this prevents introducing chromatic aberration on, for example, hardsubbed text without chromatic aberration. | + | clamp sets whether the chroma (after converting back to yv12) should be limited by the original chroma; this prevents introducing chromatic aberration on, for example, hardsubbed text without chromatic aberration. |
− | */ | + | */ |
− | + | ||
− | function caf(clip src,float "rx",float "ry",float "bx",float "by",int "warp",bool "clamp") | + | function caf(clip src,float "rx",float "ry",float "bx",float "by",int "warp",bool "clamp") |
− | { | + | { |
− | src | + | src |
− | rgb=ConvertToRGB32(matrix="rec709") | + | rgb=ConvertToRGB32(matrix="rec709") |
− | w=width() | + | w=width() |
− | h=height() | + | h=height() |
− | rx=default(rx,-1.5) | + | rx=default(rx,-1.5) |
− | ry=default(ry,rx) | + | ry=default(ry,rx) |
− | bx=default(bx,-rx) | + | bx=default(bx,-rx) |
− | by=default(by,bx) | + | by=default(by,bx) |
− | warp=default(warp,4) | + | warp=default(warp,4) |
− | clamp=default(clamp,true) | + | clamp=default(clamp,true) |
− | edge=src.aSobel().aBlur(type=0,blur=4) | + | edge=src.aSobel().aBlur(type=0,blur=4) |
− | r=rgb.ShowRed("yv12").Spline36Resize(w,h,rx,ry,w-rx*2,h-ry*2) | + | r=rgb.ShowRed("yv12").Spline36Resize(w,h,rx,ry,w-rx*2,h-ry*2) |
− | b=rgb.ShowBlue("yv12").Spline36Resize(w,h,bx,by,w-bx*2,h-by*2) | + | b=rgb.ShowBlue("yv12").Spline36Resize(w,h,bx,by,w-bx*2,h-by*2) |
− | rwarp=r.aWarp(edge,depth=warp,chroma=1) | + | rwarp=r.aWarp(edge,depth=warp,chroma=1) |
− | bwarp=b.aWarp(edge,depth=warp,chroma=1) | + | bwarp=b.aWarp(edge,depth=warp,chroma=1) |
− | warp==0?MergeRGB(r,rgb,b):MergeRGB(rwarp,rgb,bwarp) | + | warp==0?MergeRGB(r,rgb,b):MergeRGB(rwarp,rgb,bwarp) |
− | ConvertToYV12(matrix="rec709") | + | ConvertToYV12(matrix="rec709") |
− | clamp?mt_lutxy(src,last,"128 x y min x y max clip",y=2,u=3,v=3):MergeLuma(src) | + | clamp?mt_lutxy(src,last,"128 x y min x y max clip",y=2,u=3,v=3):MergeLuma(src) |
− | } | + | } |
Revision as of 07:16, 12 November 2015
source: http://pastebin.com/raw.php?i=Mt2M4CBB
/* Chromatic Aberration Fixer (original: http://pastebin.com/wEAp3tuM) rx/ry adjust how much to resize the red plane; bx/by is the same, but for blue. warp adjusts warpsharp strength on red/blue planes. clamp sets whether the chroma (after converting back to yv12) should be limited by the original chroma; this prevents introducing chromatic aberration on, for example, hardsubbed text without chromatic aberration. */ function caf(clip src,float "rx",float "ry",float "bx",float "by",int "warp",bool "clamp") { src rgb=ConvertToRGB32(matrix="rec709") w=width() h=height() rx=default(rx,-1.5) ry=default(ry,rx) bx=default(bx,-rx) by=default(by,bx) warp=default(warp,4) clamp=default(clamp,true) edge=src.aSobel().aBlur(type=0,blur=4) r=rgb.ShowRed("yv12").Spline36Resize(w,h,rx,ry,w-rx*2,h-ry*2) b=rgb.ShowBlue("yv12").Spline36Resize(w,h,bx,by,w-bx*2,h-by*2) rwarp=r.aWarp(edge,depth=warp,chroma=1) bwarp=b.aWarp(edge,depth=warp,chroma=1) warp==0?MergeRGB(r,rgb,b):MergeRGB(rwarp,rgb,bwarp) ConvertToYV12(matrix="rec709") clamp?mt_lutxy(src,last,"128 x y min x y max clip",y=2,u=3,v=3):MergeLuma(src) }