Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
4b553ece
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看板
未验证
提交
4b553ece
编写于
12月 02, 2020
作者:
C
chentianyu03
提交者:
GitHub
12月 02, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix random failed of complex matmul (#29299)
上级
d4a97673
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
88 addition
and
42 deletion
+88
-42
python/paddle/fluid/tests/unittests/test_complex_matmul.py
python/paddle/fluid/tests/unittests/test_complex_matmul.py
+88
-42
未找到文件。
python/paddle/fluid/tests/unittests/test_complex_matmul.py
浏览文件 @
4b553ece
...
...
@@ -25,61 +25,61 @@ class TestComplexMatMulLayer(unittest.TestCase):
if
fluid
.
core
.
is_compiled_with_cuda
():
self
.
_places
.
append
(
fluid
.
CUDAPlace
(
0
))
def
compare
(
self
,
x
,
y
):
def
compare_by_complex_api
(
self
,
x
,
y
):
np_result
=
np
.
matmul
(
x
,
y
)
for
place
in
self
.
_places
:
with
dg
.
guard
(
place
):
x_var
=
dg
.
to_variable
(
x
)
y_var
=
dg
.
to_variable
(
y
)
result
=
paddle
.
complex
.
matmul
(
x_var
,
y_var
)
np_result
=
np
.
matmul
(
x
,
y
)
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
def
compare_1
(
self
,
x
,
y
):
def
compare_by_basic_api
(
self
,
x
,
y
):
np_result
=
np
.
matmul
(
x
,
y
)
for
place
in
self
.
_places
:
with
dg
.
guard
(
place
):
x_var
=
fluid
.
core
.
VarBase
(
value
=
x
,
place
=
fluid
.
framework
.
_current_expected_place
()
,
place
=
place
,
persistable
=
False
,
zero_copy
=
None
,
name
=
''
)
y_var
=
fluid
.
core
.
VarBase
(
value
=
y
,
place
=
fluid
.
framework
.
_current_expected_place
()
,
place
=
place
,
persistable
=
False
,
zero_copy
=
None
,
name
=
''
)
result
=
paddle
.
matmul
(
x_var
,
y_var
)
np_result
=
np
.
matmul
(
x
,
y
)
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
def
compare_op
(
self
,
x
,
y
):
def
compare_op_by_complex_api
(
self
,
x
,
y
):
np_result
=
np
.
matmul
(
x
,
y
)
for
place
in
self
.
_places
:
with
dg
.
guard
(
place
):
x_var
=
dg
.
to_variable
(
x
)
y_var
=
dg
.
to_variable
(
y
)
result
=
x_var
.
matmul
(
y_var
)
np_result
=
np
.
matmul
(
x
,
y
)
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
def
compare_op_1
(
self
,
x
,
y
):
def
compare_op_by_basic_api
(
self
,
x
,
y
):
np_result
=
np
.
matmul
(
x
,
y
)
for
place
in
self
.
_places
:
with
dg
.
guard
(
place
):
x_var
=
fluid
.
core
.
VarBase
(
value
=
x
,
place
=
fluid
.
framework
.
_current_expected_place
()
,
place
=
place
,
persistable
=
False
,
zero_copy
=
None
,
name
=
''
)
y_var
=
fluid
.
core
.
VarBase
(
value
=
y
,
place
=
fluid
.
framework
.
_current_expected_place
()
,
place
=
place
,
persistable
=
False
,
zero_copy
=
None
,
name
=
''
)
result
=
x_var
.
matmul
(
y_var
)
np_result
=
np
.
matmul
(
x
,
y
)
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
def
test_complex_xy
(
self
):
x
=
np
.
random
.
random
(
...
...
@@ -88,35 +88,35 @@ class TestComplexMatMulLayer(unittest.TestCase):
y
=
np
.
random
.
random
(
(
2
,
3
,
5
,
4
)).
astype
(
"float32"
)
+
1J
*
np
.
random
.
random
(
(
2
,
3
,
5
,
4
)).
astype
(
"float32"
)
self
.
compare
(
x
,
y
)
self
.
compare_op
(
x
,
y
)
self
.
compare_
1
(
x
,
y
)
self
.
compare_op_
1
(
x
,
y
)
self
.
compare
_by_complex_api
(
x
,
y
)
self
.
compare_op
_by_complex_api
(
x
,
y
)
self
.
compare_
by_basic_api
(
x
,
y
)
self
.
compare_op_
by_basic_api
(
x
,
y
)
def
test_complex_x
(
self
):
x
=
np
.
random
.
random
(
(
2
,
3
,
4
,
5
)).
astype
(
"float32"
)
+
1J
*
np
.
random
.
random
(
(
2
,
3
,
4
,
5
)).
astype
(
"float32"
)
y
=
np
.
random
.
random
((
2
,
3
,
5
,
4
)).
astype
(
"float32"
)
self
.
compare
(
x
,
y
)
self
.
compare_op
(
x
,
y
)
self
.
compare
_by_complex_api
(
x
,
y
)
self
.
compare_op
_by_complex_api
(
x
,
y
)
def
test_complex_y
(
self
):
x
=
np
.
random
.
random
((
2
,
3
,
4
,
5
)).
astype
(
"float32"
)
y
=
np
.
random
.
random
(
(
2
,
3
,
5
,
4
)).
astype
(
"float32"
)
+
1J
*
np
.
random
.
random
(
(
2
,
3
,
5
,
4
)).
astype
(
"float32"
)
self
.
compare
(
x
,
y
)
self
.
compare
_by_complex_api
(
x
,
y
)
def
test_complex
128_xy
(
self
):
def
test_complex
_xy_128
(
self
):
x
=
np
.
random
.
random
(
(
2
,
3
,
4
,
5
)).
astype
(
"float64"
)
+
1J
*
np
.
random
.
random
(
(
2
,
3
,
4
,
5
)).
astype
(
"float64"
)
y
=
np
.
random
.
random
(
(
2
,
3
,
5
,
4
)).
astype
(
"float64"
)
+
1J
*
np
.
random
.
random
(
(
2
,
3
,
5
,
4
)).
astype
(
"float64"
)
self
.
compare_
1
(
x
,
y
)
self
.
compare_op_
1
(
x
,
y
)
self
.
compare_
by_basic_api
(
x
,
y
)
self
.
compare_op_
by_basic_api
(
x
,
y
)
def
test_complex_xy_gemv
(
self
):
x
=
np
.
random
.
random
(
...
...
@@ -124,35 +124,81 @@ class TestComplexMatMulLayer(unittest.TestCase):
(
2
,
1
,
100
)).
astype
(
"float32"
)
y
=
np
.
random
.
random
((
100
)).
astype
(
"float32"
)
+
1J
*
np
.
random
.
random
(
(
100
)).
astype
(
"float32"
)
self
.
compare_
1
(
x
,
y
)
self
.
compare_op_
1
(
x
,
y
)
self
.
compare_
by_basic_api
(
x
,
y
)
self
.
compare_op_
by_basic_api
(
x
,
y
)
x
=
np
.
random
.
random
(
(
2
,
1
,
100
)).
astype
(
"float64"
)
+
1J
*
np
.
random
.
random
(
(
2
,
1
,
100
)).
astype
(
"float64"
)
y
=
np
.
random
.
random
((
100
)).
astype
(
"float64"
)
+
1J
*
np
.
random
.
random
(
(
100
)).
astype
(
"float64"
)
self
.
compare_1
(
x
,
y
)
self
.
compare_op_1
(
x
,
y
)
def
test_complex_xy_gemm
(
self
):
x
=
np
.
random
.
random
(
(
1
,
2
,
50
)).
astype
(
"float32"
)
+
1J
*
np
.
random
.
random
(
(
1
,
2
,
50
)).
astype
(
"float32"
)
y
=
np
.
random
.
random
(
(
1
,
50
,
2
)).
astype
(
"float32"
)
+
1J
*
np
.
random
.
random
(
(
1
,
50
,
2
)).
astype
(
"float32"
)
self
.
compare_1
(
x
,
y
)
self
.
compare_op_1
(
x
,
y
)
self
.
compare_by_basic_api
(
x
,
y
)
self
.
compare_op_by_basic_api
(
x
,
y
)
def
test_complex_xy_gemm_128
(
self
):
x
=
np
.
random
.
random
(
(
1
,
2
,
50
)).
astype
(
"float64"
)
+
1J
*
np
.
random
.
random
(
(
1
,
2
,
50
)).
astype
(
"float64"
)
y
=
np
.
random
.
random
(
(
1
,
50
,
2
)).
astype
(
"float64"
)
+
1J
*
np
.
random
.
random
(
(
1
,
50
,
2
)).
astype
(
"float64"
)
self
.
compare_1
(
x
,
y
)
self
.
compare_op_1
(
x
,
y
)
self
.
compare_by_basic_api
(
x
,
y
)
self
.
compare_op_by_basic_api
(
x
,
y
)
class
TestComplexMatMulLayerGEMM
(
unittest
.
TestCase
):
def
setUp
(
self
):
self
.
_places
=
[
fluid
.
CPUPlace
()]
if
fluid
.
core
.
is_compiled_with_cuda
():
self
.
_places
.
append
(
fluid
.
CUDAPlace
(
0
))
def
compare_by_basic_api
(
self
,
x
,
y
):
np_result
=
np
.
matmul
(
x
,
y
)
for
place
in
self
.
_places
:
with
dg
.
guard
(
place
):
x_var
=
fluid
.
core
.
VarBase
(
value
=
x
,
place
=
place
,
persistable
=
False
,
zero_copy
=
None
,
name
=
''
)
y_var
=
fluid
.
core
.
VarBase
(
value
=
y
,
place
=
place
,
persistable
=
False
,
zero_copy
=
None
,
name
=
''
)
result
=
paddle
.
matmul
(
x_var
,
y_var
)
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
def
compare_op_by_basic_api
(
self
,
x
,
y
):
np_result
=
np
.
matmul
(
x
,
y
)
for
place
in
self
.
_places
:
with
dg
.
guard
(
place
):
x_var
=
fluid
.
core
.
VarBase
(
value
=
x
,
place
=
place
,
persistable
=
False
,
zero_copy
=
None
,
name
=
''
)
y_var
=
fluid
.
core
.
VarBase
(
value
=
y
,
place
=
place
,
persistable
=
False
,
zero_copy
=
None
,
name
=
''
)
result
=
x_var
.
matmul
(
y_var
)
self
.
assertTrue
(
np
.
allclose
(
result
.
numpy
(),
np_result
))
def
test_complex_xy_gemm_64
(
self
):
x
=
np
.
random
.
random
(
(
1
,
2
,
50
)).
astype
(
"float32"
)
+
1J
*
np
.
random
.
random
(
(
1
,
2
,
50
)).
astype
(
"float32"
)
y
=
np
.
random
.
random
(
(
1
,
50
,
2
)).
astype
(
"float32"
)
+
1J
*
np
.
random
.
random
(
(
1
,
50
,
2
)).
astype
(
"float32"
)
self
.
compare_by_basic_api
(
x
,
y
)
self
.
compare_op_by_basic_api
(
x
,
y
)
if
__name__
==
'__main__'
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录