Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
75a17cdb
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
75a17cdb
编写于
4月 04, 2022
作者:
Z
Zhanlue Yang
提交者:
GitHub
4月 04, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Skip DoubleGrad-related unit tests under eager mode (#41380)
上级
5b8c5b7b
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
168 addition
and
60 deletion
+168
-60
python/paddle/fluid/tests/unittests/autograd/test_autograd_functional_dynamic.py
...ts/unittests/autograd/test_autograd_functional_dynamic.py
+149
-56
python/paddle/fluid/tests/unittests/test_imperative_star_gan_with_gradient_penalty.py
...ittests/test_imperative_star_gan_with_gradient_penalty.py
+6
-1
python/paddle/fluid/tests/unittests/test_imperative_triple_grad.py
...ddle/fluid/tests/unittests/test_imperative_triple_grad.py
+13
-3
未找到文件。
python/paddle/fluid/tests/unittests/autograd/test_autograd_functional_dynamic.py
浏览文件 @
75a17cdb
...
@@ -21,6 +21,7 @@ import paddle
...
@@ -21,6 +21,7 @@ import paddle
import
paddle.compat
as
cpt
import
paddle.compat
as
cpt
import
paddle.nn.functional
as
F
import
paddle.nn.functional
as
F
from
paddle.autograd.functional
import
_as_tensors
from
paddle.autograd.functional
import
_as_tensors
from
paddle.fluid.framework
import
_test_eager_guard
,
_in_legacy_dygraph
,
_in_eager_without_dygraph_check
import
config
import
config
import
utils
import
utils
...
@@ -145,7 +146,7 @@ class TestAutogradFunctional(unittest.TestCase):
...
@@ -145,7 +146,7 @@ class TestAutogradFunctional(unittest.TestCase):
class
TestVJP
(
TestAutogradFunctional
):
class
TestVJP
(
TestAutogradFunctional
):
def
test
_vjp_i1o1
(
self
):
def
func
_vjp_i1o1
(
self
):
test_cases
=
[
test_cases
=
[
[
reduce
,
'A'
],
# noqa
[
reduce
,
'A'
],
# noqa
[
reduce_dim
,
'A'
],
# noqa
[
reduce_dim
,
'A'
],
# noqa
...
@@ -155,7 +156,7 @@ class TestVJP(TestAutogradFunctional):
...
@@ -155,7 +156,7 @@ class TestVJP(TestAutogradFunctional):
vjp_result
,
grad_result
=
vjp
(),
grad
()
vjp_result
,
grad_result
=
vjp
(),
grad
()
self
.
check_results
(
grad_result
,
vjp_result
)
self
.
check_results
(
grad_result
,
vjp_result
)
def
test
_vjp_i2o1
(
self
):
def
func
_vjp_i2o1
(
self
):
test_cases
=
[
test_cases
=
[
[
matmul
,
[
'A'
,
'B'
]],
# noqa
[
matmul
,
[
'A'
,
'B'
]],
# noqa
[
mul
,
[
'b'
,
'c'
]],
# noqa
[
mul
,
[
'b'
,
'c'
]],
# noqa
...
@@ -165,7 +166,7 @@ class TestVJP(TestAutogradFunctional):
...
@@ -165,7 +166,7 @@ class TestVJP(TestAutogradFunctional):
vjp_result
,
grad_result
=
vjp
(),
grad
()
vjp_result
,
grad_result
=
vjp
(),
grad
()
self
.
check_results
(
grad_result
,
vjp_result
)
self
.
check_results
(
grad_result
,
vjp_result
)
def
test
_vjp_i2o2
(
self
):
def
func
_vjp_i2o2
(
self
):
test_cases
=
[
test_cases
=
[
[
o2
,
[
'A'
,
'A'
]],
# noqa
[
o2
,
[
'A'
,
'A'
]],
# noqa
]
# noqa
]
# noqa
...
@@ -176,7 +177,7 @@ class TestVJP(TestAutogradFunctional):
...
@@ -176,7 +177,7 @@ class TestVJP(TestAutogradFunctional):
vjp_result
,
grad_result
=
vjp
(),
grad
()
vjp_result
,
grad_result
=
vjp
(),
grad
()
self
.
check_results
(
grad_result
,
vjp_result
)
self
.
check_results
(
grad_result
,
vjp_result
)
def
test
_vjp_i2o2_omitting_v
(
self
):
def
func
_vjp_i2o2_omitting_v
(
self
):
test_cases
=
[
test_cases
=
[
[
o2
,
[
'A'
,
'A'
]],
# noqa
[
o2
,
[
'A'
,
'A'
]],
# noqa
]
# noqa
]
# noqa
...
@@ -186,7 +187,7 @@ class TestVJP(TestAutogradFunctional):
...
@@ -186,7 +187,7 @@ class TestVJP(TestAutogradFunctional):
vjp_result
,
grad_result
=
vjp
(),
grad
()
vjp_result
,
grad_result
=
vjp
(),
grad
()
self
.
check_results
(
grad_result
,
vjp_result
)
self
.
check_results
(
grad_result
,
vjp_result
)
def
test
_vjp_nested
(
self
):
def
func
_vjp_nested
(
self
):
x
=
self
.
gen_input
(
'a'
)
x
=
self
.
gen_input
(
'a'
)
test_cases
=
[
test_cases
=
[
[
nested
(
x
),
'a'
],
# noqa
[
nested
(
x
),
'a'
],
# noqa
...
@@ -196,13 +197,22 @@ class TestVJP(TestAutogradFunctional):
...
@@ -196,13 +197,22 @@ class TestVJP(TestAutogradFunctional):
vjp_result
,
grad_result
=
vjp
(),
grad
()
vjp_result
,
grad_result
=
vjp
(),
grad
()
self
.
check_results
(
grad_result
,
vjp_result
)
self
.
check_results
(
grad_result
,
vjp_result
)
def
test
_vjp_aliased_input
(
self
):
def
func
_vjp_aliased_input
(
self
):
x
=
self
.
gen_input
(
'a'
)
x
=
self
.
gen_input
(
'a'
)
ref
=
self
.
gen_test_pairs
(
nested
(
x
),
'a'
)[
0
]
ref
=
self
.
gen_test_pairs
(
nested
(
x
),
'a'
)[
0
]
aliased
=
self
.
gen_test_pairs
(
nested
(
x
),
x
)[
0
]
aliased
=
self
.
gen_test_pairs
(
nested
(
x
),
x
)[
0
]
ref_result
,
aliased_result
=
ref
(),
aliased
()
ref_result
,
aliased_result
=
ref
(),
aliased
()
self
.
check_results
(
ref_result
,
aliased_result
)
self
.
check_results
(
ref_result
,
aliased_result
)
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_vjp_i1o1
()
self
.
func_vjp_i2o1
()
self
.
func_vjp_i2o2
()
self
.
func_vjp_i2o2_omitting_v
()
self
.
func_vjp_nested
()
self
.
func_vjp_aliased_input
()
@
utils
.
place
(
config
.
DEVICES
)
@
utils
.
place
(
config
.
DEVICES
)
@
utils
.
parameterize
(
@
utils
.
parameterize
(
...
@@ -210,12 +220,16 @@ class TestVJP(TestAutogradFunctional):
...
@@ -210,12 +220,16 @@ class TestVJP(TestAutogradFunctional):
(
'v_shape_not_equal_ys'
,
utils
.
square
,
np
.
random
.
rand
(
3
),
(
'v_shape_not_equal_ys'
,
utils
.
square
,
np
.
random
.
rand
(
3
),
np
.
random
.
rand
(
1
),
RuntimeError
),
))
np
.
random
.
rand
(
1
),
RuntimeError
),
))
class
TestVJPException
(
unittest
.
TestCase
):
class
TestVJPException
(
unittest
.
TestCase
):
def
test
_vjp
(
self
):
def
func
_vjp
(
self
):
with
self
.
assertRaises
(
self
.
expected_exception
):
with
self
.
assertRaises
(
self
.
expected_exception
):
paddle
.
autograd
.
vjp
(
self
.
fun
,
paddle
.
autograd
.
vjp
(
self
.
fun
,
paddle
.
to_tensor
(
self
.
xs
),
paddle
.
to_tensor
(
self
.
xs
),
paddle
.
to_tensor
(
self
.
v
))
paddle
.
to_tensor
(
self
.
v
))
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_vjp
()
def
jac
(
grad_fn
,
f
,
inputs
):
def
jac
(
grad_fn
,
f
,
inputs
):
assert
grad_fn
in
[
paddle
.
autograd
.
vjp
,
paddle
.
autograd
.
jvp
]
assert
grad_fn
in
[
paddle
.
autograd
.
vjp
,
paddle
.
autograd
.
jvp
]
...
@@ -246,7 +260,7 @@ def jac(grad_fn, f, inputs):
...
@@ -246,7 +260,7 @@ def jac(grad_fn, f, inputs):
class
TestJVP
(
TestAutogradFunctional
):
class
TestJVP
(
TestAutogradFunctional
):
def
test
_jvp_i1o1
(
self
):
def
func
_jvp_i1o1
(
self
):
test_cases
=
[
test_cases
=
[
[
reduce
,
'A'
],
# noqa
[
reduce
,
'A'
],
# noqa
[
reduce_dim
,
'A'
],
# noqa
[
reduce_dim
,
'A'
],
# noqa
...
@@ -257,7 +271,7 @@ class TestJVP(TestAutogradFunctional):
...
@@ -257,7 +271,7 @@ class TestJVP(TestAutogradFunctional):
reverse_jac
=
jac
(
paddle
.
autograd
.
vjp
,
f
,
inputs
)
reverse_jac
=
jac
(
paddle
.
autograd
.
vjp
,
f
,
inputs
)
self
.
check_results
(
forward_jac
,
reverse_jac
)
self
.
check_results
(
forward_jac
,
reverse_jac
)
def
test
_jvp_i2o1
(
self
):
def
func
_jvp_i2o1
(
self
):
test_cases
=
[
# noqa
test_cases
=
[
# noqa
[
matmul
,
[
'A'
,
'B'
]],
# noqa
[
matmul
,
[
'A'
,
'B'
]],
# noqa
]
# noqa
]
# noqa
...
@@ -267,7 +281,7 @@ class TestJVP(TestAutogradFunctional):
...
@@ -267,7 +281,7 @@ class TestJVP(TestAutogradFunctional):
reverse_jac
=
jac
(
paddle
.
autograd
.
vjp
,
f
,
inputs
)
reverse_jac
=
jac
(
paddle
.
autograd
.
vjp
,
f
,
inputs
)
self
.
check_results
(
forward_jac
,
reverse_jac
)
self
.
check_results
(
forward_jac
,
reverse_jac
)
def
test
_jvp_i2o2
(
self
):
def
func
_jvp_i2o2
(
self
):
test_cases
=
[
# noqa
test_cases
=
[
# noqa
[
o2
,
[
'A'
,
'A'
]],
# noqa
[
o2
,
[
'A'
,
'A'
]],
# noqa
]
# noqa
]
# noqa
...
@@ -277,7 +291,7 @@ class TestJVP(TestAutogradFunctional):
...
@@ -277,7 +291,7 @@ class TestJVP(TestAutogradFunctional):
reverse_jac
=
jac
(
paddle
.
autograd
.
vjp
,
f
,
inputs
)
reverse_jac
=
jac
(
paddle
.
autograd
.
vjp
,
f
,
inputs
)
self
.
check_results
(
forward_jac
,
reverse_jac
)
self
.
check_results
(
forward_jac
,
reverse_jac
)
def
test
_jvp_i2o2_omitting_v
(
self
):
def
func
_jvp_i2o2_omitting_v
(
self
):
test_cases
=
[
# noqa
test_cases
=
[
# noqa
[
o2
,
[
'A'
,
'A'
]],
# noqa
[
o2
,
[
'A'
,
'A'
]],
# noqa
]
# noqa
]
# noqa
...
@@ -288,6 +302,13 @@ class TestJVP(TestAutogradFunctional):
...
@@ -288,6 +302,13 @@ class TestJVP(TestAutogradFunctional):
results_with_v
=
paddle
.
autograd
.
jvp
(
f
,
inputs
,
v
)
results_with_v
=
paddle
.
autograd
.
jvp
(
f
,
inputs
,
v
)
self
.
check_results
(
results_omitting_v
,
results_with_v
)
self
.
check_results
(
results_omitting_v
,
results_with_v
)
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_jvp_i1o1
()
self
.
func_jvp_i2o1
()
self
.
func_jvp_i2o2
()
self
.
func_jvp_i2o2_omitting_v
()
@
utils
.
place
(
config
.
DEVICES
)
@
utils
.
place
(
config
.
DEVICES
)
@
utils
.
parameterize
((
utils
.
TEST_CASE_NAME
,
'func'
,
'xs'
),
(
@
utils
.
parameterize
((
utils
.
TEST_CASE_NAME
,
'func'
,
'xs'
),
(
...
@@ -312,7 +333,7 @@ class TestJacobianClassNoBatch(unittest.TestCase):
...
@@ -312,7 +333,7 @@ class TestJacobianClassNoBatch(unittest.TestCase):
self
.
_actual
=
paddle
.
autograd
.
Jacobian
(
self
.
func
,
self
.
xs
,
False
)
self
.
_actual
=
paddle
.
autograd
.
Jacobian
(
self
.
func
,
self
.
xs
,
False
)
self
.
_expected
=
self
.
_expected
()
self
.
_expected
=
self
.
_expected
()
def
test
_jacobian
(
self
):
def
func
_jacobian
(
self
):
Index
=
collections
.
namedtuple
(
'Index'
,
(
'type'
,
'value'
))
Index
=
collections
.
namedtuple
(
'Index'
,
(
'type'
,
'value'
))
indexes
=
(
Index
(
'all'
,
(
slice
(
0
,
None
,
None
),
slice
(
0
,
None
,
None
))),
indexes
=
(
Index
(
'all'
,
(
slice
(
0
,
None
,
None
),
slice
(
0
,
None
,
None
))),
Index
(
'row'
,
(
0
,
slice
(
0
,
None
,
None
))),
Index
(
'row'
,
(
0
,
slice
(
0
,
None
,
None
))),
...
@@ -333,6 +354,10 @@ class TestJacobianClassNoBatch(unittest.TestCase):
...
@@ -333,6 +354,10 @@ class TestJacobianClassNoBatch(unittest.TestCase):
self
.
_dtype
)
self
.
_dtype
)
return
utils
.
_np_concat_matrix_sequence
(
jac
,
utils
.
MatrixFormat
.
NM
)
return
utils
.
_np_concat_matrix_sequence
(
jac
,
utils
.
MatrixFormat
.
NM
)
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_jacobian
()
@
utils
.
place
(
config
.
DEVICES
)
@
utils
.
place
(
config
.
DEVICES
)
@
utils
.
parameterize
((
utils
.
TEST_CASE_NAME
,
'func'
,
'xs'
),
(
@
utils
.
parameterize
((
utils
.
TEST_CASE_NAME
,
'func'
,
'xs'
),
(
...
@@ -355,7 +380,7 @@ class TestJacobianClassBatchFirst(unittest.TestCase):
...
@@ -355,7 +380,7 @@ class TestJacobianClassBatchFirst(unittest.TestCase):
self
.
_actual
=
paddle
.
autograd
.
Jacobian
(
self
.
func
,
self
.
xs
,
True
)
self
.
_actual
=
paddle
.
autograd
.
Jacobian
(
self
.
func
,
self
.
xs
,
True
)
self
.
_expected
=
self
.
_expected
()
self
.
_expected
=
self
.
_expected
()
def
test
_jacobian
(
self
):
def
func
_jacobian
(
self
):
Index
=
collections
.
namedtuple
(
'Index'
,
(
'type'
,
'value'
))
Index
=
collections
.
namedtuple
(
'Index'
,
(
'type'
,
'value'
))
indexes
=
(
indexes
=
(
Index
(
'all'
,
(
slice
(
0
,
None
,
None
),
slice
(
0
,
None
,
None
),
Index
(
'all'
,
(
slice
(
0
,
None
,
None
),
slice
(
0
,
None
,
None
),
...
@@ -384,6 +409,10 @@ class TestJacobianClassBatchFirst(unittest.TestCase):
...
@@ -384,6 +409,10 @@ class TestJacobianClassBatchFirst(unittest.TestCase):
return
utils
.
_np_transpose_matrix_format
(
jac
,
utils
.
MatrixFormat
.
NBM
,
return
utils
.
_np_transpose_matrix_format
(
jac
,
utils
.
MatrixFormat
.
NBM
,
utils
.
MatrixFormat
.
BNM
)
utils
.
MatrixFormat
.
BNM
)
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_jacobian
()
class
TestHessianClassNoBatch
(
unittest
.
TestCase
):
class
TestHessianClassNoBatch
(
unittest
.
TestCase
):
@
classmethod
@
classmethod
...
@@ -400,7 +429,7 @@ class TestHessianClassNoBatch(unittest.TestCase):
...
@@ -400,7 +429,7 @@ class TestHessianClassNoBatch(unittest.TestCase):
self
.
x
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
x
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
def
test
_single_input
(
self
):
def
func
_single_input
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
...
@@ -413,7 +442,7 @@ class TestHessianClassNoBatch(unittest.TestCase):
...
@@ -413,7 +442,7 @@ class TestHessianClassNoBatch(unittest.TestCase):
np
.
testing
.
assert_allclose
(
hessian
[:].
numpy
(),
numerical_hessian
,
np
.
testing
.
assert_allclose
(
hessian
[:].
numpy
(),
numerical_hessian
,
self
.
rtol
,
self
.
atol
)
self
.
rtol
,
self
.
atol
)
def
test
_multi_input
(
self
):
def
func
_multi_input
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
y
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
y
))
...
@@ -429,7 +458,7 @@ class TestHessianClassNoBatch(unittest.TestCase):
...
@@ -429,7 +458,7 @@ class TestHessianClassNoBatch(unittest.TestCase):
rtol
=
self
.
rtol
,
rtol
=
self
.
rtol
,
atol
=
self
.
atol
)
atol
=
self
.
atol
)
def
test
_allow_unused_true
(
self
):
def
func
_allow_unused_true
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
...
@@ -442,7 +471,7 @@ class TestHessianClassNoBatch(unittest.TestCase):
...
@@ -442,7 +471,7 @@ class TestHessianClassNoBatch(unittest.TestCase):
np
.
testing
.
assert_allclose
(
hessian
[:].
numpy
(),
numerical_hessian
,
np
.
testing
.
assert_allclose
(
hessian
[:].
numpy
(),
numerical_hessian
,
self
.
rtol
,
self
.
atol
)
self
.
rtol
,
self
.
atol
)
def
test
_create_graph_true
(
self
):
def
func
_create_graph_true
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
sum
(
F
.
sigmoid
(
x
))
return
paddle
.
sum
(
F
.
sigmoid
(
x
))
...
@@ -455,13 +484,21 @@ class TestHessianClassNoBatch(unittest.TestCase):
...
@@ -455,13 +484,21 @@ class TestHessianClassNoBatch(unittest.TestCase):
np
.
testing
.
assert_allclose
(
hessian
[:].
numpy
(),
numerical_hessian
,
np
.
testing
.
assert_allclose
(
hessian
[:].
numpy
(),
numerical_hessian
,
self
.
rtol
,
self
.
atol
)
self
.
rtol
,
self
.
atol
)
def
test
_out_not_single
(
self
):
def
func
_out_not_single
(
self
):
def
func
(
x
):
def
func
(
x
):
return
x
*
x
return
x
*
x
with
self
.
assertRaises
(
RuntimeError
):
with
self
.
assertRaises
(
RuntimeError
):
paddle
.
autograd
.
Hessian
(
func
,
paddle
.
ones
([
3
]))
paddle
.
autograd
.
Hessian
(
func
,
paddle
.
ones
([
3
]))
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_single_input
()
self
.
func_multi_input
()
self
.
func_allow_unused_true
()
self
.
func_create_graph_true
()
self
.
func_out_not_single
()
class
TestHessianClassBatchFirst
(
unittest
.
TestCase
):
class
TestHessianClassBatchFirst
(
unittest
.
TestCase
):
@
classmethod
@
classmethod
...
@@ -482,7 +519,7 @@ class TestHessianClassBatchFirst(unittest.TestCase):
...
@@ -482,7 +519,7 @@ class TestHessianClassBatchFirst(unittest.TestCase):
self
.
weight
=
paddle
.
rand
(
shape
=
self
.
weight_shape
,
dtype
=
self
.
dtype
)
self
.
weight
=
paddle
.
rand
(
shape
=
self
.
weight_shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
y_shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
y_shape
,
dtype
=
self
.
dtype
)
def
test
_single_input
(
self
):
def
func
_single_input
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
...
@@ -496,7 +533,7 @@ class TestHessianClassBatchFirst(unittest.TestCase):
...
@@ -496,7 +533,7 @@ class TestHessianClassBatchFirst(unittest.TestCase):
np
.
testing
.
assert_allclose
(
actual
,
expected
,
self
.
rtol
,
self
.
atol
)
np
.
testing
.
assert_allclose
(
actual
,
expected
,
self
.
rtol
,
self
.
atol
)
def
test
_multi_input
(
self
):
def
func
_multi_input
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
*
x
*
y
*
y
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
*
y
*
y
,
self
.
weight
)[:,
0
:
1
]
...
@@ -517,7 +554,7 @@ class TestHessianClassBatchFirst(unittest.TestCase):
...
@@ -517,7 +554,7 @@ class TestHessianClassBatchFirst(unittest.TestCase):
np
.
testing
.
assert_allclose
(
actual
,
expected
,
self
.
rtol
,
self
.
atol
)
np
.
testing
.
assert_allclose
(
actual
,
expected
,
self
.
rtol
,
self
.
atol
)
def
test
_allow_unused
(
self
):
def
func
_allow_unused
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
...
@@ -538,7 +575,7 @@ class TestHessianClassBatchFirst(unittest.TestCase):
...
@@ -538,7 +575,7 @@ class TestHessianClassBatchFirst(unittest.TestCase):
np
.
testing
.
assert_allclose
(
np
.
testing
.
assert_allclose
(
actual
,
expected
,
rtol
=
self
.
rtol
,
atol
=
self
.
atol
)
actual
,
expected
,
rtol
=
self
.
rtol
,
atol
=
self
.
atol
)
def
test
_stop_gradient
(
self
):
def
func
_stop_gradient
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
...
@@ -554,13 +591,21 @@ class TestHessianClassBatchFirst(unittest.TestCase):
...
@@ -554,13 +591,21 @@ class TestHessianClassBatchFirst(unittest.TestCase):
np
.
testing
.
assert_allclose
(
actual
,
expected
,
self
.
rtol
,
self
.
atol
)
np
.
testing
.
assert_allclose
(
actual
,
expected
,
self
.
rtol
,
self
.
atol
)
def
test
_out_not_single
(
self
):
def
func
_out_not_single
(
self
):
def
func
(
x
):
def
func
(
x
):
return
(
x
*
x
)
return
(
x
*
x
)
with
self
.
assertRaises
(
RuntimeError
):
with
self
.
assertRaises
(
RuntimeError
):
paddle
.
autograd
.
Hessian
(
func
,
paddle
.
ones
((
3
,
3
)),
is_batched
=
True
)
paddle
.
autograd
.
Hessian
(
func
,
paddle
.
ones
((
3
,
3
)),
is_batched
=
True
)
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_single_input
()
self
.
func_multi_input
()
self
.
func_allow_unused
()
self
.
func_stop_gradient
()
self
.
func_out_not_single
()
class
TestHessian
(
unittest
.
TestCase
):
class
TestHessian
(
unittest
.
TestCase
):
@
classmethod
@
classmethod
...
@@ -577,7 +622,7 @@ class TestHessian(unittest.TestCase):
...
@@ -577,7 +622,7 @@ class TestHessian(unittest.TestCase):
self
.
x
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
x
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
def
test
_single_input
(
self
):
def
func
_single_input
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
...
@@ -589,7 +634,7 @@ class TestHessian(unittest.TestCase):
...
@@ -589,7 +634,7 @@ class TestHessian(unittest.TestCase):
np
.
testing
.
assert_allclose
(
hessian
.
numpy
(),
numerical_hessian
[
0
][
0
],
np
.
testing
.
assert_allclose
(
hessian
.
numpy
(),
numerical_hessian
[
0
][
0
],
self
.
rtol
,
self
.
atol
)
self
.
rtol
,
self
.
atol
)
def
test
_multi_input
(
self
):
def
func
_multi_input
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
y
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
y
))
...
@@ -605,7 +650,7 @@ class TestHessian(unittest.TestCase):
...
@@ -605,7 +650,7 @@ class TestHessian(unittest.TestCase):
numerical_hessian
[
i
][
j
],
self
.
rtol
,
numerical_hessian
[
i
][
j
],
self
.
rtol
,
self
.
atol
)
self
.
atol
)
def
test
_allow_unused_false
(
self
):
def
func
_allow_unused_false
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
...
@@ -617,7 +662,7 @@ class TestHessian(unittest.TestCase):
...
@@ -617,7 +662,7 @@ class TestHessian(unittest.TestCase):
error_msg
=
cpt
.
get_exception_message
(
e
)
error_msg
=
cpt
.
get_exception_message
(
e
)
assert
error_msg
.
find
(
"allow_unused"
)
>
0
assert
error_msg
.
find
(
"allow_unused"
)
>
0
def
test
_allow_unused_true
(
self
):
def
func
_allow_unused_true
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
...
@@ -636,7 +681,7 @@ class TestHessian(unittest.TestCase):
...
@@ -636,7 +681,7 @@ class TestHessian(unittest.TestCase):
else
:
else
:
assert
hessian
[
i
][
j
]
is
None
assert
hessian
[
i
][
j
]
is
None
def
test
_create_graph_false
(
self
):
def
func
_create_graph_false
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
...
@@ -653,7 +698,7 @@ class TestHessian(unittest.TestCase):
...
@@ -653,7 +698,7 @@ class TestHessian(unittest.TestCase):
error_msg
=
cpt
.
get_exception_message
(
e
)
error_msg
=
cpt
.
get_exception_message
(
e
)
assert
error_msg
.
find
(
"has no gradient"
)
>
0
assert
error_msg
.
find
(
"has no gradient"
)
>
0
def
test
_create_graph_true
(
self
):
def
func
_create_graph_true
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
sum
(
F
.
sigmoid
(
x
))
return
paddle
.
sum
(
F
.
sigmoid
(
x
))
...
@@ -667,6 +712,15 @@ class TestHessian(unittest.TestCase):
...
@@ -667,6 +712,15 @@ class TestHessian(unittest.TestCase):
triple_grad
=
paddle
.
grad
(
hessian
,
self
.
x
)
triple_grad
=
paddle
.
grad
(
hessian
,
self
.
x
)
assert
triple_grad
is
not
None
assert
triple_grad
is
not
None
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_single_input
()
self
.
func_multi_input
()
self
.
func_allow_unused_false
()
self
.
func_allow_unused_true
()
self
.
func_create_graph_false
()
self
.
func_create_graph_true
()
class
TestHessianFloat64
(
TestHessian
):
class
TestHessianFloat64
(
TestHessian
):
@
classmethod
@
classmethod
...
@@ -702,7 +756,7 @@ class TestBatchHessian(unittest.TestCase):
...
@@ -702,7 +756,7 @@ class TestBatchHessian(unittest.TestCase):
self
.
weight
=
paddle
.
rand
(
shape
=
self
.
weight_shape
,
dtype
=
self
.
dtype
)
self
.
weight
=
paddle
.
rand
(
shape
=
self
.
weight_shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
y_shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
y_shape
,
dtype
=
self
.
dtype
)
def
test
_single_input
(
self
):
def
func
_single_input
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
...
@@ -713,7 +767,7 @@ class TestBatchHessian(unittest.TestCase):
...
@@ -713,7 +767,7 @@ class TestBatchHessian(unittest.TestCase):
np
.
testing
.
assert_allclose
(
hessian
,
numerical_hessian
,
self
.
rtol
,
np
.
testing
.
assert_allclose
(
hessian
,
numerical_hessian
,
self
.
rtol
,
self
.
atol
)
self
.
atol
)
def
test
_multi_input
(
self
):
def
func
_multi_input
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
*
x
*
y
*
y
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
*
y
*
y
,
self
.
weight
)[:,
0
:
1
]
...
@@ -729,7 +783,7 @@ class TestBatchHessian(unittest.TestCase):
...
@@ -729,7 +783,7 @@ class TestBatchHessian(unittest.TestCase):
np
.
testing
.
assert_allclose
(
hessian_reshape
,
numerical_hessian
,
np
.
testing
.
assert_allclose
(
hessian_reshape
,
numerical_hessian
,
self
.
rtol
,
self
.
atol
)
self
.
rtol
,
self
.
atol
)
def
test
_allow_unused_false
(
self
):
def
func
_allow_unused_false
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
...
@@ -741,7 +795,7 @@ class TestBatchHessian(unittest.TestCase):
...
@@ -741,7 +795,7 @@ class TestBatchHessian(unittest.TestCase):
error_msg
=
cpt
.
get_exception_message
(
e
)
error_msg
=
cpt
.
get_exception_message
(
e
)
assert
error_msg
.
find
(
"allow_unused"
)
>
0
assert
error_msg
.
find
(
"allow_unused"
)
>
0
def
test
_allow_unused_true
(
self
):
def
func
_allow_unused_true
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
...
@@ -763,7 +817,7 @@ class TestBatchHessian(unittest.TestCase):
...
@@ -763,7 +817,7 @@ class TestBatchHessian(unittest.TestCase):
else
:
else
:
assert
hessian
[
i
][
j
]
is
None
assert
hessian
[
i
][
j
]
is
None
def
test
_create_graph_false
(
self
):
def
func
_create_graph_false
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
...
@@ -780,7 +834,7 @@ class TestBatchHessian(unittest.TestCase):
...
@@ -780,7 +834,7 @@ class TestBatchHessian(unittest.TestCase):
error_msg
=
cpt
.
get_exception_message
(
e
)
error_msg
=
cpt
.
get_exception_message
(
e
)
assert
error_msg
.
find
(
"has no gradient"
)
>
0
assert
error_msg
.
find
(
"has no gradient"
)
>
0
def
test
_create_graph_true
(
self
):
def
func
_create_graph_true
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
return
paddle
.
matmul
(
x
*
x
,
self
.
weight
)[:,
0
:
1
]
...
@@ -794,6 +848,15 @@ class TestBatchHessian(unittest.TestCase):
...
@@ -794,6 +848,15 @@ class TestBatchHessian(unittest.TestCase):
triple_grad
=
paddle
.
grad
(
hessian
,
self
.
x
)
triple_grad
=
paddle
.
grad
(
hessian
,
self
.
x
)
assert
triple_grad
is
not
None
assert
triple_grad
is
not
None
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_single_input
()
self
.
func_multi_input
()
self
.
func_allow_unused_false
()
self
.
func_allow_unused_true
()
self
.
func_create_graph_false
()
self
.
func_create_graph_true
()
class
TestBatchHessianFloat64
(
TestBatchHessian
):
class
TestBatchHessianFloat64
(
TestBatchHessian
):
@
classmethod
@
classmethod
...
@@ -831,7 +894,7 @@ class TestVHP(unittest.TestCase):
...
@@ -831,7 +894,7 @@ class TestVHP(unittest.TestCase):
self
.
vx
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
vx
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
vy
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
vy
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
def
test
_single_input
(
self
):
def
func
_single_input
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
...
@@ -846,7 +909,7 @@ class TestVHP(unittest.TestCase):
...
@@ -846,7 +909,7 @@ class TestVHP(unittest.TestCase):
np
.
testing
.
assert_allclose
(
vhp
[
0
].
numpy
(),
numerical_vhp
[
0
],
self
.
rtol
,
np
.
testing
.
assert_allclose
(
vhp
[
0
].
numpy
(),
numerical_vhp
[
0
],
self
.
rtol
,
self
.
atol
)
self
.
atol
)
def
test
_multi_input
(
self
):
def
func
_multi_input
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
y
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
y
))
...
@@ -865,7 +928,7 @@ class TestVHP(unittest.TestCase):
...
@@ -865,7 +928,7 @@ class TestVHP(unittest.TestCase):
np
.
testing
.
assert_allclose
(
vhp
[
i
].
numpy
(),
numerical_vhp
[
i
],
np
.
testing
.
assert_allclose
(
vhp
[
i
].
numpy
(),
numerical_vhp
[
i
],
self
.
rtol
,
self
.
atol
)
self
.
rtol
,
self
.
atol
)
def
test
_v_default
(
self
):
def
func
_v_default
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
y
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
y
))
...
@@ -885,7 +948,7 @@ class TestVHP(unittest.TestCase):
...
@@ -885,7 +948,7 @@ class TestVHP(unittest.TestCase):
np
.
testing
.
assert_allclose
(
vhp
[
i
].
numpy
(),
numerical_vhp
[
i
],
np
.
testing
.
assert_allclose
(
vhp
[
i
].
numpy
(),
numerical_vhp
[
i
],
self
.
rtol
,
self
.
atol
)
self
.
rtol
,
self
.
atol
)
def
test
_allow_unused_true
(
self
):
def
func
_allow_unused_true
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
return
paddle
.
sum
(
paddle
.
matmul
(
x
,
x
))
...
@@ -903,7 +966,7 @@ class TestVHP(unittest.TestCase):
...
@@ -903,7 +966,7 @@ class TestVHP(unittest.TestCase):
np
.
testing
.
assert_allclose
(
vhp
[
0
].
numpy
(),
numerical_vhp
[
0
],
self
.
rtol
,
np
.
testing
.
assert_allclose
(
vhp
[
0
].
numpy
(),
numerical_vhp
[
0
],
self
.
rtol
,
self
.
atol
)
self
.
atol
)
def
test
_create_graph_true
(
self
):
def
func
_create_graph_true
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
sum
(
F
.
sigmoid
(
x
))
return
paddle
.
sum
(
F
.
sigmoid
(
x
))
...
@@ -921,6 +984,14 @@ class TestVHP(unittest.TestCase):
...
@@ -921,6 +984,14 @@ class TestVHP(unittest.TestCase):
triple_grad
=
paddle
.
grad
(
vhp
,
self
.
x
)
triple_grad
=
paddle
.
grad
(
vhp
,
self
.
x
)
assert
triple_grad
is
not
None
assert
triple_grad
is
not
None
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_v_default
()
self
.
func_multi_input
()
self
.
func_single_input
()
self
.
func_allow_unused_true
()
self
.
func_create_graph_true
()
class
TestJacobian
(
unittest
.
TestCase
):
class
TestJacobian
(
unittest
.
TestCase
):
@
classmethod
@
classmethod
...
@@ -934,7 +1005,7 @@ class TestJacobian(unittest.TestCase):
...
@@ -934,7 +1005,7 @@ class TestJacobian(unittest.TestCase):
self
.
x
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
x
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
shape
,
dtype
=
self
.
dtype
)
def
test
_single_input_and_single_output
(
self
):
def
func
_single_input_and_single_output
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
matmul
(
x
,
x
)
return
paddle
.
matmul
(
x
,
x
)
...
@@ -945,7 +1016,7 @@ class TestJacobian(unittest.TestCase):
...
@@ -945,7 +1016,7 @@ class TestJacobian(unittest.TestCase):
np
.
testing
.
assert_allclose
(
jacobian
.
numpy
(),
numerical_jacobian
[
0
][
0
],
np
.
testing
.
assert_allclose
(
jacobian
.
numpy
(),
numerical_jacobian
[
0
][
0
],
self
.
rtol
,
self
.
atol
)
self
.
rtol
,
self
.
atol
)
def
test
_single_input_and_multi_output
(
self
):
def
func
_single_input_and_multi_output
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
matmul
(
x
,
x
),
x
*
x
return
paddle
.
matmul
(
x
,
x
),
x
*
x
...
@@ -958,7 +1029,7 @@ class TestJacobian(unittest.TestCase):
...
@@ -958,7 +1029,7 @@ class TestJacobian(unittest.TestCase):
numerical_jacobian
[
i
][
0
],
self
.
rtol
,
numerical_jacobian
[
i
][
0
],
self
.
rtol
,
self
.
atol
)
self
.
atol
)
def
test
_multi_input_and_single_output
(
self
):
def
func
_multi_input_and_single_output
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
,
y
)
return
paddle
.
matmul
(
x
,
y
)
...
@@ -972,7 +1043,7 @@ class TestJacobian(unittest.TestCase):
...
@@ -972,7 +1043,7 @@ class TestJacobian(unittest.TestCase):
numerical_jacobian
[
0
][
j
],
self
.
rtol
,
numerical_jacobian
[
0
][
j
],
self
.
rtol
,
self
.
atol
)
self
.
atol
)
def
test
_multi_input_and_multi_output
(
self
):
def
func
_multi_input_and_multi_output
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
,
y
),
x
*
y
return
paddle
.
matmul
(
x
,
y
),
x
*
y
...
@@ -987,7 +1058,7 @@ class TestJacobian(unittest.TestCase):
...
@@ -987,7 +1058,7 @@ class TestJacobian(unittest.TestCase):
numerical_jacobian
[
i
][
j
],
self
.
rtol
,
numerical_jacobian
[
i
][
j
],
self
.
rtol
,
self
.
atol
)
self
.
atol
)
def
test
_allow_unused_false
(
self
):
def
func
_allow_unused_false
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
,
x
)
return
paddle
.
matmul
(
x
,
x
)
...
@@ -999,7 +1070,7 @@ class TestJacobian(unittest.TestCase):
...
@@ -999,7 +1070,7 @@ class TestJacobian(unittest.TestCase):
error_msg
=
cpt
.
get_exception_message
(
e
)
error_msg
=
cpt
.
get_exception_message
(
e
)
assert
error_msg
.
find
(
"allow_unused"
)
>
0
assert
error_msg
.
find
(
"allow_unused"
)
>
0
def
test
_allow_unused_true
(
self
):
def
func
_allow_unused_true
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
,
x
)
return
paddle
.
matmul
(
x
,
x
)
...
@@ -1013,7 +1084,7 @@ class TestJacobian(unittest.TestCase):
...
@@ -1013,7 +1084,7 @@ class TestJacobian(unittest.TestCase):
jacobian
[
0
].
numpy
(),
numerical_jacobian
[
0
][
0
],
self
.
rtol
,
self
.
atol
)
jacobian
[
0
].
numpy
(),
numerical_jacobian
[
0
][
0
],
self
.
rtol
,
self
.
atol
)
assert
jacobian
[
1
]
is
None
assert
jacobian
[
1
]
is
None
def
test
_create_graph_false
(
self
):
def
func
_create_graph_false
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
,
y
)
return
paddle
.
matmul
(
x
,
y
)
...
@@ -1033,7 +1104,7 @@ class TestJacobian(unittest.TestCase):
...
@@ -1033,7 +1104,7 @@ class TestJacobian(unittest.TestCase):
error_msg
=
cpt
.
get_exception_message
(
e
)
error_msg
=
cpt
.
get_exception_message
(
e
)
assert
error_msg
.
find
(
"has no gradient"
)
>
0
assert
error_msg
.
find
(
"has no gradient"
)
>
0
def
test
_create_graph_true
(
self
):
def
func
_create_graph_true
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
paddle
.
matmul
(
x
,
y
)
return
paddle
.
matmul
(
x
,
y
)
...
@@ -1051,6 +1122,17 @@ class TestJacobian(unittest.TestCase):
...
@@ -1051,6 +1122,17 @@ class TestJacobian(unittest.TestCase):
double_grad
=
paddle
.
grad
(
jacobian
[
0
],
[
self
.
x
,
self
.
y
])
double_grad
=
paddle
.
grad
(
jacobian
[
0
],
[
self
.
x
,
self
.
y
])
assert
double_grad
is
not
None
assert
double_grad
is
not
None
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_multi_input_and_multi_output
()
self
.
func_multi_input_and_single_output
()
self
.
func_single_input_and_multi_output
()
self
.
func_single_input_and_single_output
()
self
.
func_allow_unused_false
()
self
.
func_allow_unused_true
()
self
.
func_create_graph_false
()
self
.
func_create_graph_true
()
class
TestJacobianFloat64
(
TestJacobian
):
class
TestJacobianFloat64
(
TestJacobian
):
@
classmethod
@
classmethod
...
@@ -1080,7 +1162,7 @@ class TestJacobianBatch(unittest.TestCase):
...
@@ -1080,7 +1162,7 @@ class TestJacobianBatch(unittest.TestCase):
self
.
weight
=
paddle
.
rand
(
shape
=
self
.
weight_shape
,
dtype
=
self
.
dtype
)
self
.
weight
=
paddle
.
rand
(
shape
=
self
.
weight_shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
y_shape
,
dtype
=
self
.
dtype
)
self
.
y
=
paddle
.
rand
(
shape
=
self
.
y_shape
,
dtype
=
self
.
dtype
)
def
test
_batch_single_input_and_batch_single_output
(
self
):
def
func
_batch_single_input_and_batch_single_output
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
matmul
(
paddle
.
matmul
(
x
,
self
.
weight
),
self
.
y
)
return
paddle
.
matmul
(
paddle
.
matmul
(
x
,
self
.
weight
),
self
.
y
)
...
@@ -1096,7 +1178,7 @@ class TestJacobianBatch(unittest.TestCase):
...
@@ -1096,7 +1178,7 @@ class TestJacobianBatch(unittest.TestCase):
np
.
allclose
(
batch_jacobian
.
numpy
().
all
(),
numerical_jacobian
[
0
][
0
]
np
.
allclose
(
batch_jacobian
.
numpy
().
all
(),
numerical_jacobian
[
0
][
0
]
.
all
()))
.
all
()))
def
test
_batch_single_input_and_batch_multi_output
(
self
):
def
func
_batch_single_input_and_batch_multi_output
(
self
):
def
func
(
x
):
def
func
(
x
):
return
paddle
.
matmul
(
paddle
.
matmul
(
x
,
self
.
weight
),
self
.
y
),
x
*
x
return
paddle
.
matmul
(
paddle
.
matmul
(
x
,
self
.
weight
),
self
.
y
),
x
*
x
...
@@ -1113,7 +1195,7 @@ class TestJacobianBatch(unittest.TestCase):
...
@@ -1113,7 +1195,7 @@ class TestJacobianBatch(unittest.TestCase):
numerical_jacobian
[
i
][
0
],
self
.
rtol
,
numerical_jacobian
[
i
][
0
],
self
.
rtol
,
self
.
atol
)
self
.
atol
)
def
test
_batch_multi_input_and_batch_single_output
(
self
):
def
func
_batch_multi_input_and_batch_single_output
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
x
*
y
return
x
*
y
...
@@ -1129,7 +1211,7 @@ class TestJacobianBatch(unittest.TestCase):
...
@@ -1129,7 +1211,7 @@ class TestJacobianBatch(unittest.TestCase):
numerical_jacobian
[
0
][
j
],
self
.
rtol
,
numerical_jacobian
[
0
][
j
],
self
.
rtol
,
self
.
atol
)
self
.
atol
)
def
test
_batch_multi_input_and_batch_multi_output
(
self
):
def
func
_batch_multi_input_and_batch_multi_output
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
x
*
y
,
x
*
y
return
x
*
y
,
x
*
y
...
@@ -1144,7 +1226,7 @@ class TestJacobianBatch(unittest.TestCase):
...
@@ -1144,7 +1226,7 @@ class TestJacobianBatch(unittest.TestCase):
np
.
testing
.
assert_allclose
(
batch_jacobian
[
i
],
numerical_jacobian
[
i
],
np
.
testing
.
assert_allclose
(
batch_jacobian
[
i
],
numerical_jacobian
[
i
],
self
.
rtol
,
self
.
atol
)
self
.
rtol
,
self
.
atol
)
def
test
_allow_unused_false
(
self
):
def
func
_allow_unused_false
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
x
*
x
return
x
*
x
...
@@ -1156,7 +1238,7 @@ class TestJacobianBatch(unittest.TestCase):
...
@@ -1156,7 +1238,7 @@ class TestJacobianBatch(unittest.TestCase):
error_msg
=
cpt
.
get_exception_message
(
e
)
error_msg
=
cpt
.
get_exception_message
(
e
)
assert
error_msg
.
find
(
"allow_unused"
)
>
0
assert
error_msg
.
find
(
"allow_unused"
)
>
0
def
test
_allow_unused_true
(
self
):
def
func
_allow_unused_true
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
x
*
x
return
x
*
x
...
@@ -1171,7 +1253,7 @@ class TestJacobianBatch(unittest.TestCase):
...
@@ -1171,7 +1253,7 @@ class TestJacobianBatch(unittest.TestCase):
jacobian
[
0
].
numpy
(),
numerical_jacobian
[
0
][
0
],
self
.
rtol
,
self
.
atol
)
jacobian
[
0
].
numpy
(),
numerical_jacobian
[
0
][
0
],
self
.
rtol
,
self
.
atol
)
assert
jacobian
[
1
]
is
None
assert
jacobian
[
1
]
is
None
def
test
_create_graph_false
(
self
):
def
func
_create_graph_false
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
x
*
y
return
x
*
y
...
@@ -1191,7 +1273,7 @@ class TestJacobianBatch(unittest.TestCase):
...
@@ -1191,7 +1273,7 @@ class TestJacobianBatch(unittest.TestCase):
error_msg
=
cpt
.
get_exception_message
(
e
)
error_msg
=
cpt
.
get_exception_message
(
e
)
assert
error_msg
.
find
(
"has no gradient"
)
>
0
assert
error_msg
.
find
(
"has no gradient"
)
>
0
def
test
_create_graph_true
(
self
):
def
func
_create_graph_true
(
self
):
def
func
(
x
,
y
):
def
func
(
x
,
y
):
return
x
*
y
return
x
*
y
...
@@ -1209,6 +1291,17 @@ class TestJacobianBatch(unittest.TestCase):
...
@@ -1209,6 +1291,17 @@ class TestJacobianBatch(unittest.TestCase):
double_grad
=
paddle
.
grad
(
jacobian
[
0
],
[
self
.
x
,
self
.
y
])
double_grad
=
paddle
.
grad
(
jacobian
[
0
],
[
self
.
x
,
self
.
y
])
assert
double_grad
is
not
None
assert
double_grad
is
not
None
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_batch_single_input_and_batch_single_output
()
self
.
func_batch_single_input_and_batch_multi_output
()
self
.
func_batch_multi_input_and_batch_single_output
()
self
.
func_batch_multi_input_and_batch_multi_output
()
self
.
func_allow_unused_false
()
self
.
func_allow_unused_true
()
self
.
func_create_graph_false
()
self
.
func_create_graph_true
()
class
TestJacobianBatchFloat64
(
TestJacobianBatch
):
class
TestJacobianBatchFloat64
(
TestJacobianBatch
):
@
classmethod
@
classmethod
...
...
python/paddle/fluid/tests/unittests/test_imperative_star_gan_with_gradient_penalty.py
浏览文件 @
75a17cdb
...
@@ -17,6 +17,7 @@ import paddle.fluid as fluid
...
@@ -17,6 +17,7 @@ import paddle.fluid as fluid
import
numpy
as
np
import
numpy
as
np
import
unittest
import
unittest
from
paddle
import
_C_ops
from
paddle
import
_C_ops
from
paddle.fluid.framework
import
_test_eager_guard
,
_in_legacy_dygraph
,
_in_eager_without_dygraph_check
if
fluid
.
is_compiled_with_cuda
():
if
fluid
.
is_compiled_with_cuda
():
fluid
.
core
.
globals
()[
'FLAGS_cudnn_deterministic'
]
=
True
fluid
.
core
.
globals
()[
'FLAGS_cudnn_deterministic'
]
=
True
...
@@ -583,7 +584,7 @@ class StaticGraphTrainModel(object):
...
@@ -583,7 +584,7 @@ class StaticGraphTrainModel(object):
class
TestStarGANWithGradientPenalty
(
unittest
.
TestCase
):
class
TestStarGANWithGradientPenalty
(
unittest
.
TestCase
):
def
test
_main
(
self
):
def
func
_main
(
self
):
self
.
place_test
(
fluid
.
CPUPlace
())
self
.
place_test
(
fluid
.
CPUPlace
())
if
fluid
.
is_compiled_with_cuda
():
if
fluid
.
is_compiled_with_cuda
():
...
@@ -615,6 +616,10 @@ class TestStarGANWithGradientPenalty(unittest.TestCase):
...
@@ -615,6 +616,10 @@ class TestStarGANWithGradientPenalty(unittest.TestCase):
self
.
assertEqual
(
g_loss_s
,
g_loss_d
)
self
.
assertEqual
(
g_loss_s
,
g_loss_d
)
self
.
assertEqual
(
d_loss_s
,
d_loss_d
)
self
.
assertEqual
(
d_loss_s
,
d_loss_d
)
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_main
()
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
paddle
.
enable_static
()
paddle
.
enable_static
()
...
...
python/paddle/fluid/tests/unittests/test_imperative_triple_grad.py
浏览文件 @
75a17cdb
...
@@ -19,6 +19,7 @@ from paddle.vision.models import resnet50, resnet101
...
@@ -19,6 +19,7 @@ from paddle.vision.models import resnet50, resnet101
import
unittest
import
unittest
from
unittest
import
TestCase
from
unittest
import
TestCase
import
numpy
as
np
import
numpy
as
np
from
paddle.fluid.framework
import
_test_eager_guard
,
_in_legacy_dygraph
,
_in_eager_without_dygraph_check
def
_dygraph_guard_
(
func
):
def
_dygraph_guard_
(
func
):
...
@@ -65,7 +66,7 @@ class TestDygraphTripleGrad(TestCase):
...
@@ -65,7 +66,7 @@ class TestDygraphTripleGrad(TestCase):
allow_unused
=
allow_unused
)
allow_unused
=
allow_unused
)
@
dygraph_guard
@
dygraph_guard
def
test
_exception
(
self
):
def
func
_exception
(
self
):
with
self
.
assertRaises
(
AssertionError
):
with
self
.
assertRaises
(
AssertionError
):
self
.
grad
(
None
,
None
)
self
.
grad
(
None
,
None
)
...
@@ -95,7 +96,7 @@ class TestDygraphTripleGrad(TestCase):
...
@@ -95,7 +96,7 @@ class TestDygraphTripleGrad(TestCase):
self
.
grad
([
random_var
(
shape
)],
[
random_var
(
shape
)],
no_grad_vars
=
1
)
self
.
grad
([
random_var
(
shape
)],
[
random_var
(
shape
)],
no_grad_vars
=
1
)
@
dygraph_guard
@
dygraph_guard
def
test
_example_with_gradient_and_create_graph
(
self
):
def
func
_example_with_gradient_and_create_graph
(
self
):
x
=
random_var
(
self
.
shape
)
x
=
random_var
(
self
.
shape
)
x_np
=
x
.
numpy
()
x_np
=
x
.
numpy
()
x
.
stop_gradient
=
False
x
.
stop_gradient
=
False
...
@@ -145,6 +146,11 @@ class TestDygraphTripleGrad(TestCase):
...
@@ -145,6 +146,11 @@ class TestDygraphTripleGrad(TestCase):
dddx_grad_actual
=
x
.
gradient
()
dddx_grad_actual
=
x
.
gradient
()
self
.
assertTrue
(
np
.
allclose
(
dddx_grad_actual
,
dddx_expected
))
self
.
assertTrue
(
np
.
allclose
(
dddx_grad_actual
,
dddx_expected
))
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_exception
()
self
.
func_example_with_gradient_and_create_graph
()
class
TestDygraphTripleGradBradcastCase
(
TestCase
):
class
TestDygraphTripleGradBradcastCase
(
TestCase
):
def
setUp
(
self
):
def
setUp
(
self
):
...
@@ -172,7 +178,7 @@ class TestDygraphTripleGradBradcastCase(TestCase):
...
@@ -172,7 +178,7 @@ class TestDygraphTripleGradBradcastCase(TestCase):
allow_unused
=
allow_unused
)
allow_unused
=
allow_unused
)
@
dygraph_guard
@
dygraph_guard
def
test
_example_with_gradient_and_create_graph
(
self
):
def
func
_example_with_gradient_and_create_graph
(
self
):
x
=
random_var
(
self
.
x_shape
)
x
=
random_var
(
self
.
x_shape
)
x_np
=
x
.
numpy
()
x_np
=
x
.
numpy
()
x
.
stop_gradient
=
False
x
.
stop_gradient
=
False
...
@@ -227,6 +233,10 @@ class TestDygraphTripleGradBradcastCase(TestCase):
...
@@ -227,6 +233,10 @@ class TestDygraphTripleGradBradcastCase(TestCase):
dddx_grad_actual
=
x
.
gradient
()
dddx_grad_actual
=
x
.
gradient
()
self
.
assertTrue
(
np
.
allclose
(
dddx_grad_actual
,
dddx_expected
))
self
.
assertTrue
(
np
.
allclose
(
dddx_grad_actual
,
dddx_expected
))
def
test_all_cases
(
self
):
if
_in_legacy_dygraph
():
self
.
func_example_with_gradient_and_create_graph
()
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
unittest
.
main
()
unittest
.
main
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录