| sidebar-title | Gradual Ramping |
|---|
Gradual ramping lets you increase concurrency and request rate smoothly over time, rather than jumping to full load immediately. This prevents overwhelming your server at benchmark start.
When a benchmark starts, immediately hitting your target load can cause problems:
Without ramping: With ramping:
Concurrency Concurrency
100 ┤●━━━━━━━━━━━━━━━━━━━ 100 ┤ ●━━━━━━━━━
│ │ ╱
│ SPIKE! Server overwhelmed │ ╱
│ - Connection storms │ ╱ Gradual increase
│ - Memory allocation spikes 50 ┤ ╱ Server stabilizes
│ - Cold-start pollution │ ╱ at each level
0 ┼──────────────────────▶ 0 ┼●─────────────────────▶
0 Time 0 30s Time
Problems without ramping:
- Connection storms — Hundreds of simultaneous connections overwhelming the server
- Memory spikes — Sudden KV-cache allocation causing OOM or degraded performance
- Misleading metrics — Cold-start effects polluting your steady-state measurements
Benefits of ramping:
- Server warms up gradually (caches, JIT compilation, connection pools)
- Early detection of capacity limits before hitting full load
- Cleaner measurements once you reach steady state
AIPerf supports ramping three dimensions:
| Dimension | CLI Option | What It Controls |
|---|---|---|
| Session Concurrency | --concurrency-ramp-duration |
Max simultaneous requests |
| Prefill Concurrency | --prefill-concurrency-ramp-duration |
Max requests in prefill phase |
| Request Rate | --request-rate-ramp-duration |
Requests per second |
Each ramps from a low starting value up to your target over the specified duration.
Gradually increase from 1 concurrent request to 100 over 30 seconds:
aiperf profile \
--model your-model \
--url localhost:8000 \
--concurrency 100 \
--concurrency-ramp-duration 30 \
--request-count 1000Sample Output (Successful Run):
INFO Starting AIPerf System
INFO Concurrency ramping from 1 to 100 over 30 seconds
INFO AIPerf System is PROFILING
Profiling: 1000/1000 |████████████████████████| 100% [02:15<00:00]
INFO Benchmark completed successfully
INFO Results saved to: artifacts/your-model-chat-concurrency100/
NVIDIA AIPerf | LLM Metrics
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━━━━┓
┃ Metric ┃ avg ┃ min ┃ max ┃ p99 ┃ p50 ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━╇━━━━━━━━╇━━━━━━━━╇━━━━━━━━╇━━━━━━━━┩
│ Request Latency (ms) │ 234.56 │ 156.23 │ 387.45 │ 356.78 │ 228.90 │
│ Time to First Token (ms) │ 52.34 │ 38.12 │ 78.23 │ 72.45 │ 50.67 │
│ Inter Token Latency (ms) │ 12.45 │ 9.12 │ 19.34 │ 17.89 │ 12.01 │
│ Request Throughput (req/s) │ 12.45 │ - │ - │ - │ - │
└────────────────────────────┴────────┴────────┴────────┴────────┴────────┘
JSON Export: artifacts/your-model-chat-concurrency100/profile_export_aiperf.json
What happens:
Concurrency
100 ┤ ●━━━━━━━━━━━
75 ┤ ●────┘
50 ┤ ●────┘
25 ┤ ●────┘
1 ┤●────┘
└─────┬─────┬─────┬─────┬─────────────────▶
7.5s 15s 22.5s 30s Time
Gradually increase from a low starting rate to 100 QPS over 60 seconds:
aiperf profile \
--model your-model \
--url localhost:8000 \
--request-rate 100 \
--request-rate-ramp-duration 60 \
--benchmark-duration 120Sample Output (Successful Run):
INFO Starting AIPerf System
INFO Request rate ramping from ~0.17 to 100.0 req/s over 60 seconds
INFO AIPerf System is PROFILING
Profiling: [02:00] - Running for 120 seconds...
INFO Benchmark completed successfully
INFO Results saved to: artifacts/your-model-chat-rate100/
NVIDIA AIPerf | LLM Metrics
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━━━━┓
┃ Metric ┃ avg ┃ min ┃ max ┃ p99 ┃ p50 ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━╇━━━━━━━━╇━━━━━━━━╇━━━━━━━━╇━━━━━━━━┩
│ Request Latency (ms) │ 187.34 │ 134.56 │ 298.12 │ 276.45 │ 182.67 │
│ Time to First Token (ms) │ 48.23 │ 35.67 │ 72.34 │ 68.90 │ 47.12 │
│ Inter Token Latency (ms) │ 11.89 │ 8.45 │ 17.23 │ 16.12 │ 11.34 │
│ Request Throughput (req/s) │ 91.23 │ - │ - │ - │ - │
└────────────────────────────┴────────┴────────┴────────┴────────┴────────┘
JSON Export: artifacts/your-model-chat-rate100/profile_export_aiperf.json
What happens:
Request Rate (QPS)
100 ┤ ●━━━━━━━━━━━
75 ┤ ●────┘
50 ┤ ●────┘
25 ┤ ●────┘
~0 ┤●────┘
└─────┬─────┬─────┬─────┬─────────────────▶
15s 30s 45s 60s Time
Note
The starting rate is calculated proportionally: start = target * (update_interval / duration). With default settings (0.1s updates), ramping to 100 QPS over 60 seconds starts at ~0.17 QPS (not zero).
Ramp both dimensions together for maximum control:
aiperf profile \
--model your-model \
--url localhost:8000 \
--request-rate 200 \
--request-rate-ramp-duration 30 \
--concurrency 100 \
--concurrency-ramp-duration 30 \
--benchmark-duration 120Sample Output (Successful Run):
INFO Starting AIPerf System
INFO Request rate ramping from ~0.67 to 200.0 req/s over 30 seconds
INFO Concurrency ramping from 1 to 100 over 30 seconds
INFO AIPerf System is PROFILING
Profiling: [02:00] - Running for 120 seconds...
INFO Benchmark completed successfully
INFO Results saved to: artifacts/your-model-chat-concurrency100-rate200/
NVIDIA AIPerf | LLM Metrics
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━━━━┓
┃ Metric ┃ avg ┃ min ┃ max ┃ p99 ┃ p50 ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━╇━━━━━━━━╇━━━━━━━━╇━━━━━━━━╇━━━━━━━━┩
│ Request Latency (ms) │ 245.67 │ 167.89 │ 412.34 │ 378.90 │ 238.45 │
│ Time to First Token (ms) │ 56.78 │ 42.34 │ 89.12 │ 82.67 │ 54.90 │
│ Inter Token Latency (ms) │ 13.45 │ 9.67 │ 21.34 │ 19.45 │ 13.01 │
│ Request Throughput (req/s) │ 178.34 │ - │ - │ - │ - │
└────────────────────────────┴────────┴────────┴────────┴────────┴────────┘
JSON Export: artifacts/your-model-chat-concurrency100-rate200/profile_export_aiperf.json
Both ramp in parallel, reaching their targets at 30 seconds.
For long-context workloads, you may want to limit how many requests are in the "prefill" phase (processing input tokens) simultaneously. This prevents memory spikes from multiple large prompts being processed at once.
aiperf profile \
--model your-model \
--url localhost:8000 \
--concurrency 100 \
--prefill-concurrency 20 \
--prefill-concurrency-ramp-duration 20 \
--synthetic-input-tokens-mean 8000Sample Output (Successful Run):
INFO Starting AIPerf System
INFO Prefill concurrency ramping from 1 to 20 over 20 seconds
INFO AIPerf System is PROFILING
Profiling: 500/500 |████████████████████████| 100% [05:30<00:00]
INFO Benchmark completed successfully
INFO Results saved to: artifacts/your-model-chat-concurrency100/
NVIDIA AIPerf | LLM Metrics
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━┳━━━━━━━━━┳━━━━━━━━━┳━━━━━━━━━┳━━━━━━━━━┓
┃ Metric ┃ avg ┃ min ┃ max ┃ p99 ┃ p50 ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━╇━━━━━━━━━╇━━━━━━━━━╇━━━━━━━━━╇━━━━━━━━━┩
│ Request Latency (ms) │ 3456.78 │ 2890.12 │ 4567.89 │ 4321.45 │ 3398.23 │
│ Time to First Token (ms) │ 1234.56 │ 987.34 │ 1678.90 │ 1598.67 │ 1201.45 │
│ Inter Token Latency (ms) │ 14.23 │ 10.45 │ 22.67 │ 20.89 │ 13.89 │
│ Request Throughput (req/s) │ 2.89 │ - │ - │ - │ - │
└────────────────────────────┴─────────┴─────────┴─────────┴─────────┴─────────┘
JSON Export: artifacts/your-model-chat-concurrency100/profile_export_aiperf.json
This limits prefill to 20 concurrent requests (ramped over 20 seconds), while allowing up to 100 total concurrent requests.
Each phase can have its own ramp settings. Warmup uses --warmup-* prefixed options:
aiperf profile \
--model your-model \
--url localhost:8000 \
# Warmup phase: ramp to 50 concurrency over 10 seconds
--warmup-concurrency 50 \
--warmup-concurrency-ramp-duration 10 \
--warmup-request-count 500 \
# Profiling phase: ramp to 200 concurrency over 30 seconds
--concurrency 200 \
--concurrency-ramp-duration 30 \
--request-count 2000Ramp slowly to avoid overwhelming the server, then sustain full load:
aiperf profile \
--model your-model \
--url localhost:8000 \
--concurrency 500 \
--concurrency-ramp-duration 60 \
--benchmark-duration 300The 60-second ramp gives the server time to allocate resources (~8 new connections per second).
Limit memory spikes from large prompts with prefill concurrency:
aiperf profile \
--model your-model \
--url localhost:8000 \
--concurrency 50 \
--prefill-concurrency 5 \
--prefill-concurrency-ramp-duration 30 \
--synthetic-input-tokens-mean 32000Only 5 requests process their 32K input tokens simultaneously, preventing KV-cache OOM.
Find your server's limits by ramping slowly and watching for degradation:
aiperf profile \
--model your-model \
--url localhost:8000 \
--request-rate 500 \
--request-rate-ramp-duration 120 \
--concurrency 200 \
--concurrency-ramp-duration 120 \
--benchmark-duration 180Watch latency and throughput metrics as load increases. When latency spikes or errors appear, you've found the limit.
Concurrency increases by +1 at evenly spaced intervals:
- 100 concurrency over 30 seconds = +1 every ~0.3 seconds
- 500 concurrency over 60 seconds = +1 every ~0.12 seconds
Each step allows one more concurrent request immediately.
Rate updates continuously (every 0.1 seconds by default):
- 100 QPS over 60 seconds = updates ~600 times, smoothly increasing
- Linear interpolation from start rate to target rate
This creates smooth traffic curves without sudden jumps.
| Option | Description | Default |
|---|---|---|
--concurrency-ramp-duration <sec> |
Ramp session concurrency over N seconds | No ramping |
--prefill-concurrency-ramp-duration <sec> |
Ramp prefill concurrency over N seconds | No ramping |
--request-rate-ramp-duration <sec> |
Ramp request rate over N seconds | No ramping |
--warmup-concurrency-ramp-duration <sec> |
Warmup phase concurrency ramp | Uses main value |
--warmup-prefill-concurrency-ramp-duration <sec> |
Warmup phase prefill ramp | Uses main value |
--warmup-request-rate-ramp-duration <sec> |
Warmup phase rate ramp | Uses main value |
Key behaviors:
- Concurrency starts at 1 and increases by +1 at even intervals
- Request rate starts proportionally low and interpolates smoothly
- Ramps complete exactly at the specified duration
- After ramping, values stay at the target for the rest of the phase
- Prefill Concurrency — Memory-safe long-context benchmarking with prefill limiting
- Request Rate with Concurrency — Combining rate and concurrency controls
- Timing Modes Reference — Complete CLI compatibility matrix