Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
f70d644a
MegEngine
项目概览
MegEngine 天元
/
MegEngine
1 年多 前同步成功
通知
403
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看板
提交
f70d644a
编写于
3月 31, 2023
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(trace): add error message for dumping func without return value
GitOrigin-RevId: 1a5885a7688378aa01fbfe530dd8bdfe31dd995d
上级
08f7a957
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
31 addition
and
1 deletion
+31
-1
imperative/python/megengine/jit/tracing.py
imperative/python/megengine/jit/tracing.py
+10
-1
imperative/python/test/unit/jit/test_tracing.py
imperative/python/test/unit/jit/test_tracing.py
+21
-0
未找到文件。
imperative/python/megengine/jit/tracing.py
浏览文件 @
f70d644a
...
...
@@ -9,7 +9,7 @@ import pickle
import
re
import
struct
import
sys
from
typing
import
Any
from
typing
import
Any
,
Sequence
import
cv2
import
numpy
as
np
...
...
@@ -241,6 +241,8 @@ class trace:
def
_process_outputs
(
self
,
outputs
):
if
isinstance
(
outputs
,
RawTensor
):
outputs
=
[
outputs
]
if
not
isinstance
(
outputs
,
Sequence
):
outputs
=
[
outputs
]
if
isinstance
(
outputs
,
collections
.
abc
.
Mapping
):
output_names
,
outputs
=
zip
(
*
sorted
(
outputs
.
items
()))
else
:
...
...
@@ -248,6 +250,9 @@ class trace:
output_names
=
None
self
.
_output_names
=
output_names
for
i
,
output
in
enumerate
(
outputs
):
assert
isinstance
(
output
,
RawTensor
),
"Only support return tensors when capture_as_const is enabled"
name_tensor
(
"output_{}"
.
format
(
i
),
output
)
if
self
.
_output_bindings
is
None
:
self
.
_output_bindings
=
[
"output_{}"
.
format
(
i
)
for
i
in
range
(
len
(
outputs
))]
...
...
@@ -679,6 +684,10 @@ class trace:
raise
ValueError
(
"you must specify capture_as_const=True at __init__ to use dump"
)
if
not
hasattr
(
self
,
"_output_names"
):
raise
ValueError
(
"the traced function without return values cannot be dumped, the traced function should return List[Tensor] or Dict[str, Tensor]"
)
if
self
.
_output_names
and
output_names
:
raise
TypeError
(
"cannot specify output_names when output is already in dict format"
...
...
imperative/python/test/unit/jit/test_tracing.py
浏览文件 @
f70d644a
...
...
@@ -782,3 +782,24 @@ def test_invalid_inp_error():
)
else
:
assert
False
def
test_dump_without_output_error
():
def
forward
(
x
):
return
x
*
x
@
trace
(
symbolic
=
True
,
capture_as_const
=
True
)
def
f
(
x
):
y
=
forward
(
x
)
data
=
tensor
([
1.0
,
2.0
,
3.0
])
f
(
data
)
try
:
file
=
io
.
BytesIO
()
f
.
dump
(
file
,
arg_names
=
[
"x"
])
except
Exception
as
e
:
assert
(
str
(
e
)
==
"the traced function without return values cannot be dumped, the traced function should return List[Tensor] or Dict[str, Tensor]"
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录