Advertisement
Guest User

Untitled

a guest
Nov 12th, 2022
83
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 4.99 KB | None | 0 0
  1. # Imports
  2. import vapoursynth as vs
  3. import os
  4. import ctypes
  5. # Loading Support Files
  6. Dllref = ctypes.windll.LoadLibrary("i:/Hybrid/64bit/vsfilters/Support/libfftw3f-3.dll")
  7. import sys
  8. # getting Vapoursynth core
  9. core = vs.core
  10. # Import scripts folder
  11. scriptPath = 'i:/Hybrid/64bit/vsscripts'
  12. sys.path.insert(0, os.path.abspath(scriptPath))
  13. # Loading Plugins
  14. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/Support/libvs_placebo.dll")
  15. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/DenoiseFilter/TTempSmooth/TTempSmooth.dll")
  16. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/DenoiseFilter/NEO_FFT3DFilter/neo-fft3d.dll")
  17. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/Support/DCTFilter.dll")
  18. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/DeblockFilter/Deblock/Deblock.dll")
  19. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/GrainFilter/RemoveGrain/RemoveGrainVS.dll")
  20. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/GrainFilter/AddGrain/AddGrain.dll")
  21. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/DenoiseFilter/FFT3DFilter/fft3dfilter.dll")
  22. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/DenoiseFilter/DFTTest/DFTTest.dll")
  23. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/Support/EEDI3m.dll")
  24. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/ResizeFilter/nnedi3/NNEDI3CL.dll")
  25. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/Support/libmvtools.dll")
  26. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/Support/scenechange.dll")
  27. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/Support/fmtconv.dll")
  28. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/MiscFilter/MiscFilters/MiscFilters.dll")
  29. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/DeinterlaceFilter/Bwdif/Bwdif.dll")
  30. core.std.LoadPlugin(path="i:/Hybrid/64bit/vsfilters/SourceFilter/LSmashSource/vslsmashsource.dll")
  31. # Import scripts
  32. import havsfunc
  33. # source: 'C:\Users\Selur\Desktop\Donna-Summer-2-tff.mp4'
  34. # current color space: YUV422P10, bit depth: 10, resolution: 760x488, fps: 29.97, color matrix: 709, yuv luminance scale: limited, scanorder: top field first
  35. # Loading C:\Users\Selur\Desktop\Donna-Summer-2-tff.mp4 using LibavSMASHSource
  36. clip = core.lsmas.LibavSMASHSource(source="C:/Users/Selur/Desktop/Donna-Summer-2-tff.mp4")
  37. # Setting color matrix to 709.
  38. clip = core.std.SetFrameProps(clip, _Matrix=1)
  39. clip = clip if not core.text.FrameProps(clip,'_Transfer') else core.std.SetFrameProps(clip, _Transfer=1)
  40. clip = clip if not core.text.FrameProps(clip,'_Primaries') else core.std.SetFrameProps(clip, _Primaries=5)
  41. # Setting color range to TV (limited) range.
  42. clip = core.std.SetFrameProp(clip=clip, prop="_ColorRange", intval=1)
  43. # making sure frame rate is set to 29.970
  44. clip = core.std.AssumeFPS(clip=clip, fpsnum=30000, fpsden=1001)
  45. clip = core.std.SetFrameProp(clip=clip, prop="_FieldBased", intval=2)
  46. # setting field order to what QTGMC should assume (top field first)
  47. clip = core.std.SetFrameProp(clip=clip, prop="_FieldBased", intval=2)
  48. # Deinterlacing using QTGMC
  49. clip = havsfunc.QTGMC(Input=clip, Preset="Fast", TFF=True, opencl=True) # new fps: 59.94
  50. # make sure content is preceived as frame based
  51. clip = core.std.SetFieldBased(clip, 0)
  52. ## Starting applying 'EdgeMask (Prewitt)' masked filtering for vsDFTTest
  53. clipMask = clip
  54. clipMask = core.std.ShufflePlanes(clipMask, 0, vs.GRAY)
  55. clipMask = core.std.Prewitt(clip=clipMask)
  56. clipMask = core.std.Minimum(clipMask)
  57. clipMask = core.std.InvertMask(clipMask)
  58. clipFiltered = clip
  59. # denoising using DFTTest
  60. clipFiltered = core.dfttest.DFTTest(clip=clipFiltered, sigma=50.00, sigma2=40.00)
  61. clip = core.std.MaskedMerge(clip, clipFiltered, clipMask)
  62. ## Finished applying 'Edgemask (Prewitt)' masked filtering for vsDFTTest
  63. # denoising using MCTemporalDenoise
  64. clip = havsfunc.MCTemporalDenoise(i=clip, settings="very high", ncpu=1)
  65. # adjusting color space from YUV422P10 to YUV444P16 for vsGLSLLumaSharpen
  66. clip = core.resize.Bicubic(clip=clip, format=vs.YUV444P16, range_s="limited")
  67. with open("i:/Hybrid/64bit/vsfilters/GLSL/parameterized/LumaSharpenHook.glsl") as glslf:
  68. glsl = glslf.read()
  69. glsl = glsl.replace('#define sharp_strength 0.30', '#define sharp_strength 1.8000')
  70. glsl = glsl.replace('#define sharp_clamp 0.035', '#define sharp_clamp 0.0350')
  71. glsl = glsl.replace('#define pattern 2', '#define pattern 8')
  72. glsl = glsl.replace('#define offset_bias 1.0', '#define offset_bias 1.0000')
  73. clip = core.placebo.Shader(clip=clip, shader_s=glsl, width=clip.width, height=clip.height)
  74. with open("i:/Hybrid/64bit/vsfilters/GLSL/parameterized/filmgrain.glsl") as glslf:
  75. glsl = glslf.read()
  76. glsl = glsl.replace('#define INTENSITY 0.05', '#define INTENSITY 0.01')
  77. clip = core.placebo.Shader(clip=clip, shader_s=glsl, width=clip.width, height=clip.height)
  78. # adjusting output color from: YUV444P16 to YUV420P10 for x265Model
  79. clip = core.resize.Bicubic(clip=clip, dither_type="none", format=vs.YUV420P10, range_s="limited")
  80. # set output frame rate to 59.94fps
  81. clip = core.std.AssumeFPS(clip=clip, fpsnum=60000, fpsden=1001)
  82. # Output
  83. clip.set_output()
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement