pub struct SimulatedAnnealingAcceptor { /* private fields */ }Expand description
Simulated annealing acceptor using the Boltzmann distribution.
Accepts improving moves unconditionally. For worsening moves, accepts with
probability exp(-delta / T) where delta is the score degradation and
T is the current temperature.
Temperature decays geometrically each step: T *= decay_rate.
§Example
use solverforge_solver::phase::localsearch::SimulatedAnnealingAcceptor;
// High initial temperature (explores broadly), slow cooling
let acceptor = SimulatedAnnealingAcceptor::new(1.0, 0.9999);Implementations§
Source§impl SimulatedAnnealingAcceptor
impl SimulatedAnnealingAcceptor
Sourcepub fn new(starting_temperature: f64, decay_rate: f64) -> Self
pub fn new(starting_temperature: f64, decay_rate: f64) -> Self
Creates a new simulated annealing acceptor.
§Arguments
starting_temperature- Initial temperature (higher = more exploration). Calibrate to ~20% of the initial hard score magnitude for best results.decay_rate- Multiplicative decay per step (e.g., 0.9999 for 30s runs at ~10k steps/s gives final T ≈ 0.05 * starting T).
Sourcepub fn with_seed(starting_temperature: f64, decay_rate: f64, seed: u64) -> Self
pub fn with_seed(starting_temperature: f64, decay_rate: f64, seed: u64) -> Self
Creates a new SA acceptor with a fixed seed for reproducibility.
Sourcepub fn auto_calibrate(decay_rate: f64) -> Self
pub fn auto_calibrate(decay_rate: f64) -> Self
Auto-calibrates starting temperature from the initial score.
Sets temperature to 20% of the absolute initial score magnitude, ensuring ~80% acceptance probability for moves with delta = |initial_score|.
Trait Implementations§
Source§impl<S: PlanningSolution> Acceptor<S> for SimulatedAnnealingAcceptor
impl<S: PlanningSolution> Acceptor<S> for SimulatedAnnealingAcceptor
Source§fn is_accepted(
&mut self,
last_step_score: &S::Score,
move_score: &S::Score,
) -> bool
fn is_accepted( &mut self, last_step_score: &S::Score, move_score: &S::Score, ) -> bool
Returns true if a move resulting in
move_score should be accepted,
given the previous step’s score.Source§fn phase_started(&mut self, initial_score: &S::Score)
fn phase_started(&mut self, initial_score: &S::Score)
Called when a phase starts.
Source§fn step_ended(&mut self, _step_score: &S::Score)
fn step_ended(&mut self, _step_score: &S::Score)
Called when a step ends with an accepted move.
Source§fn phase_ended(&mut self)
fn phase_ended(&mut self)
Called when a phase ends.
Source§fn step_started(&mut self)
fn step_started(&mut self)
Called when a step starts.
Source§impl Debug for SimulatedAnnealingAcceptor
impl Debug for SimulatedAnnealingAcceptor
Auto Trait Implementations§
impl Freeze for SimulatedAnnealingAcceptor
impl RefUnwindSafe for SimulatedAnnealingAcceptor
impl Send for SimulatedAnnealingAcceptor
impl Sync for SimulatedAnnealingAcceptor
impl Unpin for SimulatedAnnealingAcceptor
impl UnsafeUnpin for SimulatedAnnealingAcceptor
impl UnwindSafe for SimulatedAnnealingAcceptor
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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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