Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
9a79342d
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看板
提交
9a79342d
编写于
12月 14, 2020
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor(mge/virtualdep): remove virtualdep opdef
GitOrigin-RevId: bbe3ae3fa3d635e7adc1a7a5080e060699ea611f
上级
88b402ef
变更
6
显示空白变更内容
内联
并排
Showing
6 changed file
with
28 addition
and
99 deletion
+28
-99
imperative/python/megengine/core/tensor/megbrain_graph.py
imperative/python/megengine/core/tensor/megbrain_graph.py
+6
-0
imperative/python/megengine/jit/tracing.py
imperative/python/megengine/jit/tracing.py
+9
-9
imperative/python/src/graph_rt.cpp
imperative/python/src/graph_rt.cpp
+13
-0
imperative/python/src/ops.cpp
imperative/python/src/ops.cpp
+0
-6
imperative/src/impl/ops/utility.cpp
imperative/src/impl/ops/utility.cpp
+0
-44
imperative/src/include/megbrain/imperative/ops/utility.h
imperative/src/include/megbrain/imperative/ops/utility.h
+0
-40
未找到文件。
imperative/python/megengine/core/tensor/megbrain_graph.py
浏览文件 @
9a79342d
...
@@ -569,3 +569,9 @@ class AttrOutputNode(OpNode):
...
@@ -569,3 +569,9 @@ class AttrOutputNode(OpNode):
def
reset
(
self
):
def
reset
(
self
):
self
.
_rendezvous
.
reset
()
self
.
_rendezvous
.
reset
()
class
VirtualDepNode
(
OpNode
):
def
__init__
(
self
,
vars
,
device
=
""
):
out
=
_imperative_rt
.
virtual_dep
(
_unwrap
(
vars
),
device
)
super
().
__init__
(
out
)
imperative/python/megengine/jit/tracing.py
浏览文件 @
9a79342d
...
@@ -25,7 +25,6 @@ from ..core._imperative_rt.ops import (
...
@@ -25,7 +25,6 @@ from ..core._imperative_rt.ops import (
RemoteRecv
,
RemoteRecv
,
RemoteSend
,
RemoteSend
,
UniformRNG
,
UniformRNG
,
VirtualDep
,
)
)
from
..core._trace_option
import
set_symbolic_shape
from
..core._trace_option
import
set_symbolic_shape
from
..core._wrap
import
device
as
as_device
from
..core._wrap
import
device
as
as_device
...
@@ -548,9 +547,10 @@ class trace:
...
@@ -548,9 +547,10 @@ class trace:
need_reset_nodes
.
append
(
opnode
)
need_reset_nodes
.
append
(
opnode
)
info
.
varnode
,
*
in_out_links
=
opnode
.
outputs
info
.
varnode
,
*
in_out_links
=
opnode
.
outputs
if
require_links
and
i
==
0
and
len
(
io_links
)
>
0
:
if
require_links
and
i
==
0
and
len
(
io_links
)
>
0
:
info
.
varnode
=
apply
(
opnode
=
G
.
VirtualDepNode
(
VirtualDep
(
str
(
io_links
[
0
].
device
)),
info
.
varnode
,
*
io_links
[
info
.
varnode
,
*
io_links
],
str
(
io_links
[
0
].
device
)
)[
0
]
)
info
.
varnode
=
opnode
.
outputs
[
0
]
io_links
=
(
info
.
varnode
,)
io_links
=
(
info
.
varnode
,)
ivars
.
append
(
info
.
varnode
)
ivars
.
append
(
info
.
varnode
)
...
@@ -1112,11 +1112,11 @@ def apply_symbolic_mode(op: OpDef, *args: RawTensor):
...
@@ -1112,11 +1112,11 @@ def apply_symbolic_mode(op: OpDef, *args: RawTensor):
if
require_links
and
active_trace
.
_lazy_eval_links
:
if
require_links
and
active_trace
.
_lazy_eval_links
:
assert
len
(
ivars
)
>
0
,
"op should has at least one input"
assert
len
(
ivars
)
>
0
,
"op should has at least one input"
ivars
[
0
]
=
apply
(
opnode
=
G
.
VirtualDepNode
(
VirtualDep
(
str
(
active_trace
.
_lazy_eval_links
[
0
].
device
))
,
[
ivars
[
0
],
*
active_trace
.
_lazy_eval_links
]
,
ivars
[
0
]
,
str
(
active_trace
.
_lazy_eval_links
[
0
].
device
)
,
*
active_trace
.
_lazy_eval_links
,
)
)
[
0
]
ivars
[
0
]
=
opnode
.
outputs
[
0
]
active_trace
.
_lazy_eval_links
=
(
ivars
[
0
],)
active_trace
.
_lazy_eval_links
=
(
ivars
[
0
],)
ovars
=
apply
(
op
,
*
ivars
)
ovars
=
apply
(
op
,
*
ivars
)
...
...
imperative/python/src/graph_rt.cpp
浏览文件 @
9a79342d
...
@@ -15,6 +15,7 @@
...
@@ -15,6 +15,7 @@
#include "megbrain/serialization/serializer.h"
#include "megbrain/serialization/serializer.h"
#include "megbrain/imperative/opr_utility.h"
#include "megbrain/imperative/opr_utility.h"
#include "megbrain/opr/io.h"
#include "megbrain/opr/io.h"
#include "megbrain/opr/utility.h"
#include "megbrain/opr/basic_arith.h"
#include "megbrain/opr/basic_arith.h"
#include "megbrain/imperative.h"
#include "megbrain/imperative.h"
#include "./helper.h"
#include "./helper.h"
...
@@ -562,4 +563,16 @@ void init_graph_rt(py::module m) {
...
@@ -562,4 +563,16 @@ void init_graph_rt(py::module m) {
};
};
return
output_callback
(
std
::
move
(
f
),
std
::
move
(
inputs
),
p
,
true
);
return
output_callback
(
std
::
move
(
f
),
std
::
move
(
inputs
),
p
,
true
);
});
});
m
.
def
(
"virtual_dep"
,
[](
std
::
vector
<
cg
::
VarNode
*>
inputs
,
std
::
string
device
)
{
auto
&&
graph
=
inputs
[
0
]
->
owner_graph
();
VarNodeArray
inps
(
inputs
.
begin
(),
inputs
.
end
());
cg
::
OperatorNodeConfig
config
;
if
(
device
.
length
()
>
0
)
{
config
.
comp_node
(
CompNode
::
load
(
device
));
}
cg
::
OperatorNodeBase
*
opr
=
graph
->
insert_opr
(
std
::
make_unique
<
mgb
::
opr
::
VirtualDep
>
(
inps
,
config
));
return
opr
;
});
}
}
imperative/python/src/ops.cpp
浏览文件 @
9a79342d
...
@@ -10,12 +10,10 @@
...
@@ -10,12 +10,10 @@
*/
*/
#include "./ops.h"
#include "./ops.h"
#include <string>
#include "megbrain/imperative.h"
#include "megbrain/imperative.h"
#include "megbrain/imperative/ops/backward_graph.h"
#include "megbrain/imperative/ops/backward_graph.h"
#include "megbrain/imperative/ops/opr_attr.h"
#include "megbrain/imperative/ops/opr_attr.h"
#include "megbrain/imperative/ops/utility.h"
#include "megbrain/imperative/ops/autogen.h"
#include "megbrain/imperative/ops/autogen.h"
namespace
py
=
pybind11
;
namespace
py
=
pybind11
;
...
@@ -45,9 +43,5 @@ void init_ops(py::module m) {
...
@@ -45,9 +43,5 @@ void init_ops(py::module m) {
return
self
.
graph
().
interpret
<
py
::
object
>
(
f
,
c
,
inputs
);
return
self
.
graph
().
interpret
<
py
::
object
>
(
f
,
c
,
inputs
);
});
});
py
::
class_
<
VirtualDep
,
std
::
shared_ptr
<
VirtualDep
>
,
OpDef
>
(
m
,
"VirtualDep"
)
.
def
(
py
::
init
<>
())
.
def
(
py
::
init
<
std
::
string
>
());
#include "opdef.py.inl"
#include "opdef.py.inl"
}
}
imperative/src/impl/ops/utility.cpp
已删除
100644 → 0
浏览文件 @
88b402ef
/**
* \file imperative/src/impl/ops/utility.cpp
* MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
*
* Copyright (c) 2014-2020 Megvii Inc. All rights reserved.
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*/
#include "megbrain/imperative/ops/utility.h"
#include <string>
#include "megbrain/comp_node.h"
#include "megbrain/imperative/ops/opr_attr.h"
#include "megbrain/opr/utility.h"
#include "../op_trait.h"
namespace
mgb
::
imperative
{
namespace
{
cg
::
OperatorNodeBase
*
virtual_dep_apply_on_var_node
(
const
OpDef
&
def
,
const
VarNodeArray
&
inputs
)
{
auto
&&
graph
=
inputs
[
0
]
->
owner_graph
();
auto
&&
op
=
def
.
cast_final_safe
<
VirtualDep
>
();
VarNodeArray
inps
(
inputs
.
begin
(),
inputs
.
end
());
cg
::
OperatorNodeConfig
config
;
if
(
op
.
device
.
length
()
>
0
)
{
config
.
comp_node
(
CompNode
::
load
(
op
.
device
));
}
cg
::
OperatorNodeBase
*
opr
=
graph
->
insert_opr
(
std
::
make_unique
<
mgb
::
opr
::
VirtualDep
>
(
inps
,
config
));
return
opr
;
}
OP_TRAIT_REG
(
VirtualDep
,
VirtualDep
,
mgb
::
opr
::
VirtualDep
)
.
apply_on_var_node
(
virtual_dep_apply_on_var_node
)
.
fallback
();
}
// namespace
MGB_DYN_TYPE_OBJ_FINAL_IMPL
(
VirtualDep
);
}
// namespace mgb::imperative
imperative/src/include/megbrain/imperative/ops/utility.h
已删除
100644 → 0
浏览文件 @
88b402ef
/**
* \file imperative/src/include/megbrain/imperative/ops/utility.h
* MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
*
* Copyright (c) 2014-2020 Megvii Inc. All rights reserved.
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*/
#pragma once
#include <string>
#include "megbrain/graph/operator_node.h"
#include "megbrain/imperative/op_def.h"
#include "megbrain/utils/hash.h"
namespace
mgb
::
imperative
{
class
VirtualDep
:
public
OpDefImplBase
<
VirtualDep
>
{
MGB_DYN_TYPE_OBJ_FINAL_DECL
;
public:
VirtualDep
()
=
default
;
VirtualDep
(
std
::
string
dev
)
:
device
(
dev
)
{}
std
::
string
device
;
size_t
hash
()
const
override
{
return
reinterpret_cast
<
size_t
>
(
dyn_typeinfo
());
}
bool
is_same_st
(
const
Hashable
&
rhs
)
const
override
{
return
true
;
}
};
}
// namespace mgb::imperative
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录