test_print_op.py 5.4 KB
Newer Older
1
#   Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved.
D
dzhwinter 已提交
2
#
D
dzhwinter 已提交
3 4 5
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
D
dzhwinter 已提交
6
#
D
dzhwinter 已提交
7
#     http://www.apache.org/licenses/LICENSE-2.0
D
dzhwinter 已提交
8
#
D
dzhwinter 已提交
9 10 11 12 13 14
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

Y
Yan Chunwei 已提交
15
import unittest
16 17

import numpy as np
18
from simple_nets import init_data, simple_fc_net
19 20

import paddle
21
import paddle.fluid as fluid
22
import paddle.fluid.layers as layers
23
from paddle.fluid import core
24
from paddle.fluid.framework import switch_main_program
25 26 27
from paddle.static import Program, program_guard

paddle.enable_static()
Y
yangyaming 已提交
28 29 30 31


class TestPrintOpCPU(unittest.TestCase):
    def setUp(self):
32 33
        self.place = paddle.CPUPlace()
        self.x_tensor = fluid.core.LoDTensor()
Y
yangyaming 已提交
34 35
        tensor_np = np.random.random(size=(2, 3)).astype('float32')
        self.x_tensor.set(tensor_np, self.place)
36
        self.x_tensor.set_recursive_sequence_lengths([[1, 1]])
Y
Yan Chunwei 已提交
37

Y
yangyaming 已提交
38 39 40
    def build_network(self, only_forward, **kargs):
        x = layers.data('x', shape=[3], dtype='float32', lod_level=1)
        x.stop_gradient = False
41 42 43
        paddle.static.Print(input=x, **kargs)
        loss = paddle.mean(x)
        paddle.static.append_backward(loss=loss)
Y
yangyaming 已提交
44
        return loss
Y
Yan Chunwei 已提交
45

Y
yangyaming 已提交
46 47 48
    def test_forward(self):
        switch_main_program(Program())
        printed = self.build_network(True, print_phase='forward')
49
        exe = paddle.static.Executor(self.place)
50 51 52
        outs = exe.run(
            feed={'x': self.x_tensor}, fetch_list=[printed], return_numpy=False
        )
Y
Yan Chunwei 已提交
53

Y
yangyaming 已提交
54 55 56
    def test_backward(self):
        switch_main_program(Program())
        loss = self.build_network(False, print_phase='backward')
57
        exe = paddle.static.Executor(self.place)
58 59 60
        outs = exe.run(
            feed={'x': self.x_tensor}, fetch_list=[loss], return_numpy=False
        )
Y
Yan Chunwei 已提交
61

62 63 64 65 66 67 68 69
    def test_all_parameters(self):
        x = layers.data('x', shape=[3], dtype='float32', lod_level=1)
        x.stop_gradient = False

        for print_tensor_name in [True, False]:
            for print_tensor_type in [True, False]:
                for print_tensor_shape in [True, False]:
                    for print_tensor_lod in [True, False]:
70
                        paddle.static.Print(
71 72 73 74
                            input=x,
                            print_tensor_name=print_tensor_name,
                            print_tensor_type=print_tensor_type,
                            print_tensor_shape=print_tensor_shape,
75 76
                            print_tensor_lod=print_tensor_lod,
                        )
77 78 79
        loss = paddle.mean(x)
        paddle.static.append_backward(loss=loss)
        exe = paddle.static.Executor(self.place)
80 81 82
        outs = exe.run(
            feed={'x': self.x_tensor}, fetch_list=[loss], return_numpy=False
        )
83

84 85 86
    def test_no_summarize(self):
        switch_main_program(Program())
        printed = self.build_network(True, summarize=-1, print_phase='forward')
87
        exe = paddle.static.Executor(self.place)
88 89 90
        outs = exe.run(
            feed={'x': self.x_tensor}, fetch_list=[printed], return_numpy=False
        )
91

Y
Yan Chunwei 已提交
92

93
class TestPrintOpError(unittest.TestCase):
94 95 96
    def test_errors(self):
        with program_guard(Program(), Program()):
            # The input type of Print_op must be Variable.
97 98 99
            x1 = fluid.create_lod_tensor(
                np.array([[-1]]), [[1]], paddle.CPUPlace()
            )
100
            self.assertRaises(TypeError, paddle.static.Print, x1)
101
            # The input dtype of Print_op must be float32, float64, int32_t, int64_t or bool.
102 103
            x2 = paddle.static.data(name='x2', shape=[4], dtype="float16")
            self.assertRaises(TypeError, paddle.static.Print, x2)
104 105


106 107 108
@unittest.skipIf(
    not core.is_compiled_with_cuda(), "core is not compiled with CUDA"
)
Y
yangyaming 已提交
109 110
class TestPrintOpGPU(TestPrintOpCPU):
    def setUp(self):
111 112
        self.place = paddle.CUDAPlace(0)
        self.x_tensor = fluid.core.LoDTensor()
Y
yangyaming 已提交
113 114
        tensor_np = np.random.random(size=(2, 3)).astype('float32')
        self.x_tensor.set(tensor_np, self.place)
115
        self.x_tensor.set_recursive_sequence_lengths([[1, 1]])
Y
Yan Chunwei 已提交
116 117


118 119
class TestPrintOpBackward(unittest.TestCase):
    def check_backward(self, use_cuda):
120 121
        main = paddle.static.Program()
        startup = paddle.static.Program()
122

123
        with program_guard(main, startup):
124
            loss = simple_fc_net()
125 126
            loss = paddle.static.Print(loss)
            paddle.optimizer.Adam().minimize(loss)
127

128
        print_ops = [op for op in main.blocks[0].ops if op.type == 'print']
129 130
        assert len(print_ops) == 2, "The number of print op should be 2"

131 132
        place = paddle.CUDAPlace(0) if use_cuda else paddle.CPUPlace()
        exe = paddle.static.Executor(place)
133 134
        exe.run(startup)

135
        binary = paddle.static.CompiledProgram(main).with_data_parallel(
136 137
            loss_name=loss.name
        )
138 139 140 141 142 143

        img, label = init_data()
        feed_dict = {"image": img, "label": label}
        exe.run(binary, feed_dict)

    def test_fw_bw(self):
144
        if paddle.is_compiled_with_cuda():
145 146 147 148
            self.check_backward(use_cuda=True)
        self.check_backward(use_cuda=False)


Y
Yan Chunwei 已提交
149 150
if __name__ == '__main__':
    unittest.main()