Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
e9e5f442
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看板
提交
e9e5f442
编写于
12月 31, 2020
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(mge): expand custom op before trace
GitOrigin-RevId: 725a5b87cb7deb62c8ef1f4f919278b57b57ffb7
上级
3faba54f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
20 deletion
+21
-20
imperative/python/src/tensor.cpp
imperative/python/src/tensor.cpp
+21
-20
未找到文件。
imperative/python/src/tensor.cpp
浏览文件 @
e9e5f442
...
...
@@ -96,29 +96,30 @@ apply_result_t apply(ApplyContext& ctx) {
return
apply_grad
(
ctx
);
}
if
(
auto
*
op
=
ctx
.
op
->
try_cast_final
<
GenericPyOp
>
())
{
py
::
tuple
pyin
(
ctx
.
nargs
);
for
(
size_t
i
=
0
;
i
<
ctx
.
nargs
;
++
i
)
{
pyin
[
i
]
=
TensorWrapper
::
make
(
ctx
.
pytype
,
ctx
.
args
[
i
]
->
shared_from_this
());
}
auto
f
=
py
::
getattr
(
op
->
obj
,
"_default_rule"
);
auto
pyout
=
py
::
reinterpret_steal
<
py
::
object
>
(
PyObject_Call
(
f
.
ptr
(),
pyin
.
ptr
(),
nullptr
));
if
(
!
pyout
)
throw
py
::
error_already_set
();
if
(
auto
*
tw
=
TensorWrapper
::
try_cast
(
pyout
.
ptr
()))
{
return
{
tw
->
m_tensor
};
}
apply_result_t
ret
;
ret
.
reserve
(
py
::
len
(
pyout
));
for
(
auto
&&
i
:
pyout
)
{
auto
*
tw
=
TensorWrapper
::
try_cast
(
i
.
ptr
());
mgb_assert
(
tw
);
ret
.
push_back
(
tw
->
m_tensor
);
}
return
ret
;
}
if
(
flags
&
Tensor
::
Flags
::
TRACE
)
{
return
apply_trace
(
ctx
);
}
else
{
if
(
auto
*
op
=
ctx
.
op
->
try_cast_final
<
GenericPyOp
>
())
{
py
::
tuple
pyin
(
ctx
.
nargs
);
for
(
size_t
i
=
0
;
i
<
ctx
.
nargs
;
++
i
)
{
pyin
[
i
]
=
TensorWrapper
::
make
(
ctx
.
pytype
,
ctx
.
args
[
i
]
->
shared_from_this
());
}
auto
f
=
py
::
getattr
(
op
->
obj
,
"_default_rule"
);
auto
pyout
=
py
::
reinterpret_steal
<
py
::
object
>
(
PyObject_Call
(
f
.
ptr
(),
pyin
.
ptr
(),
nullptr
));
if
(
auto
*
tw
=
TensorWrapper
::
try_cast
(
pyout
.
ptr
()))
{
return
{
tw
->
m_tensor
};
}
apply_result_t
ret
;
ret
.
reserve
(
py
::
len
(
pyout
));
for
(
auto
&&
i
:
pyout
)
{
auto
*
tw
=
TensorWrapper
::
try_cast
(
i
.
ptr
());
mgb_assert
(
tw
);
ret
.
push_back
(
tw
->
m_tensor
);
}
return
ret
;
}
SmallVector
<
interpreter
::
Interpreter
::
Handle
>
handles
(
ctx
.
nargs
);
for
(
size_t
i
=
0
;
i
<
ctx
.
nargs
;
++
i
)
{
handles
[
i
]
=
ctx
.
args
[
i
]
->
m_handle
.
get
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录