-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprepare_shakespear.py
74 lines (58 loc) · 2.18 KB
/
prepare_shakespear.py
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
"""
Prepare the Shakespeare dataset for character-level language modeling.
So instead of encoding with GPT-2 BPE tokens, we just map characters to ints.
Will save train.bin, val.bin containing the ids, and meta.pkl containing the
encoder and decoder and some other related info.
"""
import pickle
from pathlib import Path
import numpy as np
import requests
input_file_path = Path(__file__).parent / "input.txt"
if not input_file_path.exists():
data_url = (
"https://raw.githubusercontent.com/karpathy/char-rnn/master/data/tinyshakespeare/input.txt"
)
input_file_path.write_text(requests.get(data_url, timeout=60).text)
data = input_file_path.read_text()
print(f"length of dataset in characters: {len(data):,}")
# get all the unique characters that occur in this text
chars = sorted(set(data))
vocab_size = len(chars)
print("all the unique characters:", "".join(chars))
print(f"vocab size: {vocab_size:,}")
# create a mapping from characters to integers
stoi = {ch: i for i, ch in enumerate(chars)}
itos = {i: ch for i, ch in enumerate(chars)} # noqa
def encode(s):
return [stoi[c] for c in s] # encoder: take a string, output a list of integers
def decode(tokens):
return "".join([itos[i] for i in tokens]) # decoder: take a list of integers, output a string
# create the train and test splits
n = len(data)
train_data = data[: int(n * 0.9)]
val_data = data[int(n * 0.9) :]
# encode both to integers
train_ids = encode(train_data)
val_ids = encode(val_data)
print(f"train has {len(train_ids):,} tokens")
print(f"val has {len(val_ids):,} tokens")
current_dir = Path(__file__).parent
train_ids = np.array(train_ids, dtype=np.uint16)
val_ids = np.array(val_ids, dtype=np.uint16)
train_ids.tofile(current_dir / "train.bin")
val_ids.tofile(current_dir / "val.bin")
# save the meta information as well, to help us encode/decode later
meta = {
"vocab_size": vocab_size,
"itos": itos,
"stoi": stoi,
}
with (current_dir / "meta.pkl").open("wb") as f:
pickle.dump(meta, f)
# length of dataset in characters: 1115394
# all the unique characters:
# !$&',-.3:;?ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
# vocab size: 65
# train has 1003854 tokens
# val has 111540 tokens