Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. E3DC Hauskraftwerk steuern

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    E3DC Hauskraftwerk steuern

    This topic has been deleted. Only users with topic management privileges can see it.
    • P
      psrelax @ArnoD last edited by

      @arnod
      Danke für deine Geduld.
      Ich versuchs jetzt mal mit einem hohen Schwellwert, wie es sich dann verhält.

      1 Reply Last reply Reply Quote 0
      • A
        ArnoD last edited by

        Tibber Skript,
        Version: 1.1.14 auf Github hochgeladen.

        Änderungen:

        • View Tibber geändert: Es wird jetzt der Schwellwert Spitzenstrompreis angezeigt und nicht mehr der Batteriestrompreis.
        • Neue Objekt Id 0_userdata.0.TibberSkript.Anzeige_VIS.Spitzenstrompreis
        • In der Funktion zur Berechnung, ob die PV-Prognose ausreicht, wurden einige Fehler korrigiert.
        P 1 Reply Last reply Reply Quote 1
        • P
          psrelax @ArnoD last edited by psrelax

          @arnod
          Ich hatte heute den ganzen Tag eine Entladesperre. Sollte doch eigentlich nicht sein, oder?
          74d32210-601d-49a1-9ab0-448198f62bb2-image.png

          2024-10-15 18:00:00.212  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: *******************  Debug LOG Tibber Skript Version 1.1.14 *******************
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: timerIds = 
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: timerTarget = []
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: timerState = []
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: timerObjektID = []
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: besteLadezeit = Laden mit PV-Leistung
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: billigsterEinzelpreisBlock = 0.2861
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: billigsterBlockPreis = 0.2887
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: minStrompreis_48h = 0.2347
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Schwellwert Preisspitze = 0.5682
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Schwellwert hoher Strompreis = 
          0.50	
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Schwellwert niedriger Strompreis = 
          0.10	
          2024-10-15 18:00:00.213  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: schneeBedeckt = false
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Prognose PV-Leistung heute = 20.428800000000003 kWh
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Prognose PV-Leistung morgen = 39.58080000000001 kWh
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: batterieKapazitaet_kWh = 15
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Batterie_SOC = 48
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: prognoseLadezeitBatterie = 1
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: pvLeistungAusreichend = false
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: reichweiteBatterie = 4:60 h / 4:60 h
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: batteriepreisAktiv = true
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: strompreisBatterie = 0.2267
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: bruttoPreisBatterie = 0.2576
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Aktueller Preis Tibber = 0.3489
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: BatterieEntladenSperren = true
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: BatterieLaden = false
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Power_Bat_W = 0
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Power_Grid = 668
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: eAutoLaden = true
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: naechsteNiedrigphase = {"Startzeit":null,"Endzeit":null,"StartzeitLokal":null,"EndzeitLokal":null}
          2024-10-15 18:00:00.214  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: naechsteHochphase = {"Startzeit":null,"Endzeit":null,"StartzeitLokal":null,"EndzeitLokal":null}
          2024-10-15 18:00:00.215  - info: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: preisPhasen = {"highPhases":[],"lowPhases":[]}
          2024-10-15 18:00:00.215  - warn: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: ProgrammAblauf = 25,1,2,4,5,6,6,8,10,12,20,22, 
          

          Nachtrag 16.10.2024
          Ich habe fast durchgehend eine Entladesperre. Was passt an meiner Einstellung nicht? 😞

          A 1 Reply Last reply Reply Quote 0
          • azzkikrboy
            azzkikrboy @ArnoD last edited by azzkikrboy

            @arnod sagte in E3DC Hauskraftwerk steuern:

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

            • Es werden die wichtigsten e3dc-rscp Adaptereinstellungen geprüft und wenn diese abweichen wird im LOG eine Warnung ausgegeben.

            Hallo @ArnoD,
            ich habe gerade das neue 1.5.8 script aktiviert und erhalte nun beim Start folgenden Fehler.

            script.js.Charge_Control_1_5_8: ##{"from":"Charge-Control", "message":"-==== Error in der function InterrogateSolcast. Fehler = Error: Error fetching data: Request failed with status code 429 ====-"}##
            

            Könnte das an den Änderungen an den API-requests von Solcast liegen?
            Der Alte Adapter funktioniert ja nicht mehr, mit Version 4.0.0 geht es dann wieder nur über die IDs ...

            A 1 Reply Last reply Reply Quote 0
            • azzkikrboy
              azzkikrboy last edited by

              Und noch eine Frage.
              Ist dein Script kompatible mit der neuen Version des E3DC.RSCP adapter (1.3.x) ?
              Da hat sich wohl einiges geändert.

              bluebean 1 Reply Last reply Reply Quote 0
              • bluebean
                bluebean @azzkikrboy last edited by

                @azzkikrboy said in E3DC Hauskraftwerk steuern:

                Ist dein Script kompatible mit der neuen Version des E3DC.RSCP adapter (1.3.x) ?

                Ich habe den Adapter 1.3.1 installiert und es läuft bei mir problemlos.

                1 Reply Last reply Reply Quote 0
                • A
                  ArnoD @azzkikrboy last edited by

                  @azzkikrboy sagte in E3DC Hauskraftwerk steuern:

                  Könnte das an den Änderungen an den API-requests von Solcast liegen?

                  Nein, wie der Fehlercode 429 bereits aussagt, liegt das an zu häufigen Verbindungsversuche.

                  Ist dein Script kompatible mit der neuen Version des E3DC.RSCP adapter (1.3.x) ?

                  Ja

                  azzkikrboy 1 Reply Last reply Reply Quote 0
                  • A
                    ArnoD @psrelax last edited by ArnoD

                    @psrelax

                    Das hat nichts mit deinen Einstellungen zu tun, sondern mit meiner Zeit die Fehler zu beheben 🙂
                    Das Thema Entladesperre habe ich kurzfristig zurückgestellt, um mich erstmal auf die Fehler beim Laden zu konzentrieren.
                    Es sind noch einige Situationen, wo das Laden nicht so funktioniert wie ich mir das vorstelle.
                    Es wird aber jeden Tag besser und ich muss jetzt erstmal mein Script wieder aufräumen und alte Versuche entfernen, sonst wird es zu unstrukturiert und umso schwerer die Fehler zu finden.

                    Nachtrag: Setze mal deinen Schwellwert hoher Strompreis auf 0,26€ dann denke ich sollte es so funktionieren wie du es erwartest.

                    P 1 Reply Last reply Reply Quote 1
                    • azzkikrboy
                      azzkikrboy @ArnoD last edited by

                      @arnod
                      OK. Danke für die schnelle Antwort

                      1 Reply Last reply Reply Quote 0
                      • A
                        Abyss last edited by Abyss

                        Hallo @ArnoD

                        sorry wenn ich in die Tibber-Diskussion so reingrätsche, aber mir ist grad ein möglicher Fehler im Heizstabscript aufgefallen.

                        Wie es scheint wird für das Script ja der Datenpunkt '0_userdata.0.Charge_Control.Allgemein.Hausverbrauch' verwendet.
                        Aus diesem wird aber nach meinem Verständnis im Charge-Control Script der Verbrauch einer Wärmepumpe, Wallbox und des Heizstabs rausgerechnet.
                        Der Verbrauch der Wärmepumpe und der Wallbox dürfen in diesem Fall aber nicht rausgerechnet werden, da man sonst ja einen falschen Überschuss ermittelt, den es so gar nicht gibt.
                        Das führt aktuell dazu, dass bei mir momentan der Heizstab mit einem vermeintlichen Übeschuss getriggert wird, den aber zeitgleich die Wärmepumpe nutzt und ich somit in einer Entladung der Batterie bzw. Netzbezug und einem ewigen hin und her lande.

                        Vermutlich müsste man im Heizstabscript den Hausverbrauch neu berechnen um den reinen Überschuss zu ermitteln oder die Variable "Hausverbrauch_W" incl. Wärempumpe und Wallbox neu beschreiben?

                        Grüße

                        EDIT
                        grad nochmal über das Script geschaut....die Wallbox wird scheinbar berücksichtigt, somit fehlt ansich nur noch der Verbrauch der Wärmepumpe...

                        azzkikrboy A 2 Replies Last reply Reply Quote 0
                        • azzkikrboy
                          azzkikrboy @Abyss last edited by

                          @abyss sagte in E3DC Hauskraftwerk steuern:

                          Aus diesem wird aber nach meinem Verständnis im Charge-Control Script der Verbrauch einer Wärmepumpe, Wallbox und des Heizstabs rausgerechnet.

                          Sorry, aber hier grätsche ich auch mal rein 😊
                          Wo kommt dann der Verbrauch Wärmepumpe her, der rausgerechnet wird ?

                          1 Reply Last reply Reply Quote 0
                          • A
                            ArnoD @Abyss last edited by ArnoD

                            @abyss sagte in E3DC Hauskraftwerk steuern:

                            grad nochmal über das Script geschaut....die Wallbox wird scheinbar berücksichtigt, somit fehlt ansich nur noch der Verbrauch der Wärmepumpe...

                            Ja, da hast du recht.
                            Ist bis jetzt nicht aufgefallen, da anscheinend keiner eine WP hat und ich keinen Heizstab.
                            Du bist der Erste, der beides hat. 🙂

                            Ich werde das im my-pv Heizstab Script anpassen, danke für den Hinweis.

                            Nachtrag: Korrigierte Version auf Github hochgeladen. Kann es aber bei mir nicht testen.

                            A 1 Reply Last reply Reply Quote 0
                            • P
                              psrelax @ArnoD last edited by

                              @arnod
                              Ich hab das einen Tag nach deiner Empfehlung auf 0,26 eingestellt.
                              Macht irgendwie nicht wirklich einen Unterschied.

                              Ich würde gerne testen und dir behilflich mit meinen Tests sein, weiß aber nicht wie, da ich praktisch nicht klar komme.
                              Ich habe das Problem, dass ich nicht weiß, wenn ich das ändere, muss das Ergebnis kommen.

                              Somit muss ich warten, bis du etwas änderst oder es von dir getestet ist.

                              A 1 Reply Last reply Reply Quote 0
                              • M
                                matze191174 last edited by

                                Hi,
                                hab mal eine Frage zu dem Log Eintrag.
                                Was bedeuten eigentlich die Zahlen hinter "ProgrammAblauf"?

                                2024-10-17 22:40:00.264 - warn: javascript.0 (351) script.js.common.tibber-skript: ProgrammAblauf = 25,1,2,4,5,6,9,11,24,28,

                                A 1 Reply Last reply Reply Quote 0
                                • A
                                  ArnoD @matze191174 last edited by

                                  @matze191174
                                  Das ist eine Hilfe, um zu erkennen, wie der Programmablauf war, um so schneller den Fehler zu finden.
                                  Wenn man nicht davor sitzt, ist es sonst schwierig zu verstehen, warum der Code nicht funktioniert.

                                  25 = Funktion zum Berechnen vom Batteriepreis durchlaufen
                                  1 = Funktion tibberSteuerungHauskraftwerk()
                                  2 = Reichweite der Batterie überprüft
                                  usw.

                                  1 Reply Last reply Reply Quote 0
                                  • A
                                    ArnoD @psrelax last edited by

                                    @psrelax
                                    Warte noch etwas mit dem testen.
                                    Wenn es bei mir mal einigermaßen fehlerfrei läuft, macht das mehr Sinn.
                                    Aktuell finde ich jeden Tag noch einige Fehler, die ich jetzt nach und nach korrigiere.

                                    1 Reply Last reply Reply Quote 1
                                    • A
                                      Abyss @ArnoD last edited by

                                      @arnod
                                      Danke für die schnelle Umsetzung.
                                      Ich bin grad mal dabei es einzuspielen, scheinbar mag er aber die neue const "LeistungWP" nicht.
                                      "cannot redeclare block scoped variable 'LeistungWP'"
                                      Das führt dann zu einem Fehler beim Einlesen.

                                      Ich hab die Variable mal in "LeistungLW_Pumpe" und die gefüllte Variabel in "LeistungLW_Pumpe_W" umbenannt, dann funktioniert es.
                                      Ich teste...

                                      // defintion which instances has to be used 
                                      const instanzE3DC_RSCP       = 'e3dc-rscp.0' 
                                      const instanzHeizstab_Modbus = 'modbus.1'
                                      
                                      // E3DC Komponenten Definition 
                                      const sID_PV_Leistung       = `${instanzE3DC_RSCP}.EMS.POWER_PV`; // PV power
                                      const sID_Netz_Leistung     = `${instanzE3DC_RSCP}.EMS.POWER_GRID`; // Grid power
                                      const sID_Wallbox_Leistung  = `${instanzE3DC_RSCP}.EMS.POWER_WB_ALL`; // Wallbox power
                                      const sID_Batterie_Leistung = `${instanzE3DC_RSCP}.EMS.POWER_BAT`; // Battery power
                                      const sID_Power_Mode        = `${instanzE3DC_RSCP}.EMS.MODE`; // Power mode state
                                      const sID_Batterie_Status   = `${instanzE3DC_RSCP}.EMS.BAT_SOC`; // Battery status state
                                      const sID_Bat_Charge_Limit  = `${instanzE3DC_RSCP}.EMS.SYS_SPECS.maxBatChargePower`;// Batterie Ladelimit
                                      
                                      // selbst definierte Variablen
                                      const sID_Eigenverbrauch    = '0_userdata.0.Charge_Control.Allgemein.Hausverbrauch'; 					// Household consumption power
                                      const sID_M_Power_W         = '0_userdata.0.Charge_Control.Allgemein.Akt_Berechnete_Ladeleistung_W'; 	// Calculated required charging power
                                      const sID_LeistungLW_Pumpe_W = 'shelly.0.shellypro3em#a0dd6ca0bf44#1.EM0.TotalActivePower';                   // Pfad zu den Leistungswerte Wärmepumpe eintragen ansonsten leer lassen
                                      
                                      // Heistab Modbus Variablen 
                                      const sID_LeistungHeizstab_W        = `${instanzHeizstab_Modbus}.holdingRegisters.41001_Power`; // Current power consumption of heating element in W
                                      const sID_Soll_LeistungHeizstab_W   = `${instanzHeizstab_Modbus}.holdingRegisters.41001_Power`; // Target heating element power
                                      const sID_IstTempHeizstab           = `${instanzHeizstab_Modbus}.holdingRegisters.41002_Temp1`; // Current temperature at the heating element
                                      const sID_MaxTempHeizstab           = `${instanzHeizstab_Modbus}.holdingRegisters.41003_WW1_Temp_max`; // Maximum temperature
                                      
                                      // Heistab states manuell zu erstellen für Statistikwerte
                                      const sID_previousHeizstabLeistung_W    = '0_userdata.0.Heizung.E3DC.previousHeizstabLeistung'; // Previous heating element load power
                                      const sID_Heizstab_Gesamtenergie        = '0_userdata.0.Heizung.E3DC.Heizstab_Gesamtenergie'; // Cumulative energy
                                      const sID_Heizstab_LetzteAktualisierung = '0_userdata.0.Heizung.E3DC.Heizstab_LetzteAktualisierung'; // Last update
                                      
                                      // Defintion von Heizstabparametern und Sicherheitsmechanismen
                                      const debounceInterval          = 3000; // Minimum interval between updates in milliseconds
                                      const temperatureBuffer         = 3;    // Buffer in degrees Celsius to prevent frequent on/off cycling
                                      const minimumHeizstabLeistung   = 300;  // Minimum power for heating element
                                      const sicherheitspuffer         = 300;  // Safety buffer to avoid frequent switching
                                      const MaximalLeistungHeizstab_W = 3000; // Maximum power in watt of the heating element
                                      
                                      let debounceTimer;
                                      
                                      async function fetchAndUpdateHeizstabLeistung() {
                                          try {
                                              // Zustände abfragen
                                              const states = await Promise.all([
                                                  getStateAsync(sID_Wallbox_Leistung),
                                                  getStateAsync(sID_Netz_Leistung),
                                                  getStateAsync(sID_LeistungHeizstab_W),
                                                  getStateAsync(sID_Eigenverbrauch),
                                                  getStateAsync(sID_M_Power_W),
                                                  getStateAsync(sID_Batterie_Leistung),
                                                  getStateAsync(sID_IstTempHeizstab),
                                                  getStateAsync(sID_MaxTempHeizstab),
                                                  getStateAsync(sID_PV_Leistung),
                                                  getStateAsync(sID_Soll_LeistungHeizstab_W),
                                                  getStateAsync(sID_Power_Mode),
                                                  getStateAsync(sID_Batterie_Status),
                                                  getStateAsync(sID_Bat_Charge_Limit),
                                      			getStateAsync(sID_LeistungLW_Pumpe_W)
                                              ]);
                                      
                                              const [
                                                  Wallbox_Leistung, Netz_Leistung, LeistungHeizstab, Eigenverbrauch, M_Power, Batterie_Leistung,
                                                  IstTempHeizstab, MaxTempHeizstab, PV_Leistung, SollLeistungHeizstab, 
                                                  Power_Mode, Batterie_Status, Bat_Charge_Limit, LeistungLW_Pumpe
                                              ] = states;
                                      
                                              // Ensure all states are fetched correctly
                                              const stateNames = [
                                                  'Wallbox_Leistung', 'Netz_Leistung', 'LeistungHeizstab', 'Eigenverbrauch', 'M_Power', 'Batterie_Leistung',
                                                  'IstTempHeizstab', 'MaxTempHeizstab', 'PV_Leistung', 'SollLeistungHeizstab',
                                                  'Power_Mode', 'Batterie_Status', 'Bat_Charge_Limit', 'LeistungLW_Pumpe'
                                              ];
                                      
                                              stateNames.forEach((name, index) => {
                                                  if (states[index] === null || states[index] === undefined) {
                                                      console.error(`State ${name} is null or undefined`);
                                                  }
                                              });
                                      
                                              if (states.some(state => state === null || state === undefined)) {
                                                  throw new Error('One or more states are null or undefined');
                                              }
                                      
                                              // Werte extrahieren
                                              let [
                                                  Wallbox_Leistung_W, NetzLeistung_W, LeistungHeizstab_W, Hausverbrauch_W, M_Power_W, BatterieLeistung_W,
                                                  IstTemp, MaxTemp, PV_Leistung_W, SollLeistungHeizstab_W, 
                                                  PowerMode, BatterieStatus, Charge_Limit, LeistungLW_Pumpe_W
                                              ] = states.map(state => state.val);
                                      
                                              console.log(`Zustände abgefragt: Netz=${NetzLeistung_W}W, PV=${PV_Leistung_W}W, Hausverbrauch=${Hausverbrauch_W}W, LeistungHeizstab=${LeistungHeizstab_W}W, Batterie=${BatterieLeistung_W}W, IstTemp=${IstTemp}°C, MaxTemp=${MaxTemp}°C, SollLeistungHeizstab=${SollLeistungHeizstab_W}W, PowerMode=${PowerMode}, BatterieStatus=${BatterieStatus}, Charge_Limit=${Charge_Limit}, M_Power_W=${M_Power_W}W, LeistungWP = ${LeistungLW_Pumpe_W}W`);
                                      
                                              // Bedingungen prüfen
                                              if (PowerMode === 2 && Charge_Limit == M_Power_W && BatterieLeistung_W > 0) {
                                                  console.log('Power_Mode ist 2 und Batterie soll mit max. Leistung geladen werden. Heizstab wird nicht aktiviert.');
                                                  await setStateAsync(sID_Soll_LeistungHeizstab_W, 0);
                                                  return;
                                              }
                                      
                                              // Verfügbaren Überschuss berechnen
                                              let verfuegbarerUeberschuss_W = PV_Leistung_W - Hausverbrauch_W - M_Power_W- Wallbox_Leistung_W - LeistungLW_Pumpe_W - sicherheitspuffer; // Verfügbarer Überschuss unter Berücksichtigung von PV-Leistung, Hausverbrauch, Wärmepumpe, Soll-Ladeleistung und Sicherheitspuffer
                                              verfuegbarerUeberschuss_W = Math.max(verfuegbarerUeberschuss_W, 0); // Stellen Sie sicher, dass der Wert nicht negativ wird
                                      
                                              // Heizstab-Leistung bestimmen
                                              let HeizstabLadeleistung_W = 0;
                                              if (IstTemp < MaxTemp - temperatureBuffer && verfuegbarerUeberschuss_W >= minimumHeizstabLeistung) { // Stellen Sie sicher, dass die Temperaturbedingung mit Puffer erfüllt ist und die Mindestleistung verfügbar ist
                                                  HeizstabLadeleistung_W = Math.min(verfuegbarerUeberschuss_W, MaximalLeistungHeizstab_W); // Begrenzen Sie auf 3000W oder verfügbare Energie
                                              } else {
                                                  HeizstabLadeleistung_W = 0; // Heizstab ausschalten, wenn die Bedingungen nicht erfüllt sind
                                              }
                                              await setStateAsync(sID_Soll_LeistungHeizstab_W, HeizstabLadeleistung_W);
                                      
                                              // Aktualisiere den vorherigen Wert der Heizstabladeleistung
                                              await setStateAsync(sID_previousHeizstabLeistung_W, HeizstabLadeleistung_W);
                                      
                                              // Kumulierte Energieberechnung, Aktualisierung und Logging
                                              const jetzt = Date.now();
                                              const letzteAktualisierung = await getStateAsync(sID_Heizstab_LetzteAktualisierung);
                                              const vergangeneZeitInStunden = (jetzt - (letzteAktualisierung.val || 0)) / (1000 * 60 * 60);
                                              const verbrauchteEnergie = (LeistungHeizstab_W * vergangeneZeitInStunden) / 1000; // In kWh umrechnen
                                              const aktuelleGesamtenergie = (await getStateAsync(sID_Heizstab_Gesamtenergie)).val || 0;
                                              const neueGesamtenergie = aktuelleGesamtenergie + verbrauchteEnergie;
                                      
                                              await setStateAsync(sID_Heizstab_Gesamtenergie, neueGesamtenergie);
                                              await setStateAsync(sID_Heizstab_LetzteAktualisierung, jetzt);
                                      
                                              console.log(`Update: Netz=${NetzLeistung_W}W, PV=${PV_Leistung_W}W, Heizstab=${HeizstabLadeleistung_W}W, Überschuss=${verfuegbarerUeberschuss_W}W`);
                                          } catch (error) {
                                              // @ts-ignore
                                              console.error('Fehler bei der Aktualisierung der Heizstab-Leistung:', error.message);
                                              console.error(error.stack);
                                          }
                                      }
                                      
                                      function debounceUpdate() {
                                          if (debounceTimer) return;
                                          fetchAndUpdateHeizstabLeistung();
                                          debounceTimer = setTimeout(() => {
                                              debounceTimer = null;
                                          }, debounceInterval);
                                      }
                                      
                                      // Register listeners for relevant state changes
                                      const ids = [
                                          sID_Wallbox_Leistung,
                                          sID_PV_Leistung,
                                          sID_Netz_Leistung,
                                          sID_Eigenverbrauch,
                                          sID_Batterie_Leistung,
                                          sID_LeistungHeizstab_W,
                                          sID_M_Power_W,
                                          sID_Power_Mode,
                                          sID_Batterie_Status
                                      ];
                                      
                                      ids.forEach(id => {
                                          on({ id, change: "ne" }, debounceUpdate);
                                          console.log(`Listener registered for ${id}`);
                                      });
                                      
                                      // Initial call
                                      fetchAndUpdateHeizstabLeistung();
                                      

                                      Gestern sind mir noch zwei Punkte aufgefallen:

                                      • wenn der Akku auf 100% steht, bleibt "M_Power_W" bei 3000 hängen (max. Batterieladung bei meiner S10), somit fehlen diese 3000W bei der Berechnung von "verfuegbarerUeberschuss_W"

                                      • und vor allem Vormittags wird der Heizstab blockiert mit der Meldung "Power_Mode ist 2" um die Batterieladung zu priorisieren. Das ist grundsätzlich toll, führt aber bei Sonne dazu, dass dann mit 3000-4000W eingespeist wird, was man aber besser in den Heizstab umleiten könnte.
                                        Evtl. könnte man hier noch eine Prüfung reinmachen, dass wenn Einspeisung > 1000W dann ignoriere Power_Mode 2 oder sowas in der Art?

                                      @azzkikrboy
                                      Ich habe an meiner Wärmepumpe einen Shelli 3EM Pro hängen der mir die Leistung der Wärmepumpe ermittelt.
                                      Das wird dann im Charge-Control in "sID_LeistungLW_Pumpe_W" eingetragen um diese dann aus dem eigentlichen Hausverbrauch rauszurechnen und die Leistungswerte separat darstellen zu können.

                                      1 Reply Last reply Reply Quote 0
                                      • R
                                        Ronniboy last edited by

                                        Hallo Zusammen,
                                        erstmal ein dickes LOB für die Entwicklung von E3DC Control

                                        Mein neuer Stromtarif rechnet in dem Zeitraum 0.00 – 5:00 Uhr mit 8,48 €/kwh.
                                        Ich möchte programmmäßig über den IOBROKER und mit RSCP folgende Befehle anstoßen:
                                        1.) Zu einem bestimmten Zeitpunkt das „manuelle Speicherladen“ aus dem Netz anstoßen

                                        2.) Festlegen der gewünschten Energiemenge

                                        3.) Batteriespeicher Entladung sperren/freigeben
                                        Hat das jemand mit IOBROKER umgesetzt?

                                        Das Programm e3dc-control wollte ich nicht einsetzen, erscheint mir für meine Bedürfnisse zu umfangreich.

                                        Oder gibt es eine fertige Alternative ,etwa eine E3DC Control light Version?

                                        LG Ronald

                                        A 1 Reply Last reply Reply Quote 0
                                        • A
                                          ArnoD last edited by ArnoD

                                          @abyss sagte in E3DC Hauskraftwerk steuern:

                                          ch bin grad mal dabei es einzuspielen, scheinbar mag er aber die neue const "LeistungWP" nicht.
                                          "cannot redeclare block scoped variable 'LeistungWP'"
                                          Das führt dann zu einem Fehler beim Einlesen.

                                          Ja, mein Fehler habe das _W bei LeistungWP vergessen, so wäre es richtig: LeistungWP_W.

                                          wenn der Akku auf 100% steht, bleibt "M_Power_W" bei 3000 hängen (max. Batterieladung bei meiner S10), somit fehlen diese 3000W bei der Berechnung von "verfuegbarerUeberschuss_W"

                                          Habe ich korrigiert. M_Power_W ist nur relevant, wenn PowerMode auf 2 (Charge) steht.

                                          und vor allem Vormittags wird der Heizstab blockiert mit der Meldung "Power_Mode ist 2" um die Batterieladung zu priorisieren. Das ist grundsätzlich toll, führt aber bei Sonne dazu, dass dann mit 3000-4000W eingespeist wird, was man aber besser in den Heizstab umleiten könnte.

                                          Vermute, das passiert jedes Mal, wenn E3DC die Regelung übernimmt und die Batterie geladen wird, dann wird M_Power nicht mehr aktualisiert und bleibt auf dem max. Wert stehen. In dem Fall müsste M_Power die aktuelle Ladeleistung der Batterie enthalten, damit die Berechnung vom Überschuss wieder stimmt.
                                          Das Problem wird hier wieder die Trägheit der Regelung sein, sodass dann ständig zwischen Regelung E3DC und Script gewechselt wird.
                                          Ich kann es ja mal einbauen und du kannst dann testen, ob das was bringt.

                                          Nachtrag: neue Version auf Github hochgeladen. Kannst du das bei Gelegenheit mal testen.

                                          A 1 Reply Last reply Reply Quote 0
                                          • A
                                            ArnoD @Ronniboy last edited by

                                            @ronniboy
                                            Kann man sicher mit einem Script und dem e3dc-rscp Adapter umsetzen, aber eine fertige Lösung, die deine Wünsche erfüllt, kenne ich nicht.
                                            Das ist auch so speziell, dass es nur wenige überhaupt brauchen werden.

                                            R 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            902
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            70
                                            3272
                                            1104647
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo