// // FILE: unit_test_001.cpp // AUTHOR: Rob Tillaart // DATE: 2022-02-27 // PURPOSE: unit tests for the GST library // https://github.com/RobTillaart/GST // https://github.com/Arduino-CI/arduino_ci/blob/master/REFERENCE.md // // supported assertions // https://github.com/Arduino-CI/arduino_ci/blob/master/cpp/unittest/Assertion.h#L33-L42 // ---------------------------- // assertEqual(expected, actual); // a == b // assertNotEqual(unwanted, actual); // a != b // assertComparativeEquivalent(expected, actual); // abs(a - b) == 0 or (!(a > b) && !(a < b)) // assertComparativeNotEquivalent(unwanted, actual); // abs(a - b) > 0 or ((a > b) || (a < b)) // assertLess(upperBound, actual); // a < b // assertMore(lowerBound, actual); // a > b // assertLessOrEqual(upperBound, actual); // a <= b // assertMoreOrEqual(lowerBound, actual); // a >= b // assertTrue(actual); // assertFalse(actual); // assertNull(actual); // // special cases for floats // assertEqualFloat(expected, actual, epsilon); // fabs(a - b) <= epsilon // assertNotEqualFloat(unwanted, actual, epsilon); // fabs(a - b) >= epsilon // assertInfinity(actual); // isinf(a) // assertNotInfinity(actual); // !isinf(a) // assertNAN(arg); // isnan(a) // assertNotNAN(arg); // !isnan(a) #include #include "Arduino.h" #include "GST.h" unittest_setup() { fprintf(stderr, "GST_LIB_VERSION: %s\n", (char *) GST_LIB_VERSION); } unittest_teardown() { } unittest(test_constructor) { GST gst; // default 0; assertEqualFloat(gst.getTruePositive() , 0, 0.001); assertEqualFloat(gst.getTrueNegative() , 0, 0.001); assertEqualFloat(gst.getFalsePositive() , 0, 0.001); assertEqualFloat(gst.getFalseNegative() , 0, 0.001); assertEqualFloat(gst.getTotal() , 0, 0.001); assertEqualFloat(gst.getActualPositive(), 0, 0.001); assertEqualFloat(gst.getActualNegative(), 0, 0.001); assertEqualFloat(gst.getTestedPositive(), 0, 0.001); assertEqualFloat(gst.getTestedNegative(), 0, 0.001); } unittest(test_add) { GST gst; gst.setTruePositive(100); gst.setTrueNegative(100); gst.setFalsePositive(100); gst.setFalseNegative(100); assertEqualFloat(gst.getTruePositive() , 100, 0.001); assertEqualFloat(gst.getTrueNegative() , 100, 0.001); assertEqualFloat(gst.getFalsePositive() , 100, 0.001); assertEqualFloat(gst.getFalseNegative() , 100, 0.001); assertEqualFloat(gst.getTotal() , 400, 0.001); assertEqualFloat(gst.getActualPositive(), 200, 0.001); assertEqualFloat(gst.getActualNegative(), 200, 0.001); assertEqualFloat(gst.getTestedPositive(), 200, 0.001); assertEqualFloat(gst.getTestedNegative(), 200, 0.001); } unittest(test_output_functions_I) { GST gst; gst.setTruePositive(653); gst.setTrueNegative(312); gst.setFalsePositive(124); gst.setFalseNegative(423); assertEqualFloat(gst.sensitivity(), 0.6069, 0.0001); assertEqualFloat(gst.specificity(), 0.7156, 0.0001); assertEqualFloat(gst.TPR(), 0.6069, 0.0001); assertEqualFloat(gst.FNR(), 0.3931, 0.0001); assertEqualFloat(gst.FPR(), 0.2844, 0.0001); assertEqualFloat(gst.TNR(), 0.7156, 0.0001); assertEqualFloat(gst.PPV(), 0.8404, 0.0001); assertEqualFloat(gst.NPV(), 0.4245, 0.0001); assertEqualFloat(gst.FDR(), 0.1596, 0.0001); assertEqualFloat(gst.FOR(), 0.5755, 0.0001); } unittest(test_output_functions_II) { GST gst; gst.setTruePositive(653); gst.setTrueNegative(312); gst.setFalsePositive(124); gst.setFalseNegative(423); assertEqualFloat(gst.LRplus(), 2.133860, 0.0001); assertEqualFloat(gst.LRminus(), 0.549364, 0.0001); assertEqualFloat(gst.prevalenceThreshold(), 0.406376, 0.0001); assertEqualFloat(gst.threatScore(), 0.544167, 0.0001); assertEqualFloat(gst.criticalSuccessIndex(), 0.544167, 0.0001); assertEqualFloat(gst.prevalence(), 0.711640, 0.0001); assertEqualFloat(gst.accuracy(), 0.638228, 0.0001); assertEqualFloat(gst.balancedAccuracy(), 0.661237, 0.0001); assertEqualFloat(gst.F1Score(), 0.704803, 0.0001); assertEqualFloat(gst.MCC(), 0.292273, 0.0001); assertEqualFloat(gst.FM(), 0.714162, 0.0001); assertEqualFloat(gst.BM(), 0.322474, 0.0001); assertEqualFloat(gst.MK(), 0.264902, 0.0001); assertEqualFloat(gst.DOR(), 3.884240, 0.0001); } unittest_main() // -- END OF FILE --