test_sequence_enumerate_op.py 4.2 KB
Newer Older
C
chenweihang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14
#   Copyright (c) 2018 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
import sys
C
chenweihang 已提交
16
import unittest
17

C
chenweihang 已提交
18
import numpy as np
19

T
tianshuo78520a 已提交
20
sys.path.append("../../python/paddle/fluid/tests/unittests")
W
wanghuancoder 已提交
21
from eager_op_test import OpTest
C
chenweihang 已提交
22 23


24 25 26 27
def sequence_enumerate(input_seq, in_lod, win_size, pad_value):
    lod0 = [0]
    for i in range(0, len(in_lod[0])):
        lod0.append(lod0[i] + in_lod[0][i])
C
chenweihang 已提交
28
    out_seq = []
29 30 31 32 33
    for i in range(0, len(lod0) - 1):
        for idx in range(lod0[i], lod0[i + 1]):
            single_seq = []
            for word_idx in range(win_size):
                word_pos = idx + word_idx
34 35 36
                dat = (
                    input_seq[word_pos] if word_pos < lod0[i + 1] else pad_value
                )
37 38
                single_seq.append(dat)
            out_seq.append(single_seq)
C
chenweihang 已提交
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
    return out_seq


class TestSequenceEnumerateOp(OpTest):
    def setUp(self):
        self.op_type = "sequence_enumerate"
        self.init_test_case()
        self.inputs = {'X': (self.in_seq, self.lod)}
        self.attrs = {'win_size': self.win_size, 'pad_value': self.pad_value}
        self.outputs = {'Out': (self.out_seq, self.lod)}

    def test_check_output(self):
        self.check_output()

    def init_test_case(self):
        self.in_seq = np.random.randint(0, 10, (30, 1)).astype("int32")
        self.lod = [[9, 4, 11, 6]]
        self.win_size = 2
        self.pad_value = 0
58 59 60
        out_seq = sequence_enumerate(
            self.in_seq, self.lod, self.win_size, self.pad_value
        )
C
chenweihang 已提交
61 62 63 64 65 66 67 68 69
        self.out_seq = np.array(out_seq).astype("int32")


class TesSequenceEnumerateOpInt64(TestSequenceEnumerateOp):
    def init_test_case(self):
        self.in_seq = np.random.randint(0, 10, (30, 1)).astype("int64")
        self.lod = [[9, 4, 11, 6]]
        self.win_size = 2
        self.pad_value = 0
70 71 72
        out_seq = sequence_enumerate(
            self.in_seq, self.lod, self.win_size, self.pad_value
        )
C
chenweihang 已提交
73 74 75
        self.out_seq = np.array(out_seq).astype("int64")


C
chenweihang 已提交
76 77 78 79 80 81
class TestSequenceEnumerateOpLargeWinSize(TestSequenceEnumerateOp):
    def init_test_case(self):
        self.in_seq = np.random.randint(0, 10, (30, 1)).astype("int32")
        self.lod = [[9, 4, 11, 6]]
        self.win_size = 5
        self.pad_value = 0
82 83 84
        out_seq = sequence_enumerate(
            self.in_seq, self.lod, self.win_size, self.pad_value
        )
C
chenweihang 已提交
85 86 87
        self.out_seq = np.array(out_seq).astype("int32")


C
chenweihang 已提交
88 89 90 91 92 93
class TestSequenceEnumerateOpMaxWinSize(TestSequenceEnumerateOp):
    def init_test_case(self):
        self.in_seq = np.random.randint(0, 10, (30, 1)).astype("int32")
        self.lod = [[9, 4, 11, 6]]
        self.win_size = 30
        self.pad_value = 0
94 95 96
        out_seq = sequence_enumerate(
            self.in_seq, self.lod, self.win_size, self.pad_value
        )
C
chenweihang 已提交
97 98 99
        self.out_seq = np.array(out_seq).astype("int32")


C
chenweihang 已提交
100 101 102 103 104 105
class TestSequenceEnumerateOpLargePadValue(TestSequenceEnumerateOp):
    def init_test_case(self):
        self.in_seq = np.random.randint(0, 10, (30, 1)).astype("int32")
        self.lod = [[9, 4, 11, 6]]
        self.win_size = 5
        self.pad_value = 5
106 107 108
        out_seq = sequence_enumerate(
            self.in_seq, self.lod, self.win_size, self.pad_value
        )
C
chenweihang 已提交
109 110 111
        self.out_seq = np.array(out_seq).astype("int32")


112 113 114 115 116 117
class TestSequenceEnumerateOpLargePadValueSeqLen0(TestSequenceEnumerateOp):
    def init_test_case(self):
        self.in_seq = np.random.randint(0, 10, (30, 1)).astype("int32")
        self.lod = [[0, 14, 0, 16, 0]]
        self.win_size = 5
        self.pad_value = 5
118 119 120
        out_seq = sequence_enumerate(
            self.in_seq, self.lod, self.win_size, self.pad_value
        )
121 122 123
        self.out_seq = np.array(out_seq).astype("int32")


C
chenweihang 已提交
124 125
if __name__ == "__main__":
    unittest.main()