Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
ebe86892
MegEngine
项目概览
MegEngine 天元
/
MegEngine
9 个月 前同步成功
通知
392
Star
4702
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看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
ebe86892
编写于
1月 08, 2021
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(sdk/load_and_run): add flags --io-dump-stdout and --io-dump-stderr
GitOrigin-RevId: 64d572bdfc4e2008497bc1e62c44e852acfd46a0
上级
5c7d48cd
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
38 addition
and
0 deletion
+38
-0
sdk/load-and-run/src/mgblar.cpp
sdk/load-and-run/src/mgblar.cpp
+20
-0
src/plugin/test/opr_io_dump.cpp
src/plugin/test/opr_io_dump.cpp
+18
-0
未找到文件。
sdk/load-and-run/src/mgblar.cpp
浏览文件 @
ebe86892
...
...
@@ -94,6 +94,8 @@ R"__usage__(
Dump input/output values of all internal variables to output file or
directory, in text or binary format. The binary file can be parsed by
`megbrain.plugin.load_tensor_binary`.
--io-dump-stdout | --io-dump-stderr
Dump input/output values of all internal variables to stdout or stderr in text format
--bin-out-dump <output dir>
Dump output tensor values in binary format to given directory.
--iter <num>
...
...
@@ -1200,6 +1202,24 @@ Args Args::from_argv(int argc, char **argv) {
ret
.
iodump
=
std
::
move
(
iodump
);
continue
;
}
if
(
!
strcmp
(
argv
[
i
],
"--io-dump-stdout"
))
{
mgb_log_warn
(
"enable opr io dump to stdout"
);
std
::
shared_ptr
<
FILE
>
sp
(
stdout
,
[](
FILE
*
){});
auto
iodump
=
std
::
make_unique
<
TextOprIODump
>
(
ret
.
load_config
.
comp_graph
.
get
(),
sp
);
iodump
->
print_addr
(
false
);
ret
.
iodump
=
std
::
move
(
iodump
);
continue
;
}
if
(
!
strcmp
(
argv
[
i
],
"--io-dump-stderr"
))
{
mgb_log_warn
(
"enable opr io dump to stderr"
);
std
::
shared_ptr
<
FILE
>
sp
(
stderr
,
[](
FILE
*
){});
auto
iodump
=
std
::
make_unique
<
TextOprIODump
>
(
ret
.
load_config
.
comp_graph
.
get
(),
sp
);
iodump
->
print_addr
(
false
);
ret
.
iodump
=
std
::
move
(
iodump
);
continue
;
}
if
(
!
strcmp
(
argv
[
i
],
"--bin-io-dump"
))
{
mgb_log_warn
(
"enable opr binary io dump"
);
++
i
;
...
...
src/plugin/test/opr_io_dump.cpp
浏览文件 @
ebe86892
...
...
@@ -181,6 +181,24 @@ TEST(TestOprIODump, Text) {
run_test
(
make_plugin
,
check_result
);
}
TEST
(
TestOprIODump
,
StdErr
)
{
HostTensorGenerator
<>
gen
;
auto
host_x
=
gen
({
5
});
auto
host_y
=
gen
({
5
});
auto
graph
=
ComputingGraph
::
make
();
std
::
shared_ptr
<
FILE
>
sp
(
stdout
,
[](
FILE
*
){});
auto
plugin
=
std
::
make_unique
<
TextOprIODump
>
(
graph
.
get
(),
sp
);
auto
x
=
opr
::
Host2DeviceCopy
::
make
(
*
graph
,
host_x
);
auto
y
=
opr
::
Host2DeviceCopy
::
make
(
*
graph
,
host_y
);
auto
z
=
x
+
y
;
HostTensorND
host_z
;
auto
func
=
graph
->
compile
({
make_callback_copy
(
z
,
host_z
)});
func
->
execute
();
}
TEST
(
TestOprIODump
,
Binary
)
{
auto
fname
=
output_file
(
""
);
auto
make_plugin
=
[
&
](
ComputingGraph
*
graph
,
int
level
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录