Spaces:
Sleeping
Sleeping
File size: 1,527 Bytes
0097326 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
from xsbpe.base import Tokenizer, get_adjacent_pair_counts, merge_pairs
class BasicTokenizer(Tokenizer):
def __init__(self):
super().__init__()
def train(self, text, vocab_size, verbose=False):
assert vocab_size >= 256
num_merges = vocab_size - 256
text_bytes = text.encode('utf-8')
ids = list(text_bytes)
merges = {}
vocab = {idx: bytes([idx]) for idx in range(256)}
for i in range(num_merges):
stats = get_adjacent_pair_counts(ids)
pair = max(stats, key=stats.get)
idx = 256 + i
ids = merge_pairs(ids, pair, idx)
merges[pair] = idx
vocab[idx] = vocab[pair[0]] + vocab[pair[1]]
if verbose:
print(f"merge {i+1}/{num_merges}: {pair} -> {idx} ({vocab[idx]}) had {stats[pair]} occurrences")
self.merges = merges
self.vocab = vocab
def decode(self, ids):
text_bytes = b''.join(self.vocab[idx] for idx in ids)
text = text_bytes.decode('utf-8', errors='replace')
return text
def encode(self, text):
text_bytes = text.encode('utf-8')
ids = list(text_bytes)
while len(ids) >= 2:
stats = get_adjacent_pair_counts(ids)
pair = min(stats, key=lambda p: self.merges.get(p, float('inf')))
if pair not in self.merges:
break
idx = self.merges[pair]
ids = merge_pairs(ids, pair, idx)
return ids |