Struct ndarray_histogram::histogram::strategies::Rice
source · pub struct Rice<T> { /* private fields */ }
Expand description
A strategy that does not take variability into account, only data size. Commonly overestimates number of bins required.
Let n
be the number of observations and n_bins
be the number of bins.
n_bins
= 2n
1/3
n_bins
is only proportional to cube root of n
. It tends to overestimate
the n_bins
and it does not take into account data variability.
Notes
This strategy requires the data
- not being empty
- not being constant
Implementations§
Trait Implementations§
source§impl<T> BinsBuildingStrategy for Rice<T>where
T: Ord + Send + Clone + FromPrimitive + ToPrimitive + NumOps + Zero,
impl<T> BinsBuildingStrategy for Rice<T>where T: Ord + Send + Clone + FromPrimitive + ToPrimitive + NumOps + Zero,
source§fn from_array_with_max<S>(
a: &ArrayBase<S, Ix1>,
max_n_bins: usize
) -> Result<Self, BinsBuildError>where
S: Data<Elem = Self::Elem>,
fn from_array_with_max<S>( a: &ArrayBase<S, Ix1>, max_n_bins: usize ) -> Result<Self, BinsBuildError>where S: Data<Elem = Self::Elem>,
Returns Err(BinsBuildError::Strategy)
if the array is constant.
Returns Err(BinsBuildError::EmptyInput)
if a.len()==0
.
Returns Ok(Self)
otherwise.
type Elem = T
source§fn build(&self) -> Bins<T>
fn build(&self) -> Bins<T>
Returns a
Bins
instance, according to parameters inferred from observations.source§fn n_bins(&self) -> usize
fn n_bins(&self) -> usize
Returns the optimal number of bins, according to parameters inferred from observations.
source§fn from_array<S>(array: &ArrayBase<S, Ix1>) -> Result<Self, BinsBuildError>where
S: Data<Elem = Self::Elem>,
Self: Sized,
fn from_array<S>(array: &ArrayBase<S, Ix1>) -> Result<Self, BinsBuildError>where S: Data<Elem = Self::Elem>, Self: Sized,
Auto Trait Implementations§
impl<T> RefUnwindSafe for Rice<T>where T: RefUnwindSafe,
impl<T> Send for Rice<T>where T: Send,
impl<T> Sync for Rice<T>where T: Sync,
impl<T> Unpin for Rice<T>where T: Unpin,
impl<T> UnwindSafe for Rice<T>where T: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more