#multi-dimensional #array #slice

multiarray

Small Rust library for handling multi-dimensional data

4 releases

Uses old Rust 2015

0.1.3 Sep 30, 2015
0.1.2 Sep 30, 2015
0.1.1 Sep 30, 2015
0.1.0 Sep 30, 2015

#2672 in Algorithms

Download history 50/week @ 2024-07-22 24/week @ 2024-07-29 21/week @ 2024-08-05 39/week @ 2024-08-12 13/week @ 2024-08-19 33/week @ 2024-08-26 8/week @ 2024-09-02 16/week @ 2024-09-09 12/week @ 2024-09-16 31/week @ 2024-09-23 20/week @ 2024-09-30 4/week @ 2024-10-07 15/week @ 2024-10-14 16/week @ 2024-10-21 50/week @ 2024-10-28 21/week @ 2024-11-04

102 downloads per month
Used in candlelighter

MIT/Apache

27KB
523 lines

This library provides ways to create and deal with multi-dimensional arrays. It basically tries to generalize Box<[T]>, &[T] and &mut[T] to multiple dimensions with some convenient methods that allow you to slice views, create lower-dimensional slices of it, subsampled or reversed views or even swap dimensions (for example, to create a transposed view of a 2D matrix).

Example

In the following example you'll see how a 3D array and two views into it (2D and 1D) can be created.

use multiarray::*;

let mut voxels = Array3D::new([3,4,5], 0); // 3x4x5 ints
voxels[[0,0,0]] = 1;
voxels[[1,2,3]] = 23;
voxels[[2,3,4]] = 42;
assert!(voxels[[1,2,3]] == 23);
let slice = voxels.eliminated_dim(1, 2);   // 2D slice
assert!(slice[[1,3]] == 23);
let lane = slice.eliminated_dim(1, 3);     // 1D lane
assert!(lane[1] == 23);

Here, slice is a 2D slice of the 3D volume (at y=2) and lane is a one-dimensional view that also acts as an ExactSize/DoubleEnded iterator.


lib.rs:

This crate provides types to deal with multi-dimensional data. It basically tries to generalize over Box<[T]>, &[T] and &mut [T] to multiple dimensions. As a side effect, it also supports one-dimensional arrays that have a stride other than one.

Examples

Here's an example of a 3D array. One 2D view and one 1D view into part of the data is created.

use multiarray::*;

let mut voxels = Array3D::new([3,4,5], 0); // 3x4x5 ints
voxels[[0,0,0]] = 1;
voxels[[1,2,3]] = 23;
voxels[[2,3,4]] = 42;
assert!(voxels[[1,2,3]] == 23);
let slice = voxels.eliminated_dim(1, 2);   // 2D slice
assert!(slice[[1,3]] == 23);
let lane = slice.eliminated_dim(1, 3);     // 1D lane
assert!(lane[1] == 23);

Please note that [usize; N] is used as index. For convenience the one-dimensional case also supports usize as index in addition to [usize; 1], the one-dimensional views are convertible from borrowed slices (&[T] and &mut[T]) via std::convert::{ From, Into } and also implement the iterator traits Iterator, ExactSizeIterator and DoubleEndedIterator.

Dependencies