outputs.py 2.17 KB
Newer Older
1
2
# SPDX-License-Identifier: Apache-2.0

3
from dataclasses import dataclass
4
from typing import Dict, List, NamedTuple, Optional
5
6
7
8

import torch


9
class LogprobsLists(NamedTuple):
10

11
12
13
14
    # [num_reqs, max_num_logprobs + 1]
    logprob_token_ids: List[List[int]]
    # [num_reqs, max_num_logprobs + 1]
    logprobs: List[List[float]]
15
    # [num_reqs]
16
17
18
19
20
21
22
23
24
25
26
    sampled_token_ranks: List[int]

    def slice(self, start: int, end: int):
        return LogprobsLists(
            self.logprob_token_ids[start:end],
            self.logprobs[start:end],
            self.sampled_token_ranks[start:end],
        )


class LogprobsTensors(NamedTuple):
27
28

    # [num_reqs, max_num_logprobs + 1]
29
    logprob_token_ids: torch.Tensor
30
    # [num_reqs, max_num_logprobs + 1]
31
32
33
    logprobs: torch.Tensor
    # [num_reqs]
    selected_token_ranks: torch.Tensor
34

35
36
37
38
39
40
41
42
43
44
45
    def tolists(self):
        return LogprobsLists(
            self.logprob_token_ids.tolist(),
            self.logprobs.tolist(),
            self.selected_token_ranks.tolist(),
        )


@dataclass
class SamplerOutput:

46
47
48
49
    # [num_reqs, max_num_generated_tokens]
    # Different requests can have different number of generated tokens.
    # All requests are padded to max_num_generated_tokens.
    # INVALID_TOKEN_ID (-1 by default) is used for padding.
50
51
    sampled_token_ids: torch.Tensor
    logprobs_tensors: Optional[LogprobsTensors]
52
53


54
55
# ModelRunnerOutput is serialized and sent to the scheduler process.
# This is expensive for torch.Tensor so prefer to use List instead.
56
57
58
59
60
61
62
63
@dataclass
class ModelRunnerOutput:

    # [num_reqs]
    req_ids: List[str]
    # req_id -> index
    req_id_to_index: Dict[str, int]

64
65
66
67
68
    # num_reqs x num_generated_tokens
    # num_generated_tokens is the number of tokens
    # generated in the current step. It can be different for
    # each request due to speculative/jump decoding.
    sampled_token_ids: List[List[int]]
69
70
71

    # [num_reqs, max_num_logprobs + 1]
    # [num_reqs, max_num_logprobs + 1]
72
73
74
75
76
77
78
79
    # [num_reqs]
    logprobs: Optional[LogprobsLists]

    # req_id -> (token_ids, logprobs, ranks)
    # [prompt_len, num_prompt_logprobs]
    # [prompt_len, num_prompt_logprobs]
    # [prompt_len]
    prompt_logprobs_dict: Dict[str, LogprobsTensors]