Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
6c413ba9
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看板
提交
6c413ba9
编写于
3月 18, 2022
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor(mge): refactor physical tensor
GitOrigin-RevId: 93ba67ca5aa3ab06d47c985ca98d6df4927ae393
上级
d56570d9
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
3 addition
and
13 deletion
+3
-13
imperative/python/src/tensor_utils.cpp
imperative/python/src/tensor_utils.cpp
+1
-0
imperative/src/impl/physical_tensor.cpp
imperative/src/impl/physical_tensor.cpp
+2
-13
未找到文件。
imperative/python/src/tensor_utils.cpp
浏览文件 @
6c413ba9
...
@@ -949,6 +949,7 @@ std::tuple<std::vector<int32_t>, bool> tuple2vector(py::object shape) {
...
@@ -949,6 +949,7 @@ std::tuple<std::vector<int32_t>, bool> tuple2vector(py::object shape) {
}
}
bool
enable_fastpath
(
py
::
handle
inp
)
{
bool
enable_fastpath
(
py
::
handle
inp
)
{
// FIXME: the way to judge whether it is in traced module is inaccurate
if
(
!
TensorWrapper
::
try_cast
(
inp
.
ptr
())
||
if
(
!
TensorWrapper
::
try_cast
(
inp
.
ptr
())
||
TransformationManager
::
get_instance
()
TransformationManager
::
get_instance
()
.
segments
[
TransformationManager
::
Segment
::
Trace
]
.
segments
[
TransformationManager
::
Segment
::
Trace
]
...
...
imperative/src/impl/physical_tensor.cpp
浏览文件 @
6c413ba9
...
@@ -113,12 +113,7 @@ Tensor::Tensor(const HostTensorND& hv) : Tensor(hv.layout(), hv.comp_node()) {
...
@@ -113,12 +113,7 @@ Tensor::Tensor(const HostTensorND& hv) : Tensor(hv.layout(), hv.comp_node()) {
MGB_RECORD_EVENT
(
MGB_RECORD_EVENT
(
profiler
::
HostToDeviceEvent
,
hv
.
layout
(),
hv
.
comp_node
(),
hv
.
raw_ptr
(),
profiler
::
HostToDeviceEvent
,
hv
.
layout
(),
hv
.
comp_node
(),
hv
.
raw_ptr
(),
dev_tensor
().
raw_ptr
());
dev_tensor
().
raw_ptr
());
DeviceTensorStorage
storage
;
dev_tensor
(
false
).
copy_from_fixlayout
(
hv
);
storage
.
reset
(
m_cn
,
m_blob
->
size
(),
m_blob
->
storage
());
storage
=
storage
.
sub
(
m_offset
);
DeviceTensorND
dv
;
dv
.
reset
(
storage
,
m_layout
);
dv
.
copy_from_fixlayout
(
hv
);
// even though hv is saved in m_value, Tensor itself could be
// even though hv is saved in m_value, Tensor itself could be
// released before copy completes
// released before copy completes
MGB_RECORD_EVENT
(
MGB_RECORD_EVENT
(
...
@@ -218,15 +213,9 @@ megdnn::TensorND Tensor::dnn_tensor() {
...
@@ -218,15 +213,9 @@ megdnn::TensorND Tensor::dnn_tensor() {
}
}
void
Tensor
::
fetch_value
()
{
void
Tensor
::
fetch_value
()
{
MGB_LOCK_GUARD
(
m_blob_mtx
);
MGB_LOCK_GUARD
(
m_value_mtx
);
MGB_LOCK_GUARD
(
m_value_mtx
);
if
(
m_value
.
empty
())
{
if
(
m_value
.
empty
())
{
DeviceTensorStorage
storage
;
m_value
.
copy_from
(
dev_tensor
(
false
));
storage
.
reset
(
m_cn
,
m_blob
->
size
(),
m_blob
->
storage
());
storage
=
storage
.
sub
(
m_offset
);
DeviceTensorND
dv
;
dv
.
reset
(
storage
,
m_layout
);
m_value
.
copy_from
(
dv
);
m_value_ready
.
reset
(
EventPool
::
without_timer
().
alloc
(
comp_node
()));
m_value_ready
.
reset
(
EventPool
::
without_timer
().
alloc
(
comp_node
()));
m_value_ready
->
record
();
m_value_ready
->
record
();
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录