NEWS
Node-Red - Shelly PlusPlugS - Mqtt Node-Red Dashboard
-
EVCS hat folgende Statusausgaben:
0 = Bedingung KEINE Ausregelung gegen 0
1 = Bedingung KEINE Ausregelung gegen 0
2 = Bedingung KEINE Ausregelung gegen 0
4 = Bedingung KEINE Ausregelung gegen 0
6 = Bedingung KEINE Ausregelung gegen 0
7 = Bedingung KEINE Ausregelung gegen 03 = Bedingung Ausregelung gegen 0
Batterie SOC
Ausgabe als Wert in %D.h. =/> 99% = Ausregelung gegen 0
-
@hape1 Damit kann ich nichts anfangen, versetze Dich doch mal in das Nachrichtenobjekt. Aus der Range Node kommt ein Wert zwischen 0 und 1600. Muss dieser Wert irgendwas überprüft werden oder soll der EVCS überprüft werden.
Sag genau wie Deine Bedingung aussehen soll.
Wenn der Wert 300 kommt und EVCS Status ungleich 3 und SOC < 80 ist, dann soll geregelt werden. Versuche mal Deinen Flow in eine Logik zu formulieren. Ich kenne mich damit NICHT aus - DU musst die Logik schon selbst formulieren - ich kann Dir nur vorschlagen, wie man es umsetzen kann.
Ich kenne mich nicht mit Batterien etc. aus - das musst Du schon selbst formulieren.
Du weißt doch, dass aus der range Node ein Wert zwischen 0 und 1600 rauskommt, was soll also als nächstes überprüft werden? oder von mir aus verzweigt sich Dein Flow - weil die Bedingungen bei unterschiedlichen Werten unterschiedlich aussehen. Du musst halt Schritt für Schritt überlegen, wie und was geprüft werden soll.
-
Kein Problem, ich bin ja froh, das Du nicht alles weißt
Ok, ich formuliere das jetzt mal so:
Wenn die Bedingung Batterie SOC =/> 99% UND der EVCS Status den Wert 3 ausgibt dann soll der Flow arbeiten und den Wechselrichter runterregeln.
Im Umkehrschluss wird daraus, das beim EVCS-Status 0;1;2;4;6;7 und alles SOC-Werten <98% KEINE Ausregelung erfolgen soll.
Dh. ich würde das mal mit meinem Wissen so ausbilden:
-
So was macht in der Regel keinen Sinn, weil dann brauche ich keine Abprüfung.
Also wenn wir das umsetzen wollen: Wenn die Bedingung Batterie SOC =/> 99% UND der EVCS Status den Wert 3 ausgibt dann müssen wir dafür sorgen, dass nur das durchgelassen wird - alles andere wird ja automatisch blockiert.
Also zeig wie du Deinen State of Charge überprüftst?
Das ist schon mal verkehrt - also Name würde ich eine geben "Batterie_SOC > 99%" - das beschriftet Dir die Node nur.
In der Eigenschaft steht der Wert den du überprüfen willst und das ist NICHT die payload - da diese ja den Wert 0-1600 aus Deiner Summierung enthält. Du willst doch den Wert Deiner Flowvariablen Batterie_SOC überprüfen und nicht die payload. Also stelle das erst mal richtig.Das mit der Überprüfung der Variablen EVCS ist natürlich auch Quatsch. Hier überprüfst Du ja wieder Deine payload - die Deine Werte aus der range Node enthält:
Dann macht es in der Regel (es gibt Ausnahmen) KEINEN Sinn wenn beide Ausgänge GLEICH behandelt werden - sprich alle in die gleiche Node münden ohne dass dazwischen das Nachrichtenobjekt unterschiedlich bearbeitet wird.
Auch hier dient der Name nur der Beschriftung der Node - das kann man dafür nutzen - da wir nur die Nachricht durchlassen wollen, wenn EVCS gleich 3 ist. Dann schreibst Du als Name am Besten "EVCS = 3"
-
@mickym ... Du bist zu schnell für mich :
-
@hape1 ##
wenn du das ist true wegmachst, dann passt es - ES wird grundsätzlich die Nachricht nur an den Ausgang weitergeleitet wenn die Bedingug erfüllt ist.
Und wie gesagt Du kannst das alles überprüfen indem Du mit Inject Nodes die Werte simulierst und änderst.
Wenn Du hinter jede Switch Node eine Debug Node machst, dann kannst Du genau nachvollziehen, welche Node die Nachricht wegfiltert oder durchlässt.
-
Ok, "alles klar" ... ich werde den Flow testen und melde mich einem Ergebnis zurück ...
Ps. Dein Tempo ist mir ein wenig unheimlich VIELEN DANK!
-
@hape1 sagte in Node-Red - Shelly PlusPlugS - Mqtt Node-Red Dashboard:
Ok, "alles klar" ... ich werde den Flow testen und melde mich einem Ergebnis zurück ...
Ps. Dein Tempo ist mir ein wenig unheimlich VIELEN DANK!
Na ich dachte eigentlich, dass ich Dir das Schritt für Schritt erkläre. Ich hätte ja auch einfach den Flow fertig machen können. Es geht mir aber darum, dass Du verstehst was passiert und welchen Vorteil Du mit dieser grafischen Programmierung hast und eben nicht Text und Text formulierst sondern die Macht der Knoten nutzt.
Ich würde es auch mal schön machen und in eine Linie zeichnen, also die Nodes NICHT so untereinander zu quetschen - dann sieht man schöner wie der Flow von Anfang (links) also dem Trigger - zur Steuerung ganz nach rechts läuft.
-
... nein, nein, Missverständnis ... die Erklärungen waren sehr hilfreich, aber ich musste erstmal nachdenken, bis ich das erklärte verstanden hatte ... Alles gut, ich freue mich, wenn ich was lernen kann!
-
@hape1 trotzdem musst du Dir halt deine Logik überlegen. Im Moment würde halt alles blockiert, sobald der Ladezustand der Batterie unter 99% sinkt. Ich weiß nicht, ob das gewünscht ist - aber wie gesagt, das musst Du wissen.
-
@mickym sagte in Node-Red - Shelly PlusPlugS - Mqtt Node-Red Dashboard:
@hape1 trotzdem musst du Dir halt deine Logik überlegen. Im Moment würde halt alles blockiert, sobald der Ladezustand der Batterie unter 99% sinkt. Ich weiß nicht, ob das gewünscht ist - aber wie gesagt, dass musst Du wissen.
Das soll natürlich nicht sein!
Bei unter 99% soll der Wechselrichter seine volle Leistung bringen!
-
@hape1 Ja wie gesagt, das musst Du wissen. Momentan blockiert die 1. Switch Node alles wenn der SOC kleiner 99 ist.
Und vielleicht bringt ja der Wechselrichter seine volle Leistung wenn nichts an den mqtt-Switch geschickt wird. Ansonsten musst Du halt nun auch dafür sorgen, was soll passieren, wenn der SOC unter 99% ist. Dann machst Du da einen 2. Ausgang hin und formulierst die Bedingungen.
-
ok, aber das würde ja sinngemäß auch für den EVCS_Status gelten:
Denn bei allen Werten die NICHT 3 sind, soll der Wechselrichter voll laufen ...
ok, ich denke noch mal darüber nach.
-
@hape1 Vielleicht solltest Du dann auch die Reihenfolgen der Switch Nodes ändern und einen 2. Ausgang bei der EVCS Filter Node machen - wo der Status ungleich (also != 3) ist.
Am Besten ist halt Du formulierst die Bedingung in Sätzen:
- Wenn SoC => 99 und EVCS = 3
- Wenn SoC <99 und EVCS !=3 usw.
Denn bei allen Werten die NICHT 3 sind, soll der Wechselrichter voll laufen ...
Sowas sagt mir nichts.
-
?
-
@hape1 NEIN - nochmal 2 Ausgänge in die gleiche Node sind unsinnig.
Wenn Du folgendes machen willst:
- Soc => 99 und EVCS = 3
Soc <99 und nicht <= 98 (ist einfach eindeutiger)
- Ausgang (nicht 2 mal = - die Bedingungen sollen ja EINDEUTIG sein)
An den 2. Ausgang machst Du dann eine 3. Switch Node hin - in der Du EVCS !=3 prüfst.
- Soc => 99 und EVCS = 3
-
So schaut der Flow korrekt aus. Hier zum Import:
Du musst Dir einfach vorstellen, Du bist ein Nachrichtenobjekt und Du kommst bei den verschiedenen Nodes an, die Dich entweder passieren lassen, Dir den richtigen Ausgang zeigen oder Deine Weiterreise unterbinden.
Wenn Du übrigens mit der Maus über die entsprechenden Ausgänge fährst wird Dir die Bedingung für den Ausgang angezeigt:
Wenn Du sowas machst:
dann kannst Du Dir auch die Bedingungen sparen - das macht nur Sinn, wenn es dann noch Fälle gibt, die weder in den Ausgang 1 noch in den Ausgang 2 gehen. Wenn aber die Nachrichten immer entweder in Ausgang 1 oder in den Ausgang 2 gehen - dann kann ich mir den Node auch sparen.
Hier wieder das Gleiche:
Egal ob der EVCS Status 3 oder ungleich 3 ist - alle Nachrichten werden in die mqtt Node weitergeleitet. Dann kann ich die Node auch weglassen.
-
hmm, irgendetwas stimmt noch nicht ...
Aus den debug-notes 6 und 7 kommt nix ...
Aus 4 und 5 schon ...
Will sagen es gibt zwar keinen Netzbezug, weil noch aus der Batterie gespeist wird, aber die Bedingung Batt <98 und EVCS-Status !=3 sind erfüllt, es sollte also keine Runterregelung des Wechselrichters stattfinden ...
-
@hape1 Na das aus 6 nichts kommt ist ja richtig - da der SOC unter 99 liegt. Also müsste es ja aus 7 rauskommen, da unter 99 % und ungleich 3. Also prüfe nochmal beide Ausgänge der 1. Switch Node
-
nein, das ist verkehrt herum, sobald unter 98 soll was rauskommen!