Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
e9d30991
P
Paddle
项目概览
机器未来
/
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看板
未验证
提交
e9d30991
编写于
2月 12, 2018
作者:
Q
Qiao Longfei
提交者:
GitHub
2月 12, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #8357 from jacquesqiao/override-compare-op-in-python
override comparison operators in Python for Variable
上级
cb4eacb1
593bec2c
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
97 addition
and
5 deletion
+97
-5
paddle/fluid/operators/compare_op.cc
paddle/fluid/operators/compare_op.cc
+2
-0
paddle/fluid/operators/compare_op.cu
paddle/fluid/operators/compare_op.cu
+1
-0
paddle/fluid/operators/compare_op.h
paddle/fluid/operators/compare_op.h
+8
-0
python/paddle/v2/fluid/layers/math_op_patch.py
python/paddle/v2/fluid/layers/math_op_patch.py
+6
-1
python/paddle/v2/fluid/learning_rate_decay.py
python/paddle/v2/fluid/learning_rate_decay.py
+2
-2
python/paddle/v2/fluid/tests/test_layers.py
python/paddle/v2/fluid/tests/test_layers.py
+2
-2
python/paddle/v2/fluid/tests/test_python_operator_overriding.py
.../paddle/v2/fluid/tests/test_python_operator_overriding.py
+76
-0
未找到文件。
paddle/fluid/operators/compare_op.cc
浏览文件 @
e9d30991
...
@@ -102,3 +102,5 @@ REGISTER_LOGICAL_OP(less_equal, "Out = X <= Y");
...
@@ -102,3 +102,5 @@ REGISTER_LOGICAL_OP(less_equal, "Out = X <= Y");
REGISTER_LOGICAL_KERNEL
(
less_equal
,
CPU
,
paddle
::
operators
::
LessEqualFunctor
);
REGISTER_LOGICAL_KERNEL
(
less_equal
,
CPU
,
paddle
::
operators
::
LessEqualFunctor
);
REGISTER_LOGICAL_OP
(
equal
,
"Out = X == Y"
);
REGISTER_LOGICAL_OP
(
equal
,
"Out = X == Y"
);
REGISTER_LOGICAL_KERNEL
(
equal
,
CPU
,
paddle
::
operators
::
EqualFunctor
);
REGISTER_LOGICAL_KERNEL
(
equal
,
CPU
,
paddle
::
operators
::
EqualFunctor
);
REGISTER_LOGICAL_OP
(
not_equal
,
"Out = X != Y"
);
REGISTER_LOGICAL_KERNEL
(
not_equal
,
CPU
,
paddle
::
operators
::
NotEqualFunctor
);
paddle/fluid/operators/compare_op.cu
浏览文件 @
e9d30991
...
@@ -17,3 +17,4 @@ limitations under the License. */
...
@@ -17,3 +17,4 @@ limitations under the License. */
REGISTER_LOGICAL_KERNEL
(
less_than
,
CUDA
,
paddle
::
operators
::
LessThanFunctor
);
REGISTER_LOGICAL_KERNEL
(
less_than
,
CUDA
,
paddle
::
operators
::
LessThanFunctor
);
REGISTER_LOGICAL_KERNEL
(
less_equal
,
CUDA
,
paddle
::
operators
::
LessEqualFunctor
);
REGISTER_LOGICAL_KERNEL
(
less_equal
,
CUDA
,
paddle
::
operators
::
LessEqualFunctor
);
REGISTER_LOGICAL_KERNEL
(
equal
,
CUDA
,
paddle
::
operators
::
EqualFunctor
);
REGISTER_LOGICAL_KERNEL
(
equal
,
CUDA
,
paddle
::
operators
::
EqualFunctor
);
REGISTER_LOGICAL_KERNEL
(
not_equal
,
CUDA
,
paddle
::
operators
::
NotEqualFunctor
);
paddle/fluid/operators/compare_op.h
浏览文件 @
e9d30991
...
@@ -48,6 +48,14 @@ struct EqualFunctor {
...
@@ -48,6 +48,14 @@ struct EqualFunctor {
}
}
};
};
template
<
typename
T
>
struct
NotEqualFunctor
{
using
ELEM_TYPE
=
T
;
HOSTDEVICE
bool
operator
()(
const
T
&
a
,
const
T
&
b
)
const
{
return
!
EqualFunctor
<
T
>
()(
a
,
b
);
}
};
template
<
typename
DeviceContext
,
typename
Functor
>
template
<
typename
DeviceContext
,
typename
Functor
>
class
CompareOpKernel
class
CompareOpKernel
:
public
framework
::
OpKernel
<
typename
Functor
::
ELEM_TYPE
>
{
:
public
framework
::
OpKernel
<
typename
Functor
::
ELEM_TYPE
>
{
...
...
python/paddle/v2/fluid/layers/math_op_patch.py
浏览文件 @
e9d30991
...
@@ -152,7 +152,12 @@ def monkey_patch_variable():
...
@@ -152,7 +152,12 @@ def monkey_patch_variable():
(
"__div__"
,
"elementwise_div"
,
False
),
(
"__div__"
,
"elementwise_div"
,
False
),
(
"__rdiv__"
,
"elementwise_div"
,
True
),
(
"__rdiv__"
,
"elementwise_div"
,
True
),
(
"__pow__"
,
"elementwise_pow"
,
False
),
(
"__pow__"
,
"elementwise_pow"
,
False
),
(
"__rpow__"
,
"elementwise_pow"
,
True
)):
(
"__rpow__"
,
"elementwise_pow"
,
True
),
# for logical compare
(
"__eq__"
,
"equal"
,
False
),
(
"__ne__"
,
"not_equal"
,
False
),
(
"__lt__"
,
"less_than"
,
False
),
(
"__le__"
,
"less_equal"
,
False
)):
setattr
(
Variable
,
method_name
,
setattr
(
Variable
,
method_name
,
_elemwise_method_creator_
(
method_name
,
op_type
,
reverse
))
_elemwise_method_creator_
(
method_name
,
op_type
,
reverse
))
...
...
python/paddle/v2/fluid/learning_rate_decay.py
浏览文件 @
e9d30991
...
@@ -179,7 +179,7 @@ def polynomial_decay(learning_rate,
...
@@ -179,7 +179,7 @@ def polynomial_decay(learning_rate,
shape
=
[
1
],
dtype
=
'float32'
,
value
=
1.0
)
shape
=
[
1
],
dtype
=
'float32'
,
value
=
1.0
)
with
layers
.
Switch
()
as
switch
:
with
layers
.
Switch
()
as
switch
:
with
switch
.
case
(
layers
.
equal
(
x
=
global_step
,
y
=
zero_var
)
):
with
switch
.
case
(
global_step
==
zero_var
):
layers
.
assign
(
input
=
one_var
,
output
=
div_res
)
layers
.
assign
(
input
=
one_var
,
output
=
div_res
)
decay_steps
=
decay_steps
*
div_res
decay_steps
=
decay_steps
*
div_res
else
:
else
:
...
@@ -229,7 +229,7 @@ def piecewise_decay(global_step, boundaries, values):
...
@@ -229,7 +229,7 @@ def piecewise_decay(global_step, boundaries, values):
shape
=
[
1
],
dtype
=
'float32'
,
value
=
float
(
boundaries
[
i
]))
shape
=
[
1
],
dtype
=
'float32'
,
value
=
float
(
boundaries
[
i
]))
value_var
=
layers
.
fill_constant
(
value_var
=
layers
.
fill_constant
(
shape
=
[
1
],
dtype
=
'float32'
,
value
=
float
(
values
[
i
]))
shape
=
[
1
],
dtype
=
'float32'
,
value
=
float
(
values
[
i
]))
with
switch
.
case
(
layers
.
less_than
(
global_step
,
boundary_val
)
):
with
switch
.
case
(
global_step
<
boundary_val
):
layers
.
assign
(
value_var
,
lr
)
layers
.
assign
(
value_var
,
lr
)
last_value_var
=
layers
.
fill_constant
(
last_value_var
=
layers
.
fill_constant
(
shape
=
[
1
],
shape
=
[
1
],
...
...
python/paddle/v2/fluid/tests/test_layers.py
浏览文件 @
e9d30991
...
@@ -161,8 +161,8 @@ class TestBook(unittest.TestCase):
...
@@ -161,8 +161,8 @@ class TestBook(unittest.TestCase):
label
=
label
,
label
=
label
,
chunk_scheme
=
"IOB"
,
chunk_scheme
=
"IOB"
,
num_chunk_types
=
(
label_dict_len
-
1
)
/
2
)
num_chunk_types
=
(
label_dict_len
-
1
)
/
2
)
self
.
assert
NotEqual
(
crf
,
None
)
self
.
assert
False
(
crf
is
None
)
self
.
assert
NotEqual
(
crf_decode
,
None
)
self
.
assert
False
(
crf_decode
is
None
)
print
(
str
(
program
))
print
(
str
(
program
))
...
...
python/paddle/v2/fluid/tests/test_python_operator_overriding.py
0 → 100644
浏览文件 @
e9d30991
# Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import
unittest
import
numpy
as
np
import
paddle.v2.fluid.layers
as
layers
import
paddle.v2.fluid.framework
as
framework
import
paddle.v2.fluid
as
fluid
class
TestPythonOperatorOverride
(
unittest
.
TestCase
):
def
check_result
(
self
,
fn
,
place
,
dtype
):
shape
=
[
9
,
10
]
x_data
=
np
.
random
.
random
(
size
=
shape
).
astype
(
dtype
)
y_data
=
np
.
random
.
random
(
size
=
shape
).
astype
(
dtype
)
python_out
=
fn
(
x_data
,
y_data
)
x_var
=
layers
.
create_global_var
(
name
=
'x'
,
shape
=
shape
,
value
=
0.0
,
dtype
=
dtype
,
persistable
=
True
)
y_var
=
layers
.
create_global_var
(
name
=
'y'
,
shape
=
shape
,
value
=
0.0
,
dtype
=
dtype
,
persistable
=
True
)
out
=
fn
(
x_var
,
y_var
)
exe
=
fluid
.
Executor
(
place
)
exe
.
run
(
fluid
.
default_startup_program
())
fluid_out
=
exe
.
run
(
fluid
.
default_main_program
(),
feed
=
{
'x'
:
x_data
,
'y'
:
y_data
},
fetch_list
=
[
out
])
np
.
testing
.
assert_array_equal
(
python_out
,
fluid_out
[
0
])
def
test_override
(
self
):
# compare func to check
compare_fns
=
[
lambda
_a
,
_b
:
_a
==
_b
,
lambda
_a
,
_b
:
_a
!=
_b
,
lambda
_a
,
_b
:
_a
<
_b
,
lambda
_a
,
_b
:
_a
<=
_b
,
lambda
_a
,
_b
:
_a
>
_b
,
lambda
_a
,
_b
:
_a
>=
_b
,
]
# places to check
places
=
[
fluid
.
CPUPlace
()]
if
fluid
.
core
.
is_compiled_with_cuda
():
places
.
append
(
fluid
.
CUDAPlace
(
0
))
# dtypes to check
dtypes
=
[
'int32'
,
'float32'
]
for
place
in
places
:
for
dtype
in
dtypes
:
for
compare_fn
in
compare_fns
:
with
framework
.
program_guard
(
framework
.
Program
(),
framework
.
Program
()):
self
.
check_result
(
compare_fn
,
place
,
dtype
)
if
__name__
==
'__main__'
:
unittest
.
main
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录