Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
5c3b4e95
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看板
提交
5c3b4e95
编写于
7月 13, 2022
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(x86/rvv): opt AlgoFP32WinogradF63_4x4_NCHW44
GitOrigin-RevId: 0cd0089982fdeea0d432da8c25a5e304ca65009a
上级
fa59a7b0
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
108 addition
and
56 deletion
+108
-56
dnn/src/fallback/conv_bias/gi/fp32/strategy_f63_mk4_nchw44.cpp
...rc/fallback/conv_bias/gi/fp32/strategy_f63_mk4_nchw44.cpp
+70
-56
dnn/src/fallback/general_intrinsic/gi_float.h
dnn/src/fallback/general_intrinsic/gi_float.h
+15
-0
dnn/test/fallback/gi.cpp
dnn/test/fallback/gi.cpp
+23
-0
未找到文件。
dnn/src/fallback/conv_bias/gi/fp32/strategy_f63_mk4_nchw44.cpp
浏览文件 @
5c3b4e95
...
@@ -73,9 +73,21 @@ struct InputTransformF63_NCHW44 {
...
@@ -73,9 +73,21 @@ struct InputTransformF63_NCHW44 {
size_t
icb
=
ic
/
pack_size
;
size_t
icb
=
ic
/
pack_size
;
GI_FLOAT32_t
d0
,
d1
,
d2
,
d3
,
d4
,
d5
,
d6
,
d7
;
GI_FLOAT32_t
d0
,
d1
,
d2
,
d3
,
d4
,
d5
,
d6
,
d7
;
#if defined(GI_TARGET_X86) || defined(GI_RVV_INTRINSICS)
//! x86 and rvv GiSimdFmaLane API is slowly, as an alternate, use
//! GiMultiplyAddScalarFloat32
#define MADD(a, b, c, d) GiMultiplyAddScalarFloat32(a, b, *(c + d))
#define MSUB(a, b, c, d) GiMultiplySubScalarFloat32(a, b, *(c + d))
const
float
*
v0
=
input_parameters
+
0
;
const
float
*
v1
=
input_parameters
+
4
;
const
float
*
v2
=
input_parameters
+
8
;
#else
#define MADD(a, b, c, d) GiSimdFmaLane(a, b, c, d)
#define MSUB(a, b, c, d) GiFmsqLaneQFloat32(a, b, c, d)
GI_FLOAT32_t
v0
=
GiLoadFloat32
(
input_parameters
+
0
);
GI_FLOAT32_t
v0
=
GiLoadFloat32
(
input_parameters
+
0
);
GI_FLOAT32_t
v1
=
GiLoadFloat32
(
input_parameters
+
4
);
GI_FLOAT32_t
v1
=
GiLoadFloat32
(
input_parameters
+
4
);
GI_FLOAT32_t
v2
=
GiLoadFloat32
(
input_parameters
+
8
);
GI_FLOAT32_t
v2
=
GiLoadFloat32
(
input_parameters
+
8
);
#endif
//! B
//! B
//! 1 0 0 0 0 0 0 0
//! 1 0 0 0 0 0 0 0
...
@@ -105,39 +117,39 @@ struct InputTransformF63_NCHW44 {
...
@@ -105,39 +117,39 @@ struct InputTransformF63_NCHW44 {
t##i##0 = GiSubtractFloat32(t##i##0, d6); \
t##i##0 = GiSubtractFloat32(t##i##0, d6); \
t##i##1 = GiAddFloat32(t##i##1, d1); \
t##i##1 = GiAddFloat32(t##i##1, d1); \
t##i##2 = GiSubtractFloat32(t##i##2, d1); \
t##i##2 = GiSubtractFloat32(t##i##2, d1); \
t##i##3 =
GiSimdFmaLane(t##i##3, d1, v0, 2);
\
t##i##3 =
MADD(t##i##3, d1, v0, 2);
\
t##i##4 =
GiFmsqLaneQFloat32(t##i##4, d1, v0, 2);
\
t##i##4 =
MSUB(t##i##4, d1, v0, 2);
\
t##i##5 =
GiSimdFmaLane(t##i##5, d1, v1, 2);
\
t##i##5 =
MADD(t##i##5, d1, v1, 2);
\
t##i##6 =
GiFmsqLaneQFloat32(t##i##6, d1, v1, 2);
\
t##i##6 =
MSUB(t##i##6, d1, v1, 2);
\
t##i##7 = GiSubtractFloat32(t##i##7, d1); \
t##i##7 = GiSubtractFloat32(t##i##7, d1); \
t##i##0 =
GiFmsqLaneQFloat32(t##i##0, d2, v0, 0);
\
t##i##0 =
MSUB(t##i##0, d2, v0, 0);
\
t##i##1 = GiAddFloat32(t##i##1, d2); \
t##i##1 = GiAddFloat32(t##i##1, d2); \
t##i##2 = GiAddFloat32(t##i##2, d2); \
t##i##2 = GiAddFloat32(t##i##2, d2); \
t##i##3 =
GiSimdFmaLane(t##i##3, d2, v0, 3);
\
t##i##3 =
MADD(t##i##3, d2, v0, 3);
\
t##i##4 =
GiSimdFmaLane(t##i##4, d2, v0, 3);
\
t##i##4 =
MADD(t##i##4, d2, v0, 3);
\
t##i##5 =
GiSimdFmaLane(t##i##5, d2, v1, 3);
\
t##i##5 =
MADD(t##i##5, d2, v1, 3);
\
t##i##6 =
GiSimdFmaLane(t##i##6, d2, v1, 3);
\
t##i##6 =
MADD(t##i##6, d2, v1, 3);
\
t##i##1 =
GiFmsqLaneQFloat32(t##i##1, d3, v0, 1);
\
t##i##1 =
MSUB(t##i##1, d3, v0, 1);
\
t##i##2 =
GiSimdFmaLane(t##i##2, d3, v0, 1);
\
t##i##2 =
MADD(t##i##2, d3, v0, 1);
\
t##i##3 =
GiFmsqLaneQFloat32(t##i##3, d3, v1, 0);
\
t##i##3 =
MSUB(t##i##3, d3, v1, 0);
\
t##i##4 =
GiSimdFmaLane(t##i##4, d3, v1, 0);
\
t##i##4 =
MADD(t##i##4, d3, v1, 0);
\
t##i##5 =
GiFmsqLaneQFloat32(t##i##5, d3, v1, 0);
\
t##i##5 =
MSUB(t##i##5, d3, v1, 0);
\
t##i##6 =
GiSimdFmaLane(t##i##6, d3, v1, 0);
\
t##i##6 =
MADD(t##i##6, d3, v1, 0);
\
t##i##7 =
GiSimdFmaLane(t##i##7, d3, v0, 0);
\
t##i##7 =
MADD(t##i##7, d3, v0, 0);
\
t##i##0 =
GiSimdFmaLane(t##i##0, d4, v0, 0);
\
t##i##0 =
MADD(t##i##0, d4, v0, 0);
\
t##i##1 =
GiFmsqLaneQFloat32(t##i##1, d4, v0, 1);
\
t##i##1 =
MSUB(t##i##1, d4, v0, 1);
\
t##i##2 =
GiFmsqLaneQFloat32(t##i##2, d4, v0, 1);
\
t##i##2 =
MSUB(t##i##2, d4, v0, 1);
\
t##i##3 =
GiFmsqLaneQFloat32(t##i##3, d4, v1, 1);
\
t##i##3 =
MSUB(t##i##3, d4, v1, 1);
\
t##i##4 =
GiFmsqLaneQFloat32(t##i##4, d4, v1, 1);
\
t##i##4 =
MSUB(t##i##4, d4, v1, 1);
\
t##i##5 =
GiFmsqLaneQFloat32(t##i##5, d4, v2, 0);
\
t##i##5 =
MSUB(t##i##5, d4, v2, 0);
\
t##i##6 =
GiFmsqLaneQFloat32(t##i##6, d4, v2, 0);
\
t##i##6 =
MSUB(t##i##6, d4, v2, 0);
\
t##i##1 = GiAddFloat32(t##i##1, d5); \
t##i##1 = GiAddFloat32(t##i##1, d5); \
t##i##2 = GiSubtractFloat32(t##i##2, d5); \
t##i##2 = GiSubtractFloat32(t##i##2, d5); \
t##i##3 =
GiSimdFmaLane(t##i##3, d5, v1, 2);
\
t##i##3 =
MADD(t##i##3, d5, v1, 2);
\
t##i##4 =
GiFmsqLaneQFloat32(t##i##4, d5, v1, 2);
\
t##i##4 =
MSUB(t##i##4, d5, v1, 2);
\
t##i##5 =
GiSimdFmaLane(t##i##5, d5, v0, 2);
\
t##i##5 =
MADD(t##i##5, d5, v0, 2);
\
t##i##6 =
GiFmsqLaneQFloat32(t##i##6, d5, v0, 2);
\
t##i##6 =
MSUB(t##i##6, d5, v0, 2);
\
t##i##7 =
GiFmsqLaneQFloat32
(t##i##7, d5, v0, 0);
t##i##7 =
MSUB
(t##i##7, d5, v0, 0);
UNROLL_CALL_RAW
(
8
,
cb
);
UNROLL_CALL_RAW
(
8
,
cb
);
#undef cb
#undef cb
...
@@ -153,39 +165,39 @@ struct InputTransformF63_NCHW44 {
...
@@ -153,39 +165,39 @@ struct InputTransformF63_NCHW44 {
d0 = GiSubtractFloat32(d0, t6##i); \
d0 = GiSubtractFloat32(d0, t6##i); \
d1 = GiAddFloat32(d1, t1##i); \
d1 = GiAddFloat32(d1, t1##i); \
d2 = GiSubtractFloat32(d2, t1##i); \
d2 = GiSubtractFloat32(d2, t1##i); \
d3 =
GiSimdFmaLane(d3, t1##i, v0, 2);
\
d3 =
MADD(d3, t1##i, v0, 2);
\
d4 =
GiFmsqLaneQFloat32(d4, t1##i, v0, 2);
\
d4 =
MSUB(d4, t1##i, v0, 2);
\
d5 =
GiSimdFmaLane(d5, t1##i, v1, 2);
\
d5 =
MADD(d5, t1##i, v1, 2);
\
d6 =
GiFmsqLaneQFloat32(d6, t1##i, v1, 2);
\
d6 =
MSUB(d6, t1##i, v1, 2);
\
d7 = GiSubtractFloat32(d7, t1##i); \
d7 = GiSubtractFloat32(d7, t1##i); \
d0 =
GiFmsqLaneQFloat32(d0, t2##i, v0, 0);
\
d0 =
MSUB(d0, t2##i, v0, 0);
\
d1 = GiAddFloat32(d1, t2##i); \
d1 = GiAddFloat32(d1, t2##i); \
d2 = GiAddFloat32(d2, t2##i); \
d2 = GiAddFloat32(d2, t2##i); \
d3 =
GiSimdFmaLane(d3, t2##i, v0, 3);
\
d3 =
MADD(d3, t2##i, v0, 3);
\
d4 =
GiSimdFmaLane(d4, t2##i, v0, 3);
\
d4 =
MADD(d4, t2##i, v0, 3);
\
d5 =
GiSimdFmaLane(d5, t2##i, v1, 3);
\
d5 =
MADD(d5, t2##i, v1, 3);
\
d6 =
GiSimdFmaLane(d6, t2##i, v1, 3);
\
d6 =
MADD(d6, t2##i, v1, 3);
\
d1 =
GiFmsqLaneQFloat32(d1, t3##i, v0, 1);
\
d1 =
MSUB(d1, t3##i, v0, 1);
\
d2 =
GiSimdFmaLane(d2, t3##i, v0, 1);
\
d2 =
MADD(d2, t3##i, v0, 1);
\
d3 =
GiFmsqLaneQFloat32(d3, t3##i, v1, 0);
\
d3 =
MSUB(d3, t3##i, v1, 0);
\
d4 =
GiSimdFmaLane(d4, t3##i, v1, 0);
\
d4 =
MADD(d4, t3##i, v1, 0);
\
d5 =
GiFmsqLaneQFloat32(d5, t3##i, v1, 0);
\
d5 =
MSUB(d5, t3##i, v1, 0);
\
d6 =
GiSimdFmaLane(d6, t3##i, v1, 0);
\
d6 =
MADD(d6, t3##i, v1, 0);
\
d7 =
GiSimdFmaLane(d7, t3##i, v0, 0);
\
d7 =
MADD(d7, t3##i, v0, 0);
\
d0 =
GiSimdFmaLane(d0, t4##i, v0, 0);
\
d0 =
MADD(d0, t4##i, v0, 0);
\
d1 =
GiFmsqLaneQFloat32(d1, t4##i, v0, 1);
\
d1 =
MSUB(d1, t4##i, v0, 1);
\
d2 =
GiFmsqLaneQFloat32(d2, t4##i, v0, 1);
\
d2 =
MSUB(d2, t4##i, v0, 1);
\
d3 =
GiFmsqLaneQFloat32(d3, t4##i, v1, 1);
\
d3 =
MSUB(d3, t4##i, v1, 1);
\
d4 =
GiFmsqLaneQFloat32(d4, t4##i, v1, 1);
\
d4 =
MSUB(d4, t4##i, v1, 1);
\
d5 =
GiFmsqLaneQFloat32(d5, t4##i, v2, 0);
\
d5 =
MSUB(d5, t4##i, v2, 0);
\
d6 =
GiFmsqLaneQFloat32(d6, t4##i, v2, 0);
\
d6 =
MSUB(d6, t4##i, v2, 0);
\
d1 = GiAddFloat32(d1, t5##i); \
d1 = GiAddFloat32(d1, t5##i); \
d2 = GiSubtractFloat32(d2, t5##i); \
d2 = GiSubtractFloat32(d2, t5##i); \
d3 =
GiSimdFmaLane(d3, t5##i, v1, 2);
\
d3 =
MADD(d3, t5##i, v1, 2);
\
d4 =
GiFmsqLaneQFloat32(d4, t5##i, v1, 2);
\
d4 =
MSUB(d4, t5##i, v1, 2);
\
d5 =
GiSimdFmaLane(d5, t5##i, v0, 2);
\
d5 =
MADD(d5, t5##i, v0, 2);
\
d6 =
GiFmsqLaneQFloat32(d6, t5##i, v0, 2);
\
d6 =
MSUB(d6, t5##i, v0, 2);
\
d7 =
GiFmsqLaneQFloat32(d7, t5##i, v0, 0);
\
d7 =
MSUB(d7, t5##i, v0, 0);
\
GiStoreFloat32( \
GiStoreFloat32( \
input_transform_buf + \
input_transform_buf + \
(0 * alpha + i) * ICB * nr_units_in_tile * pack_size + \
(0 * alpha + i) * ICB * nr_units_in_tile * pack_size + \
...
@@ -228,6 +240,8 @@ struct InputTransformF63_NCHW44 {
...
@@ -228,6 +240,8 @@ struct InputTransformF63_NCHW44 {
d7);
d7);
UNROLL_CALL_RAW
(
8
,
cb
);
UNROLL_CALL_RAW
(
8
,
cb
);
#undef cb
#undef cb
#undef MADD
#undef MSUB
}
}
};
};
...
...
dnn/src/fallback/general_intrinsic/gi_float.h
浏览文件 @
5c3b4e95
...
@@ -889,6 +889,21 @@ GI_FLOAT32_t GiMultiplyAddScalarFloat32(
...
@@ -889,6 +889,21 @@ GI_FLOAT32_t GiMultiplyAddScalarFloat32(
#endif
#endif
}
}
GI_FORCEINLINE
GI_FLOAT32_t
GiMultiplySubScalarFloat32
(
GI_FLOAT32_t
VectorSub
,
GI_FLOAT32_t
Vector
,
float
Scalar
)
{
#if defined(GI_NEON_INTRINSICS)
return
vmlsq_n_f32
(
VectorSub
,
Vector
,
Scalar
);
#elif defined(GI_SSE2_INTRINSICS)
return
_mm_sub_ps
(
VectorSub
,
_mm_mul_ps
(
Vector
,
GiBroadcastFloat32
(
Scalar
)));
#elif defined(GI_RVV_INTRINSICS)
return
vfnmsub_vf_f32m1
(
Vector
,
Scalar
,
VectorSub
,
GI_SIMD_LEN_BYTE
/
sizeof
(
float
));
#else
return
VectorSub
-
Vector
*
Scalar
;
#endif
}
#if defined(GI_NEON_INTRINSICS)
#if defined(GI_NEON_INTRINSICS)
#define GIMULTIPLYADDLANFLOAT32(i) \
#define GIMULTIPLYADDLANFLOAT32(i) \
GI_FORCEINLINE GI_FLOAT32_t GiMultiplyAddLan##i##Float32( \
GI_FORCEINLINE GI_FLOAT32_t GiMultiplyAddLan##i##Float32( \
...
...
dnn/test/fallback/gi.cpp
浏览文件 @
5c3b4e95
...
@@ -1808,6 +1808,29 @@ TEST_F(FALLBACK, GiMultiplyAddScalarFloat32) {
...
@@ -1808,6 +1808,29 @@ TEST_F(FALLBACK, GiMultiplyAddScalarFloat32) {
assert_eq
((
float
*
)
&
ret
,
naive
);
assert_eq
((
float
*
)
&
ret
,
naive
);
}
}
TEST_F
(
FALLBACK
,
GiMultiplySubScalarFloat32
)
{
GI_FLOAT32_t
src0
,
src1
,
ret
;
std
::
vector
<
float
>
s0
{
1.1
f
,
2.2
f
,
3.5
f
,
4.9
f
};
std
::
vector
<
float
>
s1
{
2312.1
f
,
345.244
f
,
3.59
f
,
-
12.8
f
};
s0
.
resize
(
SIMD_LEN
);
s1
.
resize
(
SIMD_LEN
);
init
((
float
*
)
&
src0
,
s0
);
init
((
float
*
)
&
src1
,
s1
);
float
scalar
=
3.1415
;
force_memset_ret
((
void
*
)
&
ret
,
GI_SIMD_LEN_BYTE
);
ret
=
GiMultiplySubScalarFloat32
(
src0
,
src1
,
scalar
);
std
::
vector
<
float
>
naive
;
for
(
size_t
i
=
0
;
i
<
SIMD_LEN
;
i
++
)
{
naive
.
push_back
(
s0
[
i
]
-
s1
[
i
]
*
scalar
);
}
assert_eq
((
float
*
)
&
ret
,
naive
);
}
TEST_F
(
FALLBACK
,
GiMultiplyAddLanXXFloat32
)
{
TEST_F
(
FALLBACK
,
GiMultiplyAddLanXXFloat32
)
{
GI_FLOAT32_t
src0
,
src1
,
src2
,
ret
;
GI_FLOAT32_t
src0
,
src1
,
src2
,
ret
;
std
::
vector
<
float
>
s0
{
1.1
f
,
2.2
f
,
3.5
f
,
4.9
f
};
std
::
vector
<
float
>
s0
{
1.1
f
,
2.2
f
,
3.5
f
,
4.9
f
};
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录