blob: 7dd60e346312b2372d4239e150a8a7c99cabfc97 [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 (
Ivan Smirnov669e1422016-06-21 21:05:29 +01006 create_rec_simple, create_rec_packed, create_rec_nested, print_format_descriptors,
7 print_rec_simple, print_rec_packed, print_rec_nested
Ivan Smirnovbdc99022016-06-19 16:54:07 +01008)
Ivan Smirnovbb4015d2016-06-19 15:50:31 +01009
10
11def check_eq(arr, data, dtype):
12 np.testing.assert_equal(arr, np.array(data, dtype=dtype))
13
Ivan Smirnovbdc99022016-06-19 16:54:07 +010014print_format_descriptors()
15
Ivan Smirnov8502f542016-06-19 16:09:44 +010016simple_dtype = np.dtype({'names': ['x', 'y', 'z'],
17 'formats': ['?', 'u4', 'f4'],
18 'offsets': [0, 4, 8]})
19packed_dtype = np.dtype([('x', '?'), ('y', 'u4'), ('z', 'f4')])
Ivan Smirnovbb4015d2016-06-19 15:50:31 +010020
Ivan Smirnov8502f542016-06-19 16:09:44 +010021for func, dtype in [(create_rec_simple, simple_dtype), (create_rec_packed, packed_dtype)]:
Ivan Smirnov7f913ae2016-06-19 16:41:15 +010022 arr = func(0)
23 assert arr.dtype == dtype
24 check_eq(arr, [], simple_dtype)
25 check_eq(arr, [], packed_dtype)
26
Ivan Smirnov8502f542016-06-19 16:09:44 +010027 arr = func(3)
28 assert arr.dtype == dtype
29 check_eq(arr, [(False, 0, 0.0), (True, 1, 1.5), (False, 2, 3.0)], simple_dtype)
30 check_eq(arr, [(False, 0, 0.0), (True, 1, 1.5), (False, 2, 3.0)], packed_dtype)
Ivan Smirnov2e1565e2016-06-19 16:05:23 +010031
Ivan Smirnov2a7acb62016-06-22 00:33:56 +010032 if dtype == simple_dtype:
33 print_rec_simple(arr)
34 else:
35 print_rec_packed(arr)
Ivan Smirnov7f913ae2016-06-19 16:41:15 +010036
37nested_dtype = np.dtype([('a', simple_dtype), ('b', packed_dtype)])
38
39arr = create_rec_nested(0)
40assert arr.dtype == nested_dtype
41check_eq(arr, [], nested_dtype)
42
43arr = create_rec_nested(3)
44assert arr.dtype == nested_dtype
45check_eq(arr, [((False, 0, 0.0), (True, 1, 1.5)),
46 ((True, 1, 1.5), (False, 2, 3.0)),
47 ((False, 2, 3.0), (True, 3, 4.5))], nested_dtype)
Ivan Smirnov2a7acb62016-06-22 00:33:56 +010048print_rec_nested(arr)