Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
de469d58
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看板
提交
de469d58
编写于
2月 11, 2018
作者:
Q
qiaolongfei
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
optimize test
上级
d89e1449
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
32 addition
and
21 deletion
+32
-21
python/paddle/v2/fluid/tests/test_python_operator_overriding.py
.../paddle/v2/fluid/tests/test_python_operator_overriding.py
+32
-21
未找到文件。
python/paddle/v2/fluid/tests/test_python_operator_overriding.py
浏览文件 @
de469d58
...
...
@@ -22,44 +22,55 @@ import paddle.v2.fluid as fluid
class
TestPythonOperatorOverride
(
unittest
.
TestCase
):
def
check_result
(
self
,
fn
,
x_val
,
y_val
,
place
,
dtype
):
def
check_result
(
self
,
fn
,
place
,
dtype
):
shape
=
[
9
,
10
]
x_data
=
np
.
full
(
shape
,
x_val
).
astype
(
dtype
)
y_data
=
np
.
full
(
shape
,
y_val
).
astype
(
dtype
)
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
(
shape
=
shape
,
value
=
x_val
,
dtype
=
dtype
,
persistable
=
True
)
name
=
'x'
,
shape
=
shape
,
value
=
0.0
,
dtype
=
dtype
,
persistable
=
True
)
y_var
=
layers
.
create_global_var
(
shape
=
shape
,
value
=
y_val
,
dtype
=
dtype
,
persistable
=
True
)
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
=
[],
feed
=
{
'x'
:
x_data
,
'y'
:
y_data
},
fetch_list
=
[
out
])
np
.
testing
.
assert_array_equal
(
python_out
,
fluid_out
[
0
])
def
test_override
(
self
):
cpu_place
=
fluid
.
CPUPlace
()
test_data
=
[(
lambda
_a
,
_b
:
_a
==
_b
,
0.1
,
1.1
,
cpu_place
,
'float32'
),
(
lambda
_a
,
_b
:
_a
==
_b
,
1.2
,
1.1
,
cpu_place
,
'float32'
),
(
lambda
_a
,
_b
:
_a
<
_b
,
0.1
,
1.1
,
cpu_place
,
'float32'
),
(
lambda
_a
,
_b
:
_a
<
_b
,
2.1
,
1.1
,
cpu_place
,
'float32'
),
(
lambda
_a
,
_b
:
_a
<=
_b
,
0.1
,
1.1
,
cpu_place
,
'float32'
),
(
lambda
_a
,
_b
:
_a
<=
_b
,
1.1
,
1.1
,
cpu_place
,
'float32'
),
(
lambda
_a
,
_b
:
_a
>=
_b
,
1.1
,
1.1
,
cpu_place
,
'float32'
)]
main_program
=
framework
.
Program
()
startup_program
=
framework
.
Program
()
with
framework
.
program_guard
(
main_program
,
startup_program
):
for
fn
,
x_val
,
y_val
,
place
,
dtype
in
test_data
:
self
.
check_result
(
fn
,
x_val
,
y_val
,
place
,
dtype
)
# 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
,
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
(),
gframework
.
Program
()):
self
.
check_result
(
compare_fn
,
place
,
dtype
)
if
__name__
==
'__main__'
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录