-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCoarseGrain.cpp
73 lines (56 loc) · 3.24 KB
/
CoarseGrain.cpp
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
#include "CoarseGrain.hpp"
CoarseGrain::CoarseGrain(Job::time_instant deadline)
{
d = deadline;
D = deadline/Job::time_instant(100);
}
void CoarseGrain::min(std::ofstream &ofs, Process &p, std::string argv)
{
while (D>tol && it<=max_it && diff1>=1 && diff2>=1) {
ofs << "Now the coarse grain method begins. Given a delta, we want to select the application that \r\n provides the minimum cost if we add cores and the one that \r\n provides the maximum saving if we remove cores. \r\n \r\n";
std::pair<unsigned int, unsigned int> maxmin = p.delta(D);
diff1 = p[maxmin.first]->get_n_core() - p[maxmin.first]->get_n1();
diff2 = p[maxmin.second]->get_n2() - p[maxmin.second]->get_n_core();
std::pair<double,double> costs = p.evaluate_costs(maxmin.first, maxmin.second);
ofs << "Using delta = " << D << " application " << maxmin.first << " implies a saving of " << p[maxmin.first]->get_weight()*(p[maxmin.first]->get_n_core()-p[maxmin.first]->get_n1()) << "; \r\n";
ofs << "application " << maxmin.first << " implies a saving of " << p[maxmin.second]->get_weight()*(p[maxmin.second]->get_n1()-p[maxmin.second]->get_n_core()) << ".\r\n";
// costs = (old_cost, new_cost)
ofs << "Old total cost " << costs.first << "\r\n";
ofs << "New total cost " << costs.second << "\r\n";
// if we can save something, do that
if (costs.first > costs.second){
ofs << "Since the new cost is less than the old one, we proceed with the delta method, considering every time half of the previous delta. \r\n \r\n";
while (costs.first > costs.second && p.total_real_time() < d){
p.reset_core_dline(maxmin.first, maxmin.second, D);
D=D/2;
maxmin = p.delta(D);
costs = p.evaluate_costs(maxmin.first, maxmin.second);
ofs << "Using delta = " << D << " application " << maxmin.first << " implies a saving of " << p[maxmin.first]->get_weight()*(p[maxmin.first]->get_n_core()-p[maxmin.first]->get_n1()) << "; \r\n";
ofs << "while application " << maxmin.first << " implies a saving of " << p[maxmin.second]->get_weight()*(p[maxmin.second]->get_n1()-p[maxmin.second]->get_n_core()) << ".\r\n";
ofs << "Old total cost " << costs.first << "\r\n";
ofs << "New total cost " << costs.second << "\r\n \r\n";
}
ofs << "After coarse grain method the total cost is " << p.total_cost() << "\r\n \r\n";
ofs << "Total deadline: " << d << " and total_real_time: " << p.total_real_time() << "\r\n";
for (unsigned int k=0; k<p.size(); k++)
ofs << "Application " << k+1 << " nr. of cores: " << p[k]->get_n_core() << "\r\n";
ofs << "\r\n";
ofs << "Now we start the fine grain search with the " << argv << " method. \r\n \r\n";
if (argv == "weights")
fine_grain = new FineGrainWeights();
else
fine_grain = new FineGrainDerivative();
fine_grain->set_weights(p, ofs);
time_point start = std::chrono::system_clock::now();
fine_grain->find_min(p, ofs);
time_point finish = std::chrono::system_clock::now();
help::time_consumption (start, finish, ofs);
delete fine_grain;
break; // if we already have added ore removed just one core at a time, do not use delta/2
}
else {
D=D/2;
}
it++;
}
}