pub struct I8CO { /* private fields */ }Implementations§
Source§impl I8CO
impl I8CO
pub const fn try_new(start: i8, end_excl: i8) -> Option<Self>
pub const unsafe fn new_unchecked(start: i8, end_excl: i8) -> Self
Sourcepub const fn checked_from_midpoint_len(mid: i8, len: u8) -> Option<Self>
pub const fn checked_from_midpoint_len(mid: i8, len: u8) -> Option<Self>
Constructs an I8CO interval from a midpoint and length (u8).
§Parameters
mid: the desired midpoint of the intervallen: the desired length of the interval in units, must be1..=u8::MAX
§Returns
Some(I8CO)if the interval[start, end_excl)can be represented ini8Noneiflen = 0or the computedstart/end_exclwould overflowi8
§Guarantees
- Returned interval satisfies
start < end_excl - Maximum accepted input length is
u8::MAX
Sourcepub const fn saturating_from_midpoint_len(mid: i8, len: u8) -> Option<Self>
pub const fn saturating_from_midpoint_len(mid: i8, len: u8) -> Option<Self>
Constructs an I8CO interval from a midpoint and length (u8) with saturating semantics.
§Parameters
mid: the desired midpoint of the intervallen: the desired length of the interval in units, must be1..=u8::MAX
§Behavior
- Values are saturated at
i8::MIN/i8::MAXto prevent overflow. - If
len = 0, returnsNone.
§Guarantees
- Returned interval satisfies
start < end_excl - Maximum accepted input length is
u8::MAX - Fully compatible with codegen for other signed integer interval types
Source§impl I8CO
impl I8CO
Sourcepub const fn checked_from_start_len(start: i8, len: u8) -> Option<Self>
pub const fn checked_from_start_len(start: i8, len: u8) -> Option<Self>
Constructs an I8CO interval from a start position and length.
The resulting interval is [start, start + len).
Handles signed cross-zero intervals without widening arithmetic.
For example, start = -3, len = 5 produces [-3, 2).
Returns None if:
len == 0;start + lenwould exceedi8::MAX.
Sourcepub const fn saturating_from_start_len(start: i8, len: u8) -> Option<Self>
pub const fn saturating_from_start_len(start: i8, len: u8) -> Option<Self>
Constructs an I8CO interval from a start position and length,
saturating the exclusive end bound at i8::MAX.
The resulting interval is [start, saturated_end_excl).
Returns None if:
len == 0;- saturation still produces an empty interval, e.g.
start == i8::MAX.
Source§impl I8CO
impl I8CO
pub const fn start(self) -> i8
pub const fn end_excl(self) -> i8
pub const fn end_incl(self) -> i8
pub const fn len(self) -> u8
Sourcepub const fn midpoint(self) -> i8
pub const fn midpoint(self) -> i8
Returns the midpoint of the interval [start, end_excl),
using floor division if the length is even.
§Guarantees
midpoint()∈[self.start, self.end_excl - 1]- Works for intervals with maximum length (entire
i8range)
pub const fn contains(self, x: i8) -> bool
pub const fn contains_interval(self, other: Self) -> bool
pub const fn iter(self) -> Range<i8>
pub const fn to_range(self) -> Range<i8>
pub const fn intersects(self, other: Self) -> bool
pub const fn is_adjacent(self, other: Self) -> bool
pub const fn is_contiguous_with(self, other: Self) -> bool
Source§impl I8CO
impl I8CO
Sourcepub const fn intersection(self, other: Self) -> Option<Self>
pub const fn intersection(self, other: Self) -> Option<Self>
Returns the intersection of two intervals.
If the intervals do not overlap, returns None.
Sourcepub const fn convex_hull(self, other: Self) -> Self
pub const fn convex_hull(self, other: Self) -> Self
Returns the convex hull (smallest interval containing both) of two intervals.
Always returns a valid I8CO.
Sourcepub const fn between(self, other: Self) -> Option<Self>
pub const fn between(self, other: Self) -> Option<Self>
Returns the interval strictly between two intervals.
If the intervals are contiguous or overlap, returns None.
Sourcepub const fn union(self, other: Self) -> OneTwo<Self>
pub const fn union(self, other: Self) -> OneTwo<Self>
Returns the union of two intervals.
- If intervals are contiguous or overlapping, returns
Onecontaining the merged interval. - Otherwise, returns
Twocontaining both intervals in ascending order.
Sourcepub const fn difference(self, other: Self) -> ZeroOneTwo<Self>
pub const fn difference(self, other: Self) -> ZeroOneTwo<Self>
Returns the difference of two intervals (self - other).
- If no overlap, returns
One(self). - If partial overlap, returns
OneorTwodepending on remaining segments. - If fully contained, returns
Zero.
Sourcepub const fn symmetric_difference(self, other: Self) -> ZeroOneTwo<Self>
pub const fn symmetric_difference(self, other: Self) -> ZeroOneTwo<Self>
Returns the symmetric difference of two intervals.
Equivalent to (self - other) ∪ (other - self).
- If intervals do not overlap, returns
Two(self, other)in order. - If intervals partially overlap, returns remaining non-overlapping segments as
OneorTwo.
Source§impl I8CO
impl I8CO
pub const fn checked_minkowski_add(self, other: Self) -> Option<Self>
pub const fn checked_minkowski_sub(self, other: Self) -> Option<Self>
pub const fn checked_minkowski_mul_hull(self, other: Self) -> Option<Self>
pub const fn checked_minkowski_div_hull(self, other: Self) -> Option<Self>
Source§impl I8CO
impl I8CO
pub const fn checked_minkowski_add_scalar(self, n: i8) -> Option<Self>
pub const fn checked_minkowski_sub_scalar(self, n: i8) -> Option<Self>
pub const fn checked_minkowski_mul_scalar_hull(self, n: i8) -> Option<Self>
pub const fn checked_minkowski_div_scalar_hull(self, n: i8) -> Option<Self>
Source§impl I8CO
impl I8CO
pub const fn saturating_minkowski_add(self, other: Self) -> Option<Self>
pub const fn saturating_minkowski_sub(self, other: Self) -> Option<Self>
pub const fn saturating_minkowski_mul_hull(self, other: Self) -> Option<Self>
pub const fn saturating_minkowski_div_hull(self, other: Self) -> Option<Self>
Source§impl I8CO
impl I8CO
pub const fn saturating_minkowski_add_scalar(self, n: i8) -> Option<Self>
pub const fn saturating_minkowski_sub_scalar(self, n: i8) -> Option<Self>
pub const fn saturating_minkowski_mul_scalar_hull(self, n: i8) -> Option<Self>
pub const fn saturating_minkowski_div_scalar_hull(self, n: i8) -> Option<Self>
Trait Implementations§
Source§impl COAlgebra for I8CO
impl COAlgebra for I8CO
Source§fn intersection(self, other: Self) -> Option<Self>
fn intersection(self, other: Self) -> Option<Self>
Source§fn convex_hull(self, other: Self) -> Self
fn convex_hull(self, other: Self) -> Self
Source§fn between(self, other: Self) -> Option<Self>
fn between(self, other: Self) -> Option<Self>
Source§fn difference(self, other: Self) -> ZeroOneTwo<Self>
fn difference(self, other: Self) -> ZeroOneTwo<Self>
self \ other. Read moreSource§fn symmetric_difference(self, other: Self) -> ZeroOneTwo<Self>
fn symmetric_difference(self, other: Self) -> ZeroOneTwo<Self>
Source§impl COCheckedMinkowskiHull for I8CO
impl COCheckedMinkowskiHull for I8CO
Source§fn checked_minkowski_mul_hull(self, other: Self) -> Option<Self>
fn checked_minkowski_mul_hull(self, other: Self) -> Option<Self>
self * other.Source§fn checked_minkowski_div_hull(self, other: Self) -> Option<Self>
fn checked_minkowski_div_hull(self, other: Self) -> Option<Self>
self / other.Source§fn checked_minkowski_mul_scalar_hull(self, scalar: i8) -> Option<Self>
fn checked_minkowski_mul_scalar_hull(self, scalar: i8) -> Option<Self>
self * scalar.Source§fn checked_minkowski_div_scalar_hull(self, scalar: i8) -> Option<Self>
fn checked_minkowski_div_scalar_hull(self, scalar: i8) -> Option<Self>
self / scalar.Source§impl COCheckedMinkowskiLinear for I8CO
impl COCheckedMinkowskiLinear for I8CO
Source§fn checked_minkowski_add(self, other: Self) -> Option<Self>
fn checked_minkowski_add(self, other: Self) -> Option<Self>
self + other.Source§fn checked_minkowski_sub(self, other: Self) -> Option<Self>
fn checked_minkowski_sub(self, other: Self) -> Option<Self>
self - other.Source§fn checked_minkowski_add_scalar(self, scalar: i8) -> Option<Self>
fn checked_minkowski_add_scalar(self, scalar: i8) -> Option<Self>
self + scalar.Source§fn checked_minkowski_sub_scalar(self, scalar: i8) -> Option<Self>
fn checked_minkowski_sub_scalar(self, scalar: i8) -> Option<Self>
self - scalar.Source§impl COConstruct for I8CO
impl COConstruct for I8CO
Source§impl COMidpoint for I8CO
impl COMidpoint for I8CO
Source§impl COMidpointConstruct for I8CO
impl COMidpointConstruct for I8CO
Source§impl COPredicates for I8CO
impl COPredicates for I8CO
Source§fn contains_interval(self, other: Self) -> bool
fn contains_interval(self, other: Self) -> bool
other is fully contained in this interval.Source§fn intersects(self, other: Self) -> bool
fn intersects(self, other: Self) -> bool
other overlap with positive length.Source§fn is_adjacent(self, other: Self) -> bool
fn is_adjacent(self, other: Self) -> bool
other touch at exactly one boundary
without overlapping.Source§fn is_contiguous_with(self, other: Self) -> bool
fn is_contiguous_with(self, other: Self) -> bool
other overlap or are adjacent.Source§impl COSaturatingMinkowskiHull for I8CO
impl COSaturatingMinkowskiHull for I8CO
Source§fn saturating_minkowski_mul_hull(self, other: Self) -> Option<Self>
fn saturating_minkowski_mul_hull(self, other: Self) -> Option<Self>
self * other. Read moreSource§fn saturating_minkowski_div_hull(self, other: Self) -> Option<Self>
fn saturating_minkowski_div_hull(self, other: Self) -> Option<Self>
self / other. Read moreSource§impl COSaturatingMinkowskiLinear for I8CO
impl COSaturatingMinkowskiLinear for I8CO
Source§fn saturating_minkowski_add(self, other: Self) -> Option<Self>
fn saturating_minkowski_add(self, other: Self) -> Option<Self>
self + other. Read moreSource§fn saturating_minkowski_sub(self, other: Self) -> Option<Self>
fn saturating_minkowski_sub(self, other: Self) -> Option<Self>
self - other. Read more