-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathgenerate.cpp
More file actions
125 lines (102 loc) · 3.24 KB
/
generate.cpp
File metadata and controls
125 lines (102 loc) · 3.24 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
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
#include <iostream>
#include <random>
#include <tuple>
#include <fstream>
#include <set>
using namespace std;
random_device rd;
mt19937 gen(rd());
uniform_int_distribution<uint64_t> dis(numeric_limits<uint64_t>::min(), numeric_limits<uint64_t>::max());
set<uint64_t> generated_numbers;
bool is_power_of_two(ulong x){
return (x & (x - 1)) == 0;
}
// Method for generating a tuple of integers of 64 bits (only positive)
tuple<uint64_t, uint64_t> generate_random_integers() {
uint64_t key;
// If key already exists, generate a new one
do {
key = dis(gen);
}
// Generate a random key and add to set
while(!generated_numbers.insert(key).second);
// Make tuple and return
tuple<uint64_t, uint64_t> result(key, dis(gen));
return result;
}
void generate_file(int num_to_generate) {
ofstream file;
cout << "Generating " << num_to_generate << " random integers" << endl;
cout << "Opening file... " << endl;
file.open("random_integers.txt", ios::trunc);
for(int i = 0; i < num_to_generate; i++){
auto result = generate_random_integers();
file << get<0>(result) << " " << get<1>(result) << endl;
}
file.close();
cout << "Closed file... " << endl;
}
bool keys() {
// Check if all keys are unique
return generated_numbers.size() == pow(2.0, 24.0);
}
void generate_affinity_linear(int n_threads) {
ofstream file;
cout << "Generating " << n_threads << " random integers" << endl;
cout << "Opening file... " << endl;
file.open("affinity.txt", ios::trunc);
for(int i = 0; i < n_threads; i++){
file << i << endl;
}
file.close();
cout << "Closed file... " << endl;
}
void generate_affinity_even(int n_threads) {
ofstream file;
cout << "Generating " << n_threads << " random integers" << endl;
cout << "Opening file... " << endl;
file.open("affinity.txt", ios::trunc);
for(int i = 0; i < n_threads; i++){
file << i << endl;
}
file.close();
cout << "Closed file... " << endl;
}
void generate_affinity_even(int n_threads) {
ofstream file;
cout << "Generating " << n_threads << " random integers" << endl;
cout << "Opening file... " << endl;
file.open("affinity.txt", ios::trunc);
for(int i = 0; i < n_threads; i++){
file << i * 2 << endl;
}
file.close();
cout << "Closed file... " << endl;
}
int main(int argc, char *argv[]) {
if(argc <= 1) {
cout << "Usage: " << argv[0] << " <number of tuples>" << endl;
return 1;
}
// Generate this many number of uniformly random tuples
int generate_num = stoi(argv[1]);
if(generate_num <= 0) {
cout << "Please enter a positive number" << endl;
cout << "Closing..." << endl;
return 1;
}
if (generate_num > pow(2.0, 24.0)) {
cout << "Please enter a number less than 2^24" << endl;
cout << "Closing..." << endl;
return 1;
}
if (!is_power_of_two(generate_num)){
cout << "Please enter a number that is a power of 2" << endl;
cout << "Closing..." << endl;
return 1;
}
// Generate file with random tuples of usigned 64 bit integers
generate_file(generate_num);
cout << "Generation complete..." << endl;
return 0;
}