From a7014f09bf0694223780c88166d7367d4c3cbabb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=A7=9C=E6=B0=B8=E4=B9=85?= <34344716+yjjiang11@users.noreply.github.com> Date: Mon, 12 Dec 2022 23:42:29 -0800 Subject: [PATCH] rm unittests eager guard tests part6 eager_run2expand_v2 (#48817) --- .../tests/unittests/test_eager_run_program.py | 111 +++++++-------- .../tests/unittests/test_eager_trace_op.py | 36 +++-- .../unittests/test_egr_code_generate_api.py | 71 +++++----- .../unittests/test_egr_string_tensor_api.py | 131 ++++++++---------- .../unittests/test_elementwise_add_op.py | 14 +- .../unittests/test_elementwise_div_op.py | 7 +- .../unittests/test_elementwise_mul_op.py | 7 +- .../unittests/test_elementwise_sub_op.py | 14 +- .../tests/unittests/test_expand_v2_op.py | 15 -- 9 files changed, 165 insertions(+), 241 deletions(-) diff --git a/python/paddle/fluid/tests/unittests/test_eager_run_program.py b/python/paddle/fluid/tests/unittests/test_eager_run_program.py index c52599b87d..ce53edf871 100644 --- a/python/paddle/fluid/tests/unittests/test_eager_run_program.py +++ b/python/paddle/fluid/tests/unittests/test_eager_run_program.py @@ -24,11 +24,7 @@ from paddle.fluid.executor import ( _is_dy2st_enable_standalone_executor, _is_enable_standalone_executor, ) -from paddle.fluid.framework import ( - Variable, - _in_legacy_dygraph, - _test_eager_guard, -) +from paddle.fluid.framework import Variable, _in_legacy_dygraph from paddle.fluid.layers.utils import _hash_with_id @@ -124,68 +120,57 @@ class TestRunProgram(unittest.TestCase): paddle.disable_static('cpu') # step 2: call run_program in eager mode - with _test_eager_guard(): - x_t = paddle.ones([2, 4]) - x_t.name = "x" - x_t.stop_gradient = False - y_t = paddle.ones([4, 2]) - y_t.name = "y" - y_t.stop_gradient = False - - fake_var = paddle.zeros([1]) - fake_var.name = 'Fake_var' - - out_t = _create_out(out) - - scope = core.Scope() - attrs = [ - 'global_block', - program.desc.block(0), - 'start_op_index', - 0, - 'end_op_index', - main_program.desc.block(0).op_size(), - 'is_test', - False, - 'program_id', - _hash_with_id(program), - ] - - use_interpretorcore = ( - _is_enable_standalone_executor() - and _is_dy2st_enable_standalone_executor() - ) - attrs.extend(('use_interpretorcore', use_interpretorcore)) - if use_interpretorcore: - attrs.extend( - ( - 'forward_global_block', - forward_program.desc.block(0), - 'backward_global_block', - backward_program.desc.block(0), - ) - ) + x_t = paddle.ones([2, 4]) + x_t.name = "x" + x_t.stop_gradient = False + y_t = paddle.ones([4, 2]) + y_t.name = "y" + y_t.stop_gradient = False + + fake_var = paddle.zeros([1]) + fake_var.name = 'Fake_var' + + out_t = _create_out(out) + + scope = core.Scope() + attrs = [ + 'global_block', + program.desc.block(0), + 'start_op_index', + 0, + 'end_op_index', + main_program.desc.block(0).op_size(), + 'is_test', + False, + 'program_id', + _hash_with_id(program), + ] - _legacy_C_ops.run_program( - [x_t, y_t], - [fake_var], - [out_t], - [scope], - [fake_var], - None, - *attrs + use_interpretorcore = ( + _is_enable_standalone_executor() + and _is_dy2st_enable_standalone_executor() + ) + attrs.extend(('use_interpretorcore', use_interpretorcore)) + if use_interpretorcore: + attrs.extend( + ( + 'forward_global_block', + forward_program.desc.block(0), + 'backward_global_block', + backward_program.desc.block(0), + ) ) - loss = paddle.mean(out_t) - loss.backward() + _legacy_C_ops.run_program( + [x_t, y_t], [fake_var], [out_t], [scope], [fake_var], None, *attrs + ) - np.testing.assert_array_equal(np.ones([2, 2]) * 4, out_t.numpy()) - np.testing.assert_array_equal( - np.ones([2, 4]) * 0.5, x_t.grad.numpy() - ) - np.testing.assert_array_equal( - np.ones([4, 2]) * 0.5, y_t.grad.numpy() - ) + loss = paddle.mean(out_t) + loss.backward() + + np.testing.assert_array_equal(np.ones([2, 2]) * 4, out_t.numpy()) + np.testing.assert_array_equal(np.ones([2, 4]) * 0.5, x_t.grad.numpy()) + np.testing.assert_array_equal(np.ones([4, 2]) * 0.5, y_t.grad.numpy()) if __name__ == '__main__': diff --git a/python/paddle/fluid/tests/unittests/test_eager_trace_op.py b/python/paddle/fluid/tests/unittests/test_eager_trace_op.py index b463cbb051..91e95ff04a 100644 --- a/python/paddle/fluid/tests/unittests/test_eager_trace_op.py +++ b/python/paddle/fluid/tests/unittests/test_eager_trace_op.py @@ -17,29 +17,27 @@ import unittest import numpy as np import paddle -from paddle.fluid.framework import _test_eager_guard class TestEagerTraceOp(unittest.TestCase): def test_branches(self): - with _test_eager_guard(): - data = np.random.random([1, 1]).astype(np.float32) - x = paddle.to_tensor(data) - - paddle.fluid.framework._dygraph_tracer().trace_op( - 'broadcast_tensors', - {'X': [x, x], 'Out': [x, x]}, - {'Out': [x, x]}, - {}, - ) - paddle.fluid.framework._dygraph_tracer().trace_op( - 'scale', {'X': x}, {'Out': x}, {'scale': 0.5} - ) - - scale = paddle.to_tensor(np.random.random([1]).astype(np.float32)) - paddle.fluid.framework._dygraph_tracer().trace_op( - 'instance_norm', {'Scale': [scale], 'X': [x]}, {'Y': [x]}, {} - ) + data = np.random.random([1, 1]).astype(np.float32) + x = paddle.to_tensor(data) + + paddle.fluid.framework._dygraph_tracer().trace_op( + 'broadcast_tensors', + {'X': [x, x], 'Out': [x, x]}, + {'Out': [x, x]}, + {}, + ) + paddle.fluid.framework._dygraph_tracer().trace_op( + 'scale', {'X': x}, {'Out': x}, {'scale': 0.5} + ) + + scale = paddle.to_tensor(np.random.random([1]).astype(np.float32)) + paddle.fluid.framework._dygraph_tracer().trace_op( + 'instance_norm', {'Scale': [scale], 'X': [x]}, {'Y': [x]}, {} + ) if __name__ == "__main__": diff --git a/python/paddle/fluid/tests/unittests/test_egr_code_generate_api.py b/python/paddle/fluid/tests/unittests/test_egr_code_generate_api.py index 20ce26acb9..5903e029fa 100644 --- a/python/paddle/fluid/tests/unittests/test_egr_code_generate_api.py +++ b/python/paddle/fluid/tests/unittests/test_egr_code_generate_api.py @@ -17,55 +17,50 @@ import unittest import numpy as np import paddle -from paddle.fluid.framework import _test_eager_guard class EagerOpAPIGenerateTestCase(unittest.TestCase): def test_elementwise_add(self): - with _test_eager_guard(): - paddle.set_device("cpu") - np_x = np.ones([4, 16, 16, 32]).astype('float32') - np_y = np.ones([4, 16, 16, 32]).astype('float32') - x = paddle.to_tensor(np_x) - y = paddle.to_tensor(np_y) - out = paddle.add(x, y) - out_arr = out.numpy() + paddle.set_device("cpu") + np_x = np.ones([4, 16, 16, 32]).astype('float32') + np_y = np.ones([4, 16, 16, 32]).astype('float32') + x = paddle.to_tensor(np_x) + y = paddle.to_tensor(np_y) + out = paddle.add(x, y) + out_arr = out.numpy() - out_arr_expected = np.add(np_x, np_y) - np.testing.assert_array_equal(out_arr, out_arr_expected) + out_arr_expected = np.add(np_x, np_y) + np.testing.assert_array_equal(out_arr, out_arr_expected) def test_sum(self): - with _test_eager_guard(): - x_data = np.array( - [[0.2, 0.3, 0.5, 0.9], [0.1, 0.2, 0.6, 0.7]] - ).astype('float32') - x = paddle.to_tensor(x_data, 'float32') - out = paddle.sum(x, axis=0) - out_arr = out.numpy() - out_arr_expected = np.sum(x_data, axis=0) - np.testing.assert_array_equal(out_arr, out_arr_expected) + x_data = np.array([[0.2, 0.3, 0.5, 0.9], [0.1, 0.2, 0.6, 0.7]]).astype( + 'float32' + ) + x = paddle.to_tensor(x_data, 'float32') + out = paddle.sum(x, axis=0) + out_arr = out.numpy() + out_arr_expected = np.sum(x_data, axis=0) + np.testing.assert_array_equal(out_arr, out_arr_expected) def test_mm(self): - with _test_eager_guard(): - np_input = np.random.random([16, 32]).astype('float32') - np_mat2 = np.random.random([32, 32]).astype('float32') - input = paddle.to_tensor(np_input) - mat2 = paddle.to_tensor(np_mat2) - out = paddle.mm(input, mat2) - out_arr = out.numpy() - out_arr_expected = np.matmul(np_input, np_mat2) - np.testing.assert_allclose(out_arr, out_arr_expected, rtol=1e-05) + np_input = np.random.random([16, 32]).astype('float32') + np_mat2 = np.random.random([32, 32]).astype('float32') + input = paddle.to_tensor(np_input) + mat2 = paddle.to_tensor(np_mat2) + out = paddle.mm(input, mat2) + out_arr = out.numpy() + out_arr_expected = np.matmul(np_input, np_mat2) + np.testing.assert_allclose(out_arr, out_arr_expected, rtol=1e-05) def test_sigmoid(self): - with _test_eager_guard(): - np_x = np.array([-0.4, -0.2, 0.1, 0.3]).astype('float32') - x = paddle.to_tensor(np_x) - out = paddle.nn.functional.sigmoid(x) - out_arr = out.numpy() - out_arr_expected = np.array( - [0.40131234, 0.450166, 0.52497919, 0.57444252] - ).astype('float32') - np.testing.assert_allclose(out_arr, out_arr_expected, rtol=1e-05) + np_x = np.array([-0.4, -0.2, 0.1, 0.3]).astype('float32') + x = paddle.to_tensor(np_x) + out = paddle.nn.functional.sigmoid(x) + out_arr = out.numpy() + out_arr_expected = np.array( + [0.40131234, 0.450166, 0.52497919, 0.57444252] + ).astype('float32') + np.testing.assert_allclose(out_arr, out_arr_expected, rtol=1e-05) if __name__ == "__main__": diff --git a/python/paddle/fluid/tests/unittests/test_egr_string_tensor_api.py b/python/paddle/fluid/tests/unittests/test_egr_string_tensor_api.py index 82ab0ee8ff..3032dc5810 100644 --- a/python/paddle/fluid/tests/unittests/test_egr_string_tensor_api.py +++ b/python/paddle/fluid/tests/unittests/test_egr_string_tensor_api.py @@ -17,7 +17,6 @@ import unittest import numpy as np import paddle.fluid.core as core -from paddle.fluid.framework import _test_eager_guard class EagerStringTensorTestCase(unittest.TestCase): @@ -32,77 +31,69 @@ class EagerStringTensorTestCase(unittest.TestCase): ) # From IMDB def test_constructor_with_args(self): - with _test_eager_guard(): - ST1 = core.eager.StringTensor() # constructor 1 - self.assertEqual(ST1.name, "generated_string_tensor_0") - self.assertEqual(ST1.shape, []) - self.assertEqual(ST1.numpy(), '') - - shape = [2, 3] - ST2 = core.eager.StringTensor(shape, "ST2") # constructor 2 - self.assertEqual(ST2.name, "ST2") - self.assertEqual(ST2.shape, shape) - np.testing.assert_array_equal( - ST2.numpy(), np.empty(shape, dtype=np.unicode_) - ) - - ST3 = core.eager.StringTensor(self.str_arr, "ST3") # constructor 3 - self.assertEqual(ST3.name, "ST3") - self.assertEqual(ST3.shape, list(self.str_arr.shape)) - np.testing.assert_array_equal(ST3.numpy(), self.str_arr) - - ST4 = core.eager.StringTensor(self.str_arr) # constructor 4 - self.assertEqual(ST4.name, "generated_string_tensor_1") - self.assertEqual(ST4.shape, list(self.str_arr.shape)) - np.testing.assert_array_equal(ST4.numpy(), self.str_arr) - - ST5 = core.eager.StringTensor(ST4) # constructor 5 - self.assertEqual(ST5.name, "generated_string_tensor_2") - self.assertEqual(ST5.shape, list(self.str_arr.shape)) - np.testing.assert_array_equal(ST5.numpy(), self.str_arr) - - ST6 = core.eager.StringTensor(ST5, "ST6") # constructor 6 - self.assertEqual(ST6.name, "ST6") - self.assertEqual(ST6.shape, list(self.str_arr.shape)) - np.testing.assert_array_equal(ST6.numpy(), self.str_arr) - - for st in [ST1, ST2, ST3, ST4, ST5, ST6]: - # All StringTensors are on cpu place so far. - self.assertTrue(st.place._equals(core.CPUPlace())) + ST1 = core.eager.StringTensor() # constructor 1 + self.assertEqual(ST1.name, "generated_string_tensor_0") + self.assertEqual(ST1.shape, []) + self.assertEqual(ST1.numpy(), '') + + shape = [2, 3] + ST2 = core.eager.StringTensor(shape, "ST2") # constructor 2 + self.assertEqual(ST2.name, "ST2") + self.assertEqual(ST2.shape, shape) + np.testing.assert_array_equal( + ST2.numpy(), np.empty(shape, dtype=np.unicode_) + ) + + ST3 = core.eager.StringTensor(self.str_arr, "ST3") # constructor 3 + self.assertEqual(ST3.name, "ST3") + self.assertEqual(ST3.shape, list(self.str_arr.shape)) + np.testing.assert_array_equal(ST3.numpy(), self.str_arr) + + ST4 = core.eager.StringTensor(self.str_arr) # constructor 4 + self.assertEqual(ST4.name, "generated_string_tensor_1") + self.assertEqual(ST4.shape, list(self.str_arr.shape)) + np.testing.assert_array_equal(ST4.numpy(), self.str_arr) + + ST5 = core.eager.StringTensor(ST4) # constructor 5 + self.assertEqual(ST5.name, "generated_string_tensor_2") + self.assertEqual(ST5.shape, list(self.str_arr.shape)) + np.testing.assert_array_equal(ST5.numpy(), self.str_arr) + + ST6 = core.eager.StringTensor(ST5, "ST6") # constructor 6 + self.assertEqual(ST6.name, "ST6") + self.assertEqual(ST6.shape, list(self.str_arr.shape)) + np.testing.assert_array_equal(ST6.numpy(), self.str_arr) + + for st in [ST1, ST2, ST3, ST4, ST5, ST6]: + # All StringTensors are on cpu place so far. + self.assertTrue(st.place._equals(core.CPUPlace())) def test_constructor_with_kwargs(self): - with _test_eager_guard(): - shape = [2, 3] - ST1 = core.eager.StringTensor( - dims=shape, name="ST1" - ) # constructor 2 - self.assertEqual(ST1.name, "ST1") - self.assertEqual(ST1.shape, shape) - np.testing.assert_array_equal( - ST1.numpy(), np.empty(shape, dtype=np.unicode_) - ) - - ST2 = core.eager.StringTensor( - self.str_arr, name="ST2" - ) # constructor 3 - self.assertEqual(ST2.name, "ST2") - self.assertEqual(ST2.shape, list(self.str_arr.shape)) - np.testing.assert_array_equal(ST2.numpy(), self.str_arr) - - ST3 = core.eager.StringTensor(ST2, name="ST3") # constructor 6 - self.assertEqual(ST3.name, "ST3") - self.assertEqual(ST3.shape, list(self.str_arr.shape)) - np.testing.assert_array_equal(ST3.numpy(), self.str_arr) - - ST4 = core.eager.StringTensor( - value=ST2, name="ST4" - ) # constructor 6 - self.assertEqual(ST4.name, "ST4") - self.assertEqual(ST4.shape, list(self.str_arr.shape)) - np.testing.assert_array_equal(ST4.numpy(), self.str_arr) - for st in [ST1, ST2, ST3, ST4]: - # All StringTensors are on cpu place so far. - self.assertTrue(st.place._equals(core.CPUPlace())) + shape = [2, 3] + ST1 = core.eager.StringTensor(dims=shape, name="ST1") # constructor 2 + self.assertEqual(ST1.name, "ST1") + self.assertEqual(ST1.shape, shape) + np.testing.assert_array_equal( + ST1.numpy(), np.empty(shape, dtype=np.unicode_) + ) + + ST2 = core.eager.StringTensor(self.str_arr, name="ST2") # constructor 3 + self.assertEqual(ST2.name, "ST2") + self.assertEqual(ST2.shape, list(self.str_arr.shape)) + np.testing.assert_array_equal(ST2.numpy(), self.str_arr) + + ST3 = core.eager.StringTensor(ST2, name="ST3") # constructor 6 + self.assertEqual(ST3.name, "ST3") + self.assertEqual(ST3.shape, list(self.str_arr.shape)) + np.testing.assert_array_equal(ST3.numpy(), self.str_arr) + + ST4 = core.eager.StringTensor(value=ST2, name="ST4") # constructor 6 + self.assertEqual(ST4.name, "ST4") + self.assertEqual(ST4.shape, list(self.str_arr.shape)) + np.testing.assert_array_equal(ST4.numpy(), self.str_arr) + for st in [ST1, ST2, ST3, ST4]: + # All StringTensors are on cpu place so far. + self.assertTrue(st.place._equals(core.CPUPlace())) if __name__ == "__main__": diff --git a/python/paddle/fluid/tests/unittests/test_elementwise_add_op.py b/python/paddle/fluid/tests/unittests/test_elementwise_add_op.py index 8c08ebde96..1cb57e6d72 100644 --- a/python/paddle/fluid/tests/unittests/test_elementwise_add_op.py +++ b/python/paddle/fluid/tests/unittests/test_elementwise_add_op.py @@ -19,7 +19,6 @@ import numpy as np import paddle import paddle.fluid as fluid import paddle.fluid.core as core -from paddle.fluid.framework import _test_eager_guard from paddle.fluid.tests.unittests.op_test import ( OpTest, convert_float_to_uint16, @@ -684,7 +683,7 @@ class TestBoolAddFloatElementwiseAddop(unittest.TestCase): self.assertTrue(c.dtype == core.VarDesc.VarType.FP32) paddle.enable_static() - def func_dygraph_add(self): + def test_dygraph_add(self): paddle.disable_static() a = 1.5 b = paddle.full([2], True, dtype='bool') @@ -715,14 +714,9 @@ class TestBoolAddFloatElementwiseAddop(unittest.TestCase): paddle.enable_static() - def test_dygraph_add(self): - with _test_eager_guard(): - self.func_dygraph_add() - self.func_dygraph_add() - class TestElementwiseAddop1(unittest.TestCase): - def func_dygraph_add(self): + def test_dygraph_add(self): paddle.disable_static() np_a = np.random.random((2, 3, 4)).astype(np.float32) @@ -742,10 +736,6 @@ class TestElementwiseAddop1(unittest.TestCase): paddle.enable_static() - def test_dygraph_add(self): - with _test_eager_guard(): - self.func_dygraph_add() - if __name__ == '__main__': paddle.enable_static() diff --git a/python/paddle/fluid/tests/unittests/test_elementwise_div_op.py b/python/paddle/fluid/tests/unittests/test_elementwise_div_op.py index 3c01e3fd7b..9434868272 100644 --- a/python/paddle/fluid/tests/unittests/test_elementwise_div_op.py +++ b/python/paddle/fluid/tests/unittests/test_elementwise_div_op.py @@ -20,7 +20,6 @@ from op_test import OpTest, convert_float_to_uint16, skip_check_grad_ci import paddle from paddle import fluid from paddle.fluid import core -from paddle.fluid.framework import _test_eager_guard class ElementwiseDivOp(OpTest): @@ -440,7 +439,7 @@ class TestRealComplexElementwiseDivOp(TestComplexElementwiseDivOp): class TestElementwiseDivop(unittest.TestCase): - def func_dygraph_div(self): + def test_dygraph_div(self): paddle.disable_static() np_a = np.random.random((2, 3, 4)).astype(np.float32) @@ -462,10 +461,6 @@ class TestElementwiseDivop(unittest.TestCase): paddle.enable_static() - def test_dygraph_div(self): - with _test_eager_guard(): - self.func_dygraph_div() - if __name__ == '__main__': paddle.enable_static() diff --git a/python/paddle/fluid/tests/unittests/test_elementwise_mul_op.py b/python/paddle/fluid/tests/unittests/test_elementwise_mul_op.py index 54f5306083..e34d9d0dfd 100644 --- a/python/paddle/fluid/tests/unittests/test_elementwise_mul_op.py +++ b/python/paddle/fluid/tests/unittests/test_elementwise_mul_op.py @@ -18,7 +18,6 @@ import numpy as np import paddle import paddle.fluid.core as core -from paddle.fluid.framework import _test_eager_guard from paddle.fluid.tests.unittests.op_test import ( OpTest, convert_float_to_uint16, @@ -367,7 +366,7 @@ class TestRealComplexElementwiseMulOp(TestComplexElementwiseMulOp): class TestElementwiseMulop(unittest.TestCase): - def func_dygraph_mul(self): + def test_dygraph_mul(self): paddle.disable_static() np_a = np.random.random((2, 3, 4)).astype(np.float32) @@ -387,10 +386,6 @@ class TestElementwiseMulop(unittest.TestCase): paddle.enable_static() - def test_dygraph_mul(self): - with _test_eager_guard(): - self.func_dygraph_mul() - if __name__ == '__main__': paddle.enable_static() diff --git a/python/paddle/fluid/tests/unittests/test_elementwise_sub_op.py b/python/paddle/fluid/tests/unittests/test_elementwise_sub_op.py index 99880d1e2a..398ef711e2 100644 --- a/python/paddle/fluid/tests/unittests/test_elementwise_sub_op.py +++ b/python/paddle/fluid/tests/unittests/test_elementwise_sub_op.py @@ -19,7 +19,6 @@ from op_test import OpTest, convert_float_to_uint16, skip_check_grad_ci import paddle import paddle.fluid as fluid -from paddle.fluid.framework import _test_eager_guard class TestElementwiseOp(OpTest): @@ -414,7 +413,7 @@ class TestSubtractInplaceBroadcastError3(TestSubtractInplaceBroadcastError): class TestFloatElementwiseSubop(unittest.TestCase): - def func_dygraph_sub(self): + def test_dygraph_sub(self): paddle.disable_static() np_a = np.random.random((2, 3, 4)).astype(np.float64) @@ -446,14 +445,9 @@ class TestFloatElementwiseSubop(unittest.TestCase): paddle.enable_static() - def test_dygraph_sub(self): - with _test_eager_guard(): - self.func_dygraph_sub() - self.func_dygraph_sub() - class TestFloatElementwiseSubop1(unittest.TestCase): - def func_dygraph_sub(self): + def test_dygraph_sub(self): paddle.disable_static() np_a = np.random.random((2, 3, 4)).astype(np.float32) @@ -477,10 +471,6 @@ class TestFloatElementwiseSubop1(unittest.TestCase): paddle.enable_static() - def test_dygraph_sub(self): - with _test_eager_guard(): - self.func_dygraph_sub() - if __name__ == '__main__': paddle.enable_static() diff --git a/python/paddle/fluid/tests/unittests/test_expand_v2_op.py b/python/paddle/fluid/tests/unittests/test_expand_v2_op.py index 289f27d9c4..84efb6c338 100644 --- a/python/paddle/fluid/tests/unittests/test_expand_v2_op.py +++ b/python/paddle/fluid/tests/unittests/test_expand_v2_op.py @@ -23,7 +23,6 @@ import paddle import paddle.fluid as fluid import paddle.fluid.layers as layers from paddle.fluid import Program, core, program_guard -from paddle.fluid.framework import _test_eager_guard # Situation 1: shape is a list(without tensor) @@ -256,26 +255,12 @@ class TestExpandInferShape(unittest.TestCase): class TestExpandV2DygraphAPI(unittest.TestCase): def test_expand_times_is_tensor(self): with paddle.fluid.dygraph.guard(): - with _test_eager_guard(): - paddle.seed(1) - a = paddle.rand([2, 5]) - egr_expand_1 = paddle.expand(a, shape=[2, 5]) - np_array = np.array([2, 5]) - egr_expand_2 = paddle.expand(a, shape=np_array) - paddle.seed(1) a = paddle.rand([2, 5]) expand_1 = paddle.expand(a, shape=[2, 5]) np_array = np.array([2, 5]) expand_2 = paddle.expand(a, shape=np_array) - - np.testing.assert_array_equal( - egr_expand_1.numpy(), egr_expand_2.numpy() - ) np.testing.assert_array_equal(expand_1.numpy(), expand_2.numpy()) - np.testing.assert_array_equal( - expand_1.numpy(), egr_expand_1.numpy() - ) class TestExpandDoubleGradCheck(unittest.TestCase): -- GitLab