Real-time collaboration for Jupyter Notebooks, Linux Terminals, LaTeX, VS Code, R IDE, and more,
all in one place. Commercial Alternative to JupyterHub.
Real-time collaboration for Jupyter Notebooks, Linux Terminals, LaTeX, VS Code, R IDE, and more,
all in one place. Commercial Alternative to JupyterHub.
Path: blob/main/course/fr/chapter6/section8.ipynb
Views: 2548
Kernel: Python 3
Construction d'un tokenizer, bloc par bloc
Installez les bibliothèques 🤗 Transformers et 🤗 Datasets pour exécuter ce notebook.
In [ ]:
!pip install datasets transformers[sentencepiece]
In [ ]:
from datasets import load_dataset dataset = load_dataset("wikitext", name="wikitext-2-raw-v1", split="train") def get_training_corpus(): for i in range(0, len(dataset), 1000): yield dataset[i : i + 1000]["text"]
In [ ]:
with open("wikitext-2.txt", "w", encoding="utf-8") as f: for i in range(len(dataset)): f.write(dataset[i]["text"] + "\n")
In [ ]:
from tokenizers import ( decoders, models, normalizers, pre_tokenizers, processors, trainers, Tokenizer, ) tokenizer = Tokenizer(models.WordPiece(unk_token="[UNK]"))
In [ ]:
tokenizer.normalizer = normalizers.BertNormalizer(lowercase=True)
In [ ]:
tokenizer.normalizer = normalizers.Sequence( [normalizers.NFD(), normalizers.Lowercase(), normalizers.StripAccents()] )
In [ ]:
print(tokenizer.normalizer.normalize_str("Héllò hôw are ü?"))
In [ ]:
tokenizer.pre_tokenizer = pre_tokenizers.BertPreTokenizer()
In [ ]:
tokenizer.pre_tokenizer = pre_tokenizers.Whitespace()
In [ ]:
tokenizer.pre_tokenizer.pre_tokenize_str("Testons le prétokeniseur.")
In [ ]:
pre_tokenizer = pre_tokenizers.WhitespaceSplit() pre_tokenizer.pre_tokenize_str("Testons le prétokeniseur.")
In [ ]:
pre_tokenizer = pre_tokenizers.Sequence( [pre_tokenizers.WhitespaceSplit(), pre_tokenizers.Punctuation()] ) pre_tokenizer.pre_tokenize_str("Testons le prétokeniseur.")
In [ ]:
special_tokens = ["[UNK]", "[PAD]", "[CLS]", "[SEP]", "[MASK]"] trainer = trainers.WordPieceTrainer(vocab_size=25000, special_tokens=special_tokens)
In [ ]:
tokenizer.train_from_iterator(get_training_corpus(), trainer=trainer)
In [ ]:
tokenizer.model = models.WordPiece(unk_token="[UNK]") tokenizer.train(["wikitext-2.txt"], trainer=trainer)
In [ ]:
encoding = tokenizer.encode("Testons le prétokeniseur.") print(encoding.tokens)
In [ ]:
cls_token_id = tokenizer.token_to_id("[CLS]") sep_token_id = tokenizer.token_to_id("[SEP]") print(cls_token_id, sep_token_id)
In [ ]:
tokenizer.post_processor = processors.TemplateProcessing( single=f"[CLS]:0 $A:0 [SEP]:0", pair=f"[CLS]:0 $A:0 [SEP]:0 $B:1 [SEP]:1", special_tokens=[("[CLS]", cls_token_id), ("[SEP]", sep_token_id)], )
In [ ]:
encoding = tokenizer.encode("Testons le prétokeniseur.") print(encoding.tokens)
In [ ]:
encoding = tokenizer.encode("Testons le prétokeniseur...", "sur des phrases.") print(encoding.tokens) print(encoding.type_ids)
In [ ]:
tokenizer.decoder = decoders.WordPiece(prefix="##")
In [ ]:
tokenizer.decode(encoding.ids)
In [ ]:
tokenizer.save("tokenizer.json")
In [ ]:
new_tokenizer = Tokenizer.from_file("tokenizer.json")
In [ ]:
from transformers import PreTrainedTokenizerFast wrapped_tokenizer = PreTrainedTokenizerFast( tokenizer_object=tokenizer, # tokenizer_file="tokenizer.json", # Vous pouvez charger à partir du fichier tokenizer, alternativement unk_token="[UNK]", pad_token="[PAD]", cls_token="[CLS]", sep_token="[SEP]", mask_token="[MASK]", )
In [ ]:
from transformers import BertTokenizerFast wrapped_tokenizer = BertTokenizerFast(tokenizer_object=tokenizer)
In [ ]:
tokenizer = Tokenizer(models.BPE())
In [ ]:
tokenizer.pre_tokenizer = pre_tokenizers.ByteLevel(add_prefix_space=False)
In [ ]:
tokenizer.pre_tokenizer.pre_tokenize_str("Testons la prétokenisation !")
In [ ]:
trainer = trainers.BpeTrainer(vocab_size=25000, special_tokens=["<|endoftext|>"]) tokenizer.train_from_iterator(get_training_corpus(), trainer=trainer)
In [ ]:
tokenizer.model = models.BPE() tokenizer.train(["wikitext-2.txt"], trainer=trainer)
In [ ]:
encoding = tokenizer.encode("Testons ce tokeniseur.") print(encoding.tokens)
In [ ]:
tokenizer.post_processor = processors.ByteLevel(trim_offsets=False)
In [ ]:
sentence = "Testons ce tokeniseur." encoding = tokenizer.encode(sentence) start, end = encoding.offsets[4] sentence[start:end]
In [ ]:
tokenizer.decoder = decoders.ByteLevel()
In [ ]:
tokenizer.decode(encoding.ids)
In [ ]:
from transformers import PreTrainedTokenizerFast wrapped_tokenizer = PreTrainedTokenizerFast( tokenizer_object=tokenizer, bos_token="<|endoftext|>", eos_token="<|endoftext|>", )
In [ ]:
from transformers import GPT2TokenizerFast wrapped_tokenizer = GPT2TokenizerFast(tokenizer_object=tokenizer)
In [ ]:
tokenizer = Tokenizer(models.Unigram())
In [ ]:
from tokenizers import Regex tokenizer.normalizer = normalizers.Sequence( [ normalizers.Replace("``", '"'), normalizers.Replace("''", '"'), normalizers.NFKD(), normalizers.StripAccents(), normalizers.Replace(Regex(" {2,}"), " "), ] )
In [ ]:
tokenizer.pre_tokenizer = pre_tokenizers.Metaspace()
In [ ]:
tokenizer.pre_tokenizer.pre_tokenize_str("Testons ce prétokeniseur !")
In [ ]:
special_tokens = ["<cls>", "<sep>", "<unk>", "<pad>", "<mask>", "<s>", "</s>"] trainer = trainers.UnigramTrainer( vocab_size=25000, special_tokens=special_tokens, unk_token="<unk>" ) tokenizer.train_from_iterator(get_training_corpus(), trainer=trainer)
In [ ]:
tokenizer.model = models.Unigram() tokenizer.train(["wikitext-2.txt"], trainer=trainer)
In [ ]:
encoding = tokenizer.encode("Testons ce prétokeniseur.") print(encoding.tokens)
In [ ]:
cls_token_id = tokenizer.token_to_id("<cls>") sep_token_id = tokenizer.token_to_id("<sep>") print(cls_token_id, sep_token_id)
In [ ]:
tokenizer.post_processor = processors.TemplateProcessing( single="$A:0 <sep>:0 <cls>:2", pair="$A:0 <sep>:0 $B:1 <sep>:1 <cls>:2", special_tokens=[("<sep>", sep_token_id), ("<cls>", cls_token_id)], )
In [ ]:
encoding = tokenizer.encode("Testons ce tokeniseur...", "sur des phrases !") print(encoding.tokens) print(encoding.type_ids)
In [ ]:
tokenizer.decoder = decoders.Metaspace()
In [ ]:
from transformers import PreTrainedTokenizerFast wrapped_tokenizer = PreTrainedTokenizerFast( tokenizer_object=tokenizer, bos_token="<s>", eos_token="</s>", unk_token="<unk>", pad_token="<pad>", cls_token="<cls>", sep_token="<sep>", mask_token="<mask>", padding_side="left", )
In [ ]:
from transformers import XLNetTokenizerFast wrapped_tokenizer = XLNetTokenizerFast(tokenizer_object=tokenizer)