Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
5e7d2a91
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看板
提交
5e7d2a91
编写于
7月 16, 2020
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor(mgb): add TensorND::proxy_to_default_cpu
GitOrigin-RevId: 3ab8525f1c0e04d128632982a7f3ffdb78971a23
上级
7a8a2830
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
42 addition
and
7 deletion
+42
-7
src/core/include/megbrain/tensor.h
src/core/include/megbrain/tensor.h
+33
-7
src/core/test/tensor.cpp
src/core/test/tensor.cpp
+9
-0
未找到文件。
src/core/include/megbrain/tensor.h
浏览文件 @
5e7d2a91
...
...
@@ -101,6 +101,14 @@ class Slice {
SubTensorSpec
apply
(
TensorLayout
layout
,
int
axis
)
const
;
};
template
<
class
Trait
>
class
TensorStorage
;
class
DeviceTensorStorageTrait
;
class
HostTensorStorageTrait
;
using
HostTensorStorage
=
TensorStorage
<
HostTensorStorageTrait
>
;
using
DeviceTensorStorage
=
TensorStorage
<
DeviceTensorStorageTrait
>
;
/*!
* \brief manager for raw tensor memory
*
...
...
@@ -230,6 +238,18 @@ class TensorStorage {
std
::
enable_if
<!
std
::
is_same
<
Trait
,
RTrait
>
::
value
>::
type
>
static
TensorStorage
make_proxy
(
const
TensorStorage
<
RTrait
>
&
src
);
/*!
* \brief make a DeviceTensorStorage on default_cpu
* that shares memory with this
*
* this must be a HostTensorStorage. Alignment not checked.
*/
template
<
bool
x
=
true
,
typename
=
std
::
enable_if_t
<
x
&&
std
::
is_same
<
Trait
,
HostTensorStorageTrait
>
::
value
>>
DeviceTensorStorage
proxy_to_default_cpu
()
const
{
ptr
();
return
{
true
,
CompNode
::
default_cpu
(),
m_size
,
m_capacity
,
m_offset
,
m_data
};
}
//! shortcut for raw_storage().use_count(), but won't trigger lazy alloc
size_t
use_count
()
const
{
if
(
m_size
>
m_capacity
)
{
...
...
@@ -284,11 +304,12 @@ class TensorStorage {
[[
noreturn
]]
static
void
on_invalid_comp_node
();
};
class
DeviceTensorStorageTrait
;
class
HostTensorStorageTrait
;
using
HostTensorStorage
=
TensorStorage
<
HostTensorStorageTrait
>
;
using
DeviceTensorStorage
=
TensorStorage
<
DeviceTensorStorageTrait
>
;
template
<
class
TensorStorage
>
class
TensorND
;
using
HostTensorND
=
TensorND
<
HostTensorStorage
>
;
using
DeviceTensorND
=
TensorND
<
DeviceTensorStorage
>
;
/*!
* \brief n-dimensional tensor
...
...
@@ -519,10 +540,15 @@ class TensorND {
ret
.
reset
(
TensorStorage
::
make_proxy
(
src
.
storage
()),
src
.
layout
());
return
ret
;
}
};
using
HostTensorND
=
TensorND
<
HostTensorStorage
>
;
using
DeviceTensorND
=
TensorND
<
DeviceTensorStorage
>
;
//! similar to HostTensorStorage::proxy_to_default_cpu
template
<
bool
x
=
true
,
typename
=
std
::
enable_if_t
<
x
&&
std
::
is_same
<
TensorStorage
,
HostTensorStorage
>
::
value
>>
DeviceTensorND
proxy_to_default_cpu
()
const
{
DeviceTensorND
ret
;
ret
.
reset
(
storage
().
proxy_to_default_cpu
(),
layout
());
return
ret
;
}
};
/*!
* \brief call memset in the data of a device tensor
...
...
src/core/test/tensor.cpp
浏览文件 @
5e7d2a91
...
...
@@ -418,4 +418,13 @@ TEST(TestTensor, CpuCudaD2DCopy) {
}
}
TEST
(
TestTensor
,
ProxyToDefaultCPU
)
{
auto
cn
=
CompNode
::
load
(
"xpux"
);
auto
x
=
HostTensorND
(
cn
,
TensorLayout
({
1
,
2
,
3
},
dtype
::
Float32
{}));
auto
y
=
x
.
proxy_to_default_cpu
();
ASSERT_EQ
(
y
.
comp_node
(),
CompNode
::
default_cpu
());
ASSERT_EQ
(
x
.
layout
(),
y
.
layout
());
ASSERT_EQ
(
x
.
raw_ptr
(),
y
.
raw_ptr
());
}
// vim: syntax=cpp.doxygen foldmethod=marker foldmarker=f{{{,f}}}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录