# Overlap Scheduler To maximize GPU utilization, the scheduler overlaps CPU tasks (e.g., checking sampling stop criteria, updating responses, scheduling the next batch) with GPU computation. ## How It Works At step *n*, the system launches GPU computation for step *n+1* without waiting for CPU tasks (e.g., stop criteria checks) from step *n* to complete. This allows: - CPU work (step *n*) and GPU computation (step *n+1*) to run concurrently. - Better GPU occupancy by reducing idle time. ## Tradeoff The optimization introduces one extra decoding step but significantly improves throughput. ## Usage Enabled by default. To disable, set `disable_overlap_scheduler=True` in the configuration. ## References - [NanoFlow: Towards Optimal Large Language Model Serving Throughput](https://arxiv.org/abs/2408.12757) - https://lmsys.org/blog/2024-12-04-sglang-v0-4/#zero-overhead-batch-scheduler