blob: 83a914c248c3694993b6e07b5dd78637b8e0f84f [file] [log] [blame]
Ivan Smirnovbb4015d2016-06-19 15:50:31 +01001#!/usr/bin/env python
2from __future__ import print_function
3
4import numpy as np
Ivan Smirnovbdc99022016-06-19 16:54:07 +01005from example import (
6 create_rec_simple, create_rec_packed, create_rec_nested, print_format_descriptors
7)
Ivan Smirnovbb4015d2016-06-19 15:50:31 +01008
9
10def check_eq(arr, data, dtype):
11 np.testing.assert_equal(arr, np.array(data, dtype=dtype))
12
Ivan Smirnovbdc99022016-06-19 16:54:07 +010013print_format_descriptors()
14
Ivan Smirnov8502f542016-06-19 16:09:44 +010015simple_dtype = np.dtype({'names': ['x', 'y', 'z'],
16 'formats': ['?', 'u4', 'f4'],
17 'offsets': [0, 4, 8]})
18packed_dtype = np.dtype([('x', '?'), ('y', 'u4'), ('z', 'f4')])
Ivan Smirnovbb4015d2016-06-19 15:50:31 +010019
Ivan Smirnov8502f542016-06-19 16:09:44 +010020for func, dtype in [(create_rec_simple, simple_dtype), (create_rec_packed, packed_dtype)]:
Ivan Smirnov7f913ae2016-06-19 16:41:15 +010021 arr = func(0)
22 assert arr.dtype == dtype
23 check_eq(arr, [], simple_dtype)
24 check_eq(arr, [], packed_dtype)
25
Ivan Smirnov8502f542016-06-19 16:09:44 +010026 arr = func(3)
27 assert arr.dtype == dtype
28 check_eq(arr, [(False, 0, 0.0), (True, 1, 1.5), (False, 2, 3.0)], simple_dtype)
29 check_eq(arr, [(False, 0, 0.0), (True, 1, 1.5), (False, 2, 3.0)], packed_dtype)
Ivan Smirnov2e1565e2016-06-19 16:05:23 +010030
Ivan Smirnov7f913ae2016-06-19 16:41:15 +010031
32nested_dtype = np.dtype([('a', simple_dtype), ('b', packed_dtype)])
33
34arr = create_rec_nested(0)
35assert arr.dtype == nested_dtype
36check_eq(arr, [], nested_dtype)
37
38arr = create_rec_nested(3)
39assert arr.dtype == nested_dtype
40check_eq(arr, [((False, 0, 0.0), (True, 1, 1.5)),
41 ((True, 1, 1.5), (False, 2, 3.0)),
42 ((False, 2, 3.0), (True, 3, 4.5))], nested_dtype)