"vscode:/vscode.git/clone" did not exist on "9d9b872b66f9ab9b7b7c73f2c00985dd92c4121b"
test_tokenization_albert.py 3.73 KB
Newer Older
Lysandre's avatar
Lysandre committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
# coding=utf-8
# Copyright 2019 Hugging Face inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
Aymeric Augustin's avatar
Aymeric Augustin committed
15

Lysandre's avatar
Lysandre committed
16
17

import os
18
import unittest
Lysandre's avatar
Lysandre committed
19

20
from transformers.tokenization_albert import AlbertTokenizer, AlbertTokenizerFast
Lysandre's avatar
Lysandre committed
21

22
from .test_tokenization_common import TokenizerTesterMixin
Lysandre's avatar
Lysandre committed
23

Aymeric Augustin's avatar
Aymeric Augustin committed
24

25
26
SAMPLE_VOCAB = os.path.join(os.path.dirname(os.path.abspath(__file__)), "fixtures/spiece.model")

Lysandre's avatar
Lysandre committed
27

28
class AlbertTokenizationTest(TokenizerTesterMixin, unittest.TestCase):
Lysandre's avatar
Lysandre committed
29
30

    tokenizer_class = AlbertTokenizer
31
32
    rust_tokenizer_class = AlbertTokenizerFast
    test_rust_tokenizer = True
Lysandre's avatar
Lysandre committed
33
34

    def setUp(self):
Julien Chaumond's avatar
Julien Chaumond committed
35
        super().setUp()
Lysandre's avatar
Lysandre committed
36
37
38
39
40

        # We have a SentencePiece fixture for testing
        tokenizer = AlbertTokenizer(SAMPLE_VOCAB)
        tokenizer.save_pretrained(self.tmpdirname)

41
    def get_input_output_texts(self, tokenizer):
42
43
        input_text = "this is a test"
        output_text = "this is a test"
Lysandre's avatar
Lysandre committed
44
45
        return input_text, output_text

46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
    def test_rust_and_python_full_tokenizers(self):
        if not self.test_rust_tokenizer:
            return

        tokenizer = self.get_tokenizer()
        rust_tokenizer = self.get_rust_tokenizer()

        sequence = "I was born in 92000, and this is falsé."

        tokens = tokenizer.tokenize(sequence)
        rust_tokens = rust_tokenizer.tokenize(sequence)
        self.assertListEqual(tokens, rust_tokens)

        ids = tokenizer.encode(sequence, add_special_tokens=False)
        rust_ids = rust_tokenizer.encode(sequence, add_special_tokens=False)
        self.assertListEqual(ids, rust_ids)

        rust_tokenizer = self.get_rust_tokenizer()
        ids = tokenizer.encode(sequence)
        rust_ids = rust_tokenizer.encode(sequence)
        self.assertListEqual(ids, rust_ids)

Lysandre's avatar
Lysandre committed
68
69
70
    def test_full_tokenizer(self):
        tokenizer = AlbertTokenizer(SAMPLE_VOCAB, keep_accents=True)

71
72
        tokens = tokenizer.tokenize("This is a test")
        self.assertListEqual(tokens, ["▁this", "▁is", "▁a", "▁test"])
Lysandre's avatar
Lysandre committed
73

74
        self.assertListEqual(tokenizer.convert_tokens_to_ids(tokens), [48, 25, 21, 1289])
Lysandre's avatar
Lysandre committed
75

76
77
78
79
        tokens = tokenizer.tokenize("I was born in 92000, and this is falsé.")
        self.assertListEqual(
            tokens, ["▁i", "▁was", "▁born", "▁in", "▁9", "2000", ",", "▁and", "▁this", "▁is", "▁fal", "s", "é", "."]
        )
Lysandre's avatar
Lysandre committed
80
81
82
83
        ids = tokenizer.convert_tokens_to_ids(tokens)
        self.assertListEqual(ids, [31, 23, 386, 19, 561, 3050, 15, 17, 48, 25, 8256, 18, 1, 9])

        back_tokens = tokenizer.convert_ids_to_tokens(ids)
84
85
86
87
        self.assertListEqual(
            back_tokens,
            ["▁i", "▁was", "▁born", "▁in", "▁9", "2000", ",", "▁and", "▁this", "▁is", "▁fal", "s", "<unk>", "."],
        )
Lysandre's avatar
Lysandre committed
88
89
90
91
92
93
94
95
96
97
98

    def test_sequence_builders(self):
        tokenizer = AlbertTokenizer(SAMPLE_VOCAB)

        text = tokenizer.encode("sequence builders")
        text_2 = tokenizer.encode("multi-sequence build")

        encoded_sentence = tokenizer.build_inputs_with_special_tokens(text)
        encoded_pair = tokenizer.build_inputs_with_special_tokens(text, text_2)

        assert encoded_sentence == [tokenizer.cls_token_id] + text + [tokenizer.sep_token_id]
99
100
101
        assert encoded_pair == [tokenizer.cls_token_id] + text + [tokenizer.sep_token_id] + text_2 + [
            tokenizer.sep_token_id
        ]