View difference between Paste ID: HqPCrDF6 and GyzH6gfZ
SHOW: | | - or go back to the newest paste.
1
# ASTDR DeRainbow function v1.49
2
 
3
  function ASTDR(clip input, int "strength", int "tempsoftth", int "tempsoftrad", int "tempsoftsc", float "blstr", int "tht")
4
  {
5
  strn          = Default(strength, 5)
6
  blstr         = Default(blstr, 0.5)
7
  tht           = Default(tht, 255)
8
  tschrth       = Default(tempsoftth, 30)
9
  tschrrad      = Default(tempsoftrad, 3)
10
  tschrsc       = Default(tempsoftsc, 3)  
11
12
  momask    = input.tweak(sat=1.1).mt_motion(thc2=1,thc1=1,thy2=1,thy1=1,y=3,v=3,u=3,tht=tht)
13
  momaskinv = momask.Invert().Levels(0,2,255,0,255)
14
 
15
  filtered_uv = input.DeCross(ThresholdY=15, Noise=100, Margin=1).FluxSmoothST(75,75).Mergeluma(input).awarpsharp2(depth=4,chroma=6).hqdn3d(ls=0,lt=0,cs=strn*3/5,ct=strn)
16
              \ .temporalsoften(tschrrad,0,tschrth,tschrsc,2).blur(blstr).Mergeluma(input).aWarpSharp2(depth=4,chroma=6).fft3dfilter(sigma=1,sigma3=4,plane=3,degrid=1)
17
 
18
  filtered = mt_merge(filtered_uv, input, momaskinv,y=2,u=3,v=3,luma=true)
19
  
20
  mt_merge(input, filtered, momask.mt_expand(mode="both", y=3,u=3,v=3).mt_inflate(y=3,u=3,v=3),y=2,u=3,v=3)
21
  }
22
23
# ASTDRmc DeRainbow function v1.0
24
25
  function ASTDRmc(clip prerb, int "strength", int "tempsoftth", int "tempsoftrad", int "tempsoftsc", float "blstr", int "tht")
26
  {
27
derbmask = (VersionNumber() < 2.60) ? prerb.tedgemask(threshY=2).mt_inflate() : prerb.TEMmod(threshY=2).mt_inflate()
28
derbsuper = prerb.MSuper()
29
derbbackward_vectors = MAnalyse(derbsuper, truemotion = true, isb = true, chroma=false)
30
derbforward_vectors = MAnalyse(derbsuper, truemotion = true, isb = false, chroma=false)
31
derbforward_compensation = prerb.MCompensate(derbsuper, derbforward_vectors)
32
derbbackward_compensation = prerb.MCompensate(derbsuper, derbbackward_vectors)
33
mcclip = interleave(derbforward_compensation,prerb,derbbackward_compensation)
34
ASTDRclip = mcclip.ASTDR(strength=strength,tempsoftth=tempsoftth,tempsoftrad=tempsoftrad,tempsoftsc=tempsoftsc,blstr=blstr,tht=tht).selectevery(3,1)
35
mt_merge(prerb,ASTDRclip, derbmask,luma=true,y=2,u=3,v=3)
36
  }