Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
0a3ca253
MegEngine
项目概览
MegEngine 天元
/
MegEngine
1 年多 前同步成功
通知
404
Star
4705
Fork
582
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
MegEngine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
0a3ca253
编写于
1月 14, 2021
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(mge): fix backward graph optimization
GitOrigin-RevId: 28fd00ac548e7cd663a87ce74070862e9a24b55f
上级
ea8eb4cf
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
16 addition
and
2 deletion
+16
-2
imperative/python/test/unit/core/test_autodiff.py
imperative/python/test/unit/core/test_autodiff.py
+15
-1
imperative/src/impl/backward_graph_opt.cpp
imperative/src/impl/backward_graph_opt.cpp
+1
-1
未找到文件。
imperative/python/test/unit/core/test_autodiff.py
浏览文件 @
0a3ca253
...
@@ -19,7 +19,7 @@ import megengine.functional as F
...
@@ -19,7 +19,7 @@ import megengine.functional as F
from
megengine.core._imperative_rt
import
CompNode
,
TensorAttr
,
imperative
from
megengine.core._imperative_rt
import
CompNode
,
TensorAttr
,
imperative
from
megengine.core._imperative_rt.core2
import
TensorWeakRef
,
apply
,
sync
from
megengine.core._imperative_rt.core2
import
TensorWeakRef
,
apply
,
sync
from
megengine.core.autodiff.grad
import
Grad
from
megengine.core.autodiff.grad
import
Grad
from
megengine.core.ops.builtin
import
Elemwise
from
megengine.core.ops.builtin
import
Elemwise
,
Identity
from
megengine.distributed.helper
import
get_device_count_by_fork
from
megengine.distributed.helper
import
get_device_count_by_fork
from
megengine.functional.distributed
import
remote_recv
,
remote_send
from
megengine.functional.distributed
import
remote_recv
,
remote_send
...
@@ -193,6 +193,20 @@ def test_grad_inplace():
...
@@ -193,6 +193,20 @@ def test_grad_inplace():
np
.
testing
.
assert_almost_equal
(
x
.
grad
.
numpy
(),
4
*
x_np
**
3
,
decimal
=
6
)
np
.
testing
.
assert_almost_equal
(
x
.
grad
.
numpy
(),
4
*
x_np
**
3
,
decimal
=
6
)
def
test_identity
():
x_np
=
np
.
random
.
rand
(
10
).
astype
(
"float32"
)
x
=
mge
.
Tensor
(
x_np
)
dy_np
=
np
.
random
.
rand
(
*
x
.
shape
).
astype
(
"float32"
)
dy
=
mge
.
Tensor
(
dy_np
)
grad
=
Grad
().
wrt
(
x
,
callback
=
save_to
(
x
))
(
y
,)
=
apply
(
Identity
(),
x
)
grad
(
y
,
dy
)
np
.
testing
.
assert_array_equal
(
x
.
grad
.
numpy
(),
dy_np
)
def
test_elemwise_add
():
def
test_elemwise_add
():
x_np
=
np
.
random
.
rand
(
10
).
astype
(
"float32"
)
x_np
=
np
.
random
.
rand
(
10
).
astype
(
"float32"
)
y_np
=
np
.
random
.
rand
(
10
,
10
).
astype
(
"float32"
)
y_np
=
np
.
random
.
rand
(
10
,
10
).
astype
(
"float32"
)
...
...
imperative/src/impl/backward_graph_opt.cpp
浏览文件 @
0a3ca253
...
@@ -58,7 +58,7 @@ OptimizedBackwardGraphResult::OptimizedBackwardGraphResult(const BackwardGraphRe
...
@@ -58,7 +58,7 @@ OptimizedBackwardGraphResult::OptimizedBackwardGraphResult(const BackwardGraphRe
// should be marked as always appears in backward
// should be marked as always appears in backward
for
(
size_t
i
=
0
,
j
=
0
;
i
<
mask
.
size
();
++
i
)
{
for
(
size_t
i
=
0
,
j
=
0
;
i
<
mask
.
size
();
++
i
)
{
if
(
!
mask
[
i
])
continue
;
if
(
!
mask
[
i
])
continue
;
if
(
i
>
input_size
+
output_size
)
{
if
(
i
>
=
input_size
+
output_size
)
{
vinfo
[
graph
.
inputs
[
j
]].
appears_in_backward
=
true
;
vinfo
[
graph
.
inputs
[
j
]].
appears_in_backward
=
true
;
}
}
++
j
;
++
j
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录