Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
512e4339
P
Paddle
项目概览
BaiXuePrincess
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
512e4339
编写于
12月 13, 2021
作者:
S
Shang Zhizhou
提交者:
GitHub
12月 13, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix reduce_max bug (#38026)
* fix reduce_max bug * add unittest
上级
92ad682f
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
23 addition
and
3 deletion
+23
-3
paddle/pten/kernels/hybird/eigen/reduce.h
paddle/pten/kernels/hybird/eigen/reduce.h
+11
-3
python/paddle/fluid/tests/unittests/test_max_op.py
python/paddle/fluid/tests/unittests/test_max_op.py
+12
-0
未找到文件。
paddle/pten/kernels/hybird/eigen/reduce.h
浏览文件 @
512e4339
...
...
@@ -82,10 +82,18 @@ inline void GetShuffledDim(const DDim& src_dims,
std
::
vector
<
bool
>
src_dims_check
(
src_dims
.
size
(),
false
);
size_t
src_size
=
src_dims
.
size
();
size_t
reduce_size
=
reduced_dims
.
size
();
std
::
vector
<
int64_t
>
regular_reduced_dims
=
reduced_dims
;
for
(
size_t
i
=
0
;
i
<
regular_reduced_dims
.
size
();
i
++
)
{
if
(
regular_reduced_dims
[
i
]
<
0
)
{
regular_reduced_dims
[
i
]
=
src_size
+
regular_reduced_dims
[
i
];
}
}
for
(
size_t
i
=
0
;
i
<
reduce_size
;
++
i
)
{
dst_dims
->
at
(
src_size
-
reduce_size
+
i
)
=
src_dims
[
reduced_dims
[
i
]];
(
*
perm_axis
)[
src_size
-
reduce_size
+
i
]
=
reduced_dims
[
i
];
src_dims_check
[
reduced_dims
[
i
]]
=
true
;
dst_dims
->
at
(
src_size
-
reduce_size
+
i
)
=
src_dims
[
regular_reduced_dims
[
i
]];
(
*
perm_axis
)[
src_size
-
reduce_size
+
i
]
=
regular_reduced_dims
[
i
];
src_dims_check
[
regular_reduced_dims
[
i
]]
=
true
;
}
size_t
offset
=
0
;
...
...
python/paddle/fluid/tests/unittests/test_max_op.py
浏览文件 @
512e4339
...
...
@@ -86,6 +86,18 @@ class ApiMaxTest(unittest.TestCase):
z_expected
=
np
.
array
(
np
.
max
(
np_x
,
axis
=
0
))
self
.
assertEqual
((
np_z
==
z_expected
).
all
(),
True
)
def
test_big_dimension
(
self
):
paddle
.
disable_static
()
x
=
paddle
.
rand
(
shape
=
[
2
,
2
,
2
,
2
,
2
,
2
,
2
])
np_x
=
x
.
numpy
()
z1
=
paddle
.
max
(
x
,
axis
=-
1
)
z2
=
paddle
.
max
(
x
,
axis
=
6
)
np_z1
=
z1
.
numpy
()
np_z2
=
z2
.
numpy
()
z_expected
=
np
.
array
(
np
.
max
(
np_x
,
axis
=
6
))
self
.
assertEqual
((
np_z1
==
z_expected
).
all
(),
True
)
self
.
assertEqual
((
np_z2
==
z_expected
).
all
(),
True
)
class
TestOutDtype
(
unittest
.
TestCase
):
def
test_max
(
self
):
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录