Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
Paddle
提交
b0ad9c90
P
Paddle
项目概览
PaddlePaddle
/
Paddle
大约 2 年 前同步成功
通知
2325
Star
20933
Fork
5424
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1423
列表
看板
标记
里程碑
合并请求
543
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1,423
Issue
1,423
列表
看板
标记
里程碑
合并请求
543
合并请求
543
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
b0ad9c90
编写于
6月 28, 2017
作者:
C
caoying03
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
enable intializing memory state for lstmemory_group.
上级
633082ad
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
57 addition
and
42 deletion
+57
-42
python/paddle/trainer_config_helpers/layers.py
python/paddle/trainer_config_helpers/layers.py
+26
-25
python/paddle/trainer_config_helpers/networks.py
python/paddle/trainer_config_helpers/networks.py
+31
-17
未找到文件。
python/paddle/trainer_config_helpers/layers.py
浏览文件 @
b0ad9c90
...
@@ -1149,10 +1149,10 @@ def pooling_layer(input,
...
@@ -1149,10 +1149,10 @@ def pooling_layer(input,
@
layer_support
(
DROPOUT
)
@
layer_support
(
DROPOUT
)
def
lstmemory
(
input
,
def
lstmemory
(
input
,
name
=
None
,
name
=
None
,
size
=
None
,
reverse
=
False
,
reverse
=
False
,
act
=
None
,
act
=
None
,
gate_act
=
None
,
gate_act
=
None
,
size
=
None
,
state_act
=
None
,
state_act
=
None
,
bias_attr
=
None
,
bias_attr
=
None
,
param_attr
=
None
,
param_attr
=
None
,
...
@@ -1194,6 +1194,8 @@ def lstmemory(input,
...
@@ -1194,6 +1194,8 @@ def lstmemory(input,
:param name: The lstmemory layer name.
:param name: The lstmemory layer name.
:type name: basestring
:type name: basestring
:param size: DEPRECATED. size of the lstm cell
:type size: int
:param input: input layer name.
:param input: input layer name.
:type input: LayerOutput
:type input: LayerOutput
:param reverse: is sequence process reversed or not.
:param reverse: is sequence process reversed or not.
...
@@ -1220,15 +1222,15 @@ def lstmemory(input,
...
@@ -1220,15 +1222,15 @@ def lstmemory(input,
assert
state_act
.
support_hppl
assert
state_act
.
support_hppl
assert
act
.
support_hppl
assert
act
.
support_hppl
assert
input
.
size
is
not
None
and
input
.
size
%
4
==
0
assert
input
.
size
is
not
None
and
input
.
size
%
4
==
0
if
size
is
not
None
:
if
size
is
not
None
:
if
input
.
size
/
4
==
size
:
if
input
.
size
/
4
==
size
:
plog
=
logger
.
warning
plog
=
logger
.
warning
else
:
else
:
plog
=
logger
.
fatal
plog
=
logger
.
fatal
plog
(
"size of lstmemory layer: %s is automatically set to "
plog
(
"NOTE: The lstmemory layer[%s]'s size is set by previous input "
"size of input layer / 4. The parameter size passing to "
"layer. The lstm size should be equal with input layer size/4. The"
"this layer is ignored."
%
(
name
))
" size which is set explicitly will be ignored."
%
name
)
Layer
(
Layer
(
name
=
name
,
name
=
name
,
...
@@ -1255,11 +1257,11 @@ def lstmemory(input,
...
@@ -1255,11 +1257,11 @@ def lstmemory(input,
@
wrap_name_default
(
"gru"
)
@
wrap_name_default
(
"gru"
)
@
layer_support
(
DROPOUT
)
@
layer_support
(
DROPOUT
)
def
grumemory
(
input
,
def
grumemory
(
input
,
size
=
None
,
name
=
None
,
name
=
None
,
reverse
=
False
,
reverse
=
False
,
act
=
None
,
act
=
None
,
gate_act
=
None
,
gate_act
=
None
,
size
=
None
,
bias_attr
=
None
,
bias_attr
=
None
,
param_attr
=
None
,
param_attr
=
None
,
layer_attr
=
None
):
layer_attr
=
None
):
...
@@ -1318,6 +1320,8 @@ def grumemory(input,
...
@@ -1318,6 +1320,8 @@ def grumemory(input,
:type name: None|basestring
:type name: None|basestring
:param input: input layer.
:param input: input layer.
:type input: LayerOutput.
:type input: LayerOutput.
:param size: DEPRECATED. size of the gru cell
:type size: int
:param reverse: Whether sequence process is reversed or not.
:param reverse: Whether sequence process is reversed or not.
:type reverse: bool
:type reverse: bool
:param act: activation type, TanhActivation by default. This activation
:param act: activation type, TanhActivation by default. This activation
...
@@ -1334,9 +1338,6 @@ def grumemory(input,
...
@@ -1334,9 +1338,6 @@ def grumemory(input,
:type param_attr: ParameterAttribute|None|False
:type param_attr: ParameterAttribute|None|False
:param layer_attr: Extra Layer attribute
:param layer_attr: Extra Layer attribute
:type layer_attr: ExtraLayerAttribute|None
:type layer_attr: ExtraLayerAttribute|None
:param size: Stub parameter of size, but actually not used. If set this size
will get a warning.
:type size: None
:return: LayerOutput object.
:return: LayerOutput object.
:rtype: LayerOutput
:rtype: LayerOutput
"""
"""
...
@@ -1348,9 +1349,9 @@ def grumemory(input,
...
@@ -1348,9 +1349,9 @@ def grumemory(input,
plog
=
logger
.
warning
plog
=
logger
.
warning
else
:
else
:
plog
=
logger
.
fatal
plog
=
logger
.
fatal
plog
(
"
NOTE: the gru memory layer's size is set by previous input layer,
"
plog
(
"
size of grumemory layer: %s is automatically set to
"
"
and should be input size / 3. Set size explicitly will be
"
"
size of input layer / 3. The parameter size passing to this
"
"
ignored."
)
"
layer is ignored."
%
(
name
)
)
Layer
(
Layer
(
name
=
name
,
name
=
name
,
...
@@ -2524,8 +2525,8 @@ def img_cmrnorm_layer(input,
...
@@ -2524,8 +2525,8 @@ def img_cmrnorm_layer(input,
@
wrap_bias_attr_default
()
@
wrap_bias_attr_default
()
@
wrap_param_attr_default
(
default_factory
=
lambda
_
:
ParamAttr
(
initial_mean
=
1.0
,
@
wrap_param_attr_default
(
initial_std
=
0.
))
default_factory
=
lambda
_
:
ParamAttr
(
initial_mean
=
1.0
,
initial_std
=
0.
))
@
wrap_act_default
(
act
=
ReluActivation
())
@
wrap_act_default
(
act
=
ReluActivation
())
@
wrap_name_default
(
"batch_norm"
)
@
wrap_name_default
(
"batch_norm"
)
@
layer_support
(
DROPOUT
)
@
layer_support
(
DROPOUT
)
...
@@ -3013,25 +3014,25 @@ def lstm_step_layer(input,
...
@@ -3013,25 +3014,25 @@ def lstm_step_layer(input,
bias_attr
=
None
,
bias_attr
=
None
,
layer_attr
=
None
):
layer_attr
=
None
):
"""
"""
LSTM Step Layer.
It used in recurrent_group. The lstm equations are shown
LSTM Step Layer.
This function is used only in recurrent_group.
as follow
.
The lstm equations are shown as follows
.
.. math::
.. math::
i_t & =
\\
sigma(W_{x
i}x_{t} + W_{hi}h_{t-1} + W_{c
i}c_{t-1} + b_i)
i_t & =
\\
sigma(W_{x
_i}x_{t} + W_{h_i}h_{t-1} + W_{c_
i}c_{t-1} + b_i)
f_t & =
\\
sigma(W_{x
f}x_{t} + W_{hf}h_{t-1} + W_{c
f}c_{t-1} + b_f)
f_t & =
\\
sigma(W_{x
_f}x_{t} + W_{h_f}h_{t-1} + W_{c_
f}c_{t-1} + b_f)
c_t & = f_tc_{t-1} + i_t tanh (W_{x
c}x_t+W_{h
c}h_{t-1} + b_c)
c_t & = f_tc_{t-1} + i_t tanh (W_{x
_c}x_t+W_{h_
c}h_{t-1} + b_c)
o_t & =
\\
sigma(W_{x
o}x_{t} + W_{ho}h_{t-1} + W_{c
o}c_t + b_o)
o_t & =
\\
sigma(W_{x
_o}x_{t} + W_{h_o}h_{t-1} + W_{c_
o}c_t + b_o)
h_t & = o_t tanh(c_t)
h_t & = o_t tanh(c_t)
The input of lstm step is :math:`Wx_t + Wh_{t-1}`, and user should use
The input of lstm step is :math:`Wx_t + Wh_{t-1}`, and user should use
:code:`mixed_layer` and :code:`full_matrix_projection` to calculate these
:code:`mixed_layer` and :code:`full_matrix_projection` to calculate these
input vector.
input vector
s
.
The state of lstm step is :math:`c_{t-1}`. And lstm step layer will do
The state of lstm step is :math:`c_{t-1}`. And lstm step layer will do
...
@@ -3042,14 +3043,14 @@ def lstm_step_layer(input,
...
@@ -3042,14 +3043,14 @@ def lstm_step_layer(input,
...
...
This layer
contain
s two outputs. Default output is :math:`h_t`. The other
This layer
ha
s two outputs. Default output is :math:`h_t`. The other
output is :math:`o_t`, wh
ich
name is 'state' and can use
output is :math:`o_t`, wh
ose
name is 'state' and can use
:code:`get_output_layer` to extract this output.
:code:`get_output_layer` to extract this output.
:param name: Layer's name.
:param name: Layer's name.
:type name: basestring
:type name: basestring
:param size: Layer's size. NOTE: lstm layer's size, should be equal
as
:param size: Layer's size. NOTE: lstm layer's size, should be equal
to
:code:`input.size/4`, and should be equal
as
:code:`input.size/4`, and should be equal
to
:code:`state.size`.
:code:`state.size`.
:type size: int
:type size: int
:param input: input layer. :math:`Wx_t + Wh_{t-1}`
:param input: input layer. :math:`Wx_t + Wh_{t-1}`
...
...
python/paddle/trainer_config_helpers/networks.py
浏览文件 @
b0ad9c90
...
@@ -614,6 +614,7 @@ def simple_lstm(input,
...
@@ -614,6 +614,7 @@ def simple_lstm(input,
@
wrap_name_default
(
'lstm_unit'
)
@
wrap_name_default
(
'lstm_unit'
)
def
lstmemory_unit
(
input
,
def
lstmemory_unit
(
input
,
memory_boot
=
None
,
name
=
None
,
name
=
None
,
size
=
None
,
size
=
None
,
param_attr
=
None
,
param_attr
=
None
,
...
@@ -626,9 +627,9 @@ def lstmemory_unit(input,
...
@@ -626,9 +627,9 @@ def lstmemory_unit(input,
lstm_layer_attr
=
None
,
lstm_layer_attr
=
None
,
get_output_layer_attr
=
None
):
get_output_layer_attr
=
None
):
"""
"""
Define calculations that a LSTM unit performs
in
a single time step.
Define calculations that a LSTM unit performs
during
a single time step.
This function itself is not a recurrent layer, so
that
it can not be
This function itself is not a recurrent layer, so it can not be
directly
applied to sequence input
. This function is always used in
directly
used to process sequence inputs
. This function is always used in
recurrent_group (see layers.py for more details) to implement attention
recurrent_group (see layers.py for more details) to implement attention
mechanism.
mechanism.
...
@@ -638,13 +639,13 @@ def lstmemory_unit(input,
...
@@ -638,13 +639,13 @@ def lstmemory_unit(input,
.. math::
.. math::
i_t & =
\\
sigma(W_{x
i}x_{t} + W_{hi}h_{t-1} + W_{c
i}c_{t-1} + b_i)
i_t & =
\\
sigma(W_{x
_i}x_{t} + W_{h_i}h_{t-1} + W_{c_
i}c_{t-1} + b_i)
f_t & =
\\
sigma(W_{x
f}x_{t} + W_{hf}h_{t-1} + W_{c
f}c_{t-1} + b_f)
f_t & =
\\
sigma(W_{x
_f}x_{t} + W_{h_f}h_{t-1} + W_{c_
f}c_{t-1} + b_f)
c_t & = f_tc_{t-1} + i_t tanh (W_{x
c}x_t+W_{h
c}h_{t-1} + b_c)
c_t & = f_tc_{t-1} + i_t tanh (W_{x
_c}x_t+W_{h_
c}h_{t-1} + b_c)
o_t & =
\\
sigma(W_{x
o}x_{t} + W_{ho}h_{t-1} + W_{c
o}c_t + b_o)
o_t & =
\\
sigma(W_{x
_o}x_{t} + W_{h_o}h_{t-1} + W_{c_
o}c_t + b_o)
h_t & = o_t tanh(c_t)
h_t & = o_t tanh(c_t)
...
@@ -661,6 +662,8 @@ def lstmemory_unit(input,
...
@@ -661,6 +662,8 @@ def lstmemory_unit(input,
:param input: input layer name.
:param input: input layer name.
:type input: LayerOutput
:type input: LayerOutput
:param memory_boot: the initialization state of the LSTM cell.
:type memory_boot: LayerOutput | None
:param name: lstmemory unit name.
:param name: lstmemory unit name.
:type name: basestring
:type name: basestring
:param size: lstmemory unit size.
:param size: lstmemory unit size.
...
@@ -692,7 +695,8 @@ def lstmemory_unit(input,
...
@@ -692,7 +695,8 @@ def lstmemory_unit(input,
assert
input
.
size
%
4
==
0
assert
input
.
size
%
4
==
0
size
=
input
.
size
/
4
size
=
input
.
size
/
4
out_mem
=
memory
(
name
=
name
,
size
=
size
)
out_mem
=
memory
(
name
=
name
,
size
=
size
)
state_mem
=
memory
(
name
=
"%s_state"
%
name
,
size
=
size
)
state_mem
=
memory
(
name
=
"%s_state"
%
name
,
size
=
size
,
boot_layer
=
memory_boot
)
with
mixed_layer
(
with
mixed_layer
(
name
=
"%s_input_recurrent"
%
name
,
name
=
"%s_input_recurrent"
%
name
,
...
@@ -726,6 +730,7 @@ def lstmemory_unit(input,
...
@@ -726,6 +730,7 @@ def lstmemory_unit(input,
def
lstmemory_group
(
input
,
def
lstmemory_group
(
input
,
size
=
None
,
size
=
None
,
name
=
None
,
name
=
None
,
memory_boot
=
None
,
reverse
=
False
,
reverse
=
False
,
param_attr
=
None
,
param_attr
=
None
,
act
=
None
,
act
=
None
,
...
@@ -737,7 +742,7 @@ def lstmemory_group(input,
...
@@ -737,7 +742,7 @@ def lstmemory_group(input,
lstm_layer_attr
=
None
,
lstm_layer_attr
=
None
,
get_output_layer_attr
=
None
):
get_output_layer_attr
=
None
):
"""
"""
lstm_group is a recurrent
layer
group version of Long Short Term Memory. It
lstm_group is a recurrent
_
group version of Long Short Term Memory. It
does exactly the same calculation as the lstmemory layer (see lstmemory in
does exactly the same calculation as the lstmemory layer (see lstmemory in
layers.py for the maths) does. A promising benefit is that LSTM memory
layers.py for the maths) does. A promising benefit is that LSTM memory
cell states, or hidden states in every time step are accessible to the
cell states, or hidden states in every time step are accessible to the
...
@@ -748,8 +753,8 @@ def lstmemory_group(input,
...
@@ -748,8 +753,8 @@ def lstmemory_group(input,
NOTE: In PaddlePaddle's implementation, the following input-to-hidden
NOTE: In PaddlePaddle's implementation, the following input-to-hidden
multiplications:
multiplications:
:math:`W_{x
i}x_{t}` , :math:`W_{x
f}x_{t}`,
:math:`W_{x
_i}x_{t}` , :math:`W_{x_
f}x_{t}`,
:math:`W_{x
c}x_t`, :math:`W_{x
o}x_{t}` are not done in lstmemory_unit to
:math:`W_{x
_c}x_t`, :math:`W_{x_
o}x_{t}` are not done in lstmemory_unit to
speed up the calculations. Consequently, an additional mixed_layer with
speed up the calculations. Consequently, an additional mixed_layer with
full_matrix_projection must be included before lstmemory_unit is called.
full_matrix_projection must be included before lstmemory_unit is called.
...
@@ -765,8 +770,10 @@ def lstmemory_group(input,
...
@@ -765,8 +770,10 @@ def lstmemory_group(input,
:param input: input layer name.
:param input: input layer name.
:type input: LayerOutput
:type input: LayerOutput
:param name:
lstmemory group name
.
:param name:
name of the lstmemory group
.
:type name: basestring
:type name: basestring
:param memory_boot: the initialization state of LSTM cell.
:type memory_boot: LayerOutput | None
:param size: lstmemory group size.
:param size: lstmemory group size.
:type size: int
:type size: int
:param reverse: is lstm reversed
:param reverse: is lstm reversed
...
@@ -798,6 +805,7 @@ def lstmemory_group(input,
...
@@ -798,6 +805,7 @@ def lstmemory_group(input,
def
__lstm_step__
(
ipt
):
def
__lstm_step__
(
ipt
):
return
lstmemory_unit
(
return
lstmemory_unit
(
input
=
ipt
,
input
=
ipt
,
memory_boot
=
memory_boot
,
name
=
name
,
name
=
name
,
size
=
size
,
size
=
size
,
mixed_bias_attr
=
mixed_bias_attr
,
mixed_bias_attr
=
mixed_bias_attr
,
...
@@ -819,6 +827,7 @@ def lstmemory_group(input,
...
@@ -819,6 +827,7 @@ def lstmemory_group(input,
@
wrap_name_default
(
'gru_unit'
)
@
wrap_name_default
(
'gru_unit'
)
def
gru_unit
(
input
,
def
gru_unit
(
input
,
memory_boot
=
None
,
size
=
None
,
size
=
None
,
name
=
None
,
name
=
None
,
gru_bias_attr
=
None
,
gru_bias_attr
=
None
,
...
@@ -829,8 +838,8 @@ def gru_unit(input,
...
@@ -829,8 +838,8 @@ def gru_unit(input,
naive
=
False
):
naive
=
False
):
"""
"""
Define calculations that a gated recurrent unit performs in a single time
Define calculations that a gated recurrent unit performs in a single time
step. This function itself is not a recurrent layer, so
that
it can not be
step. This function itself is not a recurrent layer, so it can not be
directly
applied to sequence input. This function is almost
always used in
directly
used to process sequence inputs. This function is
always used in
the recurrent_group (see layers.py for more details) to implement attention
the recurrent_group (see layers.py for more details) to implement attention
mechanism.
mechanism.
...
@@ -838,6 +847,8 @@ def gru_unit(input,
...
@@ -838,6 +847,8 @@ def gru_unit(input,
:param input: input layer name.
:param input: input layer name.
:type input: LayerOutput
:type input: LayerOutput
:param memory_boot: the initialization state of the LSTM cell.
:type memory_boot: LayerOutput | None
:param name: name of the gru group.
:param name: name of the gru group.
:type name: basestring
:type name: basestring
:param size: hidden size of the gru.
:param size: hidden size of the gru.
...
@@ -856,7 +867,7 @@ def gru_unit(input,
...
@@ -856,7 +867,7 @@ def gru_unit(input,
if
size
is
None
:
if
size
is
None
:
size
=
input
.
size
/
3
size
=
input
.
size
/
3
out_mem
=
memory
(
name
=
name
,
size
=
size
)
out_mem
=
memory
(
name
=
name
,
size
=
size
,
boot_layer
=
memory_boot
)
if
naive
:
if
naive
:
__step__
=
gru_step_naive_layer
__step__
=
gru_step_naive_layer
...
@@ -878,6 +889,7 @@ def gru_unit(input,
...
@@ -878,6 +889,7 @@ def gru_unit(input,
@
wrap_name_default
(
'gru_group'
)
@
wrap_name_default
(
'gru_group'
)
def
gru_group
(
input
,
def
gru_group
(
input
,
memory_boot
=
None
,
size
=
None
,
size
=
None
,
name
=
None
,
name
=
None
,
reverse
=
False
,
reverse
=
False
,
...
@@ -888,7 +900,7 @@ def gru_group(input,
...
@@ -888,7 +900,7 @@ def gru_group(input,
gru_layer_attr
=
None
,
gru_layer_attr
=
None
,
naive
=
False
):
naive
=
False
):
"""
"""
gru_group is a recurrent
layer
group version of Gated Recurrent Unit. It
gru_group is a recurrent
_
group version of Gated Recurrent Unit. It
does exactly the same calculation as the grumemory layer does. A promising
does exactly the same calculation as the grumemory layer does. A promising
benefit is that gru hidden states are accessible to the user. This is
benefit is that gru hidden states are accessible to the user. This is
especially useful in attention model. If you do not need to access
especially useful in attention model. If you do not need to access
...
@@ -908,6 +920,8 @@ def gru_group(input,
...
@@ -908,6 +920,8 @@ def gru_group(input,
:param input: input layer name.
:param input: input layer name.
:type input: LayerOutput
:type input: LayerOutput
:param memory_boot: the initialization state of the LSTM cell.
:type memory_boot: LayerOutput | None
:param name: name of the gru group.
:param name: name of the gru group.
:type name: basestring
:type name: basestring
:param size: hidden size of the gru.
:param size: hidden size of the gru.
...
@@ -929,6 +943,7 @@ def gru_group(input,
...
@@ -929,6 +943,7 @@ def gru_group(input,
def
__gru_step__
(
ipt
):
def
__gru_step__
(
ipt
):
return
gru_unit
(
return
gru_unit
(
input
=
ipt
,
input
=
ipt
,
memory_boot
=
memory_boot
,
name
=
name
,
name
=
name
,
size
=
size
,
size
=
size
,
gru_bias_attr
=
gru_bias_attr
,
gru_bias_attr
=
gru_bias_attr
,
...
@@ -1083,7 +1098,6 @@ def simple_gru2(input,
...
@@ -1083,7 +1098,6 @@ def simple_gru2(input,
return
grumemory
(
return
grumemory
(
name
=
name
,
name
=
name
,
size
=
size
,
input
=
m
,
input
=
m
,
reverse
=
reverse
,
reverse
=
reverse
,
bias_attr
=
gru_bias_attr
,
bias_attr
=
gru_bias_attr
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录