1*d83cc019SAndroid Build Coastguard Worker /*
2*d83cc019SAndroid Build Coastguard Worker * Copyright © 2015 Intel Corporation
3*d83cc019SAndroid Build Coastguard Worker *
4*d83cc019SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a
5*d83cc019SAndroid Build Coastguard Worker * copy of this software and associated documentation files (the "Software"),
6*d83cc019SAndroid Build Coastguard Worker * to deal in the Software without restriction, including without limitation
7*d83cc019SAndroid Build Coastguard Worker * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*d83cc019SAndroid Build Coastguard Worker * and/or sell copies of the Software, and to permit persons to whom the
9*d83cc019SAndroid Build Coastguard Worker * Software is furnished to do so, subject to the following conditions:
10*d83cc019SAndroid Build Coastguard Worker *
11*d83cc019SAndroid Build Coastguard Worker * The above copyright notice and this permission notice (including the next
12*d83cc019SAndroid Build Coastguard Worker * paragraph) shall be included in all copies or substantial portions of the
13*d83cc019SAndroid Build Coastguard Worker * Software.
14*d83cc019SAndroid Build Coastguard Worker *
15*d83cc019SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*d83cc019SAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*d83cc019SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18*d83cc019SAndroid Build Coastguard Worker * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*d83cc019SAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*d83cc019SAndroid Build Coastguard Worker * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21*d83cc019SAndroid Build Coastguard Worker * IN THE SOFTWARE.
22*d83cc019SAndroid Build Coastguard Worker *
23*d83cc019SAndroid Build Coastguard Worker */
24*d83cc019SAndroid Build Coastguard Worker
25*d83cc019SAndroid Build Coastguard Worker #include "igt_core.h"
26*d83cc019SAndroid Build Coastguard Worker #include "igt_stats.h"
27*d83cc019SAndroid Build Coastguard Worker
28*d83cc019SAndroid Build Coastguard Worker #define ARRAY_SIZE(arr) (sizeof(arr)/sizeof(arr[0]))
29*d83cc019SAndroid Build Coastguard Worker
push_fixture_1(igt_stats_t * stats)30*d83cc019SAndroid Build Coastguard Worker static void push_fixture_1(igt_stats_t *stats)
31*d83cc019SAndroid Build Coastguard Worker {
32*d83cc019SAndroid Build Coastguard Worker igt_stats_push(stats, 2);
33*d83cc019SAndroid Build Coastguard Worker igt_stats_push(stats, 4);
34*d83cc019SAndroid Build Coastguard Worker igt_stats_push(stats, 6);
35*d83cc019SAndroid Build Coastguard Worker igt_stats_push(stats, 8);
36*d83cc019SAndroid Build Coastguard Worker igt_stats_push(stats, 10);
37*d83cc019SAndroid Build Coastguard Worker }
38*d83cc019SAndroid Build Coastguard Worker
39*d83cc019SAndroid Build Coastguard Worker /* Make sure we zero igt_stats_t fields at init() time */
test_init_zero(void)40*d83cc019SAndroid Build Coastguard Worker static void test_init_zero(void)
41*d83cc019SAndroid Build Coastguard Worker {
42*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
43*d83cc019SAndroid Build Coastguard Worker
44*d83cc019SAndroid Build Coastguard Worker stats.mean = 1.;
45*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
46*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(stats.mean, 0.);
47*d83cc019SAndroid Build Coastguard Worker }
48*d83cc019SAndroid Build Coastguard Worker
test_init(void)49*d83cc019SAndroid Build Coastguard Worker static void test_init(void)
50*d83cc019SAndroid Build Coastguard Worker {
51*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
52*d83cc019SAndroid Build Coastguard Worker
53*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
54*d83cc019SAndroid Build Coastguard Worker
55*d83cc019SAndroid Build Coastguard Worker /*
56*d83cc019SAndroid Build Coastguard Worker * Make sure we default to representing only a sample of a bigger
57*d83cc019SAndroid Build Coastguard Worker * population.
58*d83cc019SAndroid Build Coastguard Worker */
59*d83cc019SAndroid Build Coastguard Worker igt_assert(igt_stats_is_population(&stats) == false);
60*d83cc019SAndroid Build Coastguard Worker }
61*d83cc019SAndroid Build Coastguard Worker
test_min_max(void)62*d83cc019SAndroid Build Coastguard Worker static void test_min_max(void)
63*d83cc019SAndroid Build Coastguard Worker {
64*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
65*d83cc019SAndroid Build Coastguard Worker
66*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
67*d83cc019SAndroid Build Coastguard Worker push_fixture_1(&stats);
68*d83cc019SAndroid Build Coastguard Worker
69*d83cc019SAndroid Build Coastguard Worker igt_assert(igt_stats_get_min(&stats) == 2);
70*d83cc019SAndroid Build Coastguard Worker igt_assert(igt_stats_get_max(&stats) == 10);
71*d83cc019SAndroid Build Coastguard Worker }
72*d83cc019SAndroid Build Coastguard Worker
test_range(void)73*d83cc019SAndroid Build Coastguard Worker static void test_range(void)
74*d83cc019SAndroid Build Coastguard Worker {
75*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
76*d83cc019SAndroid Build Coastguard Worker
77*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
78*d83cc019SAndroid Build Coastguard Worker push_fixture_1(&stats);
79*d83cc019SAndroid Build Coastguard Worker
80*d83cc019SAndroid Build Coastguard Worker igt_assert(igt_stats_get_range(&stats) == 8);
81*d83cc019SAndroid Build Coastguard Worker }
82*d83cc019SAndroid Build Coastguard Worker
83*d83cc019SAndroid Build Coastguard Worker /*
84*d83cc019SAndroid Build Coastguard Worker * Examples taken from: https://en.wikipedia.org/wiki/Quartile
85*d83cc019SAndroid Build Coastguard Worker * The values are shifted a bit to test we do indeed start by sorting data
86*d83cc019SAndroid Build Coastguard Worker * set.
87*d83cc019SAndroid Build Coastguard Worker */
test_quartiles(void)88*d83cc019SAndroid Build Coastguard Worker static void test_quartiles(void)
89*d83cc019SAndroid Build Coastguard Worker {
90*d83cc019SAndroid Build Coastguard Worker static const uint64_t s1[] =
91*d83cc019SAndroid Build Coastguard Worker { 47, 49, 6, 7, 15, 36, 39, 40, 41, 42, 43 };
92*d83cc019SAndroid Build Coastguard Worker static const uint64_t s2[] = { 40, 41, 7, 15, 36, 39 };
93*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
94*d83cc019SAndroid Build Coastguard Worker double q1, q2, q3;
95*d83cc019SAndroid Build Coastguard Worker
96*d83cc019SAndroid Build Coastguard Worker /* s1, odd number of data points */
97*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
98*d83cc019SAndroid Build Coastguard Worker igt_stats_push_array(&stats, s1, ARRAY_SIZE(s1));
99*d83cc019SAndroid Build Coastguard Worker
100*d83cc019SAndroid Build Coastguard Worker igt_stats_get_quartiles(&stats, &q1, &q2, &q3);
101*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(q1, 25.5);
102*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(q2, 40);
103*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(q3, 42.5);
104*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(igt_stats_get_median(&stats), 40);
105*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(igt_stats_get_iqr(&stats), 42.5 - 25.5);
106*d83cc019SAndroid Build Coastguard Worker
107*d83cc019SAndroid Build Coastguard Worker igt_stats_fini(&stats);
108*d83cc019SAndroid Build Coastguard Worker
109*d83cc019SAndroid Build Coastguard Worker /* s1, even number of data points */
110*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
111*d83cc019SAndroid Build Coastguard Worker igt_stats_push_array(&stats, s2, ARRAY_SIZE(s2));
112*d83cc019SAndroid Build Coastguard Worker
113*d83cc019SAndroid Build Coastguard Worker igt_stats_get_quartiles(&stats, &q1, &q2, &q3);
114*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(q1, 15);
115*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(q2, 37.5);
116*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(q3, 40);
117*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(igt_stats_get_median(&stats), 37.5);
118*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(igt_stats_get_iqr(&stats), 40 - 15);
119*d83cc019SAndroid Build Coastguard Worker
120*d83cc019SAndroid Build Coastguard Worker igt_stats_fini(&stats);
121*d83cc019SAndroid Build Coastguard Worker }
122*d83cc019SAndroid Build Coastguard Worker
test_invalidate_sorted(void)123*d83cc019SAndroid Build Coastguard Worker static void test_invalidate_sorted(void)
124*d83cc019SAndroid Build Coastguard Worker {
125*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
126*d83cc019SAndroid Build Coastguard Worker static const uint64_t s1_truncated[] =
127*d83cc019SAndroid Build Coastguard Worker { 47, 49, 6, 7, 15, 36, 39, 40, 41, 42};
128*d83cc019SAndroid Build Coastguard Worker double median1, median2;
129*d83cc019SAndroid Build Coastguard Worker
130*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
131*d83cc019SAndroid Build Coastguard Worker igt_stats_push_array(&stats, s1_truncated, ARRAY_SIZE(s1_truncated));
132*d83cc019SAndroid Build Coastguard Worker median1 = igt_stats_get_median(&stats);
133*d83cc019SAndroid Build Coastguard Worker
134*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 43);
135*d83cc019SAndroid Build Coastguard Worker median2 = igt_stats_get_median(&stats);
136*d83cc019SAndroid Build Coastguard Worker
137*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(median2, 40);
138*d83cc019SAndroid Build Coastguard Worker igt_assert(median1 != median2);
139*d83cc019SAndroid Build Coastguard Worker }
140*d83cc019SAndroid Build Coastguard Worker
test_mean(void)141*d83cc019SAndroid Build Coastguard Worker static void test_mean(void)
142*d83cc019SAndroid Build Coastguard Worker {
143*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
144*d83cc019SAndroid Build Coastguard Worker double mean;
145*d83cc019SAndroid Build Coastguard Worker
146*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
147*d83cc019SAndroid Build Coastguard Worker push_fixture_1(&stats);
148*d83cc019SAndroid Build Coastguard Worker
149*d83cc019SAndroid Build Coastguard Worker mean = igt_stats_get_mean(&stats);
150*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(mean, (2 + 4 + 6 + 8 + 10) / 5.);
151*d83cc019SAndroid Build Coastguard Worker
152*d83cc019SAndroid Build Coastguard Worker igt_stats_fini(&stats);
153*d83cc019SAndroid Build Coastguard Worker }
154*d83cc019SAndroid Build Coastguard Worker
test_invalidate_mean(void)155*d83cc019SAndroid Build Coastguard Worker static void test_invalidate_mean(void)
156*d83cc019SAndroid Build Coastguard Worker {
157*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
158*d83cc019SAndroid Build Coastguard Worker double mean1, mean2;
159*d83cc019SAndroid Build Coastguard Worker
160*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
161*d83cc019SAndroid Build Coastguard Worker push_fixture_1(&stats);
162*d83cc019SAndroid Build Coastguard Worker
163*d83cc019SAndroid Build Coastguard Worker mean1 = igt_stats_get_mean(&stats);
164*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(mean1, (2 + 4 + 6 + 8 + 10) / 5.);
165*d83cc019SAndroid Build Coastguard Worker
166*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 100);
167*d83cc019SAndroid Build Coastguard Worker
168*d83cc019SAndroid Build Coastguard Worker mean2 = igt_stats_get_mean(&stats);
169*d83cc019SAndroid Build Coastguard Worker igt_assert(mean1 != mean2);
170*d83cc019SAndroid Build Coastguard Worker
171*d83cc019SAndroid Build Coastguard Worker igt_stats_fini(&stats);
172*d83cc019SAndroid Build Coastguard Worker }
173*d83cc019SAndroid Build Coastguard Worker
174*d83cc019SAndroid Build Coastguard Worker /*
175*d83cc019SAndroid Build Coastguard Worker * Taken from the "Basic examples" section of:
176*d83cc019SAndroid Build Coastguard Worker * https://en.wikipedia.org/wiki/Standard_deviation
177*d83cc019SAndroid Build Coastguard Worker */
test_std_deviation(void)178*d83cc019SAndroid Build Coastguard Worker static void test_std_deviation(void)
179*d83cc019SAndroid Build Coastguard Worker {
180*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
181*d83cc019SAndroid Build Coastguard Worker double mean, variance, std_deviation;
182*d83cc019SAndroid Build Coastguard Worker
183*d83cc019SAndroid Build Coastguard Worker igt_stats_init(&stats);
184*d83cc019SAndroid Build Coastguard Worker igt_stats_set_population(&stats, true);
185*d83cc019SAndroid Build Coastguard Worker
186*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 2);
187*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 4);
188*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 4);
189*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 4);
190*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 5);
191*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 5);
192*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 7);
193*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, 9);
194*d83cc019SAndroid Build Coastguard Worker
195*d83cc019SAndroid Build Coastguard Worker mean = igt_stats_get_mean(&stats);
196*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(mean, (2 + 3 * 4 + 2 * 5 + 7 + 9) / 8.);
197*d83cc019SAndroid Build Coastguard Worker
198*d83cc019SAndroid Build Coastguard Worker variance = igt_stats_get_variance(&stats);
199*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(variance, 4);
200*d83cc019SAndroid Build Coastguard Worker
201*d83cc019SAndroid Build Coastguard Worker std_deviation = igt_stats_get_std_deviation(&stats);
202*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(std_deviation, 2);
203*d83cc019SAndroid Build Coastguard Worker
204*d83cc019SAndroid Build Coastguard Worker igt_stats_fini(&stats);
205*d83cc019SAndroid Build Coastguard Worker }
206*d83cc019SAndroid Build Coastguard Worker
test_reallocation(void)207*d83cc019SAndroid Build Coastguard Worker static void test_reallocation(void)
208*d83cc019SAndroid Build Coastguard Worker {
209*d83cc019SAndroid Build Coastguard Worker igt_stats_t stats;
210*d83cc019SAndroid Build Coastguard Worker unsigned int i;
211*d83cc019SAndroid Build Coastguard Worker
212*d83cc019SAndroid Build Coastguard Worker igt_stats_init_with_size(&stats, 1);
213*d83cc019SAndroid Build Coastguard Worker
214*d83cc019SAndroid Build Coastguard Worker for (i = 0; i < 101; i++) {
215*d83cc019SAndroid Build Coastguard Worker igt_stats_push(&stats, i);
216*d83cc019SAndroid Build Coastguard Worker /* also triggers ->sorted reallocations */
217*d83cc019SAndroid Build Coastguard Worker if (i > 10)
218*d83cc019SAndroid Build Coastguard Worker igt_stats_get_median(&stats);
219*d83cc019SAndroid Build Coastguard Worker }
220*d83cc019SAndroid Build Coastguard Worker igt_assert(!stats.is_float);
221*d83cc019SAndroid Build Coastguard Worker
222*d83cc019SAndroid Build Coastguard Worker igt_assert_eq(stats.n_values, 101);
223*d83cc019SAndroid Build Coastguard Worker for (i = 0; i < 101; i++)
224*d83cc019SAndroid Build Coastguard Worker igt_assert_eq(stats.values_u64[i], i);
225*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(igt_stats_get_mean(&stats), 50.0);
226*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_double(igt_stats_get_median(&stats), 50.0);
227*d83cc019SAndroid Build Coastguard Worker
228*d83cc019SAndroid Build Coastguard Worker igt_stats_fini(&stats);
229*d83cc019SAndroid Build Coastguard Worker }
230*d83cc019SAndroid Build Coastguard Worker
231*d83cc019SAndroid Build Coastguard Worker igt_simple_main
232*d83cc019SAndroid Build Coastguard Worker {
233*d83cc019SAndroid Build Coastguard Worker test_init_zero();
234*d83cc019SAndroid Build Coastguard Worker test_init();
235*d83cc019SAndroid Build Coastguard Worker test_min_max();
236*d83cc019SAndroid Build Coastguard Worker test_range();
237*d83cc019SAndroid Build Coastguard Worker test_quartiles();
238*d83cc019SAndroid Build Coastguard Worker test_invalidate_sorted();
239*d83cc019SAndroid Build Coastguard Worker test_mean();
240*d83cc019SAndroid Build Coastguard Worker test_invalidate_mean();
241*d83cc019SAndroid Build Coastguard Worker test_std_deviation();
242*d83cc019SAndroid Build Coastguard Worker test_reallocation();
243*d83cc019SAndroid Build Coastguard Worker }
244