diff --git a/apps/predbat/output.py b/apps/predbat/output.py index c6fcb49d..7f94c884 100644 --- a/apps/predbat/output.py +++ b/apps/predbat/output.py @@ -527,6 +527,8 @@ def get_html_plan_header(self, plan_debug): else: html += "
Plan starts: {} last updated: {} version: {} previous status: {} | ".format(self.now_utc.strftime("%Y-%m-%d %H:%M"), self.now_utc_real.strftime("%H:%M:%S"), THIS_VERSION, self.current_status) + html += "Plan starts: {} last updated: {} version: {} previous status: {} mode: {} | ".format(self.now_utc.strftime("%Y-%m-%d %H:%M"), self.now_utc_real.strftime("%H:%M:%S"), THIS_VERSION, self.current_status, mode) config_str = f"best_soc_min {self.best_soc_min} best_soc_max {self.best_soc_max} best_soc_keep {self.best_soc_keep} carbon_metric {self.carbon_metric} metric_self_sufficiency {self.metric_self_sufficiency} metric_battery_value_scaling {self.metric_battery_value_scaling}" html += "||||||||||||||||||
{} | ".format(config_str) @@ -647,16 +654,20 @@ def publish_html_plan(self, pv_forecast_minute_step, pv_forecast_minute_step10, load_forecast = 0 pv_forecast10 = 0 load_forecast10 = 0 + extra_forecast = 0 for offset in range(minute_relative_start, minute_relative_slot_end, PREDICT_STEP): pv_forecast += pv_forecast_minute_step.get(offset, 0.0) load_forecast += load_minutes_step.get(offset, 0.0) pv_forecast10 += pv_forecast_minute_step10.get(offset, 0.0) load_forecast10 += load_minutes_step10.get(offset, 0.0) + for step in range(PREDICT_STEP): + extra_forecast += self.get_from_incrementing(self.load_forecast, offset + self.minutes_now + step, backwards=False) pv_forecast = dp2(pv_forecast) load_forecast = dp2(load_forecast) pv_forecast10 = dp2(pv_forecast10) load_forecast10 = dp2(load_forecast10) + extra_forecast = dp2(extra_forecast) soc_percent = calc_percent_limit(self.predict_soc_best.get(minute_relative_start, 0.0), self.soc_max) soc_percent_end = calc_percent_limit(self.predict_soc_best.get(minute_relative_slot_end, 0.0), self.soc_max) @@ -685,6 +696,7 @@ def publish_html_plan(self, pv_forecast_minute_step, pv_forecast_minute_step10, pv_color = "#BCBCBC" load_color = "#FFFFFF" + extra_color = "#FFFFFF" rate_color_import = "#FFFFAA" rate_color_export = "#FFFFFF" soc_color = "#3AEE85" @@ -716,7 +728,16 @@ def publish_html_plan(self, pv_forecast_minute_step, pv_forecast_minute_step10, elif load_forecast > 0.0: load_color = "#AAFFAA" + if extra_forecast >= 0.5: + extra_color = "#F18261" + elif extra_forecast >= 0.25: + extra_color = "#FFFF00" + elif extra_forecast > 0.0: + extra_color = "#AAFFAA" + load_forecast = str(load_forecast) + extra_forecast = str(extra_forecast) + if plan_debug and load_forecast10 > 0.0: load_forecast += " (%s)" % (str(load_forecast10)) @@ -940,6 +961,8 @@ def publish_html_plan(self, pv_forecast_minute_step, pv_forecast_minute_step10, html += "" + show_limit + " | " html += "" + str(pv_forecast) + pv_symbol + " | " html += "" + str(load_forecast) + " | " + if plan_debug and self.load_forecast: + html += "" + str(extra_forecast) + " | " if self.num_cars > 0: # Don't display car charging data if there's no car html += "" + car_charging_str + " | " if self.iboost_enable: diff --git a/apps/predbat/predbat.py b/apps/predbat/predbat.py index 72273ee1..ade07fb2 100644 --- a/apps/predbat/predbat.py +++ b/apps/predbat/predbat.py @@ -38,7 +38,7 @@ import asyncio import json -THIS_VERSION = "v8.8.9" +THIS_VERSION = "v8.8.10" # fmt: off PREDBAT_FILES = ["predbat.py", "config.py", "prediction.py", "gecloud.py","utils.py", "inverter.py", "ha.py", "download.py", "unit_test.py", "web.py", "predheat.py", "futurerate.py", "octopus.py", "solcast.py","execute.py", "plan.py", "fetch.py", "output.py", "userinterface.py"]