max_cn.rst 2.4 KB
Newer Older
1 2 3

.. _cn_api_paddle_tensor_max:

T
tianshuo78520a 已提交
4 5
max
-------------------------------
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54

.. py:function:: paddle.tensor.max(input, dim=None, keep_dim=False, out=None, name=None)

该OP是对指定维度上的Tensor元素求最大值运算,并输出相应的计算结果。等价于 :ref:`cn_api_fluid_layers_reduce_max`

参数:
          - **input** (Variable)- 输入变量为多维Tensor或LoDTensor,支持数据类型为float32,float64,int32,int64。
          - **dim** (list | int ,可选)- 求最大值运算的维度。如果为None,则计算所有元素的最大值并返回包含单个元素的Tensor变量,否则必须在  :math:`[−rank(input),rank(input)]` 范围内。如果 :math:`dim [i] <0` ,则维度将变为 :math:`rank+dim[i]` ,默认值为None。
          - **keep_dim** (bool)- 是否在输出Tensor中保留减小的维度。如 keep_dim 为true,否则结果张量的维度将比输入张量小,默认值为False。
          - **out**  (Variable, 可选) -  指定算子输出结果的LoDTensor/Tensor,可以是程序中已经创建的任何Variable。默认值为None,此时将创建新的Variable来保存输出结果。
          - **name** (str, 可选)- 具体用法请参见 :ref:`api_guide_Name` ,一般无需设置,默认值为None。

返回:  在指定dim上进行求最大值运算的Tensor,数据类型和输入数据类型一致。

返回类型:  变量(Variable)

**代码示例**

..  code-block:: python

    import paddle
    import paddle.fluid as fluid
    # x是一个Tensor,元素如下:
    #    [[0.2, 0.3, 0.5, 0.9]
    #     [0.1, 0.2, 0.6, 0.7]]
    # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
    x = fluid.data(name='x', shape=[2, 4], dtype='float32')
    # paddle.max 等价于 paddle.tensor.max
    paddle.max(x)  # [0.9]
    paddle.max(x, dim=0)  # [0.2, 0.3, 0.6, 0.9]
    paddle.max(x, dim=-1)  # [0.9, 0.7]
    paddle.max(x, dim=1, keep_dim=True)  # [[0.9], [0.7]]

    # y是一个shape为[2, 2, 2]的Tensor,元素如下:
    #      [[[1.0, 2.0], [3.0, 4.0]],
    #      [[5.0, 6.0], [7.0, 8.0]]]
    # 接下来的示例中,我们在每处函数调用后面都标注出了它的结果张量。
    y = fluid.data(name='y', shape=[2, 2, 2], dtype='float32')
    paddle.max(y, dim=[1, 2]) # [4.0, 8.0]
    paddle.max(y, dim=[0, 1]) # [7.0, 8.0]