utils.py 2.09 KB
Newer Older
1
import time
2
from typing import Iterable, Optional, Tuple
3
4

from vllm import SamplingParams
5
from vllm.lora.request import LoRARequest
6
from vllm.sequence import Logprob, Sequence, SequenceGroup
7
8
9


def create_dummy_prompt(
10
11
12
13
14
15
16
    request_id: str,
    prompt_length: int,
    block_size: Optional[int] = None,
    lora_request: Optional[LoRARequest] = None,
    use_beam_search: bool = False,
    best_of: int = 1,
) -> Tuple[Sequence, SequenceGroup]:
17
18
19
20
21
22
23
24
    if not block_size:
        block_size = prompt_length

    # Create dummy prompt sequence with tokens 0...block_size-1
    # and prompt "0 ... block_size".
    prompt_tokens = list(range(prompt_length))
    prompt_str = " ".join([str(t) for t in prompt_tokens])
    prompt = Sequence(int(request_id), prompt_str, prompt_tokens, block_size)
25
26
27
28
    seq_group = SequenceGroup(
        request_id, [prompt],
        SamplingParams(use_beam_search=use_beam_search, best_of=best_of),
        time.time(), lora_request)
29
30
31
32

    return prompt, seq_group


33
def create_seq_group(
34
35
36
37
38
        seq_prompt_len: int = 1024,
        seq_output_lens: Iterable[int] = (128, ),
        request_id: str = '0',
        seq_id_start: int = 0,
        sampling_params: Optional[SamplingParams] = None) -> SequenceGroup:
39
40
41

    assert len(seq_output_lens) > 0

42
43
44
    if sampling_params is None:
        sampling_params = SamplingParams()

45
    prompt_token_ids = [0] * seq_prompt_len
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65

    seqs = []
    for seq_id_offset, output_len in enumerate(seq_output_lens):
        seq = Sequence(
            seq_id=seq_id_start + seq_id_offset,
            prompt="",
            prompt_token_ids=prompt_token_ids,
            block_size=16,
        )

        for i in range(output_len):
            seq.append_token_id(
                token_id=i,
                logprobs={i: Logprob(0.0)},
            )
        seqs.append(seq)

    seq_group = SequenceGroup(
        request_id=request_id,
        seqs=seqs,
66
        sampling_params=sampling_params,
67
68
69
70
71
72
        arrival_time=time.time(),
    )

    return seq_group


73
74
def round_up_to_next_block(seq_len: int, block_size: int) -> int:
    return (seq_len + block_size - 1) // block_size