mirror of
https://github.com/jomjol/AI-on-the-edge-device.git
synced 2025-12-08 20:46:52 +03:00
fix false value if analog + dighybrid on last digit if previous >=9.5
This commit is contained in:
@@ -181,7 +181,7 @@ int ClassFlowCNNGeneral::ZeigerEvalHybrid(float zahl, float zahl_vorgaenger, int
|
|||||||
return ((int) trunc(zahl) + 10) % 10;
|
return ((int) trunc(zahl) + 10) % 10;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((zahl_vorgaenger >= 0.5 ) && (zahl_vorgaenger <= 9.5))
|
if ((zahl_vorgaenger >= 0.5 ) && (zahl_vorgaenger < 9.5))
|
||||||
{
|
{
|
||||||
// kein Ziffernwechsel, da Vorkomma weit genug weg ist (0+/-0.5) --> zahl wird gerundet
|
// kein Ziffernwechsel, da Vorkomma weit genug weg ist (0+/-0.5) --> zahl wird gerundet
|
||||||
return ((int) round(zahl) + 10) % 10;
|
return ((int) round(zahl) + 10) % 10;
|
||||||
@@ -197,7 +197,9 @@ int ClassFlowCNNGeneral::ZeigerEvalHybrid(float zahl, float zahl_vorgaenger, int
|
|||||||
}
|
}
|
||||||
else // bleibt nur >= 9.5 --> noch kein Nulldurchgang --> 2.8 --> 2, und 3.1 --> 2
|
else // bleibt nur >= 9.5 --> noch kein Nulldurchgang --> 2.8 --> 2, und 3.1 --> 2
|
||||||
{
|
{
|
||||||
if (ergebnis_nachkomma > 5)
|
// hier auf 4 reduziert, da erst ab Vorgänder 9 anfängt umzustellen. Bei 9.5 Vorgänger kann die aktuelle
|
||||||
|
// Zahl noch x.4 - x.5 sein.
|
||||||
|
if (ergebnis_nachkomma >= 4)
|
||||||
return ergebnis_vorkomma;
|
return ergebnis_vorkomma;
|
||||||
else
|
else
|
||||||
return (ergebnis_vorkomma - 1 + 10) % 10;
|
return (ergebnis_vorkomma - 1 + 10) % 10;
|
||||||
@@ -239,10 +241,11 @@ int ClassFlowCNNGeneral::ZeigerEvalHybrid(float zahl, float zahl_vorgaenger, int
|
|||||||
|
|
||||||
|
|
||||||
int ClassFlowCNNGeneral::ZeigerEval(float zahl, int ziffer_vorgaenger)
|
int ClassFlowCNNGeneral::ZeigerEval(float zahl, int ziffer_vorgaenger)
|
||||||
{
|
{
|
||||||
int ergebnis_nachkomma = ((int) floor(zahl * 10) + 10) % 10;
|
int ergebnis_nachkomma = ((int) floor(zahl * 10) + 10) % 10;
|
||||||
int ergebnis_vorkomma = ((int) floor(zahl) + 10) % 10;
|
int ergebnis_vorkomma = ((int) floor(zahl) + 10) % 10;
|
||||||
int ergebnis, ergebnis_rating;
|
int ergebnis;
|
||||||
|
float ergebnis_rating;
|
||||||
if (debugdetailgeneral) LogFile.WriteToFile("ClassFlowCNNGeneral::ZeigerEval erg_v=" + std::to_string(ergebnis_vorkomma) + ", erg_n=" + std::to_string(ergebnis_nachkomma) + ", ziff_v=" + std::to_string(ziffer_vorgaenger));
|
if (debugdetailgeneral) LogFile.WriteToFile("ClassFlowCNNGeneral::ZeigerEval erg_v=" + std::to_string(ergebnis_vorkomma) + ", erg_n=" + std::to_string(ergebnis_nachkomma) + ", ziff_v=" + std::to_string(ziffer_vorgaenger));
|
||||||
|
|
||||||
if (ziffer_vorgaenger == -1)
|
if (ziffer_vorgaenger == -1)
|
||||||
@@ -250,10 +253,12 @@ int ClassFlowCNNGeneral::ZeigerEval(float zahl, int ziffer_vorgaenger)
|
|||||||
|
|
||||||
// Ist die aktuelle Stelle schon umgesprungen und die Vorstelle noch nicht?
|
// Ist die aktuelle Stelle schon umgesprungen und die Vorstelle noch nicht?
|
||||||
// Akt.: 2.1, Vorstelle = 0.9 => 1.9
|
// Akt.: 2.1, Vorstelle = 0.9 => 1.9
|
||||||
|
// Problem sind mehrere Rundungen
|
||||||
|
// Bsp. zahl=4.5, Vorgänger= 9.6 (ziffer_vorgaenger=0)
|
||||||
|
// Tritt nur auf bei Übergang von analog auf digit
|
||||||
ergebnis_rating = ergebnis_nachkomma - ziffer_vorgaenger;
|
ergebnis_rating = ergebnis_nachkomma - ziffer_vorgaenger;
|
||||||
|
|
||||||
if (ergebnis_nachkomma >= 5)
|
if (ergebnis_nachkomma >= 5)
|
||||||
ergebnis_rating-=5;
|
ergebnis_rating-=5.1;
|
||||||
else
|
else
|
||||||
ergebnis_rating+=5;
|
ergebnis_rating+=5;
|
||||||
ergebnis = (int) round(zahl);
|
ergebnis = (int) round(zahl);
|
||||||
|
|||||||
@@ -41,6 +41,9 @@ void test_ZeigerEval()
|
|||||||
// the 4.4 (digital100) is not above 5 and the previous digit (analog) too (9.3)
|
// the 4.4 (digital100) is not above 5 and the previous digit (analog) too (9.3)
|
||||||
TEST_ASSERT_EQUAL(4, undertest.ZeigerEval(4.4, 9));
|
TEST_ASSERT_EQUAL(4, undertest.ZeigerEval(4.4, 9));
|
||||||
|
|
||||||
|
// the 4.5 (digital100) is not above 5 and the previous digit (analog) too (9.6)
|
||||||
|
TEST_ASSERT_EQUAL(4, undertest.ZeigerEval(4.5, 0));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -77,5 +80,13 @@ void test_ZeigerEvalHybrid() {
|
|||||||
// the 5.7 with previous and the previous >=9.5 should trunc to 5
|
// the 5.7 with previous and the previous >=9.5 should trunc to 5
|
||||||
TEST_ASSERT_EQUAL(5, undertest.ZeigerEvalHybrid(5.7, 9.6, 9));
|
TEST_ASSERT_EQUAL(5, undertest.ZeigerEvalHybrid(5.7, 9.6, 9));
|
||||||
|
|
||||||
|
// the 4.5 (digital100) is not above 5 and the previous digit (analog) not over Zero (9.6)
|
||||||
|
TEST_ASSERT_EQUAL(4, undertest.ZeigerEvalHybrid(4.5, 9.6, 0));
|
||||||
|
|
||||||
|
// the 4.5 (digital100) is not above 5 and the previous digit (analog) not over Zero (9.6)
|
||||||
|
TEST_ASSERT_EQUAL(4, undertest.ZeigerEvalHybrid(4.5, 9.6, 9));
|
||||||
|
// the 4.4 (digital100) is not above 5 and the previous digit (analog) not over Zero (9.5)
|
||||||
|
TEST_ASSERT_EQUAL(4, undertest.ZeigerEvalHybrid(4.5, 9.5, 9));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user