Skip to content

Commit

Permalink
Fix: VE.Direct refactor issues from #505 (#516)
Browse files Browse the repository at this point in the history
* VE.Direct: return non-nullptr as a fallback

the changed return statement was supposed to return a shared_ptr to a
new and valid MPPT data struct as a fallback. however, it did return a
new shared_ptr that was initialized to nullptr.

* VE.Direct: make liveview total use total MPPT values

this change makes the call to VictronMppt.getData() obsolete, which in
turn will therefore not cause an error message on the console if
VE.Direct (MPPT) is not enabled. this change also takes care that once
multiple VE.Direct MPPT charge controllers are supported, the sums of
the respective total values are used in the web app totals.
  • Loading branch information
schlimmchen authored Oct 23, 2023
1 parent 8ba9048 commit 0fa2745
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 5 deletions.
9 changes: 9 additions & 0 deletions include/VictronMppt.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,15 @@ class VictronMpptClass {
// total output of all MPPT charge controllers in Watts
int32_t getPowerOutputWatts() const;

// total panel input power of all MPPT charge controllers in Watts
int32_t getPanelPowerWatts() const;

// sum of total yield of all MPPT charge controllers in kWh
double getYieldTotal() const;

// sum of today's yield of all MPPT charge controllers in kWh
double getYieldDay() const;

private:
VictronMpptClass(VictronMpptClass const& other) = delete;
VictronMpptClass(VictronMpptClass&& other) = delete;
Expand Down
35 changes: 34 additions & 1 deletion src/VictronMppt.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ VeDirectMpptController::spData_t VictronMpptClass::getData(size_t idx) const
if (_controllers.empty() || idx >= _controllers.size()) {
MessageOutput.printf("ERROR: MPPT controller index %d is out of bounds (%d controllers)\r\n",
idx, _controllers.size());
return VeDirectMpptController::spData_t{};
return std::make_shared<VeDirectMpptController::veMpptStruct>();
}

return _controllers[idx]->getData();
Expand All @@ -94,3 +94,36 @@ int32_t VictronMpptClass::getPowerOutputWatts() const

return sum;
}

int32_t VictronMpptClass::getPanelPowerWatts() const
{
int32_t sum = 0;

for (const auto& upController : _controllers) {
sum += upController->getData()->PPV;
}

return sum;
}

double VictronMpptClass::getYieldTotal() const
{
double sum = 0;

for (const auto& upController : _controllers) {
sum += upController->getData()->H19;
}

return sum;
}

double VictronMpptClass::getYieldDay() const
{
double sum = 0;

for (const auto& upController : _controllers) {
sum += upController->getData()->H20;
}

return sum;
}
7 changes: 3 additions & 4 deletions src/WebApi_ws_live.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -192,10 +192,9 @@ void WebApiWsLiveClass::generateJsonResponse(JsonVariant& root)
vedirectObj[F("enabled")] = Configuration.get().Vedirect_Enabled;
JsonObject totalVeObj = vedirectObj.createNestedObject("total");

auto spMpptData = VictronMppt.getData();
addTotalField(totalVeObj, "Power", spMpptData->PPV, "W", 1);
addTotalField(totalVeObj, "YieldDay", spMpptData->H20 * 1000, "Wh", 0);
addTotalField(totalVeObj, "YieldTotal", spMpptData->H19, "kWh", 2);
addTotalField(totalVeObj, "Power", VictronMppt.getPanelPowerWatts(), "W", 1);
addTotalField(totalVeObj, "YieldDay", VictronMppt.getYieldDay() * 1000, "Wh", 0);
addTotalField(totalVeObj, "YieldTotal", VictronMppt.getYieldTotal(), "kWh", 2);

JsonObject huaweiObj = root.createNestedObject("huawei");
huaweiObj[F("enabled")] = Configuration.get().Huawei_Enabled;
Expand Down

0 comments on commit 0fa2745

Please sign in to comment.