2017-10-11 19:19:10 +08:00
|
|
|
#include <iostream>
|
2016-11-25 17:43:34 +08:00
|
|
|
#include <random>
|
|
|
|
#include <thread>
|
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
#include <benchmark/benchmark_api.h>
|
|
|
|
#include <glog/logging.h>
|
2017-07-06 19:53:39 +08:00
|
|
|
#include "gflags/gflags.h"
|
2017-06-21 17:29:13 +08:00
|
|
|
|
2016-11-25 17:43:34 +08:00
|
|
|
#include "data_structures/concurrent/concurrent_map.hpp"
|
2017-02-19 01:03:48 +08:00
|
|
|
#include "utils/random/random_generator.hpp"
|
2016-11-25 17:43:34 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
ConcurrentMap Benchmark Test:
|
|
|
|
- tests time of Insertion, Deletion and Find
|
|
|
|
|
|
|
|
- benchmarks time for total execution with operation percentages
|
|
|
|
*/
|
|
|
|
|
|
|
|
using utils::random::NumberGenerator;
|
|
|
|
using utils::random::PairGenerator;
|
|
|
|
|
|
|
|
using IntegerGenerator = NumberGenerator<std::uniform_int_distribution<int>,
|
|
|
|
std::default_random_engine, int>;
|
|
|
|
|
|
|
|
// Global Arguments
|
|
|
|
int MAX_ELEMENTS = 1 << 20, MULTIPLIER = 2;
|
|
|
|
int THREADS, INSERT_PERC, DELETE_PERC, CONTAINS_PERC, RANGE_START, RANGE_END;
|
|
|
|
|
|
|
|
// ConcurrentMap Becnhmark Test using percentages for Insert, Delete, Find
|
|
|
|
template <class K, class V>
|
2016-12-22 22:51:16 +08:00
|
|
|
static void Rape(benchmark::State &state, ConcurrentMap<int, int> *map,
|
2017-02-18 18:54:37 +08:00
|
|
|
const std::vector<std::pair<K, V>> &elements) {
|
|
|
|
int number_of_elements = state.range(0);
|
|
|
|
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
auto accessor = map->access();
|
|
|
|
|
|
|
|
for (int start = 0; start < state.range(0); start++) {
|
|
|
|
float current_percentage = (float)start / (float)number_of_elements * 100;
|
|
|
|
if (current_percentage < (float)INSERT_PERC) {
|
|
|
|
accessor.insert(elements[start].first, elements[start].second);
|
|
|
|
} else if (current_percentage < (float)CONTAINS_PERC + INSERT_PERC) {
|
|
|
|
accessor.contains(elements[start].first);
|
|
|
|
} else {
|
|
|
|
accessor.remove(elements[start].first);
|
|
|
|
}
|
2016-11-25 17:43:34 +08:00
|
|
|
}
|
2017-02-18 18:54:37 +08:00
|
|
|
}
|
2016-11-25 17:43:34 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
state.SetComplexityN(state.range(0));
|
2016-11-25 17:43:34 +08:00
|
|
|
}
|
|
|
|
|
2016-12-22 22:51:16 +08:00
|
|
|
auto BM_Rape = [](benchmark::State &state, auto *map, auto &elements) {
|
2017-02-18 18:54:37 +08:00
|
|
|
Rape(state, map, elements);
|
2016-11-25 17:43:34 +08:00
|
|
|
};
|
|
|
|
|
2017-07-06 19:53:39 +08:00
|
|
|
DEFINE_int32(insert, 50, "Insertions percentage");
|
|
|
|
DEFINE_int32(delete, 20, "Deletions percentage");
|
|
|
|
DEFINE_int32(find, 30, "Find percentage");
|
|
|
|
DEFINE_int32(start, 0, "Range start");
|
|
|
|
DEFINE_int32(end, 1000000000, "Range end");
|
|
|
|
DEFINE_int32(threads, 1, "Number of threads");
|
|
|
|
|
2016-11-25 17:43:34 +08:00
|
|
|
/*
|
|
|
|
Commandline Arguments Parsing
|
|
|
|
|
|
|
|
Arguments:
|
|
|
|
* Insertion percentage (0-100)
|
|
|
|
-insert number(int)
|
|
|
|
|
|
|
|
* Deletion percentage (0-100)
|
|
|
|
-delete number(int)
|
|
|
|
|
|
|
|
* Find percentage (0-100)
|
|
|
|
-find number(int)
|
|
|
|
|
|
|
|
* Integer Range Minimum
|
|
|
|
-start number
|
|
|
|
|
|
|
|
* Integer Range Maximum
|
|
|
|
- end number
|
|
|
|
|
|
|
|
* Number of threads
|
|
|
|
-threads number
|
|
|
|
*/
|
2017-07-06 19:53:39 +08:00
|
|
|
void parse_arguments() {
|
|
|
|
INSERT_PERC = FLAGS_insert;
|
|
|
|
DELETE_PERC = FLAGS_delete;
|
|
|
|
CONTAINS_PERC = FLAGS_find;
|
2017-02-18 18:54:37 +08:00
|
|
|
|
|
|
|
if (INSERT_PERC + DELETE_PERC + CONTAINS_PERC != 100) {
|
|
|
|
std::cout << "Invalid percentage" << std::endl;
|
|
|
|
std::cout << "Percentage must sum to 100" << std::endl;
|
|
|
|
exit(-1);
|
|
|
|
}
|
2016-11-25 17:43:34 +08:00
|
|
|
|
2017-07-06 19:53:39 +08:00
|
|
|
RANGE_START = FLAGS_start;
|
|
|
|
RANGE_END = FLAGS_end;
|
2016-11-28 23:39:25 +08:00
|
|
|
|
2017-07-06 19:53:39 +08:00
|
|
|
THREADS = std::min(FLAGS_threads,
|
|
|
|
static_cast<int>(std::thread::hardware_concurrency()));
|
2016-11-25 17:43:34 +08:00
|
|
|
}
|
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
int main(int argc, char **argv) {
|
2017-07-06 19:53:39 +08:00
|
|
|
benchmark::Initialize(&argc, argv);
|
|
|
|
parse_arguments();
|
2017-06-21 17:29:13 +08:00
|
|
|
google::InitGoogleLogging(argv[0]);
|
2016-11-25 17:43:34 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
IntegerGenerator int_gen(RANGE_START, RANGE_END);
|
|
|
|
PairGenerator<IntegerGenerator, IntegerGenerator> pair_gen(&int_gen,
|
|
|
|
&int_gen);
|
2016-11-25 17:43:34 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
ConcurrentMap<int, int> map;
|
|
|
|
auto elements = utils::random::generate_vector(pair_gen, MAX_ELEMENTS);
|
2016-11-25 17:43:34 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
benchmark::RegisterBenchmark("Rape", BM_Rape, &map, elements)
|
|
|
|
->RangeMultiplier(MULTIPLIER)
|
|
|
|
->Range(1, MAX_ELEMENTS)
|
|
|
|
->Complexity(benchmark::oN)
|
|
|
|
->Threads(THREADS);
|
2016-11-25 17:43:34 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
benchmark::RunSpecifiedBenchmarks();
|
2016-11-25 17:43:34 +08:00
|
|
|
|
2017-02-18 18:54:37 +08:00
|
|
|
return 0;
|
2016-11-25 17:43:34 +08:00
|
|
|
}
|