summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar jan Iversen <jan@casacondor.com>2020-01-28 16:50:21 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2020-01-28 15:34:54 -0800
commiteec15112180a22ffc04f15a20706e9c6941698d0 (patch)
treea3e5c32f3fcd93e7774016cc625d72effbd99fcf
parent303b5865cdf3e9cefd5e5263ee15fd869623b1e8 (diff)
downloadsubsurface-eec15112180a22ffc04f15a20706e9c6941698d0.tar.gz
divesummary: correct SAC calculation
Do not count dives where SAC == 0. Signed-off-by: jan Iversen <jan@casacondor.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--backend-shared/divesummary.cpp17
-rw-r--r--backend-shared/divesummary.h1
2 files changed, 13 insertions, 5 deletions
diff --git a/backend-shared/divesummary.cpp b/backend-shared/divesummary.cpp
index 43f34a7ff..9f3c749cb 100644
--- a/backend-shared/divesummary.cpp
+++ b/backend-shared/divesummary.cpp
@@ -11,6 +11,7 @@ timestamp_t diveSummary::firstDive, diveSummary::lastDive;
int diveSummary::dives[2], diveSummary::divesEAN[2], diveSummary::divesDeep[2], diveSummary::diveplans[2];
long diveSummary::divetime[2], diveSummary::depth[2], diveSummary::sac[2];
long diveSummary::divetimeMax[2], diveSummary::depthMax[2], diveSummary::sacMin[2];
+int diveSummary::divesSAC[2];
void diveSummary::summaryCalculation(int primaryPeriod, int secondaryPeriod)
{
@@ -64,6 +65,7 @@ void diveSummary::loopDives(timestamp_t primaryStart, timestamp_t secondaryStart
sac[0] = sac[1] = 0;
divetimeMax[0] = divetimeMax[1] = depthMax[0] = depthMax[1] = 0;
sacMin[0] = sacMin[1] = 99999;
+ divesSAC[0] = divesSAC[1] = 0;
for_each_dive (i, dive) {
// remember time of oldest and newest dive
@@ -113,9 +115,12 @@ void diveSummary::calculateDive(int inx, struct dive *dive)
// sum SAC in liters, check for new max.
temp = dive->sac / 1000;
- sac[inx] += temp;
- if (temp < sacMin[inx])
- sacMin[inx] = temp;
+ if (temp) {
+ divesSAC[inx]++;
+ sac[inx] += temp;
+ if (temp < sacMin[inx])
+ sacMin[inx] = temp;
+ }
// EAN dive ?
for (int j = 0; j < dive->cylinders.nr; ++j) {
@@ -161,8 +166,10 @@ void diveSummary::buildStringList(int inx)
// SAC
tempStr = (qPrefUnits::volume() == units::LITER) ? "l/min" : "cuft/min";
diveSummaryText[18+inx] = QStringLiteral("%1 %2").arg(sacMin[inx]).arg(tempStr);
- temp1 = depth[inx] / dives[inx];
- diveSummaryText[20+inx] = QStringLiteral("%1%2").arg(temp1).arg(tempStr);
+ if (divesSAC[inx]) {
+ temp1 = depth[inx] / divesSAC[inx];
+ diveSummaryText[20+inx] = QStringLiteral("%1%2").arg(temp1).arg(tempStr);
+ }
// Diveplan(s)
diveSummaryText[22+inx] = QStringLiteral("%1").arg(diveplans[inx]);
diff --git a/backend-shared/divesummary.h b/backend-shared/divesummary.h
index 16f8a09ec..986024b44 100644
--- a/backend-shared/divesummary.h
+++ b/backend-shared/divesummary.h
@@ -24,5 +24,6 @@ private:
static long divetime[2], depth[2], sac[2];
static long divetimeMax[2], depthMax[2], sacMin[2];
static long divetimeAvg[2], depthAvg[2], sacAvg[2];
+ static int divesSAC[2];
};
#endif // DIVESUMMARY_H