Message ID | 1435245703-31083-1-git-send-email-damien.lespiau@intel.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Thu, Jun 25, 2015 at 04:21:40PM +0100, Damien Lespiau wrote: > The master plan would be to get a bit more stats in it, at least the > standard deviation and confidence interval. Just need the average for > now. Definitely, I wouldn't even print the average without the std.dev and how normal the distribution is. (Otherwise the information can be very misleading.) Without them, I'd rather have the median than the mean. > +void igt_stats_push(igt_stats_t *stats, uint64_t value) > +{ > + igt_assert(stats->n_values < stats->capacity); Might as well make this a realloced array from the start. > + stats->values[stats->n_values++] = value; > +} > + > +double igt_stats_get_average(igt_stats_t *stats) > +{ > + unsigned int i; > + double a = 0.0; > + > + for (i = 0; i < stats->n_values; i++) > + a += (double)stats->values[i] / stats->n_values; For fun, we could write numerically more stable versions. Welcome to the bikeshed. static double kahan_summation(igt_stats_t *stats) { double sum = 0; double error = 0; unsigned i; for (i = 0; i < stats->n_values; i++) { double x = stats->values[i] - error; double tmp = sum + x; error = (tmp - sum) - x; sum = tmp; } return sum; } double igt_stats_get_average(igt_stats_t *stats) { return kahan_summation(stats) / stats->n_values; } or static knuth_avergae(igt_stats_t *stats) { double mean = 0; unsigned i; for (i = 0; i < stats->n_values; i++) mean += (stats->values[i] - mean) / (i + 1); return mean; } double igt_stats_get_average(igt_stats_t *stats) { return knuth_average(stats); } or if we are sorting to get the median anyway, doing a pairwise summation would also reduce the numerical errors... -Chris
On Thu, Jun 25, 2015 at 04:21:40PM +0100, Damien Lespiau wrote: > The master plan would be to get a bit more stats in it, at least the > standard deviation and confidence interval. Just need the average for > now. > > Signed-off-by: Damien Lespiau <damien.lespiau@intel.com> gtkdoc is missing for this. -Daniel > --- > lib/Makefile.sources | 2 ++ > lib/igt_stats.c | 56 ++++++++++++++++++++++++++++++++++++++++++++++ > lib/igt_stats.h | 36 +++++++++++++++++++++++++++++ > lib/tests/.gitignore | 1 + > lib/tests/Makefile.sources | 1 + > lib/tests/igt_stats.c | 49 ++++++++++++++++++++++++++++++++++++++++ > 6 files changed, 145 insertions(+) > create mode 100644 lib/igt_stats.c > create mode 100644 lib/igt_stats.h > create mode 100644 lib/tests/igt_stats.c > > diff --git a/lib/Makefile.sources b/lib/Makefile.sources > index 85dc321..f8a1b92 100644 > --- a/lib/Makefile.sources > +++ b/lib/Makefile.sources > @@ -12,6 +12,8 @@ libintel_tools_la_SOURCES = \ > igt_aux.h \ > igt_gt.c \ > igt_gt.h \ > + igt_stats.c \ > + igt_stats.h \ > instdone.c \ > instdone.h \ > intel_batchbuffer.c \ > diff --git a/lib/igt_stats.c b/lib/igt_stats.c > new file mode 100644 > index 0000000..fcf7abe > --- /dev/null > +++ b/lib/igt_stats.c > @@ -0,0 +1,56 @@ > +/* > + * Copyright © 2015 Intel Corporation > + * > + * Permission is hereby granted, free of charge, to any person obtaining a > + * copy of this software and associated documentation files (the "Software"), > + * to deal in the Software without restriction, including without limitation > + * the rights to use, copy, modify, merge, publish, distribute, sublicense, > + * and/or sell copies of the Software, and to permit persons to whom the > + * Software is furnished to do so, subject to the following conditions: > + * > + * The above copyright notice and this permission notice (including the next > + * paragraph) shall be included in all copies or substantial portions of the > + * Software. > + * > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR > + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, > + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL > + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER > + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING > + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS > + * IN THE SOFTWARE. > + * > + */ > + > +#include "igt_core.h" > +#include "igt_stats.h" > + > +void igt_stats_init(igt_stats_t *stats, unsigned int capacity) > +{ > + stats->values = calloc(capacity, sizeof(*stats->values)); > + igt_assert(stats->values); > + stats->capacity = capacity; > + stats->n_values = 0; > +} > + > +void igt_stats_fini(igt_stats_t *stats) > +{ > + free(stats->values); > +} > + > +void igt_stats_push(igt_stats_t *stats, uint64_t value) > +{ > + igt_assert(stats->n_values < stats->capacity); > + stats->values[stats->n_values++] = value; > +} > + > +double igt_stats_get_average(igt_stats_t *stats) > +{ > + unsigned int i; > + double a = 0.0; > + > + for (i = 0; i < stats->n_values; i++) > + a += (double)stats->values[i] / stats->n_values; > + > + return a; > +} > diff --git a/lib/igt_stats.h b/lib/igt_stats.h > new file mode 100644 > index 0000000..99dc1c9 > --- /dev/null > +++ b/lib/igt_stats.h > @@ -0,0 +1,36 @@ > +/* > + * Copyright © 2015 Intel Corporation > + * > + * Permission is hereby granted, free of charge, to any person obtaining a > + * copy of this software and associated documentation files (the "Software"), > + * to deal in the Software without restriction, including without limitation > + * the rights to use, copy, modify, merge, publish, distribute, sublicense, > + * and/or sell copies of the Software, and to permit persons to whom the > + * Software is furnished to do so, subject to the following conditions: > + * > + * The above copyright notice and this permission notice (including the next > + * paragraph) shall be included in all copies or substantial portions of the > + * Software. > + * > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR > + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, > + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL > + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER > + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING > + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS > + * IN THE SOFTWARE. > + * > + */ > + > +#include <stdint.h> > + > +typedef struct { > + uint64_t *values; > + unsigned int capacity; > + unsigned int n_values; > +} igt_stats_t; > + > +void igt_stats_init(igt_stats_t *stats, unsigned int capacity); > +void igt_stats_fini(igt_stats_t *stats); > +void igt_stats_push(igt_stats_t *stats, uint64_t value); > +double igt_stats_get_average(igt_stats_t *stats); > diff --git a/lib/tests/.gitignore b/lib/tests/.gitignore > index a745a23..5b6b3c4 100644 > --- a/lib/tests/.gitignore > +++ b/lib/tests/.gitignore > @@ -7,4 +7,5 @@ igt_no_exit_list_only > igt_no_subtest > igt_simple_test_subtests > igt_simulation > +igt_stats > igt_timeout > diff --git a/lib/tests/Makefile.sources b/lib/tests/Makefile.sources > index 10e0617..7521228 100644 > --- a/lib/tests/Makefile.sources > +++ b/lib/tests/Makefile.sources > @@ -6,6 +6,7 @@ check_PROGRAMS = \ > igt_no_subtest \ > igt_simulation \ > igt_simple_test_subtests \ > + igt_stats \ > igt_timeout \ > igt_invalid_subtest_name \ > $(NULL) > diff --git a/lib/tests/igt_stats.c b/lib/tests/igt_stats.c > new file mode 100644 > index 0000000..e75a203 > --- /dev/null > +++ b/lib/tests/igt_stats.c > @@ -0,0 +1,49 @@ > +/* > + * Copyright © 2015 Intel Corporation > + * > + * Permission is hereby granted, free of charge, to any person obtaining a > + * copy of this software and associated documentation files (the "Software"), > + * to deal in the Software without restriction, including without limitation > + * the rights to use, copy, modify, merge, publish, distribute, sublicense, > + * and/or sell copies of the Software, and to permit persons to whom the > + * Software is furnished to do so, subject to the following conditions: > + * > + * The above copyright notice and this permission notice (including the next > + * paragraph) shall be included in all copies or substantial portions of the > + * Software. > + * > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR > + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, > + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL > + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER > + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING > + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS > + * IN THE SOFTWARE. > + * > + */ > + > +#include "igt_core.h" > +#include "igt_stats.h" > + > +static void test_average(void) > +{ > + igt_stats_t stats; > + double average; > + > + igt_stats_init(&stats, 5); > + > + igt_stats_push(&stats, 2); > + igt_stats_push(&stats, 4); > + igt_stats_push(&stats, 6); > + igt_stats_push(&stats, 8); > + igt_stats_push(&stats, 10); > + > + average = igt_stats_get_average(&stats); > + > + igt_assert(average == (2 + 4 + 6 + 8 + 10) / 5.); > +} > + > +igt_simple_main > +{ > + test_average(); > +} > -- > 2.1.0 > > _______________________________________________ > Intel-gfx mailing list > Intel-gfx@lists.freedesktop.org > http://lists.freedesktop.org/mailman/listinfo/intel-gfx
diff --git a/lib/Makefile.sources b/lib/Makefile.sources index 85dc321..f8a1b92 100644 --- a/lib/Makefile.sources +++ b/lib/Makefile.sources @@ -12,6 +12,8 @@ libintel_tools_la_SOURCES = \ igt_aux.h \ igt_gt.c \ igt_gt.h \ + igt_stats.c \ + igt_stats.h \ instdone.c \ instdone.h \ intel_batchbuffer.c \ diff --git a/lib/igt_stats.c b/lib/igt_stats.c new file mode 100644 index 0000000..fcf7abe --- /dev/null +++ b/lib/igt_stats.c @@ -0,0 +1,56 @@ +/* + * Copyright © 2015 Intel Corporation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice (including the next + * paragraph) shall be included in all copies or substantial portions of the + * Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS + * IN THE SOFTWARE. + * + */ + +#include "igt_core.h" +#include "igt_stats.h" + +void igt_stats_init(igt_stats_t *stats, unsigned int capacity) +{ + stats->values = calloc(capacity, sizeof(*stats->values)); + igt_assert(stats->values); + stats->capacity = capacity; + stats->n_values = 0; +} + +void igt_stats_fini(igt_stats_t *stats) +{ + free(stats->values); +} + +void igt_stats_push(igt_stats_t *stats, uint64_t value) +{ + igt_assert(stats->n_values < stats->capacity); + stats->values[stats->n_values++] = value; +} + +double igt_stats_get_average(igt_stats_t *stats) +{ + unsigned int i; + double a = 0.0; + + for (i = 0; i < stats->n_values; i++) + a += (double)stats->values[i] / stats->n_values; + + return a; +} diff --git a/lib/igt_stats.h b/lib/igt_stats.h new file mode 100644 index 0000000..99dc1c9 --- /dev/null +++ b/lib/igt_stats.h @@ -0,0 +1,36 @@ +/* + * Copyright © 2015 Intel Corporation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice (including the next + * paragraph) shall be included in all copies or substantial portions of the + * Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS + * IN THE SOFTWARE. + * + */ + +#include <stdint.h> + +typedef struct { + uint64_t *values; + unsigned int capacity; + unsigned int n_values; +} igt_stats_t; + +void igt_stats_init(igt_stats_t *stats, unsigned int capacity); +void igt_stats_fini(igt_stats_t *stats); +void igt_stats_push(igt_stats_t *stats, uint64_t value); +double igt_stats_get_average(igt_stats_t *stats); diff --git a/lib/tests/.gitignore b/lib/tests/.gitignore index a745a23..5b6b3c4 100644 --- a/lib/tests/.gitignore +++ b/lib/tests/.gitignore @@ -7,4 +7,5 @@ igt_no_exit_list_only igt_no_subtest igt_simple_test_subtests igt_simulation +igt_stats igt_timeout diff --git a/lib/tests/Makefile.sources b/lib/tests/Makefile.sources index 10e0617..7521228 100644 --- a/lib/tests/Makefile.sources +++ b/lib/tests/Makefile.sources @@ -6,6 +6,7 @@ check_PROGRAMS = \ igt_no_subtest \ igt_simulation \ igt_simple_test_subtests \ + igt_stats \ igt_timeout \ igt_invalid_subtest_name \ $(NULL) diff --git a/lib/tests/igt_stats.c b/lib/tests/igt_stats.c new file mode 100644 index 0000000..e75a203 --- /dev/null +++ b/lib/tests/igt_stats.c @@ -0,0 +1,49 @@ +/* + * Copyright © 2015 Intel Corporation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice (including the next + * paragraph) shall be included in all copies or substantial portions of the + * Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS + * IN THE SOFTWARE. + * + */ + +#include "igt_core.h" +#include "igt_stats.h" + +static void test_average(void) +{ + igt_stats_t stats; + double average; + + igt_stats_init(&stats, 5); + + igt_stats_push(&stats, 2); + igt_stats_push(&stats, 4); + igt_stats_push(&stats, 6); + igt_stats_push(&stats, 8); + igt_stats_push(&stats, 10); + + average = igt_stats_get_average(&stats); + + igt_assert(average == (2 + 4 + 6 + 8 + 10) / 5.); +} + +igt_simple_main +{ + test_average(); +}
The master plan would be to get a bit more stats in it, at least the standard deviation and confidence interval. Just need the average for now. Signed-off-by: Damien Lespiau <damien.lespiau@intel.com> --- lib/Makefile.sources | 2 ++ lib/igt_stats.c | 56 ++++++++++++++++++++++++++++++++++++++++++++++ lib/igt_stats.h | 36 +++++++++++++++++++++++++++++ lib/tests/.gitignore | 1 + lib/tests/Makefile.sources | 1 + lib/tests/igt_stats.c | 49 ++++++++++++++++++++++++++++++++++++++++ 6 files changed, 145 insertions(+) create mode 100644 lib/igt_stats.c create mode 100644 lib/igt_stats.h create mode 100644 lib/tests/igt_stats.c