From eec15112180a22ffc04f15a20706e9c6941698d0 Mon Sep 17 00:00:00 2001 From: jan Iversen Date: Tue, 28 Jan 2020 16:50:21 +0100 Subject: divesummary: correct SAC calculation Do not count dives where SAC == 0. Signed-off-by: jan Iversen Signed-off-by: Dirk Hohndel --- backend-shared/divesummary.cpp | 17 ++++++++++++----- backend-shared/divesummary.h | 1 + 2 files changed, 13 insertions(+), 5 deletions(-) (limited to 'backend-shared') 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 -- cgit v1.2.3-70-g09d2