/** Unit tests for histogram * * @author Steffen Vogel * @copyright 2014-2016, Institute for Automation of Complex Power Systems, EONERC * This file is part of VILLASnode. All Rights Reserved. Proprietary and confidential. * Unauthorized copying of this file, via any medium is strictly prohibited. *********************************************************************************/ #include #include "hist.h" #include "utils.h" const double test_data[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; /* Histogram of test_data with 200 buckets between -100 and 100 */ const int hist_result[] = {}; Test(hist, simple) { struct hist h; int ret; ret = hist_create(&h, -100, 100, 1); cr_assert_eq(ret, 0); for (int i = 0; i < ARRAY_LEN(test_data); i++) hist_put(&h, test_data[i]); cr_assert_float_eq(hist_mean(&h), 5.5, 1e-6); cr_assert_float_eq(hist_var(&h), 9.1666, 1e-3,); cr_assert_float_eq(hist_stddev(&h), 3.027650, 1e-6); // for (int i = 0; i < ARRAY_LEN(hist_result); i++) // cr_assert_eq() hist_destroy(&h); }