NEWS
[Gelöst]Batteriespeichersimulation mit AMIS-Daten in Blockly
-
ich kann mich da schwer rein denken, hilf mir mal...
wenn das hier
z.B. in dem DP das hier stünde (-100W)
dann müßte da was rauskommen ?
Das hier ?
-
Im Grunde ist es ganz einfach, wie ein Batteriespeicher funktioniert, ich erkläre dies gerne anhand eines Sparbuches.
Funktioniert genauso wie ein Sparbuch wo es Ein- und Auszahlungen gibt. Zusätzlich kommt noch dazu, dass man für die Einzahlungen- u. Auszahlungen in das und aus dem Sparbuch Spesen verrechnet bekommt. In der Realität Negativzinsen u. Bankspesen.
Die Spesen entsprechen den Be- und Entladeverlusten von ca. je 10 %.Beispiel Beladung:
Das Sparbuch=Speicherstand wird immer in kWh, noch besser in Wh (1 kWh=1.000 Wh) gerechnet, aber mit positiven Werten, da der Saldo des Speichers oder Sparbuchs nie ins minus rutschen kann. Entnehmen kann ich nur das, was ich vorher eingelegt (angespart) habe.Der DP SUMME_170_270_- = EINSPEISUNG in das NETZ liefert aktuell -400 W.
Diesen Leistungswert (Überschuss aus der PV-Anlage) mit -400 W kann ich nur mit 90 % in den Speicher einlegen, da ich Beladeverluste in Höhe von 10 % habe, ergibt -360 W. Bruttoladeleistung in W x 0,9 = Nettoladeleistung in W.
Weiters muss ich diese Netto-Ladeleistung noch vorher in Wh umrechnen, da dieser Leistungswert nur für 2 Sekunden zur Verfügung steht. D. h. 360 W Netto-Lade-Leistung / 3600 Sek. / 2 = entspricht 0,05 Wh Einlage/Beladung in den Speicher für die 2 Sekunden. Ein realer Speicher funktioniert genauso.
In den nächsten 2 Sekunden liefert der DP SUMME_170_270_- z. B. 1000 W Überschuss, da z. B. die Solarstrahlung so stark ansteigt. Berechnung erfolgt gleich wie vorhin mit -400 W. -1000 W x 0,9 = (-900 W x -1) -20 = 890 Netto-Ladeleistung und Umrechnung in Wh, 890/3600/2=0,1236 Wh.Ich multipliziere den Minus-Wert deshalb mit -1, da ich anschließend die positive Zahl leicht zum bestehenden Speicher-Saldo (+) am Speicher (Sparbuch) hinzuaddieren kann.
Der Wert mit -20 (W) soll Kleinladeleistungen bei der Vergleichsfunktion von vornherein unterbinden, gilt auch für die Entladung.Beispiel Entladung: Funktioniert vollkommen gleich, nur mit anderen Vorzeichen.
Der DP SUMME_170_270_+ = BEZUG aus dem NETZ liefert z. B. aktuell + 400 W.
Hier würde ich nicht aus dem Netz beziehen, sondern auf das angesparte Speicherguthaben (Sparbuch) zugreifen, falls vorhanden und hier auch mit Vorzeichendrehung den postiven Wert mit -1 multiplizieren, damit ich diesen Netto-Entnahme-Entladewert als Minuswert zum Speichersaldo hinzuaddieren kann. 5000 Wh Speichersaldo - 10 Wh Entladung = 4.990 Wh Speichersaldo.Folgende Datenpunkte benötige ich auch, damit ich den kumulierten Saldo Be- und Entladung in den Speicher visualisieren kann. Beispiel: Summe Beladungen 1.1.-31.1. = 80.000 Wh, Summe Entladungen: 75.000 Wh.
Hoffe, dass ich dich mit meinen Erläuterungen nicht zu viel verwirrt habe.
Danke
-
Sorry, habe alles wunderbar erläutert, aber anschließend wurde ich vom Internet getrennt.
Hat doch funktioniert. -
Mit diesem Blockly schreibt er mit zumindest mal die Ladeleistung BELADEN_W in den DP.
Aber das war es auch schon.
Nur stimmt das Ergebnis mit (Ladeleistung * -1) -20 W nicht ?
Hier habe ich ein Syntaxproblem.Ich kann die Berechnung auch auf 5 Sek. ändern.
-
@goetschhofer
Und jetzt beantwortest Du bitte noch meine Frage von hier -
@dslraser said in Batteriespeichersimulation mit AMIS-Daten in Blockly:
@goetschhofer
Und jetzt beantwortest Du bitte noch meine Frage von hierSorry, das habe ich überlesen.
dann müßte da was rauskommen ?
Das hier ? Ja, korrekt 80 W.
Beladung:
(-100 W x -1)-20 W = 80 W. -
Ich habe mal das hier "versucht" (aber ich habe ja keine Daten die dafür kommen) Der andere Teil, der noch fehlt, wäre ja der gleiche Weg.
Du kannst das Blockly ja mal importieren und ausführen. Zum testen kannst Du die DP ja auf javascript.0 probieren (ist im Blockly schon eingestellt)
-
-
-
@goetschhofer sagte in Batteriespeichersimulation mit AMIS-Daten in Blockly:
Ich glaube du hast die falsche Datei angehängt.
Im Inhalt geht es um Pumpen.sorry, ja war die falsche Datei. Ich habe es eben ausgetauscht.
-
Kein Problem, danke.
Wie schafft man es denn, dass man so eine verschachtelte Funktion bastelt ?
-
@goetschhofer sagte in Batteriespeichersimulation mit AMIS-Daten in Blockly:
Wie schafft man es denn, dass man so eine verschachtelte Funktion bastelt ?
Quasi Deine "Excel Formel" von "innen nach aussen", immer einen Mathe Baustein mit + oder - oder × oder ÷ usw....dazu.
Kannst ja mal die Bausteine auseinander nehmen, ich weiß nicht wie ich es besser beschreiben kann.Aber, ist die Berechnung so von Dir gemeint, also passt das so ?
-
@dslraser said in Batteriespeichersimulation mit AMIS-Daten in Blockly:
@goetschhofer sagte in Batteriespeichersimulation mit AMIS-Daten in Blockly:
Wie schafft man es denn, dass man so eine verschachtelte Funktion bastelt ?
Quasi Deine "Excel Formel" von "innen nach aussen", immer einen Mathe Baustein mit + oder - oder × oder ÷ usw....dazu.
Kannst ja mal die Bausteine auseinander nehmen, ich weiß nicht wie ich es besser beschreiben kann.Aber, ist die Berechnung so von Dir gemeint, also passt das so ?
O.k. dann glaube ich, dass ich klar komme, den Entscheidende Hinweis ist von von "innen nach aussen".
Ja, die Berechnung passt meines Erachtens auf jeden Fall. -
Das mit dem Zerlegen der Bausteine, war ein guter Tipp, so verstehe ich die Logik besser.
Danke:
-
Wie kriege ich denn hier den Datenpunkt hinein ?
Bei mir schaut dies so aus, wenn ich auf Objekt-ID klicke komme ich nicht zum Datenpunkt ?
-
@goetschhofer sagte in Batteriespeichersimulation mit AMIS-Daten in Blockly:
Wie kriege ich denn hier den Datenpunkt hinein ?
In meinem Blockly ist das schon der Datenpunkt. Die Datenpunkte werden hier (in meinem Blockly) "variabel" ermittelt und zusammengebaut.
Daraus
und daraus
und daraus
und aus dem hier entsteht der Bezug zum Datenpunkt.
das ist dann die ID in den Datenpunkten
javascript.0.BATTERIE_SPEICHER.BELADEN_W
Das ist dann dieser Datenpunkt
Bei mir schaut dies so aus, wenn ich auf Objekt-ID klicke komme ich nicht zum Datenpunkt ?
Lösche den roten Objekt ID Baustein und dann klicke darunter rein.
(dann verwendest Du mein Blockly nicht, sondern ein anderes ? Deshalb fragte ich welches Blockly Du verwendest) -
Ja, davor habe ich mächtig Angst, dass ich mir meine AMIS-Datenpunkte demoliere, denn diese funktionieren bis jetzt einwandfrei.
Ich werde deine Berechnung bis morgen in mein Blockly einbauen, nachbasteln und würde mich morgen wieder melden.
Danke einstweilen.
-
Du hast mir so eine tolle Vorlage geliefert, dass ich dies relativ einfach, aber doch mit einer grossen Herausforderung in mein Blockly einbauen konnte.
Nochmals vielen Dank für deine Hilfestellung.
Mit dem Tipp die Mathematik-Formel von innen nach außen zu bauen, hast du mir ein ein großes Tor an Möglichkeiten aufgemacht.
Ich komme aus der Excel-Welt und da sehe ich hier sehr viele Möglichkeiten.
Macht echt Spaß !Um die Richtigkeit der Werte auch rechnerisch nachvollziehen zu können, habe ich den Be- und Entladefaktor mal auf 1 belassen u. den Abzug für Minimalwerte von 20 auf null, Bei Be- und Entladung, gestellt.
Wenn ich hier im Blockly noch etwas einfacher, effizienter, in der Programmierung machen könnte, bitte ich dich dies mir mitzuteilen. Ich habe halt versucht als Anfänger zu einer Lösung zu kommen.
Die BAT_SIMU_1 wird ja noch um 2 Facetten komplexer bei der Abfrage der Be- und Entladeleistung und des Speicherstandes.
2 Punkte muss ich in der Abfrage noch einbauen.
- Ein Batteriespeicher hat eine maximale Be- und Entladeleistung z. B. von 3.000 W, d. h. wäre der Überschuss 3.200 W, kann nur mit 3.000 W beladen werden.
- Wie bereits erwähnt kann man aus einem Batteriespeicher nur etwas entnehmen, wenn der Speicherstand >0 Wh ist und weiters kann man nur beladen, wenn die maximale Speicherkapazität z. B. 5 kWh=5.000 Wh nicht überschritten ist.
BLOCKLY_BAT_SMU_19.9.2021-11h50.txt
-
Ich komme aus der Excel-Welt und da sehe ich hier sehr viele Möglichkeiten.
Vor Jahren hatte ich damit auch zu tun. Angefangen von sehr komplexen Formeln und Makros in Visual Basic, aber aktuell habe ich damit lange nichts gemacht. Ich hatte mir damit automatische Abfragen aus unserem Großrechnersystem/Host (über IBM PICOMM) gebaut. Das lief so gut, das ich das morgens einfach gestartet habe, dann habe ich mir einen Kaffee gemacht und wenn ich wieder kam war die Tabelle fertig
. Ohne Diese Abfrage dauerte das (auch bei meinen Kollegen) meistens mehrere Stunden um die Tabelle händisch zu erstellen.
-
Ja, wenn man etwas Gehirnschmalz reinsteckt, kann man sich das Leben oft sehr erleichtern, vor allem bei Routinetätigkeiten.
Ich brüte gerade bei der Abfrage max. Be- und Entladeleistung z. B. 2.500 W.
Könnte man beim 2. falls bereits auf den geschriebenen DP Beladen_W zurückgreifen, denn dann bräuchte ich nicht nochmals eine >0 <= 2.500 W Abfrage ? Oder ist dies nicht möglich ?
Danke