Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
96ec586d
MegEngine
项目概览
MegEngine 天元
/
MegEngine
大约 1 年 前同步成功
通知
399
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看板
提交
96ec586d
编写于
8月 17, 2020
作者:
M
Megvii Engine Team
提交者:
Xinran Xu
8月 25, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(dnn): fix bool cvt
GitOrigin-RevId: 2f883dcbe005a8a8cd43e9051d1d0a59b8e61c0e
上级
f26cd398
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
25 addition
and
4 deletion
+25
-4
dnn/src/cuda/cond_take/opr_impl.cpp
dnn/src/cuda/cond_take/opr_impl.cpp
+1
-0
dnn/src/cuda/type_cvt/kern.cu
dnn/src/cuda/type_cvt/kern.cu
+2
-4
dnn/src/cuda/type_cvt/opr_impl.cpp
dnn/src/cuda/type_cvt/opr_impl.cpp
+1
-0
src/opr/test/basic_arith/others.cpp
src/opr/test/basic_arith/others.cpp
+21
-0
未找到文件。
dnn/src/cuda/cond_take/opr_impl.cpp
浏览文件 @
96ec586d
...
...
@@ -59,6 +59,7 @@ CondTakeImpl::Output CondTakeImpl::exec(
break; \
}
MEGDNN_FOREACH_COMPUTING_DTYPE
(
cb
)
cb
(
::
megdnn
::
dtype
::
Bool
)
#undef cb
default:
megdnn_throw
(
"bad mask dtype"
);
...
...
dnn/src/cuda/type_cvt/kern.cu
浏览文件 @
96ec586d
...
...
@@ -111,8 +111,7 @@ struct TypeCvtOpFromQuantized<
ctype_dest
,
ctype_src
,
typename
std
::
enable_if
<
std
::
is_same
<
ctype_src
,
dt_qint8
>::
value
||
std
::
is_same
<
ctype_src
,
dt_quint8
>::
value
||
std
::
is_same
<
ctype_src
,
dt_bool
>::
value
>::
type
>
{
std
::
is_same
<
ctype_src
,
dt_quint8
>::
value
>::
type
>
{
ctype_dest
*
dest
;
CudaDTypeParam
<
ctype_src
>
param
;
using
src_vect_type
=
typename
VectTypeTrait
<
ctype_src
>::
vect_type
;
...
...
@@ -140,8 +139,7 @@ struct TypeCvtOpBetweenQuantized<
ctype_dest
,
ctype_src
,
typename
std
::
enable_if
<
std
::
is_same
<
ctype_src
,
dt_qint8
>::
value
||
std
::
is_same
<
ctype_src
,
dt_quint8
>::
value
||
std
::
is_same
<
ctype_src
,
dt_bool
>::
value
>::
type
>
{
std
::
is_same
<
ctype_src
,
dt_quint8
>::
value
>::
type
>
{
ctype_dest
*
dest
;
CudaDTypeParam
<
ctype_src
>
src_param
;
CudaDTypeParam
<
ctype_dest
>
dst_param
;
...
...
dnn/src/cuda/type_cvt/opr_impl.cpp
浏览文件 @
96ec586d
...
...
@@ -109,6 +109,7 @@ void TypeCvtImpl::exec(_megdnn_tensor_in src, _megdnn_tensor_out dst) {
return; \
}
MEGDNN_FOREACH_COMPUTING_DTYPE
(
cb
)
cb
(
::
megdnn
::
dtype
::
Bool
)
#undef cb
default:
megdnn_assert_internal
(
0
);
...
...
src/opr/test/basic_arith/others.cpp
浏览文件 @
96ec586d
...
...
@@ -568,6 +568,27 @@ TEST(TestOprBasicArith, TypeCvtBool) {
ASSERT_EQ
(
TensorShape
({
3
}),
host_y
.
shape
());
}
TEST
(
TestOprBasicArith
,
TypeCvtFromBool
)
{
auto
graph
=
ComputingGraph
::
make
();
HostTensorGenerator
<
dtype
::
Bool
>
gen
;
auto
host_x
=
gen
({
2
});
auto
px
=
host_x
->
ptr
<
bool
>
();
px
[
0
]
=
true
;
px
[
1
]
=
false
;
auto
x
=
opr
::
Host2DeviceCopy
::
make
(
*
graph
,
host_x
),
y
=
opr
::
TypeCvt
::
make
(
x
,
dtype
::
Int32
{});
HostTensorND
host_y
;
auto
func
=
graph
->
compile
({
make_callback_copy
(
y
,
host_y
)});
func
->
execute
();
auto
py
=
host_y
.
ptr
<
int
>
();
for
(
size_t
i
=
0
;
i
<
2
;
i
++
)
{
ASSERT_EQ
(
static_cast
<
int
>
(
px
[
i
]),
py
[
i
]);
}
ASSERT_EQ
(
TensorShape
({
2
}),
host_y
.
shape
());
}
TEST
(
TestOprBasicArith
,
ElemwiseMemFwd
)
{
auto
graph
=
ComputingGraph
::
make
();
graph
->
options
().
graph_opt_level
=
0
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录