Sha256: 7300b6552ecef5fcb0460ad4f80513ee4b3220749d568c8a0102b82e1a2e3f3a

Contents?: true

Size: 1.11 KB

Versions: 5

Compression:

Stored size: 1.11 KB

Contents

require "dnn"
require "dnn/lib/mnist"
# require "numo/linalg/autoloader"

include DNN::Layers
include DNN::Activations
include DNN::Optimizers
include DNN::Losses
Model = DNN::Model
MNIST = DNN::MNIST

x_train, y_train = MNIST.load_train
x_test, y_test = MNIST.load_test

x_train = Numo::SFloat.cast(x_train).reshape(x_train.shape[0], 28, 28, 1)
x_test = Numo::SFloat.cast(x_test).reshape(x_test.shape[0], 28, 28, 1)

x_train /= 255
x_test /= 255

y_train = DNN::Utils.to_categorical(y_train, 10, Numo::SFloat)
y_test = DNN::Utils.to_categorical(y_test, 10, Numo::SFloat)

model = Model.new

model << InputLayer.new([28, 28, 1])

model << Conv2D.new(16, 5)
model << BatchNormalization.new
model << ReLU.new

model << MaxPool2D.new(2)

model << Conv2D.new(32, 5)
model << BatchNormalization.new
model << ReLU.new

model << Flatten.new

model << Dense.new(256)
model << BatchNormalization.new
model << ReLU.new
model << Dropout.new(0.5)

model << Dense.new(10)

model.compile(Adam.new, SoftmaxCrossEntropy.new)

model.train(x_train, y_train, 10, batch_size: 100, test: [x_test, y_test])

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
ruby-dnn-0.9.4 examples/mnist_conv2d_example.rb
ruby-dnn-0.9.3 examples/mnist_conv2d_example.rb
ruby-dnn-0.9.2 examples/mnist_conv2d_example.rb
ruby-dnn-0.9.1 examples/mnist_conv2d_example.rb
ruby-dnn-0.9.0 examples/mnist_conv2d_example.rb