Struct Extent

Source
pub struct Extent { /* private fields */ }
Expand description

Extent defines the logical shape of a multidimensional space by assigning a size to each named dimension. It abstracts away memory layout and focuses solely on structure — what dimensions exist and how many elements each contains.

Conceptually, it corresponds to a coordinate space in the mathematical sense.

Implementations§

Source§

impl Extent

Source

pub fn new(labels: Vec<String>, sizes: Vec<usize>) -> Result<Self, ExtentError>

Creates a new Extent from the given labels and sizes.

Source

pub fn unity() -> Extent

Source

pub fn labels(&self) -> &[String]

Returns the ordered list of dimension labels in this extent.

Source

pub fn sizes(&self) -> &[usize]

Returns the dimension sizes, ordered to match the labels.

Source

pub fn size(&self, label: &str) -> Option<usize>

Returns the size of the dimension with the given label, if it exists.

Source

pub fn position(&self, label: &str) -> Option<usize>

Returns the position of the dimension with the given label, if it exists exists.

Source

pub fn rank_of_coords(&self, coords: &[usize]) -> Result<usize, PointError>

Source

pub fn point(&self, coords: Vec<usize>) -> Result<Point, PointError>

Creates a Point in this extent from the given coordinate vector.

The coordinates are interpreted in row-major order against self.sizes(). This constructor does not store the coordinates; it computes the linear rank and returns a Point that stores { rank, extent }.

§Errors

Returns:

§Examples
use ndslice::extent;

let ext = extent!(x = 2, y = 3, z = 4);
let p = ext.point(vec![1, 2, 3]).unwrap();
assert_eq!(p.rank(), 1 * (3 * 4) + 2 * 4 + 3); // row-major
assert_eq!(p.coords(), vec![1, 2, 3]);

Dimension mismatch:

use ndslice::PointError;
use ndslice::extent;

let ext = extent!(x = 2, y = 3);
let err = ext.point(vec![1]).unwrap_err();
matches!(err, PointError::DimMismatch { .. });

Coordinate out of range:

use ndslice::PointError;
use ndslice::extent;

let ext = extent!(x = 2, y = 3);
let err = ext.point(vec![1, 3]).unwrap_err(); // y size is 3, max index is 2
matches!(err, PointError::OutOfRangeIndex { .. });
Source

pub fn point_of_rank(&self, rank: usize) -> Result<Point, PointError>

Returns the Point corresponding to the given linearized rank within this extent, using row-major order.

§Errors

Returns PointError::OutOfRangeRank if rank >= self.num_ranks(), i.e. when the requested rank lies outside the bounds of this extent.

§Examples
use ndslice::extent;

let ext = extent!(x = 2, y = 3);
assert_eq!(ext.num_ranks(), 6);

let p = ext.point_of_rank(4).unwrap();
assert_eq!(p.coords(), vec![1, 1]); // row-major: x=1, y=1
assert_eq!(p.rank(), 4);

assert!(ext.point_of_rank(6).is_err()); // out of range
Source

pub fn len(&self) -> usize

Returns the number of dimensions in this extent.

For example, an extent defined as (x=2, y=3, z=4) has dimensionality 3.

Source

pub fn is_empty(&self) -> bool

Returns true if this extent has zero dimensions.

A 0-dimensional extent corresponds to the scalar case: a coordinate space with exactly one rank (the empty tuple []).

Source

pub fn num_ranks(&self) -> usize

Returns the total number of ranks (points) in this extent.

This is the product of all dimension sizes, i.e. the number of distinct coordinates in row-major order.

Source

pub fn into_inner(self) -> (Vec<String>, Vec<usize>)

Convert this extent into its labels and sizes.

Source

pub fn to_slice(&self) -> Slice

Creates a slice representing the full extent.

Source

pub fn iter(&self) -> impl Iterator<Item = (String, usize)> + use<'_>

Iterate over this extent’s labels and sizes.

Source

pub fn points(&self) -> ExtentPointsIterator<'_>

Iterate points in this extent.

Source

pub fn concat(&self, other: &Extent) -> Result<Self, ExtentError>

Append the dimensions of other to this extent, preserving order.

Duplicate labels are not allowed: if any label in other already appears in self, this returns ExtentError::OverlappingLabel.

This operation is not commutative: a.concat(&b) may differ from b.concat(&a).

Trait Implementations§

Source§

impl Clone for Extent

Source§

fn clone(&self) -> Extent

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Extent

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de> Deserialize<'de> for Extent

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Display for Extent

Formats an Extent as a compact map‐literal:

{label: size, label: size, ...}

§Grammar

Extent   := "{" [ Pair ( "," Pair )* ] "}"
Pair     := Label ": " Size
Label    := SafeIdent | Quoted
SafeIdent:= [A-Za-z0-9_]+
Quoted   := "\"" ( [^"\\] | "\\" . )* "\""
Size     := [0-9]+

§Quoting rules

  • Labels that are not SafeIdent are rendered using Rust string literal syntax (via format!("{:?}", label)), e.g. "dim/0" or "x y".
  • “Safe” means ASCII alphanumeric or underscore ([A-Za-z0-9_]+). Everything else is quoted. This keeps common identifiers unquoted and unambiguous.

§Examples

{x: 4, y: 5, z: 6}
{"dim/0": 3, "dim,1": 5}
{}

Implementation note: label rendering goes through fmt_label, which emits the label as-is for safe idents, otherwise as a Rust string literal.

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl From<&Shape> for Extent

Source§

fn from(s: &Shape) -> Self

Converts to this type from the input type.
Source§

impl From<Extent> for Region

Source§

fn from(extent: Extent) -> Self

Converts to this type from the input type.
Source§

impl From<Shape> for Extent

Source§

fn from(s: Shape) -> Self

Converts to this type from the input type.
Source§

impl Hash for Extent

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for Extent

Source§

fn eq(&self, other: &Extent) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for Extent

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl View for Extent

An Extent is also a View.

Source§

type Item = usize

The type of item is the rank itself.

Source§

type View = Region

The type of sub-view can be a Region, since Extent can only describe a complete space.

Source§

fn region(&self) -> Region

The ranks contained in this view.
Source§

fn subset(&self, region: Region) -> Result<Region, ViewError>

Subsets this view with the provided ranks. This is mainly used by combinators on Views themselves. The set of ranks passed in must be a subset of the ranks of the base view.
Source§

fn get(&self, rank: usize) -> Option<Self::Item>

Retrieve the item corresponding to the given rank in the Region of this view. An implementation MUST return a value for all ranks defined in this view.
Source§

impl Eq for Extent

Source§

impl StructuralPartialEq for Extent

Auto Trait Implementations§

§

impl Freeze for Extent

§

impl RefUnwindSafe for Extent

§

impl Send for Extent

§

impl Sync for Extent

§

impl Unpin for Extent

§

impl UnwindSafe for Extent

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

Source§

impl<T> ViewExt for T
where T: View,

Source§

fn range<R>(&self, dim: &str, range: R) -> Result<<T as View>::View, ViewError>
where R: Into<Range>,

Construct a view comprising the range of points along the provided dimension. Read more
Source§

fn group_by( &self, dim: &str, ) -> Result<impl Iterator<Item = <T as View>::View>, ViewError>

Group by view on dim. The returned iterator enumerates all groups as views in the extent of dim to the last dimension of the view. Read more
Source§

fn extent(&self) -> Extent

The extent of this view. Every point in this space is defined.
Source§

fn iter(&self) -> impl Iterator<Item = (Point, <T as View>::Item)>

Iterate over all points in this region.
Source§

fn values(&self) -> impl Iterator<Item = <T as View>::Item>

Iterate over the values in the region.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,