NEWS
E3DC Hauskraftwerk steuern
-
@arnod
Ich habe mich nun auch an Charge-Control 1.0.24 gewagtim Script wird folgender Fehler generiert
2022-09-28 14:58:36.005 - info: javascript.0 (549542) script.js.common.E3DC.Charge-Control: ****************************** Es wird Solcast Dach 2 abgerufen ******************************
2022-09-28 14:58:36.157 - info: javascript.0 (549542) script.js.common.E3DC.Modbus: EMS-Status Dez =132/ BIN =0000000010000100
2022-09-28 14:58:36.885 - warn: javascript.0 (549542) script.js.common.E3DC.Charge-Control: Error in der function InterrogateSolcast. Fehler = Error, status code = 404
2022-09-28 14:58:36.886 - info: javascript.0 (549542) script.js.common.E3DC.Charge-Control: ****************************** Es wird Solcast Dach 1 abgerufen ******************************
2022-09-28 14:58:37.563 - warn: javascript.0 (549542) script.js.common.E3DC.Charge-Control: Error in der function InterrogateSolcast. Fehler = Error, status code = 404
2Es werden keine Daten bei Solcast abgerufen.
was ist hier falsch ? -
@freudi
Hast du deinen Solcast API Key und die Dach ID Dachfläche1 und eventuell 2 richtig eingetragen?
Error 404 bedeutet, dass die Seite nicht gefunden wurde und diese baut sich aus diesen drei Parameter zusammen. -
@funzel sagte in E3DC Hauskraftwerk steuern:
Ich bin auf der Suche nach dem Direktverbrauch der S10.
Meinst du mit Direktverbrauch deinen Eigenverbrauch?
Da verwende ich den Stromzähler vom EVU. -
@jans_ios sagte in E3DC Hauskraftwerk steuern:
Grundsätzlich wäre es ganz cool, wenn das Skript in einem Datenpunkt die "für anderes" verwendbare Energie in Watt angeben würde. Da könnte man dann bspw. ein Skript für eine Wärmepumpe anhängen oder aber auch wie in meinem Fall den Heizstab. Das müsste doch recht einfach realisierbar sein, oder?
Das ist dann die Einspeiseleistung, das ist der Rest, was aktuell nicht benötigt wird.
-
@arnod
Das ist richtig - wenn ich die jedoch "aufsauge" und in Heizstab, Wärmepumpe o.ä. schicke, so dass die Einspeisung so gering wie möglich ist, bricht Charge-Control ab, weil zu wenig Strom zum Verwalten da ist. Daher dachte ich, Charge-Control könnte bspw. einen Strom per ioBroker-Objekt "zur Verfügung stellen", in einen weiteren Datenpunkt sollten dann die Abnehmer genau diesen Teils des Stroms reinschreiben, was sie nutzen. Daraus könnte Charge-Control dann errechnen, was wirklich verfügbar ist etc.Quasi eine kleine Schnittstelle, über die sonst eingespeister Strom kontrolliert zur Verfügung gestellt wird.
Ich hoffe, ich konnte es einigermaßen erklären.
-
@ArnoD
So, hier nochmal zur Bestätigung: Klappt seitdem top! -
Ich habe noch ein anderes "Problem": Der Energieverbrauch des Wallbox-Skripts wird lt. Log um 23:58 Uhr erfolgreich gespeichert:
2022-09-22 23:58:00.017 - [32minfo[39m: javascript.0 (475) script.js.Eigene_Skripte.Energie.E3DC_Wallbox: Tagesertragswert gespeichert
An dem Tag habe ich ca. 12kWh in meinen Hybrid geladen. Ich würde jetzt erwarten, dass im Objekt
0_userdata.0.E3DC_Wallbox.Stromverbrauch.Verbrauch_E-Auto_kWh_Tag22
genau diese ca. 12kWh auftauchen, dort steht aber eine glatte 0, zuletzt geändert am 13.09., allerdings mit Zeitstempel passend zum obigen Log 22.09. 28:58 Uhr:
Auch das Objekt "History.JSON" scheint nicht befüllt zu werden, hier ist sogar der Zeitstempel der 13.09.:
Am 13.09. habe ich das Skript übrigens in Betrieb genommen, da wurden dann die Objekte erstellt, daher dieses Datum.
Im View ist dadurch logischerweise auch alles leer:
Was läuft hier wo falsch?Danke!
Einen Download-Link zum kompletten Log des 22.09. schicke ich Dir per Chat, @ArnoD
-
@arnod
ja, beide Flächen und den APIkey aus Solcast kopiert.Ich habe einen Blackout.
-
@freudi
Da ich das hinbekommen habe, hier Hinweise, wo genau was zu finden ist. Auf der Solcast Website findest Du in Deinem Account (Manage Account) das Feld API Key, in dem Du Dir nach Klick auf "Show API Key" Deinen API-Key anzeigen lassen oder durch "Copy Key" in die Zwischenablage übernehmen kannst.
Im Bereich "Live and Forecast" findest Du die IDs Deiner beiden Dachflächen:
Und damit sollte es dann klappen. -
Super Danke. Ich habe "https://api.solcast.com.au/rooftop_sites......" kopiert.
-
@jans_ios sagte in E3DC Hauskraftwerk steuern:
Das ist richtig - wenn ich die jedoch "aufsauge" und in Heizstab, Wärmepumpe o.ä. schicke, so dass die Einspeisung so gering wie möglich ist, bricht Charge-Control ab, weil zu wenig Strom zum Verwalten da ist. Daher dachte ich, Charge-Control könnte bspw. einen Strom per ioBroker-Objekt "zur Verfügung stellen", in einen weiteren Datenpunkt sollten dann die Abnehmer genau diesen Teils des Stroms reinschreiben, was sie nutzen. Daraus könnte Charge-Control dann errechnen, was wirklich verfügbar ist etc.
Das ist dann aber das gleiche wie, wenn gleich die Einspeiseleistung verwendet wird.
Das Script Charge-Control regelt die Batterieladung natürlich nur so lange, wie auch was zum Regeln da ist.
Wenn jetzt mit 1000W in das Netz eingespeist wird, kann jeder Verbraucher 900W verwenden, ohne dass es Charge-Control beeinflusst. Wenn allerdings mehr verbraucht wird, dann wird Charge-Control nicht mehr regeln, weil ja nicht ausreichend Leistung vorhanden ist. Daran ändert aber ein eigenes Objekt auch nichts, sondern nur eine intelligente Steuerung (Script) was dafür sorg das eben nur 900W verbraucht werden oder wenn das nicht ausreicht, der Verbraucher nicht eingeschalten wird. -
@jans_ios sagte in E3DC Hauskraftwerk steuern:
An dem Tag habe ich ca. 12kWh in meinen Hybrid geladen. Ich würde jetzt erwarten, dass im Objekt
0_userdata.0.E3DC_Wallbox.Stromverbrauch.Verbrauch_E-Auto_kWh_Tag22
genau diese ca. 12kWh auftauchen, dort steht aber eine glatte 0, zuletzt geändert am 13.09., allerdings mit Zeitstempel passend zum obigen Log 22.09. 28:58Das Script verwendet den Zähler
modbus.1.inputRegisters.128_total_kwh
und speichert den Wert in0_userdata.0.E3DC_Wallbox.Stromverbrauch.ZaehlerstandTagAlt
.
Jeden Tag vergleicht es den aktuellen Zählerstand mit dem alten gespeicherten Zählerstand und speichert die Differenz in0_userdata.0.E3DC_Wallbox.Stromverbrauch.Verbrauch_E-Auto_kWh_Tagxx
.
Wenn bei dir immer 0 eingetragen wird, dann prüfe mal, ob über Modbus der Zählerstand richtig übertragen wird. -
@arnod
Tatsächlich steht hier eine aktuell eine 0, obwohl heute schon ca. 5kWh in mein Auto geladen wurden - woran kann das liegen? Der Ladevorgang läuft aktuell noch.
-
@jans_ios
kann sein das deine Wallbox keinen Zähler hat, was ich nicht glaube oder aber das Modbus Register bei dir ein anderes ist. -
@jans_ios
Schau mal was bei dir verbaut ist, sollte so aussehen:
-
@jans_ios
Was steht bei dir inmodbus.1.holdingRegisters.904_Energiezähler_Total
drin ? Zählt der bei dir richtig ?
Dann könnte ich das im Script umstellen. -
-
@arnod
Beim Wallbox-Skript habe ich einen Fehler entdeckt. Wenn das Hauskraftwerk sein Ladeziel erreicht hat und die Ladeleistung auf 0 geht, wird im Lademodus 1 nicht die Wallbox mit Strom versorgt, sondern eingespeist. Dies kommt aus folgendem Skript-Teil zustande, da die 0 irgendwie nicht als Option angenommen wird:// Prüfen ob Werte Netz oder Batterie negativ sind if (NetzLeistung_W <= -500 && BatterieLeistung_W < 0){ AutoLadeleistung_W = (PV_Leistung_W-Hausverbrauch_W+BatterieLeistung_W-NetzLeistung_W)-2070; }else if (NetzLeistung_W > -500 && BatterieLeistung_W < 0) { AutoLadeleistung_W = (PV_Leistung_W-Hausverbrauch_W+BatterieLeistung_W)-2070; // 2070 W Trägheitsreserve bei Netzbezug }else if (NetzLeistung_W > -500 && BatterieLeistung_W > 0) { AutoLadeleistung_W = (PV_Leistung_W-Hausverbrauch_W-BatterieLeistung_W); // 2070 W Trägheitsreserve bei Netzbezug }else if (NetzLeistung_W <= -500 && BatterieLeistung_W > 0){ AutoLadeleistung_W = (PV_Leistung_W-Hausverbrauch_W-BatterieLeistung_W-NetzLeistung_W); }
Ergänze ich in der ersten Prüfzeile ein = startet der Ladevorgang - ich weiß nur nicht so recht, ob das logisch richtig ist:
if (NetzLeistung_W <= -500 && BatterieLeistung_W <= 0){
Was meinst Du dazu? Ist das = hier richtig?
-
@arnod sorry war off
ja, das würde überall passen, außer bei Limit ist Vorzeichen anders
@arnod sagte in E3DC Hauskraftwerk steuern:
@Chilihead
Aktuell könnte ich
e3dc-rscp.0.EMS.SYS_SPECS.maxDischargePower
4500W
e3dc-rscp.0.EMS.USED_DISCHARGE_LIMIT
-4500W
e3dc-rscp.0.EMS.SYS_SPECS.maxStartDischargePower
4500W
verwenden.Dem Namen nach würde
e3dc-rscp.0.EMS.SYS_SPECS.maxStartDischargePower
am besten passen.
Wie sieht es da bei dir aus, würde da die max. Batterie Entladeleistung passen? -
@jans_ios sagte in E3DC Hauskraftwerk steuern:
Dieses Holdingregister wird bei mir gar nicht abgefragt. Ich habe Deine Datei von Github importiert, da ist es nicht enthalten. Ist die Datei nicht komplett?
Ja, stimmt. Hatte das bei mir getestet und bei mir wurde hier nichts Sinnvolles übertragen.
Kannst es ja mal bei dir versuchen, ob es da anders aussieht.
Bei Holding-Register neue Adresse 904 Typ: Unsigned 32 bit (Big Endian) Faktor= 0.001