diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/igt_stats.c | 9 | ||||
-rw-r--r-- | lib/igt_stats.h | 1 | ||||
-rw-r--r-- | lib/tests/Makefile.am | 2 | ||||
-rw-r--r-- | lib/tests/igt_stats.c | 33 |
4 files changed, 44 insertions, 1 deletions
diff --git a/lib/igt_stats.c b/lib/igt_stats.c index 20db806d..65c0ac62 100644 --- a/lib/igt_stats.c +++ b/lib/igt_stats.c @@ -22,6 +22,8 @@ * */ +#include <math.h> + #include "igt_core.h" #include "igt_stats.h" @@ -86,3 +88,10 @@ double igt_stats_get_variance(igt_stats_t *stats) return stats->variance; } + +double igt_stats_get_std_deviation(igt_stats_t *stats) +{ + igt_stats_knuth_mean_variance(stats); + + return sqrt(stats->variance); +} diff --git a/lib/igt_stats.h b/lib/igt_stats.h index acb86a6b..371def33 100644 --- a/lib/igt_stats.h +++ b/lib/igt_stats.h @@ -37,3 +37,4 @@ void igt_stats_fini(igt_stats_t *stats); void igt_stats_push(igt_stats_t *stats, uint64_t value); double igt_stats_get_mean(igt_stats_t *stats); double igt_stats_get_variance(igt_stats_t *stats); +double igt_stats_get_std_deviation(igt_stats_t *stats); diff --git a/lib/tests/Makefile.am b/lib/tests/Makefile.am index e59065bb..938d2ab0 100644 --- a/lib/tests/Makefile.am +++ b/lib/tests/Makefile.am @@ -15,5 +15,5 @@ AM_CFLAGS = $(DRM_CFLAGS) $(CWARNFLAGS) \ LDADD = ../libintel_tools.la $(PCIACCESS_LIBS) $(DRM_LIBS) $(LIBUNWIND_LIBS) -LDADD += $(CAIRO_LIBS) $(LIBUDEV_LIBS) $(GLIB_LIBS) +LDADD += $(CAIRO_LIBS) $(LIBUDEV_LIBS) $(GLIB_LIBS) -lm AM_CFLAGS += $(CAIRO_CFLAGS) $(LIBUDEV_CFLAGS) $(GLIB_CFLAGS) diff --git a/lib/tests/igt_stats.c b/lib/tests/igt_stats.c index c20b4537..172e4b32 100644 --- a/lib/tests/igt_stats.c +++ b/lib/tests/igt_stats.c @@ -45,7 +45,40 @@ static void test_mean(void) igt_stats_fini(&stats); } +/* + * Taken from the "Basic examples" section of: + * https://en.wikipedia.org/wiki/Standard_deviation + */ +static void test_std_deviation(void) +{ + igt_stats_t stats; + double mean, variance, std_deviation; + + igt_stats_init(&stats, 8); + + igt_stats_push(&stats, 2); + igt_stats_push(&stats, 4); + igt_stats_push(&stats, 4); + igt_stats_push(&stats, 4); + igt_stats_push(&stats, 5); + igt_stats_push(&stats, 5); + igt_stats_push(&stats, 7); + igt_stats_push(&stats, 9); + + mean = igt_stats_get_mean(&stats); + igt_assert(mean == (2 + 3 * 4 + 2 * 5 + 7 + 9) / 8.); + + variance = igt_stats_get_variance(&stats); + igt_assert(variance == 4); + + std_deviation = igt_stats_get_std_deviation(&stats); + igt_assert(std_deviation == 2); + + igt_stats_fini(&stats); +} + igt_simple_main { test_mean(); + test_std_deviation(); } |