NEWS
E3DC Hauskraftwerk steuern
-
@arnod
Ich hatte heute den ganzen Tag eine Entladesperre. Sollte doch eigentlich nicht sein, oder?
2024-10-15 18:00:00.212 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: ******************* Debug LOG Tibber Skript Version 1.1.14 ******************* 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: timerIds = 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: timerTarget = [] 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: timerState = [] 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: timerObjektID = [] 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: besteLadezeit = Laden mit PV-Leistung 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: billigsterEinzelpreisBlock = 0.2861 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: billigsterBlockPreis = 0.2887 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: minStrompreis_48h = 0.2347 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Schwellwert Preisspitze = 0.5682 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Schwellwert hoher Strompreis = 0.50 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Schwellwert niedriger Strompreis = 0.10 2024-10-15 18:00:00.213 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: schneeBedeckt = false 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Prognose PV-Leistung heute = 20.428800000000003 kWh 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Prognose PV-Leistung morgen = 39.58080000000001 kWh 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: batterieKapazitaet_kWh = 15 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Batterie_SOC = 48 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: prognoseLadezeitBatterie = 1 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: pvLeistungAusreichend = false 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: reichweiteBatterie = 4:60 h / 4:60 h 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: batteriepreisAktiv = true 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: strompreisBatterie = 0.2267 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: bruttoPreisBatterie = 0.2576 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Aktueller Preis Tibber = 0.3489 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: BatterieEntladenSperren = true 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: BatterieLaden = false 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Power_Bat_W = 0 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: Power_Grid = 668 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: eAutoLaden = true 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: naechsteNiedrigphase = {"Startzeit":null,"Endzeit":null,"StartzeitLokal":null,"EndzeitLokal":null} 2024-10-15 18:00:00.214 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: naechsteHochphase = {"Startzeit":null,"Endzeit":null,"StartzeitLokal":null,"EndzeitLokal":null} 2024-10-15 18:00:00.215 - [32minfo[39m: javascript.0 (18305) script.js.E3DC_ChargeControl.Tibber: preisPhasen = {"highPhases":[],"lowPhases":[]} 2024-10-15 18:00:00.215 - [33mwarn[39m: 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? -
@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 ... -
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. -
@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.
-
@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
-
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.
-
@arnod
OK. Danke für die schnelle Antwort -
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... -
@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 ? -
@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.
-
@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.
-
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,
-
@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. -
@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. -
@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. -
-
Hallo Zusammen,
erstmal ein dickes LOB für die Entwicklung von E3DC ControlMein 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ßen2.) 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
-
@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.
-
@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. -
@arnod
Danke.
Habs soeben eingepsielt, startet ohne Fehler.
Ich werds die kommenden Tage beobachten und hoffe auf mehr Sonne.Grüße und schöne Wochenende
-
@arnod sagte in E3DC Hauskraftwerk steuern:
@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.das habe ich schon gedacht das es keine fertige Lösung gibt.
aber so ganz speziell ist das Programm doch gar nicht.
Bedingung:
In der Zeit von 0:00 - 5:00 Speicher mit max 3000 Watt laden bis SOC max 90%
Täglich in der Zeit von 5:00 bis 9:00 Entladesperre setzen. (könnte ich auch über die App einstellen)Was ich benötige
welche Datenpunkte im RSCP sind für
Befehl ->Speicher laden aus dem Netz
Befehl -> Speicher mit max ???? W laden
Befehl -> Entladessperre setzen
Diese Info müssen doch in dem E3DC Control doch irgendwo umgesetzt worden sein.