sglang 0.4.6.post3__tar.gz → 0.4.6.post4__tar.gz

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.
Files changed (653) hide show
  1. {sglang-0.4.6.post3/sglang.egg-info → sglang-0.4.6.post4}/PKG-INFO +6 -5
  2. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/README.md +3 -3
  3. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/pyproject.toml +7 -3
  4. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/bench_offline_throughput.py +4 -2
  5. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/bench_one_batch.py +2 -2
  6. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/bench_one_batch_server.py +143 -15
  7. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/bench_serving.py +9 -7
  8. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/compile_deep_gemm.py +1 -1
  9. sglang-0.4.6.post4/sglang/eval/loogle_eval.py +157 -0
  10. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/chat_template.py +78 -78
  11. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/tracer.py +1 -1
  12. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/code_completion_parser.py +1 -1
  13. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/deepseekvl2.py +2 -2
  14. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/model_config.py +1 -0
  15. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/constrained/base_grammar_backend.py +55 -72
  16. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/constrained/llguidance_backend.py +25 -21
  17. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/constrained/outlines_backend.py +27 -26
  18. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/constrained/reasoner_grammar_backend.py +22 -33
  19. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/constrained/xgrammar_backend.py +69 -43
  20. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/conversation.py +48 -43
  21. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/base/conn.py +1 -0
  22. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/decode.py +7 -2
  23. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/fake/conn.py +1 -1
  24. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/mooncake/conn.py +227 -120
  25. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/nixl/conn.py +1 -0
  26. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/prefill.py +7 -4
  27. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/utils.py +7 -1
  28. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/entrypoints/engine.py +17 -2
  29. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/entrypoints/http_server.py +17 -2
  30. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/function_call_parser.py +2 -2
  31. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/flashattention_backend.py +1 -1
  32. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/triton_ops/double_sparsity_attention.py +1 -1
  33. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/utils.py +4 -2
  34. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/dp_attention.py +71 -21
  35. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/layernorm.py +1 -1
  36. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/logits_processor.py +46 -11
  37. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/ep_moe/kernels.py +1 -1
  38. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/ep_moe/layer.py +1 -1
  39. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/fused_moe.py +1 -1
  40. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/topk.py +1 -1
  41. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/__init__.py +1 -1
  42. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/blockwise_int8.py +2 -2
  43. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/deep_gemm.py +72 -71
  44. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/fp8.py +2 -2
  45. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/fp8_kernel.py +3 -3
  46. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/int8_kernel.py +2 -2
  47. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/sampler.py +0 -4
  48. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/vocab_parallel_embedding.py +18 -7
  49. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/lora_manager.py +1 -1
  50. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/mem_pool.py +4 -4
  51. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/triton_ops/gate_up_lora_b.py +1 -1
  52. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/triton_ops/qkv_lora_b.py +1 -1
  53. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/triton_ops/sgemm_lora_a.py +1 -1
  54. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/triton_ops/sgemm_lora_b.py +1 -1
  55. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/utils.py +1 -1
  56. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/data_parallel_controller.py +3 -3
  57. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/detokenizer_manager.py +21 -8
  58. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/io_struct.py +3 -1
  59. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/mm_utils.py +1 -1
  60. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/llava.py +46 -0
  61. sglang-0.4.6.post4/sglang/srt/managers/multimodal_processors/pixtral.py +127 -0
  62. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/schedule_batch.py +76 -24
  63. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/schedule_policy.py +0 -3
  64. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/scheduler.py +113 -88
  65. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/scheduler_output_processor_mixin.py +124 -55
  66. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/tokenizer_manager.py +133 -34
  67. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/tp_worker.py +12 -9
  68. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/tp_worker_overlap_thread.py +22 -11
  69. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/mem_cache/memory_pool.py +2 -0
  70. sglang-0.4.6.post4/sglang/srt/metrics/collector.py +535 -0
  71. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/model_executor/cuda_graph_runner.py +10 -11
  72. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/model_executor/forward_batch_info.py +1 -1
  73. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/model_executor/model_runner.py +19 -14
  74. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/deepseek_janus_pro.py +2 -2
  75. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/deepseek_v2.py +23 -20
  76. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/llama.py +2 -0
  77. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/llama4.py +5 -6
  78. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/llava.py +248 -5
  79. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/mixtral.py +98 -34
  80. sglang-0.4.6.post4/sglang/srt/models/pixtral.py +467 -0
  81. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/roberta.py +1 -1
  82. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/torch_native_llama.py +1 -1
  83. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/openai_api/adapter.py +30 -4
  84. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/openai_api/protocol.py +0 -8
  85. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/reasoning_parser.py +3 -3
  86. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/sampling/custom_logit_processor.py +18 -3
  87. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/sampling/sampling_batch_info.py +4 -56
  88. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/sampling/sampling_params.py +2 -2
  89. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/server_args.py +34 -4
  90. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/speculative/eagle_draft_cuda_graph_runner.py +3 -3
  91. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/speculative/eagle_utils.py +7 -7
  92. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/speculative/eagle_worker.py +22 -19
  93. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/utils.py +6 -5
  94. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/few_shot_gsm8k.py +2 -2
  95. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/few_shot_gsm8k_engine.py +2 -2
  96. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/run_eval.py +2 -2
  97. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/runners.py +8 -1
  98. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/send_one.py +13 -3
  99. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/simple_eval_common.py +1 -1
  100. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/simple_eval_humaneval.py +1 -1
  101. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/test_programs.py +5 -5
  102. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/test_utils.py +89 -14
  103. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/utils.py +1 -1
  104. sglang-0.4.6.post4/sglang/version.py +1 -0
  105. {sglang-0.4.6.post3 → sglang-0.4.6.post4/sglang.egg-info}/PKG-INFO +6 -5
  106. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang.egg-info/SOURCES.txt +4 -1
  107. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang.egg-info/requires.txt +2 -1
  108. sglang-0.4.6.post3/sglang/srt/metrics/collector.py +0 -260
  109. sglang-0.4.6.post3/sglang/version.py +0 -1
  110. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/LICENSE +0 -0
  111. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/setup.cfg +0 -0
  112. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/__init__.py +0 -0
  113. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/api.py +0 -0
  114. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/check_env.py +0 -0
  115. {sglang-0.4.6.post3/sglang → sglang-0.4.6.post4/sglang/eval}/llama3_eval.py +0 -0
  116. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/global_config.py +0 -0
  117. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/backend/__init__.py +0 -0
  118. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/backend/anthropic.py +0 -0
  119. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/backend/base_backend.py +0 -0
  120. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/backend/litellm.py +0 -0
  121. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/backend/openai.py +0 -0
  122. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/backend/runtime_endpoint.py +0 -0
  123. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/backend/vertexai.py +0 -0
  124. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/choices.py +0 -0
  125. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/compiler.py +0 -0
  126. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/interpreter.py +0 -0
  127. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/lang/ir.py +0 -0
  128. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/launch_server.py +0 -0
  129. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/_custom_ops.py +0 -0
  130. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/aio_rwlock.py +0 -0
  131. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/__init__.py +0 -0
  132. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/chatglm.py +0 -0
  133. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/dbrx.py +0 -0
  134. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/device_config.py +0 -0
  135. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/exaone.py +0 -0
  136. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/internvl.py +0 -0
  137. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/janus_pro.py +0 -0
  138. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/kimi_vl.py +0 -0
  139. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/kimi_vl_moonvit.py +0 -0
  140. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/load_config.py +0 -0
  141. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/configs/utils.py +0 -0
  142. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/connector/__init__.py +0 -0
  143. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/connector/base_connector.py +0 -0
  144. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/connector/redis.py +0 -0
  145. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/connector/s3.py +0 -0
  146. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/connector/serde/__init__.py +0 -0
  147. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/connector/serde/safe_serde.py +0 -0
  148. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/connector/serde/serde.py +0 -0
  149. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/connector/utils.py +0 -0
  150. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/constrained/outlines_jump_forward.py +0 -0
  151. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/constrained/triton_ops/bitmask_ops.py +0 -0
  152. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/custom_op.py +0 -0
  153. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/base/__init__.py +0 -0
  154. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/fake/__init__.py +0 -0
  155. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/mini_lb.py +0 -0
  156. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/mooncake/__init__.py +0 -0
  157. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/mooncake/transfer_engine.py +0 -0
  158. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/disaggregation/nixl/__init__.py +0 -0
  159. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/__init__.py +0 -0
  160. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/communication_op.py +0 -0
  161. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/device_communicators/cuda_wrapper.py +0 -0
  162. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/device_communicators/custom_all_reduce.py +0 -0
  163. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/device_communicators/custom_all_reduce_utils.py +0 -0
  164. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/device_communicators/hpu_communicator.py +0 -0
  165. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/device_communicators/npu_communicator.py +0 -0
  166. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/device_communicators/pynccl.py +0 -0
  167. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/device_communicators/pynccl_wrapper.py +0 -0
  168. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/device_communicators/shm_broadcast.py +0 -0
  169. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/device_communicators/xpu_communicator.py +0 -0
  170. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/parallel_state.py +0 -0
  171. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/distributed/utils.py +0 -0
  172. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/entrypoints/EngineBase.py +0 -0
  173. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/entrypoints/http_server_engine.py +0 -0
  174. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/entrypoints/verl_engine.py +0 -0
  175. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/hf_transformers_utils.py +0 -0
  176. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/activation.py +0 -0
  177. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/base_attn_backend.py +0 -0
  178. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/cutlass_mla_backend.py +0 -0
  179. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/double_sparsity_backend.py +0 -0
  180. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/flashinfer_backend.py +0 -0
  181. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/flashinfer_mla_backend.py +0 -0
  182. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/flashmla_backend.py +0 -0
  183. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/merge_state.py +0 -0
  184. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/torch_native_backend.py +0 -0
  185. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/triton_backend.py +0 -0
  186. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/triton_ops/decode_attention.py +0 -0
  187. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/triton_ops/extend_attention.py +0 -0
  188. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/triton_ops/merge_state.py +0 -0
  189. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/triton_ops/prefill_attention.py +0 -0
  190. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/triton_ops/rocm_mla_decode_rope.py +0 -0
  191. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/attention/vision.py +0 -0
  192. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/elementwise.py +0 -0
  193. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/linear.py +0 -0
  194. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/ep_moe/__init__.py +0 -0
  195. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/ep_moe/token_dispatcher.py +0 -0
  196. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_native.py +0 -0
  197. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/__init__.py +0 -0
  198. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  199. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  200. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  201. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  202. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  203. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +0 -0
  204. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  205. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  206. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  207. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  208. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  209. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=192,device_name=NVIDIA_A800-SXM4-80GB.json +0 -0
  210. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=192,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  211. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=192,device_name=NVIDIA_H20.json +0 -0
  212. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=192,device_name=NVIDIA_H200.json +0 -0
  213. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=384,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  214. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=384,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  215. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=384,device_name=NVIDIA_H20.json +0 -0
  216. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=384,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  217. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=384,device_name=NVIDIA_H200.json +0 -0
  218. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=512,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  219. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=768,device_name=NVIDIA_A800-SXM4-80GB.json +0 -0
  220. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=768,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  221. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=768,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  222. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=768,device_name=NVIDIA_H20.json +0 -0
  223. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=768,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  224. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=768,device_name=NVIDIA_H200.json +0 -0
  225. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=128,N=96,device_name=NVIDIA_H20.json +0 -0
  226. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=144,N=512,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  227. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=1024,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  228. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=1024,device_name=NVIDIA_H200.json +0 -0
  229. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=1344,device_name=NVIDIA_A100-SXM4-40GB.json +0 -0
  230. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=1344,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  231. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=1344,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  232. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  233. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  234. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  235. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  236. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  237. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=2688,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  238. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=2688,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  239. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  240. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +0 -0
  241. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=3200,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  242. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  243. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  244. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=6400,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  245. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +0 -0
  246. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  247. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +0 -0
  248. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=16,N=800,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  249. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=160,N=192,device_name=NVIDIA_A800-SXM4-80GB.json +0 -0
  250. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=20,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  251. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=24,N=1024,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  252. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/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 +0 -0
  253. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8.json +0 -0
  254. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/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 +0 -0
  255. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json +0 -0
  256. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/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 +0 -0
  257. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=128,device_name=NVIDIA_H20,block_shape=[128, 128].json +0 -0
  258. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  259. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=128,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  260. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/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 +0 -0
  261. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/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 +0 -0
  262. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/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 +0 -0
  263. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  264. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=256,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  265. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  266. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=64,device_name=NVIDIA_A800-SXM4-80GB.json +0 -0
  267. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=64,device_name=NVIDIA_L20,dtype=int8_w8a8.json +0 -0
  268. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=256,N=64,device_name=NVIDIA_L40S,dtype=int8_w8a8.json +0 -0
  269. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=264,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json +0 -0
  270. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=264,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  271. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=264,N=256,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  272. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=264,N=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  273. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=272,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json +0 -0
  274. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/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 +0 -0
  275. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=272,N=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  276. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=272,N=64,device_name=NVIDIA_A800-SXM4-80GB.json +0 -0
  277. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=288,N=64,device_name=NVIDIA_A800-SXM4-80GB.json +0 -0
  278. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/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 +0 -0
  279. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=1280,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  280. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=1280,device_name=NVIDIA_A800-SXM4-80GB.json +0 -0
  281. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  282. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  283. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=1280,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  284. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=1280,device_name=NVIDIA_H200.json +0 -0
  285. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=2560,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  286. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=2560,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  287. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=2560,device_name=NVIDIA_H200.json +0 -0
  288. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  289. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  290. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=320,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  291. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=320,device_name=NVIDIA_H200.json +0 -0
  292. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  293. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=640,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  294. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=640,device_name=NVIDIA_A800-SXM4-80GB.json +0 -0
  295. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=640,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json +0 -0
  296. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  297. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  298. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=640,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  299. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=64,N=640,device_name=NVIDIA_H200.json +0 -0
  300. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=14336,device_name=AMD_Instinct_MI300X.json +0 -0
  301. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=14336,device_name=AMD_Instinct_MI325X.json +0 -0
  302. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=14336,device_name=AMD_Radeon_Graphics.json +0 -0
  303. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=14336,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  304. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=14336,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  305. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=14336,device_name=NVIDIA_H200.json +0 -0
  306. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=1792,device_name=AMD_Instinct_MI300X.json +0 -0
  307. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=1792,device_name=AMD_Instinct_MI325X.json +0 -0
  308. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=1792,device_name=AMD_Radeon_Graphics.json +0 -0
  309. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=1792,device_name=NVIDIA_A100-SXM4-40GB.json +0 -0
  310. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  311. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=1792,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  312. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=1792,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  313. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=1792,device_name=NVIDIA_H200.json +0 -0
  314. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=2048,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  315. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  316. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  317. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  318. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=2048,device_name=NVIDIA_H200.json +0 -0
  319. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=AMD_Instinct_MI300X.json +0 -0
  320. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=AMD_Instinct_MI325X.json +0 -0
  321. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=AMD_Radeon_Graphics.json +0 -0
  322. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=NVIDIA_A100-SXM4-40GB.json +0 -0
  323. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  324. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json +0 -0
  325. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  326. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  327. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  328. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=NVIDIA_H200.json +0 -0
  329. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=3584,device_name=NVIDIA_L40S.json +0 -0
  330. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=4096,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +0 -0
  331. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=4096,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +0 -0
  332. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=4096,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8.json +0 -0
  333. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=4096,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  334. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  335. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  336. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=4096,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  337. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=4096,device_name=NVIDIA_H200.json +0 -0
  338. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=7168,device_name=AMD_Instinct_MI300X.json +0 -0
  339. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=7168,device_name=AMD_Instinct_MI325X.json +0 -0
  340. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=7168,device_name=AMD_Radeon_Graphics.json +0 -0
  341. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json +0 -0
  342. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  343. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3.json +0 -0
  344. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  345. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=7168,device_name=NVIDIA_H200.json +0 -0
  346. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=8192,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +0 -0
  347. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=8192,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +0 -0
  348. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=8192,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8.json +0 -0
  349. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=8192,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +0 -0
  350. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/configs/E=8,N=8192,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +0 -0
  351. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/fused_moe_triton/layer.py +0 -0
  352. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/moe/router.py +0 -0
  353. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/parameter.py +0 -0
  354. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/pooler.py +0 -0
  355. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/awq.py +0 -0
  356. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/base_config.py +0 -0
  357. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/compressed_tensors/__init__.py +0 -0
  358. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/compressed_tensors/compressed_tensors.py +0 -0
  359. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/compressed_tensors/compressed_tensors_moe.py +0 -0
  360. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/compressed_tensors/schemes/__init__.py +0 -0
  361. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/compressed_tensors/schemes/compressed_tensors_scheme.py +0 -0
  362. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/compressed_tensors/schemes/compressed_tensors_w8a16_fp8.py +0 -0
  363. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/compressed_tensors/schemes/compressed_tensors_w8a8_fp8.py +0 -0
  364. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/compressed_tensors/utils.py +0 -0
  365. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=1536,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  366. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=1536,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  367. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=1536,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  368. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=1536,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  369. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=1536,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  370. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  371. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  372. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=7168,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  373. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  374. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  375. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  376. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  377. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  378. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=1536,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  379. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2048,K=512,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  380. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2048,K=512,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  381. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2048,K=512,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  382. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2048,K=512,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  383. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2048,K=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  384. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2048,K=512,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  385. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2304,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  386. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2304,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  387. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2304,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  388. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2304,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  389. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2304,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  390. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=2304,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  391. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=1536,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  392. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=1536,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  393. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=1536,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  394. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  395. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  396. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  397. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  398. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  399. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  400. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  401. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=24576,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  402. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=256,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  403. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=256,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  404. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=256,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  405. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=256,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  406. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=256,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  407. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=1536,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  408. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=1536,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  409. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=1536,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  410. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=1536,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  411. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=1536,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  412. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=1536,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  413. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  414. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  415. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  416. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=3072,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  417. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  418. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  419. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  420. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  421. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  422. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  423. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  424. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  425. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  426. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  427. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=32768,K=512,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  428. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=36864,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  429. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=36864,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  430. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4096,K=512,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  431. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4096,K=512,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  432. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4096,K=512,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  433. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4096,K=512,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  434. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4096,K=512,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  435. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4096,K=512,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  436. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4096,K=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  437. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4608,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  438. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4608,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  439. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4608,K=7168,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  440. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4608,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  441. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4608,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  442. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4608,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  443. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=4608,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  444. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=512,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  445. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=512,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  446. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=512,K=7168,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  447. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=512,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  448. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=512,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  449. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=512,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  450. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  451. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  452. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  453. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  454. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  455. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  456. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  457. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  458. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  459. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  460. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=576,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  461. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1024,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  462. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1024,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  463. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1024,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  464. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1024,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  465. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1024,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  466. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1024,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  467. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1152,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  468. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1152,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  469. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1152,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  470. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1152,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  471. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1152,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  472. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=1152,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  473. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  474. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  475. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  476. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  477. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=128,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  478. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  479. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  480. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  481. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  482. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  483. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  484. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  485. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  486. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  487. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  488. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=16384,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  489. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=18432,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  490. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=18432,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  491. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=18432,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  492. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=18432,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  493. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=18432,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  494. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=18432,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  495. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=18432,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  496. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=18432,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  497. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2048,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  498. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2048,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  499. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2048,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  500. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2048,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  501. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2048,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  502. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2048,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  503. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  504. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2304,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  505. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2304,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  506. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2304,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  507. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2304,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  508. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2304,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  509. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2304,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  510. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=2304,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  511. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=256,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  512. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=256,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  513. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=256,device_name=AMD_Radeon_Graphics,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  514. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  515. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=256,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128, 128].json +0 -0
  516. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/configs/N=7168,K=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128, 128].json +0 -0
  517. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/fp8_utils.py +0 -0
  518. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/gptq.py +0 -0
  519. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/int8_utils.py +0 -0
  520. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/kv_cache.py +0 -0
  521. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/modelopt_quant.py +0 -0
  522. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/moe_wna16.py +0 -0
  523. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/utils.py +0 -0
  524. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/w8a8_fp8.py +0 -0
  525. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/quantization/w8a8_int8.py +0 -0
  526. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/radix_attention.py +0 -0
  527. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/rotary_embedding.py +0 -0
  528. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/torchao_utils.py +0 -0
  529. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/layers/utils.py +0 -0
  530. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/backend/base_backend.py +0 -0
  531. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/backend/flashinfer_backend.py +0 -0
  532. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/backend/triton_backend.py +0 -0
  533. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/layers.py +0 -0
  534. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/lora.py +0 -0
  535. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/lora_config.py +0 -0
  536. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/lora/triton_ops/__init__.py +0 -0
  537. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/cache_controller.py +0 -0
  538. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/configure_logging.py +0 -0
  539. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/expert_distribution.py +0 -0
  540. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processor.py +0 -0
  541. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/base_processor.py +0 -0
  542. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/clip.py +0 -0
  543. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/deepseek_vl_v2.py +0 -0
  544. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/gemma3.py +0 -0
  545. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/internvl.py +0 -0
  546. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/janus_pro.py +0 -0
  547. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/kimi_vl.py +0 -0
  548. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/minicpm.py +0 -0
  549. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/mlama.py +0 -0
  550. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/mllama4.py +0 -0
  551. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/multimodal_processors/qwen_vl.py +0 -0
  552. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/session_controller.py +0 -0
  553. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/managers/utils.py +0 -0
  554. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/mem_cache/base_prefix_cache.py +0 -0
  555. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/mem_cache/chunk_cache.py +0 -0
  556. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/mem_cache/flush_cache.py +0 -0
  557. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/mem_cache/hiradix_cache.py +0 -0
  558. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/mem_cache/paged_allocator.py +0 -0
  559. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/mem_cache/radix_cache.py +0 -0
  560. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/metrics/func_timer.py +0 -0
  561. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/mm_utils.py +0 -0
  562. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/model_loader/__init__.py +0 -0
  563. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/model_loader/loader.py +0 -0
  564. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/model_loader/utils.py +0 -0
  565. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/model_loader/weight_utils.py +0 -0
  566. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/model_parallel.py +0 -0
  567. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/baichuan.py +0 -0
  568. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/bert.py +0 -0
  569. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/chatglm.py +0 -0
  570. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/clip.py +0 -0
  571. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/commandr.py +0 -0
  572. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/dbrx.py +0 -0
  573. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/deepseek.py +0 -0
  574. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/deepseek_nextn.py +0 -0
  575. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/deepseek_vl2.py +0 -0
  576. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/exaone.py +0 -0
  577. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/gemma.py +0 -0
  578. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/gemma2.py +0 -0
  579. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/gemma2_reward.py +0 -0
  580. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/gemma3_causal.py +0 -0
  581. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/gemma3_mm.py +0 -0
  582. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/gpt2.py +0 -0
  583. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/gpt_bigcode.py +0 -0
  584. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/granite.py +0 -0
  585. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/grok.py +0 -0
  586. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/internlm2.py +0 -0
  587. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/internlm2_reward.py +0 -0
  588. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/internvl.py +0 -0
  589. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/kimi_vl.py +0 -0
  590. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/kimi_vl_moonvit.py +0 -0
  591. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/llama_classification.py +0 -0
  592. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/llama_eagle.py +0 -0
  593. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/llama_eagle3.py +0 -0
  594. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/llama_embedding.py +0 -0
  595. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/llama_reward.py +0 -0
  596. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/llavavid.py +0 -0
  597. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/minicpm.py +0 -0
  598. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/minicpm3.py +0 -0
  599. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/minicpmo.py +0 -0
  600. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/minicpmv.py +0 -0
  601. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/mistral.py +0 -0
  602. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/mixtral_quant.py +0 -0
  603. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/mllama.py +0 -0
  604. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/mllama4.py +0 -0
  605. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/olmo.py +0 -0
  606. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/olmo2.py +0 -0
  607. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/olmoe.py +0 -0
  608. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/phi3_small.py +0 -0
  609. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen.py +0 -0
  610. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen2.py +0 -0
  611. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen2_5_vl.py +0 -0
  612. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen2_classification.py +0 -0
  613. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen2_eagle.py +0 -0
  614. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen2_moe.py +0 -0
  615. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen2_rm.py +0 -0
  616. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen2_vl.py +0 -0
  617. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen3.py +0 -0
  618. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/qwen3_moe.py +0 -0
  619. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/registry.py +0 -0
  620. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/stablelm.py +0 -0
  621. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/xiaomi_mimo.py +0 -0
  622. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/xverse.py +0 -0
  623. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/xverse_moe.py +0 -0
  624. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/models/yivl.py +0 -0
  625. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/patch_torch.py +0 -0
  626. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/platforms/interface.py +0 -0
  627. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/sampling/penaltylib/__init__.py +0 -0
  628. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/sampling/penaltylib/frequency_penalty.py +0 -0
  629. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/sampling/penaltylib/min_new_tokens.py +0 -0
  630. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/sampling/penaltylib/orchestrator.py +0 -0
  631. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/sampling/penaltylib/presence_penalty.py +0 -0
  632. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/speculative/build_eagle_tree.py +0 -0
  633. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/speculative/spec_info.py +0 -0
  634. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/torch_memory_saver_adapter.py +0 -0
  635. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/srt/warmup.py +0 -0
  636. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/__init__.py +0 -0
  637. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/attention/__init__.py +0 -0
  638. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/attention/test_flashattn_backend.py +0 -0
  639. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/attention/test_flashattn_mla_backend.py +0 -0
  640. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/attention/test_prefix_chunk_info.py +0 -0
  641. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/simple_eval_gpqa.py +0 -0
  642. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/simple_eval_math.py +0 -0
  643. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/simple_eval_mgsm.py +0 -0
  644. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/simple_eval_mmlu.py +0 -0
  645. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/test_activation.py +0 -0
  646. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/test_block_fp8.py +0 -0
  647. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/test_block_fp8_ep.py +0 -0
  648. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/test_custom_ops.py +0 -0
  649. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/test_deepep_utils.py +0 -0
  650. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/test_dynamic_grad_mode.py +0 -0
  651. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang/test/test_layernorm.py +0 -0
  652. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang.egg-info/dependency_links.txt +0 -0
  653. {sglang-0.4.6.post3 → sglang-0.4.6.post4}/sglang.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: sglang
3
- Version: 0.4.6.post3
3
+ Version: 0.4.6.post4
4
4
  Summary: SGLang is yet another fast serving framework for large language models and vision language models.
5
5
  License: Apache License
6
6
  Version 2.0, January 2004
@@ -247,7 +247,7 @@ Requires-Dist: xgrammar==0.1.19; extra == "runtime-common"
247
247
  Requires-Dist: blobfile==3.0.0; extra == "runtime-common"
248
248
  Provides-Extra: srt
249
249
  Requires-Dist: sglang[runtime_common]; extra == "srt"
250
- Requires-Dist: sgl-kernel==0.1.1; extra == "srt"
250
+ Requires-Dist: sgl-kernel==0.1.2.post1; extra == "srt"
251
251
  Requires-Dist: flashinfer_python==0.2.5; extra == "srt"
252
252
  Requires-Dist: torch==2.6.0; extra == "srt"
253
253
  Requires-Dist: torchvision==0.21.0; extra == "srt"
@@ -301,6 +301,7 @@ Requires-Dist: sglang[srt]; extra == "all"
301
301
  Requires-Dist: sglang[openai]; extra == "all"
302
302
  Requires-Dist: sglang[anthropic]; extra == "all"
303
303
  Requires-Dist: sglang[litellm]; extra == "all"
304
+ Requires-Dist: sglang[torch_memory_saver]; extra == "all"
304
305
  Provides-Extra: all-hip
305
306
  Requires-Dist: sglang[srt_hip]; extra == "all-hip"
306
307
  Requires-Dist: sglang[openai]; extra == "all-hip"
@@ -368,16 +369,16 @@ Dynamic: license-file
368
369
  - [2025/05] 🔥 Deploying DeepSeek with PD Disaggregation and Large-scale Expert Parallelism on 96 H100 GPUs ([blog](https://lmsys.org/blog/2025-05-05-large-scale-ep/)).
369
370
  - [2025/03] Supercharge DeepSeek-R1 Inference on AMD Instinct MI300X ([AMD blog](https://rocm.blogs.amd.com/artificial-intelligence/DeepSeekR1-Part2/README.html))
370
371
  - [2025/03] SGLang Joins PyTorch Ecosystem: Efficient LLM Serving Engine ([PyTorch blog](https://pytorch.org/blog/sglang-joins-pytorch/))
371
- - [2025/02] Unlock DeepSeek-R1 Inference Performance on AMD Instinct™ MI300X GPU ([AMD blog](https://rocm.blogs.amd.com/artificial-intelligence/DeepSeekR1_Perf/README.html))
372
372
  - [2025/01] 🔥 SGLang provides day one support for DeepSeek V3/R1 models on NVIDIA and AMD GPUs with DeepSeek-specific optimizations. ([instructions](https://github.com/sgl-project/sglang/tree/main/benchmark/deepseek_v3), [AMD blog](https://www.amd.com/en/developer/resources/technical-articles/amd-instinct-gpus-power-deepseek-v3-revolutionizing-ai-development-with-sglang.html), [10+ other companies](https://x.com/lmsysorg/status/1887262321636221412))
373
373
  - [2024/12] 🔥 v0.4 Release: Zero-Overhead Batch Scheduler, Cache-Aware Load Balancer, Faster Structured Outputs ([blog](https://lmsys.org/blog/2024-12-04-sglang-v0-4/)).
374
- - [2024/09] v0.3 Release: 7x Faster DeepSeek MLA, 1.5x Faster torch.compile, Multi-Image/Video LLaVA-OneVision ([blog](https://lmsys.org/blog/2024-09-04-sglang-v0-3/)).
375
374
  - [2024/07] v0.2 Release: Faster Llama3 Serving with SGLang Runtime (vs. TensorRT-LLM, vLLM) ([blog](https://lmsys.org/blog/2024-07-25-sglang-llama3/)).
376
375
 
377
376
  <details>
378
377
  <summary>More</summary>
379
378
 
379
+ - [2025/02] Unlock DeepSeek-R1 Inference Performance on AMD Instinct™ MI300X GPU ([AMD blog](https://rocm.blogs.amd.com/artificial-intelligence/DeepSeekR1_Perf/README.html))
380
380
  - [2024/10] The First SGLang Online Meetup ([slides](https://github.com/sgl-project/sgl-learning-materials?tab=readme-ov-file#the-first-sglang-online-meetup)).
381
+ - [2024/09] v0.3 Release: 7x Faster DeepSeek MLA, 1.5x Faster torch.compile, Multi-Image/Video LLaVA-OneVision ([blog](https://lmsys.org/blog/2024-09-04-sglang-v0-3/)).
381
382
  - [2024/02] SGLang enables **3x faster JSON decoding** with compressed finite state machine ([blog](https://lmsys.org/blog/2024-02-05-compressed-fsm/)).
382
383
  - [2024/01] SGLang provides up to **5x faster inference** with RadixAttention ([blog](https://lmsys.org/blog/2024-01-17-sglang/)).
383
384
  - [2024/01] SGLang powers the serving of the official **LLaVA v1.6** release demo ([usage](https://github.com/haotian-liu/LLaVA?tab=readme-ov-file#demo)).
@@ -409,7 +410,7 @@ Learn more in the release blogs: [v0.2 blog](https://lmsys.org/blog/2024-07-25-s
409
410
 
410
411
  ## Adoption and Sponsorship
411
412
  The project has been deployed to large-scale production, generating trillions of tokens every day.
412
- It is supported by the following institutions: AMD, Atlas Cloud, Baseten, Cursor, DataCrunch, Etched, Google Cloud, Hyperbolic, Iflytek, Jam & Tea Studios, LinkedIn, LMSYS, Meituan, Nebius, Novita AI, NVIDIA, Oracle, RunPod, Stanford, UC Berkeley, UCLA, xAI, and 01.AI.
413
+ It is supported by the following institutions: AMD, Atlas Cloud, Baseten, Cursor, DataCrunch, Etched, Google Cloud, Hyperbolic, Iflytek, InnoMatrix, Jam & Tea Studios, LinkedIn, LMSYS, Meituan, Nebius, Novita AI, NVIDIA, Oracle, RunPod, Stanford, UC Berkeley, UCLA, xAI, and 01.AI.
413
414
 
414
415
  <img src="https://raw.githubusercontent.com/sgl-project/sgl-learning-materials/main/slides/adoption.png" alt="logo" width="800" margin="10px"></img>
415
416
 
@@ -23,16 +23,16 @@
23
23
  - [2025/05] 🔥 Deploying DeepSeek with PD Disaggregation and Large-scale Expert Parallelism on 96 H100 GPUs ([blog](https://lmsys.org/blog/2025-05-05-large-scale-ep/)).
24
24
  - [2025/03] Supercharge DeepSeek-R1 Inference on AMD Instinct MI300X ([AMD blog](https://rocm.blogs.amd.com/artificial-intelligence/DeepSeekR1-Part2/README.html))
25
25
  - [2025/03] SGLang Joins PyTorch Ecosystem: Efficient LLM Serving Engine ([PyTorch blog](https://pytorch.org/blog/sglang-joins-pytorch/))
26
- - [2025/02] Unlock DeepSeek-R1 Inference Performance on AMD Instinct™ MI300X GPU ([AMD blog](https://rocm.blogs.amd.com/artificial-intelligence/DeepSeekR1_Perf/README.html))
27
26
  - [2025/01] 🔥 SGLang provides day one support for DeepSeek V3/R1 models on NVIDIA and AMD GPUs with DeepSeek-specific optimizations. ([instructions](https://github.com/sgl-project/sglang/tree/main/benchmark/deepseek_v3), [AMD blog](https://www.amd.com/en/developer/resources/technical-articles/amd-instinct-gpus-power-deepseek-v3-revolutionizing-ai-development-with-sglang.html), [10+ other companies](https://x.com/lmsysorg/status/1887262321636221412))
28
27
  - [2024/12] 🔥 v0.4 Release: Zero-Overhead Batch Scheduler, Cache-Aware Load Balancer, Faster Structured Outputs ([blog](https://lmsys.org/blog/2024-12-04-sglang-v0-4/)).
29
- - [2024/09] v0.3 Release: 7x Faster DeepSeek MLA, 1.5x Faster torch.compile, Multi-Image/Video LLaVA-OneVision ([blog](https://lmsys.org/blog/2024-09-04-sglang-v0-3/)).
30
28
  - [2024/07] v0.2 Release: Faster Llama3 Serving with SGLang Runtime (vs. TensorRT-LLM, vLLM) ([blog](https://lmsys.org/blog/2024-07-25-sglang-llama3/)).
31
29
 
32
30
  <details>
33
31
  <summary>More</summary>
34
32
 
33
+ - [2025/02] Unlock DeepSeek-R1 Inference Performance on AMD Instinct™ MI300X GPU ([AMD blog](https://rocm.blogs.amd.com/artificial-intelligence/DeepSeekR1_Perf/README.html))
35
34
  - [2024/10] The First SGLang Online Meetup ([slides](https://github.com/sgl-project/sgl-learning-materials?tab=readme-ov-file#the-first-sglang-online-meetup)).
35
+ - [2024/09] v0.3 Release: 7x Faster DeepSeek MLA, 1.5x Faster torch.compile, Multi-Image/Video LLaVA-OneVision ([blog](https://lmsys.org/blog/2024-09-04-sglang-v0-3/)).
36
36
  - [2024/02] SGLang enables **3x faster JSON decoding** with compressed finite state machine ([blog](https://lmsys.org/blog/2024-02-05-compressed-fsm/)).
37
37
  - [2024/01] SGLang provides up to **5x faster inference** with RadixAttention ([blog](https://lmsys.org/blog/2024-01-17-sglang/)).
38
38
  - [2024/01] SGLang powers the serving of the official **LLaVA v1.6** release demo ([usage](https://github.com/haotian-liu/LLaVA?tab=readme-ov-file#demo)).
@@ -64,7 +64,7 @@ Learn more in the release blogs: [v0.2 blog](https://lmsys.org/blog/2024-07-25-s
64
64
 
65
65
  ## Adoption and Sponsorship
66
66
  The project has been deployed to large-scale production, generating trillions of tokens every day.
67
- It is supported by the following institutions: AMD, Atlas Cloud, Baseten, Cursor, DataCrunch, Etched, Google Cloud, Hyperbolic, Iflytek, Jam & Tea Studios, LinkedIn, LMSYS, Meituan, Nebius, Novita AI, NVIDIA, Oracle, RunPod, Stanford, UC Berkeley, UCLA, xAI, and 01.AI.
67
+ It is supported by the following institutions: AMD, Atlas Cloud, Baseten, Cursor, DataCrunch, Etched, Google Cloud, Hyperbolic, Iflytek, InnoMatrix, Jam & Tea Studios, LinkedIn, LMSYS, Meituan, Nebius, Novita AI, NVIDIA, Oracle, RunPod, Stanford, UC Berkeley, UCLA, xAI, and 01.AI.
68
68
 
69
69
  <img src="https://raw.githubusercontent.com/sgl-project/sgl-learning-materials/main/slides/adoption.png" alt="logo" width="800" margin="10px"></img>
70
70
 
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
4
4
 
5
5
  [project]
6
6
  name = "sglang"
7
- version = "0.4.6.post3"
7
+ version = "0.4.6.post4"
8
8
  description = "SGLang is yet another fast serving framework for large language models and vision language models."
9
9
  readme = "README.md"
10
10
  requires-python = ">=3.8"
@@ -48,7 +48,7 @@ runtime_common = [
48
48
 
49
49
  srt = [
50
50
  "sglang[runtime_common]",
51
- "sgl-kernel==0.1.1",
51
+ "sgl-kernel==0.1.2.post1",
52
52
  "flashinfer_python==0.2.5",
53
53
  "torch==2.6.0",
54
54
  "torchvision==0.21.0",
@@ -103,7 +103,7 @@ test = [
103
103
  "accelerate",
104
104
  "peft",
105
105
  ]
106
- all = ["sglang[srt]", "sglang[openai]", "sglang[anthropic]", "sglang[litellm]"]
106
+ all = ["sglang[srt]", "sglang[openai]", "sglang[anthropic]", "sglang[litellm]", "sglang[torch_memory_saver]"]
107
107
  all_hip = ["sglang[srt_hip]", "sglang[openai]", "sglang[anthropic]", "sglang[litellm]"]
108
108
  all_xpu = ["sglang[srt_xpu]", "sglang[openai]", "sglang[anthropic]", "sglang[litellm]"]
109
109
  all_hpu = ["sglang[srt_hpu]", "sglang[openai]", "sglang[anthropic]", "sglang[litellm]"]
@@ -147,3 +147,7 @@ exclude = [
147
147
  "scripts*",
148
148
  "tests*",
149
149
  ]
150
+
151
+ [tool.codespell]
152
+ ignore-words-list = "ans, als, hel, boostrap, childs, te, vas, hsa, ment"
153
+ skip = "*.json,*.jsonl,*.patch,*.txt"
@@ -259,7 +259,9 @@ def throughput_test_once(
259
259
  measurement_results["total_input_tokens"]
260
260
  + measurement_results["total_output_tokens"]
261
261
  ) / latency
262
- measurement_results["last_gen_throughput"] = server_info["last_gen_throughput"]
262
+ measurement_results["last_gen_throughput"] = server_info["internal_states"][0][
263
+ "last_gen_throughput"
264
+ ]
263
265
 
264
266
  return measurement_results
265
267
 
@@ -315,7 +317,7 @@ def throughput_test(
315
317
  tokenizer_id = server_args.tokenizer_path or server_args.model_path
316
318
  tokenizer = get_tokenizer(tokenizer_id)
317
319
 
318
- # Set global environmnets
320
+ # Set global environments
319
321
  set_ulimit()
320
322
  random.seed(bench_args.seed)
321
323
  np.random.seed(bench_args.seed)
@@ -246,7 +246,7 @@ def extend(reqs, model_runner):
246
246
  _maybe_prepare_dp_attn_batch(batch, model_runner)
247
247
  model_worker_batch = batch.get_model_worker_batch()
248
248
  forward_batch = ForwardBatch.init_new(model_worker_batch, model_runner)
249
- logits_output = model_runner.forward(forward_batch)
249
+ logits_output, _ = model_runner.forward(forward_batch)
250
250
  next_token_ids = model_runner.sample(logits_output, forward_batch)
251
251
  return next_token_ids, logits_output.next_token_logits, batch
252
252
 
@@ -258,7 +258,7 @@ def decode(input_token_ids, batch, model_runner):
258
258
  _maybe_prepare_dp_attn_batch(batch, model_runner)
259
259
  model_worker_batch = batch.get_model_worker_batch()
260
260
  forward_batch = ForwardBatch.init_new(model_worker_batch, model_runner)
261
- logits_output = model_runner.forward(forward_batch)
261
+ logits_output, _ = model_runner.forward(forward_batch)
262
262
  next_token_ids = model_runner.sample(logits_output, forward_batch)
263
263
  return next_token_ids, logits_output.next_token_logits
264
264
 
@@ -25,6 +25,7 @@ import requests
25
25
  from sglang.srt.entrypoints.http_server import launch_server
26
26
  from sglang.srt.server_args import ServerArgs
27
27
  from sglang.srt.utils import kill_process_tree
28
+ from sglang.test.test_utils import is_in_ci, write_github_step_summary
28
29
 
29
30
 
30
31
  @dataclasses.dataclass
@@ -33,9 +34,13 @@ class BenchArgs:
33
34
  batch_size: Tuple[int] = (1,)
34
35
  input_len: Tuple[int] = (1024,)
35
36
  output_len: Tuple[int] = (16,)
37
+ temperature: float = 0.0
38
+ return_logprob: bool = False
39
+ input_len_step_percentage: float = 0.0
36
40
  result_filename: str = "result.jsonl"
37
41
  base_url: str = ""
38
42
  skip_warmup: bool = False
43
+ show_report: bool = False
39
44
 
40
45
  @staticmethod
41
46
  def add_cli_args(parser: argparse.ArgumentParser):
@@ -49,11 +54,19 @@ class BenchArgs:
49
54
  parser.add_argument(
50
55
  "--output-len", type=int, nargs="+", default=BenchArgs.output_len
51
56
  )
57
+ parser.add_argument("--temperature", type=float, default=BenchArgs.temperature)
58
+ parser.add_argument("--return-logprob", action="store_true")
59
+ parser.add_argument(
60
+ "--input-len-step-percentage",
61
+ type=float,
62
+ default=BenchArgs.input_len_step_percentage,
63
+ )
52
64
  parser.add_argument(
53
65
  "--result-filename", type=str, default=BenchArgs.result_filename
54
66
  )
55
67
  parser.add_argument("--base-url", type=str, default=BenchArgs.base_url)
56
68
  parser.add_argument("--skip-warmup", action="store_true")
69
+ parser.add_argument("--show-report", action="store_true")
57
70
 
58
71
  @classmethod
59
72
  def from_cli_args(cls, args: argparse.Namespace):
@@ -99,36 +112,89 @@ def run_one_case(
99
112
  batch_size: int,
100
113
  input_len: int,
101
114
  output_len: int,
115
+ temperature: float,
116
+ return_logprob: bool,
117
+ input_len_step_percentage: float,
102
118
  run_name: str,
103
119
  result_filename: str,
104
120
  ):
121
+ requests.post(url + "/flush_cache")
122
+ input_lens = [
123
+ int(input_len * (1 + (i - (batch_size - 1) / 2) * input_len_step_percentage))
124
+ for i in range(batch_size)
125
+ ]
105
126
  input_ids = [
106
- [int(x) for x in np.random.randint(0, high=16384, size=(input_len,))]
107
- for _ in range(batch_size)
127
+ [int(x) for x in np.random.randint(0, high=16384, size=(input_lens[i],))]
128
+ for i in range(batch_size)
108
129
  ]
109
130
 
131
+ use_structured_outputs = False
132
+ if use_structured_outputs:
133
+ texts = []
134
+ for _ in range(batch_size):
135
+ texts.append(
136
+ "Human: What is the capital city of france? can you give as many trivial information as possible about that city? answer in json.\n"
137
+ * 50
138
+ + "Assistant:"
139
+ )
140
+ json_schema = "$$ANY$$"
141
+ else:
142
+ json_schema = None
143
+
110
144
  tic = time.time()
111
145
  response = requests.post(
112
146
  url + "/generate",
113
147
  json={
148
+ # "text": texts,
114
149
  "input_ids": input_ids,
115
150
  "sampling_params": {
116
- "temperature": 0,
151
+ "temperature": temperature,
117
152
  "max_new_tokens": output_len,
118
153
  "ignore_eos": True,
154
+ "json_schema": json_schema,
119
155
  },
156
+ "return_logprob": return_logprob,
157
+ "stream": True,
120
158
  },
159
+ stream=True,
121
160
  )
122
- latency = time.time() - tic
123
161
 
124
- _ = response.json()
125
- output_throughput = batch_size * output_len / latency
162
+ # The TTFT of the last request in the batch
163
+ ttft = 0.0
164
+ for chunk in response.iter_lines(decode_unicode=False):
165
+ chunk = chunk.decode("utf-8")
166
+ if chunk and chunk.startswith("data:"):
167
+ if chunk == "data: [DONE]":
168
+ break
169
+ data = json.loads(chunk[5:].strip("\n"))
170
+ if "error" in data:
171
+ raise RuntimeError(f"Request has failed. {data}.")
172
+
173
+ assert (
174
+ data["meta_info"]["finish_reason"] is None
175
+ or data["meta_info"]["finish_reason"]["type"] == "length"
176
+ )
177
+ if data["meta_info"]["completion_tokens"] == 1:
178
+ ttft = time.time() - tic
179
+
180
+ latency = time.time() - tic
181
+ input_throughput = batch_size * input_len / ttft
182
+ output_throughput = batch_size * output_len / (latency - ttft)
126
183
  overall_throughput = batch_size * (input_len + output_len) / latency
127
184
 
185
+ server_info = requests.get(url + "/get_server_info").json()
186
+ acc_length = server_info["internal_states"][0].get("avg_spec_accept_length", None)
187
+ last_gen_throughput = server_info["internal_states"][0]["last_gen_throughput"]
188
+
128
189
  print(f"batch size: {batch_size}")
190
+ print(f"input_len: {input_len}")
191
+ print(f"output_len: {output_len}")
129
192
  print(f"latency: {latency:.2f} s")
130
- print(f"output throughput: {output_throughput:.2f} token/s")
131
- print(f"(input + output) throughput: {overall_throughput:.2f} token/s")
193
+ print(f"ttft: {ttft:.2f} s")
194
+ print(f"Last generation throughput: {last_gen_throughput:.2f} tok/s")
195
+ print(f"Input throughput: {input_throughput:.2f} tok/s")
196
+ if output_len != 1:
197
+ print(f"output throughput: {output_throughput:.2f} tok/s")
132
198
 
133
199
  if result_filename:
134
200
  with open(result_filename, "a") as fout:
@@ -140,9 +206,21 @@ def run_one_case(
140
206
  "latency": round(latency, 4),
141
207
  "output_throughput": round(output_throughput, 2),
142
208
  "overall_throughput": round(overall_throughput, 2),
209
+ "last_gen_throughput": round(last_gen_throughput, 2),
143
210
  }
144
211
  fout.write(json.dumps(res) + "\n")
145
212
 
213
+ return (
214
+ batch_size,
215
+ latency,
216
+ ttft,
217
+ input_throughput,
218
+ output_throughput,
219
+ overall_throughput,
220
+ last_gen_throughput,
221
+ acc_length,
222
+ )
223
+
146
224
 
147
225
  def run_benchmark(server_args: ServerArgs, bench_args: BenchArgs):
148
226
  if bench_args.base_url:
@@ -152,27 +230,38 @@ def run_benchmark(server_args: ServerArgs, bench_args: BenchArgs):
152
230
 
153
231
  # warmup
154
232
  if not bench_args.skip_warmup:
233
+ print("=" * 8 + " Warmup Begin " + "=" * 8)
155
234
  run_one_case(
156
235
  base_url,
157
236
  batch_size=16,
158
237
  input_len=1024,
159
238
  output_len=16,
239
+ temperature=bench_args.temperature,
240
+ return_logprob=bench_args.return_logprob,
241
+ input_len_step_percentage=bench_args.input_len_step_percentage,
160
242
  run_name="",
161
243
  result_filename="",
162
244
  )
245
+ print("=" * 8 + " Warmup End " + "=" * 8 + "\n")
163
246
 
164
247
  # benchmark
248
+ result = []
165
249
  try:
166
250
  for bs, il, ol in itertools.product(
167
251
  bench_args.batch_size, bench_args.input_len, bench_args.output_len
168
252
  ):
169
- run_one_case(
170
- base_url,
171
- bs,
172
- il,
173
- ol,
174
- bench_args.run_name,
175
- bench_args.result_filename,
253
+ result.append(
254
+ run_one_case(
255
+ base_url,
256
+ bs,
257
+ il,
258
+ ol,
259
+ temperature=bench_args.temperature,
260
+ return_logprob=bench_args.return_logprob,
261
+ input_len_step_percentage=bench_args.input_len_step_percentage,
262
+ run_name=bench_args.run_name,
263
+ result_filename=bench_args.result_filename,
264
+ )
176
265
  )
177
266
  finally:
178
267
  if proc:
@@ -180,6 +269,45 @@ def run_benchmark(server_args: ServerArgs, bench_args: BenchArgs):
180
269
 
181
270
  print(f"\nResults are saved to {bench_args.result_filename}")
182
271
 
272
+ if not bench_args.show_report:
273
+ return
274
+
275
+ summary = " | batch size | latency (s) | input throughput (tok/s) | output throughput (tok/s) | acc length | ITL (ms) | input price ($/1M) | output price ($/1M) |\n"
276
+ summary += "| ---------- | ----------- | ------------------------- | ------------------------- | ---------- | -------- | ------------------ | ------------------- |\n"
277
+
278
+ for (
279
+ batch_size,
280
+ latency,
281
+ ttft,
282
+ input_throughput,
283
+ output_throughput,
284
+ overall_throughput,
285
+ last_gen_throughput,
286
+ acc_length,
287
+ ) in result:
288
+ hourly_cost = 2 * server_args.tp_size # $2/hour for one H100
289
+ input_util = 0.7
290
+ accept_length = round(acc_length, 2) if acc_length is not None else "n/a"
291
+ line = (
292
+ f"| {batch_size} | "
293
+ f"{latency:.2f} | "
294
+ f"{input_throughput:.2f} | "
295
+ f"{output_throughput:.2f} | "
296
+ f"{accept_length} | "
297
+ f"{1 / (output_throughput/batch_size) * 1000:.2f} | "
298
+ f"{1e6 / (input_throughput * input_util) / 3600 * hourly_cost:.2f} | "
299
+ f"{1e6 / output_throughput / 3600 * hourly_cost:.2f} |\n"
300
+ )
301
+ summary += line
302
+
303
+ # print metrics table
304
+ print(summary)
305
+
306
+ if is_in_ci():
307
+ write_github_step_summary(
308
+ f"### Test Nightly Benchmark (bench_one_batch) \n{summary}"
309
+ )
310
+
183
311
 
184
312
  if __name__ == "__main__":
185
313
  parser = argparse.ArgumentParser()
@@ -1103,7 +1103,7 @@ async def benchmark(
1103
1103
  lora_names: List[str],
1104
1104
  extra_request_body: Dict[str, Any],
1105
1105
  profile: bool,
1106
- pd_seperated: bool = False,
1106
+ pd_separated: bool = False,
1107
1107
  flush_cache: bool = False,
1108
1108
  warmup_requests: int = 1,
1109
1109
  ):
@@ -1239,12 +1239,14 @@ async def benchmark(
1239
1239
 
1240
1240
  if "sglang" in backend:
1241
1241
  server_info = requests.get(base_url + "/get_server_info")
1242
- if pd_seperated:
1243
- accept_length = server_info.json()["decode"][0].get(
1242
+ if pd_separated:
1243
+ accept_length = server_info.json()["decode"][0]["internal_states"][0].get(
1244
1244
  "avg_spec_accept_length", None
1245
1245
  )
1246
1246
  else:
1247
- accept_length = server_info.json().get("avg_spec_accept_length", None)
1247
+ accept_length = server_info.json()["internal_states"][0].get(
1248
+ "avg_spec_accept_length", None
1249
+ )
1248
1250
  else:
1249
1251
  accept_length = None
1250
1252
 
@@ -1263,7 +1265,7 @@ async def benchmark(
1263
1265
  print("{:<40} {:<10}".format("Traffic request rate:", request_rate))
1264
1266
  print(
1265
1267
  "{:<40} {:<10}".format(
1266
- "Max reqeuest concurrency:",
1268
+ "Max request concurrency:",
1267
1269
  max_concurrency if max_concurrency else "not set",
1268
1270
  )
1269
1271
  )
@@ -1541,7 +1543,7 @@ def run_benchmark(args_: argparse.Namespace):
1541
1543
  lora_names=args.lora_name,
1542
1544
  extra_request_body=extra_request_body,
1543
1545
  profile=args.profile,
1544
- pd_seperated=args.pd_seperated,
1546
+ pd_separated=args.pd_separated,
1545
1547
  flush_cache=args.flush_cache,
1546
1548
  )
1547
1549
  )
@@ -1720,7 +1722,7 @@ if __name__ == "__main__":
1720
1722
  help="Suffix applied to the end of all user prompts, followed by assistant prompt suffix.",
1721
1723
  )
1722
1724
  parser.add_argument(
1723
- "--pd-seperated",
1725
+ "--pd-separated",
1724
1726
  action="store_true",
1725
1727
  help="Benchmark PD disaggregation server",
1726
1728
  )
@@ -129,7 +129,7 @@ def launch_server_process_and_send_one_request(
129
129
 
130
130
 
131
131
  def refine_server_args(server_args: ServerArgs, compile_args: CompileArgs):
132
- # Disbale cuda graph and torch compile to save time
132
+ # Disable cuda graph and torch compile to save time
133
133
  server_args.disable_cuda_graph = True
134
134
  server_args.enable_torch_compile = False
135
135
  print(f"Disable CUDA Graph and Torch Compile to save time...")
@@ -0,0 +1,157 @@
1
+ import argparse
2
+ import asyncio
3
+ import os
4
+ import pickle
5
+ from pathlib import Path
6
+ from typing import List
7
+
8
+ import openai
9
+ import torch
10
+ from bert_score import BERTScorer
11
+ from datasets import load_dataset
12
+ from tqdm import tqdm
13
+
14
+
15
+ def get_client(api_url: str) -> openai.AsyncOpenAI:
16
+ if os.getenv("OPENAI_API_KEY") is None:
17
+ os.environ["OPENAI_API_KEY"] = "EMPTY"
18
+ return openai.AsyncOpenAI(base_url=api_url)
19
+
20
+
21
+ def get_dataset():
22
+ return load_dataset("bigai-nlco/LooGLE", "longdep_qa", split="test")
23
+
24
+
25
+ async def fetch_response(
26
+ client: openai.AsyncOpenAI,
27
+ context: str,
28
+ question: str,
29
+ semaphore: asyncio.Semaphore,
30
+ index: int,
31
+ model: str,
32
+ output_dir: Path,
33
+ ):
34
+ output_file = output_dir / f"response_{index}.pkl"
35
+ if output_file.exists():
36
+ return
37
+
38
+ prompt = (
39
+ "Please answer the question based on the long texts below.\n"
40
+ f"{context}\n"
41
+ f"Question: {question}\n"
42
+ "Answer:"
43
+ )
44
+ messages = [
45
+ {"role": "system", "content": "You are a helpful assistant."},
46
+ {"role": "user", "content": prompt},
47
+ ]
48
+
49
+ async with semaphore:
50
+ try:
51
+ response = await client.chat.completions.create(
52
+ model=model,
53
+ messages=messages,
54
+ temperature=0.0,
55
+ max_tokens=512,
56
+ )
57
+ except openai.BadRequestError as e:
58
+ with open(output_file, "wb") as f:
59
+ pickle.dump({"error": str(e)}, f)
60
+ return
61
+
62
+ with open(output_file, "wb") as f:
63
+ pickle.dump(response, f)
64
+
65
+
66
+ async def benchmark(args):
67
+ dataset = get_dataset()
68
+ output_dir = Path(args.output_dir)
69
+ output_dir.mkdir(parents=True, exist_ok=True)
70
+
71
+ client = get_client(args.api_url)
72
+ semaphore = asyncio.Semaphore(args.max_concurrency)
73
+
74
+ tasks: List[asyncio.Task] = []
75
+ for idx, ex in enumerate(dataset):
76
+ tasks.append(
77
+ asyncio.create_task(
78
+ fetch_response(
79
+ client,
80
+ ex["context"],
81
+ ex["question"],
82
+ semaphore,
83
+ idx,
84
+ args.model,
85
+ output_dir,
86
+ )
87
+ )
88
+ )
89
+
90
+ for _ in tqdm(
91
+ asyncio.as_completed(tasks), total=len(tasks), desc="Running benchmark"
92
+ ):
93
+ await _
94
+
95
+
96
+ def analyse(args):
97
+ dataset = get_dataset()
98
+ output_dir = Path(args.output_dir)
99
+
100
+ device = "cuda" if torch.cuda.is_available() else "cpu"
101
+ scorer = BERTScorer(lang="en", device=device)
102
+
103
+ hyps: List[str] = []
104
+ refs: List[str] = []
105
+ for idx, ex in enumerate(tqdm(dataset, desc="Loading responses")):
106
+ pkl_file = output_dir / f"response_{idx}.pkl"
107
+ if not pkl_file.exists():
108
+ raise FileNotFoundError(pkl_file)
109
+
110
+ response = pickle.load(open(pkl_file, "rb"))
111
+ if isinstance(response, dict) and "error" in response:
112
+ continue
113
+
114
+ hyps.append(response.choices[0].message.content.strip())
115
+ refs.append(ex["answer"])
116
+
117
+ if not hyps:
118
+ print("No valid responses to score!")
119
+ return
120
+
121
+ batch_size = 64
122
+ all_f1: List[float] = []
123
+ for i in tqdm(range(0, len(hyps), batch_size), desc="Scoring batches"):
124
+ h_batch = hyps[i : i + batch_size]
125
+ r_batch = refs[i : i + batch_size]
126
+ _, _, f1_scores = scorer.score(h_batch, r_batch, verbose=False)
127
+ all_f1.extend([float(x) for x in f1_scores])
128
+
129
+ avg = sum(all_f1) / len(all_f1)
130
+ print(f"Average BERTScore (F1): {avg:.2%}")
131
+
132
+
133
+ if __name__ == "__main__":
134
+ parser = argparse.ArgumentParser(
135
+ description="Run benchmark and evaluation in one go."
136
+ )
137
+ parser.add_argument(
138
+ "--api-url",
139
+ default="http://127.0.0.1:30000/v1",
140
+ help="OpenAI‑compatible API base URL",
141
+ )
142
+ parser.add_argument(
143
+ "--model",
144
+ default="meta-llama/Llama-4-Maverick-17B-128E-Instruct",
145
+ help="Model name or ID, only used for model name",
146
+ )
147
+ parser.add_argument(
148
+ "--max-concurrency", type=int, default=144, help="Maximum concurrent requests"
149
+ )
150
+ parser.add_argument(
151
+ "--output-dir", default="tmp-output-dir", help="Directory for cached responses"
152
+ )
153
+ args = parser.parse_args()
154
+
155
+ asyncio.run(benchmark(args))
156
+
157
+ analyse(args)