Sha256: 1054260272c06b73958d25447ce411a0d86fc19d656f850ca96686476aea324c

Contents?: true

Size: 1.26 KB

Versions: 1

Compression:

Stored size: 1.26 KB

Contents

require "dnn"
require "dnn/mnist"
require "numo/linalg/autoloader"
require_relative "dcgan"

MNIST = DNN::MNIST

Numo::SFloat.srand(rand(1 << 31))

epochs = 20
batch_size = 128

gen = Generator.new
dis = Discriminator.new
dcgan = DCGAN.new(gen, dis)

dis.setup(Adam.new(alpha: 0.00001, beta1: 0.1), SigmoidCrossEntropy.new)
dcgan.setup(Adam.new(alpha: 0.0002, beta1: 0.5), SigmoidCrossEntropy.new)

x_train, y_train = MNIST.load_train
x_train = Numo::SFloat.cast(x_train)
x_train = x_train / 127.5 - 1

iter = DNN::Iterator.new(x_train, y_train)
(1..epochs).each do |epoch|
  puts "epoch: #{epoch}"
  iter.foreach(batch_size) do |x_batch, y_batch, index|
    noise = Numo::SFloat.new(batch_size, 20).rand(-1, 1)
    images = gen.predict(noise)
    x = x_batch.concatenate(images)
    y = Numo::SFloat.cast([1] * batch_size + [0] * batch_size).reshape(batch_size * 2, 1)
    dis_loss = dis.train_on_batch(x, y)

    noise = Numo::SFloat.new(batch_size, 20).rand(-1, 1)
    label = Numo::SFloat.cast([1] * batch_size).reshape(batch_size, 1)
    dcgan_loss = dcgan.train_on_batch(noise, label)

    puts "index: #{index}, dis_loss: #{dis_loss.mean}, dcgan_loss: #{dcgan_loss.mean}"
  end
  dcgan.save("trained/dcgan_model_epoch#{epoch}.marshal")
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
ruby-dnn-0.12.4 examples/dcgan/train.rb