Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
a86e8c0e
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看板
未验证
提交
a86e8c0e
编写于
8月 11, 2020
作者:
Z
Zhen Wang
提交者:
GitHub
8月 11, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add more error info for these ops without double grad ops. (#25987)
上级
75a13114
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
29 addition
and
10 deletion
+29
-10
paddle/fluid/imperative/partial_grad_engine.cc
paddle/fluid/imperative/partial_grad_engine.cc
+4
-1
python/paddle/fluid/tests/unittests/test_imperative_double_grad.py
...ddle/fluid/tests/unittests/test_imperative_double_grad.py
+25
-9
未找到文件。
paddle/fluid/imperative/partial_grad_engine.cc
浏览文件 @
a86e8c0e
...
@@ -887,7 +887,10 @@ void PartialGradTask::RunEachOp(OpBase *op) {
...
@@ -887,7 +887,10 @@ void PartialGradTask::RunEachOp(OpBase *op) {
op
->
Attrs
(),
op
->
place
());
op
->
Attrs
(),
op
->
place
());
PADDLE_ENFORCE_NOT_NULL
(
PADDLE_ENFORCE_NOT_NULL
(
double_grad_node
,
double_grad_node
,
platform
::
errors
::
NotFound
(
"The Op %s doesn't have any grad op."
,
platform
::
errors
::
NotFound
(
"The Op %s doesn't have any grad op. If you "
"don't intend calculating higher order "
"derivatives, please set `create_graph` to "
"False."
,
op
->
Type
()));
op
->
Type
()));
VLOG
(
10
)
<<
"Create "
<<
double_grad_node
->
size
()
VLOG
(
10
)
<<
"Create "
<<
double_grad_node
->
size
()
<<
" double grad op(s) for "
<<
op
->
Type
()
<<
" double grad op(s) for "
<<
op
->
Type
()
...
...
python/paddle/fluid/tests/unittests/test_imperative_double_grad.py
浏览文件 @
a86e8c0e
...
@@ -298,15 +298,16 @@ class TestDygraphDoubleGradSortGradient(TestDygraphDoubleGrad):
...
@@ -298,15 +298,16 @@ class TestDygraphDoubleGradSortGradient(TestDygraphDoubleGrad):
class
TestDygraphDoubleGradVisitedUniq
(
TestCase
):
class
TestDygraphDoubleGradVisitedUniq
(
TestCase
):
def
test_compare
(
self
):
def
test_compare
(
self
):
value
=
np
.
random
.
uniform
(
-
1
,
1
,
[
10
,
3
,
32
,
32
]).
astype
(
'float32'
)
value
=
np
.
random
.
uniform
(
-
0.5
,
0.5
,
100
).
reshape
(
10
,
2
,
5
).
astype
(
"float32"
)
def
model_f
(
input
):
def
model_f
(
input
):
conv2d
=
fluid
.
dygraph
.
Conv2D
(
3
,
2
,
3
)
linear
=
fluid
.
dygraph
.
Linear
(
5
,
3
,
bias_attr
=
False
)
for
i
in
range
(
10
):
for
i
in
range
(
10
):
if
i
==
0
:
if
i
==
0
:
out
=
conv2d
(
input
)
out
=
linear
(
input
)
else
:
else
:
out
=
out
+
conv2d
(
input
)
out
=
out
+
linear
(
input
)
return
out
return
out
backward_strategy
=
fluid
.
dygraph
.
BackwardStrategy
()
backward_strategy
=
fluid
.
dygraph
.
BackwardStrategy
()
...
@@ -321,8 +322,7 @@ class TestDygraphDoubleGradVisitedUniq(TestCase):
...
@@ -321,8 +322,7 @@ class TestDygraphDoubleGradVisitedUniq(TestCase):
dx
=
fluid
.
dygraph
.
grad
(
dx
=
fluid
.
dygraph
.
grad
(
outputs
=
[
out
],
outputs
=
[
out
],
inputs
=
[
a
],
inputs
=
[
a
],
create_graph
=
True
,
create_graph
=
False
,
retain_graph
=
True
,
only_inputs
=
True
,
only_inputs
=
True
,
allow_unused
=
False
,
allow_unused
=
False
,
backward_strategy
=
backward_strategy
)
backward_strategy
=
backward_strategy
)
...
@@ -339,9 +339,25 @@ class TestDygraphDoubleGradVisitedUniq(TestCase):
...
@@ -339,9 +339,25 @@ class TestDygraphDoubleGradVisitedUniq(TestCase):
grad_2
=
a
.
gradient
()
grad_2
=
a
.
gradient
()
self
.
assertTrue
(
self
.
assertTrue
(
np
.
array_equal
(
grad_1
,
grad_2
))
np
.
allclose
(
grad_1
,
grad_2
,
rtol
=
1.e-5
,
atol
=
1.e-8
,
equal_nan
=
True
))
class
TestRaiseNoDoubleGradOp
(
TestCase
):
def
raise_no_grad_op
(
self
):
with
fluid
.
dygraph
.
guard
():
x
=
fluid
.
layers
.
ones
(
shape
=
[
2
,
3
,
2
,
2
],
dtype
=
'float32'
)
x
.
stop_gradient
=
False
y
=
paddle
.
fluid
.
layers
.
batch_norm
(
x
)
dx
=
fluid
.
dygraph
.
grad
(
outputs
=
[
y
],
inputs
=
[
x
],
create_graph
=
True
,
retain_graph
=
True
)[
0
]
loss
=
fluid
.
layers
.
reduce_mean
(
dx
)
loss
.
backward
()
def
test_raise
(
self
):
self
.
assertRaises
(
fluid
.
core
.
EnforceNotMet
,
self
.
raise_no_grad_op
)
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录