NEWS
ecoflow-connector-Script zur dynamischen Leistungsanpassung
-
@waly_de weißt Du schon wann Du den Schalter einbauen kannst, um den AC Ladeeingang (Shelly), wenn die DP voll ist? Schön wäre ein Zusatz in der Sektion "Überschussladung" wo man sagen kann Stelle den angegebenen shelly wieder ab, wenn DP voll.
-
Guten Morgen,
ich habe heute die neue 2 kWh Batterie in Betrieb genommen. Eco Flow hat meinen PowerStream auf die Version 1.0.1.195 geupdatet (durch den Service), da ansonsten der PowerStream die Batterie nicht erkannt hat.
Das Skript läuft grundsätzlich bei mir (ohne erkennbare Fehler oder Abbrüche).
Der Timber Pulse (Lokale Auslosung, nicht über die Cloud), liefert auch zuverlässig die Daten.Leider erfolgen keine Änderungen durch das Skript (Anpassung an den aktuellen Stromverbrauch). Die Batterie wird unter Objekte in IoBroker auch nicht mit Werten gefüllt (habe alle möglichen Batterietypen ausgetestet).
Ich glaube tatsächlich das Skript müsste angepasst werden. Oder hat jemand das ganze schon zum laufen bekommen?
Wie kann ich helfen? Was für Logdateien etc. werden benötigt?
Ergänzung:
Ich habe jetzt doch einen Fehler im Skript bei mir gefunden:
javascript.0 2024-04-06 12:01:01.909 info script.js.common.Ecoflow: Fehler beim Abrufen des niedrigsten Werts: timeout javascript.0 2024-04-06 12:01:01.908 info script.js.common.Ecoflow: getLowestValue-error: timeout javascript.0 2024-04-06 12:00:46.909 info script.js.common.Ecoflow: Fehler beim Abrufen des niedrigsten Werts: timeout javascript.0 2024-04-06 12:00:46.908 info script.js.common.Ecoflow: getLowestValue-error: timeout
Stand 12:40 Uhr:
Es war der History Adapter, der gefehlt hatte.. Habs in den anderen Beiträgen gefunden. Das Skript läuft jetzt! Die Batterie wird dennoch nicht erkannt (Wert Null für Batteriezustand)
Ich habe das Ganze jetzt erstmal so gelöst, dass bei dieser Zeile folgende Werte reinkommen (weil Batteriestand ja unbekannt):
lowBatLimitPozOn: 0, lowBatLimitPozOff: -1, // Bei Unterschreiten der Batterieladung von "lowBatLimitPozOn" % ist die maximale Einspeiseleistung auf
-
- Frage: Besteht die Möglichkeit einen gewissen Verbraucher (z.B. aus einer Zigbee Steckdose mit Verbrauchsanzeige) explizit nicht aus dem Speicher mit Strom zu versorgen?
Also quasi aktueller Stromverbrauch lt. Timber Pulse ./. der Steckdose?
Das ist eine interessante Frage. Tatsächlich müsste das sogar funktionieren, wenn du die Steckdose unter AdditionalPower anlegst. Dann musst du noch den parameter NoPV auf True setzen und den Faktor auf -1. Dadurch würde dann die Leistung der Steckdose von RealPower abgezogen und vom Skript nicht aus reguliert.
Ich habe das heute Abend mal probiert. Also in AdditionalPowerSum gibt einen negativen Verbrauchswert raus. Dennoch wird dieser ignoriert. In der Ecoflow App werden trotzdem 600 Watt angefordert.
RealPower und lowestValue steigen kurz auf einen hohen Wert, geben dann aber den ungefähren eigentlichen Verbrauch aus. Eine Änderung in der Grundlast tritt dabei dann aber nicht auf. Diese bleibt bei 600 Watt.
Hast du vielleicht noch eine Idee, woran das liegen könnte?
- Frage: Besteht die Möglichkeit einen gewissen Verbraucher (z.B. aus einer Zigbee Steckdose mit Verbrauchsanzeige) explizit nicht aus dem Speicher mit Strom zu versorgen?
-
-
@mario1995 sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
- Frage: Besteht die Möglichkeit einen gewissen Verbraucher (z.B. aus einer Zigbee Steckdose mit Verbrauchsanzeige) explizit nicht aus dem Speicher mit Strom zu versorgen?
Also quasi aktueller Stromverbrauch lt. Timber Pulse ./. der Steckdose?
Das ist eine interessante Frage. Tatsächlich müsste das sogar funktionieren, wenn du die Steckdose unter AdditionalPower anlegst. Dann musst du noch den parameter NoPV auf True setzen und den Faktor auf -1. Dadurch würde dann die Leistung der Steckdose von RealPower abgezogen und vom Skript nicht aus reguliert.
Ich habe das heute Abend mal probiert. Also in AdditionalPowerSum gibt einen negativen Verbrauchswert raus. Dennoch wird dieser ignoriert. In der Ecoflow App werden trotzdem 600 Watt angefordert.
RealPower und lowestValue steigen kurz auf einen hohen Wert, geben dann aber den ungefähren eigentlichen Verbrauch aus. Eine Änderung in der Grundlast tritt dabei dann aber nicht auf. Diese bleibt bei 600 Watt.
Hast du vielleicht noch eine Idee, woran das liegen könnte?
Ich hab das Problem lösen können.. Ich habe über Blockly ein Skript geschrieben. Aktueller Stromverbrauch laut Tibber ./. dieser einen Fritz!Box Steckdose = Wert über Stromverbrauch für das Ecoflow Skript. Das hat geklappt.
Tut mir leid falls das zu viele Fragen hier im Forum waren. Musste mich erstmal belesen. Habe iOBroker eigentlich nur für dieses Ecoflow Skript
- Frage: Besteht die Möglichkeit einen gewissen Verbraucher (z.B. aus einer Zigbee Steckdose mit Verbrauchsanzeige) explizit nicht aus dem Speicher mit Strom zu versorgen?
-
@waly_de nächste Frage: Unterstützung von zwei Shelly 3EM oder Regelung mit Nutzung von Smartplugs. Anwendungsfall: ich habe ein Haus mit zwei Sicherungskasten und habe den Shelly 3EM bisher nur an einem. Nun würde ich natürlich gerne den restlichen Teil des Hauses auch mit regeln lassen, was ich entweder über "übrige" Smartplugs lösen könnte oder über einen zweiten Shelly 3EM im zweiten Sicherungskasten (oder natürlich über einen IR Sensor im Zählerschrank, was aber einen Elektriker braucht wg. Steckdose). Soweit ich das Skript verstehe, funktioniert das (noch) nicht, müsste aber (vermutlich) relativ einfach sein, einzubauen. Wäre also ein Featurewunsch von mir bzw. die Frage, ob Du mir Hinweise geben könntest, wo ich es einbauen muss, dann würde ich das mal versuchen.
Erster Versuch: alle 4 Plugs, die nicht im Shelly 3EM inbegriffen sind, abonnieren (und einmal Verbraucher einschalten), dann bei
//Gesamtbedarf ist: let NewValue = lowestValue - ConfigData.BasePowerOffset NewValue = NewValue + getPlugsWatt() // Verbrauch der Plugs hinzufügen
wobei
function getPlugsWatt() { let sum = 0 sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 sum = sum + Number(getState("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXXXXXXX.data.plug_heartbeat_pack.watts").val)/10 return sum }
Scheint zu funktionieren, ich sehe beim Shelly negative Werte, wenn Strom über die Plugs läuft und am Stromzähler entsprechend weniger positive ...
Vielleicht kann das Skript das aber auch schon und ich weiß nur noch nicht wie?
-
Ich hätte auch noch einen Wunsch:
RegulationMultiPsMode: 2 = invers
Ziel soll sein die Last in umgekehrter Reihenfolge auf die Powerstreams zu verteilen als sonst bei seriell. -
@mario1995 das hast du gut gelöst!
Was hast du denn für eine Batterie angeschlossen?
Wird denn in der App, wenn du den Power Stream anklickst die angeschlossene Batterie und der aktuelle Batteriestand richtig angezeigt?
Für mich klingt das eher nach einem Softwareproblem zwischen den Ecoflow.
Vielleicht hast du auch das Batterie Kabel vom Power Stream zur Delta in den falschen Port bei der Delta gesteckt? Das Kabel muss auf jeden Fall mit Port eins verbunden sein. -
@gooflo sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Scheint zu funktionieren, ich sehe beim Shelly negative Werte, wenn Strom über die Plugs läuft und am Stromzähler entsprechend weniger positive ...
Vielleicht kann das Skript das aber auch schon und ich weiß nur noch nicht wie?Nein, das ist im Skript nicht so vorgesehen. Ich würde das wie folgt lösen: lege ein eigenes Objekt manuell an, in das du deinen Zählerstand zuzüglich der Summen deiner Plugs schreibst. Das geht prima mit einem Blocky oder aber mit einem kleinen Extra Skript.
Dieses neu angelegte Objekt gibst du dann im Skript als Smartmeter ID an. -
@thomas-weller sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Von mir einfach nochmal ein Riesen Dankeschön!!!
Hier mein März mit dem genialen Skript:Das sieht Großartig aus... freut mich
-
@waly_de sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
@mario1995 das hast du gut gelöst!
Was hast du denn für eine Batterie angeschlossen?
Wird denn in der App, wenn du den Power Stream anklickst die angeschlossene Batterie und der aktuelle Batteriestand richtig angezeigt?
Für mich klingt das eher nach einem Softwareproblem zwischen den Ecoflow.
Vielleicht hast du auch das Batterie Kabel vom Power Stream zur Delta in den falschen Port bei der Delta gesteckt? Das Kabel muss auf jeden Fall mit Port eins verbunden sein.Das ist die neue 2kwh Batterie (Wasserfest). Einen einprägsamen Namen hat diese bisher nicht.
Durch ein Update des Powerstreams auf die Version 1.0.1.195 durch den Support wird die Batterie mit Temperatur und Prozentzahl angezeigt.
Home-Assistant kann die Daten der Batterie auch auslesen (Ecoflow Integration).
Welche Werte werden denn zur Verwendung des Skripts benötigt? z.B. Wenn ich die Delta 2 (D2) im Skript einstelle?
Das wären doch diese Angaben, oder?
{ id: 0, name: 'acChgCfg_D2', ValueName: 'chgWatts', Typ: 'D2', MT: 5, AddParam: '{"chgWatts":600,"chgPauseFlag":255}' }, { id: 0, name: 'acOutCfg_D2', ValueName: 'enabled', Typ: 'D2', MT: 3 }, { id: 0, name: 'dcOutCfg_D2', ValueName: 'enabled', Typ: 'D2', MT: 1 }, { id: 0, name: 'quietMode_D2', ValueName: 'enabled', Typ: 'D2', MT: 5 }, { id: 0, name: 'dcChgCfg_D2', ValueName: 'dcChgCfg', Typ: 'D2', MT: 5 },
Wäre es möglich, dass diese Daten der Batterie allesamt vom Powerstream kommen?
Für mich wäre das eine Erklärung dafür, warum Home Assistant die Funktion schon hat...
Weil ich glaube tatsächlich, dass dieser Akku sich nicht getrennt per Wlan oder Bluetooth anmeldet sondern die Daten über den Powerstream einreicht...
Nachtrag:
Unter dem Powerstream werden die Daten dieser neuen Batterie abgelegt.
Zu finden sind diese unter: Objekte - app_device_property_SeriennummerderPowerstation- Data - InverterHeartbeat. Dort sind folgende Informationen zur Batterie angegeben:
0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputVolt
0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputWatts
0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batSoc
0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batTemp -
@mario1995 sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Zu finden sind diese unter: Objekte - app_device_property_SeriennummerderPowerstation- Data - InverterHeartbeat. Dort sind folgende Informationen zur Batterie angegeben:
0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputVolt
0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batInputWatts
0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batSoc
0_userdata.0.ecoflow.app_device_property_XXXXXXX.data.InverterHeartbeat.batTempAlso wenn da die richtigen aktuellen Daten eingetragen sind, dann hat das Skript auch den Batteriestand zur Verfügung genau wie bei den anderen Deltas.
Es müsste also ganz normal funktionieren. Bitte beachte aber, dass die Batteriestanddaten nicht sofort übertragen werden, sondern in der Regel nur dann, wenn sich der Wert ändert. Daher musst du nach dem Starten des Skripts vielleicht ein wenig Geduld haben oder mal einen größeren Verbrauch eine Zeit lang einschalten, um zu sehen, was passiert, wenn sich der Batteriestand ändert. -
Hi zusammen
Heute habe ich 2 zusätzliche Panel an den Delta max angeschlossen.
Dies wird ja dann beim "Aditional Power" eingetragen. Hierfür brauche ich den WattsIn Wert des Delta also muss ich subscribe des Delta auf true setzen. Das klappt alles soweit, nun habe ich aber zu viele Abfragen und das Skript wird beendet!? Sobald ich subscribe auf false setze, ist der Fehler weg..
Grüsse aus der Schweiz
Rafal8.4.2024, 14:59:59.789 [info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:00:01.161 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 8.4.2024, 15:00:01.583 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker 8.4.2024, 15:02:01.370 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:02:01.377 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet 8.4.2024, 15:02:01.452 [info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:02:01.513 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 8.4.2024, 15:02:01.734 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker 8.4.2024, 15:02:14.799 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:02:14.801 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet 8.4.2024, 15:02:14.878 [info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:02:14.924 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 8.4.2024, 15:02:15.111 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker 8.4.2024, 15:04:19.766 [error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script! 8.4.2024, 15:04:19.769 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:04:19.772 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet 8.4.2024, 15:06:09.014 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:06:09.098 [info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:06:09.161 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 8.4.2024, 15:06:09.440 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker 8.4.2024, 15:06:24.159 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Fehler beim Abrufen des niedrigsten Werts: Error: No data 8.4.2024, 15:08:19.767 [error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script! 8.4.2024, 15:08:19.770 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:08:19.773 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
-
@audiofreak sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
Hi zusammen
Heute habe ich 2 zusätzliche Panel an den Delta max angeschlossen.
Dies wird ja dann beim "Aditional Power" eingetragen. Hierfür brauche ich den WattsIn Wert des Delta also muss ich subscribe des Delta auf true setzen. Das klappt alles soweit, nun habe ich aber zu viele Abfragen und das Skript wird beendet!? Sobald ich subscribe auf false setze, ist der Fehler weg..
Grüsse aus der Schweiz
Rafal8.4.2024, 14:59:59.789 [info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:00:01.161 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 8.4.2024, 15:00:01.583 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker 8.4.2024, 15:02:01.370 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:02:01.377 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet 8.4.2024, 15:02:01.452 [info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:02:01.513 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 8.4.2024, 15:02:01.734 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker 8.4.2024, 15:02:14.799 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:02:14.801 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet 8.4.2024, 15:02:14.878 [info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:02:14.924 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 8.4.2024, 15:02:15.111 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker 8.4.2024, 15:04:19.766 [error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script! 8.4.2024, 15:04:19.769 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:04:19.772 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet 8.4.2024, 15:06:09.014 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:06:09.098 [info ]: javascript.0 (45446) Start javascript script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:06:09.161 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 8.4.2024, 15:06:09.440 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Verbunden mit dem Ecoflow MQTT-Broker 8.4.2024, 15:06:24.159 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Fehler beim Abrufen des niedrigsten Werts: Error: No data 8.4.2024, 15:08:19.767 [error]: javascript.0 (45446) Script script.js.Leistungsanpassung.Leistungsanpassung_V2 is calling setState more than 1000 times per minute! Stopping Script now! Please check your script! 8.4.2024, 15:08:19.770 [info ]: javascript.0 (45446) Stop script script.js.Leistungsanpassung.Leistungsanpassung_V2 8.4.2024, 15:08:19.773 [info ]: javascript.0 (45446) script.js.Leistungsanpassung.Leistungsanpassung_V2: Ecoflow MQTT-Client beendet
siehe den Eingangsbeitrag dieses Threads... da ist beschrieben was zu tun ist.
-
@waly_de said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:
siehe den Eingangsbeitrag dieses Threads... da ist beschrieben was zu tun ist.
Hi Markus
Sorry, hätte ich drauf kommen können im ersten Post nachzuschauen.. Habs jetzt auf 3000 erhöht
-
@waly_de danke für den Tip. Falls jemand auch diesen Anwendungsfall hat, hier meine aktuelle Lösung mit einem zweiten Skript, wobei ich im Originalskript in der Konfiguration das hier setze:
SmartmeterID: "0_userdata.0.ecoflow.TotalActivePowerPlusPlugs", // State, der den aktuellen Gesamtverbrauch in Watt anzeigt
und hier das neue Skript:
// globale Konfiguration var ConfigData = { statesPrefix: "0_userdata.0.ecoflow", // übernommen TotalActivePower : ".TotalActivePower", // Shelly total active power TotalActivePowerPlusPlugs : ".TotalActivePowerPlusPlugs", // Neuer State für Power mit Plugs in den Userdaten SmartmeterID: "shelly.0.shellypro3em#XXXXXXXXXXX.EM0.TotalActivePower", // übernommen State, der den aktuellen Gesamtverbrauch in Watt anzeigt } // state TotalActivePowerPlusPlugs anlegen if ( !existsState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs)) { createState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs,0,{name: "TotalActivePowerPlusPlugs", type: 'number', role: 'value'}, function () {}); } else { setState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs,0); } // state TotalActivePower anlegen if ( !existsState(ConfigData.statesPrefix + ConfigData.TotalActivePower)) { createState(ConfigData.statesPrefix + ConfigData.TotalActivePower,0,{name: "TotalActivePower", type: 'number', role: 'value'}, function () {}); } else { setState(ConfigData.statesPrefix + ConfigData.TotalActivePower,0); } /** * @param {string} id */ function getPlugWatts(id) { let watts = 0 let age_min = (Date.now() - getState(id).ts) / (1000 * 60) let w = Number(getState(id).val)/10 // sanity check: nur wenn die Daten Daten jünger als 4 min sind oder nicht so hoch werden sie verwendet if (age_min < 4 || w < 50) { watts += w } // log(id + " " + watts + " W, age (min) = " + age_min) return watts } // wenn der Smartmeter gesetzt wird, die Plugs Watt ermitteln und die states setzen on({id: ConfigData.SmartmeterID}, function (obj) { let smartMeterTotal = Math.floor(Number(getState(ConfigData.SmartmeterID).val)) setState(ConfigData.statesPrefix + ConfigData.TotalActivePower, smartMeterTotal) // store initial TotalActivePower let plugsSum = 0 plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_1.data.plug_heartbeat_pack.watts") plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_2.data.plug_heartbeat_pack.watts") plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_3data.plug_heartbeat_pack.watts") plugsSum += getPlugWatts("0_userdata.0.ecoflow.app_device_property_XXXXXXXXXXX_4.data.plug_heartbeat_pack.watts") // log("Plugs Watts = " + plugsSum) setState(ConfigData.statesPrefix + ConfigData.TotalActivePowerPlusPlugs, Math.floor(smartMeterTotal + plugsSum)) });
Natürlich müssen für Shelly und Plugs die entsprechenden IDs gesetzt werden.
-
Hi,
seit knapp einer Woche steuert das script meine Einspeiseleistung nicht mehr bzw stellt sie auf 0. Der Verbrauch wird regelmäßig aktualisiert und auch das 2 Minuten-Minimum aktualisiert sich entsprechend, nur wird "setac" immer auf 0 gesetzt. Wenn ich den Wert unter Objekte anpasse speist der Powerstream dann auch ein und nach kurzer Zeit wird der Wert wieder mit 0 überschrieben. Hatte jemand schonmal das selbe Problem oder hat eine Idee was ich ändern kann? Der Ladestand der Delta 2 war eigentlich so ziemlich schon so ziemlich jeder Wert zwischen 5 und 100%.
Danke schonmal -
@tom-goos hast du zufällig in der App für Backup Reserve aktiviert? Das hatte ich auch schon
-
@Waly_de Lieben dank für das Script. Dank dem Tibber script zum lokalen auslesen und dem ecoflow-connector-Script braucht mein neue Powerstream keine smartplugs. Es funktioniert alles, obwohl ich neu in iobroker bin, doch eine Sache konnte ich noch nicht finden:
Wie bekomme ich die korrekte Nach-Kommastelle hin z.b für invOutputWatts ?
-
@Waly_de ich hatte heute wieder das Szenario, dass mein PS mit 560W eingespeist hat, während die das Skript den Ladeeingang der DP angeschalten hat und diese mit 300W geladen hat. kann man das nicht irgendwie umgehen, dass der AC Ladeeingang der DP nicht eingeschaltet wird, wenn der PS einspeist. Sonst gehts ja vorne raus und hinten wieder rein.