to_variable_cn.rst 1.4 KB
Newer Older
H
Hao Wang 已提交
1 2 3 4 5
.. _cn_api_fluid_dygraph_to_variable:

to_variable
-------------------------------

6
.. py:function:: paddle.fluid.dygraph.to_variable(value, block=None, name=None, zero_copy=None)
H
Hao Wang 已提交
7

8
该函数实现从numpy\.ndarray对象或者Variable对象创建一个 ``Variable`` 类型的对象。
H
Hao Wang 已提交
9 10

参数:
11 12 13
    - **value** (ndarray) – 需要转换的numpy\.ndarray对象,维度可以为多维,数据类型为numpy\.{float16, float32, float64, int16, int32, int64, uint8, uint16}中的一种。
    - **block** (fluid.Block, 可选) – Variable所在的Block,默认值为None。
    - **name**  (str, 可选) – 具体用法请参见 :ref:`api_guide_Name` ,一般无需设置,默认值为None。
14
    - **zero_copy**  (bool, 可选) – 是否与输入的numpy数组共享内存。此参数仅适用于CPUPlace,当它为None时将设置为True。默认值为None。
H
Hao Wang 已提交
15 16


17
返回:从指定numpy\.ndarray对象创建的 ``Tensor`` ,数据类型和 ``value`` 一致,返回值维度和 ``value`` 一致
H
Hao Wang 已提交
18 19 20 21 22 23 24 25 26 27

返回类型:Variable

**代码示例**:

.. code-block:: python
    
    import numpy as np
    import paddle.fluid as fluid

28
    with fluid.dygraph.guard(fluid.CPUPlace()):
H
Hao Wang 已提交
29
        x = np.ones([2, 2], np.float32)
30 31 32
        y = fluid.dygraph.to_variable(x, zero_copy=False)
        x[0][0] = -1
        y[0][0].numpy()  # array([1.], dtype=float32)
H
Hao Wang 已提交
33
        y = fluid.dygraph.to_variable(x)
34 35
        x[0][0] = 0
        y[0][0].numpy()  # array([0.], dtype=float32)
H
Hao Wang 已提交
36