[][src]Struct math::partition::ordered_interval_partitions::OrderedIntervalPartitions

pub struct OrderedIntervalPartitions<E: Integer + Copy> { /* fields omitted */ }

Implementations

impl<E: Integer + Copy> OrderedIntervalPartitions<E>[src]

pub fn from_vec(
    partitions: Vec<ContiguousIntegerSet<E>>
) -> OrderedIntervalPartitions<E>
[src]

pub fn from_vec_with_trusted_order(
    partitions: Vec<ContiguousIntegerSet<E>>
) -> OrderedIntervalPartitions<E>
[src]

pub fn from_slice(slice: &[[E; 2]]) -> OrderedIntervalPartitions<E>[src]

pub fn num_partitions_overlapped_by(
    &self,
    other: &OrderedIntervalPartitions<E>
) -> usize
[src]

returns the number of partitions that intersect with the other's partitions

pub fn num_partitions(&self) -> usize[src]

pub fn get_partitions_by_ref(&self) -> &Vec<ContiguousIntegerSet<E>>[src]

pub fn into_vec(self) -> Vec<ContiguousIntegerSet<E>>[src]

impl<E: Integer + Copy + ToPrimitive> OrderedIntervalPartitions<E>[src]

impl<E: Integer + Copy + Hash> OrderedIntervalPartitions<E>[src]

pub fn get_partition_containing(
    &self,
    subinterval: &ContiguousIntegerSet<E>
) -> Option<(usize, ContiguousIntegerSet<E>)>
[src]

if there is a partition containing the subinterval, returns a tuple (partition_index, partition)

Trait Implementations

impl<E: Clone + Integer + Copy> Clone for OrderedIntervalPartitions<E>[src]

impl<E: Debug + Integer + Copy> Debug for OrderedIntervalPartitions<E>[src]

impl<E: PartialEq + Integer + Copy> PartialEq<OrderedIntervalPartitions<E>> for OrderedIntervalPartitions<E>[src]

impl<E: Integer + Copy> Refineable<OrderedIntervalPartitions<E>> for OrderedIntervalPartitions<E>[src]

fn get_common_refinement(
    &self,
    other: &OrderedIntervalPartitions<E>
) -> OrderedIntervalPartitions<E>
[src]

Example

use math::{
    partition::ordered_interval_partitions::OrderedIntervalPartitions,
    set::{contiguous_integer_set::ContiguousIntegerSet, traits::Refineable},
};
let p1 = OrderedIntervalPartitions::from_slice(&[[-1, 4], [8, 10]]);
let p2 = OrderedIntervalPartitions::from_slice(&[[3, 7]]);
assert_eq!(
    p1.get_common_refinement(&p2).into_vec(),
    [[-1, 2], [3, 4], [5, 7], [8, 10]]
        .iter()
        .map(|[a, b]| ContiguousIntegerSet::new(*a, *b))
        .collect::<Vec<ContiguousIntegerSet<i32>>>()
);

impl<E: Integer + Copy> StructuralPartialEq for OrderedIntervalPartitions<E>[src]

impl<E: Integer + Copy + Hash> SubsetIndexable<ContiguousIntegerSet<E>, ContiguousIntegerSet<E>> for OrderedIntervalPartitions<E>[src]

Auto Trait Implementations

impl<E> RefUnwindSafe for OrderedIntervalPartitions<E> where
    E: RefUnwindSafe

impl<E> Send for OrderedIntervalPartitions<E> where
    E: Send

impl<E> Sync for OrderedIntervalPartitions<E> where
    E: Sync

impl<E> Unpin for OrderedIntervalPartitions<E> where
    E: Unpin

impl<E> UnwindSafe for OrderedIntervalPartitions<E> where
    E: UnwindSafe

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>,