wmt16_test.py 2.4 KB
Newer Older
Y
ying 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14
# Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserved
#
# 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.

15 16
from __future__ import print_function

17
import paddle.dataset.wmt16
Y
ying 已提交
18 19
import unittest

20 21
__all__ = []

Y
ying 已提交
22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40

class TestWMT16(unittest.TestCase):
    def checkout_one_sample(self, sample):
        # train data has 3 field: source language word indices,
        # target language word indices, and target next word indices.
        self.assertEqual(len(sample), 3)

        # test start mark and end mark in source word indices.
        self.assertEqual(sample[0][0], 0)
        self.assertEqual(sample[0][-1], 1)

        # test start mask in target word indices
        self.assertEqual(sample[1][0], 0)

        # test en mask in target next word indices
        self.assertEqual(sample[2][-1], 1)

    def test_train(self):
        for idx, sample in enumerate(
41
                paddle.dataset.wmt16.train(
Y
ying 已提交
42 43 44 45 46 47
                    src_dict_size=100000, trg_dict_size=100000)()):
            if idx >= 10: break
            self.checkout_one_sample(sample)

    def test_test(self):
        for idx, sample in enumerate(
48
                paddle.dataset.wmt16.test(
Y
ying 已提交
49 50 51 52 53 54
                    src_dict_size=1000, trg_dict_size=1000)()):
            if idx >= 10: break
            self.checkout_one_sample(sample)

    def test_val(self):
        for idx, sample in enumerate(
55
                paddle.dataset.wmt16.validation(
Y
ying 已提交
56 57 58 59 60 61
                    src_dict_size=1000, trg_dict_size=1000)()):
            if idx >= 10: break
            self.checkout_one_sample(sample)

    def test_get_dict(self):
        dict_size = 1000
62
        word_dict = paddle.dataset.wmt16.get_dict("en", dict_size, True)
Y
ying 已提交
63 64 65 66 67 68 69 70
        self.assertEqual(len(word_dict), dict_size)
        self.assertEqual(word_dict[0], "<s>")
        self.assertEqual(word_dict[1], "<e>")
        self.assertEqual(word_dict[2], "<unk>")


if __name__ == "__main__":
    unittest.main()