Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleDetection
提交
db1bb822
P
PaddleDetection
项目概览
PaddlePaddle
/
PaddleDetection
大约 2 年 前同步成功
通知
708
Star
11112
Fork
2696
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
184
列表
看板
标记
里程碑
合并请求
40
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleDetection
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
184
Issue
184
列表
看板
标记
里程碑
合并请求
40
合并请求
40
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
db1bb822
编写于
10月 26, 2017
作者:
C
chengduoZH
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
follow comments
上级
8e3ecf5d
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
28 addition
and
31 deletion
+28
-31
paddle/operators/math/context_project.h
paddle/operators/math/context_project.h
+3
-6
paddle/operators/sequence_conv_op.cc
paddle/operators/sequence_conv_op.cc
+13
-13
paddle/operators/sequence_conv_op.h
paddle/operators/sequence_conv_op.h
+8
-8
python/paddle/v2/framework/tests/test_seq_conv.py
python/paddle/v2/framework/tests/test_seq_conv.py
+4
-4
未找到文件。
paddle/operators/math/context_project.h
浏览文件 @
db1bb822
...
@@ -34,18 +34,15 @@ using EigenMatrix = framework::EigenMatrix<T, MajorType, IndexType>;
...
@@ -34,18 +34,15 @@ using EigenMatrix = framework::EigenMatrix<T, MajorType, IndexType>;
* \param in Input data.
* \param in Input data.
* \param Shape The shape of Input data,
* \param Shape The shape of Input data,
* [minibatch, number_of_input_features].
* [minibatch, input_hidden_size].
* \param type A float LoDTensor.
*
*
* \param padding_data Padding data.
* \param padding_data Padding data.
* \param Shape The shape of Padding data,
* \param Shape The shape of Padding data,
* [up_pad + down_pad, number_of_input_features].
* [up_pad + down_pad, input_hidden_size].
* \param type A float Tensor.
*
*
* \param col Col data.
* \param col Col data.
* \param Shape The shape of Col data,
* \param Shape The shape of Col data,
* [minibatch, context_length * number_of_input_features].
* [minibatch, context_length * input_hidden_size].
* \param type A float Tensor.
*
*
* For a mini-batch of 2 variable lengths sentences, containing 3, and 1
* For a mini-batch of 2 variable lengths sentences, containing 3, and 1
* time-steps:
* time-steps:
...
...
paddle/operators/sequence_conv_op.cc
浏览文件 @
db1bb822
...
@@ -30,9 +30,9 @@ class SequenceConvOp : public framework::OperatorWithKernel {
...
@@ -30,9 +30,9 @@ class SequenceConvOp : public framework::OperatorWithKernel {
PADDLE_ENFORCE
(
ctx
->
HasOutput
(
"Out"
),
PADDLE_ENFORCE
(
ctx
->
HasOutput
(
"Out"
),
"Output(Out) of SequenceConvOp should not be null."
);
"Output(Out) of SequenceConvOp should not be null."
);
int
context_length
=
ctx
->
Attrs
().
Get
<
int
>
(
"context
_l
ength"
);
int
context_length
=
ctx
->
Attrs
().
Get
<
int
>
(
"context
L
ength"
);
bool
padding_trainable
=
ctx
->
Attrs
().
Get
<
bool
>
(
"padding
_t
rainable"
);
bool
padding_trainable
=
ctx
->
Attrs
().
Get
<
bool
>
(
"padding
T
rainable"
);
int
context_start
=
ctx
->
Attrs
().
Get
<
int
>
(
"context
_s
tart"
);
int
context_start
=
ctx
->
Attrs
().
Get
<
int
>
(
"context
S
tart"
);
auto
in_dims
=
ctx
->
GetInputDim
(
"X"
);
auto
in_dims
=
ctx
->
GetInputDim
(
"X"
);
auto
filter_dims
=
ctx
->
GetInputDim
(
"Filter"
);
auto
filter_dims
=
ctx
->
GetInputDim
(
"Filter"
);
...
@@ -54,7 +54,7 @@ class SequenceConvOp : public framework::OperatorWithKernel {
...
@@ -54,7 +54,7 @@ class SequenceConvOp : public framework::OperatorWithKernel {
if
(
context_start
==
0
&&
context_length
==
1
)
{
if
(
context_start
==
0
&&
context_length
==
1
)
{
PADDLE_THROW
(
PADDLE_THROW
(
"If context_start is 0 and context_length is 1, padding
_t
rainable "
"If context_start is 0 and context_length is 1, padding
T
rainable "
"should be false."
);
"should be false."
);
}
}
PADDLE_ENFORCE
(
padding_dim
.
size
()
==
2
,
PADDLE_ENFORCE
(
padding_dim
.
size
()
==
2
,
...
@@ -81,7 +81,7 @@ class SequenceConvGradOp : public framework::OperatorWithKernel {
...
@@ -81,7 +81,7 @@ class SequenceConvGradOp : public framework::OperatorWithKernel {
"Gradient of output(Out) should not be null."
);
"Gradient of output(Out) should not be null."
);
PADDLE_ENFORCE
(
ctx
->
HasInput
(
"X"
),
"The input(X) should not be null."
);
PADDLE_ENFORCE
(
ctx
->
HasInput
(
"X"
),
"The input(X) should not be null."
);
if
(
ctx
->
Attrs
().
Get
<
bool
>
(
"padding
_t
rainable"
)
&&
if
(
ctx
->
Attrs
().
Get
<
bool
>
(
"padding
T
rainable"
)
&&
ctx
->
HasOutput
(
framework
::
GradVarName
(
"PaddingData"
)))
{
ctx
->
HasOutput
(
framework
::
GradVarName
(
"PaddingData"
)))
{
ctx
->
SetOutputDim
(
framework
::
GradVarName
(
"PaddingData"
),
ctx
->
SetOutputDim
(
framework
::
GradVarName
(
"PaddingData"
),
ctx
->
GetInputDim
(
"PaddingData"
));
ctx
->
GetInputDim
(
"PaddingData"
));
...
@@ -128,25 +128,25 @@ class SequenceConvOpMaker : public framework::OpProtoAndCheckerMaker {
...
@@ -128,25 +128,25 @@ class SequenceConvOpMaker : public framework::OpProtoAndCheckerMaker {
"this LoDTensor is a matrix with shape (T, D), where, T is the "
"this LoDTensor is a matrix with shape (T, D), where, T is the "
"total time steps in this mini-batch, D is the output feature size."
);
"total time steps in this mini-batch, D is the output feature size."
);
AddAttr
<
bool
>
(
"padding
_t
rainable"
,
AddAttr
<
bool
>
(
"padding
T
rainable"
,
"(bool, default false) the padding data of SequenceConvOp "
"(bool, default false) the padding data of SequenceConvOp "
"is trainable or not."
)
"is trainable or not."
)
.
SetDefault
(
false
);
.
SetDefault
(
false
);
AddAttr
<
int
>
(
"context
_l
ength"
,
AddAttr
<
int
>
(
"context
L
ength"
,
"(int, default 3) the context
_l
ength of SequenceConvOp is the "
"(int, default 3) the context
L
ength of SequenceConvOp is the "
"height of the convolution kernel."
)
"height of the convolution kernel."
)
.
SetDefault
(
3
)
.
SetDefault
(
3
)
.
GreaterThan
(
0
);
.
GreaterThan
(
0
);
AddAttr
<
int
>
(
"context
_s
tart"
,
AddAttr
<
int
>
(
"context
S
tart"
,
"(int, default 0) the context
_s
tart of SequenceConvOp "
"(int, default 0) the context
S
tart of SequenceConvOp "
"represents the beginning of the convolution of the number of "
"represents the beginning of the convolution of the number of "
"rows of sequence, which can be negative."
)
"rows of sequence, which can be negative."
)
.
SetDefault
(
0
);
.
SetDefault
(
0
);
AddAttr
<
int
>
(
"context
_s
tride"
,
AddAttr
<
int
>
(
"context
S
tride"
,
"(int, default 1) the context
_s
tride of SequenceConvOp "
"(int, default 1) the context
S
tride of SequenceConvOp "
"represents the step length of convolution. "
"represents the step length of convolution. "
"Currently, SequenceConvOp only supports"
"Currently, SequenceConvOp only supports"
"context
_s
tride=1."
)
"context
S
tride=1."
)
.
SetDefault
(
1
)
.
SetDefault
(
1
)
.
GreaterThan
(
0
);
.
GreaterThan
(
0
);
...
...
paddle/operators/sequence_conv_op.h
浏览文件 @
db1bb822
...
@@ -35,10 +35,10 @@ class SequenceConvKernel : public framework::OpKernel<T> {
...
@@ -35,10 +35,10 @@ class SequenceConvKernel : public framework::OpKernel<T> {
out
->
mutable_data
<
T
>
(
context
.
GetPlace
());
out
->
mutable_data
<
T
>
(
context
.
GetPlace
());
context
.
ShareLoD
(
"X"
,
"Out"
);
context
.
ShareLoD
(
"X"
,
"Out"
);
int
context_start
=
context
.
Attr
<
int
>
(
"context
_s
tart"
);
int
context_start
=
context
.
Attr
<
int
>
(
"context
S
tart"
);
int
context_length
=
context
.
Attr
<
int
>
(
"context
_l
ength"
);
int
context_length
=
context
.
Attr
<
int
>
(
"context
L
ength"
);
int
context_stride
=
context
.
Attr
<
int
>
(
"context
_s
tride"
);
int
context_stride
=
context
.
Attr
<
int
>
(
"context
S
tride"
);
bool
padding_trainable
=
context
.
Attr
<
bool
>
(
"padding
_t
rainable"
);
bool
padding_trainable
=
context
.
Attr
<
bool
>
(
"padding
T
rainable"
);
// InferShape by in_lod
// InferShape by in_lod
PADDLE_ENFORCE_EQ
(
in
->
lod
().
size
(),
1UL
,
PADDLE_ENFORCE_EQ
(
in
->
lod
().
size
(),
1UL
,
...
@@ -89,10 +89,10 @@ class SequenceConvGradKernel : public framework::OpKernel<T> {
...
@@ -89,10 +89,10 @@ class SequenceConvGradKernel : public framework::OpKernel<T> {
auto
*
in
=
context
.
Input
<
LoDTensor
>
(
"X"
);
auto
*
in
=
context
.
Input
<
LoDTensor
>
(
"X"
);
auto
*
filter
=
context
.
Input
<
Tensor
>
(
"Filter"
);
auto
*
filter
=
context
.
Input
<
Tensor
>
(
"Filter"
);
int
context_start
=
context
.
Attr
<
int
>
(
"context
_s
tart"
);
int
context_start
=
context
.
Attr
<
int
>
(
"context
S
tart"
);
int
context_length
=
context
.
Attr
<
int
>
(
"context
_l
ength"
);
int
context_length
=
context
.
Attr
<
int
>
(
"context
L
ength"
);
int
context_stride
=
context
.
Attr
<
int
>
(
"context
_s
tride"
);
int
context_stride
=
context
.
Attr
<
int
>
(
"context
S
tride"
);
bool
padding_trainable
=
context
.
Attr
<
bool
>
(
"padding
_t
rainable"
);
bool
padding_trainable
=
context
.
Attr
<
bool
>
(
"padding
T
rainable"
);
PADDLE_ENFORCE_EQ
(
in
->
lod
().
size
(),
1UL
,
PADDLE_ENFORCE_EQ
(
in
->
lod
().
size
(),
1UL
,
"Only support one level sequence now."
);
"Only support one level sequence now."
);
...
...
python/paddle/v2/framework/tests/test_seq_conv.py
浏览文件 @
db1bb822
...
@@ -45,10 +45,10 @@ class TestSeqProject(OpTest):
...
@@ -45,10 +45,10 @@ class TestSeqProject(OpTest):
self
.
inputs_val_no_f
=
[
'PaddingData'
,
'X'
]
self
.
inputs_val_no_f
=
[
'PaddingData'
,
'X'
]
self
.
attrs
=
{
self
.
attrs
=
{
'context
_s
tart'
:
self
.
context_start
,
'context
S
tart'
:
self
.
context_start
,
'context
_l
ength'
:
self
.
context_length
,
'context
L
ength'
:
self
.
context_length
,
'padding
_t
rainable'
:
self
.
padding_trainable
,
'padding
T
rainable'
:
self
.
padding_trainable
,
'context
_s
tride'
:
self
.
context_stride
'context
S
tride'
:
self
.
context_stride
}
}
out
=
np
.
zeros
(
out
=
np
.
zeros
(
(
self
.
input_size
[
0
],
self
.
output_represention
)).
astype
(
'float32'
)
(
self
.
input_size
[
0
],
self
.
output_represention
)).
astype
(
'float32'
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录