Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
P
pybind11
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
open
pybind11
Commits
8fa09cb8
Commit
8fa09cb8
authored
Jul 06, 2016
by
Ivan Smirnov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Strip padding fields in dtypes, update the tests
parent
13022f1b
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
65 additions
and
9 deletions
+65
-9
example/example20.cpp
+33
-3
example/example20.py
+22
-3
example/example20.ref
+10
-3
include/pybind11/numpy.h
+0
-0
No files found.
example/example20.cpp
View file @
8fa09cb8
...
@@ -44,6 +44,19 @@ std::ostream& operator<<(std::ostream& os, const NestedStruct& v) {
...
@@ -44,6 +44,19 @@ std::ostream& operator<<(std::ostream& os, const NestedStruct& v) {
return
os
<<
"n:a="
<<
v
.
a
<<
";b="
<<
v
.
b
;
return
os
<<
"n:a="
<<
v
.
a
<<
";b="
<<
v
.
b
;
}
}
struct
PartialStruct
{
bool
x
;
uint32_t
y
;
float
z
;
long
dummy2
;
};
struct
PartialNestedStruct
{
long
dummy1
;
PartialStruct
a
;
long
dummy2
;
};
struct
UnboundStruct
{
};
struct
UnboundStruct
{
};
template
<
typename
T
>
template
<
typename
T
>
...
@@ -54,7 +67,7 @@ py::array mkarray_via_buffer(size_t n) {
...
@@ -54,7 +67,7 @@ py::array mkarray_via_buffer(size_t n) {
}
}
template
<
typename
S
>
template
<
typename
S
>
py
::
array_t
<
S
>
create_recarray
(
size_t
n
)
{
py
::
array_t
<
S
,
0
>
create_recarray
(
size_t
n
)
{
auto
arr
=
mkarray_via_buffer
<
S
>
(
n
);
auto
arr
=
mkarray_via_buffer
<
S
>
(
n
);
auto
ptr
=
static_cast
<
S
*>
(
arr
.
request
().
ptr
);
auto
ptr
=
static_cast
<
S
*>
(
arr
.
request
().
ptr
);
for
(
size_t
i
=
0
;
i
<
n
;
i
++
)
{
for
(
size_t
i
=
0
;
i
<
n
;
i
++
)
{
...
@@ -67,7 +80,7 @@ std::string get_format_unbound() {
...
@@ -67,7 +80,7 @@ std::string get_format_unbound() {
return
py
::
format_descriptor
<
UnboundStruct
>::
format
();
return
py
::
format_descriptor
<
UnboundStruct
>::
format
();
}
}
py
::
array_t
<
NestedStruct
>
create_nested
(
size_t
n
)
{
py
::
array_t
<
NestedStruct
,
0
>
create_nested
(
size_t
n
)
{
auto
arr
=
mkarray_via_buffer
<
NestedStruct
>
(
n
);
auto
arr
=
mkarray_via_buffer
<
NestedStruct
>
(
n
);
auto
ptr
=
static_cast
<
NestedStruct
*>
(
arr
.
request
().
ptr
);
auto
ptr
=
static_cast
<
NestedStruct
*>
(
arr
.
request
().
ptr
);
for
(
size_t
i
=
0
;
i
<
n
;
i
++
)
{
for
(
size_t
i
=
0
;
i
<
n
;
i
++
)
{
...
@@ -77,8 +90,17 @@ py::array_t<NestedStruct> create_nested(size_t n) {
...
@@ -77,8 +90,17 @@ py::array_t<NestedStruct> create_nested(size_t n) {
return
arr
;
return
arr
;
}
}
py
::
array_t
<
PartialNestedStruct
,
0
>
create_partial_nested
(
size_t
n
)
{
auto
arr
=
mkarray_via_buffer
<
PartialNestedStruct
>
(
n
);
auto
ptr
=
static_cast
<
PartialNestedStruct
*>
(
arr
.
request
().
ptr
);
for
(
size_t
i
=
0
;
i
<
n
;
i
++
)
{
ptr
[
i
].
a
.
x
=
i
%
2
;
ptr
[
i
].
a
.
y
=
(
uint32_t
)
i
;
ptr
[
i
].
a
.
z
=
(
float
)
i
*
1.5
f
;
}
return
arr
;
}
template
<
typename
S
>
template
<
typename
S
>
void
print_recarray
(
py
::
array_t
<
S
>
arr
)
{
void
print_recarray
(
py
::
array_t
<
S
,
0
>
arr
)
{
auto
buf
=
arr
.
request
();
auto
buf
=
arr
.
request
();
auto
ptr
=
static_cast
<
S
*>
(
buf
.
ptr
);
auto
ptr
=
static_cast
<
S
*>
(
buf
.
ptr
);
for
(
size_t
i
=
0
;
i
<
buf
.
size
;
i
++
)
for
(
size_t
i
=
0
;
i
<
buf
.
size
;
i
++
)
...
@@ -89,6 +111,8 @@ void print_format_descriptors() {
...
@@ -89,6 +111,8 @@ void print_format_descriptors() {
std
::
cout
<<
py
::
format_descriptor
<
SimpleStruct
>::
format
()
<<
std
::
endl
;
std
::
cout
<<
py
::
format_descriptor
<
SimpleStruct
>::
format
()
<<
std
::
endl
;
std
::
cout
<<
py
::
format_descriptor
<
PackedStruct
>::
format
()
<<
std
::
endl
;
std
::
cout
<<
py
::
format_descriptor
<
PackedStruct
>::
format
()
<<
std
::
endl
;
std
::
cout
<<
py
::
format_descriptor
<
NestedStruct
>::
format
()
<<
std
::
endl
;
std
::
cout
<<
py
::
format_descriptor
<
NestedStruct
>::
format
()
<<
std
::
endl
;
std
::
cout
<<
py
::
format_descriptor
<
PartialStruct
>::
format
()
<<
std
::
endl
;
std
::
cout
<<
py
::
format_descriptor
<
PartialNestedStruct
>::
format
()
<<
std
::
endl
;
}
}
void
print_dtypes
()
{
void
print_dtypes
()
{
...
@@ -98,16 +122,22 @@ void print_dtypes() {
...
@@ -98,16 +122,22 @@ void print_dtypes() {
std
::
cout
<<
to_str
(
py
::
dtype_of
<
SimpleStruct
>
())
<<
std
::
endl
;
std
::
cout
<<
to_str
(
py
::
dtype_of
<
SimpleStruct
>
())
<<
std
::
endl
;
std
::
cout
<<
to_str
(
py
::
dtype_of
<
PackedStruct
>
())
<<
std
::
endl
;
std
::
cout
<<
to_str
(
py
::
dtype_of
<
PackedStruct
>
())
<<
std
::
endl
;
std
::
cout
<<
to_str
(
py
::
dtype_of
<
NestedStruct
>
())
<<
std
::
endl
;
std
::
cout
<<
to_str
(
py
::
dtype_of
<
NestedStruct
>
())
<<
std
::
endl
;
std
::
cout
<<
to_str
(
py
::
dtype_of
<
PartialStruct
>
())
<<
std
::
endl
;
std
::
cout
<<
to_str
(
py
::
dtype_of
<
PartialNestedStruct
>
())
<<
std
::
endl
;
}
}
void
init_ex20
(
py
::
module
&
m
)
{
void
init_ex20
(
py
::
module
&
m
)
{
PYBIND11_NUMPY_DTYPE
(
SimpleStruct
,
x
,
y
,
z
);
PYBIND11_NUMPY_DTYPE
(
SimpleStruct
,
x
,
y
,
z
);
PYBIND11_NUMPY_DTYPE
(
PackedStruct
,
x
,
y
,
z
);
PYBIND11_NUMPY_DTYPE
(
PackedStruct
,
x
,
y
,
z
);
PYBIND11_NUMPY_DTYPE
(
NestedStruct
,
a
,
b
);
PYBIND11_NUMPY_DTYPE
(
NestedStruct
,
a
,
b
);
PYBIND11_NUMPY_DTYPE
(
PartialStruct
,
x
,
y
,
z
);
PYBIND11_NUMPY_DTYPE
(
PartialNestedStruct
,
a
);
m
.
def
(
"create_rec_simple"
,
&
create_recarray
<
SimpleStruct
>
);
m
.
def
(
"create_rec_simple"
,
&
create_recarray
<
SimpleStruct
>
);
m
.
def
(
"create_rec_packed"
,
&
create_recarray
<
PackedStruct
>
);
m
.
def
(
"create_rec_packed"
,
&
create_recarray
<
PackedStruct
>
);
m
.
def
(
"create_rec_nested"
,
&
create_nested
);
m
.
def
(
"create_rec_nested"
,
&
create_nested
);
m
.
def
(
"create_rec_partial"
,
&
create_recarray
<
PartialStruct
>
);
m
.
def
(
"create_rec_partial_nested"
,
&
create_partial_nested
);
m
.
def
(
"print_format_descriptors"
,
&
print_format_descriptors
);
m
.
def
(
"print_format_descriptors"
,
&
print_format_descriptors
);
m
.
def
(
"print_rec_simple"
,
&
print_recarray
<
SimpleStruct
>
);
m
.
def
(
"print_rec_simple"
,
&
print_recarray
<
SimpleStruct
>
);
m
.
def
(
"print_rec_packed"
,
&
print_recarray
<
PackedStruct
>
);
m
.
def
(
"print_rec_packed"
,
&
print_recarray
<
PackedStruct
>
);
...
...
example/example20.py
View file @
8fa09cb8
...
@@ -5,7 +5,8 @@ import unittest
...
@@ -5,7 +5,8 @@ import unittest
import
numpy
as
np
import
numpy
as
np
from
example
import
(
from
example
import
(
create_rec_simple
,
create_rec_packed
,
create_rec_nested
,
print_format_descriptors
,
create_rec_simple
,
create_rec_packed
,
create_rec_nested
,
print_format_descriptors
,
print_rec_simple
,
print_rec_packed
,
print_rec_nested
,
print_dtypes
,
get_format_unbound
print_rec_simple
,
print_rec_packed
,
print_rec_nested
,
print_dtypes
,
get_format_unbound
,
create_rec_partial
,
create_rec_partial_nested
)
)
...
@@ -23,6 +24,8 @@ simple_dtype = np.dtype({'names': ['x', 'y', 'z'],
...
@@ -23,6 +24,8 @@ simple_dtype = np.dtype({'names': ['x', 'y', 'z'],
'offsets'
:
[
0
,
4
,
8
]})
'offsets'
:
[
0
,
4
,
8
]})
packed_dtype
=
np
.
dtype
([(
'x'
,
'?'
),
(
'y'
,
'u4'
),
(
'z'
,
'f4'
)])
packed_dtype
=
np
.
dtype
([(
'x'
,
'?'
),
(
'y'
,
'u4'
),
(
'z'
,
'f4'
)])
elements
=
[(
False
,
0
,
0.0
),
(
True
,
1
,
1.5
),
(
False
,
2
,
3.0
)]
for
func
,
dtype
in
[(
create_rec_simple
,
simple_dtype
),
(
create_rec_packed
,
packed_dtype
)]:
for
func
,
dtype
in
[(
create_rec_simple
,
simple_dtype
),
(
create_rec_packed
,
packed_dtype
)]:
arr
=
func
(
0
)
arr
=
func
(
0
)
assert
arr
.
dtype
==
dtype
assert
arr
.
dtype
==
dtype
...
@@ -31,14 +34,30 @@ for func, dtype in [(create_rec_simple, simple_dtype), (create_rec_packed, packe
...
@@ -31,14 +34,30 @@ for func, dtype in [(create_rec_simple, simple_dtype), (create_rec_packed, packe
arr
=
func
(
3
)
arr
=
func
(
3
)
assert
arr
.
dtype
==
dtype
assert
arr
.
dtype
==
dtype
check_eq
(
arr
,
[(
False
,
0
,
0.0
),
(
True
,
1
,
1.5
),
(
False
,
2
,
3.0
)]
,
simple_dtype
)
check_eq
(
arr
,
elements
,
simple_dtype
)
check_eq
(
arr
,
[(
False
,
0
,
0.0
),
(
True
,
1
,
1.5
),
(
False
,
2
,
3.0
)]
,
packed_dtype
)
check_eq
(
arr
,
elements
,
packed_dtype
)
if
dtype
==
simple_dtype
:
if
dtype
==
simple_dtype
:
print_rec_simple
(
arr
)
print_rec_simple
(
arr
)
else
:
else
:
print_rec_packed
(
arr
)
print_rec_packed
(
arr
)
arr
=
create_rec_partial
(
3
)
print
(
arr
.
dtype
)
partial_dtype
=
arr
.
dtype
assert
''
not
in
arr
.
dtype
.
fields
assert
partial_dtype
.
itemsize
>
simple_dtype
.
itemsize
check_eq
(
arr
,
elements
,
simple_dtype
)
check_eq
(
arr
,
elements
,
packed_dtype
)
arr
=
create_rec_partial_nested
(
3
)
print
(
arr
.
dtype
)
assert
''
not
in
arr
.
dtype
.
fields
assert
''
not
in
arr
.
dtype
.
fields
[
'a'
][
0
]
.
fields
assert
arr
.
dtype
.
itemsize
>
partial_dtype
.
itemsize
np
.
testing
.
assert_equal
(
arr
[
'a'
],
create_rec_partial
(
3
))
nested_dtype
=
np
.
dtype
([(
'a'
,
simple_dtype
),
(
'b'
,
packed_dtype
)])
nested_dtype
=
np
.
dtype
([(
'a'
,
simple_dtype
),
(
'b'
,
packed_dtype
)])
arr
=
create_rec_nested
(
0
)
arr
=
create_rec_nested
(
0
)
...
...
example/example20.ref
View file @
8fa09cb8
T{?:x:xxxI:y:f:z:}
T{=?:x:3x=I:y:=f:z:}
T{?:x:=I:y:f:z:}
T{=?:x:=I:y:=f:z:}
T{T{?:x:xxxI:y:f:z:}:a:T{?:x:=I:y:f:z:}:b:}
T{=T{=?:x:3x=I:y:=f:z:}:a:=T{=?:x:=I:y:=f:z:}:b:}
T{=?:x:3x=I:y:=f:z:12x}
T{8x=T{=?:x:3x=I:y:=f:z:12x}:a:8x}
{'names':['x','y','z'], 'formats':['?','<u4','<f4'], 'offsets':[0,4,8], 'itemsize':12}
{'names':['x','y','z'], 'formats':['?','<u4','<f4'], 'offsets':[0,4,8], 'itemsize':12}
[('x', '?'), ('y', '<u4'), ('z', '<f4')]
[('x', '?'), ('y', '<u4'), ('z', '<f4')]
[('a', {'names':['x','y','z'], 'formats':['?','<u4','<f4'], 'offsets':[0,4,8], 'itemsize':12}), ('b', [('x', '?'), ('y', '<u4'), ('z', '<f4')])]
[('a', {'names':['x','y','z'], 'formats':['?','<u4','<f4'], 'offsets':[0,4,8], 'itemsize':12}), ('b', [('x', '?'), ('y', '<u4'), ('z', '<f4')])]
{'names':['x','y','z'], 'formats':['?','<u4','<f4'], 'offsets':[0,4,8], 'itemsize':24}
{'names':['a'], 'formats':[{'names':['x','y','z'], 'formats':['?','<u4','<f4'], 'offsets':[0,4,8], 'itemsize':24}], 'offsets':[8], 'itemsize':40}
s:0,0,0
s:0,0,0
s:1,1,1.5
s:1,1,1.5
s:0,2,3
s:0,2,3
p:0,0,0
p:0,0,0
p:1,1,1.5
p:1,1,1.5
p:0,2,3
p:0,2,3
{'names':['x','y','z'], 'formats':['?','<u4','<f4'], 'offsets':[0,4,8], 'itemsize':24}
{'names':['a'], 'formats':[{'names':['x','y','z'], 'formats':['?','<u4','<f4'], 'offsets':[0,4,8], 'itemsize':24}], 'offsets':[8], 'itemsize':40}
n:a=s:0,0,0;b=p:1,1,1.5
n:a=s:0,0,0;b=p:1,1,1.5
n:a=s:1,1,1.5;b=p:0,2,3
n:a=s:1,1,1.5;b=p:0,2,3
n:a=s:0,2,3;b=p:1,3,4.5
n:a=s:0,2,3;b=p:1,3,4.5
\ No newline at end of file
include/pybind11/numpy.h
View file @
8fa09cb8
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment