27 #include "../std_transforms_fixed.hpp"
28 #include "../performance_parameters.hpp"
31 unsigned int, const unsigned int *, \
32 IndirectInputArg<int8_t>, \
35 IndirectOutputArg<int8_t>, \
36 const Requantize32 *, const int32_t *, unsigned int
41 void a64_hybrid_s8qa_dot_4x16( ARGLIST );
42 void a64_hybrid_s8qa_dot_4x16_a55( ARGLIST );
44 class cls_a64_hybrid_s8qa_dot_4x16
47 typedef int8_t lhs_operand_type;
48 typedef int8_t rhs_operand_type;
49 typedef int8_t result_type;
51 typedef void (*kern_type)( ARGLIST );
54 static constexpr
unsigned int out_height()
59 static unsigned int out_width()
64 static constexpr
unsigned int k_unroll()
69 static constexpr
bool supports_accumulate()
74 StdTransformsFixed<rhs_operand_type, result_type, 4, 16, 4> transforms = {};
76 static inline PerformanceParameters get_performance_parameters(
const CPUInfo *
ci)
78 if (std::is_same<T, int8_t>::value) {
95 kern_type kernel=a64_hybrid_s8qa_dot_4x16;
96 cls_a64_hybrid_s8qa_dot_4x16(
const CPUInfo *
ci)
101 case CPUModel::A55r1:
102 kernel=a64_hybrid_s8qa_dot_4x16_a55;
111 #endif // __aarch64__