mirror of
https://github.com/tiagovignatti/intel-gpu-tools.git
synced 2025-06-20 14:26:17 +00:00
stats: Spwan igt_init_with_size() from igt_init()
It's all about good looking APIs. Signed-off-by: Damien Lespiau <damien.lespiau@intel.com>
This commit is contained in:
parent
00432ff260
commit
66e0bf66da
@ -97,15 +97,32 @@ static void igt_stats_ensure_capacity(igt_stats_t *stats,
|
|||||||
/**
|
/**
|
||||||
* igt_stats_init:
|
* igt_stats_init:
|
||||||
* @stats: An #igt_stats_t instance
|
* @stats: An #igt_stats_t instance
|
||||||
|
*
|
||||||
|
* Initializes an #igt_stats_t instance. igt_stats_fini() must be called once
|
||||||
|
* finished with @stats.
|
||||||
|
*/
|
||||||
|
void igt_stats_init(igt_stats_t *stats)
|
||||||
|
{
|
||||||
|
memset(stats, 0, sizeof(*stats));
|
||||||
|
|
||||||
|
igt_stats_ensure_capacity(stats, 128);
|
||||||
|
|
||||||
|
stats->min = U64_MAX;
|
||||||
|
stats->max = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* igt_stats_init_with_size:
|
||||||
|
* @stats: An #igt_stats_t instance
|
||||||
* @capacity: Number of data samples @stats can contain
|
* @capacity: Number of data samples @stats can contain
|
||||||
*
|
*
|
||||||
* Initializes an #igt_stats_t instance to hold @capacity samples.
|
* Like igt_stats_init() but with a size to avoid reallocating the underlying
|
||||||
* igt_stats_fini() must be called once finished with @stats.
|
* array(s) when pushing new values. Useful if we have a good idea of the
|
||||||
|
* number of data points we want @stats to hold.
|
||||||
*
|
*
|
||||||
* We currently assume the user knows how many data samples upfront and there's
|
* igt_stats_fini() must be called once finished with @stats.
|
||||||
* no need to grow the array of values.
|
|
||||||
*/
|
*/
|
||||||
void igt_stats_init(igt_stats_t *stats, unsigned int capacity)
|
void igt_stats_init_with_size(igt_stats_t *stats, unsigned int capacity)
|
||||||
{
|
{
|
||||||
memset(stats, 0, sizeof(*stats));
|
memset(stats, 0, sizeof(*stats));
|
||||||
|
|
||||||
|
@ -47,7 +47,8 @@ typedef struct {
|
|||||||
uint64_t *sorted;
|
uint64_t *sorted;
|
||||||
} igt_stats_t;
|
} igt_stats_t;
|
||||||
|
|
||||||
void igt_stats_init(igt_stats_t *stats, unsigned int capacity);
|
void igt_stats_init(igt_stats_t *stats);
|
||||||
|
void igt_stats_init_with_size(igt_stats_t *stats, unsigned int capacity);
|
||||||
void igt_stats_fini(igt_stats_t *stats);
|
void igt_stats_fini(igt_stats_t *stats);
|
||||||
bool igt_stats_is_population(igt_stats_t *stats);
|
bool igt_stats_is_population(igt_stats_t *stats);
|
||||||
void igt_stats_set_population(igt_stats_t *stats, bool full_population);
|
void igt_stats_set_population(igt_stats_t *stats, bool full_population);
|
||||||
|
@ -42,7 +42,7 @@ static void test_init_zero(void)
|
|||||||
igt_stats_t stats;
|
igt_stats_t stats;
|
||||||
|
|
||||||
stats.mean = 1.;
|
stats.mean = 1.;
|
||||||
igt_stats_init(&stats, 2);
|
igt_stats_init(&stats);
|
||||||
igt_assert_eq_double(stats.mean, 0.);
|
igt_assert_eq_double(stats.mean, 0.);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -50,7 +50,7 @@ static void test_init(void)
|
|||||||
{
|
{
|
||||||
igt_stats_t stats;
|
igt_stats_t stats;
|
||||||
|
|
||||||
igt_stats_init(&stats, 2);
|
igt_stats_init(&stats);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Make sure we default to representing only a sample of a bigger
|
* Make sure we default to representing only a sample of a bigger
|
||||||
@ -63,7 +63,7 @@ static void test_min_max(void)
|
|||||||
{
|
{
|
||||||
igt_stats_t stats;
|
igt_stats_t stats;
|
||||||
|
|
||||||
igt_stats_init(&stats, 5);
|
igt_stats_init(&stats);
|
||||||
push_fixture_1(&stats);
|
push_fixture_1(&stats);
|
||||||
|
|
||||||
igt_assert(igt_stats_get_min(&stats) == 2);
|
igt_assert(igt_stats_get_min(&stats) == 2);
|
||||||
@ -74,7 +74,7 @@ static void test_range(void)
|
|||||||
{
|
{
|
||||||
igt_stats_t stats;
|
igt_stats_t stats;
|
||||||
|
|
||||||
igt_stats_init(&stats, 5);
|
igt_stats_init(&stats);
|
||||||
push_fixture_1(&stats);
|
push_fixture_1(&stats);
|
||||||
|
|
||||||
igt_assert(igt_stats_get_range(&stats) == 8);
|
igt_assert(igt_stats_get_range(&stats) == 8);
|
||||||
@ -94,7 +94,7 @@ static void test_quartiles(void)
|
|||||||
double q1, q2, q3;
|
double q1, q2, q3;
|
||||||
|
|
||||||
/* s1, odd number of data points */
|
/* s1, odd number of data points */
|
||||||
igt_stats_init(&stats, ARRAY_SIZE(s1));
|
igt_stats_init(&stats);
|
||||||
igt_stats_push_array(&stats, s1, ARRAY_SIZE(s1));
|
igt_stats_push_array(&stats, s1, ARRAY_SIZE(s1));
|
||||||
|
|
||||||
igt_stats_get_quartiles(&stats, &q1, &q2, &q3);
|
igt_stats_get_quartiles(&stats, &q1, &q2, &q3);
|
||||||
@ -107,7 +107,7 @@ static void test_quartiles(void)
|
|||||||
igt_stats_fini(&stats);
|
igt_stats_fini(&stats);
|
||||||
|
|
||||||
/* s1, even number of data points */
|
/* s1, even number of data points */
|
||||||
igt_stats_init(&stats, ARRAY_SIZE(s2));
|
igt_stats_init(&stats);
|
||||||
igt_stats_push_array(&stats, s2, ARRAY_SIZE(s2));
|
igt_stats_push_array(&stats, s2, ARRAY_SIZE(s2));
|
||||||
|
|
||||||
igt_stats_get_quartiles(&stats, &q1, &q2, &q3);
|
igt_stats_get_quartiles(&stats, &q1, &q2, &q3);
|
||||||
@ -127,7 +127,7 @@ static void test_invalidate_sorted(void)
|
|||||||
{ 47, 49, 6, 7, 15, 36, 39, 40, 41, 42};
|
{ 47, 49, 6, 7, 15, 36, 39, 40, 41, 42};
|
||||||
double median1, median2;
|
double median1, median2;
|
||||||
|
|
||||||
igt_stats_init(&stats, ARRAY_SIZE(s1_truncated) + 1);
|
igt_stats_init(&stats);
|
||||||
igt_stats_push_array(&stats, s1_truncated, ARRAY_SIZE(s1_truncated));
|
igt_stats_push_array(&stats, s1_truncated, ARRAY_SIZE(s1_truncated));
|
||||||
median1 = igt_stats_get_median(&stats);
|
median1 = igt_stats_get_median(&stats);
|
||||||
|
|
||||||
@ -143,7 +143,7 @@ static void test_mean(void)
|
|||||||
igt_stats_t stats;
|
igt_stats_t stats;
|
||||||
double mean;
|
double mean;
|
||||||
|
|
||||||
igt_stats_init(&stats, 5);
|
igt_stats_init(&stats);
|
||||||
push_fixture_1(&stats);
|
push_fixture_1(&stats);
|
||||||
|
|
||||||
mean = igt_stats_get_mean(&stats);
|
mean = igt_stats_get_mean(&stats);
|
||||||
@ -157,7 +157,7 @@ static void test_invalidate_mean(void)
|
|||||||
igt_stats_t stats;
|
igt_stats_t stats;
|
||||||
double mean1, mean2;
|
double mean1, mean2;
|
||||||
|
|
||||||
igt_stats_init(&stats, 6);
|
igt_stats_init(&stats);
|
||||||
push_fixture_1(&stats);
|
push_fixture_1(&stats);
|
||||||
|
|
||||||
mean1 = igt_stats_get_mean(&stats);
|
mean1 = igt_stats_get_mean(&stats);
|
||||||
@ -180,7 +180,7 @@ static void test_std_deviation(void)
|
|||||||
igt_stats_t stats;
|
igt_stats_t stats;
|
||||||
double mean, variance, std_deviation;
|
double mean, variance, std_deviation;
|
||||||
|
|
||||||
igt_stats_init(&stats, 8);
|
igt_stats_init(&stats);
|
||||||
igt_stats_set_population(&stats, true);
|
igt_stats_set_population(&stats, true);
|
||||||
|
|
||||||
igt_stats_push(&stats, 2);
|
igt_stats_push(&stats, 2);
|
||||||
|
@ -866,7 +866,7 @@ static void test_run(struct test_ops *test)
|
|||||||
unsigned p_odd_even[2] = { 0, 0 };
|
unsigned p_odd_even[2] = { 0, 0 };
|
||||||
igt_stats_t stats;
|
igt_stats_t stats;
|
||||||
|
|
||||||
igt_stats_init(&stats, ARRAY_SIZE(modes));
|
igt_stats_init_with_size(&stats, ARRAY_SIZE(modes));
|
||||||
igt_stats_set_population(&stats, true);
|
igt_stats_set_population(&stats, true);
|
||||||
|
|
||||||
for (m = 0; m < ARRAY_SIZE(modes); m++) {
|
for (m = 0; m < ARRAY_SIZE(modes); m++) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user