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
use itertools::Itertools;
use super::{AggregateRequestBound, RequestBound};
use crate::time::{Duration, Service};
#[derive(Clone, Debug)]
pub struct Aggregate<T> {
individual: Vec<T>,
}
impl<T> Aggregate<T> {
pub fn new(components: Vec<T>) -> Self {
Aggregate {
individual: components,
}
}
}
impl<T: RequestBound> RequestBound for Aggregate<T> {
fn service_needed(&self, delta: Duration) -> Service {
self.individual
.iter()
.map(|rbf| rbf.service_needed(delta))
.sum()
}
fn least_wcet_in_interval(&self, delta: Duration) -> Service {
self.individual
.iter()
.map(|rbf| rbf.least_wcet_in_interval(delta))
.min()
.unwrap_or_else(Service::none)
}
fn steps_iter<'a>(&'a self) -> Box<dyn Iterator<Item = Duration> + 'a> {
Box::new(
self.individual
.iter()
.map(|rbf| rbf.steps_iter())
.kmerge()
.dedup(),
)
}
fn job_cost_iter<'a>(&'a self, delta: Duration) -> Box<dyn Iterator<Item = Service> + 'a> {
Box::new(
self.individual
.iter()
.map(|rbf| rbf.job_cost_iter(delta))
.kmerge(),
)
}
}
impl<T: RequestBound> AggregateRequestBound for Aggregate<T> {
fn service_needed_by_n_jobs_per_component(&self, delta: Duration, max_jobs: usize) -> Service {
self.individual
.iter()
.map(|rbf| rbf.service_needed_by_n_jobs(delta, max_jobs))
.sum()
}
}