|
|
|
# Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# 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
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
|
|
|
# TODO: define random functions
|
|
|
|
|
|
|
|
import numpy as np
|
|
|
|
|
|
|
|
from ..fluid import core
|
|
|
|
from ..fluid.framework import device_guard, in_dygraph_mode, _varbase_creator, Variable, convert_np_dtype_to_dtype_
|
|
|
|
from ..fluid.layers.layer_function_generator import templatedoc
|
|
|
|
from ..fluid.layer_helper import LayerHelper
|
|
|
|
from ..fluid.data_feeder import convert_dtype, check_variable_and_dtype, check_type, check_dtype
|
|
|
|
from ..fluid.layers import utils, uniform_random, gaussian_random
|
|
|
|
from ..fluid.layers.tensor import fill_constant
|
|
|
|
|
|
|
|
from ..fluid.io import shuffle #DEFINE_ALIAS
|
|
|
|
|
|
|
|
__all__ = [
|
|
|
|
# 'gaussin',
|
|
|
|
# 'uniform',
|
|
|
|
'shuffle',
|
|
|
|
'randn',
|
|
|
|
'rand',
|
|
|
|
'randint',
|
|
|
|
'randperm'
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
def randint(low,
|
|
|
|
high=None,
|
|
|
|
shape=None,
|
|
|
|
out=None,
|
|
|
|
dtype=None,
|
|
|
|
device=None,
|
|
|
|
stop_gradient=False,
|
|
|
|
seed=0,
|
|
|
|
name=None):
|
|
|
|
"""
|
|
|
|
:alias_main: paddle.randint
|
|
|
|
:alias: paddle.randint,paddle.tensor.randint,paddle.tensor.random.randint
|
|
|
|
|
|
|
|
This function returns a Tensor filled with random integers from the "discrete uniform" distribution of the
|
|
|
|
specified data type in the interval [low, high). If high is None (the default), then results are from [0, low).
|
|
|
|
|
|
|
|
Args:
|
|
|
|
low (int): The lower bound on the range of random values to generate, the low is included in the range.
|
|
|
|
(unless high=None, in which case this parameter is one above the highest such integer).
|
|
|
|
high (int, optional): The upper bound on the range of random values to generate, the high is excluded
|
|
|
|
in the range. Default None(see above for behavior if high=None).
|
|
|
|
shape (list|tuple|Variable, optional): The shape of the output Tensor, if the shape is a list or tuple,
|
|
|
|
its elements can be an integer
|
|
|
|
or a Tensor with the shape [1], and the type of the Tensor must be int32 or int64.
|
|
|
|
If the shape is a Variable, it is a 1-D Tensor, and the type of the Tensor must be
|
|
|
|
int32 or int64. Default is None, in which case the shape is [1].
|
|
|
|
out(Variable, optional): Optional output which can be any created
|
|
|
|
Variable that meets the requirements to store the result of operation.
|
|
|
|
if out is None, a new Varibale will be create to store the result.
|
|
|
|
dtype(np.dtype|core.VarDesc.VarType|str, optional): Data type of the output Tensor
|
|
|
|
which can be int32, int64, if dytpe is `None`, the data
|
|
|
|
type of created Tensor is `int64`
|
|
|
|
device(str, optional): This parameter specifies that the Tensor is created
|
|
|
|
on the GPU or CPU.
|
|
|
|
stop_gradient(bool, optional): Indicating if we stop gradient from current(out) Variable,
|
|
|
|
default value is False.
|
|
|
|
seed (int, optional): Random seed used for permute samples. If seed is
|
|
|
|
equal to 0, it means use a seed generated by the system. Note that
|
|
|
|
if seed is not 0, this operator will always generate the same random
|
|
|
|
permutation every time. Default: 0.
|
|
|
|
name(str, optional): The default value is None. Normally there is no need for user to set this
|
|
|
|
property. For more information, please refer to :ref:`api_guide_Name`.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
Variable: A Tensor of the specified shape filled with random integers.
|
|
|
|
|
|
|
|
Raises:
|
|
|
|
TypeError: Randint's low must less then high.
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
import paddle
|
|
|
|
import paddle.fluid as fluid
|
|
|
|
|
|
|
|
# example 1:
|
|
|
|
# attr shape is a list which doesn't contain tensor Variable.
|
|
|
|
result_1 = paddle.randint(low=-5, high=5, shape=[3, 4], dtype="int64")
|
|
|
|
|
|
|
|
# example 2:
|
|
|
|
# attr shape is a list which contains tensor Variable.
|
|
|
|
dim_1 = fluid.layers.fill_constant([1],"int64",3)
|
|
|
|
dim_2 = fluid.layers.fill_constant([1],"int32",5)
|
|
|
|
result_2 = paddle.randint(low=-5, high=5, shape=[dim_1, dim_2], dtype="int32")
|
|
|
|
|
|
|
|
# example 3:
|
|
|
|
# attr shape is a Variable, the data type must be int64 or int32.
|
|
|
|
var_shape = fluid.data(name='var_shape', shape=[2], dtype="int64")
|
|
|
|
result_3 = paddle.randint(low=-5, high=5, shape=var_shape, dtype="int32")
|
|
|
|
var_shape_int32 = fluid.data(name='var_shape_int32', shape=[2], dtype="int32")
|
|
|
|
result_4 = paddle.randint(low=-5, high=5, shape=var_shape_int32, dtype="int64")
|
|
|
|
|
|
|
|
# example 4:
|
|
|
|
# Input only one parameter
|
|
|
|
# low=0, high=10, shape=[1], dtype='int64'
|
|
|
|
result_4 = paddle.randint(10)
|
|
|
|
"""
|
|
|
|
|
|
|
|
def get_new_shape_tensor(list_shape):
|
|
|
|
new_shape_tensor = []
|
|
|
|
for dim in list_shape:
|
|
|
|
if isinstance(dim, Variable):
|
|
|
|
dim.stop_gradient = True
|
|
|
|
new_shape_tensor.append(dim)
|
|
|
|
else:
|
|
|
|
assert isinstance(dim, int) or isinstance(dim, long)
|
|
|
|
temp_out = helper.create_variable_for_type_inference('int64')
|
|
|
|
fill_constant([1], 'int64', dim, force_cpu=True, out=temp_out)
|
|
|
|
new_shape_tensor.append(temp_out)
|
|
|
|
return new_shape_tensor
|
|
|
|
|
|
|
|
def get_attr_shape(list_shape):
|
|
|
|
unk_dim_idx = -1
|
|
|
|
attrs_shape = []
|
|
|
|
for dim_idx, dim_size in enumerate(list_shape):
|
|
|
|
if isinstance(dim_size, Variable):
|
|
|
|
attrs_shape.append(-1)
|
|
|
|
else:
|
|
|
|
attrs_shape.append(dim_size)
|
|
|
|
assert dim_size > 0, (
|
|
|
|
"Each dimension size given in shape must not be negative "
|
|
|
|
"except one unknown dimension.")
|
|
|
|
return attrs_shape
|
|
|
|
|
|
|
|
if dtype is None:
|
|
|
|
dtype = 'int64'
|
|
|
|
check_dtype(dtype, 'dtype', ['int32', 'int64'], 'randint')
|
|
|
|
|
|
|
|
inputs = dict()
|
|
|
|
attrs = dict()
|
|
|
|
|
|
|
|
if shape is None:
|
|
|
|
shape = [1]
|
|
|
|
assert len(shape) > 0, ("The size of argument(shape) can't be zero.")
|
|
|
|
|
|
|
|
helper = LayerHelper("randint", **locals())
|
|
|
|
|
|
|
|
if in_dygraph_mode():
|
|
|
|
attrs['shape'] = shape
|
|
|
|
else:
|
|
|
|
if isinstance(shape, Variable):
|
|
|
|
shape.stop_gradient = True
|
|
|
|
inputs["ShapeTensor"] = shape
|
|
|
|
elif isinstance(shape, (list, tuple)):
|
|
|
|
assert len(shape) > 0, (
|
|
|
|
"The size of argument(shape) can't be zero.")
|
|
|
|
if utils._contain_var(shape):
|
|
|
|
inputs['ShapeTensorList'] = get_new_shape_tensor(shape)
|
|
|
|
else:
|
|
|
|
attrs["shape"] = get_attr_shape(shape)
|
|
|
|
check_type(shape, 'shape', (list, tuple, Variable), 'randint')
|
|
|
|
|
|
|
|
if high is None:
|
|
|
|
high = low
|
|
|
|
low = 0
|
|
|
|
attrs['low'] = low
|
|
|
|
attrs['high'] = high
|
|
|
|
attrs['seed'] = seed
|
|
|
|
if (low >= high):
|
|
|
|
raise ValueError(
|
|
|
|
"randint's low must less then high, but received low = {0}, "
|
|
|
|
"high = {1}".format(low, high))
|
|
|
|
|
|
|
|
if out is None:
|
|
|
|
if name is None:
|
|
|
|
out = helper.create_variable_for_type_inference(dtype=dtype)
|
|
|
|
else:
|
|
|
|
out = helper.create_variable(
|
|
|
|
name=name, dtype=dtype, persistable=False)
|
|
|
|
else:
|
|
|
|
check_dtype(dtype, 'dtype',
|
|
|
|
convert_dtype(out.dtype), 'randint',
|
|
|
|
"(The dtype in randint must be the same with out's dtype.)")
|
|
|
|
attrs['dtype'] = out.dtype
|
|
|
|
out.stop_gradient = stop_gradient
|
|
|
|
|
|
|
|
if device is None:
|
|
|
|
helper.append_op(
|
|
|
|
type='randint', inputs=inputs, outputs={'Out': out}, attrs=attrs)
|
|
|
|
else:
|
|
|
|
with device_guard(device):
|
|
|
|
helper.append_op(
|
|
|
|
type='randint',
|
|
|
|
inputs=inputs,
|
|
|
|
outputs={'Out': out},
|
|
|
|
attrs=attrs)
|
|
|
|
return out
|
|
|
|
|
|
|
|
|
|
|
|
def randn(shape, dtype=None, name=None):
|
|
|
|
"""
|
|
|
|
:alias_main: paddle.randn
|
|
|
|
:alias: paddle.randn,paddle.tensor.randn,paddle.tensor.random.randn
|
|
|
|
|
|
|
|
This function returns a tensor filled with random numbers from a normal
|
|
|
|
distribution with mean 0 and standard deviation 1 (also called the standard normal
|
|
|
|
distribution).
|
|
|
|
|
|
|
|
Args:
|
|
|
|
shape(list|tuple|Variable): Shape of the Tensor to be created. The data
|
|
|
|
type is ``int32`` or ``int64`` . If ``shape`` is a list or tuple,
|
|
|
|
the elements of it should be integers or Tensors with shape [1]. If
|
|
|
|
``shape`` is a Variable, it should be an 1-D Tensor .
|
|
|
|
dtype(np.dtype|core.VarDesc.VarType|str, optional): Data type of the output
|
|
|
|
tensor, which can be float32, float64. If dtype is `None` , the data
|
|
|
|
type of output tensor is `float32` . Default is None.
|
|
|
|
name(str, optional): Normally there is no need for user to set this property.
|
|
|
|
For more information, please refer to :ref:`api_guide_Name` .
|
|
|
|
Default is None.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
Random tensor whose data is drawn from a standard normal distribution,
|
|
|
|
dtype: flaot32 or float64 as specified.
|
|
|
|
|
|
|
|
Return type: Variable
|
|
|
|
|
|
|
|
Raises:
|
|
|
|
TypeError: If the type of `shape` is not Variable, list or tuple.
|
|
|
|
TypeError: If the data type of `dtype` is not float32 or float64.
|
|
|
|
ValueError: If the length of `shape` is not bigger than 0.
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
import paddle
|
|
|
|
import numpy as np
|
|
|
|
|
|
|
|
paddle.enable_imperative()
|
|
|
|
|
|
|
|
# example 1: attr shape is a list which doesn't contain tensor Variable.
|
|
|
|
result_1 = paddle.randn(shape=[2, 3])
|
|
|
|
# [[-2.923464 0.11934398 -0.51249987]
|
|
|
|
# [ 0.39632758 0.08177969 0.2692008 ]]
|
|
|
|
|
|
|
|
# example 2: attr shape is a list which contains tensor Variable.
|
|
|
|
dim_1 = paddle.fill_constant([1], "int64", 2)
|
|
|
|
dim_2 = paddle.fill_constant([1], "int32", 3)
|
|
|
|
result_2 = paddle.randn(shape=[dim_1, dim_2, 2])
|
|
|
|
# [[[-2.8852394 -0.25898588]
|
|
|
|
# [-0.47420555 0.17683524]
|
|
|
|
# [-0.7989969 0.00754541]]
|
|
|
|
# [[ 0.85201347 0.32320443]
|
|
|
|
# [ 1.1399018 0.48336947]
|
|
|
|
# [ 0.8086993 0.6868893 ]]]
|
|
|
|
|
|
|
|
# example 3: attr shape is a Variable, the data type must be int64 or int32.
|
|
|
|
var_shape = paddle.imperative.to_variable(np.array([2, 3]))
|
|
|
|
result_3 = paddle.randn(var_shape)
|
|
|
|
# [[-2.878077 0.17099959 0.05111201]
|
|
|
|
# [-0.3761474 -1.044801 1.1870178 ]]
|
|
|
|
|
|
|
|
"""
|
|
|
|
if dtype is None:
|
|
|
|
dtype = 'float32'
|
|
|
|
|
|
|
|
out = gaussian_random(
|
|
|
|
shape=shape, mean=0.0, std=1.0, seed=0, dtype=dtype, name=name)
|
|
|
|
out.stop_gradient = True
|
|
|
|
return out
|
|
|
|
|
|
|
|
|
|
|
|
@templatedoc()
|
|
|
|
def randperm(n, dtype="int64", name=None):
|
|
|
|
"""
|
|
|
|
:alias_main: paddle.randperm
|
|
|
|
:alias: paddle.randperm,paddle.tensor.randperm,paddle.tensor.random.randperm
|
|
|
|
|
|
|
|
${comment}
|
|
|
|
|
|
|
|
Args:
|
|
|
|
n(int): The upper bound (exclusive), and it should be greater than 0.
|
|
|
|
dtype(np.dtype|core.VarDesc.VarType|str, optional): The type of the
|
|
|
|
output Tensor. Supported data types: int32, int64, float32, float64.
|
|
|
|
Default: int32.
|
|
|
|
name(str, optional): Normally there is no need for user to set this property.
|
|
|
|
For more information, please refer to :ref:`api_guide_Name` .
|
|
|
|
Default is None.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
${out_comment}.
|
|
|
|
|
|
|
|
Return Type:
|
|
|
|
${out_type}
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
import paddle
|
|
|
|
|
|
|
|
paddle.enable_imperative()
|
|
|
|
|
|
|
|
result_1 = paddle.randperm(5)
|
|
|
|
# [4 1 2 3 0]
|
|
|
|
|
|
|
|
result_2 = paddle.randperm(7, 'int32')
|
|
|
|
# [1 6 2 0 4 3 5]
|
|
|
|
|
|
|
|
"""
|
|
|
|
if not isinstance(dtype, core.VarDesc.VarType):
|
|
|
|
dtype = convert_np_dtype_to_dtype_(dtype)
|
|
|
|
|
|
|
|
if in_dygraph_mode():
|
|
|
|
return core.ops.randperm('n', n, 'seed', 0, 'dtype', dtype)
|
|
|
|
|
|
|
|
if n < 1:
|
|
|
|
raise ValueError("The input n should be greater than 0 in randperm op.")
|
|
|
|
check_dtype(dtype, 'dtype', ['int64', 'int32', 'float32', 'float64'],
|
|
|
|
'randperm')
|
|
|
|
|
|
|
|
helper = LayerHelper("randperm", **locals())
|
|
|
|
out = helper.create_variable_for_type_inference(dtype)
|
|
|
|
attrs = {'n': n, 'dtype': dtype, 'seed': 0}
|
|
|
|
helper.append_op(
|
|
|
|
type='randperm', inputs={}, outputs={'Out': out}, attrs=attrs)
|
|
|
|
out.stop_gradient = True
|
|
|
|
return out
|
upload code for tensor.rand (#23507)
* upload code for tensor.rand
* fix import
* update example, change paddle.tensor.rand to paddle.rand
* change 'variable' to 'Variable', test=develop
change 'variable' to 'Variable' in description, test=develop
* add pre-commit check
* add pre-commit check
* pre-commit check, test=develop
* add more unittest code
* trigger ci, test=develop
* pre-commit check, test=develop
* update api and test comment, test=develop
* update api and test comment, test=develop
* add more type check, test=develop
* add detail error info for device, test=develop
* add unnittest, test=develop
* resolve conflict and pre-commit check, test=develop
5 years ago
|
|
|
|
|
|
|
|
|
|
|
def rand(shape, dtype=None, name=None):
|
upload code for tensor.rand (#23507)
* upload code for tensor.rand
* fix import
* update example, change paddle.tensor.rand to paddle.rand
* change 'variable' to 'Variable', test=develop
change 'variable' to 'Variable' in description, test=develop
* add pre-commit check
* add pre-commit check
* pre-commit check, test=develop
* add more unittest code
* trigger ci, test=develop
* pre-commit check, test=develop
* update api and test comment, test=develop
* update api and test comment, test=develop
* add more type check, test=develop
* add detail error info for device, test=develop
* add unnittest, test=develop
* resolve conflict and pre-commit check, test=develop
5 years ago
|
|
|
"""
|
|
|
|
:alias_main: paddle.rand
|
|
|
|
:alias: paddle.rand,paddle.tensor.rand,paddle.tensor.random.rand
|
|
|
|
|
upload code for tensor.rand (#23507)
* upload code for tensor.rand
* fix import
* update example, change paddle.tensor.rand to paddle.rand
* change 'variable' to 'Variable', test=develop
change 'variable' to 'Variable' in description, test=develop
* add pre-commit check
* add pre-commit check
* pre-commit check, test=develop
* add more unittest code
* trigger ci, test=develop
* pre-commit check, test=develop
* update api and test comment, test=develop
* update api and test comment, test=develop
* add more type check, test=develop
* add detail error info for device, test=develop
* add unnittest, test=develop
* resolve conflict and pre-commit check, test=develop
5 years ago
|
|
|
This OP initializes a variable with random values sampled from a
|
|
|
|
uniform distribution in the range [0, 1).
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
::
|
|
|
|
|
|
|
|
Input:
|
|
|
|
shape = [1, 2]
|
|
|
|
|
|
|
|
Output:
|
|
|
|
result=[[0.8505902, 0.8397286]]
|
|
|
|
|
|
|
|
Args:
|
|
|
|
shape(list|tuple|Variable): Shape of the Tensor to be created. The data
|
|
|
|
type is ``int32`` or ``int64`` . If ``shape`` is a list or tuple,
|
|
|
|
the elements of it should be integers or Tensors with shape [1]. If
|
|
|
|
``shape`` is a Variable, it should be an 1-D Tensor .
|
|
|
|
dtype(np.dtype|core.VarDesc.VarType|str, optional): Data type of the
|
|
|
|
output tensor which can be float32, float64, if dytpe is `None`,
|
|
|
|
the data type of created tensor is `float32`
|
|
|
|
name(str, optional): The default value is None. Normally there is no
|
|
|
|
need for user to set this property. For more information, please
|
|
|
|
refer to :ref:`api_guide_Name`.
|
upload code for tensor.rand (#23507)
* upload code for tensor.rand
* fix import
* update example, change paddle.tensor.rand to paddle.rand
* change 'variable' to 'Variable', test=develop
change 'variable' to 'Variable' in description, test=develop
* add pre-commit check
* add pre-commit check
* pre-commit check, test=develop
* add more unittest code
* trigger ci, test=develop
* pre-commit check, test=develop
* update api and test comment, test=develop
* update api and test comment, test=develop
* add more type check, test=develop
* add detail error info for device, test=develop
* add unnittest, test=develop
* resolve conflict and pre-commit check, test=develop
5 years ago
|
|
|
Returns:
|
|
|
|
Variable: A Tensor of the specified shape filled with random numbers
|
|
|
|
from a uniform distribution on the interval [0, 1).
|
upload code for tensor.rand (#23507)
* upload code for tensor.rand
* fix import
* update example, change paddle.tensor.rand to paddle.rand
* change 'variable' to 'Variable', test=develop
change 'variable' to 'Variable' in description, test=develop
* add pre-commit check
* add pre-commit check
* pre-commit check, test=develop
* add more unittest code
* trigger ci, test=develop
* pre-commit check, test=develop
* update api and test comment, test=develop
* update api and test comment, test=develop
* add more type check, test=develop
* add detail error info for device, test=develop
* add unnittest, test=develop
* resolve conflict and pre-commit check, test=develop
5 years ago
|
|
|
|
|
|
|
Raises:
|
|
|
|
TypeError: The shape type should be list or tupple or Variable.
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
import paddle
|
|
|
|
import numpy as np
|
|
|
|
|
|
|
|
paddle.enable_imperative()
|
|
|
|
# example 1: attr shape is a list which doesn't contain tensor Variable.
|
|
|
|
result_1 = paddle.rand(shape=[2, 3])
|
|
|
|
# [[0.451152 , 0.55825245, 0.403311 ],
|
|
|
|
# [0.22550228, 0.22106001, 0.7877319 ]]
|
|
|
|
|
|
|
|
# example 2: attr shape is a list which contains tensor Variable.
|
|
|
|
dim_1 = paddle.fill_constant([1], "int64", 2)
|
|
|
|
dim_2 = paddle.fill_constant([1], "int32", 3)
|
|
|
|
result_2 = paddle.rand(shape=[dim_1, dim_2, 2])
|
|
|
|
# [[[0.8879919 0.25788337]
|
|
|
|
# [0.28826773 0.9712097 ]
|
|
|
|
# [0.26438272 0.01796806]]
|
|
|
|
# [[0.33633623 0.28654453]
|
|
|
|
# [0.79109055 0.7305809 ]
|
|
|
|
# [0.870881 0.2984597 ]]]
|
|
|
|
|
|
|
|
# example 3: attr shape is a Variable, the data type must be int64 or int32.
|
|
|
|
var_shape = paddle.imperative.to_variable(np.array([2, 3]))
|
|
|
|
result_3 = paddle.rand(var_shape)
|
|
|
|
# [[0.22920267 0.841956 0.05981819]
|
|
|
|
# [0.4836288 0.24573246 0.7516129 ]]
|
upload code for tensor.rand (#23507)
* upload code for tensor.rand
* fix import
* update example, change paddle.tensor.rand to paddle.rand
* change 'variable' to 'Variable', test=develop
change 'variable' to 'Variable' in description, test=develop
* add pre-commit check
* add pre-commit check
* pre-commit check, test=develop
* add more unittest code
* trigger ci, test=develop
* pre-commit check, test=develop
* update api and test comment, test=develop
* update api and test comment, test=develop
* add more type check, test=develop
* add detail error info for device, test=develop
* add unnittest, test=develop
* resolve conflict and pre-commit check, test=develop
5 years ago
|
|
|
|
|
|
|
"""
|
|
|
|
if dtype is None:
|
|
|
|
dtype = 'float32'
|
|
|
|
|
|
|
|
out = uniform_random(shape, dtype, min=0.0, max=1.0, name=name)
|
|
|
|
out.stop_gradient = True
|
|
|
|
return out
|