simple_frontend.py 2.05 KB
Newer Older
1
import time
2
from typing import List, Optional, Set, Tuple
Woosuk Kwon's avatar
Woosuk Kwon committed
3
4
5
6

from transformers import AutoTokenizer

from cacheflow.sampling_params import SamplingParams
7
from cacheflow.sequence import Sequence, SequenceGroup
Woosuk Kwon's avatar
Woosuk Kwon committed
8
9
10
from cacheflow.utils import Counter


11
class SimpleFrontend:
Woosuk Kwon's avatar
Woosuk Kwon committed
12
13
14
15
16
17
18
19
20
21
22
23
24

    def __init__(
        self,
        model_name: str,
        block_size: int,
    ) -> None:
        self.block_size = block_size

        self.tokenizer = AutoTokenizer.from_pretrained(model_name)
        self.seq_group_counter = Counter()
        self.seq_counter = Counter()
        self.inputs: List[Tuple[SequenceGroup, SamplingParams]] = []

25
26
27
28
29
    def add_eos_token(self, sampling_params: SamplingParams) -> SamplingParams:
        # Stop generation when we see an EOS token.
        sampling_params.stop_token_ids.add(self.tokenizer.eos_token_id)
        return sampling_params

Woosuk Kwon's avatar
Woosuk Kwon committed
30
31
32
    def query(
        self,
        prompt: str,
33
        sampling_params: SamplingParams,
Woosuk Kwon's avatar
Woosuk Kwon committed
34
    ) -> None:
35
36
        token_ids = self.tokenizer.encode(prompt)
        self._add_query(token_ids, sampling_params)
Woosuk Kwon's avatar
Woosuk Kwon committed
37

38
39
40
41
42
    def _add_query(
        self,
        token_ids: List[int],
        sampling_params: SamplingParams,
    ) -> None:
43
        arrival_time = time.time()
Woosuk Kwon's avatar
Woosuk Kwon committed
44
45
46
47
48
49
50
        seqs: List[Sequence] = []
        for _ in range(sampling_params.n):
            seq_id = next(self.seq_counter)
            seq = Sequence(seq_id, token_ids, block_size=self.block_size)
            seqs.append(seq)

        group_id = next(self.seq_group_counter)
51
        seq_group = SequenceGroup(group_id, seqs, arrival_time)
Woosuk Kwon's avatar
Woosuk Kwon committed
52
53
54
55
56
57
58
59
60
61
62
63
64
65
        self.inputs.append((seq_group, sampling_params))

    def get_inputs(self) -> List[Tuple[SequenceGroup, SamplingParams]]:
        inputs = self.inputs
        self.inputs = []
        return inputs

    def print_response(
        self,
        seq_group: SequenceGroup,
    ) -> None:
        for seq in seq_group.seqs:
            token_ids = seq.get_token_ids()
            output = self.tokenizer.decode(token_ids, skip_special_tokens=True)
Woosuk Kwon's avatar
Woosuk Kwon committed
66
            output = output.strip()
Woosuk Kwon's avatar
Woosuk Kwon committed
67
            print(f'Seq {seq.seq_id}: {output!r}')