| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 | 
							- require 'pl'
 
- local __FILE__ = (function() return string.gsub(debug.getinfo(2, 'S').source, "^@", "") end)()
 
- package.path = path.join(path.dirname(__FILE__), "lib", "?.lua;") .. package.path
 
- require 'image'
 
- local compression = require 'compression'
 
- local settings = require 'settings'
 
- local image_loader = require 'image_loader'
 
- local iproc = require 'iproc'
 
- local alpha_util = require 'alpha_util'
 
- local function crop_if_large(src, max_size)
 
-    local tries = 4
 
-    if src:size(2) >= max_size and src:size(3) >= max_size then
 
-       local rect
 
-       for i = 1, tries do
 
- 	 local yi = torch.random(0, src:size(2) - max_size)
 
- 	 local xi = torch.random(0, src:size(3) - max_size)
 
- 	 rect = iproc.crop(src, xi, yi, xi + max_size, yi + max_size)
 
- 	 -- ignore simple background
 
- 	 if rect:float():std() >= 0 then
 
- 	    break
 
- 	 end
 
-       end
 
-       return rect
 
-    else
 
-       return src
 
-    end
 
- end
 
- local function load_images(list)
 
-    local MARGIN = 32
 
-    local lines = utils.split(file.read(list), "\n")
 
-    local x = {}
 
-    local skip_notice = false
 
-    for i = 1, #lines do
 
-       local line = lines[i]
 
-       local v = utils.split(line, ",")
 
-       local filename = v[1]
 
-       local filters = v[2]
 
-       if filters then
 
- 	 filters = utils.split(filters, ":")
 
-       end
 
-       local im, meta = image_loader.load_byte(filename)
 
-       local skip = false
 
-       if meta and meta.alpha then
 
- 	 if settings.use_transparent_png then
 
- 	    im = alpha_util.fill(im, meta.alpha, torch.random(0, 1))
 
- 	 else
 
- 	    skip = true
 
- 	 end
 
-       end
 
-       if skip then
 
- 	 if not skip_notice then
 
- 	    io.stderr:write("skip transparent png (settings.use_transparent_png=0)\n")
 
- 	    skip_notice = true
 
- 	 end
 
-       else
 
- 	 if settings.max_training_image_size > 0 then
 
- 	    im = crop_if_large(im, settings.max_training_image_size)
 
- 	 end
 
- 	 im = iproc.crop_mod4(im)
 
- 	 local scale = 1.0
 
- 	 if settings.random_half_rate > 0.0 then
 
- 	    scale = 2.0
 
- 	 end
 
- 	 if im then
 
- 	    if im:size(2) > (settings.crop_size * scale + MARGIN) and im:size(3) > (settings.crop_size * scale + MARGIN) then
 
- 	       table.insert(x, {compression.compress(im), {data = {filters = filters}}})
 
- 	    else
 
- 	       io.stderr:write(string.format("\n%s: skip: image is too small (%d > size).\n", filename, settings.crop_size * scale + MARGIN))
 
- 	    end
 
- 	 else
 
- 	    io.stderr:write(string.format("\n%s: skip: load error.\n", filename))
 
- 	 end
 
-       end
 
-       xlua.progress(i, #lines)
 
-       if i % 10 == 0 then
 
- 	 collectgarbage()
 
-       end
 
-    end
 
-    return x
 
- end
 
- torch.manualSeed(settings.seed)
 
- print(settings)
 
- local x = load_images(settings.image_list)
 
- torch.save(settings.images, x)
 
 
  |