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

from transformers import AutoTokenizer

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


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

    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]] = []

24
25
26
27
28
    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
29
30
31
    def query(
        self,
        prompt: str,
32
        sampling_params: SamplingParams,
Woosuk Kwon's avatar
Woosuk Kwon committed
33
    ) -> None:
34
35
        token_ids = self.tokenizer.encode(prompt)
        self._add_query(token_ids, sampling_params)
Woosuk Kwon's avatar
Woosuk Kwon committed
36

37
38
39
40
41
    def _add_query(
        self,
        token_ids: List[int],
        sampling_params: SamplingParams,
    ) -> None:
Woosuk Kwon's avatar
Woosuk Kwon committed
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
        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)
        seq_group = SequenceGroup(group_id, seqs)
        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
64
            print(f'Seq {seq.seq_id}: {output!r}')