vllm-cpu 0.8.5.post2__cp310-cp310-manylinux_2_17_x86_64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of vllm-cpu might be problematic. Click here for more details.

Files changed (1103) hide show
  1. vllm/_C.abi3.so +0 -0
  2. vllm/__init__.py +170 -0
  3. vllm/_custom_ops.py +1536 -0
  4. vllm/_ipex_ops.py +241 -0
  5. vllm/_version.py +34 -0
  6. vllm/adapter_commons/__init__.py +0 -0
  7. vllm/adapter_commons/layers.py +16 -0
  8. vllm/adapter_commons/models.py +105 -0
  9. vllm/adapter_commons/request.py +25 -0
  10. vllm/adapter_commons/utils.py +92 -0
  11. vllm/adapter_commons/worker_manager.py +38 -0
  12. vllm/assets/__init__.py +0 -0
  13. vllm/assets/audio.py +38 -0
  14. vllm/assets/base.py +40 -0
  15. vllm/assets/image.py +31 -0
  16. vllm/assets/video.py +103 -0
  17. vllm/attention/__init__.py +19 -0
  18. vllm/attention/backends/__init__.py +0 -0
  19. vllm/attention/backends/abstract.py +306 -0
  20. vllm/attention/backends/blocksparse_attn.py +457 -0
  21. vllm/attention/backends/cpu_mla.py +303 -0
  22. vllm/attention/backends/flash_attn.py +999 -0
  23. vllm/attention/backends/flashinfer.py +1092 -0
  24. vllm/attention/backends/flashmla.py +242 -0
  25. vllm/attention/backends/hpu_attn.py +301 -0
  26. vllm/attention/backends/ipex_attn.py +396 -0
  27. vllm/attention/backends/mla/__init__.py +0 -0
  28. vllm/attention/backends/mla/common.py +1444 -0
  29. vllm/attention/backends/pallas.py +346 -0
  30. vllm/attention/backends/placeholder_attn.py +399 -0
  31. vllm/attention/backends/rocm_aiter_mla.py +412 -0
  32. vllm/attention/backends/rocm_flash_attn.py +969 -0
  33. vllm/attention/backends/torch_sdpa.py +691 -0
  34. vllm/attention/backends/triton_mla.py +113 -0
  35. vllm/attention/backends/utils.py +609 -0
  36. vllm/attention/backends/xformers.py +798 -0
  37. vllm/attention/layer.py +443 -0
  38. vllm/attention/ops/__init__.py +0 -0
  39. vllm/attention/ops/blocksparse_attention/__init__.py +0 -0
  40. vllm/attention/ops/blocksparse_attention/blocksparse_attention_kernel.py +432 -0
  41. vllm/attention/ops/blocksparse_attention/interface.py +238 -0
  42. vllm/attention/ops/blocksparse_attention/utils.py +244 -0
  43. vllm/attention/ops/chunked_prefill_paged_decode.py +366 -0
  44. vllm/attention/ops/flashmla.py +115 -0
  45. vllm/attention/ops/hpu_paged_attn.py +105 -0
  46. vllm/attention/ops/ipex_attn.py +193 -0
  47. vllm/attention/ops/merge_attn_states.py +42 -0
  48. vllm/attention/ops/nki_flash_attn.py +905 -0
  49. vllm/attention/ops/paged_attn.py +255 -0
  50. vllm/attention/ops/prefix_prefill.py +902 -0
  51. vllm/attention/ops/rocm_aiter_mla.py +42 -0
  52. vllm/attention/ops/rocm_aiter_paged_attn.py +101 -0
  53. vllm/attention/ops/triton_decode_attention.py +675 -0
  54. vllm/attention/ops/triton_flash_attention.py +1375 -0
  55. vllm/attention/ops/triton_merge_attn_states.py +96 -0
  56. vllm/attention/selector.py +186 -0
  57. vllm/attention/utils/fa_utils.py +54 -0
  58. vllm/beam_search.py +82 -0
  59. vllm/benchmarks/__init__.py +0 -0
  60. vllm/benchmarks/datasets.py +831 -0
  61. vllm/benchmarks/endpoint_request_func.py +160 -0
  62. vllm/benchmarks/latency.py +181 -0
  63. vllm/benchmarks/serve.py +925 -0
  64. vllm/benchmarks/throughput.py +608 -0
  65. vllm/benchmarks/utils.py +69 -0
  66. vllm/collect_env.py +795 -0
  67. vllm/compilation/__init__.py +0 -0
  68. vllm/compilation/backends.py +715 -0
  69. vllm/compilation/compiler_interface.py +437 -0
  70. vllm/compilation/counter.py +33 -0
  71. vllm/compilation/decorators.py +249 -0
  72. vllm/compilation/fix_functionalization.py +182 -0
  73. vllm/compilation/fusion.py +617 -0
  74. vllm/compilation/fx_utils.py +60 -0
  75. vllm/compilation/inductor_pass.py +114 -0
  76. vllm/compilation/monitor.py +38 -0
  77. vllm/compilation/multi_output_match.py +108 -0
  78. vllm/compilation/noop_elimination.py +135 -0
  79. vllm/compilation/pass_manager.py +74 -0
  80. vllm/compilation/sequence_parallelism.py +266 -0
  81. vllm/compilation/torch25_custom_graph_pass.py +41 -0
  82. vllm/compilation/vllm_inductor_pass.py +68 -0
  83. vllm/compilation/wrapper.py +129 -0
  84. vllm/config.py +4179 -0
  85. vllm/connections.py +170 -0
  86. vllm/core/__init__.py +0 -0
  87. vllm/core/block/__init__.py +0 -0
  88. vllm/core/block/block_table.py +398 -0
  89. vllm/core/block/common.py +370 -0
  90. vllm/core/block/cpu_gpu_block_allocator.py +440 -0
  91. vllm/core/block/interfaces.py +318 -0
  92. vllm/core/block/naive_block.py +465 -0
  93. vllm/core/block/prefix_caching_block.py +1134 -0
  94. vllm/core/block/utils.py +27 -0
  95. vllm/core/block_manager.py +520 -0
  96. vllm/core/evictor.py +156 -0
  97. vllm/core/interfaces.py +134 -0
  98. vllm/core/placeholder_block_space_manager.py +99 -0
  99. vllm/core/scheduler.py +2060 -0
  100. vllm/device_allocator/__init__.py +0 -0
  101. vllm/device_allocator/cumem.py +280 -0
  102. vllm/distributed/__init__.py +5 -0
  103. vllm/distributed/communication_op.py +40 -0
  104. vllm/distributed/device_communicators/__init__.py +0 -0
  105. vllm/distributed/device_communicators/base_device_communicator.py +151 -0
  106. vllm/distributed/device_communicators/cpu_communicator.py +139 -0
  107. vllm/distributed/device_communicators/cuda_communicator.py +131 -0
  108. vllm/distributed/device_communicators/cuda_wrapper.py +179 -0
  109. vllm/distributed/device_communicators/custom_all_reduce.py +301 -0
  110. vllm/distributed/device_communicators/custom_all_reduce_utils.py +257 -0
  111. vllm/distributed/device_communicators/hpu_communicator.py +45 -0
  112. vllm/distributed/device_communicators/neuron_communicator.py +19 -0
  113. vllm/distributed/device_communicators/pynccl.py +217 -0
  114. vllm/distributed/device_communicators/pynccl_wrapper.py +340 -0
  115. vllm/distributed/device_communicators/shm_broadcast.py +557 -0
  116. vllm/distributed/device_communicators/tpu_communicator.py +93 -0
  117. vllm/distributed/device_communicators/xpu_communicator.py +54 -0
  118. vllm/distributed/kv_transfer/README.md +29 -0
  119. vllm/distributed/kv_transfer/__init__.py +11 -0
  120. vllm/distributed/kv_transfer/disagg_prefill_workflow.jpg +0 -0
  121. vllm/distributed/kv_transfer/kv_connector/__init__.py +0 -0
  122. vllm/distributed/kv_transfer/kv_connector/base.py +127 -0
  123. vllm/distributed/kv_transfer/kv_connector/factory.py +107 -0
  124. vllm/distributed/kv_transfer/kv_connector/lmcache_connector.py +98 -0
  125. vllm/distributed/kv_transfer/kv_connector/mooncake_store_connector.py +201 -0
  126. vllm/distributed/kv_transfer/kv_connector/simple_connector.py +328 -0
  127. vllm/distributed/kv_transfer/kv_connector/utils.py +90 -0
  128. vllm/distributed/kv_transfer/kv_connector/v1/__init__.py +8 -0
  129. vllm/distributed/kv_transfer/kv_connector/v1/base.py +209 -0
  130. vllm/distributed/kv_transfer/kv_connector/v1/lmcache_connector.py +131 -0
  131. vllm/distributed/kv_transfer/kv_connector/v1/shared_storage_connector.py +383 -0
  132. vllm/distributed/kv_transfer/kv_connector_agent.py +76 -0
  133. vllm/distributed/kv_transfer/kv_lookup_buffer/__init__.py +0 -0
  134. vllm/distributed/kv_transfer/kv_lookup_buffer/base.py +174 -0
  135. vllm/distributed/kv_transfer/kv_lookup_buffer/mooncake_store.py +160 -0
  136. vllm/distributed/kv_transfer/kv_lookup_buffer/simple_buffer.py +236 -0
  137. vllm/distributed/kv_transfer/kv_pipe/__init__.py +0 -0
  138. vllm/distributed/kv_transfer/kv_pipe/base.py +66 -0
  139. vllm/distributed/kv_transfer/kv_pipe/mooncake_pipe.py +279 -0
  140. vllm/distributed/kv_transfer/kv_pipe/pynccl_pipe.py +279 -0
  141. vllm/distributed/kv_transfer/kv_transfer_state.py +70 -0
  142. vllm/distributed/parallel_state.py +1209 -0
  143. vllm/distributed/utils.py +366 -0
  144. vllm/engine/__init__.py +0 -0
  145. vllm/engine/arg_utils.py +1724 -0
  146. vllm/engine/async_llm_engine.py +1261 -0
  147. vllm/engine/async_timeout.py +191 -0
  148. vllm/engine/llm_engine.py +2150 -0
  149. vllm/engine/metrics.py +717 -0
  150. vllm/engine/metrics_types.py +96 -0
  151. vllm/engine/multiprocessing/__init__.py +183 -0
  152. vllm/engine/multiprocessing/client.py +745 -0
  153. vllm/engine/multiprocessing/engine.py +450 -0
  154. vllm/engine/output_processor/__init__.py +0 -0
  155. vllm/engine/output_processor/interfaces.py +74 -0
  156. vllm/engine/output_processor/multi_step.py +210 -0
  157. vllm/engine/output_processor/single_step.py +136 -0
  158. vllm/engine/output_processor/stop_checker.py +130 -0
  159. vllm/engine/output_processor/util.py +27 -0
  160. vllm/engine/protocol.py +302 -0
  161. vllm/entrypoints/__init__.py +0 -0
  162. vllm/entrypoints/api_server.py +177 -0
  163. vllm/entrypoints/chat_utils.py +1259 -0
  164. vllm/entrypoints/cli/__init__.py +0 -0
  165. vllm/entrypoints/cli/benchmark/__init__.py +0 -0
  166. vllm/entrypoints/cli/benchmark/base.py +38 -0
  167. vllm/entrypoints/cli/benchmark/latency.py +29 -0
  168. vllm/entrypoints/cli/benchmark/main.py +53 -0
  169. vllm/entrypoints/cli/benchmark/serve.py +29 -0
  170. vllm/entrypoints/cli/benchmark/throughput.py +29 -0
  171. vllm/entrypoints/cli/collect_env.py +35 -0
  172. vllm/entrypoints/cli/main.py +59 -0
  173. vllm/entrypoints/cli/openai.py +175 -0
  174. vllm/entrypoints/cli/serve.py +59 -0
  175. vllm/entrypoints/cli/types.py +24 -0
  176. vllm/entrypoints/launcher.py +146 -0
  177. vllm/entrypoints/llm.py +1450 -0
  178. vllm/entrypoints/logger.py +44 -0
  179. vllm/entrypoints/openai/__init__.py +0 -0
  180. vllm/entrypoints/openai/api_server.py +1130 -0
  181. vllm/entrypoints/openai/cli_args.py +296 -0
  182. vllm/entrypoints/openai/logits_processors.py +89 -0
  183. vllm/entrypoints/openai/protocol.py +1806 -0
  184. vllm/entrypoints/openai/run_batch.py +439 -0
  185. vllm/entrypoints/openai/serving_chat.py +1210 -0
  186. vllm/entrypoints/openai/serving_completion.py +557 -0
  187. vllm/entrypoints/openai/serving_embedding.py +245 -0
  188. vllm/entrypoints/openai/serving_engine.py +569 -0
  189. vllm/entrypoints/openai/serving_models.py +314 -0
  190. vllm/entrypoints/openai/serving_pooling.py +237 -0
  191. vllm/entrypoints/openai/serving_score.py +439 -0
  192. vllm/entrypoints/openai/serving_tokenization.py +147 -0
  193. vllm/entrypoints/openai/serving_transcription.py +421 -0
  194. vllm/entrypoints/openai/tool_parsers/__init__.py +19 -0
  195. vllm/entrypoints/openai/tool_parsers/abstract_tool_parser.py +163 -0
  196. vllm/entrypoints/openai/tool_parsers/granite_20b_fc_tool_parser.py +254 -0
  197. vllm/entrypoints/openai/tool_parsers/granite_tool_parser.py +232 -0
  198. vllm/entrypoints/openai/tool_parsers/hermes_tool_parser.py +370 -0
  199. vllm/entrypoints/openai/tool_parsers/internlm2_tool_parser.py +211 -0
  200. vllm/entrypoints/openai/tool_parsers/jamba_tool_parser.py +303 -0
  201. vllm/entrypoints/openai/tool_parsers/llama_tool_parser.py +262 -0
  202. vllm/entrypoints/openai/tool_parsers/mistral_tool_parser.py +342 -0
  203. vllm/entrypoints/openai/tool_parsers/phi4mini_tool_parser.py +110 -0
  204. vllm/entrypoints/openai/tool_parsers/pythonic_tool_parser.py +292 -0
  205. vllm/entrypoints/openai/tool_parsers/utils.py +123 -0
  206. vllm/entrypoints/score_utils.py +49 -0
  207. vllm/entrypoints/ssl.py +74 -0
  208. vllm/entrypoints/utils.py +136 -0
  209. vllm/env_override.py +34 -0
  210. vllm/envs.py +800 -0
  211. vllm/executor/__init__.py +0 -0
  212. vllm/executor/executor_base.py +400 -0
  213. vllm/executor/mp_distributed_executor.py +243 -0
  214. vllm/executor/msgspec_utils.py +29 -0
  215. vllm/executor/multiproc_worker_utils.py +312 -0
  216. vllm/executor/ray_distributed_executor.py +700 -0
  217. vllm/executor/ray_utils.py +400 -0
  218. vllm/executor/uniproc_executor.py +141 -0
  219. vllm/forward_context.py +159 -0
  220. vllm/inputs/__init__.py +37 -0
  221. vllm/inputs/data.py +248 -0
  222. vllm/inputs/parse.py +121 -0
  223. vllm/inputs/preprocess.py +745 -0
  224. vllm/inputs/registry.py +212 -0
  225. vllm/jsontree.py +79 -0
  226. vllm/logger.py +210 -0
  227. vllm/logging_utils/__init__.py +7 -0
  228. vllm/logging_utils/formatter.py +17 -0
  229. vllm/logits_process.py +121 -0
  230. vllm/lora/__init__.py +0 -0
  231. vllm/lora/fully_sharded_layers.py +335 -0
  232. vllm/lora/layers.py +1263 -0
  233. vllm/lora/lora.py +198 -0
  234. vllm/lora/models.py +802 -0
  235. vllm/lora/ops/__init__.py +0 -0
  236. vllm/lora/ops/torch_ops/__init__.py +15 -0
  237. vllm/lora/ops/torch_ops/lora_ops.py +115 -0
  238. vllm/lora/ops/triton_ops/__init__.py +11 -0
  239. vllm/lora/ops/triton_ops/kernel_utils.py +243 -0
  240. vllm/lora/ops/triton_ops/lora_expand.py +293 -0
  241. vllm/lora/ops/triton_ops/lora_kernel_metadata.py +147 -0
  242. vllm/lora/ops/triton_ops/lora_shrink.py +247 -0
  243. vllm/lora/ops/triton_ops/utils.py +121 -0
  244. vllm/lora/peft_helper.py +115 -0
  245. vllm/lora/punica_wrapper/__init__.py +9 -0
  246. vllm/lora/punica_wrapper/punica_base.py +483 -0
  247. vllm/lora/punica_wrapper/punica_cpu.py +348 -0
  248. vllm/lora/punica_wrapper/punica_gpu.py +289 -0
  249. vllm/lora/punica_wrapper/punica_hpu.py +144 -0
  250. vllm/lora/punica_wrapper/punica_selector.py +20 -0
  251. vllm/lora/punica_wrapper/utils.py +161 -0
  252. vllm/lora/request.py +97 -0
  253. vllm/lora/resolver.py +83 -0
  254. vllm/lora/utils.py +237 -0
  255. vllm/lora/worker_manager.py +251 -0
  256. vllm/model_executor/__init__.py +15 -0
  257. vllm/model_executor/custom_op.py +153 -0
  258. vllm/model_executor/guided_decoding/__init__.py +180 -0
  259. vllm/model_executor/guided_decoding/guidance_decoding.py +63 -0
  260. vllm/model_executor/guided_decoding/guidance_logits_processors.py +85 -0
  261. vllm/model_executor/guided_decoding/guided_fields.py +42 -0
  262. vllm/model_executor/guided_decoding/lm_format_enforcer_decoding.py +66 -0
  263. vllm/model_executor/guided_decoding/outlines_decoding.py +154 -0
  264. vllm/model_executor/guided_decoding/outlines_logits_processors.py +271 -0
  265. vllm/model_executor/guided_decoding/reasoner/__init__.py +35 -0
  266. vllm/model_executor/guided_decoding/utils.py +241 -0
  267. vllm/model_executor/guided_decoding/xgrammar_decoding.py +425 -0
  268. vllm/model_executor/layers/__init__.py +0 -0
  269. vllm/model_executor/layers/activation.py +368 -0
  270. vllm/model_executor/layers/fused_moe/__init__.py +51 -0
  271. vllm/model_executor/layers/fused_moe/configs/E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  272. vllm/model_executor/layers/fused_moe/configs/E=1,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  273. vllm/model_executor/layers/fused_moe/configs/E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  274. vllm/model_executor/layers/fused_moe/configs/E=1,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  275. vllm/model_executor/layers/fused_moe/configs/E=1,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  276. vllm/model_executor/layers/fused_moe/configs/E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +218 -0
  277. vllm/model_executor/layers/fused_moe/configs/E=1,N=3072,device_name=NVIDIA_H100_80GB_HBM3.json +218 -0
  278. vllm/model_executor/layers/fused_moe/configs/E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  279. vllm/model_executor/layers/fused_moe/configs/E=1,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  280. vllm/model_executor/layers/fused_moe/configs/E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  281. vllm/model_executor/layers/fused_moe/configs/E=1,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  282. vllm/model_executor/layers/fused_moe/configs/E=128,N=1024,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  283. vllm/model_executor/layers/fused_moe/configs/E=128,N=192,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  284. vllm/model_executor/layers/fused_moe/configs/E=128,N=192,device_name=NVIDIA_H20.json +146 -0
  285. vllm/model_executor/layers/fused_moe/configs/E=128,N=192,device_name=NVIDIA_H200.json +146 -0
  286. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  287. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H20.json +146 -0
  288. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  289. vllm/model_executor/layers/fused_moe/configs/E=128,N=384,device_name=NVIDIA_H200.json +146 -0
  290. vllm/model_executor/layers/fused_moe/configs/E=128,N=512,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  291. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  292. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_H20.json +146 -0
  293. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  294. vllm/model_executor/layers/fused_moe/configs/E=128,N=768,device_name=NVIDIA_H200.json +146 -0
  295. vllm/model_executor/layers/fused_moe/configs/E=128,N=96,device_name=NVIDIA_H20.json +146 -0
  296. vllm/model_executor/layers/fused_moe/configs/E=16,N=1024,device_name=AMD_Instinct_MI300X.json +200 -0
  297. vllm/model_executor/layers/fused_moe/configs/E=16,N=1024,device_name=NVIDIA_H100.json +146 -0
  298. vllm/model_executor/layers/fused_moe/configs/E=16,N=1344,device_name=NVIDIA_A100-SXM4-40GB.json +146 -0
  299. vllm/model_executor/layers/fused_moe/configs/E=16,N=1344,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  300. vllm/model_executor/layers/fused_moe/configs/E=16,N=1344,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  301. vllm/model_executor/layers/fused_moe/configs/E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  302. vllm/model_executor/layers/fused_moe/configs/E=16,N=14336,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  303. vllm/model_executor/layers/fused_moe/configs/E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +218 -0
  304. vllm/model_executor/layers/fused_moe/configs/E=16,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  305. vllm/model_executor/layers/fused_moe/configs/E=16,N=2688,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  306. vllm/model_executor/layers/fused_moe/configs/E=16,N=2688,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  307. vllm/model_executor/layers/fused_moe/configs/E=16,N=3072,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  308. vllm/model_executor/layers/fused_moe/configs/E=16,N=3072,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  309. vllm/model_executor/layers/fused_moe/configs/E=16,N=3200,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +130 -0
  310. vllm/model_executor/layers/fused_moe/configs/E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  311. vllm/model_executor/layers/fused_moe/configs/E=16,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json +218 -0
  312. vllm/model_executor/layers/fused_moe/configs/E=16,N=6400,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +130 -0
  313. vllm/model_executor/layers/fused_moe/configs/E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a16.json +146 -0
  314. vllm/model_executor/layers/fused_moe/configs/E=16,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  315. vllm/model_executor/layers/fused_moe/configs/E=16,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=int8_w8a16.json +146 -0
  316. vllm/model_executor/layers/fused_moe/configs/E=16,N=800,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +130 -0
  317. vllm/model_executor/layers/fused_moe/configs/E=160,N=192,device_name=NVIDIA_A800-SXM4-80GB.json +146 -0
  318. vllm/model_executor/layers/fused_moe/configs/E=256,N=1024,device_name=AMD_Instinct_MI325X,block_shape=[128,128].json +200 -0
  319. vllm/model_executor/layers/fused_moe/configs/E=256,N=1024,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +200 -0
  320. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  321. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8.json +146 -0
  322. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  323. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8.json +146 -0
  324. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  325. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  326. vllm/model_executor/layers/fused_moe/configs/E=256,N=128,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  327. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  328. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +200 -0
  329. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +200 -0
  330. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  331. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  332. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  333. vllm/model_executor/layers/fused_moe/configs/E=256,N=256,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  334. vllm/model_executor/layers/fused_moe/configs/E=256,N=512,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +200 -0
  335. vllm/model_executor/layers/fused_moe/configs/E=256,N=64,device_name=NVIDIA_A800-SXM4-80GB.json +146 -0
  336. vllm/model_executor/layers/fused_moe/configs/E=60,N=1408,device_name=AMD_Instinct_MI300X.json +200 -0
  337. vllm/model_executor/layers/fused_moe/configs/E=60,N=176,device_name=AMD_Instinct_MI300X.json +200 -0
  338. vllm/model_executor/layers/fused_moe/configs/E=60,N=352,device_name=AMD_Instinct_MI300X.json +200 -0
  339. vllm/model_executor/layers/fused_moe/configs/E=60,N=704,device_name=AMD_Instinct_MI300X.json +200 -0
  340. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  341. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_A800-SXM4-80GB.json +146 -0
  342. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  343. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  344. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  345. vllm/model_executor/layers/fused_moe/configs/E=64,N=1280,device_name=NVIDIA_H200.json +146 -0
  346. vllm/model_executor/layers/fused_moe/configs/E=64,N=2560,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  347. vllm/model_executor/layers/fused_moe/configs/E=64,N=2560,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  348. vllm/model_executor/layers/fused_moe/configs/E=64,N=2560,device_name=NVIDIA_H200.json +146 -0
  349. vllm/model_executor/layers/fused_moe/configs/E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  350. vllm/model_executor/layers/fused_moe/configs/E=64,N=320,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  351. vllm/model_executor/layers/fused_moe/configs/E=64,N=320,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  352. vllm/model_executor/layers/fused_moe/configs/E=64,N=320,device_name=NVIDIA_H200.json +146 -0
  353. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  354. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_A800-SXM4-80GB.json +146 -0
  355. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json +146 -0
  356. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  357. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  358. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  359. vllm/model_executor/layers/fused_moe/configs/E=64,N=640,device_name=NVIDIA_H200.json +146 -0
  360. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  361. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=AMD_Instinct_MI300X.json +200 -0
  362. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  363. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=AMD_Instinct_MI325X.json +200 -0
  364. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +138 -0
  365. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  366. vllm/model_executor/layers/fused_moe/configs/E=8,N=14336,device_name=NVIDIA_H200.json +146 -0
  367. vllm/model_executor/layers/fused_moe/configs/E=8,N=16384,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  368. vllm/model_executor/layers/fused_moe/configs/E=8,N=16384,device_name=AMD_Instinct_MI300X.json +200 -0
  369. vllm/model_executor/layers/fused_moe/configs/E=8,N=16384,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  370. vllm/model_executor/layers/fused_moe/configs/E=8,N=16384,device_name=AMD_Instinct_MI325X.json +200 -0
  371. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  372. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=AMD_Instinct_MI300X.json +200 -0
  373. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  374. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=AMD_Instinct_MI325X.json +200 -0
  375. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_A100-SXM4-40GB.json +146 -0
  376. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  377. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  378. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  379. vllm/model_executor/layers/fused_moe/configs/E=8,N=1792,device_name=NVIDIA_H200.json +146 -0
  380. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  381. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=AMD_Instinct_MI300X.json +200 -0
  382. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  383. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=AMD_Instinct_MI325X.json +200 -0
  384. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  385. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  386. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  387. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  388. vllm/model_executor/layers/fused_moe/configs/E=8,N=2048,device_name=NVIDIA_H200.json +146 -0
  389. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  390. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=AMD_Instinct_MI300X.json +200 -0
  391. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  392. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=AMD_Instinct_MI325X.json +200 -0
  393. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_A100-SXM4-40GB.json +146 -0
  394. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  395. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_GeForce_RTX_4090,dtype=fp8_w8a8.json +146 -0
  396. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  397. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  398. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  399. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_H200.json +146 -0
  400. vllm/model_executor/layers/fused_moe/configs/E=8,N=3584,device_name=NVIDIA_L40S.json +173 -0
  401. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  402. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=AMD_Instinct_MI300X.json +200 -0
  403. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  404. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=AMD_Instinct_MI325X.json +200 -0
  405. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  406. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  407. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  408. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  409. vllm/model_executor/layers/fused_moe/configs/E=8,N=4096,device_name=NVIDIA_H200.json +146 -0
  410. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  411. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=AMD_Instinct_MI300X.json +200 -0
  412. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  413. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=AMD_Instinct_MI325X.json +200 -0
  414. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_A100-SXM4-80GB.json +146 -0
  415. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  416. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_H100_80GB_HBM3.json +146 -0
  417. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  418. vllm/model_executor/layers/fused_moe/configs/E=8,N=7168,device_name=NVIDIA_H200.json +146 -0
  419. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8.json +164 -0
  420. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=AMD_Instinct_MI300X.json +200 -0
  421. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8.json +164 -0
  422. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=AMD_Instinct_MI325X.json +200 -0
  423. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8.json +146 -0
  424. vllm/model_executor/layers/fused_moe/configs/E=8,N=8192,device_name=NVIDIA_H200,dtype=fp8_w8a8.json +146 -0
  425. vllm/model_executor/layers/fused_moe/configs/README +12 -0
  426. vllm/model_executor/layers/fused_moe/cutlass_moe.py +180 -0
  427. vllm/model_executor/layers/fused_moe/deep_gemm_moe.py +294 -0
  428. vllm/model_executor/layers/fused_moe/fused_marlin_moe.py +374 -0
  429. vllm/model_executor/layers/fused_moe/fused_moe.py +1539 -0
  430. vllm/model_executor/layers/fused_moe/layer.py +949 -0
  431. vllm/model_executor/layers/fused_moe/moe_align_block_size.py +243 -0
  432. vllm/model_executor/layers/fused_moe/moe_pallas.py +64 -0
  433. vllm/model_executor/layers/fused_moe/moe_torch_iterative.py +59 -0
  434. vllm/model_executor/layers/fused_moe/rocm_aiter_fused_moe.py +416 -0
  435. vllm/model_executor/layers/fused_moe/utils.py +48 -0
  436. vllm/model_executor/layers/layernorm.py +277 -0
  437. vllm/model_executor/layers/lightning_attn.py +651 -0
  438. vllm/model_executor/layers/linear.py +1518 -0
  439. vllm/model_executor/layers/logits_processor.py +196 -0
  440. vllm/model_executor/layers/mamba/__init__.py +0 -0
  441. vllm/model_executor/layers/mamba/mamba2_metadata.py +109 -0
  442. vllm/model_executor/layers/mamba/mamba_mixer.py +244 -0
  443. vllm/model_executor/layers/mamba/mamba_mixer2.py +538 -0
  444. vllm/model_executor/layers/mamba/ops/__init__.py +0 -0
  445. vllm/model_executor/layers/mamba/ops/causal_conv1d.py +104 -0
  446. vllm/model_executor/layers/mamba/ops/mamba_ssm.py +415 -0
  447. vllm/model_executor/layers/mamba/ops/ssd_bmm.py +261 -0
  448. vllm/model_executor/layers/mamba/ops/ssd_chunk_scan.py +588 -0
  449. vllm/model_executor/layers/mamba/ops/ssd_chunk_state.py +750 -0
  450. vllm/model_executor/layers/mamba/ops/ssd_combined.py +231 -0
  451. vllm/model_executor/layers/mamba/ops/ssd_state_passing.py +205 -0
  452. vllm/model_executor/layers/pooler.py +336 -0
  453. vllm/model_executor/layers/quantization/__init__.py +153 -0
  454. vllm/model_executor/layers/quantization/aqlm.py +374 -0
  455. vllm/model_executor/layers/quantization/awq.py +184 -0
  456. vllm/model_executor/layers/quantization/awq_marlin.py +518 -0
  457. vllm/model_executor/layers/quantization/awq_triton.py +319 -0
  458. vllm/model_executor/layers/quantization/base_config.py +145 -0
  459. vllm/model_executor/layers/quantization/bitblas.py +459 -0
  460. vllm/model_executor/layers/quantization/bitsandbytes.py +396 -0
  461. vllm/model_executor/layers/quantization/compressed_tensors/__init__.py +0 -0
  462. vllm/model_executor/layers/quantization/compressed_tensors/compressed_tensors.py +624 -0
  463. vllm/model_executor/layers/quantization/compressed_tensors/compressed_tensors_moe.py +1100 -0
  464. vllm/model_executor/layers/quantization/compressed_tensors/schemes/__init__.py +20 -0
  465. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_24.py +357 -0
  466. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_scheme.py +54 -0
  467. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w4a16_24.py +159 -0
  468. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w8a16_fp8.py +119 -0
  469. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w8a8_fp8.py +149 -0
  470. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_w8a8_int8.py +110 -0
  471. vllm/model_executor/layers/quantization/compressed_tensors/schemes/compressed_tensors_wNa16.py +200 -0
  472. vllm/model_executor/layers/quantization/compressed_tensors/triton_scaled_mm.py +205 -0
  473. vllm/model_executor/layers/quantization/compressed_tensors/utils.py +213 -0
  474. vllm/model_executor/layers/quantization/deepspeedfp.py +193 -0
  475. vllm/model_executor/layers/quantization/experts_int8.py +194 -0
  476. vllm/model_executor/layers/quantization/fbgemm_fp8.py +168 -0
  477. vllm/model_executor/layers/quantization/fp8.py +832 -0
  478. vllm/model_executor/layers/quantization/gguf.py +408 -0
  479. vllm/model_executor/layers/quantization/gptq.py +276 -0
  480. vllm/model_executor/layers/quantization/gptq_bitblas.py +438 -0
  481. vllm/model_executor/layers/quantization/gptq_marlin.py +643 -0
  482. vllm/model_executor/layers/quantization/gptq_marlin_24.py +295 -0
  483. vllm/model_executor/layers/quantization/hqq_marlin.py +328 -0
  484. vllm/model_executor/layers/quantization/ipex_quant.py +250 -0
  485. vllm/model_executor/layers/quantization/kernels/__init__.py +0 -0
  486. vllm/model_executor/layers/quantization/kernels/mixed_precision/MPLinearKernel.py +89 -0
  487. vllm/model_executor/layers/quantization/kernels/mixed_precision/__init__.py +82 -0
  488. vllm/model_executor/layers/quantization/kernels/mixed_precision/allspark.py +115 -0
  489. vllm/model_executor/layers/quantization/kernels/mixed_precision/bitblas.py +299 -0
  490. vllm/model_executor/layers/quantization/kernels/mixed_precision/exllama.py +142 -0
  491. vllm/model_executor/layers/quantization/kernels/mixed_precision/machete.py +119 -0
  492. vllm/model_executor/layers/quantization/kernels/mixed_precision/marlin.py +132 -0
  493. vllm/model_executor/layers/quantization/kernels/scaled_mm/ScaledMMLinearKernel.py +66 -0
  494. vllm/model_executor/layers/quantization/kernels/scaled_mm/__init__.py +86 -0
  495. vllm/model_executor/layers/quantization/kernels/scaled_mm/aiter.py +119 -0
  496. vllm/model_executor/layers/quantization/kernels/scaled_mm/cutlass.py +136 -0
  497. vllm/model_executor/layers/quantization/kernels/scaled_mm/triton.py +40 -0
  498. vllm/model_executor/layers/quantization/kernels/scaled_mm/xla.py +104 -0
  499. vllm/model_executor/layers/quantization/kv_cache.py +137 -0
  500. vllm/model_executor/layers/quantization/marlin.py +259 -0
  501. vllm/model_executor/layers/quantization/modelopt.py +410 -0
  502. vllm/model_executor/layers/quantization/moe_wna16.py +447 -0
  503. vllm/model_executor/layers/quantization/neuron_quant.py +67 -0
  504. vllm/model_executor/layers/quantization/ptpc_fp8.py +125 -0
  505. vllm/model_executor/layers/quantization/qqq.py +273 -0
  506. vllm/model_executor/layers/quantization/quark/__init__.py +0 -0
  507. vllm/model_executor/layers/quantization/quark/quark.py +385 -0
  508. vllm/model_executor/layers/quantization/quark/quark_moe.py +236 -0
  509. vllm/model_executor/layers/quantization/quark/schemes/__init__.py +7 -0
  510. vllm/model_executor/layers/quantization/quark/schemes/quark_scheme.py +54 -0
  511. vllm/model_executor/layers/quantization/quark/schemes/quark_w8a8_fp8.py +142 -0
  512. vllm/model_executor/layers/quantization/quark/schemes/quark_w8a8_int8.py +121 -0
  513. vllm/model_executor/layers/quantization/quark/utils.py +102 -0
  514. vllm/model_executor/layers/quantization/schema.py +85 -0
  515. vllm/model_executor/layers/quantization/torchao.py +127 -0
  516. vllm/model_executor/layers/quantization/tpu_int8.py +119 -0
  517. vllm/model_executor/layers/quantization/utils/__init__.py +5 -0
  518. vllm/model_executor/layers/quantization/utils/allspark_utils.py +51 -0
  519. vllm/model_executor/layers/quantization/utils/bitblas_utils.py +198 -0
  520. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  521. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  522. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  523. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  524. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  525. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  526. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  527. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=1536,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  528. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  529. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  530. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  531. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  532. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  533. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  534. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  535. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  536. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  537. vllm/model_executor/layers/quantization/utils/configs/N=1536,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  538. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  539. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  540. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  541. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  542. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  543. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  544. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  545. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  546. vllm/model_executor/layers/quantization/utils/configs/N=2048,K=512,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  547. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  548. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  549. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  550. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  551. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  552. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  553. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  554. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  555. vllm/model_executor/layers/quantization/utils/configs/N=2304,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  556. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  557. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  558. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  559. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  560. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  561. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  562. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  563. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  564. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  565. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  566. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  567. vllm/model_executor/layers/quantization/utils/configs/N=24576,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  568. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  569. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  570. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  571. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  572. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  573. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  574. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  575. vllm/model_executor/layers/quantization/utils/configs/N=256,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  576. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  577. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  578. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  579. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  580. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  581. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  582. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=1536,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  583. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  584. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  585. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  586. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  587. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  588. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  589. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  590. vllm/model_executor/layers/quantization/utils/configs/N=3072,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  591. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  592. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  593. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  594. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  595. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  596. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  597. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  598. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  599. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  600. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  601. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  602. vllm/model_executor/layers/quantization/utils/configs/N=32768,K=512,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  603. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  604. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  605. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  606. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  607. vllm/model_executor/layers/quantization/utils/configs/N=36864,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  608. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  609. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  610. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  611. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  612. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  613. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  614. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  615. vllm/model_executor/layers/quantization/utils/configs/N=4096,K=512,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  616. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  617. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  618. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  619. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  620. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  621. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  622. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  623. vllm/model_executor/layers/quantization/utils/configs/N=4608,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  624. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  625. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  626. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  627. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  628. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  629. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  630. vllm/model_executor/layers/quantization/utils/configs/N=512,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  631. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  632. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  633. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  634. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  635. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  636. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  637. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  638. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  639. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  640. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  641. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +18 -0
  642. vllm/model_executor/layers/quantization/utils/configs/N=576,K=7168,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  643. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  644. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  645. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  646. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  647. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  648. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  649. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  650. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  651. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1024,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  652. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  653. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  654. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  655. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  656. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  657. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  658. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  659. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  660. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=1152,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  661. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  662. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  663. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  664. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  665. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  666. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  667. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  668. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=128,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  669. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  670. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  671. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  672. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  673. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  674. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  675. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  676. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  677. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  678. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  679. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  680. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=16384,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  681. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  682. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  683. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  684. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_A100-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  685. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_A800-SXM4-80GB,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  686. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  687. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  688. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_H20,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  689. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  690. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  691. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  692. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=18432,device_name=NVIDIA_L20Y,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  693. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  694. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  695. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  696. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  697. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  698. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  699. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  700. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2048,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  701. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  702. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  703. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  704. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  705. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_H100_80GB_HBM3,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  706. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  707. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  708. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=2304,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  709. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  710. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  711. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  712. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=NVIDIA_B200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  713. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=NVIDIA_H20,dtype=int8_w8a8,block_shape=[128,128].json +146 -0
  714. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=NVIDIA_H200,dtype=fp8_w8a8,block_shape=[128,128].json +146 -0
  715. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=256,device_name=NVIDIA_L20,dtype=fp8_w8a8,block_shape=[128,128].json +26 -0
  716. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=8192,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  717. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=8192,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  718. vllm/model_executor/layers/quantization/utils/configs/N=7168,K=8192,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  719. vllm/model_executor/layers/quantization/utils/configs/N=8192,K=1536,device_name=AMD_Instinct_MI300X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  720. vllm/model_executor/layers/quantization/utils/configs/N=8192,K=1536,device_name=AMD_Instinct_MI325X,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  721. vllm/model_executor/layers/quantization/utils/configs/N=8192,K=1536,device_name=AMD_Instinct_MI325_OAM,dtype=fp8_w8a8,block_shape=[128,128].json +164 -0
  722. vllm/model_executor/layers/quantization/utils/fp8_utils.py +523 -0
  723. vllm/model_executor/layers/quantization/utils/gptq_utils.py +94 -0
  724. vllm/model_executor/layers/quantization/utils/int8_utils.py +459 -0
  725. vllm/model_executor/layers/quantization/utils/layer_utils.py +39 -0
  726. vllm/model_executor/layers/quantization/utils/machete_utils.py +32 -0
  727. vllm/model_executor/layers/quantization/utils/marlin_utils.py +413 -0
  728. vllm/model_executor/layers/quantization/utils/marlin_utils_fp8.py +110 -0
  729. vllm/model_executor/layers/quantization/utils/marlin_utils_test.py +164 -0
  730. vllm/model_executor/layers/quantization/utils/marlin_utils_test_24.py +464 -0
  731. vllm/model_executor/layers/quantization/utils/marlin_utils_test_qqq.py +127 -0
  732. vllm/model_executor/layers/quantization/utils/quant_utils.py +571 -0
  733. vllm/model_executor/layers/quantization/utils/w8a8_utils.py +404 -0
  734. vllm/model_executor/layers/rejection_sampler.py +400 -0
  735. vllm/model_executor/layers/resampler.py +269 -0
  736. vllm/model_executor/layers/rotary_embedding.py +1598 -0
  737. vllm/model_executor/layers/sampler.py +1221 -0
  738. vllm/model_executor/layers/spec_decode_base_sampler.py +258 -0
  739. vllm/model_executor/layers/typical_acceptance_sampler.py +172 -0
  740. vllm/model_executor/layers/utils.py +99 -0
  741. vllm/model_executor/layers/vocab_parallel_embedding.py +485 -0
  742. vllm/model_executor/model_loader/__init__.py +20 -0
  743. vllm/model_executor/model_loader/loader.py +1542 -0
  744. vllm/model_executor/model_loader/neuron.py +243 -0
  745. vllm/model_executor/model_loader/tensorizer.py +468 -0
  746. vllm/model_executor/model_loader/utils.py +171 -0
  747. vllm/model_executor/model_loader/weight_utils.py +749 -0
  748. vllm/model_executor/models/__init__.py +27 -0
  749. vllm/model_executor/models/adapters.py +247 -0
  750. vllm/model_executor/models/arctic.py +559 -0
  751. vllm/model_executor/models/aria.py +656 -0
  752. vllm/model_executor/models/aya_vision.py +461 -0
  753. vllm/model_executor/models/baichuan.py +469 -0
  754. vllm/model_executor/models/bamba.py +542 -0
  755. vllm/model_executor/models/bart.py +936 -0
  756. vllm/model_executor/models/bert.py +725 -0
  757. vllm/model_executor/models/blip.py +337 -0
  758. vllm/model_executor/models/blip2.py +717 -0
  759. vllm/model_executor/models/bloom.py +358 -0
  760. vllm/model_executor/models/chameleon.py +1135 -0
  761. vllm/model_executor/models/chatglm.py +476 -0
  762. vllm/model_executor/models/clip.py +410 -0
  763. vllm/model_executor/models/commandr.py +466 -0
  764. vllm/model_executor/models/constant_size_cache.py +136 -0
  765. vllm/model_executor/models/dbrx.py +469 -0
  766. vllm/model_executor/models/deepseek.py +484 -0
  767. vllm/model_executor/models/deepseek_mtp.py +266 -0
  768. vllm/model_executor/models/deepseek_v2.py +830 -0
  769. vllm/model_executor/models/deepseek_vl2.py +647 -0
  770. vllm/model_executor/models/eagle.py +247 -0
  771. vllm/model_executor/models/exaone.py +548 -0
  772. vllm/model_executor/models/fairseq2_llama.py +153 -0
  773. vllm/model_executor/models/falcon.py +508 -0
  774. vllm/model_executor/models/florence2.py +1102 -0
  775. vllm/model_executor/models/fuyu.py +388 -0
  776. vllm/model_executor/models/gemma.py +423 -0
  777. vllm/model_executor/models/gemma2.py +423 -0
  778. vllm/model_executor/models/gemma3.py +531 -0
  779. vllm/model_executor/models/gemma3_mm.py +716 -0
  780. vllm/model_executor/models/glm.py +22 -0
  781. vllm/model_executor/models/glm4.py +303 -0
  782. vllm/model_executor/models/glm4v.py +647 -0
  783. vllm/model_executor/models/gpt2.py +313 -0
  784. vllm/model_executor/models/gpt_bigcode.py +336 -0
  785. vllm/model_executor/models/gpt_j.py +337 -0
  786. vllm/model_executor/models/gpt_neox.py +330 -0
  787. vllm/model_executor/models/granite.py +494 -0
  788. vllm/model_executor/models/granite_speech.py +777 -0
  789. vllm/model_executor/models/granitemoe.py +435 -0
  790. vllm/model_executor/models/granitemoeshared.py +339 -0
  791. vllm/model_executor/models/gritlm.py +245 -0
  792. vllm/model_executor/models/grok1.py +560 -0
  793. vllm/model_executor/models/h2ovl.py +542 -0
  794. vllm/model_executor/models/idefics2_vision_model.py +387 -0
  795. vllm/model_executor/models/idefics3.py +767 -0
  796. vllm/model_executor/models/interfaces.py +569 -0
  797. vllm/model_executor/models/interfaces_base.py +163 -0
  798. vllm/model_executor/models/intern_vit.py +476 -0
  799. vllm/model_executor/models/internlm2.py +453 -0
  800. vllm/model_executor/models/internlm2_ve.py +146 -0
  801. vllm/model_executor/models/internvl.py +945 -0
  802. vllm/model_executor/models/jais.py +371 -0
  803. vllm/model_executor/models/jamba.py +590 -0
  804. vllm/model_executor/models/kimi_vl.py +577 -0
  805. vllm/model_executor/models/llama.py +619 -0
  806. vllm/model_executor/models/llama4.py +530 -0
  807. vllm/model_executor/models/llama_eagle.py +152 -0
  808. vllm/model_executor/models/llama_eagle3.py +232 -0
  809. vllm/model_executor/models/llava.py +869 -0
  810. vllm/model_executor/models/llava_next.py +582 -0
  811. vllm/model_executor/models/llava_next_video.py +470 -0
  812. vllm/model_executor/models/llava_onevision.py +954 -0
  813. vllm/model_executor/models/mamba.py +271 -0
  814. vllm/model_executor/models/mamba2.py +302 -0
  815. vllm/model_executor/models/mamba_cache.py +76 -0
  816. vllm/model_executor/models/medusa.py +210 -0
  817. vllm/model_executor/models/minicpm.py +592 -0
  818. vllm/model_executor/models/minicpm3.py +229 -0
  819. vllm/model_executor/models/minicpmo.py +725 -0
  820. vllm/model_executor/models/minicpmv.py +1287 -0
  821. vllm/model_executor/models/minimax_cache.py +35 -0
  822. vllm/model_executor/models/minimax_text_01.py +1261 -0
  823. vllm/model_executor/models/mistral3.py +598 -0
  824. vllm/model_executor/models/mixtral.py +485 -0
  825. vllm/model_executor/models/mixtral_quant.py +447 -0
  826. vllm/model_executor/models/mllama.py +1623 -0
  827. vllm/model_executor/models/mllama4.py +838 -0
  828. vllm/model_executor/models/mlp_speculator.py +205 -0
  829. vllm/model_executor/models/modernbert.py +325 -0
  830. vllm/model_executor/models/module_mapping.py +71 -0
  831. vllm/model_executor/models/molmo.py +1567 -0
  832. vllm/model_executor/models/moonvit.py +628 -0
  833. vllm/model_executor/models/mpt.py +329 -0
  834. vllm/model_executor/models/nemotron.py +506 -0
  835. vllm/model_executor/models/nemotron_nas.py +446 -0
  836. vllm/model_executor/models/nvlm_d.py +212 -0
  837. vllm/model_executor/models/olmo.py +390 -0
  838. vllm/model_executor/models/olmo2.py +412 -0
  839. vllm/model_executor/models/olmoe.py +449 -0
  840. vllm/model_executor/models/opt.py +410 -0
  841. vllm/model_executor/models/orion.py +356 -0
  842. vllm/model_executor/models/paligemma.py +397 -0
  843. vllm/model_executor/models/persimmon.py +342 -0
  844. vllm/model_executor/models/phi.py +354 -0
  845. vllm/model_executor/models/phi3.py +18 -0
  846. vllm/model_executor/models/phi3_small.py +463 -0
  847. vllm/model_executor/models/phi3v.py +722 -0
  848. vllm/model_executor/models/phi4mm.py +1263 -0
  849. vllm/model_executor/models/phi4mm_audio.py +1232 -0
  850. vllm/model_executor/models/phi4mm_utils.py +1883 -0
  851. vllm/model_executor/models/phimoe.py +666 -0
  852. vllm/model_executor/models/pixtral.py +1281 -0
  853. vllm/model_executor/models/plamo2.py +736 -0
  854. vllm/model_executor/models/prithvi_geospatial_mae.py +231 -0
  855. vllm/model_executor/models/qwen.py +360 -0
  856. vllm/model_executor/models/qwen2.py +552 -0
  857. vllm/model_executor/models/qwen2_5_omni_thinker.py +901 -0
  858. vllm/model_executor/models/qwen2_5_vl.py +1136 -0
  859. vllm/model_executor/models/qwen2_audio.py +402 -0
  860. vllm/model_executor/models/qwen2_moe.py +531 -0
  861. vllm/model_executor/models/qwen2_rm.py +130 -0
  862. vllm/model_executor/models/qwen2_vl.py +1409 -0
  863. vllm/model_executor/models/qwen3.py +319 -0
  864. vllm/model_executor/models/qwen3_moe.py +528 -0
  865. vllm/model_executor/models/qwen_vl.py +784 -0
  866. vllm/model_executor/models/registry.py +611 -0
  867. vllm/model_executor/models/roberta.py +332 -0
  868. vllm/model_executor/models/siglip.py +522 -0
  869. vllm/model_executor/models/skyworkr1v.py +949 -0
  870. vllm/model_executor/models/smolvlm.py +51 -0
  871. vllm/model_executor/models/solar.py +504 -0
  872. vllm/model_executor/models/stablelm.py +349 -0
  873. vllm/model_executor/models/starcoder2.py +355 -0
  874. vllm/model_executor/models/telechat2.py +139 -0
  875. vllm/model_executor/models/teleflm.py +78 -0
  876. vllm/model_executor/models/transformers.py +442 -0
  877. vllm/model_executor/models/ultravox.py +655 -0
  878. vllm/model_executor/models/utils.py +714 -0
  879. vllm/model_executor/models/vision.py +149 -0
  880. vllm/model_executor/models/whisper.py +746 -0
  881. vllm/model_executor/models/zamba2.py +1008 -0
  882. vllm/model_executor/parameter.py +458 -0
  883. vllm/model_executor/pooling_metadata.py +71 -0
  884. vllm/model_executor/sampling_metadata.py +596 -0
  885. vllm/model_executor/utils.py +53 -0
  886. vllm/multimodal/__init__.py +31 -0
  887. vllm/multimodal/audio.py +105 -0
  888. vllm/multimodal/base.py +218 -0
  889. vllm/multimodal/hasher.py +103 -0
  890. vllm/multimodal/image.py +77 -0
  891. vllm/multimodal/inputs.py +843 -0
  892. vllm/multimodal/parse.py +454 -0
  893. vllm/multimodal/processing.py +1760 -0
  894. vllm/multimodal/profiling.py +274 -0
  895. vllm/multimodal/registry.py +321 -0
  896. vllm/multimodal/utils.py +386 -0
  897. vllm/multimodal/video.py +166 -0
  898. vllm/outputs.py +521 -0
  899. vllm/platforms/__init__.py +286 -0
  900. vllm/platforms/cpu.py +182 -0
  901. vllm/platforms/cuda.py +463 -0
  902. vllm/platforms/hpu.py +94 -0
  903. vllm/platforms/interface.py +427 -0
  904. vllm/platforms/neuron.py +69 -0
  905. vllm/platforms/rocm.py +346 -0
  906. vllm/platforms/tpu.py +174 -0
  907. vllm/platforms/xpu.py +142 -0
  908. vllm/plugins/__init__.py +82 -0
  909. vllm/pooling_params.py +53 -0
  910. vllm/profiler/__init__.py +7 -0
  911. vllm/profiler/layerwise_profile.py +374 -0
  912. vllm/profiler/utils.py +147 -0
  913. vllm/prompt_adapter/__init__.py +0 -0
  914. vllm/prompt_adapter/layers.py +82 -0
  915. vllm/prompt_adapter/models.py +357 -0
  916. vllm/prompt_adapter/request.py +36 -0
  917. vllm/prompt_adapter/utils.py +97 -0
  918. vllm/prompt_adapter/worker_manager.py +178 -0
  919. vllm/py.typed +2 -0
  920. vllm/reasoning/__init__.py +12 -0
  921. vllm/reasoning/abs_reasoning_parsers.py +189 -0
  922. vllm/reasoning/deepseek_r1_reasoning_parser.py +172 -0
  923. vllm/reasoning/granite_reasoning_parser.py +362 -0
  924. vllm/sampling_params.py +598 -0
  925. vllm/scalar_type.py +335 -0
  926. vllm/scripts.py +14 -0
  927. vllm/sequence.py +1486 -0
  928. vllm/spec_decode/__init__.py +0 -0
  929. vllm/spec_decode/batch_expansion.py +505 -0
  930. vllm/spec_decode/draft_model_runner.py +335 -0
  931. vllm/spec_decode/interfaces.py +98 -0
  932. vllm/spec_decode/medusa_worker.py +137 -0
  933. vllm/spec_decode/metrics.py +212 -0
  934. vllm/spec_decode/mlp_speculator_worker.py +93 -0
  935. vllm/spec_decode/mqa_scorer.py +159 -0
  936. vllm/spec_decode/multi_step_worker.py +416 -0
  937. vllm/spec_decode/ngram_worker.py +195 -0
  938. vllm/spec_decode/proposer_worker_base.py +58 -0
  939. vllm/spec_decode/smaller_tp_proposer_worker.py +194 -0
  940. vllm/spec_decode/spec_decode_worker.py +1324 -0
  941. vllm/spec_decode/target_model_runner.py +44 -0
  942. vllm/spec_decode/top1_proposer.py +274 -0
  943. vllm/spec_decode/util.py +276 -0
  944. vllm/test_utils.py +129 -0
  945. vllm/third_party/__init__.py +0 -0
  946. vllm/third_party/pynvml.py +6139 -0
  947. vllm/tracing.py +130 -0
  948. vllm/transformers_utils/__init__.py +19 -0
  949. vllm/transformers_utils/config.py +813 -0
  950. vllm/transformers_utils/configs/__init__.py +52 -0
  951. vllm/transformers_utils/configs/arctic.py +206 -0
  952. vllm/transformers_utils/configs/chatglm.py +71 -0
  953. vllm/transformers_utils/configs/cohere2.py +194 -0
  954. vllm/transformers_utils/configs/dbrx.py +280 -0
  955. vllm/transformers_utils/configs/deepseek_vl2.py +216 -0
  956. vllm/transformers_utils/configs/eagle.py +65 -0
  957. vllm/transformers_utils/configs/exaone.py +191 -0
  958. vllm/transformers_utils/configs/falcon.py +89 -0
  959. vllm/transformers_utils/configs/h2ovl.py +15 -0
  960. vllm/transformers_utils/configs/internvl.py +53 -0
  961. vllm/transformers_utils/configs/jais.py +237 -0
  962. vllm/transformers_utils/configs/kimi_vl.py +36 -0
  963. vllm/transformers_utils/configs/medusa.py +62 -0
  964. vllm/transformers_utils/configs/mllama.py +30 -0
  965. vllm/transformers_utils/configs/mlp_speculator.py +67 -0
  966. vllm/transformers_utils/configs/moonvit.py +32 -0
  967. vllm/transformers_utils/configs/mpt.py +179 -0
  968. vllm/transformers_utils/configs/nemotron.py +204 -0
  969. vllm/transformers_utils/configs/nvlm_d.py +14 -0
  970. vllm/transformers_utils/configs/skyworkr1v.py +53 -0
  971. vllm/transformers_utils/configs/solar.py +246 -0
  972. vllm/transformers_utils/configs/telechat2.py +63 -0
  973. vllm/transformers_utils/configs/ultravox.py +107 -0
  974. vllm/transformers_utils/detokenizer.py +167 -0
  975. vllm/transformers_utils/detokenizer_utils.py +188 -0
  976. vllm/transformers_utils/processor.py +210 -0
  977. vllm/transformers_utils/processors/__init__.py +6 -0
  978. vllm/transformers_utils/processors/deepseek_vl2.py +363 -0
  979. vllm/transformers_utils/s3_utils.py +161 -0
  980. vllm/transformers_utils/tokenizer.py +291 -0
  981. vllm/transformers_utils/tokenizer_base.py +146 -0
  982. vllm/transformers_utils/tokenizer_group.py +110 -0
  983. vllm/transformers_utils/tokenizers/__init__.py +9 -0
  984. vllm/transformers_utils/tokenizers/mistral.py +483 -0
  985. vllm/transformers_utils/utils.py +98 -0
  986. vllm/triton_utils/__init__.py +5 -0
  987. vllm/triton_utils/importing.py +53 -0
  988. vllm/usage/__init__.py +0 -0
  989. vllm/usage/usage_lib.py +255 -0
  990. vllm/utils.py +2692 -0
  991. vllm/v1/__init__.py +0 -0
  992. vllm/v1/attention/__init__.py +0 -0
  993. vllm/v1/attention/backends/__init__.py +0 -0
  994. vllm/v1/attention/backends/flash_attn.py +783 -0
  995. vllm/v1/attention/backends/flashinfer.py +638 -0
  996. vllm/v1/attention/backends/mla/__init__.py +0 -0
  997. vllm/v1/attention/backends/mla/common.py +974 -0
  998. vllm/v1/attention/backends/mla/flashmla.py +149 -0
  999. vllm/v1/attention/backends/mla/triton_mla.py +118 -0
  1000. vllm/v1/attention/backends/pallas.py +221 -0
  1001. vllm/v1/attention/backends/triton_attn.py +198 -0
  1002. vllm/v1/core/__init__.py +0 -0
  1003. vllm/v1/core/block_pool.py +281 -0
  1004. vllm/v1/core/encoder_cache_manager.py +149 -0
  1005. vllm/v1/core/kv_cache_manager.py +385 -0
  1006. vllm/v1/core/kv_cache_utils.py +744 -0
  1007. vllm/v1/core/sched/__init__.py +0 -0
  1008. vllm/v1/core/sched/interface.py +134 -0
  1009. vllm/v1/core/sched/output.py +126 -0
  1010. vllm/v1/core/sched/scheduler.py +838 -0
  1011. vllm/v1/core/sched/utils.py +22 -0
  1012. vllm/v1/core/specialized_manager.py +161 -0
  1013. vllm/v1/engine/__init__.py +166 -0
  1014. vllm/v1/engine/async_llm.py +532 -0
  1015. vllm/v1/engine/core.py +701 -0
  1016. vllm/v1/engine/core_client.py +942 -0
  1017. vllm/v1/engine/detokenizer.py +260 -0
  1018. vllm/v1/engine/exceptions.py +16 -0
  1019. vllm/v1/engine/llm_engine.py +285 -0
  1020. vllm/v1/engine/logprobs.py +198 -0
  1021. vllm/v1/engine/mm_input_cache.py +82 -0
  1022. vllm/v1/engine/output_processor.py +420 -0
  1023. vllm/v1/engine/parallel_sampling.py +132 -0
  1024. vllm/v1/engine/processor.py +387 -0
  1025. vllm/v1/executor/__init__.py +0 -0
  1026. vllm/v1/executor/abstract.py +112 -0
  1027. vllm/v1/executor/multiproc_executor.py +480 -0
  1028. vllm/v1/executor/ray_distributed_executor.py +61 -0
  1029. vllm/v1/kv_cache_interface.py +166 -0
  1030. vllm/v1/metrics/__init__.py +0 -0
  1031. vllm/v1/metrics/loggers.py +498 -0
  1032. vllm/v1/metrics/stats.py +238 -0
  1033. vllm/v1/outputs.py +111 -0
  1034. vllm/v1/request.py +178 -0
  1035. vllm/v1/sample/__init__.py +0 -0
  1036. vllm/v1/sample/metadata.py +43 -0
  1037. vllm/v1/sample/ops/__init__.py +0 -0
  1038. vllm/v1/sample/ops/bad_words.py +38 -0
  1039. vllm/v1/sample/ops/penalties.py +58 -0
  1040. vllm/v1/sample/ops/topk_topp_sampler.py +315 -0
  1041. vllm/v1/sample/rejection_sampler.py +631 -0
  1042. vllm/v1/sample/sampler.py +270 -0
  1043. vllm/v1/sample/tpu/__init__.py +0 -0
  1044. vllm/v1/sample/tpu/metadata.py +118 -0
  1045. vllm/v1/sample/tpu/sampler.py +154 -0
  1046. vllm/v1/serial_utils.py +274 -0
  1047. vllm/v1/spec_decode/__init__.py +0 -0
  1048. vllm/v1/spec_decode/eagle.py +318 -0
  1049. vllm/v1/spec_decode/metadata.py +61 -0
  1050. vllm/v1/spec_decode/metrics.py +164 -0
  1051. vllm/v1/spec_decode/ngram_proposer.py +131 -0
  1052. vllm/v1/spec_decode/utils.py +18 -0
  1053. vllm/v1/stats/__init__.py +0 -0
  1054. vllm/v1/stats/common.py +453 -0
  1055. vllm/v1/structured_output/__init__.py +113 -0
  1056. vllm/v1/structured_output/backend_guidance.py +215 -0
  1057. vllm/v1/structured_output/backend_types.py +96 -0
  1058. vllm/v1/structured_output/backend_xgrammar.py +299 -0
  1059. vllm/v1/structured_output/request.py +84 -0
  1060. vllm/v1/structured_output/utils.py +174 -0
  1061. vllm/v1/utils.py +249 -0
  1062. vllm/v1/worker/__init__.py +0 -0
  1063. vllm/v1/worker/block_table.py +87 -0
  1064. vllm/v1/worker/gpu_input_batch.py +677 -0
  1065. vllm/v1/worker/gpu_model_runner.py +1776 -0
  1066. vllm/v1/worker/gpu_worker.py +349 -0
  1067. vllm/v1/worker/lora_model_runner_mixin.py +145 -0
  1068. vllm/v1/worker/tpu_model_runner.py +1419 -0
  1069. vllm/v1/worker/tpu_worker.py +260 -0
  1070. vllm/v1/worker/utils.py +74 -0
  1071. vllm/v1/worker/worker_base.py +64 -0
  1072. vllm/version.py +40 -0
  1073. vllm/vllm_flash_attn/.gitkeep +0 -0
  1074. vllm/worker/__init__.py +0 -0
  1075. vllm/worker/cache_engine.py +144 -0
  1076. vllm/worker/cpu_enc_dec_model_runner.py +323 -0
  1077. vllm/worker/cpu_model_runner.py +668 -0
  1078. vllm/worker/cpu_pooling_model_runner.py +122 -0
  1079. vllm/worker/cpu_worker.py +400 -0
  1080. vllm/worker/enc_dec_model_runner.py +542 -0
  1081. vllm/worker/hpu_model_runner.py +2221 -0
  1082. vllm/worker/hpu_worker.py +483 -0
  1083. vllm/worker/model_runner.py +2056 -0
  1084. vllm/worker/model_runner_base.py +281 -0
  1085. vllm/worker/multi_step_hpu_worker.py +122 -0
  1086. vllm/worker/multi_step_model_runner.py +908 -0
  1087. vllm/worker/multi_step_tpu_worker.py +107 -0
  1088. vllm/worker/multi_step_worker.py +196 -0
  1089. vllm/worker/neuron_model_runner.py +336 -0
  1090. vllm/worker/neuron_worker.py +138 -0
  1091. vllm/worker/pooling_model_runner.py +200 -0
  1092. vllm/worker/tpu_model_runner.py +908 -0
  1093. vllm/worker/tpu_worker.py +332 -0
  1094. vllm/worker/utils.py +52 -0
  1095. vllm/worker/worker.py +570 -0
  1096. vllm/worker/worker_base.py +644 -0
  1097. vllm/worker/xpu_model_runner.py +603 -0
  1098. vllm/worker/xpu_worker.py +185 -0
  1099. vllm_cpu-0.8.5.post2.dist-info/METADATA +309 -0
  1100. vllm_cpu-0.8.5.post2.dist-info/RECORD +1103 -0
  1101. vllm_cpu-0.8.5.post2.dist-info/WHEEL +5 -0
  1102. vllm_cpu-0.8.5.post2.dist-info/entry_points.txt +2 -0
  1103. vllm_cpu-0.8.5.post2.dist-info/top_level.txt +1 -0
@@ -0,0 +1,1259 @@
1
+ # SPDX-License-Identifier: Apache-2.0
2
+
3
+ import asyncio
4
+ import json
5
+ from abc import ABC, abstractmethod
6
+ from collections import defaultdict, deque
7
+ from collections.abc import Awaitable, Iterable
8
+ from functools import cache, lru_cache, partial
9
+ from pathlib import Path
10
+ from typing import (Any, Callable, Generic, Literal, Optional, TypeVar, Union,
11
+ cast)
12
+
13
+ import jinja2.nodes
14
+ import transformers.utils.chat_template_utils as hf_chat_utils
15
+ # yapf conflicts with isort for this block
16
+ # yapf: disable
17
+ from openai.types.chat import (ChatCompletionAssistantMessageParam,
18
+ ChatCompletionContentPartImageParam,
19
+ ChatCompletionContentPartInputAudioParam)
20
+ from openai.types.chat import (
21
+ ChatCompletionContentPartParam as OpenAIChatCompletionContentPartParam)
22
+ from openai.types.chat import (ChatCompletionContentPartRefusalParam,
23
+ ChatCompletionContentPartTextParam)
24
+ from openai.types.chat import (
25
+ ChatCompletionMessageParam as OpenAIChatCompletionMessageParam)
26
+ from openai.types.chat import (ChatCompletionMessageToolCallParam,
27
+ ChatCompletionToolMessageParam)
28
+ from openai.types.chat.chat_completion_content_part_input_audio_param import (
29
+ InputAudio)
30
+ from pydantic import TypeAdapter
31
+ # yapf: enable
32
+ from transformers import (PreTrainedTokenizer, PreTrainedTokenizerFast,
33
+ ProcessorMixin)
34
+ # pydantic needs the TypedDict from typing_extensions
35
+ from typing_extensions import Required, TypeAlias, TypedDict
36
+
37
+ from vllm.config import ModelConfig
38
+ from vllm.logger import init_logger
39
+ from vllm.multimodal import MULTIMODAL_REGISTRY, MultiModalDataDict
40
+ from vllm.multimodal.utils import MediaConnector
41
+ from vllm.transformers_utils.processor import cached_get_processor
42
+ from vllm.transformers_utils.tokenizer import AnyTokenizer, MistralTokenizer
43
+
44
+ logger = init_logger(__name__)
45
+
46
+
47
+ class AudioURL(TypedDict, total=False):
48
+ url: Required[str]
49
+ """
50
+ Either a URL of the audio or a data URL with base64 encoded audio data.
51
+ """
52
+
53
+
54
+ class ChatCompletionContentPartAudioParam(TypedDict, total=False):
55
+ audio_url: Required[AudioURL]
56
+
57
+ type: Required[Literal["audio_url"]]
58
+ """The type of the content part."""
59
+
60
+
61
+ class ChatCompletionContentPartImageEmbedsParam(TypedDict, total=False):
62
+ image_embeds: Required[Union[str, dict[str, str]]]
63
+ """
64
+ The image embeddings. It can be either:
65
+ - A single base64 string.
66
+ - A dictionary where each value is a base64 string.
67
+ """
68
+ type: Required[Literal["image_embeds"]]
69
+ """The type of the content part."""
70
+
71
+
72
+ class VideoURL(TypedDict, total=False):
73
+ url: Required[str]
74
+ """
75
+ Either a URL of the video or a data URL with base64 encoded video data.
76
+ """
77
+
78
+
79
+ class ChatCompletionContentPartVideoParam(TypedDict, total=False):
80
+ video_url: Required[VideoURL]
81
+
82
+ type: Required[Literal["video_url"]]
83
+ """The type of the content part."""
84
+
85
+
86
+ class CustomChatCompletionContentSimpleImageParam(TypedDict, total=False):
87
+ """A simpler version of the param that only accepts a plain image_url.
88
+ This is supported by OpenAI API, although it is not documented.
89
+
90
+ Example:
91
+ {
92
+ "image_url": "https://example.com/image.jpg"
93
+ }
94
+ """
95
+ image_url: Required[str]
96
+
97
+
98
+ class CustomChatCompletionContentSimpleAudioParam(TypedDict, total=False):
99
+ """A simpler version of the param that only accepts a plain audio_url.
100
+
101
+ Example:
102
+ {
103
+ "audio_url": "https://example.com/audio.mp3"
104
+ }
105
+ """
106
+ audio_url: Required[str]
107
+
108
+
109
+ class CustomChatCompletionContentSimpleVideoParam(TypedDict, total=False):
110
+ """A simpler version of the param that only accepts a plain audio_url.
111
+
112
+ Example:
113
+ {
114
+ "video_url": "https://example.com/video.mp4"
115
+ }
116
+ """
117
+ video_url: Required[str]
118
+
119
+
120
+ ChatCompletionContentPartParam: TypeAlias = Union[
121
+ OpenAIChatCompletionContentPartParam, ChatCompletionContentPartAudioParam,
122
+ ChatCompletionContentPartInputAudioParam,
123
+ ChatCompletionContentPartVideoParam, ChatCompletionContentPartRefusalParam,
124
+ CustomChatCompletionContentSimpleImageParam,
125
+ ChatCompletionContentPartImageEmbedsParam,
126
+ CustomChatCompletionContentSimpleAudioParam,
127
+ CustomChatCompletionContentSimpleVideoParam, str]
128
+
129
+
130
+ class CustomChatCompletionMessageParam(TypedDict, total=False):
131
+ """Enables custom roles in the Chat Completion API."""
132
+ role: Required[str]
133
+ """The role of the message's author."""
134
+
135
+ content: Union[str, list[ChatCompletionContentPartParam]]
136
+ """The contents of the message."""
137
+
138
+ name: str
139
+ """An optional name for the participant.
140
+
141
+ Provides the model information to differentiate between participants of the
142
+ same role.
143
+ """
144
+
145
+ tool_call_id: Optional[str]
146
+ """Tool call that this message is responding to."""
147
+
148
+ tool_calls: Optional[Iterable[ChatCompletionMessageToolCallParam]]
149
+ """The tool calls generated by the model, such as function calls."""
150
+
151
+
152
+ ChatCompletionMessageParam = Union[OpenAIChatCompletionMessageParam,
153
+ CustomChatCompletionMessageParam]
154
+
155
+
156
+ # TODO: Make fields ReadOnly once mypy supports it
157
+ class ConversationMessage(TypedDict, total=False):
158
+ role: Required[str]
159
+ """The role of the message's author."""
160
+
161
+ content: Union[Optional[str], list[dict[str, str]]]
162
+ """The contents of the message"""
163
+
164
+ tool_call_id: Optional[str]
165
+ """Tool call that this message is responding to."""
166
+
167
+ name: Optional[str]
168
+ """The name of the function to call"""
169
+
170
+ tool_calls: Optional[Iterable[ChatCompletionMessageToolCallParam]]
171
+ """The tool calls generated by the model, such as function calls."""
172
+
173
+
174
+ # Passed in by user
175
+ ChatTemplateContentFormatOption = Literal["auto", "string", "openai"]
176
+
177
+ # Used internally
178
+ _ChatTemplateContentFormat = Literal["string", "openai"]
179
+
180
+
181
+ def _is_var_access(node: jinja2.nodes.Node, varname: str) -> bool:
182
+ if isinstance(node, jinja2.nodes.Name):
183
+ return node.ctx == "load" and node.name == varname
184
+
185
+ return False
186
+
187
+
188
+ def _is_attr_access(node: jinja2.nodes.Node, varname: str, key: str) -> bool:
189
+ if isinstance(node, jinja2.nodes.Getitem):
190
+ return (_is_var_access(node.node, varname)
191
+ and isinstance(node.arg, jinja2.nodes.Const)
192
+ and node.arg.value == key)
193
+
194
+ if isinstance(node, jinja2.nodes.Getattr):
195
+ return _is_var_access(node.node, varname) and node.attr == key
196
+
197
+ return False
198
+
199
+
200
+ def _is_var_or_elems_access(
201
+ node: jinja2.nodes.Node,
202
+ varname: str,
203
+ key: Optional[str] = None,
204
+ ) -> bool:
205
+ if isinstance(node, jinja2.nodes.Filter):
206
+ return (node.node is not None
207
+ and _is_var_or_elems_access(node.node, varname, key))
208
+ if isinstance(node, jinja2.nodes.Test):
209
+ return _is_var_or_elems_access(node.node, varname, key)
210
+
211
+ if (isinstance(node, jinja2.nodes.Getitem)
212
+ and isinstance(node.arg, jinja2.nodes.Slice)):
213
+ return _is_var_or_elems_access(node.node, varname, key)
214
+
215
+ # yapf: disable
216
+ return (
217
+ _is_attr_access(node, varname, key) if key
218
+ else _is_var_access(node, varname)
219
+ ) # yapf: enable
220
+
221
+
222
+ def _iter_nodes_assign_var_or_elems(root: jinja2.nodes.Node, varname: str):
223
+ # Global variable that is implicitly defined at the root
224
+ yield root, varname
225
+
226
+ # Iterative BFS
227
+ related_varnames = deque([varname])
228
+ while related_varnames:
229
+ related_varname = related_varnames.popleft()
230
+
231
+ for assign_ast in root.find_all(jinja2.nodes.Assign):
232
+ lhs = assign_ast.target
233
+ rhs = assign_ast.node
234
+
235
+ if _is_var_or_elems_access(rhs, related_varname):
236
+ assert isinstance(lhs, jinja2.nodes.Name)
237
+ yield assign_ast, lhs.name
238
+
239
+ # Avoid infinite looping for self-assignment
240
+ if lhs.name != related_varname:
241
+ related_varnames.append(lhs.name)
242
+
243
+
244
+ # NOTE: The proper way to handle this is to build a CFG so that we can handle
245
+ # the scope in which each variable is defined, but that is too complicated
246
+ def _iter_nodes_assign_messages_item(root: jinja2.nodes.Node):
247
+ messages_varnames = [
248
+ varname
249
+ for _, varname in _iter_nodes_assign_var_or_elems(root, "messages")
250
+ ]
251
+
252
+ # Search for {%- for message in messages -%} loops
253
+ for loop_ast in root.find_all(jinja2.nodes.For):
254
+ loop_iter = loop_ast.iter
255
+ loop_target = loop_ast.target
256
+
257
+ for varname in messages_varnames:
258
+ if _is_var_or_elems_access(loop_iter, varname):
259
+ assert isinstance(loop_target, jinja2.nodes.Name)
260
+ yield loop_ast, loop_target.name
261
+ break
262
+
263
+
264
+ def _iter_nodes_assign_content_item(root: jinja2.nodes.Node):
265
+ message_varnames = [
266
+ varname for _, varname in _iter_nodes_assign_messages_item(root)
267
+ ]
268
+
269
+ # Search for {%- for content in message['content'] -%} loops
270
+ for loop_ast in root.find_all(jinja2.nodes.For):
271
+ loop_iter = loop_ast.iter
272
+ loop_target = loop_ast.target
273
+
274
+ for varname in message_varnames:
275
+ if _is_var_or_elems_access(loop_iter, varname, "content"):
276
+ assert isinstance(loop_target, jinja2.nodes.Name)
277
+ yield loop_ast, loop_target.name
278
+ break
279
+
280
+
281
+ def _try_extract_ast(chat_template: str) -> Optional[jinja2.nodes.Template]:
282
+ try:
283
+ jinja_compiled = hf_chat_utils._compile_jinja_template(chat_template)
284
+ return jinja_compiled.environment.parse(chat_template)
285
+ except Exception:
286
+ logger.exception("Error when compiling Jinja template")
287
+ return None
288
+
289
+
290
+ def _detect_content_format(
291
+ chat_template: str,
292
+ *,
293
+ default: _ChatTemplateContentFormat,
294
+ ) -> _ChatTemplateContentFormat:
295
+ jinja_ast = _try_extract_ast(chat_template)
296
+ if jinja_ast is None:
297
+ return default
298
+
299
+ try:
300
+ next(_iter_nodes_assign_content_item(jinja_ast))
301
+ except StopIteration:
302
+ return "string"
303
+ except Exception:
304
+ logger.exception("Error when parsing AST of Jinja template")
305
+ return default
306
+ else:
307
+ return "openai"
308
+
309
+
310
+ def resolve_mistral_chat_template(
311
+ chat_template: Optional[str],
312
+ **kwargs: Any,
313
+ ) -> Optional[str]:
314
+ if chat_template is not None:
315
+ logger.warning_once(
316
+ "'chat_template' cannot be overridden for mistral tokenizer.")
317
+ if "add_generation_prompt" in kwargs:
318
+ logger.warning_once(
319
+ "'add_generation_prompt' is not supported for mistral tokenizer, "
320
+ "so it will be ignored.")
321
+ if "continue_final_message" in kwargs:
322
+ logger.warning_once(
323
+ "'continue_final_message' is not supported for mistral tokenizer, "
324
+ "so it will be ignored.")
325
+ return None
326
+
327
+ def resolve_hf_chat_template(
328
+ tokenizer: Union[PreTrainedTokenizer, PreTrainedTokenizerFast],
329
+ chat_template: Optional[str],
330
+ tools: Optional[list[dict[str, Any]]],
331
+ *,
332
+ trust_remote_code: bool,
333
+ ) -> Optional[str]:
334
+ # 1st priority: The given chat template
335
+ if chat_template is not None:
336
+ return chat_template
337
+
338
+ # 2nd priority: AutoProcessor chat template, unless tool calling is enabled
339
+ if tools is None:
340
+ try:
341
+ processor = cached_get_processor(
342
+ tokenizer.name_or_path,
343
+ processor_cls=(PreTrainedTokenizer, PreTrainedTokenizerFast,
344
+ ProcessorMixin),
345
+ trust_remote_code=trust_remote_code,
346
+ )
347
+ if isinstance(processor, ProcessorMixin) and \
348
+ processor.chat_template is not None:
349
+ return processor.chat_template
350
+ except Exception:
351
+ logger.debug("Failed to load AutoProcessor chat template for %s",
352
+ tokenizer.name_or_path, exc_info=True)
353
+
354
+ # 3rd priority: AutoTokenizer chat template
355
+ try:
356
+ return tokenizer.get_chat_template(chat_template, tools=tools)
357
+ except Exception:
358
+ logger.debug("Failed to load AutoTokenizer chat template for %s",
359
+ tokenizer.name_or_path, exc_info=True)
360
+
361
+ return None
362
+
363
+
364
+ def _resolve_chat_template_content_format(
365
+ chat_template: Optional[str],
366
+ tools: Optional[list[dict[str, Any]]],
367
+ given_format: ChatTemplateContentFormatOption,
368
+ tokenizer: AnyTokenizer,
369
+ *,
370
+ trust_remote_code: bool,
371
+ ) -> _ChatTemplateContentFormat:
372
+ if isinstance(tokenizer, (PreTrainedTokenizer, PreTrainedTokenizerFast)):
373
+ hf_chat_template = resolve_hf_chat_template(
374
+ tokenizer,
375
+ chat_template=chat_template,
376
+ trust_remote_code=trust_remote_code,
377
+ tools=tools,
378
+ )
379
+ else:
380
+ hf_chat_template = None
381
+
382
+ jinja_text = (hf_chat_template if isinstance(hf_chat_template, str)
383
+ else load_chat_template(chat_template, is_literal=True))
384
+
385
+ detected_format = ("string" if jinja_text is None else
386
+ _detect_content_format(jinja_text, default="string"))
387
+
388
+ return detected_format if given_format == "auto" else given_format
389
+
390
+
391
+ @lru_cache
392
+ def _log_chat_template_content_format(
393
+ chat_template: Optional[str],
394
+ given_format: ChatTemplateContentFormatOption,
395
+ detected_format: ChatTemplateContentFormatOption,
396
+ ):
397
+ logger.info(
398
+ "Detected the chat template content format to be '%s'. "
399
+ "You can set `--chat-template-content-format` to override this.",
400
+ detected_format,
401
+ )
402
+
403
+ if given_format != "auto" and given_format != detected_format:
404
+ logger.warning(
405
+ "You specified `--chat-template-content-format %s` "
406
+ "which is different from the detected format '%s'. "
407
+ "If our automatic detection is incorrect, please consider "
408
+ "opening a GitHub issue so that we can improve it: "
409
+ "https://github.com/vllm-project/vllm/issues/new/choose",
410
+ given_format,
411
+ detected_format,
412
+ )
413
+
414
+
415
+ def resolve_chat_template_content_format(
416
+ chat_template: Optional[str],
417
+ tools: Optional[list[dict[str, Any]]],
418
+ given_format: ChatTemplateContentFormatOption,
419
+ tokenizer: AnyTokenizer,
420
+ *,
421
+ trust_remote_code: bool = False,
422
+ ) -> _ChatTemplateContentFormat:
423
+ detected_format = _resolve_chat_template_content_format(
424
+ chat_template,
425
+ tools,
426
+ given_format,
427
+ tokenizer,
428
+ trust_remote_code=trust_remote_code,
429
+ )
430
+
431
+ _log_chat_template_content_format(
432
+ chat_template,
433
+ given_format=given_format,
434
+ detected_format=detected_format,
435
+ )
436
+
437
+ return detected_format
438
+
439
+
440
+ ModalityStr = Literal["image", "audio", "video", "image_embeds"]
441
+ _T = TypeVar("_T")
442
+
443
+
444
+ class BaseMultiModalItemTracker(ABC, Generic[_T]):
445
+ """
446
+ Tracks multi-modal items in a given request and ensures that the number
447
+ of multi-modal items in a given request does not exceed the configured
448
+ maximum per prompt.
449
+ """
450
+
451
+ def __init__(self, model_config: ModelConfig, tokenizer: AnyTokenizer):
452
+ super().__init__()
453
+
454
+ self._model_config = model_config
455
+ self._tokenizer = tokenizer
456
+
457
+ self._items_by_modality = defaultdict[str, list[_T]](list)
458
+
459
+ @property
460
+ def model_config(self) -> ModelConfig:
461
+ return self._model_config
462
+
463
+ @property
464
+ def allowed_local_media_path(self):
465
+ return self._model_config.allowed_local_media_path
466
+
467
+ @property
468
+ def mm_registry(self):
469
+ return MULTIMODAL_REGISTRY
470
+
471
+ @staticmethod
472
+ @cache
473
+ def _cached_token_str(tokenizer: AnyTokenizer, token_index: int) -> str:
474
+ return tokenizer.decode(token_index)
475
+
476
+ def _placeholder_str(self, modality: ModalityStr,
477
+ current_count: int) -> Optional[str]:
478
+ # TODO: Let user specify how to insert image tokens into prompt
479
+ # (similar to chat template)
480
+ hf_config = self._model_config.hf_config
481
+ model_type = hf_config.model_type
482
+
483
+ if modality in ("image", "image_embeds"):
484
+ if model_type == "chatglm":
485
+ return "<|begin_of_image|><|endoftext|><|end_of_image|>"
486
+ if model_type in ("phi3_v", "phi4mm"):
487
+ return f"<|image_{current_count}|>"
488
+ if model_type in ("minicpmo", "minicpmv"):
489
+ return "(<image>./</image>)"
490
+ if model_type in ("blip-2", "florence2", "fuyu", "paligemma",
491
+ "pixtral", "mistral3"):
492
+ # These models do not use image tokens in the prompt
493
+ return None
494
+ if model_type == "qwen":
495
+ return f"Picture {current_count}: <img></img>"
496
+ if model_type.startswith("llava"):
497
+ return self._cached_token_str(self._tokenizer,
498
+ hf_config.image_token_index)
499
+ if model_type in ("aya_vision", "chameleon", "deepseek_vl_v2",
500
+ "internvl_chat", "skywork_chat", "NVLM_D",
501
+ "h2ovl_chat", "idefics3", "smolvlm"):
502
+ return "<image>"
503
+ if model_type in ("mllama", "llama4"):
504
+ return "<|image|>"
505
+ if model_type in ("qwen2_vl", "qwen2_5_vl"):
506
+ return "<|vision_start|><|image_pad|><|vision_end|>"
507
+ if model_type == "qwen2_5_omni":
508
+ return "<|vision_start|><|IMAGE|><|vision_end|>"
509
+ if model_type == "molmo":
510
+ return ""
511
+ if model_type == "aria":
512
+ return "<|fim_prefix|><|img|><|fim_suffix|>"
513
+ if model_type == "gemma3":
514
+ return "<start_of_image>"
515
+ if model_type == "kimi_vl":
516
+ return "<|media_start|>image<|media_content|><|media_pad|><|media_end|>" # noqa: E501
517
+
518
+ raise TypeError(f"Unknown {modality} model type: {model_type}")
519
+ elif modality == "audio":
520
+ if model_type in ("ultravox", "granite_speech"):
521
+ return "<|audio|>"
522
+ if model_type == "phi4mm":
523
+ return f"<|audio_{current_count}|>"
524
+ if model_type in ("qwen2_audio", "qwen2_5_omni"):
525
+ return (f"Audio {current_count}: "
526
+ f"<|audio_bos|><|AUDIO|><|audio_eos|>")
527
+ if model_type == "minicpmo":
528
+ return "(<audio>./</audio>)"
529
+ raise TypeError(f"Unknown model type: {model_type}")
530
+ elif modality == "video":
531
+ if model_type in ("qwen2_vl", "qwen2_5_vl"):
532
+ return "<|vision_start|><|video_pad|><|vision_end|>"
533
+ if model_type == "qwen2_5_omni":
534
+ return "<|vision_start|><|VIDEO|><|vision_end|>"
535
+ if model_type in ("minicpmo", "minicpmv"):
536
+ return "(<video>./</video>)"
537
+ if model_type.startswith("llava"):
538
+ return self._cached_token_str(self._tokenizer,
539
+ hf_config.video_token_index)
540
+ raise TypeError(f"Unknown {modality} model type: {model_type}")
541
+ else:
542
+ raise TypeError(f"Unknown modality: {modality}")
543
+
544
+ def add(self, modality: ModalityStr, item: _T) -> Optional[str]:
545
+ """
546
+ Add a multi-modal item to the current prompt and returns the
547
+ placeholder string to use, if any.
548
+ """
549
+ mm_registry = self.mm_registry
550
+ model_config = self.model_config
551
+
552
+ input_modality = modality.replace("_embeds", "")
553
+
554
+ if mm_registry.has_processor(model_config):
555
+ mm_processor = mm_registry.create_processor(model_config)
556
+ allowed_counts = mm_processor.info.get_allowed_mm_limits()
557
+ allowed_count = allowed_counts.get(input_modality, 0)
558
+ else:
559
+ mm_config = model_config.multimodal_config
560
+ if mm_config is None:
561
+ msg = "This model does not support multi-modal inputs"
562
+ raise ValueError(msg)
563
+
564
+ allowed_count = mm_config.get_limit_per_prompt(input_modality)
565
+
566
+ current_count = len(self._items_by_modality[modality]) + 1
567
+ if current_count > allowed_count:
568
+ raise ValueError(
569
+ f"At most {allowed_count} {modality}(s) may be provided in "
570
+ "one request. You can set `--limit-mm-per-prompt` to "
571
+ "increase this limit if the model supports it.")
572
+
573
+ self._items_by_modality[modality].append(item)
574
+
575
+ return self._placeholder_str(modality, current_count)
576
+
577
+ @abstractmethod
578
+ def create_parser(self) -> "BaseMultiModalContentParser":
579
+ raise NotImplementedError
580
+
581
+
582
+ class MultiModalItemTracker(BaseMultiModalItemTracker[object]):
583
+
584
+ def all_mm_data(self) -> Optional[MultiModalDataDict]:
585
+ if not self._items_by_modality:
586
+ return None
587
+ mm_inputs = {}
588
+ items_by_modality = dict(self._items_by_modality)
589
+ if "image" in items_by_modality and "image_embeds" in items_by_modality:
590
+ raise ValueError(\
591
+ "Mixing raw image and embedding inputs is not allowed")
592
+
593
+ if "image_embeds" in items_by_modality:
594
+ image_embeds_lst = items_by_modality["image_embeds"]
595
+ if len(image_embeds_lst) > 1:
596
+ raise ValueError(\
597
+ "Only one message can have {'type': 'image_embeds'}")
598
+ mm_inputs["image"] = image_embeds_lst[0]
599
+ if "image" in items_by_modality:
600
+ mm_inputs["image"] = items_by_modality["image"] # A list of images
601
+ if "audio" in items_by_modality:
602
+ mm_inputs["audio"] = items_by_modality["audio"] # A list of audios
603
+ if "video" in items_by_modality:
604
+ mm_inputs["video"] = items_by_modality["video"] # A list of videos
605
+ return mm_inputs
606
+
607
+ def create_parser(self) -> "BaseMultiModalContentParser":
608
+ return MultiModalContentParser(self)
609
+
610
+
611
+ class AsyncMultiModalItemTracker(BaseMultiModalItemTracker[Awaitable[object]]):
612
+
613
+ async def all_mm_data(self) -> Optional[MultiModalDataDict]:
614
+ if not self._items_by_modality:
615
+ return None
616
+ mm_inputs = {}
617
+ items_by_modality = {
618
+ modality: await asyncio.gather(*items)
619
+ for modality, items in self._items_by_modality.items()
620
+ }
621
+
622
+ if "image" in items_by_modality and "image_embeds" in items_by_modality:
623
+ raise ValueError(
624
+ "Mixing raw image and embedding inputs is not allowed")
625
+
626
+ if "image_embeds" in items_by_modality:
627
+ image_embeds_lst = items_by_modality["image_embeds"]
628
+ if len(image_embeds_lst) > 1:
629
+ raise ValueError(
630
+ "Only one message can have {'type': 'image_embeds'}")
631
+ mm_inputs["image"] = image_embeds_lst[0]
632
+ if "image" in items_by_modality:
633
+ mm_inputs["image"] = items_by_modality["image"] # A list of images
634
+ if "audio" in items_by_modality:
635
+ mm_inputs["audio"] = items_by_modality["audio"] # A list of audios
636
+ if "video" in items_by_modality:
637
+ mm_inputs["video"] = items_by_modality["video"] # A list of videos
638
+ return mm_inputs
639
+
640
+ def create_parser(self) -> "BaseMultiModalContentParser":
641
+ return AsyncMultiModalContentParser(self)
642
+
643
+
644
+ class BaseMultiModalContentParser(ABC):
645
+
646
+ def __init__(self) -> None:
647
+ super().__init__()
648
+
649
+ # multimodal placeholder_string : count
650
+ self._placeholder_counts: dict[str, int] = defaultdict(lambda: 0)
651
+
652
+ def _add_placeholder(self, placeholder: Optional[str]):
653
+ if placeholder:
654
+ self._placeholder_counts[placeholder] += 1
655
+
656
+ def mm_placeholder_counts(self) -> dict[str, int]:
657
+ return dict(self._placeholder_counts)
658
+
659
+ @abstractmethod
660
+ def parse_image(self, image_url: str) -> None:
661
+ raise NotImplementedError
662
+
663
+ @abstractmethod
664
+ def parse_image_embeds(self,
665
+ image_embeds: Union[str, dict[str, str]]) -> None:
666
+ raise NotImplementedError
667
+
668
+ @abstractmethod
669
+ def parse_audio(self, audio_url: str) -> None:
670
+ raise NotImplementedError
671
+
672
+ @abstractmethod
673
+ def parse_input_audio(self, input_audio: InputAudio) -> None:
674
+ raise NotImplementedError
675
+
676
+ @abstractmethod
677
+ def parse_video(self, video_url: str) -> None:
678
+ raise NotImplementedError
679
+
680
+
681
+ class MultiModalContentParser(BaseMultiModalContentParser):
682
+
683
+ def __init__(self, tracker: MultiModalItemTracker) -> None:
684
+ super().__init__()
685
+
686
+ self._tracker = tracker
687
+
688
+ self._connector = MediaConnector(
689
+ allowed_local_media_path=tracker.allowed_local_media_path,
690
+ )
691
+
692
+ def parse_image(self, image_url: str) -> None:
693
+ image = self._connector.fetch_image(image_url)
694
+
695
+ placeholder = self._tracker.add("image", image)
696
+ self._add_placeholder(placeholder)
697
+
698
+ def parse_image_embeds(self,
699
+ image_embeds: Union[str, dict[str, str]]) -> None:
700
+ if isinstance(image_embeds, dict):
701
+ embeds = {
702
+ k: self._connector.fetch_image_embedding(v)
703
+ for k, v in image_embeds.items()
704
+ }
705
+ placeholder = self._tracker.add("image_embeds", embeds)
706
+
707
+ if isinstance(image_embeds, str):
708
+ embedding = self._connector.fetch_image_embedding(image_embeds)
709
+ placeholder = self._tracker.add("image_embeds", embedding)
710
+
711
+ self._add_placeholder(placeholder)
712
+
713
+ def parse_audio(self, audio_url: str) -> None:
714
+ audio = self._connector.fetch_audio(audio_url)
715
+
716
+ placeholder = self._tracker.add("audio", audio)
717
+ self._add_placeholder(placeholder)
718
+
719
+ def parse_input_audio(self, input_audio: InputAudio) -> None:
720
+ audio_data = input_audio.get("data", "")
721
+ audio_format = input_audio.get("format", "")
722
+ audio_url = f"data:audio/{audio_format};base64,{audio_data}"
723
+
724
+ return self.parse_audio(audio_url)
725
+
726
+ def parse_video(self, video_url: str) -> None:
727
+ video = self._connector.fetch_video(video_url)
728
+
729
+ placeholder = self._tracker.add("video", video)
730
+ self._add_placeholder(placeholder)
731
+
732
+
733
+ class AsyncMultiModalContentParser(BaseMultiModalContentParser):
734
+
735
+ def __init__(self, tracker: AsyncMultiModalItemTracker) -> None:
736
+ super().__init__()
737
+
738
+ self._tracker = tracker
739
+ self._connector = MediaConnector(
740
+ allowed_local_media_path=tracker.allowed_local_media_path,
741
+ )
742
+
743
+ def parse_image(self, image_url: str) -> None:
744
+ image_coro = self._connector.fetch_image_async(image_url)
745
+
746
+ placeholder = self._tracker.add("image", image_coro)
747
+ self._add_placeholder(placeholder)
748
+
749
+ def parse_image_embeds(self,
750
+ image_embeds: Union[str, dict[str, str]]) -> None:
751
+ future: asyncio.Future[Union[str, dict[str, str]]] = asyncio.Future()
752
+
753
+ if isinstance(image_embeds, dict):
754
+ embeds = {
755
+ k: self._connector.fetch_image_embedding(v)
756
+ for k, v in image_embeds.items()
757
+ }
758
+ future.set_result(embeds)
759
+
760
+ if isinstance(image_embeds, str):
761
+ embedding = self._connector.\
762
+ fetch_image_embedding(image_embeds)
763
+ future.set_result(embedding)
764
+
765
+ placeholder = self._tracker.add("image_embeds", future)
766
+ self._add_placeholder(placeholder)
767
+
768
+ def parse_audio(self, audio_url: str) -> None:
769
+ audio_coro = self._connector.fetch_audio_async(audio_url)
770
+
771
+ placeholder = self._tracker.add("audio", audio_coro)
772
+ self._add_placeholder(placeholder)
773
+
774
+ def parse_input_audio(self, input_audio: InputAudio) -> None:
775
+ audio_data = input_audio.get("data", "")
776
+ audio_format = input_audio.get("format", "")
777
+ audio_url = f"data:audio/{audio_format};base64,{audio_data}"
778
+
779
+ return self.parse_audio(audio_url)
780
+
781
+ def parse_video(self, video_url: str) -> None:
782
+ video = self._connector.fetch_video_async(video_url)
783
+
784
+ placeholder = self._tracker.add("video", video)
785
+ self._add_placeholder(placeholder)
786
+
787
+
788
+ def validate_chat_template(chat_template: Optional[Union[Path, str]]):
789
+ """Raises if the provided chat template appears invalid."""
790
+ if chat_template is None:
791
+ return
792
+
793
+ elif isinstance(chat_template, Path) and not chat_template.exists():
794
+ raise FileNotFoundError(
795
+ "the supplied chat template path doesn't exist")
796
+
797
+ elif isinstance(chat_template, str):
798
+ JINJA_CHARS = "{}\n"
799
+ if not any(c in chat_template
800
+ for c in JINJA_CHARS) and not Path(chat_template).exists():
801
+ raise ValueError(
802
+ f"The supplied chat template string ({chat_template}) "
803
+ f"appears path-like, but doesn't exist!")
804
+
805
+ else:
806
+ raise TypeError(
807
+ f"{type(chat_template)} is not a valid chat template type")
808
+
809
+
810
+ def _load_chat_template(
811
+ chat_template: Optional[Union[Path, str]],
812
+ *,
813
+ is_literal: bool = False,
814
+ ) -> Optional[str]:
815
+ if chat_template is None:
816
+ return None
817
+
818
+ if is_literal:
819
+ if isinstance(chat_template, Path):
820
+ raise TypeError("chat_template is expected to be read directly "
821
+ "from its value")
822
+
823
+ return chat_template
824
+
825
+ try:
826
+ with open(chat_template) as f:
827
+ return f.read()
828
+ except OSError as e:
829
+ if isinstance(chat_template, Path):
830
+ raise
831
+
832
+ JINJA_CHARS = "{}\n"
833
+ if not any(c in chat_template for c in JINJA_CHARS):
834
+ msg = (f"The supplied chat template ({chat_template}) "
835
+ f"looks like a file path, but it failed to be "
836
+ f"opened. Reason: {e}")
837
+ raise ValueError(msg) from e
838
+
839
+ # If opening a file fails, set chat template to be args to
840
+ # ensure we decode so our escape are interpreted correctly
841
+ return _load_chat_template(chat_template, is_literal=True)
842
+
843
+
844
+ _cached_load_chat_template = lru_cache(_load_chat_template)
845
+
846
+
847
+ def load_chat_template(
848
+ chat_template: Optional[Union[Path, str]],
849
+ *,
850
+ is_literal: bool = False,
851
+ ) -> Optional[str]:
852
+ return _cached_load_chat_template(chat_template, is_literal=is_literal)
853
+
854
+
855
+ # TODO: Let user specify how to insert multimodal tokens into prompt
856
+ # (similar to chat template)
857
+ def _get_full_multimodal_text_prompt(placeholder_counts: dict[str, int],
858
+ text_prompt: str) -> str:
859
+ """Combine multimodal prompts for a multimodal language model."""
860
+
861
+ # Look through the text prompt to check for missing placeholders
862
+ missing_placeholders: list[str] = []
863
+ for placeholder in placeholder_counts:
864
+
865
+ # For any existing placeholder in the text prompt, we leave it as is
866
+ placeholder_counts[placeholder] -= text_prompt.count(placeholder)
867
+
868
+ if placeholder_counts[placeholder] < 0:
869
+ raise ValueError(
870
+ f"Found more '{placeholder}' placeholders in input prompt than "
871
+ "actual multimodal data items.")
872
+
873
+ missing_placeholders.extend([placeholder] *
874
+ placeholder_counts[placeholder])
875
+
876
+ # NOTE: For now we always add missing placeholders at the front of
877
+ # the prompt. This may change to be customizable in the future.
878
+ return "\n".join(missing_placeholders + [text_prompt])
879
+
880
+
881
+ # No need to validate using Pydantic again
882
+ _TextParser = partial(cast, ChatCompletionContentPartTextParam)
883
+ _ImageEmbedsParser = partial(cast, ChatCompletionContentPartImageEmbedsParam)
884
+ _InputAudioParser = partial(cast, ChatCompletionContentPartInputAudioParam)
885
+ _RefusalParser = partial(cast, ChatCompletionContentPartRefusalParam)
886
+ # Need to validate url objects
887
+ _ImageParser = TypeAdapter(ChatCompletionContentPartImageParam).validate_python
888
+ _AudioParser = TypeAdapter(ChatCompletionContentPartAudioParam).validate_python
889
+ _VideoParser = TypeAdapter(ChatCompletionContentPartVideoParam).validate_python
890
+
891
+ _ContentPart: TypeAlias = Union[str, dict[str, str], InputAudio]
892
+
893
+ # Define a mapping from part types to their corresponding parsing functions.
894
+ MM_PARSER_MAP: dict[
895
+ str,
896
+ Callable[[ChatCompletionContentPartParam], _ContentPart],
897
+ ] = {
898
+ "text":
899
+ lambda part: _TextParser(part).get("text", None),
900
+ "image_url":
901
+ lambda part: _ImageParser(part).get("image_url", {}).get("url", None),
902
+ "image_embeds":
903
+ lambda part: _ImageEmbedsParser(part).get("image_embeds", None),
904
+ "audio_url":
905
+ lambda part: _AudioParser(part).get("audio_url", {}).get("url", None),
906
+ "input_audio":
907
+ lambda part: _InputAudioParser(part).get("input_audio", None),
908
+ "refusal":
909
+ lambda part: _RefusalParser(part).get("refusal", None),
910
+ "video_url":
911
+ lambda part: _VideoParser(part).get("video_url", {}).get("url", None),
912
+ }
913
+
914
+
915
+ def _parse_chat_message_content_mm_part(
916
+ part: ChatCompletionContentPartParam) -> tuple[str, _ContentPart]:
917
+ """
918
+ Parses a given multi-modal content part based on its type.
919
+
920
+ Args:
921
+ part: A dict containing the content part, with a potential 'type' field.
922
+
923
+ Returns:
924
+ A tuple (part_type, content) where:
925
+ - part_type: Type of the part (e.g., 'text', 'image_url').
926
+ - content: Parsed content (e.g., text, image URL).
927
+
928
+ Raises:
929
+ ValueError: If the 'type' field is missing and no direct URL is found.
930
+ """
931
+ assert isinstance(
932
+ part, dict) # This is needed to avoid mypy errors: part.get() from str
933
+ part_type = part.get("type", None)
934
+
935
+ if isinstance(part_type, str) and part_type in MM_PARSER_MAP:
936
+ content = MM_PARSER_MAP[part_type](part)
937
+
938
+ # Special case for 'image_url.detail'
939
+ # We only support 'auto', which is the default
940
+ if part_type == "image_url" and part.get("detail", "auto") != "auto":
941
+ logger.warning("'image_url.detail' is currently not supported "
942
+ "and will be ignored.")
943
+
944
+ return part_type, content
945
+
946
+ # Handle missing 'type' but provided direct URL fields.
947
+ # 'type' is required field by pydantic
948
+ if part_type is None:
949
+ if part.get("image_url") is not None:
950
+ image_params = cast(CustomChatCompletionContentSimpleImageParam,
951
+ part)
952
+ return "image_url", image_params.get("image_url", "")
953
+ if part.get("audio_url") is not None:
954
+ audio_params = cast(CustomChatCompletionContentSimpleAudioParam,
955
+ part)
956
+ return "audio_url", audio_params.get("audio_url", "")
957
+ if part.get("input_audio") is not None:
958
+ input_audio_params = cast(dict[str, str], part)
959
+ return "input_audio", input_audio_params
960
+ if part.get("video_url") is not None:
961
+ video_params = cast(CustomChatCompletionContentSimpleVideoParam,
962
+ part)
963
+ return "video_url", video_params.get("video_url", "")
964
+ # Raise an error if no 'type' or direct URL is found.
965
+ raise ValueError("Missing 'type' field in multimodal part.")
966
+
967
+ if not isinstance(part_type, str):
968
+ raise ValueError("Invalid 'type' field in multimodal part.")
969
+ return part_type, "unknown part_type content"
970
+
971
+
972
+ VALID_MESSAGE_CONTENT_MM_PART_TYPES = ("text", "refusal", "image_url",
973
+ "image_embeds",
974
+ "audio_url", "input_audio", "video_url")
975
+
976
+
977
+ def _parse_chat_message_content_parts(
978
+ role: str,
979
+ parts: Iterable[ChatCompletionContentPartParam],
980
+ mm_tracker: BaseMultiModalItemTracker,
981
+ *,
982
+ wrap_dicts: bool,
983
+ ) -> list[ConversationMessage]:
984
+ content = list[_ContentPart]()
985
+
986
+ mm_parser = mm_tracker.create_parser()
987
+
988
+ for part in parts:
989
+ parse_res = _parse_chat_message_content_part(
990
+ part,
991
+ mm_parser,
992
+ wrap_dicts=wrap_dicts,
993
+ )
994
+ if parse_res:
995
+ content.append(parse_res)
996
+
997
+ if wrap_dicts:
998
+ # Parsing wraps images and texts as interleaved dictionaries
999
+ return [ConversationMessage(role=role,
1000
+ content=content)] # type: ignore
1001
+ texts = cast(list[str], content)
1002
+ text_prompt = "\n".join(texts)
1003
+ mm_placeholder_counts = mm_parser.mm_placeholder_counts()
1004
+ if mm_placeholder_counts:
1005
+ text_prompt = _get_full_multimodal_text_prompt(mm_placeholder_counts,
1006
+ text_prompt)
1007
+ return [ConversationMessage(role=role, content=text_prompt)]
1008
+
1009
+
1010
+ def _parse_chat_message_content_part(
1011
+ part: ChatCompletionContentPartParam,
1012
+ mm_parser: BaseMultiModalContentParser,
1013
+ *,
1014
+ wrap_dicts: bool,
1015
+ ) -> Optional[_ContentPart]:
1016
+ """Parses a single part of a conversation. If wrap_dicts is True,
1017
+ structured dictionary pieces for texts and images will be
1018
+ wrapped in dictionaries, i.e., {"type": "text", "text", ...} and
1019
+ {"type": "image"}, respectively. Otherwise multimodal data will be
1020
+ handled by mm_parser, and texts will be returned as strings to be joined
1021
+ with multimodal placeholders.
1022
+ """
1023
+ if isinstance(part, str): # Handle plain text parts
1024
+ return part
1025
+
1026
+ # Handle structured dictionary parts
1027
+ part_type, content = _parse_chat_message_content_mm_part(part)
1028
+
1029
+ # if part_type is text/refusal/image_url/audio_url/video_url/input_audio but
1030
+ # content is None, log a warning and skip
1031
+ if part_type in VALID_MESSAGE_CONTENT_MM_PART_TYPES and content is None:
1032
+ logger.warning(
1033
+ "Skipping multimodal part '%s' (type: '%s') "
1034
+ "with empty / unparsable content.", part, part_type)
1035
+ return None
1036
+
1037
+ if part_type in ("text", "refusal"):
1038
+ str_content = cast(str, content)
1039
+ if wrap_dicts:
1040
+ return {'type': 'text', 'text': str_content}
1041
+ else:
1042
+ return str_content
1043
+
1044
+ if part_type == "image_url":
1045
+ str_content = cast(str, content)
1046
+ mm_parser.parse_image(str_content)
1047
+ return {'type': 'image'} if wrap_dicts else None
1048
+ if part_type == "image_embeds":
1049
+ content = cast(Union[str, dict[str, str]], content)
1050
+ mm_parser.parse_image_embeds(content)
1051
+ return {'type': 'image'} if wrap_dicts else None
1052
+ if part_type == "audio_url":
1053
+ str_content = cast(str, content)
1054
+ mm_parser.parse_audio(str_content)
1055
+ return {'type': 'audio'} if wrap_dicts else None
1056
+
1057
+ if part_type == "input_audio":
1058
+ dict_content = cast(InputAudio, content)
1059
+ mm_parser.parse_input_audio(dict_content)
1060
+ return {'type': 'audio'} if wrap_dicts else None
1061
+
1062
+ if part_type == "video_url":
1063
+ str_content = cast(str, content)
1064
+ mm_parser.parse_video(str_content)
1065
+ return {'type': 'video'} if wrap_dicts else None
1066
+
1067
+ raise NotImplementedError(f"Unknown part type: {part_type}")
1068
+
1069
+
1070
+ # No need to validate using Pydantic again
1071
+ _AssistantParser = partial(cast, ChatCompletionAssistantMessageParam)
1072
+ _ToolParser = partial(cast, ChatCompletionToolMessageParam)
1073
+
1074
+
1075
+ def _parse_chat_message_content(
1076
+ message: ChatCompletionMessageParam,
1077
+ mm_tracker: BaseMultiModalItemTracker,
1078
+ content_format: _ChatTemplateContentFormat,
1079
+ ) -> list[ConversationMessage]:
1080
+ role = message["role"]
1081
+ content = message.get("content")
1082
+
1083
+ if content is None:
1084
+ content = []
1085
+ elif isinstance(content, str):
1086
+ content = [
1087
+ ChatCompletionContentPartTextParam(type="text", text=content)
1088
+ ]
1089
+ result = _parse_chat_message_content_parts(
1090
+ role,
1091
+ content, # type: ignore
1092
+ mm_tracker,
1093
+ wrap_dicts=(content_format == "openai"),
1094
+ )
1095
+
1096
+ for result_msg in result:
1097
+ if role == 'assistant':
1098
+ parsed_msg = _AssistantParser(message)
1099
+
1100
+ # The 'tool_calls' is not None check ensures compatibility.
1101
+ # It's needed only if downstream code doesn't strictly
1102
+ # follow the OpenAI spec.
1103
+ if ("tool_calls" in parsed_msg
1104
+ and parsed_msg["tool_calls"] is not None):
1105
+ result_msg["tool_calls"] = list(parsed_msg["tool_calls"])
1106
+ elif role == "tool":
1107
+ parsed_msg = _ToolParser(message)
1108
+ if "tool_call_id" in parsed_msg:
1109
+ result_msg["tool_call_id"] = parsed_msg["tool_call_id"]
1110
+
1111
+ if "name" in message and isinstance(message["name"], str):
1112
+ result_msg["name"] = message["name"]
1113
+
1114
+ return result
1115
+
1116
+
1117
+ def _postprocess_messages(messages: list[ConversationMessage]) -> None:
1118
+ # per the Transformers docs & maintainers, tool call arguments in
1119
+ # assistant-role messages with tool_calls need to be dicts not JSON str -
1120
+ # this is how tool-use chat templates will expect them moving forwards
1121
+ # so, for messages that have tool_calls, parse the string (which we get
1122
+ # from openAI format) to dict
1123
+ for message in messages:
1124
+ if (message["role"] == "assistant" and "tool_calls" in message
1125
+ and isinstance(message["tool_calls"], list)):
1126
+
1127
+ for item in message["tool_calls"]:
1128
+ item["function"]["arguments"] = json.loads(
1129
+ item["function"]["arguments"])
1130
+
1131
+
1132
+ def parse_chat_messages(
1133
+ messages: list[ChatCompletionMessageParam],
1134
+ model_config: ModelConfig,
1135
+ tokenizer: AnyTokenizer,
1136
+ content_format: _ChatTemplateContentFormat,
1137
+ ) -> tuple[list[ConversationMessage], Optional[MultiModalDataDict]]:
1138
+ conversation: list[ConversationMessage] = []
1139
+ mm_tracker = MultiModalItemTracker(model_config, tokenizer)
1140
+
1141
+ for msg in messages:
1142
+ sub_messages = _parse_chat_message_content(
1143
+ msg,
1144
+ mm_tracker,
1145
+ content_format,
1146
+ )
1147
+
1148
+ conversation.extend(sub_messages)
1149
+
1150
+ _postprocess_messages(conversation)
1151
+
1152
+ return conversation, mm_tracker.all_mm_data()
1153
+
1154
+
1155
+ def parse_chat_messages_futures(
1156
+ messages: list[ChatCompletionMessageParam],
1157
+ model_config: ModelConfig,
1158
+ tokenizer: AnyTokenizer,
1159
+ content_format: _ChatTemplateContentFormat,
1160
+ ) -> tuple[list[ConversationMessage], Awaitable[Optional[MultiModalDataDict]]]:
1161
+ conversation: list[ConversationMessage] = []
1162
+ mm_tracker = AsyncMultiModalItemTracker(model_config, tokenizer)
1163
+
1164
+ for msg in messages:
1165
+ sub_messages = _parse_chat_message_content(
1166
+ msg,
1167
+ mm_tracker,
1168
+ content_format,
1169
+ )
1170
+
1171
+ conversation.extend(sub_messages)
1172
+
1173
+ _postprocess_messages(conversation)
1174
+
1175
+ return conversation, mm_tracker.all_mm_data()
1176
+
1177
+
1178
+ def apply_hf_chat_template(
1179
+ tokenizer: Union[PreTrainedTokenizer, PreTrainedTokenizerFast],
1180
+ conversation: list[ConversationMessage],
1181
+ chat_template: Optional[str],
1182
+ tools: Optional[list[dict[str, Any]]],
1183
+ *,
1184
+ trust_remote_code: bool = False,
1185
+ tokenize: bool = False, # Different from HF's default
1186
+ **kwargs: Any,
1187
+ ) -> str:
1188
+ hf_chat_template = resolve_hf_chat_template(
1189
+ tokenizer,
1190
+ chat_template=chat_template,
1191
+ tools=tools,
1192
+ trust_remote_code=trust_remote_code,
1193
+ )
1194
+
1195
+ if hf_chat_template is None:
1196
+ raise ValueError(
1197
+ "As of transformers v4.44, default chat template is no longer "
1198
+ "allowed, so you must provide a chat template if the tokenizer "
1199
+ "does not define one.")
1200
+
1201
+ try:
1202
+
1203
+ return tokenizer.apply_chat_template(
1204
+ conversation=conversation, # type: ignore[arg-type]
1205
+ tools=tools, # type: ignore[arg-type]
1206
+ chat_template=hf_chat_template,
1207
+ tokenize=tokenize,
1208
+ **kwargs,
1209
+ )
1210
+
1211
+ # External library exceptions can sometimes occur despite the framework's
1212
+ # internal exception management capabilities.
1213
+ except Exception as e:
1214
+
1215
+ # Log and report any library-related exceptions for further
1216
+ # investigation.
1217
+ logger.exception(
1218
+ "An error occurred in `transformers` while applying chat template")
1219
+ raise ValueError from e
1220
+
1221
+ def apply_mistral_chat_template(
1222
+ tokenizer: MistralTokenizer,
1223
+ messages: list[ChatCompletionMessageParam],
1224
+ chat_template: Optional[str],
1225
+ tools: Optional[list[dict[str, Any]]],
1226
+ **kwargs: Any,
1227
+ ) -> list[int]:
1228
+ from mistral_common.exceptions import MistralCommonException
1229
+
1230
+ # The return value of resolve_mistral_chat_template is always None,
1231
+ # and we won't use it.
1232
+ resolve_mistral_chat_template(
1233
+ chat_template=chat_template,
1234
+ **kwargs,
1235
+ )
1236
+
1237
+ try:
1238
+ return tokenizer.apply_chat_template(
1239
+ messages=messages,
1240
+ tools=tools,
1241
+ **kwargs,
1242
+ )
1243
+ # mistral-common uses assert statements to stop processing of input
1244
+ # if input does not comply with the expected format.
1245
+ # We convert those assertion errors to ValueErrors so they can be
1246
+ # are properly caught in the preprocessing_input step
1247
+ except (AssertionError, MistralCommonException) as e:
1248
+ raise ValueError from e
1249
+
1250
+ # External library exceptions can sometimes occur despite the framework's
1251
+ # internal exception management capabilities.
1252
+ except Exception as e:
1253
+
1254
+ # Log and report any library-related exceptions for further
1255
+ # investigation.
1256
+ logger.exception(
1257
+ "An error occurred in `mistral_common` while applying chat "
1258
+ "template")
1259
+ raise ValueError from e