| | #pragma once |
| | |
| | * __device__ datatypes vectorized by 4 |
| | */ |
| |
|
| | |
| | |
| | #include <c10/util/Float8_e4m3fnuz.h> |
| | #include <c10/util/Float8_e4m3fn.h> |
| |
|
| | namespace vllm { |
| |
|
| | |
| | template <typename scalar_t> |
| | struct __align__(8) vec4_t { |
| | scalar_t x; |
| | scalar_t y; |
| | scalar_t z; |
| | scalar_t w; |
| | }; |
| |
|
| | template <typename quant_type_t> |
| | struct __align__(4) q8x4_t { |
| | static_assert(std::is_same_v<quant_type_t, int8_t> || |
| | std::is_same_v<quant_type_t, c10::Float8_e4m3fn> || |
| | std::is_same_v<quant_type_t, c10::Float8_e4m3fnuz>); |
| | quant_type_t x; |
| | quant_type_t y; |
| | quant_type_t z; |
| | quant_type_t w; |
| | }; |
| |
|
| | } |
| |
|