sglang 0.4.6.post5__py3-none-any.whl → 0.4.7.post1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- sglang/__init__.py +2 -0
- sglang/api.py +7 -0
- sglang/bench_offline_throughput.py +10 -4
- sglang/bench_one_batch_server.py +67 -11
- sglang/bench_serving.py +86 -75
- sglang/lang/backend/runtime_endpoint.py +24 -1
- sglang/lang/interpreter.py +40 -1
- sglang/lang/ir.py +27 -0
- sglang/math_utils.py +8 -0
- sglang/profiler.py +167 -0
- sglang/srt/_custom_ops.py +34 -0
- sglang/srt/configs/internvl.py +8 -12
- sglang/srt/configs/model_config.py +33 -1
- sglang/srt/constrained/base_grammar_backend.py +5 -2
- sglang/srt/constrained/llguidance_backend.py +9 -8
- sglang/srt/constrained/outlines_backend.py +5 -4
- sglang/srt/constrained/xgrammar_backend.py +18 -18
- sglang/srt/conversation.py +52 -8
- sglang/srt/custom_op.py +38 -3
- sglang/srt/debug_utils.py +74 -0
- sglang/srt/disaggregation/base/__init__.py +1 -1
- sglang/srt/disaggregation/base/conn.py +25 -11
- sglang/srt/disaggregation/common/__init__.py +5 -0
- sglang/srt/disaggregation/common/conn.py +407 -0
- sglang/srt/disaggregation/common/utils.py +42 -0
- sglang/srt/disaggregation/decode.py +261 -52
- sglang/srt/disaggregation/fake/__init__.py +1 -1
- sglang/srt/disaggregation/fake/conn.py +16 -9
- sglang/srt/disaggregation/kv_events.py +60 -5
- sglang/srt/disaggregation/launch_lb.py +140 -0
- sglang/srt/disaggregation/mini_lb.py +29 -48
- sglang/srt/disaggregation/mooncake/__init__.py +1 -1
- sglang/srt/disaggregation/mooncake/conn.py +446 -149
- sglang/srt/disaggregation/mooncake/transfer_engine.py +32 -16
- sglang/srt/disaggregation/nixl/__init__.py +6 -1
- sglang/srt/disaggregation/nixl/conn.py +134 -437
- sglang/srt/disaggregation/prefill.py +130 -43
- sglang/srt/disaggregation/utils.py +127 -86
- sglang/srt/distributed/device_communicators/pymscclpp.py +315 -0
- sglang/srt/distributed/parallel_state.py +52 -5
- sglang/srt/entrypoints/EngineBase.py +6 -0
- sglang/srt/entrypoints/engine.py +116 -5
- sglang/srt/entrypoints/http_server.py +28 -4
- sglang/srt/eplb_simulator/__init__.py +1 -0
- sglang/srt/eplb_simulator/reader.py +51 -0
- sglang/srt/function_call/base_format_detector.py +138 -86
- sglang/srt/function_call/deepseekv3_detector.py +54 -6
- sglang/srt/function_call/ebnf_composer.py +33 -19
- sglang/srt/function_call/function_call_parser.py +27 -0
- sglang/srt/function_call/llama32_detector.py +33 -14
- sglang/srt/function_call/mistral_detector.py +73 -26
- sglang/srt/function_call/pythonic_detector.py +86 -20
- sglang/srt/function_call/qwen25_detector.py +64 -10
- sglang/srt/function_call/utils.py +17 -0
- sglang/srt/hf_transformers_utils.py +4 -0
- sglang/srt/layers/activation.py +19 -0
- sglang/srt/layers/attention/aiter_backend.py +503 -125
- sglang/srt/layers/attention/base_attn_backend.py +4 -0
- sglang/srt/layers/attention/cutlass_mla_backend.py +40 -34
- sglang/srt/layers/attention/flashattention_backend.py +137 -63
- sglang/srt/layers/attention/flashinfer_backend.py +46 -3
- sglang/srt/layers/attention/flashinfer_mla_backend.py +59 -25
- sglang/srt/layers/attention/flashmla_backend.py +2 -10
- sglang/srt/layers/attention/intel_amx_backend.py +128 -0
- sglang/srt/layers/attention/tbo_backend.py +232 -0
- sglang/srt/layers/attention/torch_native_backend.py +3 -0
- sglang/srt/layers/attention/triton_backend.py +304 -65
- sglang/srt/layers/attention/triton_ops/decode_attention.py +2 -7
- sglang/srt/layers/attention/triton_ops/extend_attention.py +12 -4
- sglang/srt/layers/attention/vision.py +51 -24
- sglang/srt/layers/communicator.py +281 -197
- sglang/srt/layers/dp_attention.py +6 -5
- sglang/srt/layers/layernorm.py +30 -19
- sglang/srt/layers/linear.py +0 -4
- sglang/srt/layers/logits_processor.py +0 -12
- sglang/srt/layers/moe/cutlass_moe.py +170 -7
- sglang/srt/layers/moe/cutlass_moe_params.py +169 -0
- sglang/srt/layers/moe/ep_moe/kernels.py +33 -11
- sglang/srt/layers/moe/ep_moe/layer.py +136 -72
- sglang/srt/layers/moe/ep_moe/token_dispatcher.py +24 -45
- sglang/srt/layers/moe/fused_moe_native.py +4 -0
- sglang/srt/layers/moe/fused_moe_triton/configs/triton_3_2_0/E=257,N=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +146 -0
- sglang/srt/layers/moe/fused_moe_triton/configs/triton_3_2_0/E=257,N=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +146 -0
- sglang/srt/layers/moe/fused_moe_triton/configs/triton_3_2_0/E=257,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +146 -0
- sglang/srt/layers/moe/fused_moe_triton/configs/triton_3_2_0/E=257,N=256,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +146 -0
- sglang/srt/layers/moe/fused_moe_triton/configs/triton_3_2_0/E=257,N=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +146 -0
- sglang/srt/layers/moe/fused_moe_triton/configs/triton_3_2_0/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
- sglang/srt/layers/moe/fused_moe_triton/configs/triton_3_3_1/E=257,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +146 -0
- sglang/srt/layers/moe/fused_moe_triton/configs/triton_3_3_1/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
- sglang/srt/layers/moe/fused_moe_triton/fused_moe.py +221 -29
- sglang/srt/layers/moe/fused_moe_triton/layer.py +34 -4
- sglang/srt/layers/moe/topk.py +60 -26
- sglang/srt/layers/multimodal.py +3 -3
- sglang/srt/layers/pooler.py +56 -0
- sglang/srt/layers/quantization/__init__.py +3 -2
- sglang/srt/layers/quantization/blockwise_int8.py +3 -0
- sglang/srt/layers/quantization/compressed_tensors/compressed_tensors_moe.py +5 -0
- sglang/srt/layers/quantization/deep_gemm_wrapper/__init__.py +1 -0
- sglang/srt/layers/quantization/{deep_gemm.py → deep_gemm_wrapper/compile_utils.py} +69 -127
- sglang/srt/layers/quantization/deep_gemm_wrapper/configurer.py +32 -0
- sglang/srt/layers/quantization/deep_gemm_wrapper/entrypoint.py +110 -0
- sglang/srt/layers/quantization/fp8.py +28 -23
- sglang/srt/layers/quantization/fp8_kernel.py +156 -75
- sglang/srt/layers/quantization/fp8_utils.py +250 -69
- sglang/srt/layers/quantization/modelopt_quant.py +334 -7
- sglang/srt/layers/quantization/moe_wna16.py +3 -0
- sglang/srt/layers/quantization/w8a8_fp8.py +3 -0
- sglang/srt/layers/quantization/w8a8_int8.py +3 -0
- sglang/srt/layers/radix_attention.py +2 -3
- sglang/srt/layers/rotary_embedding.py +6 -12
- sglang/srt/layers/sampler.py +80 -79
- sglang/srt/layers/utils.py +6 -0
- sglang/srt/lora/layers.py +12 -15
- sglang/srt/lora/lora.py +49 -5
- sglang/srt/lora/lora_manager.py +98 -39
- sglang/srt/lora/mem_pool.py +28 -21
- sglang/srt/lora/utils.py +17 -13
- sglang/srt/managers/cache_controller.py +2 -1
- sglang/srt/managers/data_parallel_controller.py +13 -5
- sglang/srt/managers/eplb_algorithms/__init__.py +63 -0
- sglang/srt/managers/eplb_algorithms/deepseek.py +223 -0
- sglang/srt/managers/{deepseek_eplb.py → eplb_algorithms/deepseek_vec.py} +5 -7
- sglang/srt/managers/eplb_manager.py +55 -14
- sglang/srt/managers/expert_distribution.py +220 -46
- sglang/srt/managers/expert_location.py +110 -56
- sglang/srt/managers/expert_location_dispatch.py +23 -6
- sglang/srt/managers/io_struct.py +43 -8
- sglang/srt/managers/mm_utils.py +88 -38
- sglang/srt/managers/multimodal_processors/base_processor.py +190 -18
- sglang/srt/managers/multimodal_processors/gemma3.py +4 -31
- sglang/srt/managers/multimodal_processors/internvl.py +4 -0
- sglang/srt/managers/multimodal_processors/kimi_vl.py +15 -34
- sglang/srt/managers/multimodal_processors/minicpm.py +2 -1
- sglang/srt/managers/multimodal_processors/phi4mm.py +87 -0
- sglang/srt/managers/multimodal_processors/qwen_vl.py +22 -64
- sglang/srt/managers/multimodal_processors/vila.py +85 -0
- sglang/srt/managers/schedule_batch.py +173 -38
- sglang/srt/managers/scheduler.py +376 -127
- sglang/srt/managers/tokenizer_manager.py +163 -19
- sglang/srt/managers/utils.py +0 -4
- sglang/srt/mem_cache/chunk_cache.py +1 -0
- sglang/srt/mem_cache/hiradix_cache.py +4 -2
- sglang/srt/mem_cache/memory_pool.py +111 -407
- sglang/srt/mem_cache/memory_pool_host.py +380 -0
- sglang/srt/mem_cache/radix_cache.py +36 -12
- sglang/srt/metrics/collector.py +9 -0
- sglang/srt/model_executor/cuda_graph_runner.py +191 -113
- sglang/srt/model_executor/expert_location_updater.py +157 -22
- sglang/srt/model_executor/forward_batch_info.py +52 -22
- sglang/srt/model_executor/model_runner.py +102 -62
- sglang/srt/model_loader/loader.py +8 -1
- sglang/srt/model_loader/utils.py +67 -1
- sglang/srt/models/bert.py +113 -13
- sglang/srt/models/deepseek_nextn.py +1 -1
- sglang/srt/models/deepseek_v2.py +623 -290
- sglang/srt/models/gemma3_causal.py +7 -0
- sglang/srt/models/gemma3_mm.py +19 -14
- sglang/srt/models/idefics2.py +342 -0
- sglang/srt/models/internvl.py +46 -102
- sglang/srt/models/kimi_vl.py +4 -4
- sglang/srt/models/llama.py +1 -1
- sglang/srt/models/minicpmo.py +2 -5
- sglang/srt/models/minicpmv.py +3 -295
- sglang/srt/models/phi4mm.py +512 -0
- sglang/srt/models/qwen2.py +38 -9
- sglang/srt/models/qwen2_5_vl.py +3 -9
- sglang/srt/models/qwen2_eagle.py +4 -1
- sglang/srt/models/qwen2_moe.py +58 -191
- sglang/srt/models/qwen2_vl.py +3 -9
- sglang/srt/models/qwen3.py +41 -10
- sglang/srt/models/qwen3_moe.py +230 -191
- sglang/srt/models/registry.py +9 -1
- sglang/srt/models/roberta.py +117 -9
- sglang/srt/models/transformers.py +291 -0
- sglang/srt/models/vila.py +305 -0
- sglang/srt/openai_api/adapter.py +248 -28
- sglang/srt/openai_api/protocol.py +68 -3
- sglang/srt/openai_api/utils.py +172 -0
- sglang/srt/operations.py +37 -2
- sglang/srt/operations_strategy.py +200 -24
- sglang/srt/sampling/sampling_batch_info.py +37 -1
- sglang/srt/sampling/sampling_params.py +4 -1
- sglang/srt/server_args.py +381 -209
- sglang/srt/speculative/build_eagle_tree.py +9 -9
- sglang/srt/speculative/eagle_draft_cuda_graph_runner.py +12 -14
- sglang/srt/speculative/eagle_draft_extend_cuda_graph_runner.py +256 -0
- sglang/srt/speculative/eagle_utils.py +440 -200
- sglang/srt/speculative/eagle_worker.py +234 -63
- sglang/srt/two_batch_overlap.py +637 -0
- sglang/srt/utils.py +187 -7
- sglang/test/attention/test_prefix_chunk_info.py +2 -0
- sglang/test/runners.py +54 -10
- sglang/test/send_one.py +4 -0
- sglang/test/test_block_fp8.py +1 -0
- sglang/test/test_block_fp8_deep_gemm_blackwell.py +252 -0
- sglang/test/test_block_fp8_ep.py +1 -0
- sglang/test/test_cutlass_moe.py +3 -3
- sglang/test/test_fp4_moe.py +248 -0
- sglang/test/test_utils.py +82 -7
- sglang/utils.py +9 -0
- sglang/version.py +1 -1
- {sglang-0.4.6.post5.dist-info → sglang-0.4.7.post1.dist-info}/METADATA +17 -14
- {sglang-0.4.6.post5.dist-info → sglang-0.4.7.post1.dist-info}/RECORD +359 -321
- {sglang-0.4.6.post5.dist-info → sglang-0.4.7.post1.dist-info}/WHEEL +1 -1
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=1,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json → triton_3_1_0/E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=144,N=512,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=144,N=512,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=1024,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=16,N=1024,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=1024,device_name=NVIDIA_H200.json → triton_3_1_0/E=16,N=1024,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=1344,device_name=NVIDIA_A100-SXM4-40GB.json → triton_3_1_0/E=16,N=1344,device_name=NVIDIA_A100-SXM4-40GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=1344,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=16,N=1344,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=1344,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=16,N=1344,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=16,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=2688,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=16,N=2688,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=2688,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=16,N=2688,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=16,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json → triton_3_1_0/E=16,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=3200,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=16,N=3200,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=6400,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=16,N=6400,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json → triton_3_1_0/E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json → triton_3_1_0/E=16,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=16,N=800,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=16,N=800,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=160,N=192,device_name=NVIDIA_A800-SXM4-80GB.json → triton_3_1_0/E=160,N=192,device_name=NVIDIA_A800-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=20,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=20,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=24,N=1024,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=24,N=1024,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8.json → triton_3_1_0/E=256,N=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json → triton_3_1_0/E=256,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=128,device_name=NVIDIA_H20,block_shape=[128, 128].json → triton_3_1_0/E=256,N=128,device_name=NVIDIA_H20,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=128,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=128,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=256,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=256,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=256,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=256,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=256,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=256,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=256,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=256,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=256,N=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=64,device_name=NVIDIA_A800-SXM4-80GB.json → triton_3_1_0/E=256,N=64,device_name=NVIDIA_A800-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=64,device_name=NVIDIA_L20,dtype=int8_w8a8.json → triton_3_1_0/E=256,N=64,device_name=NVIDIA_L20,dtype=int8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=256,N=64,device_name=NVIDIA_L40S,dtype=int8_w8a8.json → triton_3_1_0/E=256,N=64,device_name=NVIDIA_L40S,dtype=int8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=1024,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=64,N=1024,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=1280,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=64,N=1280,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=1280,device_name=NVIDIA_A800-SXM4-80GB.json → triton_3_1_0/E=64,N=1280,device_name=NVIDIA_A800-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=1280,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=64,N=1280,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=1280,device_name=NVIDIA_H200.json → triton_3_1_0/E=64,N=1280,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=2560,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=64,N=2560,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=2560,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=64,N=2560,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=2560,device_name=NVIDIA_H200.json → triton_3_1_0/E=64,N=2560,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=320,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=64,N=320,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=320,device_name=NVIDIA_H200.json → triton_3_1_0/E=64,N=320,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_1_0/E=64,N=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=640,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=64,N=640,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=640,device_name=NVIDIA_A800-SXM4-80GB.json → triton_3_1_0/E=64,N=640,device_name=NVIDIA_A800-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=640,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json → triton_3_1_0/E=64,N=640,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=640,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=64,N=640,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=64,N=640,device_name=NVIDIA_H200.json → triton_3_1_0/E=64,N=640,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=14336,device_name=AMD_Instinct_MI300X.json → triton_3_1_0/E=8,N=14336,device_name=AMD_Instinct_MI300X.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=14336,device_name=AMD_Instinct_MI325X.json → triton_3_1_0/E=8,N=14336,device_name=AMD_Instinct_MI325X.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=14336,device_name=AMD_Radeon_Graphics.json → triton_3_1_0/E=8,N=14336,device_name=AMD_Radeon_Graphics.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=14336,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=14336,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=14336,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=14336,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=14336,device_name=NVIDIA_H200.json → triton_3_1_0/E=8,N=14336,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=1792,device_name=AMD_Instinct_MI300X.json → triton_3_1_0/E=8,N=1792,device_name=AMD_Instinct_MI300X.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=1792,device_name=AMD_Instinct_MI325X.json → triton_3_1_0/E=8,N=1792,device_name=AMD_Instinct_MI325X.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=1792,device_name=AMD_Radeon_Graphics.json → triton_3_1_0/E=8,N=1792,device_name=AMD_Radeon_Graphics.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=1792,device_name=NVIDIA_A100-SXM4-40GB.json → triton_3_1_0/E=8,N=1792,device_name=NVIDIA_A100-SXM4-40GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=8,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=1792,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=8,N=1792,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=1792,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=1792,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=1792,device_name=NVIDIA_H200.json → triton_3_1_0/E=8,N=1792,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=2048,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=8,N=2048,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=2048,device_name=NVIDIA_H200.json → triton_3_1_0/E=8,N=2048,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=AMD_Instinct_MI300X.json → triton_3_1_0/E=8,N=3584,device_name=AMD_Instinct_MI300X.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=AMD_Instinct_MI325X.json → triton_3_1_0/E=8,N=3584,device_name=AMD_Instinct_MI325X.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=AMD_Radeon_Graphics.json → triton_3_1_0/E=8,N=3584,device_name=AMD_Radeon_Graphics.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=NVIDIA_A100-SXM4-40GB.json → triton_3_1_0/E=8,N=3584,device_name=NVIDIA_A100-SXM4-40GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=8,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=3584,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=3584,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=NVIDIA_H200.json → triton_3_1_0/E=8,N=3584,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=3584,device_name=NVIDIA_L40S.json → triton_3_1_0/E=8,N=3584,device_name=NVIDIA_L40S.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=4096,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=4096,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=4096,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=4096,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=4096,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=4096,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=4096,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=8,N=4096,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=4096,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=4096,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=4096,device_name=NVIDIA_H200.json → triton_3_1_0/E=8,N=4096,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=7168,device_name=AMD_Instinct_MI300X.json → triton_3_1_0/E=8,N=7168,device_name=AMD_Instinct_MI300X.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=7168,device_name=AMD_Instinct_MI325X.json → triton_3_1_0/E=8,N=7168,device_name=AMD_Instinct_MI325X.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=7168,device_name=AMD_Radeon_Graphics.json → triton_3_1_0/E=8,N=7168,device_name=AMD_Radeon_Graphics.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json → triton_3_1_0/E=8,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_1_0/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=7168,device_name=NVIDIA_H200.json → triton_3_1_0/E=8,N=7168,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=8192,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=8192,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=8192,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=8192,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=8192,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=8192,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=8192,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=8192,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=8,N=8192,device_name=NVIDIA_H200,dtype=fp8_w8a8.json → triton_3_1_0/E=8,N=8192,device_name=NVIDIA_H200,dtype=fp8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=192,device_name=NVIDIA_A800-SXM4-80GB.json → triton_3_2_0/E=128,N=192,device_name=NVIDIA_A800-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=192,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_2_0/E=128,N=192,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=192,device_name=NVIDIA_H20.json → triton_3_2_0/E=128,N=192,device_name=NVIDIA_H20.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=192,device_name=NVIDIA_H200.json → triton_3_2_0/E=128,N=192,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=384,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_2_0/E=128,N=384,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=384,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_2_0/E=128,N=384,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=384,device_name=NVIDIA_H20.json → triton_3_2_0/E=128,N=384,device_name=NVIDIA_H20.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=384,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_2_0/E=128,N=384,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=384,device_name=NVIDIA_H200.json → triton_3_2_0/E=128,N=384,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=512,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_2_0/E=128,N=512,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=768,device_name=NVIDIA_A800-SXM4-80GB.json → triton_3_2_0/E=128,N=768,device_name=NVIDIA_A800-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=768,device_name=NVIDIA_H100_80GB_HBM3.json → triton_3_2_0/E=128,N=768,device_name=NVIDIA_H100_80GB_HBM3.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=768,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_2_0/E=128,N=768,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=768,device_name=NVIDIA_H20.json → triton_3_2_0/E=128,N=768,device_name=NVIDIA_H20.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=768,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_2_0/E=128,N=768,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=768,device_name=NVIDIA_H200.json → triton_3_2_0/E=128,N=768,device_name=NVIDIA_H200.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=128,N=96,device_name=NVIDIA_H20.json → triton_3_2_0/E=128,N=96,device_name=NVIDIA_H20.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=264,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json → triton_3_2_0/E=264,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=264,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_2_0/E=264,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=264,N=256,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_2_0/E=264,N=256,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=264,N=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_2_0/E=264,N=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=272,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json → triton_3_2_0/E=272,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=272,N=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_2_0/E=272,N=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=272,N=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json → triton_3_2_0/E=272,N=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=272,N=64,device_name=NVIDIA_A800-SXM4-80GB.json → triton_3_2_0/E=272,N=64,device_name=NVIDIA_A800-SXM4-80GB.json} +0 -0
- /sglang/srt/layers/moe/fused_moe_triton/configs/{E=288,N=64,device_name=NVIDIA_A800-SXM4-80GB.json → triton_3_2_0/E=288,N=64,device_name=NVIDIA_A800-SXM4-80GB.json} +0 -0
- {sglang-0.4.6.post5.dist-info → sglang-0.4.7.post1.dist-info}/licenses/LICENSE +0 -0
- {sglang-0.4.6.post5.dist-info → sglang-0.4.7.post1.dist-info}/top_level.txt +0 -0
sglang/__init__.py
CHANGED
@@ -15,6 +15,7 @@ from sglang.api import (
|
|
15
15
|
get_server_info,
|
16
16
|
image,
|
17
17
|
select,
|
18
|
+
separate_reasoning,
|
18
19
|
set_default_backend,
|
19
20
|
system,
|
20
21
|
system_begin,
|
@@ -54,6 +55,7 @@ __all__ = [
|
|
54
55
|
"get_server_info",
|
55
56
|
"image",
|
56
57
|
"select",
|
58
|
+
"separate_reasoning",
|
57
59
|
"set_default_backend",
|
58
60
|
"system",
|
59
61
|
"system_begin",
|
sglang/api.py
CHANGED
@@ -15,6 +15,7 @@ from sglang.lang.ir import (
|
|
15
15
|
SglRoleBegin,
|
16
16
|
SglRoleEnd,
|
17
17
|
SglSelect,
|
18
|
+
SglSeparateReasoning,
|
18
19
|
SglVideo,
|
19
20
|
)
|
20
21
|
|
@@ -277,3 +278,9 @@ def assistant_begin():
|
|
277
278
|
|
278
279
|
def assistant_end():
|
279
280
|
return SglRoleEnd("assistant")
|
281
|
+
|
282
|
+
|
283
|
+
def separate_reasoning(
|
284
|
+
expr: Optional[SglExpr] = None, model_type: Optional[str] = None
|
285
|
+
):
|
286
|
+
return SglExprList([expr, SglSeparateReasoning(model_type, expr=expr)])
|
@@ -11,7 +11,9 @@ python -m sglang.bench_offline_throughput --model-path meta-llama/Meta-Llama-3.1
|
|
11
11
|
"""
|
12
12
|
|
13
13
|
import argparse
|
14
|
+
import asyncio
|
14
15
|
import dataclasses
|
16
|
+
import inspect
|
15
17
|
import json
|
16
18
|
import logging
|
17
19
|
import os
|
@@ -235,8 +237,10 @@ def throughput_test_once(
|
|
235
237
|
latency = time.perf_counter() - st
|
236
238
|
|
237
239
|
if profile:
|
240
|
+
dir = os.getenv("SGLANG_TORCH_PROFILER_DIR")
|
241
|
+
known_files = set(os.listdir(dir))
|
238
242
|
backend.stop_profile()
|
239
|
-
monitor_trace_file(
|
243
|
+
monitor_trace_file(known_files, dir)
|
240
244
|
|
241
245
|
if backend_name == "runtime":
|
242
246
|
gen_out = json.loads(gen_out)
|
@@ -260,6 +264,10 @@ def throughput_test_once(
|
|
260
264
|
measurement_results["total_input_tokens"]
|
261
265
|
+ measurement_results["total_output_tokens"]
|
262
266
|
) / latency
|
267
|
+
|
268
|
+
if inspect.isawaitable(server_info):
|
269
|
+
server_info = asyncio.run(server_info)
|
270
|
+
|
263
271
|
measurement_results["last_gen_throughput"] = server_info["internal_states"][0][
|
264
272
|
"last_gen_throughput"
|
265
273
|
]
|
@@ -267,11 +275,9 @@ def throughput_test_once(
|
|
267
275
|
return measurement_results
|
268
276
|
|
269
277
|
|
270
|
-
def monitor_trace_file(directory, interval=1):
|
278
|
+
def monitor_trace_file(known_files, directory, interval=1):
|
271
279
|
print(f"Monitoring {directory} for new trace files...")
|
272
280
|
|
273
|
-
known_files = set(os.listdir(directory))
|
274
|
-
|
275
281
|
while True:
|
276
282
|
flag = False
|
277
283
|
time.sleep(interval)
|
sglang/bench_one_batch_server.py
CHANGED
@@ -8,6 +8,7 @@ Usage:
|
|
8
8
|
python3 -m sglang.bench_one_batch_server --model meta-llama/Meta-Llama-3.1-8B --batch-size 1 16 64 --input-len 1024 --output-len 8
|
9
9
|
|
10
10
|
python3 -m sglang.bench_one_batch_server --model None --base-url http://localhost:30000 --batch-size 16 --input-len 1024 --output-len 8
|
11
|
+
python3 -m sglang.bench_one_batch_server --model None --base-url http://localhost:30000 --batch-size 16 --input-len 1024 --output-len 8 --show-report --profile --profile-by-stage
|
11
12
|
"""
|
12
13
|
|
13
14
|
import argparse
|
@@ -19,10 +20,10 @@ import os
|
|
19
20
|
import time
|
20
21
|
from typing import Tuple
|
21
22
|
|
22
|
-
import numpy as np
|
23
23
|
import requests
|
24
24
|
|
25
25
|
from sglang.bench_serving import get_tokenizer, sample_random_requests
|
26
|
+
from sglang.profiler import run_profile
|
26
27
|
from sglang.srt.entrypoints.http_server import launch_server
|
27
28
|
from sglang.srt.server_args import ServerArgs
|
28
29
|
from sglang.srt.utils import kill_process_tree
|
@@ -42,6 +43,8 @@ class BenchArgs:
|
|
42
43
|
base_url: str = ""
|
43
44
|
skip_warmup: bool = False
|
44
45
|
show_report: bool = False
|
46
|
+
profile: bool = False
|
47
|
+
profile_by_stage: bool = False
|
45
48
|
|
46
49
|
@staticmethod
|
47
50
|
def add_cli_args(parser: argparse.ArgumentParser):
|
@@ -68,6 +71,8 @@ class BenchArgs:
|
|
68
71
|
parser.add_argument("--base-url", type=str, default=BenchArgs.base_url)
|
69
72
|
parser.add_argument("--skip-warmup", action="store_true")
|
70
73
|
parser.add_argument("--show-report", action="store_true")
|
74
|
+
parser.add_argument("--profile", action="store_true")
|
75
|
+
parser.add_argument("--profile-by-stage", action="store_true")
|
71
76
|
|
72
77
|
@classmethod
|
73
78
|
def from_cli_args(cls, args: argparse.Namespace):
|
@@ -93,8 +98,8 @@ def launch_server_process(server_args: ServerArgs):
|
|
93
98
|
base_url = f"http://{server_args.host}:{server_args.port}"
|
94
99
|
timeout = 600
|
95
100
|
|
96
|
-
start_time = time.
|
97
|
-
while time.
|
101
|
+
start_time = time.time()
|
102
|
+
while time.time() - start_time < timeout:
|
98
103
|
try:
|
99
104
|
headers = {
|
100
105
|
"Content-Type": "application/json; charset=utf-8",
|
@@ -119,6 +124,8 @@ def run_one_case(
|
|
119
124
|
run_name: str,
|
120
125
|
result_filename: str,
|
121
126
|
tokenizer,
|
127
|
+
profile: bool = False,
|
128
|
+
profile_by_stage: bool = False,
|
122
129
|
):
|
123
130
|
requests.post(url + "/flush_cache")
|
124
131
|
input_requests = sample_random_requests(
|
@@ -145,6 +152,12 @@ def run_one_case(
|
|
145
152
|
else:
|
146
153
|
json_schema = None
|
147
154
|
|
155
|
+
profile_link = None
|
156
|
+
if profile:
|
157
|
+
profile_link: str = run_profile(
|
158
|
+
url, 3, ["CPU", "GPU"], None, None, profile_by_stage
|
159
|
+
)
|
160
|
+
|
148
161
|
tic = time.perf_counter()
|
149
162
|
response = requests.post(
|
150
163
|
url + "/generate",
|
@@ -194,8 +207,8 @@ def run_one_case(
|
|
194
207
|
print(f"output_len: {output_len}")
|
195
208
|
print(f"latency: {latency:.2f} s")
|
196
209
|
print(f"ttft: {ttft:.2f} s")
|
197
|
-
print(f"
|
198
|
-
print(f"
|
210
|
+
print(f"last generation throughput: {last_gen_throughput:.2f} tok/s")
|
211
|
+
print(f"input throughput: {input_throughput:.2f} tok/s")
|
199
212
|
if output_len != 1:
|
200
213
|
print(f"output throughput: {output_throughput:.2f} tok/s")
|
201
214
|
|
@@ -222,6 +235,7 @@ def run_one_case(
|
|
222
235
|
overall_throughput,
|
223
236
|
last_gen_throughput,
|
224
237
|
acc_length,
|
238
|
+
profile_link if profile else None,
|
225
239
|
)
|
226
240
|
|
227
241
|
|
@@ -253,6 +267,7 @@ def run_benchmark(server_args: ServerArgs, bench_args: BenchArgs):
|
|
253
267
|
|
254
268
|
# benchmark
|
255
269
|
result = []
|
270
|
+
bench_result = []
|
256
271
|
try:
|
257
272
|
for bs, il, ol in itertools.product(
|
258
273
|
bench_args.batch_size, bench_args.input_len, bench_args.output_len
|
@@ -271,6 +286,33 @@ def run_benchmark(server_args: ServerArgs, bench_args: BenchArgs):
|
|
271
286
|
tokenizer=tokenizer,
|
272
287
|
)
|
273
288
|
)
|
289
|
+
|
290
|
+
if bench_args.profile:
|
291
|
+
try:
|
292
|
+
for bs, il, ol in itertools.product(
|
293
|
+
bench_args.batch_size, bench_args.input_len, bench_args.output_len
|
294
|
+
):
|
295
|
+
bench_result.append(
|
296
|
+
(
|
297
|
+
run_one_case(
|
298
|
+
base_url,
|
299
|
+
bs,
|
300
|
+
il,
|
301
|
+
ol,
|
302
|
+
temperature=bench_args.temperature,
|
303
|
+
return_logprob=bench_args.return_logprob,
|
304
|
+
input_len_step_percentage=bench_args.input_len_step_percentage,
|
305
|
+
run_name=bench_args.run_name,
|
306
|
+
result_filename=bench_args.result_filename,
|
307
|
+
tokenizer=tokenizer,
|
308
|
+
profile=bench_args.profile,
|
309
|
+
profile_by_stage=bench_args.profile_by_stage,
|
310
|
+
)[-1],
|
311
|
+
)
|
312
|
+
)
|
313
|
+
result = [t1[:-1] + t2 for t1, t2 in zip(result, bench_result)]
|
314
|
+
except Exception as e:
|
315
|
+
print(f"Error profiling, there will be no profile trace dump: {e}")
|
274
316
|
finally:
|
275
317
|
if proc:
|
276
318
|
kill_process_tree(proc.pid)
|
@@ -280,8 +322,20 @@ def run_benchmark(server_args: ServerArgs, bench_args: BenchArgs):
|
|
280
322
|
if not bench_args.show_report:
|
281
323
|
return
|
282
324
|
|
283
|
-
summary =
|
284
|
-
|
325
|
+
summary = (
|
326
|
+
f"\nInput lens: {bench_args.input_len}. Output lens: {bench_args.output_len}.\n"
|
327
|
+
)
|
328
|
+
summary += "| batch size | latency (s) | input throughput (tok/s) | output throughput (tok/s) | acc length | ITL (ms) | input cost ($/1M) | output cost ($/1M) |"
|
329
|
+
|
330
|
+
if bench_args.profile:
|
331
|
+
summary += " profile |"
|
332
|
+
|
333
|
+
summary += "\n"
|
334
|
+
summary += "| ---------- | ----------- | ------------------------- | ------------------------- | ---------- | -------- | ----------------- | ------------------ |"
|
335
|
+
|
336
|
+
if bench_args.profile:
|
337
|
+
summary += "-------------|"
|
338
|
+
summary += "\n"
|
285
339
|
|
286
340
|
for (
|
287
341
|
batch_size,
|
@@ -292,6 +346,7 @@ def run_benchmark(server_args: ServerArgs, bench_args: BenchArgs):
|
|
292
346
|
overall_throughput,
|
293
347
|
last_gen_throughput,
|
294
348
|
acc_length,
|
349
|
+
trace_link,
|
295
350
|
) in result:
|
296
351
|
hourly_cost = 2 * server_args.tp_size # $2/hour for one H100
|
297
352
|
input_util = 0.7
|
@@ -304,17 +359,18 @@ def run_benchmark(server_args: ServerArgs, bench_args: BenchArgs):
|
|
304
359
|
f"{accept_length} | "
|
305
360
|
f"{1 / (output_throughput/batch_size) * 1000:.2f} | "
|
306
361
|
f"{1e6 / (input_throughput * input_util) / 3600 * hourly_cost:.2f} | "
|
307
|
-
f"{1e6 / output_throughput / 3600 * hourly_cost:.2f}
|
362
|
+
f"{1e6 / output_throughput / 3600 * hourly_cost:.2f} |"
|
308
363
|
)
|
364
|
+
if trace_link:
|
365
|
+
line += f" [Profile]({trace_link}) |"
|
366
|
+
line += "\n"
|
309
367
|
summary += line
|
310
368
|
|
311
369
|
# print metrics table
|
312
370
|
print(summary)
|
313
371
|
|
314
372
|
if is_in_ci():
|
315
|
-
write_github_step_summary(
|
316
|
-
f"### Test Nightly Benchmark (bench_one_batch) \n{summary}"
|
317
|
-
)
|
373
|
+
write_github_step_summary(summary)
|
318
374
|
|
319
375
|
|
320
376
|
if __name__ == "__main__":
|
sglang/bench_serving.py
CHANGED
@@ -39,7 +39,6 @@ from transformers import (
|
|
39
39
|
PreTrainedTokenizerFast,
|
40
40
|
)
|
41
41
|
|
42
|
-
AIOHTTP_TIMEOUT = aiohttp.ClientTimeout(total=6 * 60 * 60)
|
43
42
|
ASSISTANT_SUFFIX = "Assistant:"
|
44
43
|
|
45
44
|
global args
|
@@ -51,6 +50,19 @@ def _get_bool_env_var(name: str, default: str = "false") -> bool:
|
|
51
50
|
return value.lower() in ("true", "1")
|
52
51
|
|
53
52
|
|
53
|
+
def _create_bench_client_session():
|
54
|
+
# When the pressure is big, the read buffer could be full before aio thread read
|
55
|
+
# the content. We increase the read_bufsize from 64K to 10M.
|
56
|
+
# Define constants for timeout and buffer size for clarity and maintainability
|
57
|
+
BENCH_AIOHTTP_TIMEOUT_SECONDS = 6 * 60 * 60 # 6 hours
|
58
|
+
BENCH_AIOHTTP_READ_BUFSIZE_BYTES = 10 * 1024**2 # 10 MB
|
59
|
+
|
60
|
+
aiohttp_timeout = aiohttp.ClientTimeout(total=BENCH_AIOHTTP_TIMEOUT_SECONDS)
|
61
|
+
return aiohttp.ClientSession(
|
62
|
+
timeout=aiohttp_timeout, read_bufsize=BENCH_AIOHTTP_READ_BUFSIZE_BYTES
|
63
|
+
)
|
64
|
+
|
65
|
+
|
54
66
|
@dataclass
|
55
67
|
class RequestFuncInput:
|
56
68
|
prompt: str
|
@@ -106,7 +118,7 @@ async def async_request_trt_llm(
|
|
106
118
|
api_url = request_func_input.api_url
|
107
119
|
assert api_url.endswith("generate_stream")
|
108
120
|
|
109
|
-
async with
|
121
|
+
async with _create_bench_client_session() as session:
|
110
122
|
payload = {
|
111
123
|
"accumulate_tokens": True,
|
112
124
|
"text_input": request_func_input.prompt,
|
@@ -179,7 +191,7 @@ async def async_request_openai_completions(
|
|
179
191
|
|
180
192
|
prompt = request_func_input.prompt
|
181
193
|
|
182
|
-
async with
|
194
|
+
async with _create_bench_client_session() as session:
|
183
195
|
payload = {
|
184
196
|
"model": request_func_input.model,
|
185
197
|
"prompt": prompt,
|
@@ -261,7 +273,7 @@ async def async_request_truss(
|
|
261
273
|
|
262
274
|
prompt = request_func_input.prompt
|
263
275
|
|
264
|
-
async with
|
276
|
+
async with _create_bench_client_session() as session:
|
265
277
|
payload = {
|
266
278
|
"model": request_func_input.model,
|
267
279
|
"prompt": prompt,
|
@@ -338,9 +350,9 @@ async def async_request_sglang_generate(
|
|
338
350
|
api_url = request_func_input.api_url
|
339
351
|
prompt = request_func_input.prompt
|
340
352
|
|
341
|
-
async with
|
353
|
+
async with _create_bench_client_session() as session:
|
342
354
|
payload = {
|
343
|
-
"text": prompt,
|
355
|
+
("text" if isinstance(prompt, str) else "input_ids"): prompt,
|
344
356
|
"sampling_params": {
|
345
357
|
"temperature": 0.0,
|
346
358
|
"max_new_tokens": request_func_input.output_len,
|
@@ -376,7 +388,6 @@ async def async_request_sglang_generate(
|
|
376
388
|
chunk_bytes = chunk_bytes.strip()
|
377
389
|
if not chunk_bytes:
|
378
390
|
continue
|
379
|
-
# print(chunk_bytes)
|
380
391
|
|
381
392
|
chunk = remove_prefix(chunk_bytes.decode("utf-8"), "data: ")
|
382
393
|
latency = time.perf_counter() - st
|
@@ -388,7 +399,7 @@ async def async_request_sglang_generate(
|
|
388
399
|
# NOTE: Some completion API might have a last
|
389
400
|
# usage summary response without a token so we
|
390
401
|
# want to check a token was generated
|
391
|
-
if data["text"]:
|
402
|
+
if "text" in data and data["text"]:
|
392
403
|
timestamp = time.perf_counter()
|
393
404
|
generated_text = data["text"]
|
394
405
|
output_len = data["meta_info"]["completion_tokens"]
|
@@ -437,7 +448,7 @@ async def async_request_gserver(
|
|
437
448
|
|
438
449
|
|
439
450
|
async def async_request_profile(api_url: str) -> RequestFuncOutput:
|
440
|
-
async with
|
451
|
+
async with _create_bench_client_session() as session:
|
441
452
|
output = RequestFuncOutput()
|
442
453
|
try:
|
443
454
|
async with session.post(url=api_url) as response:
|
@@ -493,7 +504,9 @@ def get_tokenizer(
|
|
493
504
|
|
494
505
|
|
495
506
|
def get_dataset(args, tokenizer):
|
507
|
+
tokenize_prompt = getattr(args, "tokenize_prompt", False)
|
496
508
|
if args.dataset_name == "sharegpt":
|
509
|
+
assert not tokenize_prompt
|
497
510
|
input_requests = sample_sharegpt_requests(
|
498
511
|
dataset_path=args.dataset_path,
|
499
512
|
num_requests=args.num_prompts,
|
@@ -512,8 +525,10 @@ def get_dataset(args, tokenizer):
|
|
512
525
|
tokenizer=tokenizer,
|
513
526
|
dataset_path=args.dataset_path,
|
514
527
|
random_sample=args.dataset_name == "random",
|
528
|
+
return_text=not tokenize_prompt,
|
515
529
|
)
|
516
530
|
elif args.dataset_name == "generated-shared-prefix":
|
531
|
+
assert not tokenize_prompt
|
517
532
|
input_requests = sample_generated_shared_prefix_requests(
|
518
533
|
num_groups=args.gsp_num_groups,
|
519
534
|
prompts_per_group=args.gsp_prompts_per_group,
|
@@ -524,6 +539,7 @@ def get_dataset(args, tokenizer):
|
|
524
539
|
args=args,
|
525
540
|
)
|
526
541
|
elif args.dataset_name == "mmmu":
|
542
|
+
assert not tokenize_prompt
|
527
543
|
input_requests = sample_mmmu_requests(
|
528
544
|
num_requests=args.num_prompts,
|
529
545
|
tokenizer=tokenizer,
|
@@ -638,6 +654,7 @@ class DatasetRow:
|
|
638
654
|
prompt: str
|
639
655
|
prompt_len: int
|
640
656
|
output_len: int
|
657
|
+
image_data: Optional[str] = None
|
641
658
|
|
642
659
|
|
643
660
|
def sample_mmmu_requests(
|
@@ -713,42 +730,50 @@ def sample_mmmu_requests(
|
|
713
730
|
buffered = io.BytesIO()
|
714
731
|
image.save(buffered, format="JPEG")
|
715
732
|
img_str = base64.b64encode(buffered.getvalue()).decode("utf-8")
|
716
|
-
|
733
|
+
image_data = f"data:image/jpeg;base64,{img_str}"
|
717
734
|
else:
|
718
735
|
continue
|
719
736
|
|
720
737
|
# Extract the question
|
721
738
|
question = example.get("question")
|
722
739
|
|
723
|
-
#
|
740
|
+
# Construct the prompt
|
724
741
|
prompt = f"Question: {question}\n\nAnswer: "
|
725
|
-
prompt = tokenizer.apply_chat_template(
|
726
|
-
[
|
727
|
-
{
|
728
|
-
"role": "user",
|
729
|
-
"content": [
|
730
|
-
{"type": "image_url", "image_url": {"url": image_path}},
|
731
|
-
{"type": "text", "text": prompt},
|
732
|
-
],
|
733
|
-
}
|
734
|
-
],
|
735
|
-
add_generation_prompt=True,
|
736
|
-
tokenize=False,
|
737
|
-
)
|
738
|
-
prompt = f"<image>{image_path}</image>{prompt}"
|
739
742
|
|
740
|
-
|
741
|
-
|
743
|
+
try:
|
744
|
+
prompt = tokenizer.apply_chat_template(
|
745
|
+
[
|
746
|
+
{
|
747
|
+
"role": "user",
|
748
|
+
"content": [
|
749
|
+
{
|
750
|
+
"type": "image_url",
|
751
|
+
"image_url": {"url": image_data},
|
752
|
+
},
|
753
|
+
{"type": "text", "text": prompt},
|
754
|
+
],
|
755
|
+
}
|
756
|
+
],
|
757
|
+
add_generation_prompt=True,
|
758
|
+
tokenize=False,
|
759
|
+
)
|
760
|
+
except Exception as e:
|
761
|
+
# Note (Xinyuan): This is a workaround for an issue where some tokenizers do not support content as a list. (e.g. InternVL)
|
762
|
+
print(f"Error applying chat template: {e}, fallback to <image> tag")
|
763
|
+
prompt = f"<image>{prompt}"
|
764
|
+
|
765
|
+
# Calculate token lengths for text only (without image data)
|
742
766
|
prompt_token_ids = tokenizer.encode(prompt)
|
743
|
-
prompt_len = (
|
744
|
-
len(prompt_token_ids) + 512
|
745
|
-
) # Add estimate for image tokens
|
767
|
+
prompt_len = len(prompt_token_ids)
|
746
768
|
|
747
769
|
output_len = fixed_output_len if fixed_output_len is not None else 256
|
748
770
|
|
749
771
|
filtered_dataset.append(
|
750
772
|
DatasetRow(
|
751
|
-
prompt=prompt,
|
773
|
+
prompt=prompt,
|
774
|
+
prompt_len=prompt_len,
|
775
|
+
output_len=output_len,
|
776
|
+
image_data=image_data,
|
752
777
|
)
|
753
778
|
)
|
754
779
|
|
@@ -1182,34 +1207,21 @@ async def benchmark(
|
|
1182
1207
|
|
1183
1208
|
# Use the first request for all warmup iterations
|
1184
1209
|
test_request = input_requests[0]
|
1185
|
-
|
1186
|
-
test_request.prompt,
|
1187
|
-
test_request.prompt_len,
|
1188
|
-
test_request.output_len,
|
1189
|
-
)
|
1210
|
+
|
1190
1211
|
if lora_names is not None and len(lora_names) != 0:
|
1191
1212
|
lora_name = lora_names[0]
|
1192
1213
|
else:
|
1193
1214
|
lora_name = None
|
1194
1215
|
|
1195
|
-
if "<image>" in test_prompt:
|
1196
|
-
import re
|
1197
|
-
|
1198
|
-
image_match = re.search(r"<image>(.*?)</image>(.*)", test_prompt)
|
1199
|
-
image_data = image_match.group(1) if image_match else None
|
1200
|
-
test_prompt = image_match.group(2) if image_match else test_prompt
|
1201
|
-
else:
|
1202
|
-
image_data = None
|
1203
|
-
|
1204
1216
|
# Create the test input once
|
1205
1217
|
test_input = RequestFuncInput(
|
1206
1218
|
model=model_id,
|
1207
|
-
prompt=
|
1219
|
+
prompt=test_request.prompt,
|
1208
1220
|
api_url=api_url,
|
1209
|
-
prompt_len=
|
1210
|
-
output_len=min(
|
1221
|
+
prompt_len=test_request.prompt_len,
|
1222
|
+
output_len=min(test_request.output_len, 32),
|
1211
1223
|
lora_name=lora_name,
|
1212
|
-
image_data=image_data,
|
1224
|
+
image_data=test_request.image_data,
|
1213
1225
|
extra_request_body=extra_request_body,
|
1214
1226
|
)
|
1215
1227
|
|
@@ -1254,36 +1266,23 @@ async def benchmark(
|
|
1254
1266
|
benchmark_start_time = time.perf_counter()
|
1255
1267
|
tasks: List[asyncio.Task] = []
|
1256
1268
|
async for request in get_request(input_requests, request_rate):
|
1257
|
-
prompt, prompt_len, output_len = (
|
1258
|
-
request.prompt,
|
1259
|
-
request.prompt_len,
|
1260
|
-
request.output_len,
|
1261
|
-
)
|
1262
1269
|
if lora_names is not None and len(lora_names) != 0:
|
1263
1270
|
idx = random.randint(0, len(lora_names) - 1)
|
1264
1271
|
lora_name = lora_names[idx]
|
1265
1272
|
else:
|
1266
1273
|
lora_name = None
|
1267
1274
|
|
1268
|
-
if "<image>" in prompt:
|
1269
|
-
import re
|
1270
|
-
|
1271
|
-
image_match = re.search(r"<image>(.*?)</image>(.*)", prompt)
|
1272
|
-
image_data = image_match.group(1) if image_match else None
|
1273
|
-
prompt = image_match.group(2) if image_match else prompt
|
1274
|
-
else:
|
1275
|
-
image_data = None
|
1276
|
-
|
1277
1275
|
request_func_input = RequestFuncInput(
|
1278
1276
|
model=model_id,
|
1279
|
-
prompt=prompt,
|
1277
|
+
prompt=request.prompt,
|
1280
1278
|
api_url=api_url,
|
1281
|
-
prompt_len=prompt_len,
|
1282
|
-
output_len=output_len,
|
1279
|
+
prompt_len=request.prompt_len,
|
1280
|
+
output_len=request.output_len,
|
1283
1281
|
lora_name=lora_name,
|
1284
|
-
image_data=image_data,
|
1282
|
+
image_data=request.image_data,
|
1285
1283
|
extra_request_body=extra_request_body,
|
1286
1284
|
)
|
1285
|
+
|
1287
1286
|
tasks.append(
|
1288
1287
|
asyncio.create_task(
|
1289
1288
|
limited_request_func(request_func_input=request_func_input, pbar=pbar)
|
@@ -1304,14 +1303,12 @@ async def benchmark(
|
|
1304
1303
|
if "sglang" in backend:
|
1305
1304
|
server_info = requests.get(base_url + "/get_server_info")
|
1306
1305
|
if server_info.status_code == 200:
|
1307
|
-
|
1308
|
-
|
1309
|
-
|
1310
|
-
|
1311
|
-
|
1312
|
-
|
1313
|
-
"avg_spec_accept_length", None
|
1314
|
-
)
|
1306
|
+
server_info_json = server_info.json()
|
1307
|
+
if "decode" in server_info_json:
|
1308
|
+
server_info_json = server_info_json["decode"][0]
|
1309
|
+
accept_length = server_info_json["internal_states"][0].get(
|
1310
|
+
"avg_spec_accept_length", None
|
1311
|
+
)
|
1315
1312
|
else:
|
1316
1313
|
accept_length = None
|
1317
1314
|
else:
|
@@ -1497,6 +1494,9 @@ def run_benchmark(args_: argparse.Namespace):
|
|
1497
1494
|
if not hasattr(args, "output_details"):
|
1498
1495
|
args.output_details = False
|
1499
1496
|
|
1497
|
+
if not hasattr(args, "tokenize_prompt"):
|
1498
|
+
args.tokenize_prompt = False
|
1499
|
+
|
1500
1500
|
print(f"benchmark_args={args}")
|
1501
1501
|
|
1502
1502
|
# Set global environments
|
@@ -1508,6 +1508,11 @@ def run_benchmark(args_: argparse.Namespace):
|
|
1508
1508
|
if args.extra_request_body:
|
1509
1509
|
extra_request_body = json.loads(args.extra_request_body)
|
1510
1510
|
|
1511
|
+
if args.tokenize_prompt:
|
1512
|
+
assert (
|
1513
|
+
args.backend == "sglang"
|
1514
|
+
), "`--tokenize-prompt` only compatible with `--backend sglang` currently"
|
1515
|
+
|
1511
1516
|
# Set url
|
1512
1517
|
if args.port is None:
|
1513
1518
|
args.port = {
|
@@ -1618,6 +1623,7 @@ def run_benchmark(args_: argparse.Namespace):
|
|
1618
1623
|
profile=args.profile,
|
1619
1624
|
pd_separated=args.pd_separated,
|
1620
1625
|
flush_cache=args.flush_cache,
|
1626
|
+
warmup_requests=args.warmup_requests,
|
1621
1627
|
)
|
1622
1628
|
)
|
1623
1629
|
|
@@ -1813,6 +1819,11 @@ if __name__ == "__main__":
|
|
1813
1819
|
default=1,
|
1814
1820
|
help="Number of warmup requests to run before the benchmark",
|
1815
1821
|
)
|
1822
|
+
parser.add_argument(
|
1823
|
+
"--tokenize-prompt",
|
1824
|
+
action="store_true",
|
1825
|
+
help="Use integer ids instead of string for inputs. Useful to control prompt lengths accurately",
|
1826
|
+
)
|
1816
1827
|
|
1817
1828
|
group = parser.add_argument_group("generated-shared-prefix dataset arguments")
|
1818
1829
|
group.add_argument(
|
@@ -85,6 +85,22 @@ class RuntimeEndpoint(BaseBackend):
|
|
85
85
|
)
|
86
86
|
self._assert_success(res)
|
87
87
|
|
88
|
+
def start_profile(self):
|
89
|
+
res = http_request(
|
90
|
+
self.base_url + "/start_profile",
|
91
|
+
api_key=self.api_key,
|
92
|
+
verify=self.verify,
|
93
|
+
)
|
94
|
+
self._assert_success(res)
|
95
|
+
|
96
|
+
def stop_profile(self):
|
97
|
+
res = http_request(
|
98
|
+
self.base_url + "/stop_profile",
|
99
|
+
api_key=self.api_key,
|
100
|
+
verify=self.verify,
|
101
|
+
)
|
102
|
+
self._assert_success(res)
|
103
|
+
|
88
104
|
def commit_lazy_operations(self, s: StreamExecutor):
|
89
105
|
data = {"text": s.text_, "sampling_params": {"max_new_tokens": 0}}
|
90
106
|
self._add_images(s, data)
|
@@ -374,7 +390,8 @@ class Runtime:
|
|
374
390
|
self.pid = None
|
375
391
|
pipe_reader, pipe_writer = multiprocessing.Pipe(duplex=False)
|
376
392
|
|
377
|
-
|
393
|
+
ctx = multiprocessing.get_context("spawn")
|
394
|
+
proc = ctx.Process(
|
378
395
|
target=launch_server,
|
379
396
|
args=(self.server_args, pipe_writer),
|
380
397
|
)
|
@@ -406,6 +423,12 @@ class Runtime:
|
|
406
423
|
kill_process_tree(self.pid)
|
407
424
|
self.pid = None
|
408
425
|
|
426
|
+
def start_profile(self):
|
427
|
+
self.endpoint.start_profile()
|
428
|
+
|
429
|
+
def stop_profile(self):
|
430
|
+
self.endpoint.stop_profile()
|
431
|
+
|
409
432
|
def cache_prefix(self, prefix: str):
|
410
433
|
self.endpoint.cache_prefix(prefix)
|
411
434
|
|