summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar jan Iversen <jan@casacondor.com>2019-12-25 10:45:20 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2019-12-28 06:53:12 +0900
commitb6b514ea862051bfb8b389047a5d996da81155f6 (patch)
treee55cf6ce09ccadb6b9756728788bbf43b71c182a
parent2d353a756be2a8469c4a8596303b334ad85beae8 (diff)
downloadsubsurface-b6b514ea862051bfb8b389047a5d996da81155f6.tar.gz
planner: correct rating calculations.
Test show that the ratings calculations were off by +/- 1, due to rounding errors. Found due to test cases in tests (other commits) The calculations are copied 1-1 from diveplanner.cpp, but are used slightly different in plannerShared.cpp Correct calculations, by securing the calculation is done with float precision and the rounded with lrint(). Signed-off-by: Jan Iversen <jan@casacondor.com>
-rw-r--r--backend-shared/plannershared.cpp22
1 files changed, 11 insertions, 11 deletions
diff --git a/backend-shared/plannershared.cpp b/backend-shared/plannershared.cpp
index 4de4fd80a..dc44cc37c 100644
--- a/backend-shared/plannershared.cpp
+++ b/backend-shared/plannershared.cpp
@@ -12,52 +12,52 @@ plannerShared *plannerShared::instance()
}
// Used to convert between meter/feet and keep the qPref variables independent
-#define TO_MM_BY_SEC ((prefs.units.length == units::METERS) ? 1000.0 / 60.0 : feet_to_mm(1.0) / 60.0)
+#define TO_MM_BY_SEC ((prefs.units.length == units::METERS) ? 1000.0 / 60.0 : feet_to_mm(1) / 60.0)
// Converted meter/feet qPrefDivePlanner values
int plannerShared::ascratelast6m()
{
- return lrint(prefs.ascratelast6m / TO_MM_BY_SEC);
+ return lrint((float)prefs.ascratelast6m / TO_MM_BY_SEC);
}
void plannerShared::set_ascratelast6m(int value)
{
- qPrefDivePlanner::set_ascratelast6m(value * TO_MM_BY_SEC);
+ qPrefDivePlanner::set_ascratelast6m(lrint((float)value * TO_MM_BY_SEC));
}
int plannerShared::ascratestops()
{
- return lrint(prefs.ascratestops / TO_MM_BY_SEC);
+ return lrint((float)prefs.ascratestops / TO_MM_BY_SEC);
}
void plannerShared::set_ascratestops(int value)
{
- qPrefDivePlanner::set_ascratestops(value * TO_MM_BY_SEC);
+ qPrefDivePlanner::set_ascratestops(lrint((float)value * TO_MM_BY_SEC));
}
int plannerShared::ascrate50()
{
- return lrint(prefs.ascrate50 / TO_MM_BY_SEC);
+ return lrint((float)prefs.ascrate50 / TO_MM_BY_SEC);
}
void plannerShared::set_ascrate50(int value)
{
- qPrefDivePlanner::set_ascrate50(value * TO_MM_BY_SEC);
+ qPrefDivePlanner::set_ascrate50(lrint((float)value * TO_MM_BY_SEC));
}
int plannerShared::ascrate75()
{
- return lrint(prefs.ascrate75 / TO_MM_BY_SEC);
+ return lrint((float)prefs.ascrate75 / TO_MM_BY_SEC);
}
void plannerShared::set_ascrate75(int value)
{
- qPrefDivePlanner::set_ascrate75(value * TO_MM_BY_SEC);
+ qPrefDivePlanner::set_ascrate75(lrint((float)value * TO_MM_BY_SEC));
}
int plannerShared::descrate()
{
- return lrint(prefs.descrate / TO_MM_BY_SEC);
+ return lrint((float)prefs.descrate / TO_MM_BY_SEC);
}
void plannerShared::set_descrate(int value)
{
- qPrefDivePlanner::set_descrate(value * TO_MM_BY_SEC);
+ qPrefDivePlanner::set_descrate(lrint((float)value * TO_MM_BY_SEC));
}
// Planning values