Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
OpenDAS
vllm_cscc
Commits
9ebe3034
Commit
9ebe3034
authored
Sep 07, 2025
by
zhuwenwen
Browse files
fix precision issue in mtp
parent
3cec42d1
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
13 additions
and
3 deletions
+13
-3
vllm/v1/worker/gpu_input_batch.py
vllm/v1/worker/gpu_input_batch.py
+9
-1
vllm/v1/worker/gpu_model_runner.py
vllm/v1/worker/gpu_model_runner.py
+4
-2
No files found.
vllm/v1/worker/gpu_input_batch.py
View file @
9ebe3034
...
...
@@ -40,6 +40,7 @@ class CachedRequestState:
block_ids
:
tuple
[
list
[
int
],
...]
num_computed_tokens
:
int
output_token_ids
:
list
[
int
]
spec_token_ids
:
list
[
int
]
=
None
mrope_positions
:
Optional
[
torch
.
Tensor
]
=
None
mrope_position_delta
:
Optional
[
int
]
=
None
...
...
@@ -303,9 +304,16 @@ class InputBatch:
end_idx
=
start_idx
+
len
(
request
.
output_token_ids
)
self
.
token_ids_cpu
[
req_index
,
start_idx
:
end_idx
]
=
request
.
output_token_ids
num_spec_tokens
=
0
if
request
.
spec_token_ids
!=
None
:
num_spec_tokens
=
len
(
request
.
spec_token_ids
)
self
.
token_ids_cpu
[
req_index
,
end_idx
:
end_idx
+
num_spec_tokens
]
=
request
.
spec_token_ids
# Number of token ids in token_ids_cpu.
# NOTE(woosuk): This may include spec decode tokens.
self
.
num_tokens
[
req_index
]
=
request
.
num_tokens
self
.
num_tokens
[
req_index
]
=
request
.
num_tokens
+
num_spec_tokens
# Number of tokens without spec decode tokens.
self
.
num_tokens_no_spec
[
req_index
]
=
request
.
num_tokens
...
...
vllm/v1/worker/gpu_model_runner.py
View file @
9ebe3034
...
...
@@ -555,6 +555,8 @@ class GPUModelRunner(LoRAModelRunnerMixin, KVConnectorModelRunnerMixin):
# Update the cached states.
req_state
.
num_computed_tokens
=
num_computed_tokens
spec_token_ids
=
(
scheduler_output
.
scheduled_spec_decode_tokens
.
get
(
req_id
,
()))
if
not
is_last_rank
:
# When using PP, the scheduler sends the sampled tokens back,
...
...
@@ -571,6 +573,8 @@ class GPUModelRunner(LoRAModelRunnerMixin, KVConnectorModelRunnerMixin):
elif
num_new_tokens
>
0
:
req_state
.
output_token_ids
.
extend
(
new_token_ids
[
-
num_new_tokens
:])
if
len
(
spec_token_ids
)
>
0
:
req_state
.
spec_token_ids
=
spec_token_ids
# Update the block IDs.
if
not
resumed_from_preemption
:
...
...
@@ -610,8 +614,6 @@ class GPUModelRunner(LoRAModelRunnerMixin, KVConnectorModelRunnerMixin):
self
.
input_batch
.
num_tokens
[
req_index
]
=
end_token_index
# Add spec_token_ids to token_ids_cpu.
spec_token_ids
=
(
scheduler_output
.
scheduled_spec_decode_tokens
.
get
(
req_id
,
()))
if
spec_token_ids
:
num_spec_tokens
=
len
(
spec_token_ids
)
start_index
=
self
.
input_batch
.
num_tokens_no_spec
[
req_index
]
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment