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

11
BATCH_SIZE = 128
Q
Qiao Longfei 已提交
12
image = layers.data(name='x', shape=[784], data_type='float32')
Q
qijun 已提交
13

14 15
param_attr = {
    'name': None,
16 17
    'initializer': UniformInitializer(
        low=-1.0, high=1.0),
18 19 20
    'regularization': L2DecayRegularizer(0.0005 * BATCH_SIZE)
}

Q
Qiao Longfei 已提交
21 22
hidden1 = layers.fc(input=image, size=128, act='relu', param_attr=param_attr)
hidden2 = layers.fc(input=hidden1, size=64, act='relu', param_attr=param_attr)
Q
qijun 已提交
23 24 25 26

predict = layers.fc(input=hidden2,
                    size=10,
                    act='softmax',
27
                    param_attr=param_attr)
Q
qijun 已提交
28

Q
Qiao Longfei 已提交
29
label = layers.data(name='y', shape=[1], data_type='int64')
Q
qijun 已提交
30

31 32
cost = layers.cross_entropy(input=predict, label=label)
avg_cost = layers.mean(x=cost)
Q
Qiao Longfei 已提交
33
accuracy = layers.accuracy(input=predict, label=label)
Q
qijun 已提交
34

Q
Qiao Longfei 已提交
35
optimizer = MomentumOptimizer(learning_rate=0.001, momentum=0.9)
36
opts = optimizer.minimize(avg_cost)
Q
qijun 已提交
37 38 39 40 41 42 43 44 45

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

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

46
exe.run(framework.default_startup_program())
Q
qijun 已提交
47 48 49 50 51

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")
52
        y_data = np.array(map(lambda x: x[1], data)).astype("int64")
Q
qijun 已提交
53 54 55 56 57 58 59 60
        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)

61
        outs = exe.run(framework.default_main_program(),
Q
qijun 已提交
62 63
                       feed={'x': tensor_x,
                             'y': tensor_y},
64
                       fetch_list=[avg_cost, accuracy])
Q
qijun 已提交
65
        out = np.array(outs[0])
66
        acc = np.array(outs[1])
Q
qijun 已提交
67 68 69
        if out[0] < 5.0:
            exit(0)  # if avg cost less than 5.0, we think our code is good.
exit(1)