util.py 1.03 KB
Newer Older
1
2
# SPDX-License-Identifier: Apache-2.0

3
from typing import List
4
from typing import Sequence as GenericSequence
5
from typing import cast
6

7
from vllm.model_executor.layers.sampler import SamplerOutput
8
from vllm.sequence import CompletionSequenceGroupOutput, SequenceGroupOutput
9
10


11
def create_output_by_sequence_group(
12
        outputs: GenericSequence[SamplerOutput],
13
        num_seq_groups: int) -> List[List[SequenceGroupOutput]]:
14
15
16
    """Helper method which transforms a 2d list organized by
    [step][sequence group] into [sequence group][step].
    """
17
    output_by_sequence_group: List[List[CompletionSequenceGroupOutput]] = [
18
19
        [] for _ in range(num_seq_groups)
    ]
20
    for step in outputs:
21
        sequence_group_output: CompletionSequenceGroupOutput
22
23
24
        for i, sequence_group_output in enumerate(step):
            output_by_sequence_group[i].append(sequence_group_output)

25
26
27
    # Cast to the more generic type that CompletionSequenceGroupOutput
    # inherits from.
    return cast(List[List[SequenceGroupOutput]], output_by_sequence_group)