Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
717b88e6
MegEngine
项目概览
MegEngine 天元
/
MegEngine
1 年多 前同步成功
通知
404
Star
4705
Fork
582
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
MegEngine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
717b88e6
编写于
5月 12, 2021
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(mge/elemwise): fix problem that elemwise.mode is not comparable with string mode
GitOrigin-RevId: 82e39be0a975cc72dfe1fe7c206be218c2ada131
上级
9c17cfc4
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
17 addition
and
15 deletion
+17
-15
imperative/python/src/ops.cpp
imperative/python/src/ops.cpp
+12
-6
imperative/python/test/unit/functional/test_elemwise.py
imperative/python/test/unit/functional/test_elemwise.py
+5
-9
未找到文件。
imperative/python/src/ops.cpp
浏览文件 @
717b88e6
...
@@ -191,10 +191,13 @@ struct EnumWrapper {
...
@@ -191,10 +191,13 @@ struct EnumWrapper {
.
release
().
ptr
();
.
release
().
ptr
();
}
}
static
PyObject
*
tp_richcompare
(
PyObject
*
self
,
PyObject
*
other
,
int
op
)
{
static
PyObject
*
tp_richcompare
(
PyObject
*
self
,
PyObject
*
other
,
int
op
)
{
T
lhs
=
reinterpret_cast
<
EnumWrapper
*>
(
self
)
->
value
,
rhs
=
reinterpret_cast
<
EnumWrapper
*>
(
other
)
->
value
;
if
(
op
==
Py_EQ
||
op
==
Py_NE
)
{
if
(
op
==
Py_EQ
||
op
==
Py_NE
)
{
T
lhs
,
rhs
;
if
(
load
(
other
,
rhs
)
&&
load
(
self
,
lhs
))
{
RETURN_RICHCOMPARE
(
lhs
,
rhs
,
op
);
RETURN_RICHCOMPARE
(
lhs
,
rhs
,
op
);
}
else
{
RETURN_RICHCOMPARE
(
0
,
1
,
op
);
}
}
}
Py_RETURN_NOTIMPLEMENTED
;
Py_RETURN_NOTIMPLEMENTED
;
}
}
...
@@ -296,10 +299,13 @@ struct BitCombinedEnumWrapper {
...
@@ -296,10 +299,13 @@ struct BitCombinedEnumWrapper {
return
cast
(
lhs
&
rhs
);
return
cast
(
lhs
&
rhs
);
}
}
static
PyObject
*
tp_richcompare
(
PyObject
*
self
,
PyObject
*
other
,
int
op
)
{
static
PyObject
*
tp_richcompare
(
PyObject
*
self
,
PyObject
*
other
,
int
op
)
{
T
lhs
=
reinterpret_cast
<
BitCombinedEnumWrapper
*>
(
self
)
->
value
,
rhs
=
reinterpret_cast
<
BitCombinedEnumWrapper
*>
(
other
)
->
value
;
if
(
op
==
Py_EQ
||
op
==
Py_NE
)
{
if
(
op
==
Py_EQ
||
op
==
Py_NE
)
{
T
lhs
,
rhs
;
if
(
load
(
other
,
rhs
)
&&
load
(
self
,
lhs
))
{
RETURN_RICHCOMPARE
(
lhs
,
rhs
,
op
);
RETURN_RICHCOMPARE
(
lhs
,
rhs
,
op
);
}
else
{
RETURN_RICHCOMPARE
(
0
,
1
,
op
);
}
}
}
Py_RETURN_NOTIMPLEMENTED
;
Py_RETURN_NOTIMPLEMENTED
;
}
}
...
...
imperative/python/test/unit/functional/test_elemwise.py
浏览文件 @
717b88e6
...
@@ -12,7 +12,7 @@ import megengine.functional as F
...
@@ -12,7 +12,7 @@ import megengine.functional as F
import
megengine.functional.elemwise
as
elemwise
import
megengine.functional.elemwise
as
elemwise
from
megengine
import
tensor
from
megengine
import
tensor
from
megengine.core.tensor
import
dtype
from
megengine.core.tensor
import
dtype
from
megengine.functional.elemwise
import
_elwise
from
megengine.functional.elemwise
import
Elemwise
,
_elwise
def
test_abs
():
def
test_abs
():
...
@@ -25,14 +25,10 @@ def test_abs():
...
@@ -25,14 +25,10 @@ def test_abs():
def
test_elemwise_mode_string
():
def
test_elemwise_mode_string
():
np
.
testing
.
assert_allclose
(
for
key
,
mode
in
vars
(
Elemwise
.
Mode
).
items
():
_elwise
(
tensor
([
-
3.0
,
-
4.0
,
-
5.0
]),
mode
=
"ABS"
).
numpy
(),
if
isinstance
(
mode
,
Elemwise
.
Mode
):
np
.
abs
(
np
.
array
([
-
3.0
,
-
4.0
,
-
5.0
],
dtype
=
np
.
float32
)),
assert
key
==
mode
)
assert
Elemwise
(
mode
=
key
)
==
Elemwise
(
mode
=
mode
)
np
.
testing
.
assert_allclose
(
_elwise
(
-
3.0
,
mode
=
"ABS"
).
numpy
(),
np
.
abs
(
np
.
float32
(
-
3.0
))
)
def
test_multiply
():
def
test_multiply
():
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录