#include "machete_mm_launcher.cuh" #include "machete_prepack_launcher.cuh" #include "core/scalar_type.hpp" namespace machete { using namespace aphrodite; // // Utils (type dispatching) // template static auto scalar_type_dispatch(ScalarType const& type, Fn fn) { if (type == aphrodite::kU4) { return fn(cutlass::uint4b_t{}); } else if (type == aphrodite::kU8) { return fn(cutlass::uint8_t{}); } else if (type == aphrodite::kU4B8) { return fn(cutlass::aphrodite_uint4b8_t{}); } else if (type == aphrodite::kU8B128) { return fn(cutlass::aphrodite_uint8b128_t{}); } else { TORCH_CHECK(false, "Unsupported type ", type.str()); } } #define AT_DISPATCH_CASE_SUPPORTED_COMPUTE_TYPES(...) \ AT_DISPATCH_CASE_REDUCED_FLOATING_TYPES(__VA_ARGS__) #define AT_DISPATCH_SUPPORTED_COMPUTE_TYPES(TYPE, NAME, ...) \ AT_DISPATCH_SWITCH(TYPE, NAME, \ AT_DISPATCH_CASE_SUPPORTED_COMPUTE_TYPES(__VA_ARGS__)) // // Interface // std::vector supported_schedules(ScalarTypeTorchPtr const& btype) { return scalar_type_dispatch(*btype, [&](auto BType) { return GemmDispatcher::supported_schedules(); }); } torch::Tensor gemm(torch::Tensor const& A, torch::Tensor const& B, ScalarTypeTorchPtr const& btype, c10::optional const& scales, c10::optional const& zeros, c10::optional group_size, c10::optional const& C, c10::optional alpha, c10::optional beta, c10::optional schedule) { auto args = PyTorchArguments{.A = A, .B = B, .scales = scales, .zeros = zeros, .group_size = group_size, .C = C, .alpha = alpha, .beta = beta, .schedule = schedule}; return scalar_type_dispatch(*btype, [&](auto BType) { return AT_DISPATCH_SUPPORTED_COMPUTE_TYPES( A.scalar_type(), "machete_gemm", [&] { using ComputeType = equivalent_cutlass_type_t; return GemmDispatcher::dispatch(args); }); }); } torch::Tensor prepack_B(torch::Tensor const& B, ScalarTypeTorchPtr const& btype) { return scalar_type_dispatch(*btype, [&](auto BType) { return PrepackBDispatcher::dispatch(B); }); } }; // namespace machete