test_recognize_digits_conv.py 3.1 KB
Newer Older
F
fengjiayi 已提交
1
import paddle.v2 as paddle
Q
Qiao Longfei 已提交
2 3 4 5
import paddle.v2.fluid.layers as layers
import paddle.v2.fluid.nets as nets
import paddle.v2.fluid.core as core
import paddle.v2.fluid.optimizer as optimizer
F
fengjiayi 已提交
6

Q
Qiao Longfei 已提交
7 8
from paddle.v2.fluid.framework import Program
from paddle.v2.fluid.executor import Executor
F
fengjiayi 已提交
9 10 11

import numpy as np

12 13
startup_program = Program()
main_program = Program()
F
fengjiayi 已提交
14 15 16 17 18

images = layers.data(
    name='pixel',
    shape=[1, 28, 28],
    data_type='float32',
19 20
    main_program=main_program,
    startup_program=startup_program)
F
fengjiayi 已提交
21 22 23
label = layers.data(
    name='label',
    shape=[1],
24
    data_type='int64',
25 26
    main_program=main_program,
    startup_program=startup_program)
F
fengjiayi 已提交
27 28 29 30 31 32 33
conv_pool_1 = nets.simple_img_conv_pool(
    input=images,
    filter_size=5,
    num_filters=20,
    pool_size=2,
    pool_stride=2,
    act="relu",
34 35
    main_program=main_program,
    startup_program=startup_program)
F
fengjiayi 已提交
36 37 38 39 40 41 42
conv_pool_2 = nets.simple_img_conv_pool(
    input=conv_pool_1,
    filter_size=5,
    num_filters=50,
    pool_size=2,
    pool_stride=2,
    act="relu",
43 44
    main_program=main_program,
    startup_program=startup_program)
F
fengjiayi 已提交
45 46 47 48

predict = layers.fc(input=conv_pool_2,
                    size=10,
                    act="softmax",
49 50
                    main_program=main_program,
                    startup_program=startup_program)
F
fengjiayi 已提交
51
cost = layers.cross_entropy(
52 53 54 55 56
    input=predict,
    label=label,
    main_program=main_program,
    startup_program=startup_program)
avg_cost = layers.mean(x=cost, main_program=main_program)
Q
Qiao Longfei 已提交
57
optimizer = optimizer.AdamOptimizer(learning_rate=0.01, beta1=0.9, beta2=0.999)
58
opts = optimizer.minimize(avg_cost, startup_program)
F
fengjiayi 已提交
59

D
Dong Zhihong 已提交
60
accuracy, acc_out = evaluator.accuracy(
D
Dong Zhihong 已提交
61 62 63 64 65
    input=predict,
    label=label,
    main_program=main_program,
    startup_program=startup_program)

F
fengjiayi 已提交
66
BATCH_SIZE = 50
F
fengjiayi 已提交
67
PASS_NUM = 3
F
fengjiayi 已提交
68 69 70 71 72 73 74 75
train_reader = paddle.batch(
    paddle.reader.shuffle(
        paddle.dataset.mnist.train(), buf_size=500),
    batch_size=BATCH_SIZE)

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

76
exe.run(startup_program, feed={}, fetch_list=[])
F
fengjiayi 已提交
77 78 79

for pass_id in range(PASS_NUM):
    count = 0
D
Dong Zhihong 已提交
80
    accuracy.reset(exe)
F
fengjiayi 已提交
81 82 83
    for data in train_reader():
        img_data = np.array(map(lambda x: x[0].reshape([1, 28, 28]),
                                data)).astype("float32")
84
        y_data = np.array(map(lambda x: x[1], data)).astype("int64")
F
fengjiayi 已提交
85 86 87 88 89 90 91
        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)

92
        outs = exe.run(main_program,
F
fengjiayi 已提交
93 94
                       feed={"pixel": tensor_img,
                             "label": tensor_y},
D
Dong Zhihong 已提交
95
                       fetch_list=[avg_cost, acc_out])
F
fengjiayi 已提交
96
        loss = np.array(outs[0])
F
fengjiayi 已提交
97
        acc = np.array(outs[1])
D
Dong Zhihong 已提交
98 99 100 101 102 103 104 105 106
        pass_acc = accuracy.eval(exe)
        print "pass id : ", pass_id, pass_acc
        # print loss, acc
        if loss < 10.0 and acc > 0.9:
            # if avg cost less than 10.0 and accuracy is larger than 0.9, we think our code is good.
            exit(0)

    pass_acc = accuracy.eval(exe)
    print "pass id : ", pass_id, pass_acc
F
fengjiayi 已提交
107 108

exit(1)