vrp-core 1.23.0

A core algorithms to solve a Vehicle Routing Problem
Documentation
use super::*;
use crate::construction::enablers::{advance_departure_time, ScheduleKeys};
use crate::construction::heuristics::InsertionContext;
use rosomaxa::HeuristicSolution;

/// Provides way to reduce waiting time by advancing departure time.
pub struct AdvanceDeparture {
    state_keys: ScheduleKeys,
}

impl AdvanceDeparture {
    /// Creates an instance of `AdvanceDeparture`.
    pub fn new(state_keys: ScheduleKeys) -> Self {
        Self { state_keys }
    }
}

impl HeuristicSolutionProcessing for AdvanceDeparture {
    type Solution = InsertionContext;

    fn post_process(&self, solution: Self::Solution) -> Self::Solution {
        let mut insertion_ctx = solution.deep_copy();

        let problem = insertion_ctx.problem.clone();

        let activity = problem.activity.as_ref();
        let transport = problem.transport.as_ref();

        insertion_ctx.solution.routes.iter_mut().for_each(|route_ctx| {
            advance_departure_time(route_ctx, activity, transport, true, &self.state_keys);
        });

        problem.goal.accept_solution_state(&mut insertion_ctx.solution);

        insertion_ctx
    }
}