pub struct NdArrayWrapper { /* private fields */ }Expand description
A concrete array type implementing the NumPy __array__ and
__array_interface__ protocols.
Wraps an owned flat Vec<f64> buffer with a logical shape, and exposes
it to NumPy via the array interface protocol.
Implementations§
Source§impl NdArrayWrapper
impl NdArrayWrapper
Sourcepub fn new(data: Vec<f64>, shape: Vec<usize>) -> PyResult<Self>
pub fn new(data: Vec<f64>, shape: Vec<usize>) -> PyResult<Self>
Construct a new NdArrayWrapper with C-contiguous strides.
§Arguments
data– flat element buffer; must haveshape.iter().product::<usize>()elements.shape– logical dimensions.
Sourcepub fn array_method(&self, py: Python<'_>) -> PyResult<Py<PyAny>>
pub fn array_method(&self, py: Python<'_>) -> PyResult<Py<PyAny>>
Return a Python representation suitable for numpy consumption.
Calls numpy.array(list_of_floats).reshape(shape) so that consumers
that call np.asarray(obj) or np.array(obj.__array__()) obtain the
correct array.
Note: requires NumPy to be installed in the active Python environment.
Sourcepub fn array_interface(&self, py: Python<'_>) -> PyResult<Py<PyAny>>
pub fn array_interface(&self, py: Python<'_>) -> PyResult<Py<PyAny>>
The __array_interface__ property, returning a dict describing the buffer.
Sourcepub fn shape_tuple(&self, py: Python<'_>) -> Py<PyAny>
pub fn shape_tuple(&self, py: Python<'_>) -> Py<PyAny>
Return the shape as a Python tuple.
Trait Implementations§
Source§impl ArrayProtocol for NdArrayWrapper
impl ArrayProtocol for NdArrayWrapper
Source§fn array_interface(&self) -> ArrayInterfaceDict
fn array_interface(&self) -> ArrayInterfaceDict
ArrayInterfaceDict for this object.Source§impl<'py> IntoPyObject<'py> for NdArrayWrapper
impl<'py> IntoPyObject<'py> for NdArrayWrapper
Source§type Target = NdArrayWrapper
type Target = NdArrayWrapper
Source§type Output = Bound<'py, <NdArrayWrapper as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <NdArrayWrapper as IntoPyObject<'py>>::Target>
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Source§impl PyClass for NdArrayWrapper
impl PyClass for NdArrayWrapper
Source§impl PyClassImpl for NdArrayWrapper
impl PyClassImpl for NdArrayWrapper
Source§const MODULE: Option<&str> = ::core::option::Option::None
const MODULE: Option<&str> = ::core::option::Option::None
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§const RAW_DOC: &'static CStr = /// A concrete array type implementing the NumPy `__array__` and
/// `__array_interface__` protocols.
///
/// Wraps an owned flat `Vec<f64>` buffer with a logical shape, and exposes
/// it to NumPy via the array interface protocol.
const RAW_DOC: &'static CStr = /// A concrete array type implementing the NumPy `__array__` and /// `__array_interface__` protocols. /// /// Wraps an owned flat `Vec<f64>` buffer with a logical shape, and exposes /// it to NumPy via the array interface protocol.
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type Layout = <<NdArrayWrapper as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<NdArrayWrapper>
type Layout = <<NdArrayWrapper as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<NdArrayWrapper>
Source§type ThreadChecker = NoopThreadChecker
type ThreadChecker = NoopThreadChecker
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
Source§fn dict_offset() -> Option<PyObjectOffset>
fn dict_offset() -> Option<PyObjectOffset>
Source§fn weaklist_offset() -> Option<PyObjectOffset>
fn weaklist_offset() -> Option<PyObjectOffset>
Source§impl PyClassNewTextSignature for NdArrayWrapper
impl PyClassNewTextSignature for NdArrayWrapper
const TEXT_SIGNATURE: &'static str = "(data, shape)"
Source§impl PyMethods<NdArrayWrapper> for PyClassImplCollector<NdArrayWrapper>
impl PyMethods<NdArrayWrapper> for PyClassImplCollector<NdArrayWrapper>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for NdArrayWrapper
impl PyTypeInfo for NdArrayWrapper
Source§const NAME: &str = <Self as ::pyo3::PyClass>::NAME
const NAME: &str = <Self as ::pyo3::PyClass>::NAME
prefer using ::type_object(py).name() to get the correct runtime value
Source§const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
prefer using ::type_object(py).module() to get the correct runtime value
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Source§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
impl DerefToPyAny for NdArrayWrapper
impl ExtractPyClassWithClone for NdArrayWrapper
Auto Trait Implementations§
impl Freeze for NdArrayWrapper
impl RefUnwindSafe for NdArrayWrapper
impl Send for NdArrayWrapper
impl Sync for NdArrayWrapper
impl Unpin for NdArrayWrapper
impl UnsafeUnpin for NdArrayWrapper
impl UnwindSafe for NdArrayWrapper
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
Source§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
self into an owned Python object, dropping type information.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
Source§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
Source§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
Use ::classinfo_object() instead and format the type name at runtime. Note that using built-in cast features is often better than manual PyTypeCheck usage.
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.