Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
24a38781
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看板
提交
24a38781
编写于
4月 28, 2021
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(dnn/cuda): add nchw conv u4xs4 support
GitOrigin-RevId: 5edba47bd96371b0afa99d85645e41af5d2f3180
上级
606540be
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
5 addition
and
213 deletion
+5
-213
dnn/src/cuda/conv_bias/algo.h
dnn/src/cuda/conv_bias/algo.h
+1
-0
dnn/src/cuda/conv_bias/cudnn_conv_bias_activation.cpp
dnn/src/cuda/conv_bias/cudnn_conv_bias_activation.cpp
+2
-1
dnn/src/cuda/conv_bias/fallback_nchw_qs4.cpp
dnn/src/cuda/conv_bias/fallback_nchw_qs4.cpp
+0
-211
dnn/src/cuda/conv_bias/helper.cpp
dnn/src/cuda/conv_bias/helper.cpp
+2
-1
未找到文件。
dnn/src/cuda/conv_bias/algo.h
浏览文件 @
24a38781
...
...
@@ -70,6 +70,7 @@ public:
CUDA_IMPLICIT_GEMM_1X1_SASS_NCHW32_IMMA_INT8
,
CUDA_IMPLICIT_GEMM_SASS_NCHW64_IMMA_INT4_INT4
,
CUDA_IMPLICIT_GEMM_SASS_NCHW64_IMMA_UINT4_INT4
,
CUDA_FALLBACK_NCHW_INT4
};
using
Mapper
=
std
::
unordered_map
<
AlgorithmDesc
,
AlgoBase
*>
;
...
...
dnn/src/cuda/conv_bias/cudnn_conv_bias_activation.cpp
浏览文件 @
24a38781
...
...
@@ -24,7 +24,8 @@ using namespace conv_bias;
bool
ConvBiasForwardImpl
::
AlgoCUDNNConvBiasActivation
::
is_available
(
const
SizeArgs
&
args
)
const
{
if
(
args
.
src_layout
->
dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS4
&&
if
((
args
.
src_layout
->
dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS4
||
args
.
src_layout
->
dtype
.
enumv
()
==
DTypeEnum
::
Quantized4Asymm
)
&&
args
.
filter_layout
->
dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS4
)
return
false
;
if
(
args
.
src_layout
->
dtype
==
args
.
filter_layout
->
dtype
&&
...
...
dnn/src/cuda/conv_bias/fallback_nchw_qs4.cpp
已删除
100644 → 0
浏览文件 @
606540be
/**
* \file dnn/src/cuda/conv_bias/fallback_nchw_qs4.cpp
* MegEngine is Licensed under the Apache License, Version 2.0 (the "License")
*
* Copyright (c) 2014-2021 Megvii Inc. All rights reserved.
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT ARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied.
*/
#include "./algo.h"
#include "src/cuda/utils.h"
#include "src/common/conv_bias.h"
using
namespace
megdnn
;
using
namespace
cuda
;
bool
ConvBiasForwardImpl
::
AlgoFallbackNCHWQS4
::
is_available
(
const
SizeArgs
&
args
)
const
{
if
(
args
.
bias_layout
->
ndim
<=
0
)
return
false
;
using
Param
=
param
::
ConvBias
;
using
Format
=
Param
::
Format
;
using
Sparse
=
Param
::
Sparse
;
using
Mode
=
Param
::
Mode
;
bool
available
=
true
;
auto
&&
param
=
args
.
opr
->
param
();
auto
&&
fm
=
args
.
filter_meta
;
if
(
!
check_bias_share_in_channel
(
*
(
args
.
bias_layout
),
param
.
format
))
return
false
;
if
(
param
.
format
!=
Format
::
NCHW
)
return
false
;
UNPACK_CONV_BIAS_NCHW_PARAM
(
*
(
args
.
src_layout
),
fm
,
*
(
args
.
dst_layout
),
param
);
// TODO support group conv
available
&=
param
.
sparse
==
Sparse
::
DENSE
;
// mode must be cross correlation
available
&=
param
.
mode
==
Mode
::
CROSS_CORRELATION
;
// check data type
auto
src_dtype
=
args
.
src_layout
->
dtype
,
filter_dtype
=
args
.
filter_layout
->
dtype
,
bias_dtype
=
args
.
bias_layout
->
dtype
,
dst_dtype
=
args
.
dst_layout
->
dtype
;
available
&=
(
src_dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS4
&&
filter_dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS4
&&
bias_dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS32
&&
dst_dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS4
);
// TODO: support dialtion
available
&=
dh
==
1
&&
dw
==
1
;
// ensure precomputed offsets are positive integers
available
&=
hi
>=
fh
&&
wi
>=
fw
;
// only support sm_75 or later, platform should have tensorcore int8
// support
available
&=
is_compute_capability_required
(
7
,
5
);
// param buffer size is 4K, use 3K to store precomputed offset, fh * fw <=
// (3*1024/4/2/2) - 1
available
&=
fh
*
fw
<=
191
;
return
available
;
}
size_t
ConvBiasForwardImpl
::
AlgoFallbackNCHWQS4
::
get_workspace_in_bytes
(
const
SizeArgs
&
args
)
const
{
return
get_workspace_bundle
(
nullptr
,
args
).
total_size_in_bytes
();
}
void
ConvBiasForwardImpl
::
AlgoFallbackNCHWQS4
::
exec
(
const
ExecArgs
&
args
)
const
{
auto
layouts
=
make_underlying_tensor_layout
(
*
(
args
.
src_layout
),
*
(
args
.
filter_layout
),
*
(
args
.
bias_layout
),
*
(
args
.
z_layout
),
*
(
args
.
dst_layout
));
auto
ws
=
get_workspace_bundle
(
args
.
workspace
.
raw_ptr
,
args
);
auto
ws_src
=
ws
.
get
(
0
);
auto
ws_filter
=
ws
.
get
(
1
);
auto
ws_bias
=
args
.
bias_tensor
->
raw_ptr
;
auto
ws_dst
=
ws
.
get
(
2
);
void
*
ws_z
=
nullptr
;
if
(
args
.
z_layout
->
ndim
>
0
)
ws_z
=
ws
.
get
(
4
);
auto
nchw2nchw64
=
[
&
args
](
const
TensorND
&
src
,
TensorND
&&
dst
)
{
if
(
dst
.
raw_ptr
==
nullptr
)
return
;
auto
relayout
=
args
.
handle
->
create_operator
<
RelayoutFormat
>
();
relayout
->
param
()
=
RelayoutFormat
::
Param
::
Mode
::
NCHW_NCHW64
;
Workspace
dummy
;
relayout
->
exec
(
src
,
dst
,
dummy
);
};
auto
nchw642nchw
=
[
&
args
](
const
TensorND
&
src
,
TensorND
&&
dst
)
{
auto
relayout
=
args
.
handle
->
create_operator
<
RelayoutFormat
>
();
relayout
->
param
()
=
RelayoutFormat
::
Param
::
Mode
::
NCHW64_NCHW
;
relayout
->
param
().
oc
=
dst
.
layout
[
1
];
Workspace
dummy
;
relayout
->
exec
(
src
,
dst
,
dummy
);
};
// reformat src
nchw2nchw64
(
*
(
args
.
src_tensor
),
{
ws_src
,
layouts
[
0
]});
// reformat filter
size_t
co
=
args
.
filter_layout
->
operator
[](
0
);
if
(
co
%
64
!=
0
)
{
const
auto
&
stream
=
cuda_stream
(
args
.
opr
->
handle
());
auto
ws_filter_
=
reinterpret_cast
<
dt_byte
*>
(
ws_filter
)
+
layouts
[
1
].
span
().
dist_byte
();
size_t
ci
=
args
.
filter_layout
->
operator
[](
1
),
fh
=
args
.
filter_layout
->
operator
[](
2
),
fw
=
args
.
filter_layout
->
operator
[](
3
);
TensorLayout
intermediate
({
round_up
(
co
,
64
_z
),
ci
,
fh
,
fw
},
args
.
filter_layout
->
dtype
);
ws_bias
=
ws_filter_
+
intermediate
.
span
().
dist_byte
();
cuda_check
(
cudaMemsetAsync
(
ws_filter_
,
0
,
intermediate
.
span
().
dist_byte
(),
stream
));
cuda_check
(
cudaMemcpyAsync
(
ws_filter_
,
args
.
filter_tensor
->
raw_ptr
,
args
.
filter_layout
->
span
().
dist_byte
(),
cudaMemcpyDeviceToDevice
,
stream
));
nchw2nchw64
({
ws_filter_
,
intermediate
},
{
ws_filter
,
layouts
[
1
]});
cuda_check
(
cudaMemcpyAsync
(
ws_bias
,
args
.
bias_tensor
->
raw_ptr
,
co
*
args
.
bias_layout
->
dtype
.
size
(),
cudaMemcpyDeviceToDevice
,
stream
));
}
else
{
nchw2nchw64
(
*
(
args
.
filter_tensor
),
{
ws_filter
,
layouts
[
1
]});
}
// reformat z
nchw2nchw64
(
*
(
args
.
z_tensor
),
{
ws_z
,
layouts
[
3
]});
TensorND
src_
{
ws_src
,
layouts
[
0
]},
filter_
{
ws_filter
,
layouts
[
1
]},
bias_
{
ws_bias
,
layouts
[
2
]},
z_
{
ws_z
,
layouts
[
3
]},
dst_
{
ws_dst
,
layouts
[
4
]};
auto
conv_op
=
args
.
opr
->
handle
()
->
create_operator
<
ConvBiasForward
>
();
conv_op
->
param
()
=
args
.
opr
->
param
();
using
Format
=
param
::
ConvBias
::
Format
;
conv_op
->
param
().
format
=
Format
::
NCHW64
;
ExecArgs
args_
{
reinterpret_cast
<
ConvBiasForwardImpl
*>
(
conv_op
.
get
()),
src_
,
filter_
,
bias_
,
z_
,
dst_
,
ws
.
get_workspace
(
3
)};
m_underlying_algo
.
exec
(
args_
);
// reformat dst
nchw642nchw
(
dst_
,
{
args
.
dst_tensor
->
raw_ptr
,
args
.
dst_tensor
->
layout
});
}
SmallVector
<
TensorLayout
>
ConvBiasForwardImpl
::
AlgoFallbackNCHWQS4
::
make_underlying_tensor_layout
(
const
TensorLayout
&
src
,
const
TensorLayout
&
filter
,
const
TensorLayout
&
bias
,
const
TensorLayout
&
z
,
const
TensorLayout
&
dst
)
const
{
size_t
n
=
src
[
0
],
ci
=
src
[
1
],
hi
=
src
[
2
],
wi
=
src
[
3
];
size_t
co
=
dst
[
1
],
ho
=
dst
[
2
],
wo
=
dst
[
3
];
size_t
fh
=
filter
[
2
],
fw
=
filter
[
3
];
SmallVector
<
TensorLayout
>
rst
;
rst
.
emplace_back
(
TensorLayout
{{
n
,
div_ceil
(
ci
,
64
_z
),
hi
,
wi
,
64
},
src
.
dtype
});
rst
.
emplace_back
(
TensorLayout
{{
round_up
(
co
,
64
_z
),
div_ceil
(
ci
,
64
_z
),
fh
,
fw
,
64
},
filter
.
dtype
});
rst
.
emplace_back
(
TensorLayout
{{
1
,
div_ceil
(
co
,
64
_z
),
1
,
1
,
64
},
bias
.
dtype
});
if
(
z
.
ndim
>
0
)
{
rst
.
emplace_back
(
TensorLayout
{{
n
,
div_ceil
(
co
,
64
_z
),
ho
,
wo
,
64
},
z
.
dtype
});
}
else
{
rst
.
emplace_back
(
TensorLayout
{});
}
rst
.
emplace_back
(
TensorLayout
{{
n
,
div_ceil
(
co
,
64
_z
),
ho
,
wo
,
64
},
dst
.
dtype
});
return
rst
;
}
WorkspaceBundle
ConvBiasForwardImpl
::
AlgoFallbackNCHWQS4
::
get_workspace_bundle
(
void
*
raw_ptr
,
const
SizeArgs
&
args
)
const
{
auto
layouts
=
make_underlying_tensor_layout
(
*
(
args
.
src_layout
),
*
(
args
.
filter_layout
),
*
(
args
.
bias_layout
),
*
(
args
.
z_layout
),
*
(
args
.
dst_layout
));
size_t
ws_size_src
=
layouts
[
0
].
span
().
dist_byte
();
size_t
ws_size_filter
=
layouts
[
1
].
span
().
dist_byte
();
size_t
ws_size_dst
=
layouts
.
back
().
span
().
dist_byte
();
size_t
co
=
args
.
filter_layout
->
operator
[](
0
);
if
(
co
%
64
!=
0
)
{
size_t
ci
=
args
.
filter_layout
->
operator
[](
1
),
fh
=
args
.
filter_layout
->
operator
[](
2
),
fw
=
args
.
filter_layout
->
operator
[](
3
);
ws_size_filter
+=
TensorLayout
({
round_up
(
co
,
64
_z
),
ci
,
fh
,
fw
},
args
.
filter_layout
->
dtype
)
.
span
()
.
dist_byte
();
ws_size_filter
+=
sizeof
(
int
)
*
round_up
(
co
,
64
_z
);
}
auto
conv_op
=
args
.
opr
->
handle
()
->
create_operator
<
ConvBiasForward
>
();
conv_op
->
param
()
=
args
.
opr
->
param
();
using
Format
=
param
::
ConvBias
::
Format
;
conv_op
->
param
().
format
=
Format
::
NCHW64
;
SizeArgs
args_
{
reinterpret_cast
<
ConvBiasForwardImpl
*>
(
conv_op
.
get
()),
layouts
[
0
],
layouts
[
1
],
layouts
[
2
],
layouts
[
3
],
layouts
[
4
]};
size_t
ws_size_underlying_algo
=
m_underlying_algo
.
get_workspace_in_bytes
(
args_
);
if
(
args
.
z_layout
->
ndim
>
0
)
{
size_t
ws_size_z
=
layouts
[
3
].
span
().
dist_byte
();
return
WorkspaceBundle
{
raw_ptr
,
{
ws_size_src
,
ws_size_filter
,
ws_size_dst
,
ws_size_underlying_algo
,
ws_size_z
}};
}
return
WorkspaceBundle
{
raw_ptr
,
{
ws_size_src
,
ws_size_filter
,
ws_size_dst
,
ws_size_underlying_algo
}};
}
// vim: syntax=cpp.doxygen
dnn/src/cuda/conv_bias/helper.cpp
浏览文件 @
24a38781
...
...
@@ -136,7 +136,8 @@ void ConvBiasDesc::set_conv(DType data_type, const param::ConvBias& param,
namespace
conv_bias
{
bool
is_cudnn_supported
(
const
BiasForwardSizeArgs
&
args
)
{
if
(
args
.
src_layout
->
dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS4
&&
if
((
args
.
src_layout
->
dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS4
||
args
.
src_layout
->
dtype
.
enumv
()
==
DTypeEnum
::
Quantized4Asymm
)
&&
args
.
filter_layout
->
dtype
.
enumv
()
==
DTypeEnum
::
QuantizedS4
)
return
false
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录