Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
47043fe1
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看板
提交
47043fe1
编写于
2月 20, 2017
作者:
Q
qiaolongfei
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add type to datalayer
上级
cafb075e
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
36 addition
and
5 deletion
+36
-5
demo/mnist/api_train.py
demo/mnist/api_train.py
+2
-2
python/paddle/v2/layer.py
python/paddle/v2/layer.py
+34
-3
未找到文件。
demo/mnist/api_train.py
浏览文件 @
47043fe1
...
@@ -71,8 +71,8 @@ def main():
...
@@ -71,8 +71,8 @@ def main():
assert
isinstance
(
updater
,
api
.
ParameterUpdater
)
assert
isinstance
(
updater
,
api
.
ParameterUpdater
)
# define network
# define network
images
=
paddle_v2
.
layer
.
data
(
name
=
'pixel'
,
size
=
784
)
images
=
paddle_v2
.
layer
.
data
(
name
=
'pixel'
,
type
=
dp
.
dense_vector
(
784
)
)
label
=
paddle_v2
.
layer
.
data
(
name
=
'label'
,
size
=
10
)
label
=
paddle_v2
.
layer
.
data
(
name
=
'label'
,
type
=
dp
.
integer_value
(
10
)
)
hidden1
=
paddle_v2
.
layer
.
fc
(
input
=
images
,
size
=
200
)
hidden1
=
paddle_v2
.
layer
.
fc
(
input
=
images
,
size
=
200
)
hidden2
=
paddle_v2
.
layer
.
fc
(
input
=
hidden1
,
size
=
200
)
hidden2
=
paddle_v2
.
layer
.
fc
(
input
=
hidden1
,
size
=
200
)
inference
=
paddle_v2
.
layer
.
fc
(
input
=
hidden2
,
inference
=
paddle_v2
.
layer
.
fc
(
input
=
hidden2
,
...
...
python/paddle/v2/layer.py
浏览文件 @
47043fe1
...
@@ -67,6 +67,7 @@ paddle.v2.parameters.create, no longer exposed to users.
...
@@ -67,6 +67,7 @@ paddle.v2.parameters.create, no longer exposed to users.
"""
"""
import
paddle.trainer_config_helpers
as
conf_helps
import
paddle.trainer_config_helpers
as
conf_helps
import
paddle.trainer.PyDataProvider2
as
dp
from
paddle.trainer_config_helpers.config_parser_utils
import
\
from
paddle.trainer_config_helpers.config_parser_utils
import
\
parse_network_config
as
__parse__
parse_network_config
as
__parse__
from
paddle.trainer_config_helpers.default_decorators
import
wrap_name_default
from
paddle.trainer_config_helpers.default_decorators
import
wrap_name_default
...
@@ -157,7 +158,37 @@ def __convert_to_v2__(method_name, name_prefix, parent_names):
...
@@ -157,7 +158,37 @@ def __convert_to_v2__(method_name, name_prefix, parent_names):
return
V2LayerImpl
return
V2LayerImpl
data
=
__convert_to_v2__
(
'data_layer'
,
None
,
[])
"""
Some layer may need some special config, and can not use __convert_to_v2__ to convert.
So we also need to implement some special LayerV2.
"""
class
DataLayerV2
(
Layer
):
def
__init__
(
self
,
name
,
type
,
**
kwargs
):
self
.
__method_name__
=
'data_layer'
assert
isinstance
(
type
,
dp
.
InputType
)
# get data_size from type.dim
args
=
dict
()
for
key
in
kwargs
:
args
[
key
]
=
kwargs
[
key
]
args
[
'size'
]
=
type
.
dim
self
.
__args__
=
args
super
(
DataLayerV2
,
self
).
__init__
(
name
=
name
,
parent_layers
=
dict
())
def
to_proto_impl
(
self
,
**
kwargs
):
args
=
dict
()
for
each
in
kwargs
:
args
[
each
]
=
kwargs
[
each
]
for
each
in
self
.
__args__
:
args
[
each
]
=
self
.
__args__
[
each
]
return
getattr
(
conf_helps
,
self
.
__method_name__
)(
name
=
self
.
name
,
**
args
)
data
=
DataLayerV2
fc
=
__convert_to_v2__
(
'fc_layer'
,
name_prefix
=
'fc'
,
parent_names
=
[
'input'
])
fc
=
__convert_to_v2__
(
'fc_layer'
,
name_prefix
=
'fc'
,
parent_names
=
[
'input'
])
max_id
=
__convert_to_v2__
(
max_id
=
__convert_to_v2__
(
'maxid_layer'
,
name_prefix
=
'maxid_layer'
,
parent_names
=
[
'input'
])
'maxid_layer'
,
name_prefix
=
'maxid_layer'
,
parent_names
=
[
'input'
])
...
@@ -171,8 +202,8 @@ cross_entropy_cost = __convert_to_v2__(
...
@@ -171,8 +202,8 @@ cross_entropy_cost = __convert_to_v2__(
parent_names
=
[
'input'
,
'label'
])
parent_names
=
[
'input'
,
'label'
])
if
__name__
==
'__main__'
:
if
__name__
==
'__main__'
:
pixel
=
data
(
name
=
'pixel'
,
size
=
784
)
pixel
=
data
(
name
=
'pixel'
,
type
=
dp
.
dense_vector
(
784
)
)
label
=
data
(
name
=
'label'
,
size
=
10
)
label
=
data
(
name
=
'label'
,
type
=
dp
.
integer_value
(
10
)
)
hidden
=
fc
(
input
=
pixel
,
size
=
100
,
act
=
conf_helps
.
SigmoidActivation
())
hidden
=
fc
(
input
=
pixel
,
size
=
100
,
act
=
conf_helps
.
SigmoidActivation
())
inference
=
fc
(
input
=
hidden
,
size
=
10
,
act
=
conf_helps
.
SoftmaxActivation
())
inference
=
fc
(
input
=
hidden
,
size
=
10
,
act
=
conf_helps
.
SoftmaxActivation
())
maxid
=
max_id
(
input
=
inference
)
maxid
=
max_id
(
input
=
inference
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录