mirror of
https://github.com/hpcaitech/ColossalAI.git
synced 2025-09-10 13:30:19 +00:00
[Inference/Kernel] refactor kvcache manager and rotary_embedding and kvcache_memcpy oper… (#5663)
* refactor kvcache manager and rotary_embedding and kvcache_memcpy operator * refactor decode_kv_cache_memcpy * enable alibi in pagedattention
This commit is contained in:
@@ -20,7 +20,7 @@ inference_ops = InferenceOpsLoader().load()
|
||||
configs = [
|
||||
triton.testing.Benchmark(
|
||||
x_names=["MAX_NUM_BLOCKS_PER_SEQ"],
|
||||
x_vals=[2**i for i in range(3, 8)],
|
||||
x_vals=[2**i for i in range(2, 8)],
|
||||
line_arg="provider",
|
||||
line_vals=[
|
||||
"vllm_paged_decoding_attention",
|
||||
@@ -113,6 +113,8 @@ def benchmark_flash_decoding_attention(
|
||||
kv_max_split_num = (max_seq_len_across_batch + BLOCK_SIZE - 1) // BLOCK_SIZE
|
||||
output = torch.empty((BATCH_SIZE, NUM_ATTN_HEADS, HEAD_SIZE), dtype=dtype, device=device)
|
||||
sm_scale = 1.0 / (HEAD_SIZE**0.5)
|
||||
alibi_slopes = None
|
||||
kv_scale = 1.0
|
||||
|
||||
mid_output = torch.empty(
|
||||
size=(BATCH_SIZE, NUM_ATTN_HEADS, kv_max_split_num, HEAD_SIZE), dtype=torch.float32, device=device
|
||||
@@ -136,6 +138,7 @@ def benchmark_flash_decoding_attention(
|
||||
max_seq_len_across_batch,
|
||||
alibi_slopes,
|
||||
"auto",
|
||||
kv_scale,
|
||||
)
|
||||
elif provider == "triton_flash_decoding_attention":
|
||||
fn = lambda: flash_decoding_attention(
|
||||
@@ -164,6 +167,7 @@ def benchmark_flash_decoding_attention(
|
||||
max_seq_len_across_batch,
|
||||
mid_output,
|
||||
mid_output_lse,
|
||||
alibi_slopes,
|
||||
sm_scale,
|
||||
)
|
||||
else:
|
||||
|
Reference in New Issue
Block a user