Struct Interval

Source
pub struct Interval<T> {
    pub lower: Bound<T>,
    pub upper: Bound<T>,
}
Expand description

๐Ÿ“ A range of values with lower and upper Bounds.

The Interval type allows modeling ranges of values with optional inclusion or exclusion at each bound. This is useful for mathematical operations, range checks, and interval arithmetic.

See also the interval! macro.

Fieldsยง

ยงlower: Bound<T>

The lower bound (also known as the start bound, or the left bound).

ยงupper: Bound<T>

The upper bound (also known as the end, bound or the right bound).

Implementationsยง

Sourceยง

impl<T> Interval<T>

ยงMethodical constructors

Source

pub const fn closed(lower: T, upper: T) -> Self

Creates a closed interval $[l, u]$ lower..=upper RangeInclusive.

Source

pub const fn closed_open(lower: T, upper: T) -> Self

Creates a half-open interval $[l, u)$ lower..upper Range.

Source

pub const fn closed_unbounded(lower: T) -> Self

Creates an interval $[l, โˆž)$ lower.. RangeFrom.

Source

pub const fn open(lower: T, upper: T) -> Self

Creates an open interval $(l, u)$ lower..<upper.

Source

pub const fn open_closed(lower: T, upper: T) -> Self

Creates a half-open interval $(l, u]$ lower..<=upper.

Source

pub const fn open_unbounded(lower: T) -> Self

Creates an interval $(l, โˆž)$ lower..<.

Source

pub const fn unbounded() -> Self

Creates an unbounded interval $(-โˆž, โˆž)$ .. RangeFull.

Source

pub const fn unbounded_closed(upper: T) -> Self

Creates an interval $(-โˆž, u]$ ..upper RangeTo.

Source

pub const fn unbounded_open(upper: T) -> Self

Creates an interval $(-โˆž, u)$ ..=upper RangeToInclusive.

Sourceยง

impl<T> Interval<T>

ยงAdditional constructors

Source

pub const fn new(lower: Bound<T>, upper: Bound<T>) -> Self

Creates a new interval with the given lower and upper bounds.

Source

pub fn point(value: T) -> Self
where T: Clone,

Creates a single-point interval, equivalent to closed(value, value).

Source

pub fn empty() -> Self
where T: Default,

Creates a canonical empty interval, equivalent to open(T::default(), T::default()).

Source

pub const fn empty_const() -> Self
where T: ConstDefault,

Creates a canonical empty interval, equivalent to open(T::default(), T::default()).

Source

pub fn empty_with(value: T) -> Self
where T: Clone,

Creates a canonical empty interval, equivalent to open(value, value).

Sourceยง

impl<T: Copy> Interval<T>

Source

pub const fn to_tuple(self) -> (Bound<T>, Bound<T>) โ“˜

Returns a copy of both bounds as a tuple (lower, upper).

ยงExample
let r = Interval::from(1..3usize);
assert_eq!("bc", &"abcd"[r.to_tuple()]);
Sourceยง

impl<T> Interval<T>

Source

pub fn into_tuple(self) -> (Bound<T>, Bound<T>) โ“˜

Returns both bounds as a tuple (lower, upper).

Source

pub fn to_tuple_ref(&self) -> (Bound<&T>, Bound<&T>) โ“˜

Returns a reference to both bounds as a tuple (&lower, &upper).

Source

pub fn lower_ref(&self) -> Bound<&T>

Returns a reference to the lower bound.

Source

pub fn upper_ref(&self) -> Bound<&T>

Returns a reference to the upper bound.

Source

pub const fn is_bounded(&self) -> bool

Checks if the interval is both lower and upper bounded.

Source

pub const fn is_lower_bounded(&self) -> bool

Checks if the lower bound is bounded.

Source

pub const fn is_upper_bounded(&self) -> bool

Checks if the upper bound is bounded.

Source

pub const fn is_lower_open(&self) -> bool

Checks if the lower bound is open (excluded).

Source

pub const fn is_lower_closed(&self) -> bool

Checks if the lower bound is closed (included).

Source

pub const fn is_upper_open(&self) -> bool

Checks if the upper bound is open (excluded).

Source

pub const fn is_upper_closed(&self) -> bool

Checks if the upper bound is closed (included).

Sourceยง

impl<T: PartialOrd> Interval<T>

Source

pub fn is_empty(&self) -> bool

Checks if the interval is empty (contains no values).

An interval is empty if:

  • The bounds exclude each other, such as (x, x), [x, x), or (x, x].
  • The lower bound is strictly greater than the upper bound.

Unbounded intervals are never empty.

Source

pub fn is_well_ordered(&self) -> bool

Validates that the interval bounds are ordered correctly.

Returns true if the lower bound is less than or equal to the upper bound. Unbounded intervals are always considered well ordered.

Source

pub fn contains(&self, value: &T) -> bool

Checks if the interval contains the given value.

let interval = Interval::closed(1, 5);
assert!(interval.contains(&3));
assert!(!interval.contains(&6));
Source

pub fn size(&self) -> Option<T> โ“˜
where T: Clone + Sub<Output = T>,

Returns the size of the interval, if finite.

Trait Implementationsยง

Sourceยง

impl<T: Clone> Clone for Interval<T>

Sourceยง

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

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<T> ConstDefault for Interval<T>

Provides a const default value for Interval, the unbounded interval $(-\infty, \infty)$.

See the Default implementation for more information.

See Default for more information.

Sourceยง

const DEFAULT: Self

Returns the compile-time โ€œdefault valueโ€ for a type.
Sourceยง

impl<T: Debug> Debug for Interval<T>

Sourceยง

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

Formats the value using the given formatter. Read more
Sourceยง

impl<T> Default for Interval<T>

Provides a default value for Interval, the unbounded interval $(-\infty, \infty)$.

This choice emphasizes neutrality and generality, where the interval encompasses all possible values of T. It:

  • Represents a neutral and maximal range for generic use cases.
  • Avoids reliance on Default for T, making it applicable to all types.
  • Aligns with mathematical conventions, where unbounded intervals are a natural default.
Sourceยง

fn default() -> Self

Returns the โ€œdefault valueโ€ for a type. Read more
Sourceยง

impl<T: Display> Display for Interval<T>

Sourceยง

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

Formats the interval as a human-readable string.

Examples:

  • (-โˆž, 5] for an unbounded lower bound and inclusive upper bound.
  • [1, 3) for a closed lower bound and open upper bound.
Sourceยง

impl<T> From<Range<T>> for Interval<T>

Sourceยง

fn from(r: Range<T>) -> Self

Converts to this type from the input type.
Sourceยง

impl<T> From<RangeFrom<T>> for Interval<T>

Sourceยง

fn from(r: RangeFrom<T>) -> Self

Converts to this type from the input type.
Sourceยง

impl<T> From<RangeFull> for Interval<T>

Sourceยง

fn from(_: RangeFull) -> Self

Converts to this type from the input type.
Sourceยง

impl<T> From<RangeInclusive<T>> for Interval<T>

Sourceยง

fn from(r: RangeInclusive<T>) -> Self

Converts to this type from the input type.
Sourceยง

impl<T> From<RangeTo<T>> for Interval<T>

Sourceยง

fn from(r: RangeTo<T>) -> Self

Converts to this type from the input type.
Sourceยง

impl<T> From<RangeToInclusive<T>> for Interval<T>

Sourceยง

fn from(r: RangeToInclusive<T>) -> Self

Converts to this type from the input type.
Sourceยง

impl<T: Hash> Hash for Interval<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<T: Ord> Ord for Interval<T>

Comparison Logic:

  • We compare the lower bounds first.
  • If the lower bounds are equal, we compare the upper bounds.
  • We define Unbounded as less than any bounded value.
  • We define that Included(l) < Excluded(l) at same point l.
Sourceยง

fn cmp(&self, other: &Self) -> 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 Interval<T>

Sourceยง

fn eq(&self, other: &Interval<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 Interval<T>

Comparison Logic:

  • We compare the lower bounds first.
  • If the lower bounds are equal, we compare the upper bounds.
  • We define Unbounded as less than any bounded value.
  • We define that Included(l) < Excluded(l) at same point l.
Sourceยง

fn partial_cmp(&self, other: &Self) -> 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> RangeBounds<T> for Interval<T>

Sourceยง

fn start_bound(&self) -> Bound<&T>

Start index bound. Read more
Sourceยง

fn end_bound(&self) -> Bound<&T>

End index bound. Read more
1.35.0 ยท Sourceยง

fn contains<U>(&self, item: &U) -> bool
where T: PartialOrd<U>, U: PartialOrd<T> + ?Sized,

Returns true if item is contained in the range. Read more
Sourceยง

fn is_empty(&self) -> bool
where T: PartialOrd,

๐Ÿ”ฌThis is a nightly-only experimental API. (range_bounds_is_empty)
Returns true if the range contains no items. One-sided ranges (RangeFrom, etc) always return false. Read more
Sourceยง

impl<T> TryFrom<Interval<T>> for Range<T>

ยงErrors

Returns IncompatibleBounds if the bounds are not compatible.

Sourceยง

type Error = NumError

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

fn try_from(interval: Interval<T>) -> NumResult<Self>

Performs the conversion.
Sourceยง

impl<T> TryFrom<Interval<T>> for RangeFrom<T>

ยงErrors

Returns IncompatibleBounds if the bounds are not compatible.

Sourceยง

type Error = NumError

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

fn try_from(interval: Interval<T>) -> NumResult<Self>

Performs the conversion.
Sourceยง

impl<T> TryFrom<Interval<T>> for RangeFull

ยงErrors

Returns IncompatibleBounds if the bounds are not compatible.

Sourceยง

type Error = NumError

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

fn try_from(interval: Interval<T>) -> NumResult<Self>

Performs the conversion.
Sourceยง

impl<T> TryFrom<Interval<T>> for RangeInclusive<T>

ยงErrors

Returns IncompatibleBounds if the bounds are not compatible.

Sourceยง

type Error = NumError

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

fn try_from(interval: Interval<T>) -> NumResult<Self>

Performs the conversion.
Sourceยง

impl<T> TryFrom<Interval<T>> for RangeTo<T>

ยงErrors

Returns IncompatibleBounds if the bounds are not compatible.

Sourceยง

type Error = NumError

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

fn try_from(interval: Interval<T>) -> NumResult<Self>

Performs the conversion.
Sourceยง

impl<T> TryFrom<Interval<T>> for RangeToInclusive<T>

ยงErrors

Returns IncompatibleBounds if the bounds are not compatible.

Sourceยง

type Error = NumError

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

fn try_from(interval: Interval<T>) -> NumResult<Self>

Performs the conversion.
Sourceยง

impl<T: Copy> Copy for Interval<T>

Sourceยง

impl<T: Eq> Eq for Interval<T>

Sourceยง

impl<T> StructuralPartialEq for Interval<T>

Auto Trait Implementationsยง

ยง

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

ยง

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

ยง

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

ยง

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

ยง

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

ยง

impl<T> UnwindSafe for Interval<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> ByteSized for T

Sourceยง

const BYTE_ALIGN: usize = _

The alignment of this type in bytes.
Sourceยง

const BYTE_SIZE: usize = _

The size of this type in bytes.
Sourceยง

fn byte_align(&self) -> usize

Returns the alignment of this type in bytes.
Sourceยง

fn byte_size(&self) -> usize

Returns the size of this type in bytes. Read more
Sourceยง

fn ptr_size_ratio(&self) -> [usize; 2]

Returns the size ratio between Ptr::BYTES and BYTE_SIZE. Read more
Sourceยง

impl<T, R> Chain<R> for T
where T: ?Sized,

Sourceยง

fn chain<F>(self, f: F) -> R
where F: FnOnce(Self) -> R, Self: Sized,

Chain a function which takes the parameter by value.
Sourceยง

fn chain_ref<F>(&self, f: F) -> R
where F: FnOnce(&Self) -> R,

Chain a function which takes the parameter by shared reference.
Sourceยง

fn chain_mut<F>(&mut self, f: F) -> R
where F: FnOnce(&mut Self) -> R,

Chain a function which takes the parameter by exclusive reference.
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
ยง

impl<Q, K> Comparable<K> for Q
where Q: Ord + ?Sized, K: Borrow<Q> + ?Sized,

ยง

fn compare(&self, key: &K) -> Ordering

Compare self to key and return their ordering.
ยง

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

ยง

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Sourceยง

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

Sourceยง

fn type_id() -> TypeId

Returns the TypeId of Self. Read more
Sourceยง

fn type_of(&self) -> TypeId

Returns the TypeId of self. Read more
Sourceยง

fn type_name(&self) -> &'static str โ“˜

Returns the type name of self. Read more
Sourceยง

fn type_is<T: 'static>(&self) -> bool

Returns true if Self is of type T. Read more
Sourceยง

fn type_hash(&self) -> u64

Returns a deterministic hash of the TypeId of Self.
Sourceยง

fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64

Returns a deterministic hash of the TypeId of Self using a custom hasher.
Sourceยง

fn as_any_ref(&self) -> &dyn Any
where Self: Sized,

Upcasts &self as &dyn Any. Read more
Sourceยง

fn as_any_mut(&mut self) -> &mut dyn Any
where Self: Sized,

Upcasts &mut self as &mut dyn Any. Read more
Sourceยง

fn as_any_box(self: Box<Self>) -> Box<dyn Any>
where Self: Sized,

Upcasts Box<self> as Box<dyn Any>. Read more
Sourceยง

fn downcast_ref<T: 'static>(&self) -> Option<&T> โ“˜

Available on crate feature unsafe_layout only.
Returns some shared reference to the inner value if it is of type T. Read more
Sourceยง

fn downcast_mut<T: 'static>(&mut self) -> Option<&mut T> โ“˜

Available on crate feature unsafe_layout only.
Returns some exclusive reference to the inner value if it is of type T. Read more
Sourceยง

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

Sourceยง

const NEEDS_DROP: bool = _

Know whether dropping values of this type matters, in compile-time.
Sourceยง

fn mem_align_of<T>() -> usize

Returns the minimum alignment of the type in bytes. Read more
Sourceยง

fn mem_align_of_val(&self) -> usize

Returns the alignment of the pointed-to value in bytes. Read more
Sourceยง

fn mem_size_of<T>() -> usize

Returns the size of a type in bytes. Read more
Sourceยง

fn mem_size_of_val(&self) -> usize

Returns the size of the pointed-to value in bytes. Read more
Sourceยง

fn mem_copy(&self) -> Self
where Self: Copy,

Bitwise-copies a value. Read more
Sourceยง

fn mem_needs_drop(&self) -> bool

Returns true if dropping values of this type matters. Read more
Sourceยง

fn mem_drop(self)
where Self: Sized,

Drops self by running its destructor. Read more
Sourceยง

fn mem_forget(self)
where Self: Sized,

Forgets about self without running its destructor. Read more
Sourceยง

fn mem_replace(&mut self, other: Self) -> Self
where Self: Sized,

Replaces self with other, returning the previous value of self. Read more
Sourceยง

fn mem_take(&mut self) -> Self
where Self: Default,

Replaces self with its default value, returning the previous value of self. Read more
Sourceยง

fn mem_swap(&mut self, other: &mut Self)
where Self: Sized,

Swaps the value of self and other without deinitializing either one. Read more
Sourceยง

unsafe fn mem_zeroed<T>() -> T

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Sourceยง

unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Sourceยง

fn mem_as_bytes(&self) -> &[u8] โ“˜
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &[u8]. Read more
Sourceยง

fn mem_as_bytes_mut(&mut self) -> &mut [u8] โ“˜
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &mut [u8]. Read more
Sourceยง

impl<T> From<T> for T

Sourceยง

fn from(t: T) -> T

Returns the argument unchanged.

ยง

impl<S> FromSample<S> for S

ยง

fn from_sample_(s: S) -> S

Sourceยง

impl<T> Hook for T

Sourceยง

fn hook_ref<F>(self, f: F) -> Self
where F: FnOnce(&Self),

Applies a function which takes the parameter by shared reference, and then returns the (possibly) modified owned value. Read more
Sourceยง

fn hook_mut<F>(self, f: F) -> Self
where F: FnOnce(&mut Self),

Applies a function which takes the parameter by exclusive reference, and then returns the (possibly) modified owned value. Read more
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
ยง

impl<F, T> IntoSample<T> for F
where T: FromSample<F>,

ยง

fn into_sample(self) -> T

ยง

impl<T> Pointable for T

ยง

const ALIGN: usize

The alignment of pointer.
ยง

type Init = T

The type for initializers.
ยง

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
ยง

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
ยง

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
ยง

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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
ยง

impl<T, U> ToSample<U> for T
where U: FromSample<T>,

ยง

fn to_sample_(self) -> U

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<S, T> Duplex<S> for T
where T: FromSample<S> + ToSample<S>,

ยง

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