Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Crayon鑫
Paddle
提交
7d33447d
P
Paddle
项目概览
Crayon鑫
/
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看板
提交
7d33447d
编写于
9月 21, 2017
作者:
F
fengjiayi
提交者:
GitHub
9月 21, 2017
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #4276 from Canpio/add_program_proto
Add `BlockDesc` and `ProgramDesc` to framework.proto
上级
03651b04
a77af98b
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
37 addition
and
8 deletion
+37
-8
paddle/framework/attribute.cc
paddle/framework/attribute.cc
+23
-7
paddle/framework/attribute.h
paddle/framework/attribute.h
+3
-1
paddle/framework/framework.proto
paddle/framework/framework.proto
+11
-0
未找到文件。
paddle/framework/attribute.cc
浏览文件 @
7d33447d
...
@@ -19,6 +19,15 @@ limitations under the License. */
...
@@ -19,6 +19,15 @@ limitations under the License. */
namespace
paddle
{
namespace
paddle
{
namespace
framework
{
namespace
framework
{
static
ProgramDesc
*
g_program_desc
=
nullptr
;
ProgramDesc
&
GetProgramDesc
()
{
if
(
g_program_desc
==
nullptr
)
{
g_program_desc
=
new
ProgramDesc
();
}
return
*
g_program_desc
;
}
template
<
>
template
<
>
AttrType
AttrTypeID
<
int
>
()
{
AttrType
AttrTypeID
<
int
>
()
{
return
INT
;
return
INT
;
...
@@ -47,40 +56,44 @@ template <>
...
@@ -47,40 +56,44 @@ template <>
AttrType
AttrTypeID
<
std
::
vector
<
std
::
pair
<
int
,
int
>>>
()
{
AttrType
AttrTypeID
<
std
::
vector
<
std
::
pair
<
int
,
int
>>>
()
{
return
INT_PAIRS
;
return
INT_PAIRS
;
}
}
template
<
>
AttrType
AttrTypeID
<
BlockDesc
>
()
{
return
BLOCK
;
}
Attribute
GetAttrValue
(
const
OpDesc
::
Attr
&
attr_desc
)
{
Attribute
GetAttrValue
(
const
OpDesc
::
Attr
&
attr_desc
)
{
switch
(
attr_desc
.
type
())
{
switch
(
attr_desc
.
type
())
{
case
paddle
::
framework
::
AttrType
::
INT
:
{
case
framework
::
AttrType
::
INT
:
{
return
attr_desc
.
i
();
return
attr_desc
.
i
();
}
}
case
paddle
::
framework
::
AttrType
::
FLOAT
:
{
case
framework
::
AttrType
::
FLOAT
:
{
return
attr_desc
.
f
();
return
attr_desc
.
f
();
}
}
case
paddle
::
framework
::
AttrType
::
STRING
:
{
case
framework
::
AttrType
::
STRING
:
{
return
attr_desc
.
s
();
return
attr_desc
.
s
();
}
}
case
paddle
::
framework
::
AttrType
::
INTS
:
{
case
framework
::
AttrType
::
INTS
:
{
std
::
vector
<
int
>
val
(
attr_desc
.
ints_size
());
std
::
vector
<
int
>
val
(
attr_desc
.
ints_size
());
for
(
int
i
=
0
;
i
<
attr_desc
.
ints_size
();
++
i
)
{
for
(
int
i
=
0
;
i
<
attr_desc
.
ints_size
();
++
i
)
{
val
[
i
]
=
attr_desc
.
ints
(
i
);
val
[
i
]
=
attr_desc
.
ints
(
i
);
}
}
return
val
;
return
val
;
}
}
case
paddle
::
framework
::
AttrType
::
FLOATS
:
{
case
framework
::
AttrType
::
FLOATS
:
{
std
::
vector
<
float
>
val
(
attr_desc
.
floats_size
());
std
::
vector
<
float
>
val
(
attr_desc
.
floats_size
());
for
(
int
i
=
0
;
i
<
attr_desc
.
floats_size
();
++
i
)
{
for
(
int
i
=
0
;
i
<
attr_desc
.
floats_size
();
++
i
)
{
val
[
i
]
=
attr_desc
.
floats
(
i
);
val
[
i
]
=
attr_desc
.
floats
(
i
);
}
}
return
val
;
return
val
;
}
}
case
paddle
::
framework
::
AttrType
::
STRINGS
:
{
case
framework
::
AttrType
::
STRINGS
:
{
std
::
vector
<
std
::
string
>
val
(
attr_desc
.
strings_size
());
std
::
vector
<
std
::
string
>
val
(
attr_desc
.
strings_size
());
for
(
int
i
=
0
;
i
<
attr_desc
.
strings_size
();
++
i
)
{
for
(
int
i
=
0
;
i
<
attr_desc
.
strings_size
();
++
i
)
{
val
[
i
]
=
attr_desc
.
strings
(
i
);
val
[
i
]
=
attr_desc
.
strings
(
i
);
}
}
return
val
;
return
val
;
}
}
case
paddle
::
framework
::
AttrType
::
INT_PAIRS
:
{
case
framework
::
AttrType
::
INT_PAIRS
:
{
std
::
vector
<
std
::
pair
<
int
,
int
>>
val
(
attr_desc
.
int_pairs_size
());
std
::
vector
<
std
::
pair
<
int
,
int
>>
val
(
attr_desc
.
int_pairs_size
());
for
(
int
i
=
0
;
i
<
attr_desc
.
int_pairs_size
();
++
i
)
{
for
(
int
i
=
0
;
i
<
attr_desc
.
int_pairs_size
();
++
i
)
{
val
[
i
].
first
=
attr_desc
.
int_pairs
(
i
).
first
();
val
[
i
].
first
=
attr_desc
.
int_pairs
(
i
).
first
();
...
@@ -88,6 +101,9 @@ Attribute GetAttrValue(const OpDesc::Attr& attr_desc) {
...
@@ -88,6 +101,9 @@ Attribute GetAttrValue(const OpDesc::Attr& attr_desc) {
}
}
return
val
;
return
val
;
}
}
case
framework
::
AttrType
::
BLOCK
:
{
return
GetProgramDesc
().
mutable_blocks
(
attr_desc
.
block_idx
());
}
}
}
PADDLE_ENFORCE
(
false
,
"Unknown OpDesc::AttrDesc::type !"
);
PADDLE_ENFORCE
(
false
,
"Unknown OpDesc::AttrDesc::type !"
);
return
boost
::
blank
();
return
boost
::
blank
();
...
...
paddle/framework/attribute.h
浏览文件 @
7d33447d
...
@@ -29,11 +29,13 @@ namespace framework {
...
@@ -29,11 +29,13 @@ namespace framework {
typedef
boost
::
variant
<
boost
::
blank
,
int
,
float
,
std
::
string
,
std
::
vector
<
int
>
,
typedef
boost
::
variant
<
boost
::
blank
,
int
,
float
,
std
::
string
,
std
::
vector
<
int
>
,
std
::
vector
<
float
>
,
std
::
vector
<
std
::
string
>
,
std
::
vector
<
float
>
,
std
::
vector
<
std
::
string
>
,
std
::
vector
<
std
::
pair
<
int
,
int
>>>
std
::
vector
<
std
::
pair
<
int
,
int
>>
,
BlockDesc
*
>
Attribute
;
Attribute
;
typedef
std
::
unordered_map
<
std
::
string
,
Attribute
>
AttributeMap
;
typedef
std
::
unordered_map
<
std
::
string
,
Attribute
>
AttributeMap
;
ProgramDesc
&
GetProgramDesc
();
template
<
typename
T
>
template
<
typename
T
>
AttrType
AttrTypeID
();
AttrType
AttrTypeID
();
...
...
paddle/framework/framework.proto
浏览文件 @
7d33447d
...
@@ -23,6 +23,7 @@ enum AttrType {
...
@@ -23,6 +23,7 @@ enum AttrType {
FLOATS
=
4
;
FLOATS
=
4
;
STRINGS
=
5
;
STRINGS
=
5
;
INT_PAIRS
=
6
;
INT_PAIRS
=
6
;
BLOCK
=
7
;
}
}
message
IntPair
{
message
IntPair
{
...
@@ -44,6 +45,7 @@ message OpDesc {
...
@@ -44,6 +45,7 @@ message OpDesc {
repeated
float
floats
=
7
;
repeated
float
floats
=
7
;
repeated
string
strings
=
8
;
repeated
string
strings
=
8
;
repeated
IntPair
int_pairs
=
9
;
repeated
IntPair
int_pairs
=
9
;
optional
int32
block_idx
=
10
;
};
};
message
Var
{
message
Var
{
...
@@ -108,3 +110,12 @@ message VarDesc {
...
@@ -108,3 +110,12 @@ message VarDesc {
required
string
name
=
1
;
required
string
name
=
1
;
optional
LoDTensorDesc
lod_tensor
=
2
;
optional
LoDTensorDesc
lod_tensor
=
2
;
}
}
message
BlockDesc
{
required
int32
idx
=
1
;
required
int32
parent_idx
=
2
;
repeated
VarDesc
vars
=
3
;
repeated
OpDesc
ops
=
4
;
}
message
ProgramDesc
{
repeated
BlockDesc
blocks
=
1
;
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录