#pragma once #include #include #include /** * About: * This is implementation of Independent two-sample t-test * Read about it on https://en.wikipedia.org/wiki/Student%27s_t-test (Equal or unequal sample sizes, equal variance) * * Usage: * It's it used to assume with some level of confidence that two distributions don't differ. * Values can be added with t_test.add(0/1, value) and after compared and reported with compareAndReport(). */ class StudentTTest { private: struct DistributionData { size_t size = 0; double sum = 0; double squares_sum = 0; void add(double value) { ++size; sum += value; squares_sum += value * value; } double avg() const { return sum / size; } double var() const { return (squares_sum - (sum * sum / size)) / static_cast(size - 1); } void clear() { size = 0; sum = 0; squares_sum = 0; } }; std::array data {}; public: void clear(); void add(size_t distribution, double value); /// Confidence_level_index can be set in range [0, 5]. Corresponding values can be found above. TODO: Trash - no separation of concepts in code. std::pair compareAndReport(size_t confidence_level_index = 5) const; };