Rcb

Struct Rcb 

Source
pub struct Rcb {
    pub iter_count: usize,
    pub tolerance: f64,
    pub fast: bool,
}
Expand description

§Recursive Coordinate Bisection algorithm

Partitions a mesh based on the nodes coordinates and coresponding weights.

This is the most simple and straightforward geometric algorithm. It operates as follows for a N-dimensional set of points:

At each iteration, select a vector n of the canonical basis (e_0, ..., e_{n-1}). Then, split the set of points with an hyperplane orthogonal to n, such that the two parts of the splits are evenly weighted. Finally, recurse by reapplying the algorithm to the two parts with an other normal vector selection.

§Example

use coupe::Partition as _;
use coupe::Point2D;

let points = [
    Point2D::new(1., 1.),
    Point2D::new(-1., 1.),
    Point2D::new(1., -1.),
    Point2D::new(-1., -1.),
];
let weights = [1; 4];
let mut partition = [0; 4];

// Generate a partition of 4 parts (2 splits).
coupe::Rcb { iter_count: 2, ..Default::default() }
    .partition(&mut partition, (points, weights))
    .unwrap();

// All points are in different parts.
for i in 0..4 {
    for j in 0..4 {
        if j == i {
            continue
        }
        assert_ne!(partition[i], partition[j])
    }
}

§Reference

Berger, M. J. and Bokhari, S. H., 1987. A partitioning strategy for nonuniform problems on multiprocessors. IEEE Transactions on Computers, C-36(5):570–580. doi:10.1109/TC.1987.1676942.

Fields§

§iter_count: usize

The number of iterations of the algorithm. This will yield a partition of at most 2^num_iter parts.

If this equals zero, RCB will not do anything.

§tolerance: f64

Tolerance on the normalized imbalance, for each split. Please note that the overall imbalance might end up above this threshold.

Negative values are interpreted as zeroes.

§fast: bool

Use a faster, experimental implementation of the algorithm.

Trait Implementations§

Source§

impl Default for Rcb

Source§

fn default() -> Rcb

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

impl<const D: usize, P, W> Partition<(P, W)> for Rcb

Source§

type Metadata = ()

Diagnostic data returned for a specific run of the algorithm.
Source§

type Error = Error

Error details, should the algorithm fail to run.
Source§

fn partition( &mut self, part_ids: &mut [usize], (points, weights): (P, W), ) -> Result<Self::Metadata, Self::Error>

Partition the given data and output the part ID of each element in part_ids. Read more

Auto Trait Implementations§

§

impl Freeze for Rcb

§

impl RefUnwindSafe for Rcb

§

impl Send for Rcb

§

impl Sync for Rcb

§

impl Unpin for Rcb

§

impl UnwindSafe for Rcb

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. 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> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

Source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
Source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
Source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
Source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
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.
Source§

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

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more