|
|
|
@ -13,15 +13,62 @@
|
|
|
|
|
# limitations under the License.
|
|
|
|
|
|
|
|
|
|
import paddle.fluid as fluid
|
|
|
|
|
import unittest
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def test_converter():
|
|
|
|
|
img = fluid.layers.data(name='image', shape=[1, 28, 28])
|
|
|
|
|
label = fluid.layers.data(name='label', shape=[1], dtype='int64')
|
|
|
|
|
feeder = fluid.DataFeeder([img, label], fluid.CPUPlace())
|
|
|
|
|
result = feeder.feed([[[0] * 784, [9]], [[1] * 784, [1]]])
|
|
|
|
|
print(result)
|
|
|
|
|
class TestDataFeeder(unittest.TestCase):
|
|
|
|
|
def test_lod_level_0_converter(self):
|
|
|
|
|
img = fluid.layers.data(name='image', shape=[1, 28, 28])
|
|
|
|
|
label = fluid.layers.data(name='label', shape=[1], dtype='int64')
|
|
|
|
|
feeder = fluid.DataFeeder([img, label], fluid.CPUPlace())
|
|
|
|
|
result = feeder.feed([([0] * 784, [9]), ([1] * 784, [1])])
|
|
|
|
|
print(result)
|
|
|
|
|
|
|
|
|
|
self.assertEqual(result['image'].shape(), [2, 1, 28, 28])
|
|
|
|
|
self.assertEqual(result['label'].shape(), [2, 1])
|
|
|
|
|
self.assertEqual(result['image'].lod(), [])
|
|
|
|
|
self.assertEqual(result['label'].lod(), [])
|
|
|
|
|
|
|
|
|
|
def test_lod_level_1_converter(self):
|
|
|
|
|
# lod_level = 1
|
|
|
|
|
# each sentence has a different number of words
|
|
|
|
|
sentences = fluid.layers.data(
|
|
|
|
|
name='sentences', shape=[1], dtype='int64', lod_level=1)
|
|
|
|
|
label = fluid.layers.data(name='label', shape=[1], dtype='int64')
|
|
|
|
|
feeder = fluid.DataFeeder([sentences, label], fluid.CPUPlace())
|
|
|
|
|
|
|
|
|
|
# lod = [[0, 3, 5, 9]]
|
|
|
|
|
# data = [[1, 2, 3], [4, 5], [6, 7, 8, 9]]
|
|
|
|
|
# label = [1] * len(data)
|
|
|
|
|
result = feeder.feed(
|
|
|
|
|
[([1, 2, 3], [1]), ([4, 5], [1]), ([6, 7, 8, 9], [1])])
|
|
|
|
|
print(result)
|
|
|
|
|
|
|
|
|
|
self.assertEqual(result['sentences'].shape(), [9, 1])
|
|
|
|
|
self.assertEqual(result['label'].shape(), [3, 1])
|
|
|
|
|
self.assertEqual(result['sentences'].lod(), [[0, 3, 5, 9]])
|
|
|
|
|
self.assertEqual(result['label'].lod(), [])
|
|
|
|
|
|
|
|
|
|
def test_lod_level_2_converter(self):
|
|
|
|
|
# lod_level = 2
|
|
|
|
|
# paragraphs -> sentences -> words
|
|
|
|
|
paragraphs = fluid.layers.data(
|
|
|
|
|
name='paragraphs', shape=[1], dtype='int64', lod_level=2)
|
|
|
|
|
label = fluid.layers.data(name='label', shape=[1], dtype='int64')
|
|
|
|
|
feeder = fluid.DataFeeder([paragraphs, label], fluid.CPUPlace())
|
|
|
|
|
|
|
|
|
|
# lod = [[0, 2, 3], [0, 3, 5, 9]]
|
|
|
|
|
# data = [[[1, 2, 3], [4, 5]], [[6, 7, 8, 9]]]
|
|
|
|
|
# label = [1] * len(data)
|
|
|
|
|
result = feeder.feed(
|
|
|
|
|
[([[1, 2, 3], [4, 5]], [1]), ([[6, 7, 8, 9]], [1])])
|
|
|
|
|
print(result)
|
|
|
|
|
|
|
|
|
|
self.assertEqual(result['paragraphs'].shape(), [9, 1])
|
|
|
|
|
self.assertEqual(result['label'].shape(), [2, 1])
|
|
|
|
|
self.assertEqual(result['paragraphs'].lod(), [[0, 2, 3], [0, 3, 5, 9]])
|
|
|
|
|
self.assertEqual(result['label'].lod(), [])
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
|
test_converter()
|
|
|
|
|
unittest.main()
|
|
|
|
|