Ivan Smirnov | bb4015d | 2016-06-19 15:50:31 +0100 | [diff] [blame] | 1 | #!/usr/bin/env python |
| 2 | from __future__ import print_function |
| 3 | |
Ivan Smirnov | d0bafd9 | 2016-06-26 16:35:28 +0100 | [diff] [blame] | 4 | import unittest |
Ivan Smirnov | bb4015d | 2016-06-19 15:50:31 +0100 | [diff] [blame] | 5 | import numpy as np |
Ivan Smirnov | bdc9902 | 2016-06-19 16:54:07 +0100 | [diff] [blame] | 6 | from example import ( |
Ivan Smirnov | 669e142 | 2016-06-21 21:05:29 +0100 | [diff] [blame] | 7 | create_rec_simple, create_rec_packed, create_rec_nested, print_format_descriptors, |
Ivan Smirnov | 8fa09cb | 2016-07-06 00:28:12 +0100 | [diff] [blame] | 8 | print_rec_simple, print_rec_packed, print_rec_nested, print_dtypes, get_format_unbound, |
Ivan Smirnov | f9c0def | 2016-07-20 00:19:24 +0100 | [diff] [blame^] | 9 | create_rec_partial, create_rec_partial_nested, create_string_array, print_string_array |
Ivan Smirnov | bdc9902 | 2016-06-19 16:54:07 +0100 | [diff] [blame] | 10 | ) |
Ivan Smirnov | bb4015d | 2016-06-19 15:50:31 +0100 | [diff] [blame] | 11 | |
| 12 | |
| 13 | def check_eq(arr, data, dtype): |
| 14 | np.testing.assert_equal(arr, np.array(data, dtype=dtype)) |
| 15 | |
Ivan Smirnov | d0bafd9 | 2016-06-26 16:35:28 +0100 | [diff] [blame] | 16 | unittest.TestCase().assertRaisesRegex( |
| 17 | RuntimeError, 'unsupported buffer format', get_format_unbound) |
| 18 | |
Ivan Smirnov | bdc9902 | 2016-06-19 16:54:07 +0100 | [diff] [blame] | 19 | print_format_descriptors() |
Ivan Smirnov | 4f16421 | 2016-06-22 01:07:20 +0100 | [diff] [blame] | 20 | print_dtypes() |
Ivan Smirnov | bdc9902 | 2016-06-19 16:54:07 +0100 | [diff] [blame] | 21 | |
Ivan Smirnov | 8502f54 | 2016-06-19 16:09:44 +0100 | [diff] [blame] | 22 | simple_dtype = np.dtype({'names': ['x', 'y', 'z'], |
| 23 | 'formats': ['?', 'u4', 'f4'], |
| 24 | 'offsets': [0, 4, 8]}) |
| 25 | packed_dtype = np.dtype([('x', '?'), ('y', 'u4'), ('z', 'f4')]) |
Ivan Smirnov | bb4015d | 2016-06-19 15:50:31 +0100 | [diff] [blame] | 26 | |
Ivan Smirnov | 8fa09cb | 2016-07-06 00:28:12 +0100 | [diff] [blame] | 27 | elements = [(False, 0, 0.0), (True, 1, 1.5), (False, 2, 3.0)] |
| 28 | |
Ivan Smirnov | 8502f54 | 2016-06-19 16:09:44 +0100 | [diff] [blame] | 29 | for func, dtype in [(create_rec_simple, simple_dtype), (create_rec_packed, packed_dtype)]: |
Ivan Smirnov | 7f913ae | 2016-06-19 16:41:15 +0100 | [diff] [blame] | 30 | arr = func(0) |
| 31 | assert arr.dtype == dtype |
| 32 | check_eq(arr, [], simple_dtype) |
| 33 | check_eq(arr, [], packed_dtype) |
| 34 | |
Ivan Smirnov | 8502f54 | 2016-06-19 16:09:44 +0100 | [diff] [blame] | 35 | arr = func(3) |
| 36 | assert arr.dtype == dtype |
Ivan Smirnov | 8fa09cb | 2016-07-06 00:28:12 +0100 | [diff] [blame] | 37 | check_eq(arr, elements, simple_dtype) |
| 38 | check_eq(arr, elements, packed_dtype) |
Ivan Smirnov | 2e1565e | 2016-06-19 16:05:23 +0100 | [diff] [blame] | 39 | |
Ivan Smirnov | 2a7acb6 | 2016-06-22 00:33:56 +0100 | [diff] [blame] | 40 | if dtype == simple_dtype: |
| 41 | print_rec_simple(arr) |
| 42 | else: |
| 43 | print_rec_packed(arr) |
Ivan Smirnov | 7f913ae | 2016-06-19 16:41:15 +0100 | [diff] [blame] | 44 | |
Ivan Smirnov | 8fa09cb | 2016-07-06 00:28:12 +0100 | [diff] [blame] | 45 | |
| 46 | arr = create_rec_partial(3) |
| 47 | print(arr.dtype) |
| 48 | partial_dtype = arr.dtype |
| 49 | assert '' not in arr.dtype.fields |
| 50 | assert partial_dtype.itemsize > simple_dtype.itemsize |
| 51 | check_eq(arr, elements, simple_dtype) |
| 52 | check_eq(arr, elements, packed_dtype) |
| 53 | |
| 54 | arr = create_rec_partial_nested(3) |
| 55 | print(arr.dtype) |
| 56 | assert '' not in arr.dtype.fields |
| 57 | assert '' not in arr.dtype.fields['a'][0].fields |
| 58 | assert arr.dtype.itemsize > partial_dtype.itemsize |
| 59 | np.testing.assert_equal(arr['a'], create_rec_partial(3)) |
| 60 | |
Ivan Smirnov | 7f913ae | 2016-06-19 16:41:15 +0100 | [diff] [blame] | 61 | nested_dtype = np.dtype([('a', simple_dtype), ('b', packed_dtype)]) |
| 62 | |
| 63 | arr = create_rec_nested(0) |
| 64 | assert arr.dtype == nested_dtype |
| 65 | check_eq(arr, [], nested_dtype) |
| 66 | |
| 67 | arr = create_rec_nested(3) |
| 68 | assert arr.dtype == nested_dtype |
| 69 | check_eq(arr, [((False, 0, 0.0), (True, 1, 1.5)), |
| 70 | ((True, 1, 1.5), (False, 2, 3.0)), |
| 71 | ((False, 2, 3.0), (True, 3, 4.5))], nested_dtype) |
Ivan Smirnov | 2a7acb6 | 2016-06-22 00:33:56 +0100 | [diff] [blame] | 72 | print_rec_nested(arr) |
Ivan Smirnov | 41c3399 | 2016-07-18 19:58:20 +0100 | [diff] [blame] | 73 | |
| 74 | assert create_rec_nested.__doc__.strip().endswith('numpy.ndarray[dtype=NestedStruct]') |
Ivan Smirnov | f9c0def | 2016-07-20 00:19:24 +0100 | [diff] [blame^] | 75 | |
| 76 | arr = create_string_array(True) |
| 77 | print(arr.dtype) |
| 78 | print_string_array(arr) |
| 79 | dtype = arr.dtype |
| 80 | assert arr['a'].tolist() == [b'', b'a', b'ab', b'abc'] |
| 81 | assert arr['b'].tolist() == [b'', b'a', b'ab', b'abc'] |
| 82 | arr = create_string_array(False) |
| 83 | assert dtype == arr.dtype |