123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- require 'xlua'
- require 'pl'
- require 'trepl'
- -- global settings
- if package.preload.settings then
- return package.preload.settings
- end
- -- default tensor type
- torch.setdefaulttensortype('torch.FloatTensor')
- local settings = {}
- local cmd = torch.CmdLine()
- cmd:text()
- cmd:text("waifu2x")
- cmd:text("Options:")
- cmd:option("-seed", 11, 'fixed input seed')
- cmd:option("-data_dir", "./data", 'data directory')
- -- cmd:option("-backend", "cunn", '(cunn|cudnn)') -- cudnn is slow than cunn
- cmd:option("-test", "images/miku_small.png", 'test image file')
- cmd:option("-model_dir", "./models", 'model directory')
- cmd:option("-method", "scale", '(noise|scale|noise_scale)')
- cmd:option("-noise_level", 1, '(1|2)')
- cmd:option("-category", "anime_style_art", '(anime_style_art|photo)')
- cmd:option("-color", 'rgb', '(y|rgb)')
- cmd:option("-color_noise", 0, 'enable data augmentation using color noise (1|0)')
- cmd:option("-overlay", 0, 'enable data augmentation using overlay (1|0)')
- cmd:option("-scale", 2.0, 'scale')
- cmd:option("-learning_rate", 0.00025, 'learning rate for adam')
- cmd:option("-random_half", 1, 'enable data augmentation using half resolution image (0|1)')
- cmd:option("-crop_size", 128, 'crop size')
- cmd:option("-max_size", -1, 'crop if image size larger then this value.')
- cmd:option("-batch_size", 2, 'mini batch size')
- cmd:option("-epoch", 200, 'epoch')
- cmd:option("-thread", -1, 'number of CPU threads')
- cmd:option("-jpeg_sampling_factors", 444, '(444|422)')
- cmd:option("-validation_ratio", 0.1, 'validation ratio')
- cmd:option("-validation_crops", 40, 'number of crop region in validation')
- cmd:option("-active_cropping_rate", 0.5, 'active cropping rate')
- cmd:option("-active_cropping_tries", 20, 'active cropping tries')
- local opt = cmd:parse(arg)
- for k, v in pairs(opt) do
- settings[k] = v
- end
- if settings.method == "noise" then
- settings.model_file = string.format("%s/noise%d_model.t7",
- settings.model_dir, settings.noise_level)
- elseif settings.method == "scale" then
- settings.model_file = string.format("%s/scale%.1fx_model.t7",
- settings.model_dir, settings.scale)
- elseif settings.method == "noise_scale" then
- settings.model_file = string.format("%s/noise%d_scale%.1fx_model.t7",
- settings.model_dir, settings.noise_level, settings.scale)
- else
- error("unknown method: " .. settings.method)
- end
- if not (settings.color == "rgb" or settings.color == "y") then
- error("color must be y or rgb")
- end
- if not (settings.scale == math.floor(settings.scale) and settings.scale % 2 == 0) then
- error("scale must be mod-2")
- end
- if not (settings.category == "anime_style_art" or
- settings.category == "photo") then
- error(string.format("unknown category: %s", settings.category))
- end
- if settings.random_half == 1 then
- settings.random_half = true
- else
- settings.random_half = false
- end
- if settings.color_noise == 1 then
- settings.color_noise = true
- else
- settings.color_noise = false
- end
- if settings.overlay == 1 then
- settings.overlay = true
- else
- settings.overlay = false
- end
- if settings.thread > 0 then
- torch.setnumthreads(tonumber(settings.thread))
- end
- settings.images = string.format("%s/images.t7", settings.data_dir)
- settings.image_list = string.format("%s/image_list.txt", settings.data_dir)
- settings.backend = "cunn"
- return settings
|