Posts: 459
Threads: 107
Joined: Jul 2020
Hybrid is reporting an input PAR of 31266:28579
I'm trying to upscale from 720 x 576 to 1440 x 1080, and I've tried setting output to square pixels, but the resulting video is badly squeezed.
Any suggestions?
Posts: 10.556
Threads: 57
Joined: May 2017
03.01.2023, 18:22
(This post was last modified: 03.01.2023, 18:23 by Selur.)
No debug output -> no clue whats happening.
31266:28579=1.09402008468
My guess is that the source par got detected wrong, and it should either be 12/11 or 1150/1053, see: https://forum.selur.net/thread-597.html.
So I would suggest overwriting the Input PAR to either of those and see which is correct.
But those differences should not cause bad aspect ratio derivations.
-> would need a small sample of the source which has this effect to reproduce and recommend some proper value.
(16/15 would be another typical 4:3 PAR for PAL content.)
Cu Selur
----
Dev versions are in the 'experimental'-folder of my GoogleDrive, which is linked on the download page.
Posts: 459
Threads: 107
Joined: Jul 2020
Debug below. I have tried changing the input PAR but I can't seem to get it right. Strangely the Hybrid preview looks perfect, but the resulting output file is squeezed.
link: sample clip
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: generateScript - dual: 0, crop: 0, preview: 0, script: 1, job: 0
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: There's no timecode in mov_a1fd7ab704c5b4b99cdf8dbb398f402f_853323747
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: target bit depth from filtering model: 10
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: getColorSampling for 4:2:2 yuv422p10le at 10bit
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: -> input¤t colorSampling: YUV422P10
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: Luminance scale: tv -> yuvPCScale: false
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: There's no Codec in mov_a1fd7ab704c5b4b99cdf8dbb398f402f_853323747
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: getColorSampling for i422 i422 at 10bit
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: -> input¤t colorSampling: YUV422P10
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: target color: YUV422P10
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: There's no typ in mov_a1fd7ab704c5b4b99cdf8dbb398f402f_853323747
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: vc1: false
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: Disabling DGDevNV incompatible format: prores
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: dgDecNVCompatible: false
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: vsDGDecNVAvailable: true
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: vsUseDGDecNV: false
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: Disabling DGDec incompatible input container!
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: Vapoursynth tryLSMASHSource for: S:\Twemlow Project\Eve Island-no-credits-compressor-Apple ProRes 422.mov
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: vsPreferLSMASH: true
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: mp4Compatible: true
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: forcing CFR output: true
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: -> using LibAvSource
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: getStartAndEnd(cutStartTime: 0, cutEndTime: 4991.64, selectionStartTime: 0, selectionEndTime: 4991.64, ...)
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: startTime: 0.00000000
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: endTime: 4991.64000000
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: -> startTime: 0, endTime: 4991.64
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: matchesChapter: true
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: no Vapoursynth deinterlacer,..
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: Interframe::call(59.9401,50)
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: Vapoursynth script view: # Imports
import vapoursynth as vs
import os
import ctypes
# Loading Support Files
Dllref = ctypes.windll.LoadLibrary("C:/Program Files/Hybrid/64bit/vsfilters/Support/libfftw3f-3.dll")
import sys
# getting Vapoursynth core
core = vs.core
# Import scripts folder
scriptPath = 'C:/Program Files/Hybrid/64bit/vsscripts'
sys.path.insert(0, os.path.abspath(scriptPath))
# Loading Plugins
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/ResizeFilter/nnedi3/NNEDI3CL.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/FrameFilter/Interframe/svpflow2_vs64.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/FrameFilter/Interframe/svpflow1_vs64.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/DenoiseFilter/CTMF/CTMF.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/SharpenFilter/CAS/CAS.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/DenoiseFilter/HQDN3D/libhqdn3d.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/DeblockFilter/Deblock/Deblock.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/MiscFilter/MiscFilters/MiscFilters.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/Support/EEDI3m.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/GrainFilter/RemoveGrain/RemoveGrainVS.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/GrainFilter/AddGrain/AddGrain.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/DenoiseFilter/NEO_FFT3DFilter/neo-fft3d.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/DenoiseFilter/DFTTest/DFTTest.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/ResizeFilter/nnedi3/vsznedi3.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/Support/libmvtools.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/Support/scenechange.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/Support/fmtconv.dll")
core.std.LoadPlugin(path="C:/Program Files/Hybrid/64bit/vsfilters/SourceFilter/LSmashSource/vslsmashsource.dll")
# Import scripts
import edi_rpow2
import interframe
import G41Fun
import mvsfunc
import lostfunc
import havsfunc
import adjust
# source: 'S:\Twemlow Project\Eve Island-no-credits-compressor-Apple ProRes 422.mov'
# current color space: YUV422P10, bit depth: 10, resolution: 720x576, fps: 25, color matrix: 170m, yuv luminance scale: limited, scanorder: bottom field first
# Loading S:\Twemlow Project\Eve Island-no-credits-compressor-Apple ProRes 422.mov using LWLibavSource
clip = core.lsmas.LWLibavSource(source="S:/Twemlow Project/Eve Island-no-credits-compressor-Apple ProRes 422.mov", format="YUV422P10", stream_index=1, cache=0, fpsnum=25, prefer_hw=0)
# Setting color matrix to 170m.
clip = core.std.SetFrameProps(clip, _Matrix=6)
clip = clip if not core.text.FrameProps(clip,'_Transfer') else core.std.SetFrameProps(clip, _Transfer=6)
clip = clip if not core.text.FrameProps(clip,'_Primaries') else core.std.SetFrameProps(clip, _Primaries=5)
# Setting color range to TV (limited) range.
clip = core.std.SetFrameProp(clip=clip, prop="_ColorRange", intval=1)
# making sure frame rate is set to 25
clip = core.std.AssumeFPS(clip=clip, fpsnum=25, fpsden=1)
clip = core.std.SetFrameProp(clip=clip, prop="_FieldBased", intval=1)
# Color Adjustment
clip = adjust.Tweak(clip=clip, hue=0.00, sat=0.80, cont=1.00, coring=True)
# converting interlaced to half-height progressive for filtering (vsDeSpot) (QTGMC(preset="Fast"))
clip = havsfunc.QTGMC(Input=clip, Preset="Fast", Lossless=2, TFF=False) # new fps: 50
clip = core.std.SetFrameProp(clip=clip, prop="_FieldBased", intval=0)
# adjusting color space from YUV422P10 to YUV444P16 for vsDeSpot
clip = core.resize.Bicubic(clip=clip, format=vs.YUV444P16, range_s="limited")
for i in range(5):
clip = lostfunc.DeSpot(o=clip)
# applying delocking using Deblock
clip = core.deblock.Deblock(clip=clip)
# cropping the video to 676x554
clip = core.std.CropRel(clip=clip, left=26, right=18, top=4, bottom=18)
# adjusting color space from YUV444P16 to YUV444P8 for vsMLDegrain
clip = core.resize.Bicubic(clip=clip, format=vs.YUV444P8, range_s="limited", dither_type="error_diffusion")
# removing grain using MLDegrain
clip = G41Fun.MLDegrain(clip=clip, tr=1, rec=True, soft=[0,0,0])
# denoising using HQDN3D
clip = core.hqdn3d.Hqdn3d(clip=clip, chrom_spac=7.00, chrom_tmp=10.50)
# contrast sharpening using CAS
clip = core.cas.CAS(clip=clip, sharpness=0.600)
# deringing using HQDeringmod
clip = havsfunc.HQDeringmod(clip, nrmode=2, darkthr=3.0)
# adjusting color space from YUV444P8 to YUV420P8 for vsInterframe
clip = core.resize.Bicubic(clip=clip, format=vs.YUV420P8, range_s="limited")
# adjusting frame count with Interframe/SVP
clip = interframe.InterFrame(clip, Tuning="smooth", NewNum=60000, NewDen=1001, GPU=True, OverrideAlgo=1, overwriteSmooth="{rate:{num:60000,den:1001,abs:true},algo:2,mask:{area:100},scene:{mode:0}}") # new fps: 59.9401
clip = core.std.AddBorders(clip=clip, left=0, right=0, top=0, bottom=2) # add borders to archive mod 4 (NNEDI3(CL)) - 676x556
# resizing using NNEDI3CL
# current: 676x556 target: 1440x1080 -> pow: 4
clip = edi_rpow2.nnedi3cl_rpow2(clip=clip, rfactor=4) # 2704x2224
clip = core.std.CropRel(clip=clip, left=0, right=0, top=0, bottom=8) # removing borders (NNEDI3(CL)) - 2704x2216
# adjusting resizing
clip = core.fmtc.resample(clip=clip, w=1440, h=1080, kernel="lanczos", interlaced=False, interlacedd=False)
# adding Grain using AddGrain
clip = core.grain.Add(clip=clip, uvar=0.50)
# letterboxing 1440x1080 to 1920x1080
clip = core.std.AddBorders(clip=clip, left=240, right=240, top=0, bottom=0)
# converting progressive to interlaced for 'progressive to interlaced (1)'
clip = core.std.SeparateFields(clip=clip, tff=False)
clip = core.std.SelectEvery(clip=clip, cycle=4, offsets=[0, 3])
clip = core.std.DoubleWeave(clip=clip, tff=False) # resolution 1920x1080
clip = core.std.SelectEvery(clip=clip, cycle=2, offsets=0) # new fps: 29.97
clip = core.std.SetFrameProp(clip=clip, prop="_FieldBased", intval=1)
# adjusting output color from: YUV420P16 to YUV422P10 for ProResModel
clip = core.resize.Bicubic(clip=clip, format=vs.YUV422P10, range_s="limited", dither_type="error_diffusion")
# set output frame rate to 29.97fps
clip = core.std.AssumeFPS(clip=clip, fpsnum=30000, fpsden=1001)
# Output
clip.set_output()
2023.01.06 - 11:48:34_Windows 10 Version 2009 (64bit)_2022.12.19.1 - level 9: not updating vsPreview,..
Posts: 10.556
Threads: 57
Joined: May 2017
What do you not get right?
You can't specify the input PAR?
You can't find the right PAR?
No clue what I should look at ?
=> best share a small sample of the source which also has this strange par.
----
Dev versions are in the 'experimental'-folder of my GoogleDrive, which is linked on the download page.
Posts: 459
Threads: 107
Joined: Jul 2020
Posts: 10.556
Threads: 57
Joined: May 2017
06.01.2023, 16:24
(This post was last modified: 06.01.2023, 16:28 by Selur.)
Okay, input is flagged as 1.094 PAR, which isn't any of the standard PAR values.
Problem is Hybrid doesn't use this for the input PAR.
=> I'll look into it.
Setting Input PAR to 1094x1000 should work.
(ffmpeg reports: SAR 31266:28579, so that probably works too)
Found the issue, Hybirds PAR width&height value were limited to 8000 each and thus 31266:28579 is an invalid PAR.
Cu Selur
----
Dev versions are in the 'experimental'-folder of my GoogleDrive, which is linked on the download page.
Posts: 459
Threads: 107
Joined: Jul 2020
Will try - do I also need to force the input PAR type, or can I leave unchanged?
Posts: 10.556
Threads: 57
Joined: May 2017
Leave the input par type.
----
Dev versions are in the 'experimental'-folder of my GoogleDrive, which is linked on the download page.
Posts: 459
Threads: 107
Joined: Jul 2020
Hybrid only has 4 digit options, so I can't set SAR 31266:28579
Will try setting Input PAR to 1094x1000
Posts: 10.556
Threads: 57
Joined: May 2017
Will send you a link to a new dev version which should fix that in a few minutes.
(btw.you should overwrite the scan order to tff)
Cu Selur
----
Dev versions are in the 'experimental'-folder of my GoogleDrive, which is linked on the download page.
|