pub struct MaxRegret<Var, TieBreaking> { /* private fields */ }Expand description
A VariableSelector which selects the variable with the largest difference between the two
smallest values in its domain.
Currently, due to the implementation of the domains, in the worst-case this selector will go through all variables and all values between the upper-bound and lower-bound.
Uses a TieBreaker to break ties, the default is the InOrderTieBreaker but it is
possible to construct the variable selector with a custom TieBreaker by using
the method MaxRegret::with_tie_breaker.
Implementations§
source§impl<Var: Clone + 'static, TieBreaking: TieBreaker<Var, i32>> MaxRegret<Var, TieBreaking>
impl<Var: Clone + 'static, TieBreaking: TieBreaker<Var, i32>> MaxRegret<Var, TieBreaking>
pub fn with_tie_breaker(variables: &[Var], tie_breaker: TieBreaking) -> Self
Trait Implementations§
source§impl<TieBreaking> VariableSelector<DomainId> for MaxRegret<DomainId, TieBreaking>
impl<TieBreaking> VariableSelector<DomainId> for MaxRegret<DomainId, TieBreaking>
source§fn select_variable(
&mut self,
context: &SelectionContext<'_>,
) -> Option<DomainId>
fn select_variable( &mut self, context: &SelectionContext<'_>, ) -> Option<DomainId>
Determines which variable to select next if there are any left to branch on.
Should only return
None when all variables which have been passed to the
VariableSelector have been assigned. Otherwise it should return the variable to
branch on next.source§fn on_conflict(&mut self)
fn on_conflict(&mut self)
A function which is called after a conflict has been found and processed but (currently)
does not provide any additional information.
source§fn on_unassign_literal(&mut self, _literal: Literal)
fn on_unassign_literal(&mut self, _literal: Literal)
source§fn on_unassign_integer(&mut self, _variable: DomainId, _value: i32)
fn on_unassign_integer(&mut self, _variable: DomainId, _value: i32)
source§fn on_appearance_in_conflict_literal(&mut self, _literal: Literal)
fn on_appearance_in_conflict_literal(&mut self, _literal: Literal)
A function which is called when a
Literal appears in a conflict during conflict
analysis.source§fn on_appearance_in_conflict_integer(&mut self, _variable: DomainId)
fn on_appearance_in_conflict_integer(&mut self, _variable: DomainId)
A function which is called when a variable appears in a conflict during conflict analysis.
source§fn is_restart_pointless(&mut self) -> bool
fn is_restart_pointless(&mut self) -> bool
This method returns whether a restart is currently pointless for the
VariableSelector. Read moreAuto Trait Implementations§
impl<Var, TieBreaking> Freeze for MaxRegret<Var, TieBreaking>where
TieBreaking: Freeze,
impl<Var, TieBreaking> RefUnwindSafe for MaxRegret<Var, TieBreaking>where
TieBreaking: RefUnwindSafe,
Var: RefUnwindSafe,
impl<Var, TieBreaking> Send for MaxRegret<Var, TieBreaking>
impl<Var, TieBreaking> Sync for MaxRegret<Var, TieBreaking>
impl<Var, TieBreaking> Unpin for MaxRegret<Var, TieBreaking>
impl<Var, TieBreaking> UnwindSafe for MaxRegret<Var, TieBreaking>where
TieBreaking: UnwindSafe,
Var: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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