forked from pytorch/text
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbenchmark_torcharrow_ops.py
87 lines (64 loc) · 3.18 KB
/
benchmark_torcharrow_ops.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
75
76
77
78
79
80
81
82
83
84
85
86
87
import sys, os
import torcharrow as ta
import torcharrow.pytorch as tap
import torchtext.transforms as T
from benchmark.utils import Timer
from torcharrow import functional as ta_F
from torchtext._download_hooks import load_state_dict_from_url
from torchtext.datasets import SST2
sys.path.append(os.path.join(os.path.dirname(os.path.realpath(__file__)), "../examples"))
from data_pipeline.roberta_dataframe import init_ta_gpt2bpe_encoder, init_ta_gpt2bpe_vocab
def run_torchtext_ops():
# tokenizer converting text into tokens
encoder_json_path = "https://download.pytorch.org/models/text/gpt2_bpe_encoder.json"
vocab_bpe_path = "https://download.pytorch.org/models/text/gpt2_bpe_vocab.bpe"
tokenizer = T.GPT2BPETokenizer(encoder_json_path, vocab_bpe_path)
# vocabulary converting tokens to IDs
vocab_path = "https://download.pytorch.org/models/text/roberta.vocab.pt"
vocab = T.VocabTransform(load_state_dict_from_url(vocab_path))
# add token to beginning or end of sentence
add_bos_str = T.AddToken(token="<bos>", begin=True)
add_eos_str = T.AddToken(token="<eros>", begin=False)
add_bos_int = T.AddToken(token=0, begin=True)
add_eos_int = T.AddToken(token=-1, begin=False)
convert_to_tensor = T.ToTensor(padding_value=1)
# dataset
train_dp = SST2(split="train")
text_list = list(train_dp.map(lambda x: x[0]))
with Timer("Running torchtext's GPT2BPE tokenizer"):
tokenized_text = tokenizer(text_list)
with Timer("Running torchtext's vocab query"):
token_ids = vocab(tokenized_text)
with Timer("Running torchtext's add tokens operation (string)"):
add_bos_str(tokenized_text)
add_eos_str(tokenized_text)
with Timer("Running torchtext's add tokens operation (int)"):
add_bos_int(token_ids)
add_eos_int(token_ids)
with Timer("Running torchtext's to tensor conversion"):
convert_to_tensor(token_ids)
def run_torcharrow_ops():
# tokenizer converting text into tokens
tokenizer = init_ta_gpt2bpe_encoder()
# vocabulary converting tokens to IDs
vocab = init_ta_gpt2bpe_vocab()
# dataset
train_dp = SST2(split="train")
text_list = list(train_dp.map(lambda x: x[0]))
with Timer("Converting python data to TA data frame"):
data_frame = ta.dataframe({"text": text_list})
with Timer("Running torcharrow's GPT2BPE tokenizer"):
data_frame["tokens"] = ta_F.bpe_tokenize(tokenizer, data_frame["text"])
with Timer("Running torcharrow's vocab query"):
data_frame["token_ids"] = ta_F.lookup_indices(vocab, data_frame["tokens"])
with Timer("Running torcharrow's add tokens operation (string)"):
ta_F.add_tokens(data_frame["tokens"], ["<bos>"], begin=True)
ta_F.add_tokens(data_frame["tokens"], ["<eos>"], begin=False)
with Timer("Running torcharrow's add tokens operation (int)"):
ta_F.add_tokens(data_frame["token_ids"], [0], begin=True)
ta_F.add_tokens(data_frame["token_ids"], [-1], begin=False)
with Timer("Running torcharrow's to tensor conversion"):
data_frame.to_tensor({"token_ids": tap.PadSequence(padding_value=1)})
if __name__ == "__main__":
run_torchtext_ops()
run_torcharrow_ops()