Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
529b394f
MegEngine
项目概览
MegEngine 天元
/
MegEngine
大约 1 年 前同步成功
通知
399
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看板
提交
529b394f
编写于
3月 16, 2022
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(imperative): fix profiler problem
GitOrigin-RevId: ea0d8a505458cb5b617e4146c5621c0aa4b4fc74
上级
e64536a3
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
18 addition
and
20 deletion
+18
-20
imperative/src/impl/interpreter/interpreter_impl.cpp
imperative/src/impl/interpreter/interpreter_impl.cpp
+18
-20
未找到文件。
imperative/src/impl/interpreter/interpreter_impl.cpp
浏览文件 @
529b394f
...
...
@@ -339,16 +339,17 @@ void ChannelImpl::dispatch_kernel(
auto
&
state
=
get_channel_state
();
auto
&
options
=
state
.
options
;
auto
name
=
op
->
trait
()
->
make_name
(
*
op
);
auto
_
=
StackManager
::
Guard
{
name
,
&
state
.
stack_manager
};
auto
[
output_descs
,
validated
]
=
OpDef
::
infer_output_attrs_fallible
(
*
op
,
input_descs
);
MGB_RECORD_EVENT
(
ShapeInferEvent
,
validated
);
SmallVector
<
TensorInfo
*>
output_infos
;
output_infos
.
reserve
(
output_descs
.
size
());
uint64_t
apply_id
=
Profiler
::
next_id
();
outputs
->
reserve
(
output_descs
.
size
());
for
(
int
i
=
0
;
i
<
output_descs
.
size
();
++
i
)
{
auto
&&
desc
=
output_descs
[
i
];
auto
info
=
alloc
();
...
...
@@ -361,31 +362,28 @@ void ChannelImpl::dispatch_kernel(
output_infos
.
push_back
(
info
);
outputs
->
push_back
(
reinterpret_cast
<
Handle
>
(
info
));
}
auto
op_info_getter
=
[
op
]
{
std
::
unordered_map
<
std
::
string
,
std
::
string
>
op_info
;
auto
props
=
OpDef
::
props
(
*
op
);
for
(
auto
&&
[
key
,
value
]
:
props
)
{
op_info
[
key
]
=
value
;
}
return
op_info
;
};
ApplyOp
cmd
{
Profiler
::
next_id
(),
std
::
move
(
op
),
std
::
move
(
input_infos
),
std
::
move
(
output_infos
),
validated
};
if
(
Profiler
::
is_profiling
())
{
auto
name
=
op
->
trait
()
->
make_name
(
*
op
);
auto
_
=
StackManager
::
Guard
{
name
,
&
state
.
stack_manager
};
auto
op_info_getter
=
[
op
=
cmd
.
op
]
{
std
::
unordered_map
<
std
::
string
,
std
::
string
>
op_info
;
auto
props
=
OpDef
::
props
(
*
op
);
for
(
auto
&&
[
key
,
value
]
:
props
)
{
op_info
[
key
]
=
value
;
}
return
op_info
;
};
MGB_RECORD_EVENT
(
OpDispatchEvent
,
apply_id
,
name
,
op_info_getter
,
tinfo_to_tid
(
std
::
move
(
input_infos
)),
tinfo_to_tid
(
std
::
move
(
output_infos
)),
state
.
stack_manager
.
dump
());
OpDispatchEvent
,
cmd
.
id
,
name
,
op_info_getter
,
tinfo_to_tid
(
cmd
.
inputs
),
tinfo_to_tid
(
cmd
.
outputs
),
state
.
stack_manager
.
dump
());
m_worker
.
add_task
(
{
Profiler
::
next_id
(),
ApplyOp
{
apply_id
,
std
::
move
(
op
),
std
::
move
(
input_infos
),
std
::
move
(
output_infos
),
validated
},
{
Profiler
::
next_id
(),
std
::
move
(
cmd
),
get_channel_state
().
stack_manager
.
dump
()});
}
else
{
m_worker
.
add_task
({
Profiler
::
next_id
(),
ApplyOp
{
apply_id
,
std
::
move
(
op
),
std
::
move
(
input_infos
),
std
::
move
(
output_infos
),
validated
},
std
::
move
(
cmd
),
});
}
if
(
!
validated
&&
options
.
async_level
==
1
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录