diff options
author | Florian Dold <florian.dold@gmail.com> | 2018-08-18 15:10:39 +0200 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2018-08-18 15:10:39 +0200 |
commit | af99085b7163fdded4dfad94fd2a98231bc12209 (patch) | |
tree | c055728c186a49be04c4381bf10f890eaba482c6 /contrib | |
parent | ec8162bdf0db6282fbf507e6da72b056119c7805 (diff) |
benchmark collection awk scripts
Diffstat (limited to 'contrib')
-rw-r--r-- | contrib/benchmark/collect_ops.awk | 45 | ||||
-rw-r--r-- | contrib/benchmark/collect_urls.awk | 47 |
2 files changed, 92 insertions, 0 deletions
diff --git a/contrib/benchmark/collect_ops.awk b/contrib/benchmark/collect_ops.awk new file mode 100644 index 000000000..b34fcc723 --- /dev/null +++ b/contrib/benchmark/collect_ops.awk @@ -0,0 +1,45 @@ +# This file is part of GNUnet +# Copyright (C) 2018 GNUnet e.V. +# +# GNUnet is free software: you can redistribute it and/or modify it +# under the terms of the GNU Affero General Public License as published +# by the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# GNUnet is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + + +# Aggregate benchmarking data from multiple threads/processes +# generated by util/benchmark.c. +# +# Can be used as +# awk -f collect_ops.awk gnunet-benchmark-ops-*.txt + + +# records are of the following form: +# op <op> count <count> time_us <time_us> +{ + op[$2]["count"] += $4; + op[$2]["time_us"] += $6; +} + +function avg(s, c) { + if (c == 0) { + return 0; + } else { + return s / c; + } +} + +END { + for (x in op) { + print "op", x, "count", op[x]["count"], "time_us", op[x]["time_us"], \ + "time_avg_us", avg(op[x]["time_us"], op[x]["count"]); + } +} diff --git a/contrib/benchmark/collect_urls.awk b/contrib/benchmark/collect_urls.awk new file mode 100644 index 000000000..27424b2b8 --- /dev/null +++ b/contrib/benchmark/collect_urls.awk @@ -0,0 +1,47 @@ +# records are of the following form: +# This file is part of GNUnet +# Copyright (C) 2018 GNUnet e.V. +# +# GNUnet is free software: you can redistribute it and/or modify it +# under the terms of the GNU Affero General Public License as published +# by the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# GNUnet is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + + +# Aggregate benchmarking data from multiple threads/processes +# generated by util/benchmark.c. +# +# Can be used as +# awk -f collect_ops.awk gnunet-benchmark-ops-*.txt +# url <url> status <status> count <count> time_us <time_us> + +{ + url[$2][$4]["count"] += $6; + url[$2][$4]["time_us"] += $8; +} + +function avg(s, c) { + if (c == 0) { + return 0; + } else { + return s / c; + } +} + +END { + for (x in url) { + for (y in url[x]) { + print "url", x, "status", y, \ + "count", url[x][y]["count"], "time_us", url[x][y]["time_us"], \ + "time_avg_us", avg(url[x][y]["time_us"], url[x][y]["count"]); + } + } +} |