mirror of
https://github.com/k4yt3x/video2x.git
synced 2025-01-04 04:39:10 +00:00
renaming variables, using YAML to replace JSON
This commit is contained in:
parent
91ac512d57
commit
dc2410d4da
@ -2,5 +2,6 @@ avalon_framework
|
|||||||
colorama
|
colorama
|
||||||
GPUtil
|
GPUtil
|
||||||
psutil
|
psutil
|
||||||
|
pyyaml
|
||||||
requests
|
requests
|
||||||
tqdm
|
tqdm
|
||||||
|
79
src/video2x.py
Normal file → Executable file
79
src/video2x.py
Normal file → Executable file
@ -13,7 +13,7 @@ __ __ _ _ ___ __ __
|
|||||||
Name: Video2X Controller
|
Name: Video2X Controller
|
||||||
Author: K4YT3X
|
Author: K4YT3X
|
||||||
Date Created: Feb 24, 2018
|
Date Created: Feb 24, 2018
|
||||||
Last Modified: August 29, 2019
|
Last Modified: October 6, 2019
|
||||||
|
|
||||||
Dev: BrianPetkovsek
|
Dev: BrianPetkovsek
|
||||||
Dev: SAT3LL
|
Dev: SAT3LL
|
||||||
@ -50,7 +50,6 @@ from upscaler import Upscaler
|
|||||||
# built-in imports
|
# built-in imports
|
||||||
import argparse
|
import argparse
|
||||||
import contextlib
|
import contextlib
|
||||||
import json
|
|
||||||
import pathlib
|
import pathlib
|
||||||
import re
|
import re
|
||||||
import shutil
|
import shutil
|
||||||
@ -58,13 +57,18 @@ import sys
|
|||||||
import tempfile
|
import tempfile
|
||||||
import time
|
import time
|
||||||
import traceback
|
import traceback
|
||||||
|
import yaml
|
||||||
|
|
||||||
# third-party imports
|
# third-party imports
|
||||||
from avalon_framework import Avalon
|
from avalon_framework import Avalon
|
||||||
import GPUtil
|
|
||||||
import psutil
|
import psutil
|
||||||
|
|
||||||
VERSION = '2.10.0'
|
# platform-specific imports
|
||||||
|
if sys.platform == 'win32':
|
||||||
|
import GPUtil
|
||||||
|
|
||||||
|
|
||||||
|
VERSION = '3.0.0'
|
||||||
|
|
||||||
LEGAL_INFO = f'''Video2X Version: {VERSION}
|
LEGAL_INFO = f'''Video2X Version: {VERSION}
|
||||||
Author: K4YT3X
|
Author: K4YT3X
|
||||||
@ -107,7 +111,7 @@ def process_arguments():
|
|||||||
upscaler_options.add_argument('-d', '--driver', help='upscaling driver', action='store', default='waifu2x_caffe', choices=AVAILABLE_DRIVERS)
|
upscaler_options.add_argument('-d', '--driver', help='upscaling driver', action='store', default='waifu2x_caffe', choices=AVAILABLE_DRIVERS)
|
||||||
upscaler_options.add_argument('-y', '--model_dir', type=pathlib.Path, help='directory containing model JSON files', action='store')
|
upscaler_options.add_argument('-y', '--model_dir', type=pathlib.Path, help='directory containing model JSON files', action='store')
|
||||||
upscaler_options.add_argument('-t', '--threads', help='number of threads to use for upscaling', action='store', type=int, default=1)
|
upscaler_options.add_argument('-t', '--threads', help='number of threads to use for upscaling', action='store', type=int, default=1)
|
||||||
upscaler_options.add_argument('-c', '--config', type=pathlib.Path, help='video2x config file location', action='store', default=pathlib.Path(sys.argv[0]).parent.absolute() / 'video2x.json')
|
upscaler_options.add_argument('-c', '--config', type=pathlib.Path, help='video2x config file location', action='store', default=pathlib.Path(sys.argv[0]).parent.absolute() / 'video2x.yaml')
|
||||||
upscaler_options.add_argument('-b', '--batch', help='enable batch mode (select all default values to questions)', action='store_true')
|
upscaler_options.add_argument('-b', '--batch', help='enable batch mode (select all default values to questions)', action='store_true')
|
||||||
|
|
||||||
# scaling options
|
# scaling options
|
||||||
@ -186,14 +190,18 @@ def check_memory():
|
|||||||
Avalon.warning('Proceed with caution')
|
Avalon.warning('Proceed with caution')
|
||||||
|
|
||||||
|
|
||||||
def read_config(config_file):
|
def read_config(config_file: pathlib.Path) -> dict:
|
||||||
""" Reads configuration file
|
""" read video2x configurations from config file
|
||||||
|
|
||||||
Returns a dictionary read by JSON.
|
Arguments:
|
||||||
|
config_file {pathlib.Path} -- video2x configuration file pathlib.Path
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
dict -- dictionary of video2x configuration
|
||||||
"""
|
"""
|
||||||
with open(config_file, 'r') as raw_config:
|
|
||||||
config = json.load(raw_config)
|
with open(config_file, 'r') as config:
|
||||||
return config
|
return yaml.load(config, Loader=yaml.CLoader)
|
||||||
|
|
||||||
|
|
||||||
def absolutify_paths(config):
|
def absolutify_paths(config):
|
||||||
@ -277,16 +285,16 @@ if (args.width and not args.height) or (not args.width and args.height):
|
|||||||
raise ArgumentError('only one of width or height is specified')
|
raise ArgumentError('only one of width or height is specified')
|
||||||
|
|
||||||
# check available memory if driver is waifu2x-based
|
# check available memory if driver is waifu2x-based
|
||||||
if args.driver in ['waifu2x_caffe', 'waifu2x_converter', 'waifu2x_ncnn_vulkan']:
|
if args.driver in ['waifu2x_caffe', 'waifu2x_converter', 'waifu2x_ncnn_vulkan'] and sys.platform == 'win32':
|
||||||
check_memory()
|
check_memory()
|
||||||
|
|
||||||
# anime4k runs significantly faster with more threads
|
# anime4k runs significantly faster with more threads
|
||||||
if args.driver == 'anime4k' and args.threads <= 1:
|
if args.driver == 'anime4k' and args.threads <= 1:
|
||||||
Avalon.warning('Anime4K runs significantly faster with more threads')
|
Avalon.warning('Anime4K runs significantly faster with more threads')
|
||||||
if Avalon.ask('Use more threads of Anime4K?', True):
|
if Avalon.ask('Use more threads of Anime4K?', default=True, batch=args.batch):
|
||||||
while True:
|
while True:
|
||||||
try:
|
try:
|
||||||
threads = Avalon.gets('Amount of threads to use [5]: ')
|
threads = Avalon.gets('Amount of threads to use [5]: ', default=5, batch=args.batch)
|
||||||
args.threads = int(threads)
|
args.threads = int(threads)
|
||||||
break
|
break
|
||||||
except ValueError:
|
except ValueError:
|
||||||
@ -296,35 +304,24 @@ if args.driver == 'anime4k' and args.threads <= 1:
|
|||||||
else:
|
else:
|
||||||
Avalon.error(f'{threads} is not a valid integer')
|
Avalon.error(f'{threads} is not a valid integer')
|
||||||
|
|
||||||
# read configurations from JSON
|
# read configurations from configuration file
|
||||||
config = read_config(args.config)
|
config = read_config(args.config)
|
||||||
config = absolutify_paths(config)
|
|
||||||
|
# config = absolutify_paths(config)
|
||||||
|
|
||||||
# load waifu2x configuration
|
# load waifu2x configuration
|
||||||
if args.driver == 'waifu2x_caffe':
|
driver_settings = config[args.driver]
|
||||||
waifu2x_settings = config['waifu2x_caffe']
|
|
||||||
if not pathlib.Path(waifu2x_settings['waifu2x_caffe_path']).is_file():
|
# check if driver path exists
|
||||||
Avalon.error('Specified waifu2x-caffe directory doesn\'t exist')
|
if not pathlib.Path(driver_settings['path']).is_file():
|
||||||
|
if not pathlib.Path(f'{driver_settings["path"]}.exe').is_file():
|
||||||
|
Avalon.error('Specified driver executable directory doesn\'t exist')
|
||||||
Avalon.error('Please check the configuration file settings')
|
Avalon.error('Please check the configuration file settings')
|
||||||
raise FileNotFoundError(waifu2x_settings['waifu2x_caffe_path'])
|
raise FileNotFoundError(driver_settings['path'])
|
||||||
elif args.driver == 'waifu2x_converter':
|
|
||||||
waifu2x_settings = config['waifu2x_converter']
|
# TODO: check Java here
|
||||||
if not pathlib.Path(waifu2x_settings['waifu2x_converter_path']).is_dir():
|
if args.driver == 'anime4k':
|
||||||
Avalon.error('Specified waifu2x-converter-cpp directory doesn\'t exist')
|
pass
|
||||||
Avalon.error('Please check the configuration file settings')
|
|
||||||
raise FileNotFoundError(waifu2x_settings['waifu2x_converter_path'])
|
|
||||||
elif args.driver == 'waifu2x_ncnn_vulkan':
|
|
||||||
waifu2x_settings = config['waifu2x_ncnn_vulkan']
|
|
||||||
if not pathlib.Path(waifu2x_settings['waifu2x_ncnn_vulkan_path']).is_file():
|
|
||||||
Avalon.error('Specified waifu2x_ncnn_vulkan directory doesn\'t exist')
|
|
||||||
Avalon.error('Please check the configuration file settings')
|
|
||||||
raise FileNotFoundError(waifu2x_settings['waifu2x_ncnn_vulkan_path'])
|
|
||||||
elif args.driver == 'anime4k':
|
|
||||||
waifu2x_settings = config['anime4k']
|
|
||||||
if not pathlib.Path(waifu2x_settings['anime4k_path']).is_file():
|
|
||||||
Avalon.error('Specified anime4k directory doesn\'t exist')
|
|
||||||
Avalon.error('Please check the configuration file settings')
|
|
||||||
raise FileNotFoundError(waifu2x_settings['anime4k_path'])
|
|
||||||
|
|
||||||
# read FFmpeg configuration
|
# read FFmpeg configuration
|
||||||
ffmpeg_settings = config['ffmpeg']
|
ffmpeg_settings = config['ffmpeg']
|
||||||
@ -385,7 +382,7 @@ try:
|
|||||||
Avalon.error('Suffix must be specified for FFmpeg')
|
Avalon.error('Suffix must be specified for FFmpeg')
|
||||||
raise Exception('No suffix specified')
|
raise Exception('No suffix specified')
|
||||||
|
|
||||||
upscaler = Upscaler(input_video=args.input, output_video=args.output, method=args.method, waifu2x_settings=waifu2x_settings, ffmpeg_settings=ffmpeg_settings)
|
upscaler = Upscaler(input_video=args.input, output_video=args.output, method=args.method, driver_settings=driver_settings, ffmpeg_settings=ffmpeg_settings)
|
||||||
|
|
||||||
# set optional options
|
# set optional options
|
||||||
upscaler.waifu2x_driver = args.driver
|
upscaler.waifu2x_driver = args.driver
|
||||||
@ -413,7 +410,7 @@ try:
|
|||||||
|
|
||||||
for input_video in [f for f in args.input.iterdir() if f.is_file()]:
|
for input_video in [f for f in args.input.iterdir() if f.is_file()]:
|
||||||
output_video = args.output / input_video.name
|
output_video = args.output / input_video.name
|
||||||
upscaler = Upscaler(input_video=input_video, output_video=output_video, method=args.method, waifu2x_settings=waifu2x_settings, ffmpeg_settings=ffmpeg_settings)
|
upscaler = Upscaler(input_video=input_video, output_video=output_video, method=args.method, driver_settings=driver_settings, ffmpeg_settings=ffmpeg_settings)
|
||||||
|
|
||||||
# set optional options
|
# set optional options
|
||||||
upscaler.waifu2x_driver = args.driver
|
upscaler.waifu2x_driver = args.driver
|
||||||
|
Loading…
Reference in New Issue
Block a user