ndhistogram::axis

Struct Category

Source
pub struct Category<T>
where T: Eq + Hash,
{ /* private fields */ }
Expand description

An axis to represent a set of discrete values or categories with an overflow bin.

This axis also includes an overflow bin, to include “other” values not given when the axis was constructed. See CategoryNoFlow for a variant that includes no overflow bin.

§Example

use ndhistogram::axis::{Axis, Category, SingleValueBinInterval};
let colors = Category::new(vec!["red", "blue", "pink", "yellow", "black"]);
assert_eq!(colors.index(&"red"), Some(0));
assert_eq!(colors.index(&"green"), Some(5));
assert_eq!(colors.bin(1), Some(SingleValueBinInterval::new("blue")));
assert_eq!(colors.bin(5), Some(SingleValueBinInterval::overflow()));

Implementations§

Source§

impl<T: Value> Category<T>

Source

pub fn new<I: IntoIterator<Item = T>>(values: I) -> Self

Factory method to create a category axis without an overflow bin.

Takes an iterator over a set of values that represent each category. All other values will be mapped to the overflow bin.

Trait Implementations§

Source§

impl<T: Value> Axis for Category<T>

Source§

type Coordinate = T

The type representing a location on this axis.
Source§

type BinInterval = SingleValueBinInterval<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::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 for Category<T>
where T: Eq + Hash + Clone,

Source§

fn clone(&self) -> Category<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 for Category<T>
where T: Eq + Hash + Debug,

Source§

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

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

impl<T> Default for Category<T>
where T: Eq + Hash + Default,

Source§

fn default() -> Category<T>

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

impl<T: Display + Value> Display for Category<T>

Source§

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

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

impl<'a, T: Value> IntoIterator for &'a Category<T>

Source§

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

The type of the elements being iterated over.
Source§

type IntoIter = Box<dyn Iterator<Item = <&'a Category<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> PartialEq for Category<T>
where T: Eq + Hash + PartialEq,

Source§

fn eq(&self, other: &Category<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> Eq for Category<T>
where T: Eq + Hash + Eq,

Source§

impl<T> StructuralPartialEq for Category<T>
where T: Eq + Hash,

Auto Trait Implementations§

§

impl<T> Freeze for Category<T>

§

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

§

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

§

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

§

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

§

impl<T> UnwindSafe for Category<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.