qdist: add module to represent frequency distributions of data
commitbf3afd5f419a2054bf03d963bdd223fbb27b72d2
authorEmilio G. Cota <cota@braap.org>
Wed, 8 Jun 2016 18:55:26 +0000 (8 14:55 -0400)
committerRichard Henderson <rth@twiddle.net>
Sat, 11 Jun 2016 23:10:19 +0000 (11 23:10 +0000)
treed59bfaeb23c75fbf3528a01a07b51649c12d7541
parent42bd32287f3a18d823f2258b813824a39ed7c6d9
qdist: add module to represent frequency distributions of data

Sometimes it is useful to have a quick histogram to represent a certain
distribution -- for example, when investigating a performance regression
in a hash table due to inadequate hashing.

The appended allows us to easily represent a distribution using Unicode
characters. Further, the data structure keeping track of the distribution
is so simple that obtaining its values for off-line processing is trivial.

Example, taking the last 10 commits to QEMU:

 Characters in commit title  Count
-----------------------------------
                         39      1
                         48      1
                         53      1
                         54      2
                         57      1
                         61      1
                         67      1
                         78      1
                         80      1
qdist_init(&dist);
qdist_inc(&dist, 39);
[...]
qdist_inc(&dist, 80);

char *str = qdist_pr(&dist, 9, QDIST_PR_LABELS);
// -> [39.0,43.6)▂▂ █▂ ▂ ▄[75.4,80.0]
g_free(str);

char *str = qdist_pr(&dist, 4, QDIST_PR_LABELS);
// -> [39.0,49.2)▁█▁▁[69.8,80.0]
g_free(str);

Reviewed-by: Richard Henderson <rth@twiddle.net>
Signed-off-by: Emilio G. Cota <cota@braap.org>
Message-Id: <1465412133-3029-9-git-send-email-cota@braap.org>
Signed-off-by: Richard Henderson <rth@twiddle.net>
include/qemu/qdist.h [new file with mode: 0644]
util/Makefile.objs
util/qdist.c [new file with mode: 0644]