ndhistogram::axis

Struct Uniform

Source
pub struct Uniform<T = f64> { /* private fields */ }
Expand description

An axis with equal sized bins.

An axis with N equally spaced, equal sized, bins between [low, high). Below (above) this range is an underflow (overflow) bin. Hence this axis has N+2 bins.

For floating point types, positive and negative infinities map to overflow and underflow bins respectively. NaN maps to the overflow bin.

§Example

Create a 1D histogram with 10 uniform bins between -5.0 and 5.0, plus overflow and underflow bins.

   use ndhistogram::{ndhistogram, Histogram};
   use ndhistogram::axis::{Axis, Uniform, BinInterval};
   let hist = ndhistogram!(Uniform::new(10, -5.0, 5.0)?);
   let axis = &hist.axes().as_tuple().0;
   assert_eq!(axis.bin(0), Some(BinInterval::underflow(-5.0)));
   assert_eq!(axis.bin(1), Some(BinInterval::new(-5.0, -4.0)));
   assert_eq!(axis.bin(11), Some(BinInterval::overflow(5.0)));

Implementations§

Source§

impl<T> Uniform<T>
where T: PartialOrd + Num + NumCast + NumOps + Copy,

Source

pub fn new(num: usize, low: T, high: T) -> Result<Self, AxisError>
where T: Float,

Factory method to create an axis with num uniformly spaced bins in the range [low, high). Under/overflow bins cover values outside this range.

Only implemented for Float. Use Uniform::with_step_size for integers.

Source

pub fn with_step_size(num: usize, low: T, step: T) -> Result<Self, AxisError>

Factory method to create an axis with num uniformly spaced bins in the range [low, low+num*step). Under/overflow bins cover values outside this range.

The number of bins and step size must both be greater than zero, otherwise an error is returned. The number of bins must be representable in the type T, otherwise an error is returned.

Source§

impl<T> Uniform<T>

Source

pub fn low(&self) -> &T

Low edge of axis (excluding underflow bin).

Source

pub fn high(&self) -> &T

High edge of axis (excluding overflow bin).

Trait Implementations§

Source§

impl<T: PartialOrd + NumCast + NumOps + Copy> Axis for Uniform<T>

Source§

type Coordinate = T

The type representing a location on this axis.
Source§

type BinInterval = BinInterval<T>

The type of an interval representing the set of Coordinates that correspond to a histogram bin
Source§

fn index(&self, coordinate: &Self::Coordinate) -> Option<usize>

Map from coordinate to bin number. Returns an option as not all valid coordinates are necessarily contained within a bin.
Source§

fn num_bins(&self) -> usize

The number of bins in this axis, including underflow and overflow.
Source§

fn bin(&self, index: usize) -> Option<<Self as Axis>::BinInterval>

Map from bin number to axis to the interval covering the range of coordinates that this bin contains. Returns an option in case an index >= Axis::num_bins is given.
Source§

fn indices(&self) -> Box<dyn Iterator<Item = usize>>

An iterator over bin numbers
Source§

fn iter(&self) -> Box<dyn Iterator<Item = (usize, Self::BinInterval)> + '_>

An iterator over bin numbers and bin intervals
Source§

fn bins(&self) -> Box<dyn Iterator<Item = Self::BinInterval> + '_>

An iterator over bin intervals.
Source§

fn num_dim(&self) -> usize

The number of dimensions that this object corresponds to. For most Axis types this will simply be 1. However, Axes (i.e. a set of Axis) also implement Axis and should return the number of Axis that it contains.
Source§

impl<T: Clone> Clone for Uniform<T>

Source§

fn clone(&self) -> Uniform<T>

Returns a copy 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<T: Debug> Debug for Uniform<T>

Source§

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

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

impl<T: Default> Default for Uniform<T>

Source§

fn default() -> Uniform<T>

Returns the “default value” for a type. Read more
Source§

impl<T: Display> Display for Uniform<T>

Source§

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

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

impl<T: Hash> Hash for Uniform<T>

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<'a, T> IntoIterator for &'a Uniform<T>
where Uniform<T>: Axis,

Source§

type Item = (usize, <Uniform<T> as Axis>::BinInterval)

The type of the elements being iterated over.
Source§

type IntoIter = Box<dyn Iterator<Item = <&'a Uniform<T> as IntoIterator>::Item> + 'a>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
Source§

impl<T: Ord> Ord for Uniform<T>

Source§

fn cmp(&self, other: &Uniform<T>) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<T: PartialEq> PartialEq for Uniform<T>

Source§

fn eq(&self, other: &Uniform<T>) -> 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<T: PartialOrd> PartialOrd for Uniform<T>

Source§

fn partial_cmp(&self, other: &Uniform<T>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

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

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

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

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

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

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

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

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<T: Eq> Eq for Uniform<T>

Source§

impl<T> StructuralPartialEq for Uniform<T>

Auto Trait Implementations§

§

impl<T> Freeze for Uniform<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for Uniform<T>
where T: RefUnwindSafe,

§

impl<T> Send for Uniform<T>
where T: Send,

§

impl<T> Sync for Uniform<T>
where T: Sync,

§

impl<T> Unpin for Uniform<T>
where T: Unpin,

§

impl<T> UnwindSafe for Uniform<T>
where T: UnwindSafe,

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, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit #126799)
Performs copy-assignment from self to dst. 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> 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§

default 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.