Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
03571282
P
Paddle
项目概览
BaiXuePrincess
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
03571282
编写于
4月 18, 2018
作者:
C
chengduoZH
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix VisitVariable
上级
fbb75c6b
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
13 addition
and
13 deletion
+13
-13
paddle/fluid/framework/details/broadcast_op_handle.h
paddle/fluid/framework/details/broadcast_op_handle.h
+5
-5
paddle/fluid/framework/details/variable_visitor.cc
paddle/fluid/framework/details/variable_visitor.cc
+8
-8
未找到文件。
paddle/fluid/framework/details/broadcast_op_handle.h
浏览文件 @
03571282
...
...
@@ -29,9 +29,7 @@ namespace framework {
namespace
details
{
struct
BroadcastOpHandle
:
public
OpHandleBase
{
const
std
::
vector
<
Scope
*>
&
local_scopes_
;
const
std
::
vector
<
platform
::
Place
>
&
places_
;
public:
BroadcastOpHandle
(
const
std
::
vector
<
Scope
*>
&
local_scopes
,
const
std
::
vector
<
platform
::
Place
>
&
places
);
...
...
@@ -41,10 +39,12 @@ struct BroadcastOpHandle : public OpHandleBase {
protected:
void
RunImpl
()
override
;
void
WaitInputVarGenerated
(
const
VarHandle
&
in_var
);
};
private:
const
std
::
vector
<
Scope
*>
&
local_scopes_
;
const
std
::
vector
<
platform
::
Place
>
&
places_
;
};
}
// namespace details
}
// namespace framework
}
// namespace paddle
paddle/fluid/framework/details/variable_visitor.cc
浏览文件 @
03571282
...
...
@@ -18,22 +18,22 @@ namespace paddle {
namespace
framework
{
namespace
details
{
template
<
typename
Func
>
static
void
VisitVariable
(
Variable
*
var
,
Func
func
)
{
static
void
VisitVariable
(
Variable
*
var
,
Func
*
func
)
{
if
(
var
->
IsType
<
LoDTensor
>
())
{
func
(
var
->
GetMutable
<
LoDTensor
>
());
(
*
func
)
(
var
->
GetMutable
<
LoDTensor
>
());
}
else
if
(
var
->
IsType
<
SelectedRows
>
())
{
func
(
var
->
GetMutable
<
SelectedRows
>
());
(
*
func
)
(
var
->
GetMutable
<
SelectedRows
>
());
}
else
{
PADDLE_THROW
(
"Not supported type %s"
,
var
->
Type
().
name
());
}
}
template
<
typename
Func
>
static
void
VisitVariable
(
const
Variable
&
var
,
Func
func
)
{
static
void
VisitVariable
(
const
Variable
&
var
,
Func
*
func
)
{
if
(
var
.
IsType
<
LoDTensor
>
())
{
func
(
var
.
Get
<
LoDTensor
>
());
(
*
func
)
(
var
.
Get
<
LoDTensor
>
());
}
else
if
(
var
.
IsType
<
SelectedRows
>
())
{
func
(
var
.
Get
<
SelectedRows
>
());
(
*
func
)
(
var
.
Get
<
SelectedRows
>
());
}
else
{
PADDLE_THROW
(
"Not supported type %s"
,
var
.
Type
().
name
());
}
...
...
@@ -56,7 +56,7 @@ struct TensorVisitor {
Tensor
&
VariableVisitor
::
GetMutableTensor
(
Variable
*
var
)
{
TensorVisitor
vistor
;
VisitVariable
(
var
,
vistor
);
VisitVariable
(
var
,
&
vistor
);
return
*
vistor
.
result_
;
}
...
...
@@ -85,7 +85,7 @@ struct ShareDimsAndLoDVisitor {
void
VariableVisitor
::
ShareDimsAndLoD
(
const
Variable
&
src
,
Variable
*
trg
)
{
ShareDimsAndLoDVisitor
visitor
{
trg
};
VisitVariable
(
src
,
visitor
);
VisitVariable
(
src
,
&
visitor
);
}
}
// namespace details
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录