1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
use crate::models::common::{Duration, Location, Schedule, TimeWindow};
use crate::models::problem::{Actor, Job, Multi, Single};
use crate::models::solution::Tour;
use crate::utils::compare_shared;
use std::hash::{Hash, Hasher};
use std::sync::Arc;
#[derive(Clone, Debug)]
pub struct Place {
pub location: Location,
pub duration: Duration,
pub time: TimeWindow,
}
pub struct Activity {
pub place: Place,
pub schedule: Schedule,
pub job: Option<Arc<Single>>,
}
pub struct Route {
pub actor: Arc<Actor>,
pub tour: Tour,
}
impl Route {
pub fn deep_copy(&self) -> Self {
Self { actor: self.actor.clone(), tour: self.tour.deep_copy() }
}
}
impl PartialEq<Route> for Route {
fn eq(&self, other: &Route) -> bool {
&*self as *const Route == &*other as *const Route
}
}
impl Eq for Route {}
impl Hash for Route {
fn hash<H: Hasher>(&self, state: &mut H) {
let address = &*self as *const Route;
address.hash(state);
}
}
impl Activity {
pub fn new_with_job(job: Arc<Single>) -> Self {
Activity {
place: Place { location: 0, duration: 0.0, time: TimeWindow { start: 0.0, end: std::f64::MAX } },
schedule: Schedule { arrival: 0.0, departure: 0.0 },
job: Some(job),
}
}
pub fn deep_copy(&self) -> Self {
Self {
place: Place {
location: self.place.location,
duration: self.place.duration,
time: self.place.time.clone(),
},
schedule: self.schedule.clone(),
job: self.job.clone(),
}
}
pub fn has_same_job(&self, job: &Job) -> bool {
match self.retrieve_job() {
Some(j) => match (&j, job) {
(Job::Multi(lhs), Job::Multi(rhs)) => compare_shared(&lhs, rhs),
(Job::Single(lhs), Job::Single(rhs)) => compare_shared(&lhs, rhs),
_ => false,
},
_ => false,
}
}
pub fn retrieve_job(&self) -> Option<Job> {
match self.job.as_ref() {
Some(single) => Multi::roots(single).map(Job::Multi).or_else(|| Some(Job::Single(single.clone()))),
_ => None,
}
}
}