nalgebra-numpy 0.3.0

conversions between nalgebra and numpy
Documentation
use assert2::assert;
use inline_python::{python, Context};
use nalgebra::{U1, U2, U3};
use nalgebra_numpy::{matrix_from_numpy, Error};

#[test]
fn wrong_type() {
	let gil = pyo3::Python::acquire_gil();
	let py = gil.python();
	let context = Context::new_with_gil(py);

	context.run(python! {
		float = 3.4
		int   = 8
		list  = [1.0, 2.0, 3.0]
	});

	let get_global = |name| context.globals(py).get_item(name).unwrap();

	assert!(let Err(Error::WrongObjectType(_)) = matrix_from_numpy::<f64, U1, U1>(py, get_global("float")));
	assert!(let Err(Error::WrongObjectType(_)) = matrix_from_numpy::<i32, U1, U1>(py, get_global("int")));
	assert!(let Err(Error::WrongObjectType(_)) = matrix_from_numpy::<f64, U1, U3>(py, get_global("list")));
}

#[test]
fn wrong_shape() {
	let gil = pyo3::Python::acquire_gil();
	let py = gil.python();
	let context = Context::new_with_gil(py);

	context.run(python! {
		import numpy as np
		matrix  = np.array([
			[1.0, 2.0, 3.0],
			[4.0, 5.0, 6.0],
		]);
	});

	let get_global = |name| context.globals(py).get_item(name).unwrap();

	assert!(let Ok(_) = matrix_from_numpy::<f64, U2, U3>(py, get_global("matrix")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<f64, U1, U1>(py, get_global("matrix")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<f64, U3, U2>(py, get_global("matrix")));
}

#[test]
fn wrong_data_type() {
	let gil = pyo3::Python::acquire_gil();
	let py = gil.python();
	let context = Context::new_with_gil(py);

	context.run(python! {
		import numpy as np
		matrix_f32 = np.array([[1.0]]).astype(np.float32);
		matrix_f64 = np.array([[1.0]]).astype(np.float64);
		matrix_i32 = np.array([[1]]).astype(np.int32);
		matrix_i64 = np.array([[1]]).astype(np.int64);
	});

	let get_global = |name| context.globals(py).get_item(name).expect(name);

	assert!(let Ok(_) = matrix_from_numpy::<f32, U1, U1>(py, get_global("matrix_f32")));
	assert!(let Ok(_) = matrix_from_numpy::<f64, U1, U1>(py, get_global("matrix_f64")));
	assert!(let Ok(_) = matrix_from_numpy::<i32, U1, U1>(py, get_global("matrix_i32")));
	assert!(let Ok(_) = matrix_from_numpy::<i64, U1, U1>(py, get_global("matrix_i64")));

	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<f32, U1, U1>(py, get_global("matrix_f64")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<f32, U1, U1>(py, get_global("matrix_i32")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<f32, U1, U1>(py, get_global("matrix_i64")));

	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<f64, U1, U1>(py, get_global("matrix_f32")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<f64, U1, U1>(py, get_global("matrix_i32")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<f64, U1, U1>(py, get_global("matrix_i64")));

	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<i32, U1, U1>(py, get_global("matrix_f32")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<i32, U1, U1>(py, get_global("matrix_f64")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<i32, U1, U1>(py, get_global("matrix_i64")));

	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<i64, U1, U1>(py, get_global("matrix_f32")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<i64, U1, U1>(py, get_global("matrix_f64")));
	assert!(let Err(Error::IncompatibleArray(_)) = matrix_from_numpy::<i64, U1, U1>(py, get_global("matrix_i32")));
}

#[test]
fn unaligned_data() {
	let gil = pyo3::Python::acquire_gil();
	let py = gil.python();
	let context = Context::new_with_gil(py);

	context.run(python! {
		import numpy as np
		unaligned = np.array([range(8)], dtype=np.uint8)[:, 1:7].view(np.uint16)
	});

	let get_global = |name| context.globals(py).get_item(name).unwrap();

	assert!(let Err(Error::UnalignedArray(_)) = matrix_from_numpy::<u16, U1, U3>(py, get_global("unaligned")));
}