diff options
| author | Damien Lespiau <damien.lespiau@intel.com> | 2015-06-25 23:59:21 +0100 | 
|---|---|---|
| committer | Damien Lespiau <damien.lespiau@intel.com> | 2015-06-27 16:03:27 +0100 | 
| commit | 515cec1210764241153f5d46d70ba5e943201b14 (patch) | |
| tree | 4b7866c6de7bfbf32423bbbe30dde0af78bcefb8 | |
| parent | 05c10f940f9df3a5b24e2a0b476052fbe5a22282 (diff) | |
stats: Add a way to retrieve the standard deviation
Signed-off-by: Damien Lespiau <damien.lespiau@intel.com>
| -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 | ||||
| -rw-r--r-- | tools/Makefile.am | 2 | ||||
| -rw-r--r-- | tools/quick_dump/Makefile.am | 1 | 
6 files changed, 46 insertions, 2 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();  } diff --git a/tools/Makefile.am b/tools/Makefile.am index 04bfd128..8288248a 100644 --- a/tools/Makefile.am +++ b/tools/Makefile.am @@ -8,5 +8,5 @@ endif  AM_CPPFLAGS = -I$(top_srcdir) -I$(top_srcdir)/lib  AM_CFLAGS = $(DRM_CFLAGS) $(PCIACCESS_CFLAGS) $(CWARNFLAGS) $(CAIRO_CFLAGS) $(LIBUNWIND_CFLAGS) -LDADD = $(top_builddir)/lib/libintel_tools.la $(DRM_LIBS) $(PCIACCESS_LIBS) $(CAIRO_LIBS) $(LIBUDEV_LIBS) $(LIBUNWIND_LIBS) +LDADD = $(top_builddir)/lib/libintel_tools.la $(DRM_LIBS) $(PCIACCESS_LIBS) $(CAIRO_LIBS) $(LIBUDEV_LIBS) $(LIBUNWIND_LIBS) -lm diff --git a/tools/quick_dump/Makefile.am b/tools/quick_dump/Makefile.am index 3d0bd230..0643a817 100644 --- a/tools/quick_dump/Makefile.am +++ b/tools/quick_dump/Makefile.am @@ -15,6 +15,7 @@ I915ChipsetPython_la_LIBADD =			\  	$(CAIRO_LIBS)				\  	$(LIBUNWIND_LIBS)			\  	-lrt					\ +	-lm					\  	$(NULL)  chipset.py: chipset_wrap_python.c | 
