Sha256: 4ae4934410afe5ef8be2284c11d5530f462c744baba41bebaa85ba5f0e0d8d34

Contents?: true

Size: 1.78 KB

Versions: 9

Compression:

Stored size: 1.78 KB

Contents

require "zlib"
require "archive/tar/minitar"
require_relative "../../../ext/cifar_loader/cifar_loader"
require_relative "downloader"

URL_CIFAR10 = "https://www.cs.toronto.edu/~kriz/cifar-10-binary.tar.gz"
DIR_CIFAR10 = "cifar-10-batches-bin"

module DNN
  module CIFAR10
    class DNN_CIFAR10_LoadError < DNN_Error; end

    def self.downloads
      return if Dir.exist?(DOWNLOADS_PATH + "/downloads/" + DIR_CIFAR10)
      Downloader.download(URL_CIFAR10)
      cifar10_binary_file_name = DOWNLOADS_PATH + "/downloads/" + URL_CIFAR10.match(%r`.+/(.+)`)[1]
      begin
        Zlib::GzipReader.open(cifar10_binary_file_name) do |gz|
          Archive::Tar::Minitar.unpack(gz, DOWNLOADS_PATH + "/downloads")
        end
      ensure
        File.unlink(cifar10_binary_file_name)
      end
    end

    def self.load_train
      downloads
      bin = ""
      (1..5).each do |i|
        fname = DOWNLOADS_PATH + "/downloads/#{DIR_CIFAR10}/data_batch_#{i}.bin"
        raise DNN_CIFAR10_LoadError.new(%`file "#{fname}" is not found.`) unless File.exist?(fname)
        bin << File.binread(fname)
      end
      x_bin, y_bin = CIFAR10.load_binary(bin, 50000)
      x_train = Numo::UInt8.from_binary(x_bin).reshape(50000, 3, 32, 32).transpose(0, 2, 3, 1).clone
      y_train = Numo::UInt8.from_binary(y_bin)
      [x_train, y_train]
    end

    def self.load_test
      downloads
      fname = DOWNLOADS_PATH + "/downloads/#{DIR_CIFAR10}/test_batch.bin"
      raise DNN_CIFAR10_LoadError.new(%`file "#{fname}" is not found.`) unless File.exist?(fname)
      bin = File.binread(fname)
      x_bin, y_bin = CIFAR10.load_binary(bin, 10000)
      x_test = Numo::UInt8.from_binary(x_bin).reshape(10000, 3, 32, 32).transpose(0, 2, 3, 1).clone
      y_test = Numo::UInt8.from_binary(y_bin)
      [x_test, y_test]
    end
  end
end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
ruby-dnn-0.15.3 lib/dnn/datasets/cifar10.rb
ruby-dnn-0.15.2 lib/dnn/datasets/cifar10.rb
ruby-dnn-0.15.1 lib/dnn/datasets/cifar10.rb
ruby-dnn-0.15.0 lib/dnn/datasets/cifar10.rb
ruby-dnn-0.14.3 lib/dnn/datasets/cifar10.rb
ruby-dnn-0.14.2 lib/dnn/datasets/cifar10.rb
ruby-dnn-0.14.1 lib/dnn/datasets/cifar10.rb
ruby-dnn-0.14.0 lib/dnn/datasets/cifar10.rb
ruby-dnn-0.13.4 lib/dnn/datasets/cifar10.rb