2019-02-08 21:48:56 +00:00
|
|
|
#!/usr/bin/env python3
|
2019-06-15 01:43:18 +00:00
|
|
|
# -*- coding: future_fstrings -*-
|
2019-06-16 21:32:41 +00:00
|
|
|
|
|
|
|
|
2019-02-08 21:48:56 +00:00
|
|
|
"""
|
|
|
|
Name: Waifu2x Caffe Driver
|
|
|
|
Author: K4YT3X
|
|
|
|
Date Created: Feb 24, 2018
|
2019-06-15 18:35:22 +00:00
|
|
|
Last Modified: June 15, 2019
|
2019-02-08 21:48:56 +00:00
|
|
|
|
2019-03-19 17:08:49 +00:00
|
|
|
Description: This class is a high-level wrapper
|
|
|
|
for waifu2x-caffe.
|
2019-02-08 21:48:56 +00:00
|
|
|
"""
|
|
|
|
from avalon_framework import Avalon
|
|
|
|
import subprocess
|
|
|
|
import threading
|
|
|
|
|
|
|
|
|
|
|
|
class Waifu2xCaffe:
|
|
|
|
"""This class communicates with waifu2x cui engine
|
|
|
|
|
|
|
|
An object will be created for this class, containing information
|
|
|
|
about the binary address and the processing method. When being called
|
|
|
|
by the main program, other detailed information will be passed to
|
|
|
|
the upscale function.
|
|
|
|
"""
|
|
|
|
|
2019-03-09 17:50:54 +00:00
|
|
|
def __init__(self, waifu2x_settings, process, model_dir):
|
|
|
|
self.waifu2x_settings = waifu2x_settings
|
|
|
|
self.waifu2x_settings['process'] = process
|
|
|
|
self.waifu2x_settings['model_dir'] = model_dir
|
|
|
|
|
|
|
|
# arguments passed through command line overwrites config file values
|
|
|
|
self.process = process
|
|
|
|
self.model_dir = model_dir
|
2019-02-08 21:48:56 +00:00
|
|
|
self.print_lock = threading.Lock()
|
|
|
|
|
2019-04-29 04:06:54 +00:00
|
|
|
def upscale(self, input_directory, output_directory, scale_ratio, scale_width, scale_height, image_format, upscaler_exceptions):
|
2019-02-08 21:48:56 +00:00
|
|
|
"""This is the core function for WAIFU2X class
|
|
|
|
|
|
|
|
Arguments:
|
2019-04-29 04:06:54 +00:00
|
|
|
input_directory {string} -- source directory path
|
|
|
|
output_directory {string} -- output directory path
|
2019-02-08 21:48:56 +00:00
|
|
|
width {int} -- output video width
|
|
|
|
height {int} -- output video height
|
|
|
|
"""
|
|
|
|
|
2019-03-25 03:04:50 +00:00
|
|
|
try:
|
|
|
|
# overwrite config file settings
|
2019-04-29 04:06:54 +00:00
|
|
|
self.waifu2x_settings['input_path'] = input_directory
|
|
|
|
self.waifu2x_settings['output_path'] = output_directory
|
2019-03-09 17:50:54 +00:00
|
|
|
|
2019-03-25 03:04:50 +00:00
|
|
|
if scale_ratio:
|
|
|
|
self.waifu2x_settings['scale_ratio'] = scale_ratio
|
|
|
|
elif scale_width and scale_height:
|
|
|
|
self.waifu2x_settings['scale_width'] = scale_width
|
|
|
|
self.waifu2x_settings['scale_height'] = scale_height
|
2019-03-09 17:50:54 +00:00
|
|
|
|
2019-03-30 18:01:36 +00:00
|
|
|
self.waifu2x_settings['output_extention'] = image_format
|
|
|
|
|
2019-03-25 03:04:50 +00:00
|
|
|
# print thread start message
|
|
|
|
self.print_lock.acquire()
|
2019-04-22 05:26:36 +00:00
|
|
|
Avalon.debug_info(f'[upscaler] Thread {threading.current_thread().name} started')
|
2019-03-25 03:04:50 +00:00
|
|
|
self.print_lock.release()
|
2019-02-08 21:48:56 +00:00
|
|
|
|
2019-03-25 03:04:50 +00:00
|
|
|
# list to be executed
|
|
|
|
execute = []
|
2019-03-09 17:50:54 +00:00
|
|
|
|
2019-03-25 03:04:50 +00:00
|
|
|
execute.append(self.waifu2x_settings['waifu2x_caffe_path'])
|
|
|
|
for key in self.waifu2x_settings.keys():
|
2019-03-09 17:50:54 +00:00
|
|
|
|
2019-03-25 03:04:50 +00:00
|
|
|
value = self.waifu2x_settings[key]
|
2019-03-09 17:50:54 +00:00
|
|
|
|
2019-03-25 03:04:50 +00:00
|
|
|
# is executable key or null or None means that leave this option out (keep default)
|
|
|
|
if key == 'waifu2x_caffe_path' or value is None or value is False:
|
|
|
|
continue
|
2019-03-09 17:50:54 +00:00
|
|
|
else:
|
2019-03-25 03:04:50 +00:00
|
|
|
if len(key) == 1:
|
2019-04-22 05:26:36 +00:00
|
|
|
execute.append(f'-{key}')
|
2019-03-25 03:04:50 +00:00
|
|
|
else:
|
2019-04-22 05:26:36 +00:00
|
|
|
execute.append(f'--{key}')
|
2019-03-25 03:04:50 +00:00
|
|
|
execute.append(str(value))
|
|
|
|
|
2019-04-22 05:26:36 +00:00
|
|
|
Avalon.debug_info(f'Executing: {execute}')
|
2019-03-25 03:04:50 +00:00
|
|
|
completed_command = subprocess.run(execute, check=True)
|
|
|
|
|
|
|
|
# print thread exiting message
|
|
|
|
self.print_lock.acquire()
|
2019-04-22 05:26:36 +00:00
|
|
|
Avalon.debug_info(f'[upscaler] Thread {threading.current_thread().name} exiting')
|
2019-03-25 03:04:50 +00:00
|
|
|
self.print_lock.release()
|
|
|
|
|
|
|
|
# return command execution return code
|
|
|
|
return completed_command.returncode
|
|
|
|
except Exception as e:
|
2019-03-25 13:22:33 +00:00
|
|
|
upscaler_exceptions.append(e)
|