forked from RedisLabs/memtier_benchmark
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_stats_types.h
201 lines (179 loc) · 6.57 KB
/
run_stats_types.h
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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
/*
* Copyright (C) 2011-2017 Redis Labs Ltd.
*
* This file is part of memtier_benchmark.
*
* memtier_benchmark is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, version 2.
*
* memtier_benchmark is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with memtier_benchmark. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef MEMTIER_BENCHMARK_RUN_STATS_TYPES_H
#define MEMTIER_BENCHMARK_RUN_STATS_TYPES_H
#define LATENCY_HDR_MIN_VALUE 10
#define LATENCY_HDR_MAX_VALUE 60000000 ## LL
#define LATENCY_HDR_SIGDIGTS 3
#define LATENCY_HDR_SEC_MIN_VALUE 10
#define LATENCY_HDR_SEC_MAX_VALUE 1000000 ## LL
#define LATENCY_HDR_SEC_SIGDIGTS 2
#define LATENCY_HDR_RESULTS_MULTIPLIER 1000
#define LATENCY_HDR_GRANULARITY 10
#include "deps/hdr_histogram/hdr_histogram.h"
#include "memtier_benchmark.h"
// A wrapper around hdr_histogram that handles allocation, deallocation
// and deep copy.
//
// TODO: In the future we may want to consider extending this wrapper
// further to expose all hdr functions as native methods and avoid the
// casting operator completely.
class safe_hdr_histogram {
hdr_histogram *m_hdr;
public:
safe_hdr_histogram() {
hdr_init(
LATENCY_HDR_MIN_VALUE, // Minimum value
LATENCY_HDR_SEC_MAX_VALUE, // Maximum value
LATENCY_HDR_SEC_SIGDIGTS, // Number of significant figures
&m_hdr);
}
virtual ~safe_hdr_histogram() {
hdr_close(m_hdr);
}
safe_hdr_histogram(const safe_hdr_histogram& other) {
hdr_init(
LATENCY_HDR_MIN_VALUE, // Minimum value
LATENCY_HDR_SEC_MAX_VALUE, // Maximum value
LATENCY_HDR_SEC_SIGDIGTS, // Number of significant figures
&m_hdr);
hdr_add(m_hdr, other.m_hdr);
}
safe_hdr_histogram& operator=(const safe_hdr_histogram& other) {
if (this != &other) {
hdr_reset(m_hdr);
hdr_add(m_hdr, other.m_hdr);
}
return *this;
}
// Cast safe_hdr_historgram to hdr_histogram to make it transparent
operator hdr_histogram* () const { return m_hdr; }
};
class one_sec_cmd_stats {
public:
unsigned long int m_bytes_rx;
unsigned long int m_bytes_tx;
unsigned long int m_ops;
unsigned int m_hits;
unsigned int m_misses;
unsigned int m_moved;
unsigned int m_ask;
unsigned long long int m_total_latency;
std::vector<double> summarized_quantile_values;
double m_avg_latency;
double m_min_latency;
double m_max_latency;
one_sec_cmd_stats();
void reset();
void merge(const one_sec_cmd_stats& other);
void summarize_quantiles(safe_hdr_histogram histogram, std::vector<float> quantiles);
void update_op(unsigned int bytes_rx, unsigned int bytes_tx, unsigned int latency);
void update_op(unsigned int bytes_rx, unsigned int bytes_tx, unsigned int latency, unsigned int hits, unsigned int misses);
void update_moved_op(unsigned int bytes_rx, unsigned int bytes_tx, unsigned int latency);
void update_ask_op(unsigned int bytes_rx, unsigned int bytes_tx, unsigned int latency);
};
class one_second_stats; // forward declaration
class ar_one_sec_cmd_stats {
public:
ar_one_sec_cmd_stats() {;}
void setup(size_t n_arbitrary_commands);
void reset();
void merge(const ar_one_sec_cmd_stats& other);
unsigned long int ops();
unsigned long int bytes();
unsigned long long int total_latency();
size_t size() const;
one_sec_cmd_stats& at(std::size_t idx) { return m_commands.at(idx); }
const one_sec_cmd_stats& at(std::size_t idx) const { return m_commands.at(idx); }
// array subscript operator
one_sec_cmd_stats& operator[](std::size_t idx) { return m_commands[idx]; }
const one_sec_cmd_stats& operator[](std::size_t idx) const { return m_commands[idx]; }
std::vector<one_sec_cmd_stats> m_commands;
};
class one_second_stats {
public:
unsigned int m_second; // from start of test
one_sec_cmd_stats m_set_cmd;
one_sec_cmd_stats m_get_cmd;
one_sec_cmd_stats m_wait_cmd;
one_sec_cmd_stats m_total_cmd;
ar_one_sec_cmd_stats m_ar_commands;
one_second_stats(unsigned int second);
void setup_arbitrary_commands(size_t n_arbitrary_commands);
void reset(unsigned int second);
void summarize();
void merge(const one_second_stats& other);
};
class totals_cmd {
public:
double m_ops_sec;
double m_bytes_sec;
double m_bytes_sec_rx;
double m_bytes_sec_tx;
double m_moved_sec;
double m_ask_sec;
double m_latency;
unsigned long int m_ops;
totals_cmd();
void add(const totals_cmd& other);
void aggregate_average(size_t stats_size);
void summarize(const one_sec_cmd_stats& other, unsigned long test_duration_usec);
};
class ar_totals_cmd {
public:
ar_totals_cmd() {;}
void setup(size_t n_arbitrary_commands);
void add(const ar_totals_cmd& other);
void aggregate_average(size_t stats_size);
void summarize(const ar_one_sec_cmd_stats& other, unsigned long test_duration_usec);
size_t size() const;
totals_cmd& at(std::size_t idx) { return m_commands.at(idx); }
const totals_cmd& at(std::size_t idx) const { return m_commands.at(idx); }
// array subscript operator
totals_cmd& operator[](std::size_t idx) { return m_commands[idx]; }
const totals_cmd& operator[](std::size_t idx) const { return m_commands[idx]; }
std::vector<totals_cmd> m_commands;
};
class totals {
public:
totals_cmd m_set_cmd;
totals_cmd m_get_cmd;
totals_cmd m_wait_cmd;
totals_cmd m_total_cmd;
ar_totals_cmd m_ar_commands;
safe_hdr_histogram latency_histogram;
double m_ops_sec;
double m_bytes_sec;
double m_bytes_sec_rx;
double m_bytes_sec_tx;
double m_hits_sec;
double m_misses_sec;
double m_moved_sec;
double m_ask_sec;
unsigned long long int m_latency;
// number of bytes received
unsigned long int m_bytes_rx;
// number of bytes sent
unsigned long int m_bytes_tx;
unsigned long int m_ops;
totals();
void setup_arbitrary_commands(size_t n_arbitrary_commands);
void add(const totals& other);
void update_op(unsigned long int bytes_rx, unsigned long int bytes_tx, unsigned int latency);
};
#endif //MEMTIER_BENCHMARK_RUN_STATS_TYPES_H