forked from google/XNNPACK
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathx8-packq.cc
110 lines (91 loc) · 2.58 KB
/
x8-packq.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
// Copyright 2024 Google LLC
//
// This source code is licensed under the BSD-style license found in the
// LICENSE file in the root directory of this source tree.
#include <cstddef>
#include <string>
#include <gtest/gtest.h>
#include "xnnpack/common.h"
#include "xnnpack/isa-checks.h"
#include "xnnpack/packq.h"
#include "packq-microkernel-tester.h"
namespace {
struct XnnTestParam {
const char *name;
xnn_x8_packq_f32qp8_ukernel_fn ukernel;
uint64_t arch_flags;
int unroll;
};
class XnnTest : public testing::TestWithParam<XnnTestParam> {
};
std::string GetTestName(const testing::TestParamInfo<XnnTest::ParamType>& info) {
return info.param.name;
}
#define XNN_UKERNEL(arch_flags, ukernel, unroll) \
{ #ukernel, ukernel, arch_flags, unroll },
const XnnTestParam xnn_test_params[] = {
#include "src/x8-packq/x8-packq.h"
};
#undef XNN_UKERNEL
} // namespace
namespace xnnpack {
TEST_P(XnnTest, k_div_kr_m_div_mr) {
TEST_REQUIRES_ARCH_FLAGS(GetParam().arch_flags);
for (size_t kr = 1; kr <= 4; kr++) {
for (size_t mr = 1; mr <= 4; mr++) {
PackQMicrokernelTester()
.m(mr * GetParam().unroll * 10)
.k(kr * GetParam().unroll * 10)
.mr(mr)
.kr(kr)
.Test(GetParam().ukernel);
}
}
}
TEST_P(XnnTest, k_div_kr_m_div_mr_kr_div_sr) {
TEST_REQUIRES_ARCH_FLAGS(GetParam().arch_flags);
for (size_t sr = 1; sr <= 4; sr++) {
for (size_t kr = sr; kr <= 4 * sr; kr += sr) {
for (size_t mr = 1; mr <= 4; mr++) {
PackQMicrokernelTester()
.m(mr * GetParam().unroll * 10)
.k(kr * GetParam().unroll * 10)
.mr(mr)
.kr(kr)
.sr(sr)
.Test(GetParam().ukernel);
}
}
}
}
TEST_P(XnnTest, k_div_kr_m_lt_mr) {
TEST_REQUIRES_ARCH_FLAGS(GetParam().arch_flags);
for (size_t kr = 1; kr <= 4; kr++) {
for (size_t mr = 2; mr <= 4; mr++) {
PackQMicrokernelTester()
.m(mr - 1)
.k(kr * GetParam().unroll * 10)
.mr(mr)
.kr(kr)
.Test(GetParam().ukernel);
}
}
}
TEST_P(XnnTest, k_div_kr_m_gt_mr) {
TEST_REQUIRES_ARCH_FLAGS(GetParam().arch_flags);
for (size_t kr = 1; kr <= 4; kr++) {
for (size_t mr = 2; mr <= 4; mr++) {
PackQMicrokernelTester()
.m(2 * mr + 1)
.k(kr * GetParam().unroll * 10)
.mr(mr)
.kr(kr)
.Test(GetParam().ukernel);
}
}
}
INSTANTIATE_TEST_SUITE_P(x8_packq,
XnnTest,
testing::ValuesIn(xnn_test_params),
GetTestName);
} // namespace xnnpack