pumpkin_solver::options

Enum CumulativeExplanationType

source
pub enum CumulativeExplanationType {
    Naive,
    BigStep,
    PointWise,
}
Expand description

Determines what type of explanation is used for the cumulative constraint based on the explanations described in Section 4.5.1 and 4.5.2 of [1].

For the explanations of conflicts and conflicts, we different between 3 types of explanations:

§Bibliography

[1] A. Schutt, Improving scheduling by learning. University of Melbourne, Department of Computer Science and Software Engineering, 2011.

Variants§

§

Naive

The naive explanation approach simply uses the current bounds of the profile and the propagated task in the explanation.

§

BigStep

The default; lifts the explanation to create an explanation which uses the bounds which would cause the tasks in the profile to have mandatory parts in the range of the propagating profile.

§

PointWise

Creates an explanation over a set of time-points;

§Propagations

Note that we currently do not generate chains of profiles which cause a propagation. This means that the explanation only concerns a single profile; the selected time-points for a propagation of task i are constructed as follows in the case of a lower-bound propagation: [profile.start, profile.start + i.process_time, profile.start + (2 * i.processing_time), ..., profile.end]. Thus, if the profile is shorter than i.processing_time, two explanations are generated for the time-points profile.start and profile.end.

§Conflicts

For conflicts we follow the work by Schutt (see the documentation for CumulativeExplanationType) and select the middle point in the profile as the point used for the explanation.

Trait Implementations§

source§

impl Clone for CumulativeExplanationType

source§

fn clone(&self) -> CumulativeExplanationType

Returns a copy 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 Debug for CumulativeExplanationType

source§

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

Formats the value using the given formatter. Read more
source§

impl Default for CumulativeExplanationType

source§

fn default() -> CumulativeExplanationType

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

impl Display for CumulativeExplanationType

source§

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

Formats the value using the given formatter. Read more
source§

impl Copy for CumulativeExplanationType

Auto Trait Implementations§

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> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

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
source§

impl<Value> Statistic for Value
where Value: Display,

source§

fn log(&self, statistic_logger: StatisticLogger)

Logs the Statistic using the provided StatisticLogger.
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
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default 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.
source§

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

source§

fn vzip(self) -> V