test_flow_pp_negative.cpp 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #include "test_flow_postrocess_helper.h"
  2. /**
  3. * @brief Testfall für Überprüfung allowNegatives
  4. *
  5. */
  6. void testNegative() {
  7. // Ohne decimal_shift
  8. std::vector<float> digits = { 1.2, 6.7};
  9. std::vector<float> analogs = { 9.5, 8.4};
  10. double preValue_extended = 16.985;
  11. double preValue = 16.98;
  12. const char* expected = "16.98";
  13. // extendResolution=false
  14. // da kein negativ, sollte kein Error auftreten
  15. UnderTestPost* underTestPost = init_do_flow(analogs, digits, Digital100, false, false, 0);
  16. setAllowNegatives(underTestPost, false);
  17. setPreValue(underTestPost, preValue);
  18. std::string result = process_doFlow(underTestPost);
  19. TEST_ASSERT_EQUAL_STRING("no error", underTestPost->getReadoutError().c_str());
  20. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  21. delete underTestPost;
  22. // extendResolution=true
  23. // da negativ im Rahmen (letzte Stelle -0.2 > ergebnis), kein Error
  24. // Aber der PreValue wird gesetzt
  25. underTestPost = init_do_flow(analogs, digits, Digital100, false, true, 0);
  26. setAllowNegatives(underTestPost, false);
  27. setPreValue(underTestPost, preValue_extended);
  28. result = process_doFlow(underTestPost);
  29. TEST_ASSERT_EQUAL_STRING("no error", underTestPost->getReadoutError().c_str());
  30. TEST_ASSERT_EQUAL_STRING(RundeOutput(preValue_extended, analogs.size()+1).c_str(), result.c_str());
  31. delete underTestPost;
  32. // extendResolution=true
  33. // Tolleranz überschritten, Error wird gesetzt, kein ReturnValue
  34. preValue_extended = 16.988; // zu groß
  35. underTestPost = init_do_flow(analogs, digits, Digital100, false, true, 0);
  36. setAllowNegatives(underTestPost, false);
  37. setPreValue(underTestPost, preValue_extended);
  38. result = process_doFlow(underTestPost);
  39. TEST_ASSERT_EQUAL_STRING("Neg. Rate - Read: - Raw: 16.984 - Pre: 16.988 ", underTestPost->getReadoutError().c_str());
  40. TEST_ASSERT_EQUAL_STRING("", result.c_str());
  41. delete underTestPost;
  42. // extendResolution=false
  43. // value < preValue
  44. preValue = 16.99; // zu groß
  45. underTestPost = init_do_flow(analogs, digits, Digital100, false, false, 0);
  46. setAllowNegatives(underTestPost, false);
  47. setPreValue(underTestPost, preValue_extended);
  48. result = process_doFlow(underTestPost);
  49. TEST_ASSERT_EQUAL_STRING("Neg. Rate - Read: - Raw: 16.98 - Pre: 16.99 ", underTestPost->getReadoutError().c_str());
  50. TEST_ASSERT_EQUAL_STRING("", result.c_str());
  51. delete underTestPost;
  52. // extendResolution=false
  53. // value < preValue
  54. // Aber Prüfung abgeschaltet => kein Fehler
  55. preValue = 16.99; // zu groß
  56. underTestPost = init_do_flow(analogs, digits, Digital100, false, false, 0);
  57. setAllowNegatives(underTestPost, true);
  58. setPreValue(underTestPost, preValue_extended);
  59. result = process_doFlow(underTestPost);
  60. TEST_ASSERT_EQUAL_STRING("no error", underTestPost->getReadoutError().c_str());
  61. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  62. delete underTestPost;
  63. }
  64. /**
  65. * @brief Fehlerberichte aus Issues
  66. *
  67. */
  68. void testNegative_Issues() {
  69. // Ohne decimal_shift
  70. std::vector<float> digits = { 2.0, 2.0, 0.0, 1.0, 7.2, 9.0, 8.0};
  71. std::vector<float> analogs = { };
  72. double preValue_extended = 22018.080;
  73. double preValue = 22018.08;
  74. const char* expected = "22017.98";
  75. // https://github.com/jomjol/AI-on-the-edge-device/issues/2145#issuecomment-1461899094
  76. // extendResolution=false
  77. // value < preValue
  78. // Prüfung eingeschaltet => Fehler
  79. preValue = 22018.08; // zu groß
  80. UnderTestPost* underTestPost = init_do_flow(analogs, digits, Digital100, false, false, -2);
  81. setAllowNegatives(underTestPost, false);
  82. setPreValue(underTestPost, preValue_extended);
  83. std::string result = process_doFlow(underTestPost);
  84. TEST_ASSERT_EQUAL_STRING("Neg. Rate - Read: - Raw: 22017.98 - Pre: 22018.08 ", underTestPost->getReadoutError().c_str());
  85. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  86. delete underTestPost;
  87. }