From 84e61844ab064411ead842a47276ff56b5a50a08 Mon Sep 17 00:00:00 2001 From: Gerhard Hoffmann Date: Sun, 18 Aug 2024 19:22:07 +0200 Subject: [PATCH 1/8] test case schnals --- main/main.cpp | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/main/main.cpp b/main/main.cpp index 96763ff..a0a67e8 100644 --- a/main/main.cpp +++ b/main/main.cpp @@ -741,7 +741,8 @@ int main() { input.open("/opt/ptu5/opt/customer_502/etc/psa_tariff/tariff02.json"); } if (zone == 3) { - //input.open("/opt/ptu5/opt/customer_502/etc/psa_tariff/tariff03.json"); + input.open("/opt/ptu5/opt/customer_502/etc/psa_tariff/tariff03.json"); + //input.open("/home/linux/customer_502/etc/psa_tariff/tariff01.json"); input.open("/home/linux/customer_502/etc/psa_tariff/tariff03.json"); } @@ -916,7 +917,9 @@ int main() { QDateTime end; QDateTime s(QDateTime::currentDateTime()); - s.setTime(QTime(18, 0, 0)); + s.setTime(QTime(13, 30, 0)); + +#if 0 pop_min_time = get_minimal_parkingtime(&cfg, PermitType(PERMIT_TYPE::SHORT_TERM_PARKING), paymentOptionIndex); pop_max_time = get_maximal_parkingtime(&cfg, PermitType(PERMIT_TYPE::SHORT_TERM_PARKING), paymentOptionIndex); @@ -938,11 +941,13 @@ int main() { qCritical() << " pop_min_price " << pop_min_price; qCritical() << " pop_max_price " << pop_max_price; qCritical() << "pop_daily_card_price " << pop_daily_card_price; - +#endif CalcState calcState; -#if 0 - for (int i = 1; i < 11; ++i) { +#if 1 + qCritical() << "start" << s.toString(Qt::ISODate); + //for (int i = 1; i < 11; ++i) { + for (int i = 1; i < 8; ++i) { calcState = compute_duration_for_parking_ticket(&cfg, s, (double)i*200, end, PermitType(PERMIT_TYPE::SHORT_TERM_PARKING_PKW)); From ae9a54bf028be2df23cfc60ba548a80a9737831e Mon Sep 17 00:00:00 2001 From: Gerhard Hoffmann Date: Sun, 18 Aug 2024 19:23:12 +0200 Subject: [PATCH 2/8] Added: pun_mutable: duration might be changed during runtime pun_round_to_next_24h_boundary duration has to be aligned with next possible 24h boundary pun_round_to_prev_24h_boundary duration has to be aligned with previous 24h boundary pun_align_with_timepoint duration has to be aligned with dedicated time point Removed: pun_requires_change Replaced by pu_mutable --- library/include/mobilisis/duration.h | 36 ++++++++++++++++++---------- 1 file changed, 23 insertions(+), 13 deletions(-) diff --git a/library/include/mobilisis/duration.h b/library/include/mobilisis/duration.h index 668cd8b..b307d11 100644 --- a/library/include/mobilisis/duration.h +++ b/library/include/mobilisis/duration.h @@ -1,6 +1,7 @@ #include #include +#include class ATBDuration { @@ -16,7 +17,10 @@ public: , pun_netto(false) , pun_brutto(false) , pun_fixed(false) - , pun_requires_change(false) + , pun_mutable(false) + , pun_round_to_next_24h_boundary(false) + , pun_round_to_prev_24h_boundary(false) + , pun_align_with_timepoint(QDateTime()) , pun_next_step_correction(0) { } @@ -24,17 +28,20 @@ public: QDebugStateSaver saver(debug); debug.nospace() - << " pun_id: " << td.pun_id << "\n" - << " pun_label: " << QString::fromStdString(td.pun_label) << "\n" - << " pun_duration: " << td.pun_duration << "\n" - << " pun_duration_saved: " << td.pun_duration_saved << "\n" - << " pun_duration_min: " << td.pun_duration_min << "\n" - << " pun_duration_max: " << td.pun_duration_max << "\n" - << " pun_netto: " << td.pun_netto << "\n" - << " pun_brutto: " << td.pun_brutto << "\n" - << " pun_fixed: " << td.pun_fixed << "\n" - << " pun_requires_change: " << td.pun_requires_change << "\n" - << "pun_interpolation_id: " << td.pun_interpolation_id << "\n"; + << " pun_id: " << td.pun_id << "\n" + << " pun_label: " << QString::fromStdString(td.pun_label) << "\n" + << " pun_duration: " << td.pun_duration << "\n" + << " pun_duration_saved: " << td.pun_duration_saved << "\n" + << " pun_duration_min: " << td.pun_duration_min << "\n" + << " pun_duration_max: " << td.pun_duration_max << "\n" + << " pun_interpolation_id: " << td.pun_interpolation_id << "\n" + << " pun_netto: " << td.pun_netto << "\n" + << " pun_brutto: " << td.pun_brutto << "\n" + << " pun_fixed: " << td.pun_fixed << "\n" + << " pun_mutable: " << td.pun_mutable << "\n" + << "pun_round_to_next_24h_boundary: " << td.pun_round_to_next_24h_boundary << "\n" + << "pun_round_to_prev_24h_boundary: " << td.pun_round_to_prev_24h_boundary << "\n" + << " pun_align_with_timepoint: " << td.pun_align_with_timepoint << endl; return debug; } @@ -49,6 +56,9 @@ public: bool pun_netto; // the timestep expressed by this duration is a netto timestep bool pun_brutto; // the timestep expressed by this duration is a brutto timestep bool pun_fixed; // the value given in tariff-file is fixed (constant) - bool pun_requires_change; // the value has to be changes (controlled by other parameters) + bool pun_mutable; // the value could change + bool pun_round_to_next_24h_boundary; + bool pun_round_to_prev_24h_boundary; + QDateTime pun_align_with_timepoint; int pun_next_step_correction; }; From 171b23eebb0c6cc01fa3cc3467ddc73990b28ce5 Mon Sep 17 00:00:00 2001 From: Gerhard Hoffmann Date: Sun, 18 Aug 2024 19:27:06 +0200 Subject: [PATCH 3/8] added parsing for new duration fields --- library/src/configuration.cpp | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/library/src/configuration.cpp b/library/src/configuration.cpp index 3b1c8ea..a73acc2 100644 --- a/library/src/configuration.cpp +++ b/library/src/configuration.cpp @@ -144,7 +144,7 @@ bool Configuration::ParseJson(Configuration* cfg, const char* json) continue; } - qCritical() << " -" << mb_name; + // qCritical() << " -" << mb_name; // Get array for each JSON object member auto mb_array = document[mb_name].GetArray(); @@ -797,9 +797,25 @@ bool Configuration::ParseJson(Configuration* cfg, const char* json) Duration.pun_fixed = k->value.GetBool(); } } - else if (strcmp(inner_obj_name, "pun_requires_change") == 0) { + else if (strcmp(inner_obj_name, "pun_mutable") == 0) { if (k->value.IsBool()) { - Duration.pun_requires_change = k->value.GetBool(); + Duration.pun_mutable = k->value.GetBool(); + } + } + else if (strcmp(inner_obj_name, "pun_round_to_next_24h_boundary") == 0) { + if (k->value.IsBool()) { + Duration.pun_round_to_next_24h_boundary = k->value.GetBool(); + } + } + else if (strcmp(inner_obj_name, "pun_round_to_prev_24h_boundary") == 0) { + if (k->value.IsBool()) { + Duration.pun_round_to_prev_24h_boundary = k->value.GetBool(); + } + } + else if (strcmp(inner_obj_name, "pun_align_with_timepoint") == 0) { + if (k->value.IsString()) { + QDateTime const &dt = QDateTime::fromString(k->value.GetString(), Qt::ISODate); + Duration.pun_align_with_timepoint = dt; } } break; @@ -866,7 +882,7 @@ bool Configuration::ParseJson(Configuration* cfg, const char* json) } break; case MemberType::DurationType: cfg->Duration.insert(pair(Duration.pun_id, Duration)); - // qCritical() << Duration; + //qCritical() << Duration; break; case MemberType::SpecialDaysWorktimeType: cfg->SpecialDaysWorktime.insert(pair(SpecialDaysWorktime.pedwt_period_exc_day_id, SpecialDaysWorktime)); @@ -922,7 +938,7 @@ bool Configuration::ParseJson(Configuration* cfg, const char* json) break; case MemberType::PrepaidOptionType: cfg->TariffPrepayOptions.insert(pair(TariffPrepayOption.id, TariffPrepayOption)); - qCritical() << TariffPrepayOption; + //qCritical() << TariffPrepayOption; break; default: break; From d86a688836bfdec2e0c7eacc4129651802e12b1b Mon Sep 17 00:00:00 2001 From: Gerhard Hoffmann Date: Sun, 18 Aug 2024 19:29:48 +0200 Subject: [PATCH 4/8] GetTimeSteps(): unifiy implementation for Fuchs/Muehlbach and Fuchs/Schnals. --- library/src/calculator_functions.cpp | 321 +++++++++++++++++---------- 1 file changed, 201 insertions(+), 120 deletions(-) diff --git a/library/src/calculator_functions.cpp b/library/src/calculator_functions.cpp index a845a79..915dfda 100644 --- a/library/src/calculator_functions.cpp +++ b/library/src/calculator_functions.cpp @@ -10,9 +10,12 @@ #include #include #include +#include + #include #include #include +#include double total_duration_min = 0.0f; double total_cost = 0.0f; @@ -2787,151 +2790,230 @@ QList &Calculator::GetTimeSteps(Configuration *cfg, int paymentOptionIndex, int const pop_accumulate_durations = cfg->getPaymentOptions(paymentOptionIndex).pop_accumulate_durations; m_timeSteps[paymentOptionIndex].clear(); - Configuration::TariffDurationType::iterator prev_it = cfg->Duration.end(); - start = s; - start.setTime(QTime(s.time().hour(), s.time().minute(), 0)); + QDateTime const start(s.date(), + QTime(s.time().hour(), s.time().minute(), 0), + s.timeZone()); - // qCritical() << "(" << __func__ << ":" << __LINE__ << ") start:" << start.toString(Qt::ISODate); + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") start:" << start.toString(Qt::ISODate); + } + + QDateTime current(start); + + bool casePrepay = false; + int const weekDay = start.date().dayOfWeek(); + + int const pop_prepay_option_id = cfg->getPaymentOptions(paymentOptionIndex).pop_prepay_option_id; + + // compute prepay settings + // assumption: prepay settings the same for all days + QDateTime prepayStart(start); + QDateTime prepayEnd(start); + + prepayStart.setTime(cfg->TariffPrepayOptions.find(pop_prepay_option_id)->second.prepay[weekDay].start); + prepayEnd.setTime(cfg->TariffPrepayOptions.find(pop_prepay_option_id)->second.prepay[weekDay].end); + + if (start <= prepayEnd) { + prepayStart = prepayStart.addDays(-1); + } else { + prepayEnd = prepayEnd.addDays(1); + } + + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") prepay start" << prepayStart.toString(Qt::ISODate); + qCritical() << "(" << __func__ << ":" << __LINE__ << ") prepay end" << prepayEnd.toString(Qt::ISODate); + } + + int const prepayDurationInMinutes = start.secsTo(prepayEnd) / 60; + + // compute carryover settings + // assumption: carryover settings the same for all days + int const pop_carry_over_option_id = cfg->getPaymentOptions(paymentOptionIndex).pop_carry_over_option_id; + QDateTime carryOverStart(start); + QDateTime carryOverEnd(start); + + carryOverStart.setTime(cfg->TariffCarryOverOptions.find(pop_carry_over_option_id)->second.carryover[weekDay].static_start); + carryOverEnd.setTime(cfg->TariffCarryOverOptions.find(pop_carry_over_option_id)->second.carryover[weekDay].static_end); + + if (start <= carryOverEnd) { + carryOverStart = carryOverStart.addDays(-1); + } else { + carryOverEnd = carryOverEnd.addDays(1); + } + + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") carry over start" << carryOverStart.toString(Qt::ISODate); + qCritical() << "(" << __func__ << ":" << __LINE__ << ") carry over end" << carryOverEnd.toString(Qt::ISODate); + } + + // int cnt = 0; for (Configuration::TariffDurationType::iterator it = cfg->Duration.begin(); it != cfg->Duration.end(); ++it) { it->second.pun_duration = it->second.pun_duration_saved; - if (it->second.pun_requires_change) { - if (it->second.pun_netto && !it->second.pun_brutto) { - int weekDay = start.date().dayOfWeek(); - bool casePrepay = false; - if (m_timeSteps[paymentOptionIndex].isEmpty()) { - // handle possible prepay-condition, which applies only - // for the very first step + // if (++cnt > 4) continue; - int const pop_prepay_option_id = cfg->getPaymentOptions(paymentOptionIndex).pop_prepay_option_id; - QDateTime prepayStart(start); - QDateTime prepayEnd(start); + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") pun_id" << it->second.pun_id; + } - prepayStart.setTime(cfg->TariffPrepayOptions.find(pop_prepay_option_id)->second.prepay[weekDay].start); - prepayEnd.setTime(cfg->TariffPrepayOptions.find(pop_prepay_option_id)->second.prepay[weekDay].end); + if (it->second.pun_mutable) { + if (it->second.pun_netto) { + if (it->second.pun_round_to_next_24h_boundary == false) { + //int weekDay = start.date().dayOfWeek(); + casePrepay = false; + if (m_timeSteps[paymentOptionIndex].isEmpty()) { + // handle possible prepay-condition, which applies only + // for the very first step - if (start <= prepayEnd) { - prepayStart = prepayStart.addDays(-1); - } else { - prepayEnd = prepayEnd.addDays(1); - } + if (prepayStart <= start && start <= prepayEnd) { + it->second.pun_duration = prepayDurationInMinutes; + it->second.pun_duration += it->second.pun_duration_saved ; + casePrepay = true; + } - qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << start.toString(Qt::ISODate); - qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << prepayStart.toString(Qt::ISODate); - qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << prepayEnd.toString(Qt::ISODate); - - if (prepayStart <= start && start <= prepayEnd) { - it->second.pun_duration = start.secsTo(prepayEnd) / 60; - it->second.pun_duration += it->second.pun_duration_saved ; - casePrepay = true; - } - //if (start >= prepayStart && ) { - // it->second.pun_duration = start.secsTo(prepayEnd) / 60; - // it->second.pun_duration += it->second.pun_duration_saved ; - // casePrepay = true; - //} - - qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << it->second.pun_duration; - } - - if (!casePrepay) { - // handle possible carryover-condition - int const pop_carry_over_option_id = cfg->getPaymentOptions(paymentOptionIndex).pop_carry_over_option_id; - QDateTime carryOverStart(start); - QDateTime carryOverEnd(start); - - qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << carryOverStart.toString(Qt::ISODate); - - carryOverStart.setTime(cfg->TariffCarryOverOptions.find(pop_carry_over_option_id)->second.carryover[weekDay].static_start); - carryOverEnd.setTime(cfg->TariffCarryOverOptions.find(pop_carry_over_option_id)->second.carryover[weekDay].static_end); - - //while (carryOverStart > carryOverEnd) { - // carryOverEnd = carryOverEnd.addDays(1); - //} - - if (start <= carryOverEnd) { - carryOverStart = carryOverStart.addDays(-1); - } else { - carryOverEnd = carryOverEnd.addDays(1); - } - - int durationInSecs = it->second.pun_duration_saved * 60; - - //qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << durationInSecs; - //qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << start.addSecs(durationInSecs).toString(Qt::ISODate); - //qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << carryOverStart.toString(Qt::ISODate); - - it->second.pun_duration = it->second.pun_duration_saved; - if (start >= carryOverStart) { - it->second.pun_duration += start.secsTo(carryOverEnd) / 60; - } else { - // start < carryOverStart - if (start.addSecs(durationInSecs) >= carryOverStart) { - // cross carry over section - it->second.pun_next_step_correction = carryOverStart.secsTo(carryOverEnd) / 60; - it->second.pun_duration += it->second.pun_next_step_correction; - prev_it = it; + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << it->second.pun_duration; + qCritical() << "(" << __func__ << ":" << __LINE__ << ") prepay" << casePrepay; } } + + if (!casePrepay) { + // handle possible carryover-condition + + int durationInSecs = it->second.pun_duration_saved * 60; + + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << durationInSecs; + qCritical() << "(" << __func__ << ":" << __LINE__ << ") start" << start.toString(Qt::ISODate); + qCritical() << "(" << __func__ << ":" << __LINE__ << ") current" << current.toString(Qt::ISODate); + qCritical() << "(" << __func__ << ":" << __LINE__ << ") current next" << current.addSecs(durationInSecs).toString(Qt::ISODate); + } + + it->second.pun_duration = it->second.pun_duration_saved; + if (current >= carryOverStart) { + it->second.pun_duration += current.secsTo(carryOverEnd) / 60; + } else { + // start < carryOverStart + QDateTime const &newCurrent = current.addSecs(durationInSecs); + if (newCurrent > carryOverStart) { + // cross carry over section + it->second.pun_next_step_correction = carryOverStart.secsTo(carryOverEnd) / 60; + it->second.pun_duration += it->second.pun_next_step_correction; + } + } + + } else { + // qCritical() << "(" << __func__ << ":" << __LINE__ << ")"; + } + + if (pop_accumulate_durations) { + m_timeSteps[paymentOptionIndex] << it->second.pun_duration; + } else { + if (!m_timeSteps[paymentOptionIndex].isEmpty()) { + int d = m_timeSteps[paymentOptionIndex].last(); + m_timeSteps[paymentOptionIndex] << (d + it->second.pun_duration); + } + } + + current = current.addSecs(m_timeSteps[paymentOptionIndex].last() * 60); + + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << m_timeSteps[paymentOptionIndex]; + qCritical() << "(" << __func__ << ":" << __LINE__ << ") current" << current.toString(Qt::ISODate); + } + + } else { // if (it->pun_round_to_next_24h_boundary == false) { + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") round-to-next-24h-boundary"; + qCritical() << "(" << __func__ << ":" << __LINE__ << ") prepay" << casePrepay; + qCritical() << "(" << __func__ << ":" << __LINE__ << ") current" << current.toString(Qt::ISODate); + } + + if (casePrepay) { + // the last time step contains the (dynamic) prepay duration + // so it is possible to compute the last duration + int lastDuration = m_timeSteps[paymentOptionIndex].last() - prepayDurationInMinutes; + // qCritical() << "(" << __func__ << ":" << __LINE__ << ") last duration " << lastDuration; + + int const minutesToAdd = 1440 - lastDuration; + current = current.addSecs(minutesToAdd * 60); + + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") minutes to add " << minutesToAdd; + qCritical() << "(" << __func__ << ":" << __LINE__ << ") current" << current.toString(Qt::ISODate); + } + + if (pop_accumulate_durations) { + m_timeSteps[paymentOptionIndex] << minutesToAdd; + } else { + if (!m_timeSteps[paymentOptionIndex].isEmpty()) { + int d = m_timeSteps[paymentOptionIndex].last(); + m_timeSteps[paymentOptionIndex] << (d + minutesToAdd); + } + } + + // qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << m_timeSteps[paymentOptionIndex]; + + casePrepay = false; + + } else { + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") pun_id" << it->second.pun_id; + qCritical() << "(" << __func__ << ":" << __LINE__ << ") current" << current.toString(Qt::ISODate); + qCritical() << "(" << __func__ << ":" << __LINE__ << ") pun_duration" << it->second.pun_duration; + } + + int secs = s.secsTo(current); + int const dayInSecs = 1440 * 60; + int const rest = secs % dayInSecs; + int const minutesToAdd = (dayInSecs - rest) / 60; + + current = current.addSecs(minutesToAdd * 60); + it->second.pun_duration = minutesToAdd; + + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") minutes to add " << minutesToAdd; + qCritical() << "(" << __func__ << ":" << __LINE__ << ") current" << current.toString(Qt::ISODate); + } + + if (pop_accumulate_durations) { + m_timeSteps[paymentOptionIndex] << minutesToAdd; + } else { + if (!m_timeSteps[paymentOptionIndex].isEmpty()) { + int d = m_timeSteps[paymentOptionIndex].last(); + m_timeSteps[paymentOptionIndex] << (d + minutesToAdd); + } + } + // qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << m_timeSteps[paymentOptionIndex]; + } } + } else { // if (it->second.pun_netto) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") TODO"; + } + } else { // mutable == false + if (it->second.pun_brutto) { // no handling for prepay and carry-over if (pop_accumulate_durations) { + m_timeSteps[paymentOptionIndex] << it->second.pun_duration; + } else { if (!m_timeSteps[paymentOptionIndex].isEmpty()) { int d = m_timeSteps[paymentOptionIndex].last(); m_timeSteps[paymentOptionIndex] << (d + it->second.pun_duration); - } else { - m_timeSteps[paymentOptionIndex] << it->second.pun_duration; } } + // qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << m_timeSteps[paymentOptionIndex]; + } else { - qCritical() << "(" << __func__ << ":" << __LINE__ << ")" - << "no change required, but set to brutto, which does not have to be changed"; - } - } else { - if (it->second.pun_fixed) { // no change required: must be true - if (it->second.pun_brutto) { // no handling for prepay and carry-over - if (pop_accumulate_durations) { - int correction = 0; - if (prev_it != cfg->Duration.end()) { - correction = prev_it->second.pun_next_step_correction; - prev_it->second.pun_next_step_correction = 0; - } - if (!m_timeSteps[paymentOptionIndex].isEmpty()) { - int d = m_timeSteps[paymentOptionIndex].last(); - it->second.pun_duration -= correction; - m_timeSteps[paymentOptionIndex] << (d + it->second.pun_duration); - } else { - it->second.pun_duration -= correction; - m_timeSteps[paymentOptionIndex] << it->second.pun_duration; - } - } - } else - if (it->second.pun_netto) { - qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << "TODO"; - } - } else { - qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << "fixed is false, but no change required"; + qCritical() << "(" << __func__ << ":" << __LINE__ << ") TODO"; } } } -#if 0 - for (int i = 0; i < m_timeSteps[paymentOptionIndex].size(); ++i) { - QDateTime nextTime = start; - // nextTime.setTime(QTime(0, 0, 0)); - int const secs = m_timeSteps[paymentOptionIndex][i] * 60; - nextTime = nextTime.addSecs(secs); - qCritical() << "(" << __func__ << ":" << __LINE__ << ") step" - << i << secs << m_timeSteps[0][i] << "->" << nextTime.toString(Qt::ISODate); - - } -#endif - } else { qCritical() << "(" << __func__ << ":" << __LINE__ << ") payment option time step config:" << "TimeStepConfig::STATIC"; @@ -2953,10 +3035,9 @@ QList &Calculator::GetTimeSteps(Configuration *cfg, int paymentOptionIndex, //qCritical() << "(" << __func__ << ":" << __LINE__ << ") NEW timeSteps:" << m_timeSteps; if (DBG_LEVEL >= DBG_DEBUG) { - qCritical() << "(" << __func__ << ":" << __LINE__ << ") NEW timeSteps:" << m_timeSteps; - + QDateTime nextTime(s); + qCritical() << "(" << __func__ << ":" << __LINE__ << ") start" << nextTime.toString(Qt::ISODate); for (int i = 0; i < m_timeSteps[paymentOptionIndex].size(); ++i) { - QDateTime nextTime = s; // nextTime.setTime(QTime(0, 0, 0)); int const secs = m_timeSteps[paymentOptionIndex][i] * 60; nextTime = nextTime.addSecs(secs); From 675ba607335927ea404a4bda8fae70328529556e Mon Sep 17 00:00:00 2001 From: Gerhard Hoffmann Date: Mon, 19 Aug 2024 12:10:43 +0200 Subject: [PATCH 5/8] tests for schnals/muehlbach --- main/main.cpp | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/main/main.cpp b/main/main.cpp index a0a67e8..962afc1 100644 --- a/main/main.cpp +++ b/main/main.cpp @@ -741,9 +741,14 @@ int main() { input.open("/opt/ptu5/opt/customer_502/etc/psa_tariff/tariff02.json"); } if (zone == 3) { - input.open("/opt/ptu5/opt/customer_502/etc/psa_tariff/tariff03.json"); + //input.open("/opt/ptu5/opt/customer_502/etc/psa_tariff/tariff03.json"); //input.open("/home/linux/customer_502/etc/psa_tariff/tariff01.json"); - input.open("/home/linux/customer_502/etc/psa_tariff/tariff03.json"); + + // schnals + // input.open("/opt/ptu5/opt/customer_505/etc/psa_tariff/tariff01.json"); + + // muehlbach + input.open("/opt/ptu5/opt/customer_504/etc/psa_tariff/tariff01.json"); } std::stringstream sstr; @@ -917,7 +922,7 @@ int main() { QDateTime end; QDateTime s(QDateTime::currentDateTime()); - s.setTime(QTime(13, 30, 0)); + s.setTime(QTime(10, 0, 0)); #if 0 @@ -947,12 +952,12 @@ int main() { #if 1 qCritical() << "start" << s.toString(Qt::ISODate); //for (int i = 1; i < 11; ++i) { - for (int i = 1; i < 8; ++i) { + for (int i = 0; i < 21; ++i) { calcState = compute_duration_for_parking_ticket(&cfg, s, - (double)i*200, + (double)i*10, end, PermitType(PERMIT_TYPE::SHORT_TERM_PARKING_PKW)); qCritical() << "RUN" << i << ": start" << s.toString(Qt::ISODate) - << ": price" << i*200 << "->" << end.toString(Qt::ISODate) << calcState.toString(); + << ": price" << i*10 << "->" << end.toString(Qt::ISODate) << calcState.toString(); } #else struct price_t price; From ceb78772ddb08a0ac48dfcb92168459d4e936a24 Mon Sep 17 00:00:00 2001 From: Gerhard Hoffmann Date: Mon, 19 Aug 2024 12:11:47 +0200 Subject: [PATCH 6/8] Minor: debug output --- library/src/calculate_price.cpp | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/library/src/calculate_price.cpp b/library/src/calculate_price.cpp index 92ac7d1..d053b7f 100644 --- a/library/src/calculate_price.cpp +++ b/library/src/calculate_price.cpp @@ -923,12 +923,15 @@ CalcState CALCULATE_LIBRARY_API compute_duration_for_parking_ticket( bool const nextDay = false; // DEBUG - if (DBG_LEVEL >= DBG_DEBUG) { - qCritical() << "compute_duration_for_parking_ticket(2): "; - qCritical() << " payment option index: " << paymentOptionIndex; - qCritical() << " prepaid: " << prepaid; - qCritical() << " price: " << price; - } + // if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "\ncompute_duration_for_parking_ticket(2):"; + qCritical() << " start time:" << start_parking_time.toString(Qt::ISODate); + qCritical() << " payment option index:" << paymentOptionIndex; + qCritical() << " prepaid:" << prepaid; + qCritical() << " price:" << price; + qCritical() << " permit type:" << permitType.toString() << endl; + + // } if (start_parking_time.isValid()) { QString cs = start_parking_time.toString(Qt::ISODate); @@ -1009,9 +1012,10 @@ CalcState CALCULATE_LIBRARY_API compute_duration_for_parking_ticket( } // DEBUG - qCritical() << "compute_duration_for_parking_ticket(): "; - qCritical() << " endTime: " << endTime; - qCritical() << " ticketEndTime: " << ticketEndTime; + qCritical() << "\ncompute_duration_for_parking_ticket():"; + qCritical() << " start time:" << start_parking_time.toString(Qt::ISODate); + qCritical() << " endTime:" << endTime; + qCritical() << " ticketEndTime:" << ticketEndTime.toString(Qt::ISODate) << endl; } } else { return calcState.set(CalcState::State::INVALID_START_DATE); From 84e25307676af074b08055823267ea9254448c72 Mon Sep 17 00:00:00 2001 From: Gerhard Hoffmann Date: Mon, 19 Aug 2024 12:18:05 +0200 Subject: [PATCH 7/8] Calculator::GetDurationFromCost(): Minor: debug output. --- library/src/calculator_functions.cpp | 29 ++++++++++++++-------------- 1 file changed, 15 insertions(+), 14 deletions(-) diff --git a/library/src/calculator_functions.cpp b/library/src/calculator_functions.cpp index 915dfda..e8518e5 100644 --- a/library/src/calculator_functions.cpp +++ b/library/src/calculator_functions.cpp @@ -178,6 +178,9 @@ std::string Calculator::GetDurationFromCost(Configuration* cfg, for (auto[itr, rangeEnd] = cfg->PaymentRate.equal_range(pop_id); itr != rangeEnd; ++itr) { int const pra_price = itr->second.pra_price; + + // qCritical() << DBG_HEADER << "pra_price" << pra_price; + int const durationId = itr->second.pra_payment_unit_id; if (pop_accumulate_prices) { price += pra_price; @@ -185,8 +188,8 @@ std::string Calculator::GetDurationFromCost(Configuration* cfg, price = pra_price; } - //qCritical() << DBG_HEADER << " PRICE" << price << "COST" << cost; - //qCritical() << DBG_HEADER << " duration id" << durationId; + // qCritical() << DBG_HEADER << " PRICE" << price << "COST" << cost; + // qCritical() << DBG_HEADER << " duration id" << durationId; auto search = cfg->Duration.find(durationId); if (search != cfg->Duration.end()) { @@ -2854,7 +2857,7 @@ QList &Calculator::GetTimeSteps(Configuration *cfg, int paymentOptionIndex, ++it) { it->second.pun_duration = it->second.pun_duration_saved; - // if (++cnt > 4) continue; + // if (++cnt > 2) continue; if (DBG_LEVEL >= DBG_DEBUG) { qCritical() << "(" << __func__ << ":" << __LINE__ << ") pun_id" << it->second.pun_id; @@ -2864,11 +2867,15 @@ QList &Calculator::GetTimeSteps(Configuration *cfg, int paymentOptionIndex, if (it->second.pun_netto) { if (it->second.pun_round_to_next_24h_boundary == false) { //int weekDay = start.date().dayOfWeek(); - casePrepay = false; if (m_timeSteps[paymentOptionIndex].isEmpty()) { // handle possible prepay-condition, which applies only // for the very first step + if (DBG_LEVEL >= DBG_DEBUG) { + qCritical() << "(" << __func__ << ":" << __LINE__ << ") prepay start" << prepayStart.toString(Qt::ISODate); + qCritical() << "(" << __func__ << ":" << __LINE__ << ") prepay end" << prepayEnd.toString(Qt::ISODate); + } + if (prepayStart <= start && start <= prepayEnd) { it->second.pun_duration = prepayDurationInMinutes; it->second.pun_duration += it->second.pun_duration_saved ; @@ -2884,15 +2891,7 @@ QList &Calculator::GetTimeSteps(Configuration *cfg, int paymentOptionIndex, if (!casePrepay) { // handle possible carryover-condition - int durationInSecs = it->second.pun_duration_saved * 60; - - if (DBG_LEVEL >= DBG_DEBUG) { - qCritical() << "(" << __func__ << ":" << __LINE__ << ")" << durationInSecs; - qCritical() << "(" << __func__ << ":" << __LINE__ << ") start" << start.toString(Qt::ISODate); - qCritical() << "(" << __func__ << ":" << __LINE__ << ") current" << current.toString(Qt::ISODate); - qCritical() << "(" << __func__ << ":" << __LINE__ << ") current next" << current.addSecs(durationInSecs).toString(Qt::ISODate); - } - + int const durationInSecs = it->second.pun_duration_saved * 60; it->second.pun_duration = it->second.pun_duration_saved; if (current >= carryOverStart) { it->second.pun_duration += current.secsTo(carryOverEnd) / 60; @@ -2994,6 +2993,7 @@ QList &Calculator::GetTimeSteps(Configuration *cfg, int paymentOptionIndex, } else { // if (it->second.pun_netto) { qCritical() << "(" << __func__ << ":" << __LINE__ << ") TODO"; + qCritical() << "(" << __func__ << ":" << __LINE__ << ")\n" << it->second; } } else { // mutable == false if (it->second.pun_brutto) { // no handling for prepay and carry-over @@ -3010,6 +3010,7 @@ QList &Calculator::GetTimeSteps(Configuration *cfg, int paymentOptionIndex, } else { qCritical() << "(" << __func__ << ":" << __LINE__ << ") TODO"; + qCritical() << "(" << __func__ << ":" << __LINE__ << ")\n" << it->second; } } } @@ -3064,7 +3065,7 @@ uint32_t Calculator::GetPriceForTimeStep(Configuration *cfg, int timeStep, int p uint32_t price = 0; int pun_duration = 0; - qCritical() << "(" << __func__ << ":" << __LINE__ << ") paymentOptionIndex" << paymentOptionIndex; + //qCritical() << "(" << __func__ << ":" << __LINE__ << ") paymentOptionIndex" << paymentOptionIndex; //qCritical() << "(" << __func__ << ":" << __LINE__ << ") timeStep" << timeStep; //qCritical() << "(" << __func__ << ":" << __LINE__ << ") pop_id" << pop_id; From 648799629a80346b9502d1031dd0542963a7c44f Mon Sep 17 00:00:00 2001 From: Gerhard Hoffmann Date: Mon, 19 Aug 2024 12:19:01 +0200 Subject: [PATCH 8/8] GetTimeSteps(): Fix: check not only if "current" is above carryOverStart, but also if "current" is below carryOverEnd. --- library/src/calculator_functions.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/library/src/calculator_functions.cpp b/library/src/calculator_functions.cpp index e8518e5..e01a68c 100644 --- a/library/src/calculator_functions.cpp +++ b/library/src/calculator_functions.cpp @@ -2893,12 +2893,13 @@ QList &Calculator::GetTimeSteps(Configuration *cfg, int paymentOptionIndex, int const durationInSecs = it->second.pun_duration_saved * 60; it->second.pun_duration = it->second.pun_duration_saved; - if (current >= carryOverStart) { + + if (current >= carryOverStart && current < carryOverEnd) { it->second.pun_duration += current.secsTo(carryOverEnd) / 60; } else { // start < carryOverStart QDateTime const &newCurrent = current.addSecs(durationInSecs); - if (newCurrent > carryOverStart) { + if (newCurrent > carryOverStart && newCurrent <= carryOverEnd) { // cross carry over section it->second.pun_next_step_correction = carryOverStart.secsTo(carryOverEnd) / 60; it->second.pun_duration += it->second.pun_next_step_correction;