-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathgcc_sort_pointers.cpp
122 lines (104 loc) · 2.93 KB
/
gcc_sort_pointers.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
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
#ifndef START
#define START 1000
#endif
#ifndef END
#define END 10000000
#endif
#include <string>
#include <iterator>
#include <iostream>
#include <algorithm>
#include <array>
#include <cstdlib>
#include <ctime>
#include <iomanip>
#include <vector>
#include "measurements.h"
class person {
public:
long id;
long age;
person() : age(std::rand()), id(std::rand()){};
};
typedef person sorted_type;
extern "C" { int qsort_AVX2(sorted_type **, sorted_type **, unsigned long n); }
bool myfunction(person *i, person *j) { return i->id < j->id; }
static void sorts(person **d, int n) {
if (n <= 1)
return;
long i, j;
for (i = 1; i < n; i++) {
person *tmp = d[i];
for (j = i; j >= 1 && tmp->id < d[j - 1]->id; j--)
d[j] = d[j - 1];
d[j] = tmp;
}
}
void my_qsort_AVX2(sorted_type **unsorted_array, sorted_type **tmp_array,
unsigned long n) {
int new_n;
while (n > 32) {
new_n = qsort_AVX2(unsorted_array, tmp_array, n);
n = n - new_n - 1;
my_qsort_AVX2(&unsorted_array[n + 1], tmp_array, new_n);
}
sorts(unsorted_array, n);
}
#ifndef REP
#define REP (10000)
#endif
int main() {
std::srand(std::time(0));
for (int n_elems = START; n_elems <= END; n_elems *= 10) {
std::cout << "Number of sorted elements:\t" << n_elems << " \n";
// Allocate space
std::vector<sorted_type *> *arr = new std::vector<sorted_type *>(n_elems);
std::vector<sorted_type *> *tmp = new std::vector<sorted_type *>(n_elems);
if (arr == NULL || tmp == NULL) {
std::cout << "Allocation failed.\n";
if (arr)
delete arr;
return 1;
}
// Direct point to the vector
sorted_type **a = (sorted_type **)&*arr->begin();
sorted_type **t = (sorted_type **)&*tmp->begin();
double qst_avg = 0;
double stl_avg = 0;
// Warmup
for (auto &i : *arr)
i = new person;
std::sort(arr->begin(), arr->end(), myfunction);
for (auto &i : *arr) {
delete i;
i = new person;
}
my_qsort_AVX2(a, t, n_elems);
for (int c = 0; c < REP; c++) {
// Populate random data
for (auto &i : *arr) {
delete i;
i = new person;
}
MEASURE({ std::sort(arr->begin(), arr->end(), myfunction); });
stl_avg += RDTSC_total_clk;
for (auto &i : *arr) {
delete i;
i = new person;
}
MEASURE({ my_qsort_AVX2(a, t, n_elems); });
qst_avg += RDTSC_total_clk;
}
for (auto &i : *arr) {
delete i;
}
stl_avg /= REP;
qst_avg /= REP;
std::cout << "STL sort\tTotal cycles: " << std::fixed << stl_avg
<< "\tCycles/Element: " << stl_avg / n_elems << '\n';
std::cout << "AVX sort\tTotal cycles: " << std::fixed << qst_avg
<< "\tCycles/Element: " << qst_avg / n_elems << '\n';
delete arr;
delete tmp;
}
}