Getting more precise timings (avoiding the overhead of linux perf. counters).

This commit is contained in:
Daniel Lemire 2019-06-03 10:59:07 -04:00
parent 5aaca27cda
commit 295e481a2e
2 changed files with 27 additions and 17 deletions

View File

@ -97,7 +97,7 @@ int main(int argc, char *argv[]) {
#endif #endif
std::vector<double> res; std::vector<double> res;
res.resize(iterations); res.resize(iterations);
printf("number of iterations %u \n", iterations);
#if !defined(__linux__) #if !defined(__linux__)
#define SQUASH_COUNTERS #define SQUASH_COUNTERS
if (justdata) { if (justdata) {
@ -122,38 +122,29 @@ int main(int argc, char *argv[]) {
unsigned long cmis0 = 0, cmis1 = 0, cmis2 = 0; unsigned long cmis0 = 0, cmis1 = 0, cmis2 = 0;
#endif #endif
bool isok = true; bool isok = true;
#ifndef SQUASH_COUNTERS
for (uint32_t i = 0; i < iterations; i++) { for (uint32_t i = 0; i < iterations; i++) {
if (verbose) { if (verbose) {
std::cout << "[verbose] iteration # " << i << std::endl; std::cout << "[verbose] iteration # " << i << std::endl;
} }
#ifndef SQUASH_COUNTERS
unified.start(); unified.start();
#endif
ParsedJson pj; ParsedJson pj;
bool allocok = pj.allocateCapacity(p.size()); bool allocok = pj.allocateCapacity(p.size());
if (!allocok) { if (!allocok) {
std::cerr << "failed to allocate memory" << std::endl; std::cerr << "failed to allocate memory" << std::endl;
return EXIT_FAILURE; return EXIT_FAILURE;
} }
#ifndef SQUASH_COUNTERS
unified.end(results); unified.end(results);
cy0 += results[0]; cy0 += results[0];
cl0 += results[1]; cl0 += results[1];
mis0 += results[2]; mis0 += results[2];
cref0 += results[3]; cref0 += results[3];
cmis0 += results[4]; cmis0 += results[4];
#endif
if (verbose) { if (verbose) {
std::cout << "[verbose] allocated memory for parsed JSON " << std::endl; std::cout << "[verbose] allocated memory for parsed JSON " << std::endl;
} }
auto start = std::chrono::steady_clock::now();
#ifndef SQUASH_COUNTERS
unified.start(); unified.start();
#endif
isok = find_structural_bits(p.data(), p.size(), pj); isok = find_structural_bits(p.data(), p.size(), pj);
#ifndef SQUASH_COUNTERS
unified.end(results); unified.end(results);
cy1 += results[0]; cy1 += results[0];
cl1 += results[1]; cl1 += results[1];
@ -165,10 +156,7 @@ int main(int argc, char *argv[]) {
break; break;
} }
unified.start(); unified.start();
#endif
isok = isok && (simdjson::SUCCESS == unified_machine(p.data(), p.size(), pj)); isok = isok && (simdjson::SUCCESS == unified_machine(p.data(), p.size(), pj));
#ifndef SQUASH_COUNTERS
unified.end(results); unified.end(results);
cy2 += results[0]; cy2 += results[0];
cl2 += results[1]; cl2 += results[1];
@ -179,12 +167,34 @@ int main(int argc, char *argv[]) {
std::cout << "Failed during stage 2" << std::endl; std::cout << "Failed during stage 2" << std::endl;
break; break;
} }
}
#endif #endif
// we do it again, this time just measuring the elapsed time
for (uint32_t i = 0; i < iterations; i++) {
if (verbose) {
std::cout << "[verbose] iteration # " << i << std::endl;
}
ParsedJson pj;
bool allocok = pj.allocateCapacity(p.size());
if (!allocok) {
std::cerr << "failed to allocate memory" << std::endl;
return EXIT_FAILURE;
}
if (verbose) {
std::cout << "[verbose] allocated memory for parsed JSON " << std::endl;
}
auto start = std::chrono::steady_clock::now();
isok = find_structural_bits(p.data(), p.size(), pj);
isok = isok && (simdjson::SUCCESS == unified_machine(p.data(), p.size(), pj));
auto end = std::chrono::steady_clock::now(); auto end = std::chrono::steady_clock::now();
std::chrono::duration<double> secs = end - start; std::chrono::duration<double> secs = end - start;
res[i] = secs.count(); res[i] = secs.count();
} if(! isok) {
std::cerr << "Could not parse. " << std::endl;
return EXIT_FAILURE;
}
}
ParsedJson pj = build_parsed_json(p); // do the parsing again to get the stats ParsedJson pj = build_parsed_json(p); // do the parsing again to get the stats
if (!pj.isValid()) { if (!pj.isValid()) {
std::cerr << "Could not parse. " << std::endl; std::cerr << "Could not parse. " << std::endl;

View File

@ -108,7 +108,7 @@ int main(int argc, char *argv[]) {
std::cerr << "can't allocate memory" << std::endl; std::cerr << "can't allocate memory" << std::endl;
return EXIT_FAILURE; return EXIT_FAILURE;
} }
int repeat = p.size() < 100 * 1000 * 1000 ? 50 : 5; int repeat = (p.size() < 1 * 1000 * 1000 ? 1000 : 10);
int volume = p.size(); int volume = p.size();
if (justdata) { if (justdata) {
printf("%-42s %20s %20s %20s %20s \n", "name", "cycles_per_byte", printf("%-42s %20s %20s %20s %20s \n", "name", "cycles_per_byte",