Bases: InductorPass
An inductor pass with access to vLLM PassConfig. It provides timing, logging, and dumping utilities.
Source code in vllm/compilation/vllm_inductor_pass.py
| class VllmInductorPass(InductorPass):
"""
An inductor pass with access to vLLM PassConfig.
It provides timing, logging, and dumping utilities.
"""
def __init__(self, config: VllmConfig):
self.pass_config = config.compilation_config.pass_config
self.model_dtype = config.model_config.dtype if config.model_config \
else None
self.device = config.device_config.device if config.device_config \
else None
self.pass_name = self.__class__.__name__
def dump_graph(self, graph: torch.fx.Graph, stage: str):
lazy_format_graph_code(stage, graph.owning_module)
def begin(self):
self._start_time = time.perf_counter_ns()
def end_and_log(self):
self._end_time = time.perf_counter_ns()
duration_ms = float(self._end_time - self._start_time) / 1.0e6
logger.debug("%s completed in %.1f ms", self.pass_name, duration_ms)
|
device instance-attribute
device = device if device_config else None
model_dtype instance-attribute
model_dtype = dtype if model_config else None
pass_config instance-attribute
pass_config = pass_config
pass_name instance-attribute
__init__
Source code in vllm/compilation/vllm_inductor_pass.py
| def __init__(self, config: VllmConfig):
self.pass_config = config.compilation_config.pass_config
self.model_dtype = config.model_config.dtype if config.model_config \
else None
self.device = config.device_config.device if config.device_config \
else None
self.pass_name = self.__class__.__name__
|
begin
Source code in vllm/compilation/vllm_inductor_pass.py
| def begin(self):
self._start_time = time.perf_counter_ns()
|
dump_graph
Source code in vllm/compilation/vllm_inductor_pass.py
| def dump_graph(self, graph: torch.fx.Graph, stage: str):
lazy_format_graph_code(stage, graph.owning_module)
|
end_and_log
Source code in vllm/compilation/vllm_inductor_pass.py
| def end_and_log(self):
self._end_time = time.perf_counter_ns()
duration_ms = float(self._end_time - self._start_time) / 1.0e6
logger.debug("%s completed in %.1f ms", self.pass_name, duration_ms)
|