nalgebra/src/base/vec_storage.rs

450 lines
12 KiB
Rust
Raw Normal View History

2018-07-20 21:25:55 +08:00
#[cfg(feature = "abomonation-serialize")]
use std::io::{Result as IOResult, Write};
2018-05-24 23:17:34 +08:00
#[cfg(all(feature = "alloc", not(feature = "std")))]
2018-07-20 22:10:12 +08:00
use alloc::vec::Vec;
2018-05-24 23:17:34 +08:00
2019-03-23 21:29:07 +08:00
use crate::base::allocator::Allocator;
2020-04-06 00:49:48 +08:00
use crate::base::constraint::{SameNumberOfRows, ShapeConstraint};
2019-03-23 21:29:07 +08:00
use crate::base::default_allocator::DefaultAllocator;
use crate::base::dimension::{Dim, DimName, Dynamic, U1};
use crate::base::storage::{
ContiguousStorage, ContiguousStorageMut, Owned, ReshapableStorage, Storage, StorageMut,
};
2021-07-14 17:25:16 +08:00
use crate::base::{ Vector};
#[cfg(feature = "serde-serialize-no-std")]
use serde::{
de::{Deserialize, Deserializer, Error},
ser::{Serialize, Serializer},
};
#[cfg(feature = "abomonation-serialize")]
use abomonation::Abomonation;
/*
*
* Storage.
*
*/
/// A Vec-based matrix data storage. It may be dynamically-sized.
#[repr(C)]
#[derive(Eq, Debug, Clone, PartialEq)]
2021-04-11 17:00:38 +08:00
pub struct VecStorage<T, R: Dim, C: Dim> {
2021-07-14 17:25:16 +08:00
pub(crate) data: Vec<T>,
pub(crate) nrows: R,
pub(crate) ncols: C,
}
#[cfg(feature = "serde-serialize")]
impl<T, R: Dim, C: Dim> Serialize for VecStorage<T, R, C>
where
T: Serialize,
R: Serialize,
C: Serialize,
{
fn serialize<Ser>(&self, serializer: Ser) -> Result<Ser::Ok, Ser::Error>
where
Ser: Serializer,
{
(&self.data, &self.nrows, &self.ncols).serialize(serializer)
}
}
#[cfg(feature = "serde-serialize")]
impl<'a, T, R: Dim, C: Dim> Deserialize<'a> for VecStorage<T, R, C>
where
T: Deserialize<'a>,
R: Deserialize<'a>,
C: Deserialize<'a>,
{
fn deserialize<Des>(deserializer: Des) -> Result<Self, Des::Error>
where
Des: Deserializer<'a>,
{
let (data, nrows, ncols): (Vec<T>, R, C) = Deserialize::deserialize(deserializer)?;
// SAFETY: make sure the data we deserialize have the
// correct number of elements.
if nrows.value() * ncols.value() != data.len() {
return Err(Des::Error::custom(format!(
"Expected {} components, found {}",
nrows.value() * ncols.value(),
data.len()
)));
}
Ok(Self { data, nrows, ncols })
}
}
2020-04-06 00:49:48 +08:00
#[deprecated(note = "renamed to `VecStorage`")]
/// Renamed to [VecStorage].
2021-04-11 17:00:38 +08:00
pub type MatrixVec<T, R, C> = VecStorage<T, R, C>;
2021-04-11 17:00:38 +08:00
impl<T, R: Dim, C: Dim> VecStorage<T, R, C> {
2017-02-13 01:17:09 +08:00
/// Creates a new dynamic matrix data storage from the given vector and shape.
#[inline]
2021-04-11 17:00:38 +08:00
pub fn new(nrows: R, ncols: C, data: Vec<T>) -> Self {
2018-02-02 19:26:35 +08:00
assert!(
nrows.value() * ncols.value() == data.len(),
"Data storage buffer dimension mismatch."
);
2020-10-11 16:57:26 +08:00
Self { data, nrows, ncols }
}
/// The underlying data storage.
#[inline]
#[must_use]
2021-04-11 17:00:38 +08:00
pub fn as_vec(&self) -> &Vec<T> {
&self.data
}
/// The underlying mutable data storage.
///
2021-07-04 11:19:07 +08:00
/// # Safety
/// This is unsafe because this may cause UB if the size of the vector is changed
/// by the user.
#[inline]
2021-04-11 17:00:38 +08:00
pub unsafe fn as_vec_mut(&mut self) -> &mut Vec<T> {
&mut self.data
}
2018-09-24 12:48:42 +08:00
/// Resizes the underlying mutable data storage and unwraps it.
///
2021-07-04 11:19:07 +08:00
/// # Safety
/// If `sz` is larger than the current size, additional elements are uninitialized.
2018-09-24 12:48:42 +08:00
/// If `sz` is smaller than the current size, additional elements are truncated.
#[inline]
2021-04-11 17:00:38 +08:00
pub unsafe fn resize(mut self, sz: usize) -> Vec<T> {
let len = self.len();
if sz < len {
self.data.set_len(sz);
self.data.shrink_to_fit();
2018-02-02 19:26:35 +08:00
} else {
self.data.reserve_exact(sz - len);
self.data.set_len(sz);
}
self.data
}
/// The number of elements on the underlying vector.
#[inline]
#[must_use]
pub fn len(&self) -> usize {
self.data.len()
}
/// Returns true if the underlying vector contains no elements.
#[inline]
#[must_use]
pub fn is_empty(&self) -> bool {
self.len() == 0
}
}
2021-06-18 15:45:37 +08:00
impl<T, R: Dim, C: Dim> From<VecStorage<T, R, C>> for Vec<T> {
fn from(vec: VecStorage<T, R, C>) -> Self {
vec.data
}
}
/*
*
* Dynamic Static
* Dynamic Dynamic
*
*/
2021-07-14 17:25:16 +08:00
unsafe impl<T, C: Dim> Storage<T, Dynamic, C> for VecStorage<T, Dynamic, C>
2020-04-06 00:49:48 +08:00
where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, Dynamic, C, Buffer = Self>,
2018-02-02 19:26:35 +08:00
{
type RStride = U1;
type CStride = Dynamic;
#[inline]
2021-04-11 17:00:38 +08:00
fn ptr(&self) -> *const T {
self.data.as_ptr()
}
#[inline]
fn shape(&self) -> (Dynamic, C) {
(self.nrows, self.ncols)
}
#[inline]
fn strides(&self) -> (Self::RStride, Self::CStride) {
(Self::RStride::name(), self.nrows)
}
#[inline]
2021-07-09 00:12:43 +08:00
fn is_contiguous(&self) -> bool {
true
}
#[inline]
2021-04-11 17:00:38 +08:00
fn into_owned(self) -> Owned<T, Dynamic, C>
2020-04-06 00:49:48 +08:00
where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, Dynamic, C>,
2020-04-06 00:49:48 +08:00
{
self
}
#[inline]
2021-04-11 17:00:38 +08:00
fn clone_owned(&self) -> Owned<T, Dynamic, C>
2020-04-06 00:49:48 +08:00
where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, Dynamic, C>,
2020-04-06 00:49:48 +08:00
{
self.clone()
}
#[inline]
unsafe fn as_slice_unchecked(&self) -> &[T] {
&self.data
}
}
2021-07-14 17:25:16 +08:00
unsafe impl<T, R: DimName> Storage<T, R, Dynamic> for VecStorage<T, R, Dynamic>
2020-04-06 00:49:48 +08:00
where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, R, Dynamic, Buffer = Self>,
2018-02-02 19:26:35 +08:00
{
type RStride = U1;
type CStride = R;
#[inline]
2021-04-11 17:00:38 +08:00
fn ptr(&self) -> *const T {
self.data.as_ptr()
}
#[inline]
fn shape(&self) -> (R, Dynamic) {
(self.nrows, self.ncols)
}
#[inline]
fn strides(&self) -> (Self::RStride, Self::CStride) {
(Self::RStride::name(), self.nrows)
}
#[inline]
2021-07-09 00:12:43 +08:00
fn is_contiguous(&self) -> bool {
true
}
#[inline]
2021-04-11 17:00:38 +08:00
fn into_owned(self) -> Owned<T, R, Dynamic>
2020-04-06 00:49:48 +08:00
where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, R, Dynamic>,
2020-04-06 00:49:48 +08:00
{
self
}
#[inline]
2021-04-11 17:00:38 +08:00
fn clone_owned(&self) -> Owned<T, R, Dynamic>
2020-04-06 00:49:48 +08:00
where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, R, Dynamic>,
2020-04-06 00:49:48 +08:00
{
self.clone()
}
#[inline]
unsafe fn as_slice_unchecked(&self) -> &[T] {
&self.data
}
}
/*
*
* StorageMut, ContiguousStorage.
*
*/
2021-07-14 17:25:16 +08:00
unsafe impl<T, C: Dim> StorageMut<T, Dynamic, C> for VecStorage<T, Dynamic, C>
2020-04-06 00:49:48 +08:00
where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, Dynamic, C, Buffer = Self>,
2018-02-02 19:26:35 +08:00
{
#[inline]
2021-04-11 17:00:38 +08:00
fn ptr_mut(&mut self) -> *mut T {
self.data.as_mut_ptr()
}
#[inline]
unsafe fn as_mut_slice_unchecked(&mut self) -> &mut [T] {
&mut self.data[..]
}
}
2021-07-14 17:25:16 +08:00
unsafe impl<T, C: Dim> ContiguousStorage<T, Dynamic, C> for VecStorage<T, Dynamic, C> where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, Dynamic, C, Buffer = Self>
2020-04-06 00:49:48 +08:00
{
}
2021-07-14 17:25:16 +08:00
unsafe impl<T, C: Dim> ContiguousStorageMut<T, Dynamic, C> for VecStorage<T, Dynamic, C> where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, Dynamic, C, Buffer = Self>
2020-04-06 00:49:48 +08:00
{
}
2021-07-14 17:25:16 +08:00
impl<T, C1: Dim, C2: Dim> ReshapableStorage<T, Dynamic, C1, Dynamic, C2>
for VecStorage<T, Dynamic, C1>
{
2021-04-11 17:00:38 +08:00
type Output = VecStorage<T, Dynamic, C2>;
fn reshape_generic(self, nrows: Dynamic, ncols: C2) -> Self::Output {
assert_eq!(nrows.value() * ncols.value(), self.data.len());
VecStorage {
data: self.data,
nrows,
ncols,
}
}
}
2021-07-14 17:25:16 +08:00
impl<T, C1: Dim, R2: DimName> ReshapableStorage<T, Dynamic, C1, R2, Dynamic>
for VecStorage<T, Dynamic, C1>
{
2021-04-11 17:00:38 +08:00
type Output = VecStorage<T, R2, Dynamic>;
fn reshape_generic(self, nrows: R2, ncols: Dynamic) -> Self::Output {
assert_eq!(nrows.value() * ncols.value(), self.data.len());
VecStorage {
data: self.data,
nrows,
ncols,
}
}
}
2021-07-14 17:25:16 +08:00
unsafe impl<T, R: DimName> StorageMut<T, R, Dynamic> for VecStorage<T, R, Dynamic>
2020-04-06 00:49:48 +08:00
where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, R, Dynamic, Buffer = Self>,
2018-02-02 19:26:35 +08:00
{
#[inline]
2021-04-11 17:00:38 +08:00
fn ptr_mut(&mut self) -> *mut T {
self.data.as_mut_ptr()
}
#[inline]
unsafe fn as_mut_slice_unchecked(&mut self) -> &mut [T] {
&mut self.data[..]
}
}
2021-07-14 17:25:16 +08:00
impl<T, R1: DimName, C2: Dim> ReshapableStorage<T, R1, Dynamic, Dynamic, C2>
for VecStorage<T, R1, Dynamic>
{
2021-04-11 17:00:38 +08:00
type Output = VecStorage<T, Dynamic, C2>;
fn reshape_generic(self, nrows: Dynamic, ncols: C2) -> Self::Output {
assert_eq!(nrows.value() * ncols.value(), self.data.len());
VecStorage {
data: self.data,
nrows,
ncols,
}
}
}
2021-07-14 17:25:16 +08:00
impl<T, R1: DimName, R2: DimName> ReshapableStorage<T, R1, Dynamic, R2, Dynamic>
for VecStorage<T, R1, Dynamic>
{
2021-04-11 17:00:38 +08:00
type Output = VecStorage<T, R2, Dynamic>;
fn reshape_generic(self, nrows: R2, ncols: Dynamic) -> Self::Output {
assert_eq!(nrows.value() * ncols.value(), self.data.len());
VecStorage {
data: self.data,
nrows,
ncols,
}
}
}
#[cfg(feature = "abomonation-serialize")]
2021-04-11 17:00:38 +08:00
impl<T: Abomonation, R: Dim, C: Dim> Abomonation for VecStorage<T, R, C> {
2018-07-20 21:25:55 +08:00
unsafe fn entomb<W: Write>(&self, writer: &mut W) -> IOResult<()> {
self.data.entomb(writer)
}
unsafe fn exhume<'a, 'b>(&'a mut self, bytes: &'b mut [u8]) -> Option<&'b mut [u8]> {
self.data.exhume(bytes)
}
2018-07-20 21:25:55 +08:00
fn extent(&self) -> usize {
self.data.extent()
}
}
2017-08-16 01:18:39 +08:00
2021-07-14 17:25:16 +08:00
unsafe impl<T, R: DimName> ContiguousStorage<T, R, Dynamic> for VecStorage<T, R, Dynamic> where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, R, Dynamic, Buffer = Self>
2020-04-06 00:49:48 +08:00
{
}
2021-07-14 17:25:16 +08:00
unsafe impl<T, R: DimName> ContiguousStorageMut<T, R, Dynamic> for VecStorage<T, R, Dynamic> where
2021-04-11 17:00:38 +08:00
DefaultAllocator: Allocator<T, R, Dynamic, Buffer = Self>
{
2020-04-06 00:49:48 +08:00
}
2021-04-11 17:00:38 +08:00
impl<T, R: Dim> Extend<T> for VecStorage<T, R, Dynamic> {
/// Extends the number of columns of the `VecStorage` with elements
/// from the given iterator.
///
/// # Panics
/// This function panics if the number of elements yielded by the
/// given iterator is not a multiple of the number of rows of the
/// `VecStorage`.
2021-04-11 17:00:38 +08:00
fn extend<I: IntoIterator<Item = T>>(&mut self, iter: I) {
self.data.extend(iter);
self.ncols = Dynamic::new(self.data.len() / self.nrows.value());
assert!(self.data.len() % self.nrows.value() == 0,
"The number of elements produced by the given iterator was not a multiple of the number of rows.");
}
}
2021-04-11 17:00:38 +08:00
impl<'a, T: 'a + Copy, R: Dim> Extend<&'a T> for VecStorage<T, R, Dynamic> {
/// Extends the number of columns of the `VecStorage` with elements
/// from the given iterator.
///
/// # Panics
/// This function panics if the number of elements yielded by the
/// given iterator is not a multiple of the number of rows of the
/// `VecStorage`.
2021-04-11 17:00:38 +08:00
fn extend<I: IntoIterator<Item = &'a T>>(&mut self, iter: I) {
self.extend(iter.into_iter().copied())
}
}
2021-07-14 17:25:16 +08:00
impl<T, R: Dim, RV: Dim, SV> Extend<Vector<T, RV, SV>> for VecStorage<T, R, Dynamic>
where
2021-04-11 17:00:38 +08:00
SV: Storage<T, RV>,
ShapeConstraint: SameNumberOfRows<R, RV>,
{
/// Extends the number of columns of the `VecStorage` with vectors
/// from the given iterator.
///
/// # Panics
/// This function panics if the number of rows of each `Vector`
/// yielded by the iterator is not equal to the number of rows
/// of this `VecStorage`.
2021-04-11 17:00:38 +08:00
fn extend<I: IntoIterator<Item = Vector<T, RV, SV>>>(&mut self, iter: I) {
let nrows = self.nrows.value();
let iter = iter.into_iter();
let (lower, _upper) = iter.size_hint();
self.data.reserve(nrows * lower);
for vector in iter {
assert_eq!(nrows, vector.shape().0);
self.data.extend(vector.iter().cloned());
}
self.ncols = Dynamic::new(self.data.len() / nrows);
}
}
2021-04-11 17:00:38 +08:00
impl<T> Extend<T> for VecStorage<T, Dynamic, U1> {
/// Extends the number of rows of the `VecStorage` with elements
/// from the given iterator.
2021-04-11 17:00:38 +08:00
fn extend<I: IntoIterator<Item = T>>(&mut self, iter: I) {
self.data.extend(iter);
self.nrows = Dynamic::new(self.data.len());
}
}