test_recognize_digits_conv.py 2.5 KB
Newer Older
Q
Qiao Longfei 已提交
1
import numpy as np
F
fengjiayi 已提交
2
import paddle.v2 as paddle
Q
Qiao Longfei 已提交
3
import paddle.v2.fluid.core as core
D
Dong Zhihong 已提交
4
import paddle.v2.fluid.evaluator as evaluator
H
Helin Wang 已提交
5
import paddle.v2.fluid.framework as framework
Q
Qiao Longfei 已提交
6 7
import paddle.v2.fluid.layers as layers
import paddle.v2.fluid.nets as nets
Q
Qiao Longfei 已提交
8
from paddle.v2.fluid.executor import Executor
Q
Qiao Longfei 已提交
9
from paddle.v2.fluid.optimizer import AdamOptimizer
F
fengjiayi 已提交
10

F
fengjiayi 已提交
11 12
images = layers.data(name='pixel', shape=[1, 28, 28], dtype='float32')
label = layers.data(name='label', shape=[1], dtype='int64')
F
fengjiayi 已提交
13 14 15 16 17 18
conv_pool_1 = nets.simple_img_conv_pool(
    input=images,
    filter_size=5,
    num_filters=20,
    pool_size=2,
    pool_stride=2,
19
    act="relu")
F
fengjiayi 已提交
20 21 22 23 24 25
conv_pool_2 = nets.simple_img_conv_pool(
    input=conv_pool_1,
    filter_size=5,
    num_filters=50,
    pool_size=2,
    pool_stride=2,
26
    act="relu")
F
fengjiayi 已提交
27

Q
Qiao Longfei 已提交
28
predict = layers.fc(input=conv_pool_2, size=10, act="softmax")
H
helinwang 已提交
29
cost = layers.cross_entropy(input=predict, label=label)
30
avg_cost = layers.mean(x=cost)
Q
Qiao Longfei 已提交
31
optimizer = AdamOptimizer(learning_rate=0.01, beta1=0.9, beta2=0.999)
32
opts = optimizer.minimize(avg_cost)
F
fengjiayi 已提交
33

Q
Qiao Longfei 已提交
34
accuracy, acc_out = evaluator.accuracy(input=predict, label=label)
D
Dong Zhihong 已提交
35

F
fengjiayi 已提交
36
BATCH_SIZE = 50
F
fengjiayi 已提交
37
PASS_NUM = 3
F
fengjiayi 已提交
38 39 40 41 42 43 44 45
train_reader = paddle.batch(
    paddle.reader.shuffle(
        paddle.dataset.mnist.train(), buf_size=500),
    batch_size=BATCH_SIZE)

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

46
exe.run(framework.default_startup_program())
F
fengjiayi 已提交
47 48

for pass_id in range(PASS_NUM):
D
Dong Zhihong 已提交
49
    accuracy.reset(exe)
F
fengjiayi 已提交
50 51 52
    for data in train_reader():
        img_data = np.array(map(lambda x: x[0].reshape([1, 28, 28]),
                                data)).astype("float32")
53
        y_data = np.array(map(lambda x: x[1], data)).astype("int64")
F
fengjiayi 已提交
54 55 56 57 58 59 60
        y_data = y_data.reshape([BATCH_SIZE, 1])

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

61
        outs = exe.run(framework.default_main_program(),
F
fengjiayi 已提交
62 63
                       feed={"pixel": tensor_img,
                             "label": tensor_y},
D
Dong Zhihong 已提交
64
                       fetch_list=[avg_cost, acc_out])
F
fengjiayi 已提交
65
        loss = np.array(outs[0])
F
fengjiayi 已提交
66
        acc = np.array(outs[1])
D
Dong Zhihong 已提交
67
        pass_acc = accuracy.eval(exe)
F
fengjiayi 已提交
68 69
        print("pass_id=" + str(pass_id) + " acc=" + str(acc) + " pass_acc=" +
              str(pass_acc))
D
Dong Zhihong 已提交
70
        # print loss, acc
F
fengjiayi 已提交
71
        if loss < 10.0 and pass_acc > 0.9:
F
fengjiayi 已提交
72 73
            # if avg cost less than 10.0 and accuracy is larger than 0.9, we think our code is good.
            exit(0)
D
Dong Zhihong 已提交
74 75

    pass_acc = accuracy.eval(exe)
F
fengjiayi 已提交
76
    print("pass_id=" + str(pass_id) + " pass_acc=" + str(pass_acc))
F
fengjiayi 已提交
77 78

exit(1)