to_tensor

paddle. to_tensor ( data: TensorLike | NestedNumericSequence, dtype: DTypeLike | None = None, place: PlaceLike | None = None, stop_gradient: bool = True ) paddle.Tensor [source]

Constructs a paddle.Tensor from data , which can be scalar, tuple, list, numpy.ndarray, paddle.Tensor.

If the data is already a Tensor, copy will be performed and return a new tensor. If you only want to change stop_gradient property, please call Tensor.stop_gradient = stop_gradient directly.

System Message: ERROR/3 (/usr/local/lib/python3.10/site-packages/paddle/tensor/creation.py:docstring of paddle.tensor.creation.to_tensor, line 2)

Content block expected for the “note” directive; none found.

.. note::

System Message: WARNING/2 (/usr/local/lib/python3.10/site-packages/paddle/tensor/creation.py:docstring of paddle.tensor.creation.to_tensor, line 3)

Explicit markup ends without a blank line; unexpected unindent.

Alias Support: The parameter name device can be used as an alias for place. For example, device=paddle.CUDAPlace(0) is equivalent to place=paddle.CUDAPlace(0).

We use the dtype conversion rules following this:
        Keep dtype
np.number ───────────► paddle.Tensor
                        (0-D Tensor)
            default_dtype
Python Number ───────────────► paddle.Tensor
                                (0-D Tensor)
            Keep dtype
np.ndarray ───────────► paddle.Tensor
Parameters
  • data (scalar|tuple|list|ndarray|Tensor) – Initial data for the tensor. Can be a scalar, list, tuple, numpy.ndarray, paddle.Tensor.

  • dtype (str|np.dtype, optional) – The desired data type of returned tensor. Can be ‘bool’ , ‘float16’ , ‘float32’ , ‘float64’ , ‘int8’ , ‘int16’ , ‘int32’ , ‘int64’ , ‘uint8’, ‘complex64’ , ‘complex128’. Default: None, infers dtype from data except for python float number which gets dtype from get_default_type .

  • place (CPUPlace|CUDAPinnedPlace|CUDAPlace|str, optional) – The place to allocate Tensor. Can be CPUPlace, CUDAPinnedPlace, CUDAPlace. Default: None, means global place. If place is string, It can be cpu, gpu:x and gpu_pinned, where x is the index of the GPUs.

  • device – An alias for place , with identical behavior.

  • stop_gradient (bool, optional) – Whether to block the gradient propagation of Autograd. Default: True.

Returns

A Tensor constructed from data .

Return type

Tensor

Examples

>>> import paddle

>>> type(paddle.to_tensor(1))
<class 'paddle.Tensor'>

>>> paddle.to_tensor(1)
Tensor(shape=[], dtype=int64, place=Place(cpu), stop_gradient=True,
1)

>>> x = paddle.to_tensor(1, stop_gradient=False)
>>> print(x)
Tensor(shape=[], dtype=int64, place=Place(cpu), stop_gradient=False,
1)

>>> paddle.to_tensor(x)  # A new tensor will be created with default stop_gradient=True
Tensor(shape=[], dtype=int64, place=Place(cpu), stop_gradient=True,
1)

>>> paddle.to_tensor([[0.1, 0.2], [0.3, 0.4]], place=paddle.CPUPlace(), stop_gradient=False)
Tensor(shape=[2, 2], dtype=float32, place=Place(cpu), stop_gradient=False,
[[0.10000000, 0.20000000],
 [0.30000001, 0.40000001]])

>>> type(paddle.to_tensor([[1+1j, 2], [3+2j, 4]], dtype='complex64'))
<class 'paddle.Tensor'>

>>> paddle.to_tensor([[1+1j, 2], [3+2j, 4]], dtype='complex64')
Tensor(shape=[2, 2], dtype=complex64, place=Place(cpu), stop_gradient=True,
[[(1+1j), (2+0j)],
 [(3+2j), (4+0j)]])