From b881c7aabb0c22cf7531cb66a8d4bfa40cf0f109 Mon Sep 17 00:00:00 2001 From: Jean-Roland Date: Wed, 20 Dec 2023 14:58:18 +0100 Subject: [PATCH 1/2] fix: use wall time in throughput test --- examples/universal/z_sub_thr.cxx | 28 +++++++++++++++------------- 1 file changed, 15 insertions(+), 13 deletions(-) diff --git a/examples/universal/z_sub_thr.cxx b/examples/universal/z_sub_thr.cxx index fb3a6b0c..fd9cf277 100644 --- a/examples/universal/z_sub_thr.cxx +++ b/examples/universal/z_sub_thr.cxx @@ -12,7 +12,7 @@ // ZettaScale Zenoh Team, // #include -#include +#include #include "../getargs.h" #include "zenoh.hxx" @@ -23,35 +23,37 @@ using namespace zenoh; struct Stats { volatile unsigned long count = 0; volatile unsigned long finished_rounds = 0; - volatile clock_t start = 0; - volatile clock_t stop = 0; - volatile clock_t end = 0; - volatile clock_t first_start = 0; + std::chrono::_V2::steady_clock::time_point start = {}; + std::chrono::_V2::steady_clock::time_point first_start = {}; + std::chrono::_V2::steady_clock::time_point end = {}; void operator()(const Sample &) { if (count == 0) { - start = clock(); - if (!first_start) { + start = std::chrono::steady_clock::now(); + if (first_start == std::chrono::_V2::steady_clock::time_point()) { first_start = start; } count++; } else if (count < N) { count++; } else { - stop = clock(); finished_rounds++; - printf("%f msg/s\n", N * (double)CLOCKS_PER_SEC / (double)(stop - start)); + auto elapsed_us = + std::chrono::duration_cast(std::chrono::steady_clock::now() - start).count(); + std::cout << static_cast(N) * 1000000.0 / static_cast(elapsed_us) << " msg/s\n"; count = 0; } } - void operator()() { end = clock(); } + void operator()() { end = std::chrono::steady_clock::now(); } void print() const { - const double elapsed = (double)(end - first_start) / (double)CLOCKS_PER_SEC; + auto elapsed_s = + static_cast(std::chrono::duration_cast(end - first_start).count()) / + 1000000.0; const unsigned long sent_messages = N * finished_rounds + count; - printf("Sent %ld messages over %f seconds (%f msg/s)\n", sent_messages, elapsed, - (double)sent_messages / elapsed); + std::cout << "Sent " << sent_messages << " messages over " << elapsed_s << " seconds (" + << static_cast(sent_messages) / elapsed_s << " msg/s)\n"; } }; From cc3c5ec301c46e15e7d85b397e4d8f569d9744c3 Mon Sep 17 00:00:00 2001 From: Jean-Roland Date: Wed, 20 Dec 2023 15:13:34 +0100 Subject: [PATCH 2/2] fix: type portability --- examples/universal/z_sub_thr.cxx | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/examples/universal/z_sub_thr.cxx b/examples/universal/z_sub_thr.cxx index fd9cf277..7a62492c 100644 --- a/examples/universal/z_sub_thr.cxx +++ b/examples/universal/z_sub_thr.cxx @@ -23,14 +23,14 @@ using namespace zenoh; struct Stats { volatile unsigned long count = 0; volatile unsigned long finished_rounds = 0; - std::chrono::_V2::steady_clock::time_point start = {}; - std::chrono::_V2::steady_clock::time_point first_start = {}; - std::chrono::_V2::steady_clock::time_point end = {}; + std::chrono::steady_clock::time_point start = {}; + std::chrono::steady_clock::time_point first_start = {}; + std::chrono::steady_clock::time_point end = {}; void operator()(const Sample &) { if (count == 0) { start = std::chrono::steady_clock::now(); - if (first_start == std::chrono::_V2::steady_clock::time_point()) { + if (first_start == std::chrono::steady_clock::time_point()) { first_start = start; } count++;