25 #ifdef ARM_COMPUTE_ENABLE_SVE
27 #include "../std_transforms_sve.hpp"
28 #include "../performance_parameters.hpp"
31 const int8_t *, const int8_t *, \
32 int32_t *, int, int, int
37 void sve_interleaved_s8s32_mmla_8x3VL( ARGLIST );
39 class cls_sve_interleaved_s8s32_mmla_8x3VL
42 typedef int8_t operand_type;
43 typedef int32_t result_type;
45 typedef void (*kern_type)( ARGLIST );
48 static constexpr
unsigned int out_height()
53 static unsigned int out_width()
55 return get_vector_length<int32_t>() * 3;
58 static constexpr
unsigned int k_unroll()
64 StdTransformsSVE<operand_type, result_type, 8, 6, 8, 2> transforms = {};
65 StdTransformsSVE<operand_type, result_type, 8, 6, 8, 2, true> transforms_quantized = {};
67 static inline PerformanceParameters get_performance_parameters(
const CPUInfo *
ci)
70 if (std::is_same<T, int32_t>::value) {
73 return { 61.98, 3.90, 7.94 };
75 return { 123.42, 5.00, 11.52 };
77 return { 43.14, 3.62, 2.90 };
82 if (std::is_same<T, int8_t>::value) {
85 return { 61.97, 3.64, 0.50 };
87 return { 95.28, 7.99, 0.79 };
89 return { 43.36, 1.86, 0.28 };
97 kern_type kernel=sve_interleaved_s8s32_mmla_8x3VL;
98 cls_sve_interleaved_s8s32_mmla_8x3VL(
const CPUInfo *)
106 #endif // ARM_COMPUTE_ENABLE_SVE