blob: 83725b528450c992def55b199ce6cfe0bb6ad4e4 [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 Smirnov7f913ae2016-06-19 16:41:15 +01005from example import create_rec_simple, create_rec_packed, create_rec_nested
Ivan Smirnovbb4015d2016-06-19 15:50:31 +01006
7
8def check_eq(arr, data, dtype):
9 np.testing.assert_equal(arr, np.array(data, dtype=dtype))
10
Ivan Smirnov8502f542016-06-19 16:09:44 +010011simple_dtype = np.dtype({'names': ['x', 'y', 'z'],
12 'formats': ['?', 'u4', 'f4'],
13 'offsets': [0, 4, 8]})
14packed_dtype = np.dtype([('x', '?'), ('y', 'u4'), ('z', 'f4')])
Ivan Smirnovbb4015d2016-06-19 15:50:31 +010015
Ivan Smirnov8502f542016-06-19 16:09:44 +010016for func, dtype in [(create_rec_simple, simple_dtype), (create_rec_packed, packed_dtype)]:
Ivan Smirnov7f913ae2016-06-19 16:41:15 +010017 arr = func(0)
18 assert arr.dtype == dtype
19 check_eq(arr, [], simple_dtype)
20 check_eq(arr, [], packed_dtype)
21
Ivan Smirnov8502f542016-06-19 16:09:44 +010022 arr = func(3)
23 assert arr.dtype == dtype
24 check_eq(arr, [(False, 0, 0.0), (True, 1, 1.5), (False, 2, 3.0)], simple_dtype)
25 check_eq(arr, [(False, 0, 0.0), (True, 1, 1.5), (False, 2, 3.0)], packed_dtype)
Ivan Smirnov2e1565e2016-06-19 16:05:23 +010026
Ivan Smirnov7f913ae2016-06-19 16:41:15 +010027
28nested_dtype = np.dtype([('a', simple_dtype), ('b', packed_dtype)])
29
30arr = create_rec_nested(0)
31assert arr.dtype == nested_dtype
32check_eq(arr, [], nested_dtype)
33
34arr = create_rec_nested(3)
35assert arr.dtype == nested_dtype
36check_eq(arr, [((False, 0, 0.0), (True, 1, 1.5)),
37 ((True, 1, 1.5), (False, 2, 3.0)),
38 ((False, 2, 3.0), (True, 3, 4.5))], nested_dtype)