Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. ArnoD

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    A
    • Profile
    • Following 0
    • Followers 11
    • Topics 2
    • Posts 1904
    • Best 180
    • Groups 3

    ArnoD

    @ArnoD

    Pro

    190
    Reputation
    306
    Profile views
    1904
    Posts
    11
    Followers
    0
    Following
    Joined Last Online

    ArnoD Follow
    Pro Starter Most Active

    Best posts made by ArnoD

    • E3DC Hauskraftwerk steuern

      Ich habe dieses Topic eröffnet, um gemeinsam an einer Überschusssteuerung des E3DC Hauskraftwerks in ioBroker zu arbeiten.
      Dankeschön an dieser Stelle an Eberhard und sein Programm E3DC-Control, ohne ihn wäre das alles nicht möglich gewesen.
      Großes Lob und Danke auch an Uli, der den Adapter e3dc-rscp programmiert hat, über den die Steuerung im ioBroker erst möglich wurde.

      Ziel der Steuerung ist:
      Mit der Steuerung soll erreicht werden, dass der Batteriespeicher möglichst schonend geladen wird, um die Lebensdauer zu erhöhen.

      • Speicher soll nie längere Zeit auf 100 % geladen werden oder auf 0 % entladen werden.
      • Möglichst gleichmäßige Ladeleistung beim Laden.
      • PV-Überschuss soll gespeichert werden, um nicht in die 70 % Abriegelung zu kommen.
      • Bei Überschreitung WR Begrenzung soll Überschuss in die Batterie gespeichert werden.

      ioBroker
      Es werden folgende Adapter benötigt:

      • Javascript (NPM-Module: axios, is-it-bst)
      • e3dc-rscp

      Für die View Beispiele in VIS werden noch folgende Adapter benötigt:

      • vis-hqwidgets
      • vis-materialdesign
      • vis-timeandweather

      Beispiel View zum Importieren und das Skript Charge-Control, sowie eine Anleitung findet ihr auf GitHub:
      https://github.com/ArnoD15/iobroker_E3DC

      Einstellbare Parameter:
      Unload: Wenn der SoC Wert der Batterie > Wert „Unload“ ist, wird der Batteriespeicher mit Beginn Solarproduktion bis Beginn Regelzeitraum, auf SOC Wert Parameter "Unload" entladen. Ist Unload < Ladeschwelle wird bis Ladeschwelle geladen und Unload ignoriert.

      Ladeschwelle: Mit Beginn Solarproduktion wird die Batterie mit der maximalen Ladeleistung bis zum Wert Ladeschwelle geladen. Erst wenn der Batterie SOC den Wert Ladeschwelle erreicht, wird mit dem geregelten Laden begonnen. Danach wird bis SOC Wert „Ladeende“ gleichmäßig geladen, mit Ausnahme, wenn die PV-Leistung das Einspeiselimit oder die WR-Maxleistung übersteigt, wird die Ladeleistung um den Wert erhöht, um das Einspeiselimit oder WR-Limit einhalten zu können. Bei unterschreiten von dem Wert Einspeiselimit oder WR-Limit, wird wieder mit neu berechneter Ladeleistung, gleichmäßig bis „Ladeende" geladen. Bei großem Überschuss kann die gleichmäßige Ladeleistung bis auf 0 abgesenkt werden. Parameter "Ladeschwelle" hat Vorrang vor "Unload", d.h. "Unload" wird ignoriert, falls "Ladeschwelle" größer sein sollte als „Unload“.

      Ladeende: SoC Wert Speicher, der zum Ende des Regelzeitraums erreicht werden soll.

      Ladeende2: SoC Wert Speicher, der zum Ende Sommer Ladeende erreicht werden sollten.

      Unterer Ladekorridor: Der „Untere Ladekorridor“ definiert nur den min. Wert, ab dem mit dem Laden der Batterie gestartet wird. Erst wenn die berechnetet Ladeleistung den Wert „unteren Ladekorridor“ übersteigt, wird mit dem Laden der Batterie gestartet.

      Offset Regelbeginn Zeit in hh:mm, die von der Astro Zeit "solarNoon" (höchster Sonnenstand) abgezogen wird.

      Offset Regelende Zeit in hh:mm, die zu der Astro Zeit "solarNoon" (höchster Sonnenstand) dazu addiert wird.

      Offset Ladeende Zeit in hh:mm, die von der Astro Zeit "sunset" (Sonnenuntergang) abgezogen wird.

      70c4baad-fc5b-45bb-8c02-45b0b14f89ea-grafik.png
      Eigenverbrauch: Der geschätzte Eigenverbrauch pro Tag in kWh. Wird für die Überschussberechnung der Prognose verwendet.

      Notstrom min.: Speicherreserve in % bei Wintersonnenwende 21.12

      Notstrom Sockel: min. SOC Wert bei Tag-/Nachtgleiche 21.3./21.9.

      Berechnung Notstrom: 21.12 (Wintersonnenwende) ist der Bezugs-SoC = Wert „Notstrom min“ und wird bis zum 21.3 (Tag-/Nachtgleiche) auf Wert „Notstrom Sockel“ reduziert und bis zum 20.06 (Sommersonnenwende) um ca. weitere 10% reduziert. Ab dem 20.06 (Sommersonnenwende) steigt der Bezugs-SoC wieder bis zum 21.09 (Tag-/Nachtgleiche) auf den Wert „Notstrom Sockel“ und bis zum 21.12 (Wintersonnenwende) auf den Wert „Notstrom min“. Je Monat ändert sich somit der SoC um ca. +- 3,3%. Mit Notstrom min. und Notstrom Sockel kann man eine Dynamische Notstromreserve vorhalten, Vorteil ist, dass der Speicher nicht alle 3 Wochen entladen wird wie bei der Notstromreserve von E3DC.

      Starten wir am 21.12 (Wintersonnenwende) der kürzeste Tag, da wird der Speicher bis auf Notstrom min = 20% entladen.
      Ab jetzt werden die Tage immer länger, bis zum 21.3 (Tag-/Nachtgleiche) wo die Tage und Nächte gleich lang sind.
      Das bedeutet deine Speicherreserve kann immer geringer werden je länger die Tage sind, da ja mehr PV-Leistung zur Verfügung steht. Es wird somit jeden Monat die Speichergrenze um ca.3,33% reduziert bis zum 21.03 auf den Wert Notstrom Sockel = 10%.

      Ab dem 21.03 werden die Tage immer länger bis zum 20.06 (Sommersonnenwende) dem längsten Tag im Jahr.
      Es wird also die Speichergrenze weiter jeden Monat um ca. 3,33% reduziert bis zum 20.06 auf 0%,
      Ab diesem Zeitpunkt werden die Tage wieder kürzer bis zum 21.9 (Tag-/Nachtgleiche) wo die Tage und Nächte wieder gleich lang sind und die Speicherreserve wird jeden Monat um ca. 3,33% erhöht auf Notstrom Sockel = 10%.
      Die Tage werden immer kürzer bis zum 21.12 (Wintersonnenwende) und die Speichergrenze wird weiter jeden Monat um ca. 3,33% erhöht auf den Wert Notstrom min = 20%

      Notstrom Sockel ist somit der min. SOC Wert, wenn die Tage und Nächte gleich lang sind, also am 21.3 und 21.09 und
      Notstrom min wenn die Tage am kürzesten sind am 21.12 .

      Laderegelung:
      Mit Beginn Solarproduktion wird die Batterie mit der maximalen Ladeleistung bis zum Wert Ladeschwelle geladen oder bis zum SOC Wert Unload entladen. Erst wenn der Batterie SOC den Wert Ladeschwelle erreicht, wird mit dem geregelten Laden begonnen.

      Mit Start Regelzeitraum wird die benötigte Ladeleistung berechnet, um den SOC Ladeende bis zum Ende Regelzeitraum zu erreichen.

      Bei Überschreitung der Zeit, Ende Regelzeitraum wird die benötigte Ladeleistung neu berechnet, um den SOC Ladeende2 bis zur Zeit Ladeende zu erreichen.

      Wenn die Zeit Ladeende erreicht ist und die Batterie noch nicht den SOC Ladeende2 erreicht hat, wird das Laden mit maximal noch zur Verfügung stehender PV-Leistung freigegeben.

      Ausnahme: Wenn die PV-Leistung das Einspeiselimit oder die maximale Wechselrichterleistung übersteigt, wird die Ladeleistung um den Wert erhöht, um das Einspeiselimit oder die maximale Wechselrichterleistung einhalten zu können. Bei Unterschreiten von dem Wert Einspeiselimit oder WR-Limit, wird mit neu berechneter Ladeleistung, gleichmäßig geladen.

      posted in JavaScript
      A
      ArnoD
    • RE: Neuer Adapter für Roborock-Staubsauger

      @docsnyder7 sagte in Neuer Adapter für Roborock-Staubsauger:

      Hallo zusammen... da hier ein S7 Einzug gehalten hat , hab ich natürlich auch den Adapter installiert .
      Eine Frage... der stat gibt in den Objekten zb CHARGING (8) aus... wenn ich den DP benutzten will bekomme ich immernur die 8 statt dem Wert... ein kleiner Wink evt ?

      Kann man so lösen:

      function getRoboStatus() {
          const input = getState("roborock.0.Devices.blabla.deviceStatus.state").val;
      
          const statusMapping = {
              1: "Initiating", 2: "Sleeping", 3: "Idle", 4: "Remote Control", 
              5: "Cleaning", 6: "Returning Dock", 7: "Manual Mode", 8: "Charging", 
              9: "Charging Error", 10: "Paused", 11: "Spot Cleaning", 12: "In Error", 
              13: "Shutting Down", 14: "Updating", 15: "Docking", 16: "Go To", 
              17: "Zone Clean", 18: "Room Clean", 22: "Empying dust container", 
              23: "Washing the mop", 26: "Going to wash the mop", 28: "In call", 
              29: "Mapping", 100: "Fully Charged"
          };
      
          return statusMapping[input] || "Unbekannter Status";
      }
      

      ok @tropisch war schneller 🙂

      posted in ioBroker Allgemein
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      Neue Version 0.2.25 hochgeladen.

      Version: 0.2.25 Änderungen:
      Beim Abrufen der Wetterdaten Forecast wurden die letzten Werte vorher nicht gelöscht.
      Wenn aus irgendeinem Grund keine neuen Daten abgerufen werden konnten, wurde mit den alten Werten gerechnet.

      Für alle die nicht das original Script verwenden, es muss nur ab Zeile 363 bis 367 und die Funktion "SheduleForecast()" komplett kopiert werden, alles andere ist gleich geblieben.

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      Ich habe mich jetzt etwas mit Github beschäftigt und alle Javascript Dateien für E3DC dort hochgeladen.
      Ich werde neue Versionen ab jetzt immer auf Github aktualisieren:
      https://github.com/ArnoD15/iobroker_E3DC

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      Neue Version 0.3.0 hochgeladen.

      Änderungen:
      Bei den Prognosen von Proplanta und Forecast liegt die Wahrheit wie so oft meistens in der Mitte.
      Ich habe jetzt bei "PrognoseAnwahl" zwei weiter Möglichkeiten hinzugefügt.
      Wenn beide Prognosen verwendet werden, kann jetzt nach max., min. oder Durchschnitt die Prognose berechnet werden.

      Proplanta und Forecast Berechnung nach min. Wert = 0
      nur Proplanta = 1
      nur Forecast = 2
      Proplanta und Forecast Berechnung nach max. Wert = 3
      Proplanta und Forecast Berechnung nach Ø Wert = 4

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @chrischros sagte in E3DC Hauskraftwerk steuern:

      @arnod said in E3DC Hauskraftwerk steuern:

      Das wird auch die letzte Optimierung in dieser Version sein

      Wie wird es mit dem Script weitergehen?

      Ich werde es komplett ändern, um die Ladeleistung der Batterie zu steuern. Dann sollte das ganze auch ohne E3DC-Control funktionieren.

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @icke-pp sagte in E3DC Hauskraftwerk steuern:

      Das ist aber dein persönlicher Wunsch das nicht weiter geladen wird. Ich z.B. teile diesen Wunsch nicht. Mir ist es im Gegenteil sogar ganz recht wenn E3DC die Ladung ab diesem Zeitpunkt übernimmt da ich für abends einen vollen Akku erwarte wenn ich die meisten Verbraucher anwerfe.

      Jeder darf hier natürlich seine Wünsche äußern, ich werde es in der Regel immer so lösen das dadurch kein Nachteil entsteht. In dem Fall hat es @smartboart richtig angemerkt das man den Parameter Ladeende2 dann auf 100% einstellt um die Batterie voll zu laden.
      Ob das voll Laden sinnvoll ist oder nicht, kann dann jeder selber entscheiden. 😉

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      Neue Version Charge-Control auf GitHub hochgeladen.
      Version: 1.0.28
      Änderungen:

      • Wenn die PV-Erzeugung die Prognose übersteigt, wird diese nicht mehr bei der Überschussberechnung abgezogen. Damit soll verhindert werden, dass die Einstellung sich ändert, wenn die
        Prognose zu gering war.

      • Wenn Ladeende erreicht ist und der Batterie SOC den Ladeende2 SOC erreicht hat, wird das Laden der Batterie gestoppt. Ladeende2 muss somit auf 100 % eingestellt werden, wenn die Batterie voll geladen werden soll.

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      Neue Version Charge-Control auf GitHub hochgeladen.
      Version: 1.1.0
      Änderungen:

      • Neue Funktion Notstromreserve verwenden, wenn die Prognose am nächsten Tag über einem einstellbaren Wert liegt. Es wurden zwei neue User und zwei allgemein Parameter erstellt, 10_NotstromEntladen, 10_minWertPrognose_kWh, EigenverbrauchAbend_kWh,EigenverbrauchDurchschnitt_kWh. Mit 10_NotstromEntladen = true wird die Funktion aktiviert und mit 10_minWertPrognose_kWh kann festgelegt werden, ab welcher Prognose in kWh am nächsten Tag die Notstromreserve freigegeben wird. EigenverbrauchAbend_kWh summiert den Eigenverbrauch von 0:00 Uhr bis 8:00 Uhr und unter EigenverbrauchDurchschnitt_kWh wird der berechnete Durchschnittsverbrauch von diesem Zeitraum gespeichert. Wenn der Notstrom SOC erreicht ist und 10_NotstromEntladen= true und die Prognose am nächsten Tag über dem eingestellten Wert in 10_minWertPrognose_kWh liegt, wird anhand vom Durchschnittsverbrauch berechnet, wie lange der Notstrom SOC den Eigenverbrauch abdecken kann. Ab dem Zeitpunkt, wo die Notstromreserve bis zum Sonnenaufgang reicht, wird das Entladen der Batterie freigegeben. Bitte beachten, wenn die Prognose nicht stimmt, kann es vorkommen, dass bei Stromausfall eventuell keine Notstromreserve mehr vorhanden ist. Danke an @zelkin für diese Idee.

      • Fehler behoben, dass der falsche Timer verwendet wurde. Danke an @icke-pp

      • LOG Texte optimiert, wenn das Script regelt, werden jetzt Warnungen ausgegeben, um das besser unterscheiden zu können. Natürlich, nur wenn 10_LogAusgabeRegelung = true ist

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      Neue Version Charge-Control auf GitHub hochgeladen.
      Version: 1.2.10
      Änderungen:

      • E3DC-RSCP Adapater kann ab Version 1.2.0 die Info Tags anzeigen und somit auch die Firmware Version.
        Das wurde im Script integriert und zwei neue Objekte angelegt:
        "0_userdata.0.Charge_Control.Allgemein.FirmwareDate" und
        "0_userdata.0.Charge_Control.Allgemein.LastFirmwareVersion"
        um in VIS das Datum und die Uhrzeit der Firmware Installation anzeigen zu können und sich die alte Version zu merken und auch diese anzeigen zu können.

      • Fehler behoben, dass e3dc-rscp.0.EMS.POWER_LIMITS_USED nicht automatisch aktiviert wurde.

      • Fehler behoben, dass beim Erreichen von Ladeschwelle, Ladeende und Ladeende2 es zum „Pulsen“ der Ladeleistung führen kann.

      posted in JavaScript
      A
      ArnoD

    Latest posts made by ArnoD

    • RE: E3DC Hauskraftwerk steuern

      @psrelax
      Ich kann das bei mir nicht nachstellen.
      Egal ob ich das Skript neu starte oder einfach evcc auf PV umschalte, bei mir wird CC nicht deaktiviert.
      Versuch mal das Skript neu zu starten, ob es dann funktioniert.

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @psrelax
      mir geht es um diese Einträge:

      2025-08-05 10:35:18.641  - info: javascript.0 (195) script.js.E3DC_ChargeControl.Charge_Control: ##{"from":"Charge-Control", "message":"?? evcc Änderung: mode (LP1) ? off"}##
      2025-08-05 10:35:48.426  - info: javascript.0 (195) script.js.E3DC_ChargeControl.Charge_Control: ##{"from":"Charge-Control", "message":"?? evcc Änderung: charging (LP1) ? false"}##
      
      

      Bei der Umstellung auf PV müsste das im LOG erscheinen: "evcc Änderung: mode (LP1) ? PV".
      Ist das bei dir der Fall?

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @azzkikrboy
      Bitte auch so vorgehen wie weiter oben beschrieben und die Objekt ID's löschen oder manuell ändern.

      SyntaxError: Identifier 'LogparserSyntax' has already been declared ist ein anderes Problem.
      Das deutet eher auf ein nicht sauber beendetes Script hin. Sollte bei einem Neustart dann aber nicht mehr kommen.

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @psrelax
      Kannst du mir die LOG Einträge schicken, wo du evcc auf PV umgestellt hast?
      CC wird nur noch deaktiviert, wenn evcc.0.loadpoint.1.status.mode nicht PV ist und evcc.0.loadpoint.1.status.charging = true ist.

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @malei
      Welche Version vom Script hattest du vorher?
      Der Fehler tritt auf, wenn versucht wird, einen ungültigen JSON-String mit JSON.parse() zu parsen.

      Hast du die Schritte beim Wechsel auf Version 1.6.1 berücksichtigt:
      Es wurde der Datentyp der folgenden Objekt-IDs von array auf string geändert:

      0_userdata.0.Charge_Control.History.PrognoseAuto_kWh
      0_userdata.0.Charge_Control.History.PrognoseProp_kWh
      0_userdata.0.Charge_Control.History.PrognoseSolcast90_kWh
      0_userdata.0.Charge_Control.History.PrognoseSolcast_kWh
      0_userdata.0.Charge_Control.History.istPV_LeistungTag_kWh
      

      Vorgehensweise zur Anpassung
      Es gibt zwei Möglichkeiten, diese Änderung durchzuführen:

      Objekt-IDs löschen und automatisch neu erstellen lassen:

      • Dabei gehen jedoch alle bisherigen Werte verloren.

      Objekt-IDs manuell ändern:
      Typ der fünf Objekt-IDs auf String setzen
      Bei den Werten jeweils eine eckige Klammer am Anfang und Ende ergänzen, z. B.:

          [10, 34, 19]
      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      Neue Version Charge-Control auf GitHub hochgeladen.

      Version: 1.6.2
      Änderungen:

      • Kleinere Optimierungen am Code und an der Laderegelung durchgeführt.
      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @psrelax
      Es ist bereits in zwei Abschnitte aufgeteilt.
      Abend 21:00 Uhr bis 05:00 Uhr des nächsten Tages oder Tag 05:00 Uhr bis 21:00 Uhr.

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @psrelax
      Ja das genügt.

      Letzten Montag hast du abends im Schnitt mehr Strom verbraucht (300 Watt mehr) als diesen Montag. Deshalb ist die Batterie-Reichweiten-Prognose aktuell nicht richtig.

      Das Skript geht davon aus, dass dein Verbrauch nächsten Montagabend ähnlich ist wie heute – also 300 Watt niedriger als letzte Woche.

      Wenn du nun einen festen Wert (Offset) zur Korrektur nutzt, wird die Schätzung nächste Woche zu niedrig sein.
      Ein fester Offset funktioniert also nicht gut, weil du ihn ständig anpassen müsstest – je nachdem, ob der Verbrauch letzte Woche höher oder niedriger war.

      Die Möglichkeit diese Berechnung zu beeinflussen hättest du bereits jetzt, indem du einfach deine Batteriekapazität vergrößerst.
      Das kannst du z.B. mit der Objekt-ID
      0_userdata.0.Charge_Control.USER_ANPASSUNGEN.10_maxEntladetiefeBatterie
      indem du hier 100 einträgst.

      oder mit der Objekt-ID
      0_userdata.0.Charge_Control.USER_ANPASSUNGEN.10_Systemwirkungsgrad
      indem du hier 100 einträgst.

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @azzkikrboy sagte in E3DC Hauskraftwerk steuern:

      Wallbox DIP 7: bei der EasyConnect oder MultiConnect II ???

      Ich habe die EasyConnect

      posted in JavaScript
      A
      ArnoD
    • RE: E3DC Hauskraftwerk steuern

      @abyss sagte in E3DC Hauskraftwerk steuern:

      Und mal ne blöde Frage...hast du es evtl schon mal mit dem Template der Easy-Connect versucht, die ja von EVCC unterstützt wird?
      Ich hab mir mal die ModBus_E3DC_Speichersysteme (DE)_V2.40_de-DE_20.05.2025.pdf Doku durchgeblättert...für mich als Laien sieht es ja so aus, als ob beide Wallboxen mit den gleichen Bits angesteuert werden. Evtl. funktioniert ja dann das Template der Easy-connect direkt?!

      Genau das hatte ich gemeint 🙂
      Noch ein Hinweis, der mich fast zum Verzweifeln gebracht hat.
      Bei mir funktionierte die Steuerung der Wallbox über evcc erst, nachdem ich bei der Wallbox den Dip-Schalter 7 auf off gestellt hatte.

      posted in JavaScript
      A
      ArnoD
    Community
    Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
    The ioBroker Community 2014-2023
    logo