Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
2b35fca1
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
2b35fca1
编写于
8月 02, 2017
作者:
Z
Zhuoyuan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
gather modify
上级
08021979
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
34 addition
and
37 deletion
+34
-37
paddle/operators/gather_func.h
paddle/operators/gather_func.h
+34
-37
未找到文件。
paddle/operators/gather_func.h
浏览文件 @
2b35fca1
...
...
@@ -21,44 +21,41 @@ limitations under the License. */
/**
* Return a new tensor from source tensor, gathered according to index
* input[src]: type-T source Tensor
* input[
I
ndex]: type-int index Tensor (1-D)
* input[
i
ndex]: type-int index Tensor (1-D)
* return: output tensor
*/
template
<
typename
place
,
typename
T
>
Tensor
*
Gather_func
(
Tensor
*
Src
,
Tensor
*
Index
)
{
// assert index is an int-type tensor?
// assert(Index->istype(int));
template
<
typename
Place
,
typename
T
>
Tensor
*
Gather
(
Tensor
*
src
,
Tensor
*
index
)
{
// check index of shape 1-D
PADDLE_ENFORCE
(
index
->
dims
().
size
()
==
1
);
int
index_size
=
index
->
dims
()[
0
];
// check index of shape 1-D
assert
(
Index
->
dims
().
size
()
==
1
);
int
index_size
=
Index
->
dims
()[
0
];
// Source shape
auto
src_dims
=
src
->
dims
();
DDim
output_dims
(
dims_src
);
// Create a tensor of shape [index_size, dim_src[1:]]
output_dims
[
0
]
=
index_size
;
// Source shape
auto
src_dims
=
Src
->
dims
();
DDim
output_dims
(
dims_src
);
// Create a tensor of shape [index_size, dim_src[1:]]
output_dims
[
0
]
=
index_size
;
Tensor
*
New_tensor
;
float
*
output
=
nullptr
;
Tensor
*
New_tensor
;
float
*
output
=
nullptr
;
/* slice size */
int
slice_size
=
1
;
for
(
unsigned
int
i
=
0
;
i
<
src_dims
.
size
();
++
i
)
slice_size
*=
src_dims
[
i
];
/* slice size */
int
slice_size
=
1
;
for
(
unsigned
int
i
=
0
;
i
<
src_dims
.
size
();
++
i
)
slice_size
*=
src_dims
[
i
];
/* Gathering */
if
(
place
==
CPUPlace
())
{
// init for CPU
output
=
New_tensor
.
mutable_data
<
T
>
(
output_dims
,
CPUPlace
());
CPUGather
(
Src
->
data
(),
Index
->
data
(),
slice_size
,
new_tensor
->
mutable_data
());
}
else
{
// GPU
// init for GPU
output
=
New_tensor
.
mutable_data
<
T
>
(
output_dims
,
GPUPlace
());
/* how to specialize device??*/
GPUGather
(
d
,
Src
->
data
(),
Index
->
data
(),
slice_size
,
new_tensor
->
mutable_data
());
}
return
New_tensor
;
/* Gathering */
if
(
place
==
CPUPlace
())
{
// init for CPU
output
=
New_tensor
.
mutable_data
<
T
>
(
output_dims
,
CPUPlace
());
CPUGather
(
src
->
data
(),
index
->
data
(),
slice_size
,
new_tensor
->
mutable_data
());
}
else
{
// GPU
// init for GPU
output
=
New_tensor
.
mutable_data
<
T
>
(
output_dims
,
GPUPlace
());
/* how to specialize device??*/
GPUGather
(
d
,
src
->
data
(),
index
->
data
(),
slice_size
,
new_tensor
->
mutable_data
());
}
return
New_tensor
;
}
/* Implementation of CPU copy */
...
...
@@ -82,15 +79,15 @@ void CPUGather(const T* params, const int* indices,
*/
template
<
typename
T
>
void
GPUGather
(
const
GPUDevice
&
d
,
const
T
*
src
,
const
int
*
I
ndex
,
const
T
*
src
,
const
int
*
i
ndex
,
const
int
slice_size
,
const
int
index_size
,
T
*
output
)
{
int
block_count
=
slice_size
*
index_size
;
int
thread_per_block
=
1024
;
int
block_count
=
slice_size
*
index_size
;
int
thread_per_block
=
1024
;
GatherOpKernel
<
T
>
GatherOpKernel
<
T
>
<<<
block_count
,
thread_per_block
,
0
,
d
.
stream
()
>>>
(
src
,
I
ndex
,
output
,
slice_size
,
src
,
i
ndex
,
output
,
slice_size
,
indices_size
,
slice_size
,
out_size
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录