Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
07cf302e
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看板
提交
07cf302e
编写于
1月 18, 2018
作者:
Y
Yang Yang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
first commit
上级
7905e367
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
11 addition
and
6 deletion
+11
-6
paddle/operators/parallel_do_op.cc
paddle/operators/parallel_do_op.cc
+9
-1
python/paddle/v2/fluid/tests/test_parallel_op.py
python/paddle/v2/fluid/tests/test_parallel_op.py
+2
-5
未找到文件。
paddle/operators/parallel_do_op.cc
浏览文件 @
07cf302e
...
@@ -64,6 +64,12 @@ static void SplitTensorAndMoveTensorToScopes(
...
@@ -64,6 +64,12 @@ static void SplitTensorAndMoveTensorToScopes(
}
}
}
}
void
WaitOnPlace
(
const
platform
::
Place
place
)
{
platform
::
DeviceContextPool
&
pool
=
platform
::
DeviceContextPool
::
Instance
();
auto
&
dev_ctx
=
*
pool
.
Get
(
place
);
dev_ctx
.
Wait
();
}
void
WaitOnPlaces
(
const
std
::
vector
<
platform
::
Place
>
places
)
{
void
WaitOnPlaces
(
const
std
::
vector
<
platform
::
Place
>
places
)
{
platform
::
DeviceContextPool
&
pool
=
platform
::
DeviceContextPool
::
Instance
();
platform
::
DeviceContextPool
&
pool
=
platform
::
DeviceContextPool
::
Instance
();
...
@@ -214,6 +220,7 @@ class ParallelDoGradOp : public framework::OperatorBase {
...
@@ -214,6 +220,7 @@ class ParallelDoGradOp : public framework::OperatorBase {
auto
&
tensor_to_merge
=
sub_scopes
[
i
]
->
FindVar
(
s
)
->
Get
<
LoDTensor
>
();
auto
&
tensor_to_merge
=
sub_scopes
[
i
]
->
FindVar
(
s
)
->
Get
<
LoDTensor
>
();
if
(
!
(
places
[
i
]
==
places
[
0
]))
{
if
(
!
(
places
[
i
]
==
places
[
0
]))
{
framework
::
Copy
(
tensor_to_merge
,
places
[
0
],
tmp
);
framework
::
Copy
(
tensor_to_merge
,
places
[
0
],
tmp
);
WaitOnPlace
(
places
[
0
]);
}
else
{
}
else
{
tmp
->
ShareDataWith
(
tensor_to_merge
);
tmp
->
ShareDataWith
(
tensor_to_merge
);
}
}
...
@@ -222,12 +229,13 @@ class ParallelDoGradOp : public framework::OperatorBase {
...
@@ -222,12 +229,13 @@ class ParallelDoGradOp : public framework::OperatorBase {
"sum"
,
{{
"X"
,
{
s
,
tmp_name
}}},
{{
"Out"
,
{
s
}}},
"sum"
,
{{
"X"
,
{
s
,
tmp_name
}}},
{{
"Out"
,
{
s
}}},
framework
::
AttributeMap
{});
framework
::
AttributeMap
{});
sum_op
->
Run
(
*
sub_scopes
[
0
],
places
[
0
]);
sum_op
->
Run
(
*
sub_scopes
[
0
],
places
[
0
]);
WaitOnPlace
s
(
places
);
WaitOnPlace
(
places
[
0
]
);
}
}
VLOG
(
3
)
<<
result
;
VLOG
(
3
)
<<
result
;
framework
::
Copy
(
result
,
place
,
scope
.
FindVar
(
s
)
->
GetMutable
<
LoDTensor
>
());
framework
::
Copy
(
result
,
place
,
scope
.
FindVar
(
s
)
->
GetMutable
<
LoDTensor
>
());
}
}
WaitOnPlaces
(
places
);
}
}
};
};
...
...
python/paddle/v2/fluid/tests/test_parallel_op.py
浏览文件 @
07cf302e
...
@@ -15,9 +15,6 @@ import unittest
...
@@ -15,9 +15,6 @@ import unittest
import
paddle.v2.fluid
as
fluid
import
paddle.v2.fluid
as
fluid
import
numpy
import
numpy
import
sys
# TODO(dzhwinter): get places op check need to be enhanced.
sys
.
exit
(
0
)
class
BaseParallelForTest
(
unittest
.
TestCase
):
class
BaseParallelForTest
(
unittest
.
TestCase
):
...
@@ -165,13 +162,13 @@ class ParallelOpTest(BaseParallelForTest):
...
@@ -165,13 +162,13 @@ class ParallelOpTest(BaseParallelForTest):
feed
=
{
feed
=
{
'img'
:
numpy
.
random
.
random
(
size
=
(
51
,
784
)).
astype
(
'float32'
)
'img'
:
numpy
.
random
.
random
(
size
=
(
51
,
784
)).
astype
(
'float32'
)
},
},
fetch
=
'fc1.w@GRAD'
)
fetch
=
[
'fc1.w@GRAD'
]
)
def
test_fc_with_tiny_data
(
self
):
def
test_fc_with_tiny_data
(
self
):
self
.
run_test
(
self
.
run_test
(
callback
=
ParallelOpTest
.
__network__
,
callback
=
ParallelOpTest
.
__network__
,
feed
=
{
'img'
:
numpy
.
random
.
random
(
size
=
(
1
,
784
)).
astype
(
'float32'
)},
feed
=
{
'img'
:
numpy
.
random
.
random
(
size
=
(
1
,
784
)).
astype
(
'float32'
)},
fetch
=
'fc1.w@GRAD'
)
fetch
=
[
'fc1.w@GRAD'
]
)
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录