test_recognize_digits_mlp.py 2.4 KB
Newer Older
Q
qijun 已提交
1
import paddle.v2 as paddle
Q
Qiao Longfei 已提交
2 3 4
import paddle.v2.fluid.layers as layers
import paddle.v2.fluid.core as core
import paddle.v2.fluid.optimizer as optimizer
5
import paddle.v2.fluid.framework as framework
Q
Qiao Longfei 已提交
6 7 8
from paddle.v2.fluid.executor import Executor
from paddle.v2.fluid.regularizer import L2DecayRegularizer
from paddle.v2.fluid.initializer import UniformInitializer
Q
qijun 已提交
9 10 11

import numpy as np

12
BATCH_SIZE = 128
Q
qijun 已提交
13 14 15
image = layers.data(
    name='x',
    shape=[784],
16
    data_type='float32')
Q
qijun 已提交
17

18 19
param_attr = {
    'name': None,
20 21
    'initializer': UniformInitializer(
        low=-1.0, high=1.0),
22 23 24
    'regularization': L2DecayRegularizer(0.0005 * BATCH_SIZE)
}

Q
qijun 已提交
25 26 27
hidden1 = layers.fc(input=image,
                    size=128,
                    act='relu',
28
                    param_attr=param_attr)
Q
qijun 已提交
29 30 31
hidden2 = layers.fc(input=hidden1,
                    size=64,
                    act='relu',
32
                    param_attr=param_attr)
Q
qijun 已提交
33 34 35 36

predict = layers.fc(input=hidden2,
                    size=10,
                    act='softmax',
37
                    param_attr=param_attr)
Q
qijun 已提交
38 39 40 41

label = layers.data(
    name='y',
    shape=[1],
42
    data_type='int64')
Q
qijun 已提交
43

44 45
cost = layers.cross_entropy(input=predict, label=label)
avg_cost = layers.mean(x=cost)
46
accuracy = layers.accuracy(
47
    input=predict,
48
    label=label)
Q
qijun 已提交
49

Q
Qiao Longfei 已提交
50
optimizer = optimizer.MomentumOptimizer(learning_rate=0.001, momentum=0.9)
51
opts = optimizer.minimize(avg_cost)
Q
qijun 已提交
52 53 54 55 56 57 58 59 60

train_reader = paddle.batch(
    paddle.reader.shuffle(
        paddle.dataset.mnist.train(), buf_size=8192),
    batch_size=BATCH_SIZE)

place = core.CPUPlace()
exe = Executor(place)

61
exe.run(framework.default_startup_program())
Q
qijun 已提交
62 63 64 65 66

PASS_NUM = 100
for pass_id in range(PASS_NUM):
    for data in train_reader():
        x_data = np.array(map(lambda x: x[0], data)).astype("float32")
67
        y_data = np.array(map(lambda x: x[1], data)).astype("int64")
Q
qijun 已提交
68 69 70 71 72 73 74 75
        y_data = np.expand_dims(y_data, axis=1)

        tensor_x = core.LoDTensor()
        tensor_x.set(x_data, place)

        tensor_y = core.LoDTensor()
        tensor_y.set(y_data, place)

76
        outs = exe.run(framework.default_main_program(),
Q
qijun 已提交
77 78
                       feed={'x': tensor_x,
                             'y': tensor_y},
79
                       fetch_list=[avg_cost, accuracy])
Q
qijun 已提交
80
        out = np.array(outs[0])
81
        acc = np.array(outs[1])
Q
qijun 已提交
82 83 84
        if out[0] < 5.0:
            exit(0)  # if avg cost less than 5.0, we think our code is good.
exit(1)