Skip to main content

Mojo struct

KVCacheMHAOperand

@register_passable(trivial) struct KVCacheMHAOperand[cache_t: KVCacheT]

An implementation for mo.opaque KVCacheT arguments to MHA kernels.

We can eventually remove this trait and just add it as a sub-trait in the KVCacheT type, but we need to solve some cyclic dependencies first.

Fields

  • cache (cache_t):

Implemented traits

AnyType, Copyable, MHAOperand, Movable, UnknownDestructibility

Aliases

dtype

alias dtype = get_witness(cache_t, kv_cache::types::KVCacheT, dtype)

Methods

__init__

__init__(cache: cache_t) -> Self

block_paged_ptr

block_paged_ptr[tile_size: Int](self, batch_idx: SIMD[uint32, 1], start_tok_idx: SIMD[uint32, 1], head_idx: SIMD[uint32, 1], head_dim_idx: SIMD[uint32, 1] = 0) -> UnsafePointer[SIMD[get_witness(cache_t, kv_cache::types::KVCacheT, dtype), 1]]

cache_length

cache_length(self, batch_idx: Int) -> Int

max_context_length

max_context_length(self) -> SIMD[uint32, 1]

Was this page helpful?