renaming variables, using YAML to replace JSON

This commit is contained in:
k4yt3x 2019-10-19 21:53:12 -04:00
parent 91ac512d57
commit dc2410d4da
2 changed files with 39 additions and 41 deletions

View File

@ -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
View 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