forked from 1a1a11a/libCacheSim
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathreqRate.cpp
More file actions
72 lines (58 loc) · 1.88 KB
/
reqRate.cpp
File metadata and controls
72 lines (58 loc) · 1.88 KB
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
#include "reqRate.h"
namespace traceAnalyzer {
using namespace std;
void ReqRate::add_req(request_t *req) {
if (unlikely(next_window_ts_ == -1)) {
next_window_ts_ = (int64_t)req->clock_time + time_window_;
}
assert(next_window_ts_ != -1);
window_n_req_ += 1;
window_n_byte_ += req->obj_size;
if (req->first_seen_in_window) window_n_obj_ += 1;
// if (window_seen_obj_.find(req->obj_id) == window_seen_obj_.end()) {
// window_seen_obj_.insert(req->obj_id);
// }
if (req->compulsory_miss) {
window_compulsory_miss_obj_ += 1;
}
while (req->clock_time >= next_window_ts_) {
req_rate_.push_back(window_n_req_);
byte_rate_.push_back(window_n_byte_);
obj_rate_.push_back(window_n_obj_);
first_seen_obj_rate_.push_back(window_compulsory_miss_obj_);
window_n_req_ = 0;
window_n_byte_ = 0;
window_n_obj_ = 0;
window_compulsory_miss_obj_ = 0;
// window_seen_obj_.clear();
next_window_ts_ += time_window_;
}
}
void ReqRate::dump(const string &path_base) {
ofstream ofs(path_base + ".reqRate_w" + to_string(time_window_),
ios::out | ios::trunc);
ofs << "# " << path_base << "\n";
ofs << "# req rate - time window " << time_window_ << " second\n";
for (auto &n_req : req_rate_) {
ofs << n_req / time_window_ << ",";
}
ofs << "\n";
ofs << "# byte rate - time window " << time_window_ << " second\n";
for (auto &n_byte : byte_rate_) {
ofs << n_byte / time_window_ << ",";
}
ofs << "\n";
ofs << "# obj rate - time window " << time_window_ << " second\n";
for (auto &n_obj : obj_rate_) {
ofs << n_obj / time_window_ << ",";
}
ofs << "\n";
ofs << "# first seen obj (cold miss) rate - time window " << time_window_
<< " second\n";
for (auto &n_obj : first_seen_obj_rate_) {
ofs << n_obj / time_window_ << ",";
}
ofs << "\n";
ofs.close();
}
}; // namespace traceAnalyzer