Print_cn.rst 2.8 KB
Newer Older
H
Hao Wang 已提交
1 2 3 4 5 6 7 8 9
.. _cn_api_fluid_layers_Print:

Print
-------------------------------

.. py:function:: paddle.fluid.layers.Print(input, first_n=-1, message=None, summarize=-1, print_tensor_name=True, print_tensor_type=True, print_tensor_shape=True, print_tensor_lod=True, print_phase='both')

**Print操作命令**

10
该OP创建一个打印操作,打印正在访问的Tensor内容。
H
Hao Wang 已提交
11

12
封装传入的Tensor,以便无论何时访问Tensor,都会打印信息message和Tensor的当前值。
H
Hao Wang 已提交
13 14

参数:
15 16 17 18 19 20 21 22 23
    - **input** (Variable)-将要打印的Tensor
    - **summarize** (int)-打印Tensor中的元素数目,如果值为-1则打印所有元素
    - **message** (str)-打印Tensor信息前自定义的字符串类型消息,作为前缀打印
    - **first_n** (int)-打印Tensor的次数
    - **print_tensor_name** (bool)-可选,指明是否打印Tensor名称,默认为True
    - **print_tensor_type** (bool)-可选,指明是否打印Tensor类型,默认为True
    - **print_tensor_shape** (bool)-可选,指明是否打印Tensor维度信息,默认为True
    - **print_tensor_lod** (bool)-可选,指明是否打印Tensor的LoD信息,默认为True
    - **print_phase** (str)-可选,指明打印的阶段,包括 ``forward`` , ``backward`` 和 ``both`` ,默认为 ``both`` 。设置为 ``forward`` 时,只打印Tensor的前向信息;设置为 ``backward`` 时,只打印Tensor的梯度信息;设置为 ``both`` 时,则同时打印Tensor的前向信息以及梯度信息。
H
Hao Wang 已提交
24

25
返回:输出Tensor
H
Hao Wang 已提交
26

27
返回类型:Variable
H
Hao Wang 已提交
28 29

.. note::
30
   输入和输出是两个不同的Variable,在接下来的过程中,应该使用输出Variable而非输入Variable,否则打印层将失去backward的信息。
H
Hao Wang 已提交
31 32 33 34 35 36

**代码示例**:

.. code-block:: python

    import paddle.fluid as fluid
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
    import paddle
    import numpy as np

    x = fluid.layers.data(name='x', shape=[1], dtype='float32', lod_level=1)
    x = fluid.layers.Print(x, message="The content of input layer:") 
    
    y = fluid.layers.data(name='y', shape=[1], dtype='float32', lod_level=2)
    out = fluid.layers.sequence_expand(x=x, y=y, ref_level=0)
    place = fluid.CPUPlace()
    exe = fluid.Executor(place)
    exe.run(fluid.default_startup_program())
    x_d = fluid.create_lod_tensor(np.array([[1.1], [2.2],[3.3],[4.4]]).astype('float32'), [[1,3]], place)
    y_d = fluid.create_lod_tensor(np.array([[1.1],[1.1],[1.1],[1.1],[1.1],[1.1]]).astype('float32'), [[1,3], [1,2,1,2]], place)
    results = exe.run(fluid.default_main_program(),
                      feed={'x':x_d, 'y': y_d },
                      fetch_list=[out],return_numpy=False)
Z
zq19 已提交
53 54 55 56
**运行输出**:

.. code-block:: bash 
   
57 58 59 60 61 62
   The content of input layer:    The place is:CPUPlace
   Tensor[x]
    shape: [4,1,]
    dtype: f
    LoD: [[ 0,1,4, ]]
    data: 1.1,2.2,3.3,4.4,
H
Hao Wang 已提交
63 64 65 66 67