test_flowpostprocessing.cpp 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518
  1. #include "test_flow_postrocess_helper.h"
  2. /**
  3. * ACHTUNG! Die Test laufen aktuell nur mit ausgeschaltetem Debug in ClassFlowCNNGeneral
  4. *
  5. *
  6. * @brief Testet die doFlow-Methode von ClassFlowPostprocessing
  7. * digits[] - enthält die liste der vom Model zurückgegebenen Ergebnisse (class100/cont) in der Reihenfolge von links nach rechts
  8. * analog[] - enthält die Liste der Zeiger vom Model, wie bei den digits
  9. * expected - enthält das erwartete Ergebnis, wobei der Dezimalpunkt genau zwischen digits und analog ist.
  10. *
  11. */
  12. void test_doFlow() {
  13. /*
  14. *
  15. * digit1 = 1.2
  16. * digit2 = 6.7
  17. * analog1 = 9.5
  18. * analog2 = 8.4
  19. *
  20. * Das Ergebnis sollte "16.984" sein. Bzw. 16.98 ohne Extended true
  21. */
  22. std::vector<float> digits = { 1.2, 6.7};
  23. std::vector<float> analogs = { 9.5, 8.4};
  24. const char* expected = "16.98";
  25. const char* expected_extended = "16.984";
  26. std::string result = process_doFlow(analogs, digits);
  27. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  28. /*
  29. * https://github.com/jomjol/AI-on-the-edge-device/issues/921#issue-1344032217
  30. *
  31. * Das Ergebnis sollte "376529.6" sein.
  32. */
  33. digits = { 3.0, 7.0, 6.0, 5.0, 2.5, 9.6};
  34. analogs = { 6.4};
  35. expected = "376529.6";
  36. result = process_doFlow(analogs, digits);
  37. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  38. /*
  39. * https://github.com/jomjol/AI-on-the-edge-device/issues/921#issuecomment-1220365920
  40. *
  41. * Das Ergebnis sollte "167734.6" sein. Bzw. 16.98 ohne Extended true
  42. */
  43. digits = { 1.1, 6.0, 7.0, 7.0, 3.0, 4.6};
  44. analogs = { 6.2};
  45. expected = "167734.6";
  46. result = process_doFlow(analogs, digits);
  47. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  48. /*
  49. * https://github.com/jomjol/AI-on-the-edge-device/issues/919
  50. *
  51. * Das Ergebnis sollte "58.96889" sein. Bzw. 16.98 ohne Extended true
  52. */
  53. digits = { 5.0, 8.6};
  54. analogs = { 9.8, 6.7, 8.9, 8.6, 9.8};
  55. expected = "58.96889";
  56. result = process_doFlow(analogs, digits);
  57. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  58. /*
  59. * https://github.com/jomjol/AI-on-the-edge-device/issues/921#issuecomment-1222672175
  60. *
  61. * Das Ergebnis sollte "376529.6" sein. Bzw. 16.98 ohne Extended true
  62. */
  63. digits = { 2.9, 7.0, 6.8, 9.9, 8.0, 3.9};
  64. analogs = { 9.7};
  65. expected = "377083.9";
  66. result = process_doFlow(analogs, digits);
  67. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  68. digits = { 1.1, 9.0, 4.0};
  69. analogs = { 6.1, 2.6, 6.25, 9.7};
  70. expected = "194.6259";
  71. result = process_doFlow(analogs, digits);
  72. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  73. digits = { 1.1, 9.0, 4.0};
  74. analogs = { 8.1, 2.6, 6.25, 9.7};
  75. expected = "194.8259";
  76. result = process_doFlow(analogs, digits);
  77. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  78. digits = { 1.1, 9.0, 4.0};
  79. analogs = { 9.1, 2.6, 6.25, 9.7};
  80. expected = "194.9259";
  81. result = process_doFlow(analogs, digits);
  82. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  83. // https://github.com/jomjol/AI-on-the-edge-device/discussions/950
  84. digits = { 1.0, 9.0, 9.0};
  85. analogs = { 7.1, 4.8, 8.3};
  86. expected = "199.748";
  87. result = process_doFlow(analogs, digits);
  88. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  89. // https://github.com/jomjol/AI-on-the-edge-device/issues/948
  90. digits = { 1.0, 9.0, 9.0};
  91. analogs = { 7.1, 4.8, 8.3};
  92. expected = "199.748";
  93. result = process_doFlow(analogs, digits);
  94. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  95. // https://github.com/jomjol/AI-on-the-edge-device/issues/942#issuecomment-1226966346
  96. digits = { 0.0, 2.9, 3.0, 2.9, 3.5, 9.5};
  97. analogs = { };
  98. expected = "33330";
  99. result = process_doFlow(analogs, digits);
  100. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  101. // https://github.com/jomjol/AI-on-the-edge-device/issues/942#issuecomment-1226966346
  102. digits = { 9.9, 2.8, 2.9, 2.9, 3.7, 9.7};
  103. analogs = { };
  104. expected = "33340";
  105. result = process_doFlow(analogs, digits);
  106. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  107. // https://github.com/jomjol/AI-on-the-edge-device/issues/942
  108. digits = { 0.0, 9.9, 6.8, 9.9, 3.7, 0.8, 6.9, 8.7};
  109. analogs = { };
  110. expected = "704179";
  111. result = process_doFlow(analogs, digits);
  112. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  113. // https://github.com/jomjol/AI-on-the-edge-device/issues/942#issuecomment-1228343319
  114. digits = { 9.9, 6.8, 1.1, 4.7, 2.7, 6.0, 9.0, 2.8}; // changed 3.7 --> 2.7 (see picture in issue)
  115. analogs = { };
  116. expected = "7153693";
  117. result = process_doFlow(analogs, digits);
  118. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  119. // Analoger Übergang Zähler Jomjolcom/jomjol/AI-on-the-edge-device/issues/942#issuecomment-1228343319
  120. digits = { 1.0, 9.0, 4.3}; // changed 3.7 --> 2.7 (see picture in issue)
  121. analogs = { 8.9, 0.7, 8.9, 9.4 };
  122. expected = "194.9089";
  123. result = process_doFlow(analogs, digits);
  124. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  125. // Fehler bei V11.2.0
  126. // https://github.com/jomjol/AI-on-the-edge-device/issues/921#issuecomment-1229552041
  127. digits = { 2.9, 7.0, 7.0, 9.1, 8.1, 8.5}; // 376.9884(1) als falsches Ergebnis
  128. analogs = { 4.1 };
  129. expected = "377988.4";
  130. result = process_doFlow(analogs, digits);
  131. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  132. // Fehler bei V11.2.0
  133. // https://github.com/jomjol/AI-on-the-edge-device/issues/921#issuecomment-1233149877
  134. digits = { 0.0, 0.0, 7.0, 8.9}; // 79.9999(6) als falsches Ergebnis
  135. analogs = { 0.1, 0.1, 0.1, 9.6};
  136. expected = "78.9999";
  137. result = process_doFlow(analogs, digits);
  138. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  139. // Fehler bei V11.2.0
  140. // https://github.com/jomjol/AI-on-the-edge-device/issues/921#issuecomment-1236119370
  141. digits = { 3.1, 9.1, 5.7}; // 9.1 führt zu falscher Erkennung eines unvollständigen Übergangs
  142. analogs = { 8.8, 6.1, 3.0, 2.0};
  143. expected = "395.8632";
  144. result = process_doFlow(analogs, digits);
  145. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  146. // Fehler bei V11.2.0
  147. // https://github.com/jomjol/AI-on-the-edge-device/discussions/950#discussion-4338615
  148. digits = { 1.0, 9.0, 9.0}; // Übergang wurde um 1 erhöht (200, statt 199)
  149. analogs = { 7.1, 4.8, 8.3};
  150. expected = "199.748";
  151. result = process_doFlow(analogs, digits, Digital);
  152. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  153. // Fehler bei Rolling (2002-09-09)
  154. // https://github.com/jomjol/AI-on-the-edge-device/issues/921#issuecomment-1242730397
  155. digits = { 3.0, 2.0, 2.0, 8.0, 9.0, 4.0, 1.7, 9.8}; // falscher Wert 32290.420
  156. analogs = { };
  157. expected = "32289.420";
  158. expected_extended= "32289.4198";
  159. // FALSCH! wegen ungenügender Präzision von NUMBERS->Value
  160. // expected_extended= "32289.4198";
  161. // extendResolution=false, checkConsistency=false
  162. result = process_doFlow(analogs, digits, Digital100, false, false, -3);
  163. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  164. // extendResolution=true
  165. result = process_doFlow(analogs, digits, Digital100, false, true, -3);
  166. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  167. // checkConsistency=true und extendResolution=true
  168. result = process_doFlow(analogs, digits, Digital100, false, true, -3);
  169. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  170. // Fehler Rolling (2022-09-10)
  171. // not documented as issue
  172. digits = { 0.0, 0.0, 7.9, 3.8}; // 84.99401 als falsches Ergebnis
  173. analogs = { 0.0, 9.4, 4.1, 0.1};
  174. expected = "83.9940";
  175. expected_extended= "83.99401";
  176. // checkConsistency=false
  177. result = process_doFlow(analogs, digits, Digital100, false);
  178. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  179. // checkConsistency=true
  180. result = process_doFlow(analogs, digits, Digital100, true);
  181. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  182. // extendResolution=true
  183. result = process_doFlow(analogs, digits, Digital100, false, true);
  184. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  185. // checkConsistency=true und extendResolution=true
  186. result = process_doFlow(analogs, digits, Digital100, false, true);
  187. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  188. // Fehler Rolling (2022-09-10)
  189. // https://github.com/jomjol/AI-on-the-edge-device/issues/994#issue-1368570945
  190. digits = { 0.0, 0.0, 1.0, 2.0, 2.8, 1.9, 2.8, 5.6}; // 123245.6 als falsches Ergebnis
  191. analogs = { };
  192. expected = "123236";
  193. expected_extended= "123235.6";
  194. // checkConsistency=true
  195. result = process_doFlow(analogs, digits, Digital100, false, false);
  196. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  197. // checkConsistency=true
  198. result = process_doFlow(analogs, digits, Digital100, true, false);
  199. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  200. // extendResolution=true
  201. result = process_doFlow(analogs, digits, Digital100, false, true);
  202. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  203. // Fehler bei V11.2.0
  204. // https://github.com/jomjol/AI-on-the-edge-device/discussions/950#discussioncomment-3661982
  205. digits = { 3.0, 2.0, 4.1, 9.0, 4.0, 6.3, 9.2}; // 3249.459 als falsches Ergebnis
  206. analogs = { };
  207. expected = "3249.469";
  208. expected_extended= "3249.4692";
  209. // checkConsistency=true
  210. result = process_doFlow(analogs, digits, Digital100, false, false, -3);
  211. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  212. // extendResolution=true
  213. result = process_doFlow(analogs, digits, Digital100, false, true, -3);
  214. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  215. // Fehler bei V11.2.0
  216. // https://github.com/jomjol/AI-on-the-edge-device/issues/1020#issue-1375648891
  217. digits = { 0.0, 2.0, 6.1, 9.2}; // 259.9227 als falsches Ergebnis
  218. analogs = { 9.0, 2.5, 2.9, 7.2};
  219. expected = "269.9227";
  220. expected_extended= "269.92272";
  221. // extendResolution=true
  222. result = process_doFlow(analogs, digits, Digital100, false, false);
  223. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  224. // checkConsistency=false und extendResolution=true
  225. result = process_doFlow(analogs, digits, Digital100, false, true);
  226. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  227. // Fehler bei V11.3.1
  228. // https://github.com/jomjol/AI-on-the-edge-device/issues/1028#issuecomment-1250239481
  229. digits = { 1.1, 6.0, 9.1, 3.0, 5.3, 9.4}; // 169.3493 als falsches Ergebnis
  230. analogs = { 3.5};
  231. expected = "169.3593";
  232. expected_extended= "169.35935";
  233. // extendResolution=false
  234. result = process_doFlow(analogs, digits, Digital100, false, false, -3);
  235. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  236. // checkConsistency=false und extendResolution=true
  237. result = process_doFlow(analogs, digits, Digital100, false, true, -3);
  238. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  239. // Fehler bei V12.0.1
  240. // Lokal
  241. digits = { 9.8, 9.8, 1.9, 0.9, 0.9, 9.9, 2.9, 4.8}; // 211.0345 als falsches Ergebnis
  242. analogs = { 5.5};
  243. expected = "211.0355";
  244. expected_extended= "211.03555";
  245. // extendResolution=false
  246. result = process_doFlow(analogs, digits, Digital100, false, false, -3);
  247. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  248. // checkConsistency=false und extendResolution=true
  249. result = process_doFlow(analogs, digits, Digital100, false, true, -3);
  250. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  251. // Fehler bei V12.0.1
  252. // https://github.com/jomjol/AI-on-the-edge-device/issues/1110#issuecomment-1277425333
  253. digits = { 2.2, 4.5, 5.9}; // 245.938 als falsches Ergebnis
  254. analogs = { 9.4, 3.8, 8.6};
  255. expected = "245.938";
  256. expected_extended= "245.9386";
  257. // extendResolution=false
  258. result = process_doFlow(analogs, digits, Digital100, false, false, 0);
  259. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  260. // checkConsistency=false und extendResolution=true
  261. result = process_doFlow(analogs, digits, Digital100, false, true, 0);
  262. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  263. // Fehler bei V12.0.1
  264. // https://github.com/jomjol/AI-on-the-edge-device/issues/1110#issuecomment-1277425333
  265. digits = { 2.2, 4.5, 5.9}; // 245.938 kein Fehler. Aber Grenzfall, deshalb mit als Test aufgenommen.
  266. analogs = { 9.4, 3.8, 8.6};
  267. expected = "245.938";
  268. expected_extended= "245.9386";
  269. // extendResolution=false
  270. result = process_doFlow(analogs, digits, Digital100, false, false, 0);
  271. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  272. // checkConsistency=false und extendResolution=true
  273. result = process_doFlow(analogs, digits, Digital100, false, true, 0);
  274. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  275. // Fehler bei V12.0.1
  276. // https://github.com/jomjol/AI-on-the-edge-device/issues/1110#issuecomment-1265523710
  277. digits = { 2.0, 4.0, 6.8}; // 246.2045 als falsches Ergebnis
  278. analogs = { 2.2, 0.1, 4.5};
  279. expected = "247.204";
  280. expected_extended= "247.2045";
  281. // extendResolution=false
  282. result = process_doFlow(analogs, digits, Digital100, false, false, 0);
  283. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  284. // checkConsistency=false und extendResolution=true
  285. result = process_doFlow(analogs, digits, Digital100, false, true, 0);
  286. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  287. // Fehler bei V12.0.1
  288. // https://github.com/jomjol/AI-on-the-edge-device/issues/1110#issue-1391153343
  289. digits = { 1.0, 4.0, 2.0}; // 141.9269 als falsches Ergebnis
  290. analogs = { 9.2, 2.5, 6.8, 9.0};
  291. expected = "142.9269";
  292. expected_extended= "142.92690";
  293. // extendResolution=false
  294. result = process_doFlow(analogs, digits, Digital100, false, false, 0);
  295. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  296. // checkConsistency=false und extendResolution=true
  297. result = process_doFlow(analogs, digits, Digital100, false, true, 0);
  298. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  299. // Fehler bei V12.0.1
  300. // https://github.com/jomjol/AI-on-the-edge-device/issues/1110#issuecomment-1262626388
  301. digits = { 1.2, 6.8, 0.0, 0.0, 5.0, 2.8}; //170.05387 als falsches Ergebnis
  302. // letztes digit läuft mit analog zeiger mit. Hier nur lösbar mit setAnalogdigitTransistionStart=7.7
  303. analogs = { 8.7};
  304. expected = "170.0528";
  305. expected_extended= "170.05287";
  306. // extendResolution=false
  307. UnderTestPost* undertestPost = init_do_flow(analogs, digits, Digital100, false, false, -3);
  308. setAnalogdigitTransistionStart(undertestPost, 7.7);
  309. result = process_doFlow(undertestPost);
  310. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  311. delete undertestPost;
  312. // checkConsistency=false und extendResolution=true
  313. undertestPost = init_do_flow(analogs, digits, Digital100, false, true, -3);
  314. setAnalogdigitTransistionStart(undertestPost, 7.7);
  315. result = process_doFlow(undertestPost);
  316. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  317. delete undertestPost;
  318. // Fehler bei rolling post V12.0.1
  319. // lokal watermeter1
  320. digits = { 0.0, 0.0, 9.0, 1.0}; //90.88174 als falsches Ergebnis
  321. analogs = {9.0, 8.0, 1.8, 7.4};
  322. expected = "91.8817";
  323. expected_extended= "91.88174";
  324. // extendResolution=false
  325. result = process_doFlow(analogs, digits, Digital100, false, false, 0);
  326. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  327. // checkConsistency=false und extendResolution=true
  328. result = process_doFlow(analogs, digits, Digital100, false, true, 0);
  329. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  330. // Fehler bei rolling post V12.0.1
  331. // lokal watermeter1
  332. digits = { 0.0, 0.0, 9.0, 1.9}; //91.38403 als falsches Ergebnis
  333. analogs = {3.6, 8.2, 3.2, 2.0};
  334. expected = "92.3832";
  335. expected_extended= "92.38320";
  336. // extendResolution=false
  337. result = process_doFlow(analogs, digits, Digital100, false, false, 0);
  338. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  339. // checkConsistency=false und extendResolution=true
  340. result = process_doFlow(analogs, digits, Digital100, false, true, 0);
  341. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  342. // Fehler V11.3.0
  343. // https://github.com/jomjol/AI-on-the-edge-device/issues/1143#issue-1400807695
  344. digits = { 7.0, 4.0, 7.0, 2.0, 7.0, 5.4, 9.4}; // 7472.749 als falsches Ergebnis
  345. analogs = {};
  346. expected = "7472.759";
  347. expected_extended= "7472.7594";
  348. // extendResolution=false
  349. result = process_doFlow(analogs, digits, Digital100, false, false, -3);
  350. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  351. // checkConsistency=false und extendResolution=true
  352. result = process_doFlow(analogs, digits, Digital100, false, true, -3);
  353. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  354. // Fehler V12.0.1
  355. // https://github.com/jomjol/AI-on-the-edge-device/issues/1143#issuecomment-1274434805
  356. digits = { 4.9, 6.9, 6.8}; // 576.8649 als falsches Ergebnis
  357. analogs = {8.6, 6.2, 5.0, 9.0};
  358. expected = "577.8649";
  359. expected_extended= "577.86490";
  360. // extendResolution=false
  361. result = process_doFlow(analogs, digits, Digital100, false, false, 0);
  362. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  363. // checkConsistency=false und extendResolution=true
  364. result = process_doFlow(analogs, digits, Digital100, false, true, 0);
  365. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  366. // Fehler V12.0.1 "TODO 00211.03480 vs 00211.03580"
  367. // Lokal "Hängendes Digit"
  368. digits = { 2.0, 1.0, 1.0, 0.0, 3.0, 4.8}; // 00211.03480 als falsches Ergebnis
  369. analogs = {8.0};
  370. expected = "211.0358";
  371. expected_extended= "211.03580";
  372. // extendResolution=false
  373. result = process_doFlow(analogs, digits, Digital100, false, false, -3);
  374. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  375. // checkConsistency=false und extendResolution=true
  376. result = process_doFlow(analogs, digits, Digital100, false, true, -3);
  377. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  378. // Fehler V12.0.1
  379. // https://github.com/jomjol/AI-on-the-edge-device/issues/1143#issuecomment-1281231468
  380. digits = { 1.0, 1.9, 6.0}; // 125.923 als falsches Ergebnis
  381. analogs = {9.3, 2.3, 3.1};
  382. expected = "126.923";
  383. expected_extended= "126.9231";
  384. // extendResolution=false
  385. result = process_doFlow(analogs, digits, Digital100, false, false, 0);
  386. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  387. // checkConsistency=false und extendResolution=true
  388. result = process_doFlow(analogs, digits, Digital100, false, true, 0);
  389. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  390. // Fehler V12.0.1
  391. // https://github.com/jomjol/AI-on-the-edge-device/issues/1110#issuecomment-1282168030
  392. digits = { 3.0, 8.1, 5.9, 0.0, 5.0, 6.7}; // 386.05672 als richtiges Ergebnis. Letztes digit schein mit dem Analogzeiger mitzulaufen
  393. analogs = {7.2};
  394. expected = "386.0567";
  395. expected_extended= "386.05672";
  396. // extendResolution=false
  397. result = process_doFlow(analogs, digits, Digital100, false, false, -3);
  398. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  399. // checkConsistency=false und extendResolution=true
  400. result = process_doFlow(analogs, digits, Digital100, false, true, -3);
  401. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  402. // Fehler V12.0.1
  403. // https://github.com/jomjol/AI-on-the-edge-device/issues/1110#issuecomment-1282168030
  404. digits = { 1.2, 7.0, 1.2, 2.0, 4.0, 1.8}; // 171.24278 als falsches Ergebnis.
  405. // Test ist nur erfolgreich mit Veränderung des AnalogdigitTransistionStart
  406. analogs = {7.8};
  407. expected = "171.2417";
  408. expected_extended= "171.24178";
  409. // extendResolution=false
  410. undertestPost = init_do_flow(analogs, digits, Digital100, false, false, -3);
  411. setAnalogdigitTransistionStart(undertestPost, 7.7);
  412. result = process_doFlow(undertestPost);
  413. TEST_ASSERT_EQUAL_STRING(expected, result.c_str());
  414. delete undertestPost;
  415. // checkConsistency=false und extendResolution=true
  416. undertestPost = init_do_flow(analogs, digits, Digital100, false, true, -3);
  417. setAnalogdigitTransistionStart(undertestPost, 7.7);
  418. result = process_doFlow(undertestPost);
  419. TEST_ASSERT_EQUAL_STRING(expected_extended, result.c_str());
  420. delete undertestPost;
  421. }