|
Packit |
534379 |
import struct
|
|
Packit |
534379 |
import pytest
|
|
Packit |
534379 |
from pybind11_tests import buffers as m
|
|
Packit |
534379 |
from pybind11_tests import ConstructorStats
|
|
Packit |
534379 |
|
|
Packit |
534379 |
pytestmark = pytest.requires_numpy
|
|
Packit |
534379 |
|
|
Packit |
534379 |
with pytest.suppress(ImportError):
|
|
Packit |
534379 |
import numpy as np
|
|
Packit |
534379 |
|
|
Packit |
534379 |
|
|
Packit |
534379 |
def test_from_python():
|
|
Packit |
534379 |
with pytest.raises(RuntimeError) as excinfo:
|
|
Packit |
534379 |
m.Matrix(np.array([1, 2, 3])) # trying to assign a 1D array
|
|
Packit |
534379 |
assert str(excinfo.value) == "Incompatible buffer format!"
|
|
Packit |
534379 |
|
|
Packit |
534379 |
m3 = np.array([[1, 2, 3], [4, 5, 6]]).astype(np.float32)
|
|
Packit |
534379 |
m4 = m.Matrix(m3)
|
|
Packit |
534379 |
|
|
Packit |
534379 |
for i in range(m4.rows()):
|
|
Packit |
534379 |
for j in range(m4.cols()):
|
|
Packit |
534379 |
assert m3[i, j] == m4[i, j]
|
|
Packit |
534379 |
|
|
Packit |
534379 |
cstats = ConstructorStats.get(m.Matrix)
|
|
Packit |
534379 |
assert cstats.alive() == 1
|
|
Packit |
534379 |
del m3, m4
|
|
Packit |
534379 |
assert cstats.alive() == 0
|
|
Packit |
534379 |
assert cstats.values() == ["2x3 matrix"]
|
|
Packit |
534379 |
assert cstats.copy_constructions == 0
|
|
Packit |
534379 |
# assert cstats.move_constructions >= 0 # Don't invoke any
|
|
Packit |
534379 |
assert cstats.copy_assignments == 0
|
|
Packit |
534379 |
assert cstats.move_assignments == 0
|
|
Packit |
534379 |
|
|
Packit |
534379 |
|
|
Packit |
534379 |
# PyPy: Memory leak in the "np.array(m, copy=False)" call
|
|
Packit |
534379 |
# https://bitbucket.org/pypy/pypy/issues/2444
|
|
Packit |
534379 |
@pytest.unsupported_on_pypy
|
|
Packit |
534379 |
def test_to_python():
|
|
Packit |
534379 |
mat = m.Matrix(5, 4)
|
|
Packit |
534379 |
assert memoryview(mat).shape == (5, 4)
|
|
Packit |
534379 |
|
|
Packit |
534379 |
assert mat[2, 3] == 0
|
|
Packit |
534379 |
mat[2, 3] = 4.0
|
|
Packit |
534379 |
mat[3, 2] = 7.0
|
|
Packit |
534379 |
assert mat[2, 3] == 4
|
|
Packit |
534379 |
assert mat[3, 2] == 7
|
|
Packit |
534379 |
assert struct.unpack_from('f', mat, (3 * 4 + 2) * 4) == (7, )
|
|
Packit |
534379 |
assert struct.unpack_from('f', mat, (2 * 4 + 3) * 4) == (4, )
|
|
Packit |
534379 |
|
|
Packit |
534379 |
mat2 = np.array(mat, copy=False)
|
|
Packit |
534379 |
assert mat2.shape == (5, 4)
|
|
Packit |
534379 |
assert abs(mat2).sum() == 11
|
|
Packit |
534379 |
assert mat2[2, 3] == 4 and mat2[3, 2] == 7
|
|
Packit |
534379 |
mat2[2, 3] = 5
|
|
Packit |
534379 |
assert mat2[2, 3] == 5
|
|
Packit |
534379 |
|
|
Packit |
534379 |
cstats = ConstructorStats.get(m.Matrix)
|
|
Packit |
534379 |
assert cstats.alive() == 1
|
|
Packit |
534379 |
del mat
|
|
Packit |
534379 |
pytest.gc_collect()
|
|
Packit |
534379 |
assert cstats.alive() == 1
|
|
Packit |
534379 |
del mat2 # holds a mat reference
|
|
Packit |
534379 |
pytest.gc_collect()
|
|
Packit |
534379 |
assert cstats.alive() == 0
|
|
Packit |
534379 |
assert cstats.values() == ["5x4 matrix"]
|
|
Packit |
534379 |
assert cstats.copy_constructions == 0
|
|
Packit |
534379 |
# assert cstats.move_constructions >= 0 # Don't invoke any
|
|
Packit |
534379 |
assert cstats.copy_assignments == 0
|
|
Packit |
534379 |
assert cstats.move_assignments == 0
|
|
Packit |
534379 |
|
|
Packit |
534379 |
|
|
Packit |
534379 |
@pytest.unsupported_on_pypy
|
|
Packit |
534379 |
def test_inherited_protocol():
|
|
Packit |
534379 |
"""SquareMatrix is derived from Matrix and inherits the buffer protocol"""
|
|
Packit |
534379 |
|
|
Packit |
534379 |
matrix = m.SquareMatrix(5)
|
|
Packit |
534379 |
assert memoryview(matrix).shape == (5, 5)
|
|
Packit |
534379 |
assert np.asarray(matrix).shape == (5, 5)
|
|
Packit |
534379 |
|
|
Packit |
534379 |
|
|
Packit |
534379 |
@pytest.unsupported_on_pypy
|
|
Packit |
534379 |
def test_pointer_to_member_fn():
|
|
Packit |
534379 |
for cls in [m.Buffer, m.ConstBuffer, m.DerivedBuffer]:
|
|
Packit |
534379 |
buf = cls()
|
|
Packit |
534379 |
buf.value = 0x12345678
|
|
Packit |
534379 |
value = struct.unpack('i', bytearray(buf))[0]
|
|
Packit |
534379 |
assert value == 0x12345678
|