NEWS
Auswertung für smartmeter
-
@jhg:Aber an welcher Stelle muss ich nun die Runden Funktion einfügen? `
function haupt (VorId, ZielId, SetN) { var nVorwert = getState(VorId).val; var nAktuell = getState(idESTotal).val; var nDiff = nAktuell - nVorwert; setState(ZielId, runden(nDiff, 1), true); if(debug) log("Aus: " + nAktuell +" - "+ nVorwert + " = " + nDiff); if(SetN) { var shandler = on ({id: ZielId, change: 'any'}, function(data) { setState(VorId, runden(nAktuell, 1), true); unsubscribe(shandler); }); } }
-
Danke sehr.
Hat alles geklappt und die anderen Fehler habe ich auch gleich korrigiert.
-
Hi a200,
danke für das super Skript. Damit Werte ich mein Smartmeter, als auch meine Photovoltaik-Anlage, aus.
Ich wollte ein paar Erweiterungen basteln, allerdings verstehe ich das Skript noch nicht ganz. Vielleicht kannst Du mir die entscheidende Erklärung geben.
Es geht um:
function haupt (VorId, ZielId, SetN) { var nVorwert = getState(VorId).val; var nAktuell = getState(idHAGTotal).val; var nDiff = ((nAktuell * 10) - (nVorwert * 10)) * 100; setState(ZielId, nDiff, true); if(debug) log("Aus: " + nAktuell +" - "+ nVorwert + " = " + nDiff); if(SetN) { var shandler = on ({id: ZielId, change: 'any'}, function(data) { setState(VorId, (nAktuell*10)/10, true); unsubscribe(shandler); }); } }
Warum wird die VorId in dem handler bei Änderung der ZielId gesetzt?
Könnte ich das nicht direkt nach dem setState(ZielId, nDiff, true) machen?
Irgendwie hakt es da bei mir. Wann wird denn der Handler genau ausgeführt? Beim nächsten Aufruf von haupt() über den Scheduler? Dann ist aber der Wert von nVorwert vor dem setState(ZielId, nDiff, true) noch auf dem alten Wert???
Danke schon mal,
Huebeni
-
Hi a200,
danke für das super Skript. Damit Werte ich mein Smartmeter, als auch meine Photovoltaik-Anlage, aus.
Ich wollte ein paar Erweiterungen basteln, allerdings verstehe ich das Skript noch nicht ganz. Vielleicht kannst Du mir die entscheidende Erklärung geben.
Es geht um:
function haupt (VorId, ZielId, SetN) { var nVorwert = getState(VorId).val; var nAktuell = getState(idHAGTotal).val; var nDiff = ((nAktuell * 10) - (nVorwert * 10)) * 100; setState(ZielId, nDiff, true); if(debug) log("Aus: " + nAktuell +" - "+ nVorwert + " = " + nDiff); if(SetN) { var shandler = on ({id: ZielId, change: 'any'}, function(data) { setState(VorId, (nAktuell*10)/10, true); unsubscribe(shandler); }); } }
Warum wird die VorId in dem handler bei Änderung der ZielId gesetzt?
Könnte ich das nicht direkt nach dem setState(ZielId, nDiff, true) machen?
Irgendwie hakt es da bei mir. Wann wird denn der Handler genau ausgeführt? Beim nächsten Aufruf von haupt() über den Scheduler? Dann ist aber der Wert von nVorwert vor dem setState(ZielId, nDiff, true) noch auf dem alten Wert???
Danke schon mal,
Huebeni `
Hi,
@Huebeni:Warum wird die VorId in dem handler bei Änderung der ZielId gesetzt? `
Weil ich den Wert nicht immer schreiben will. Der Wert VorId wird nur dann geschrieben, wenn:- in dem Aufruf der Funktion haupt als dritter Parameter "true" steht (if(SetN))
und
- wenn der Wert, der geschrieben werden soll, sich von dem bereits vorhandenen Wert unterscheidet (id: ZielId, change: 'any').
@Huebeni:
Könnte ich das nicht direkt nach dem setState(ZielId, nDiff, true) machen? `
Wird ja auch prinzipiell gemacht. Mit den o.a. Einschränkungen.
@Huebeni:Wann wird denn der Handler genau ausgeführt? Beim nächsten Aufruf von haupt() über den Scheduler? `
Schau dir mal die Aufrufe von haupt an:schedule(cronH, function () { haupt(idHAGTotH, idHAGZielH, true); haupt(idHAGTotD, idHAGZielT, false); });
Erstmal wird der Stunden-Zwischenwert berechnet und soll auch geschrieben werden. Beim zweiten Aufruf nutzen wir diesen Wert zwar, wir speichern ihn aber nicht neu. Deshalb "false" als 3. Parameter.
Ich hoffe diese Erklärung hilft dir weiter. Falls sie nicht gut genug war und du noch offene Fragen hast, dann melde dich einfach!
a200.
-
Hallo zusammen.
Ich versuche gerade mit dem Skript
! //````
NEU - Zählerstand vom Anfang der akt. Stunde wird ermittelt v 0.11
//
! var AktWoche = true; // Berechnung des Wertes: Aktuelle Woche ein-/ausschalten
var AktMonat = true; // Berechnung des Wertes: Aktueller Monat ein-/ausschalten
var PathToDP = "javascript.0.scriptEnabled.Netzbezug"/scriptEnabled.Netzbezug/; // Pfad zum Datenpunkt
! var cronH = "0 * * * *";
var cronD = "59 23 * * *";
var cronW = "0 0 * * 1";
var cronM = "0 0 1 * *";
! var idHAGTotH = PathToDP + "tmp.Total-h";
var idHAGTotD = PathToDP + "tmp.Total-d";
var idHAGTotW = PathToDP + "tmp.Total-w";
var idHAGTotM = PathToDP + "tmp.Total-m";
var idHAGTotal = PathToDP + "sma-em.0.1900205359.pregardcounter"/pregardcounter/; /Netzbezug insgesammt/
var idHAGZielH = PathToDP + "Hour";
var idHAGZielD = PathToDP + "Day";
var idHAGZielW = PathToDP + "Week";
var idHAGZielM = PathToDP + "Month";
var idHAGZielT = PathToDP + "Today";
var idHAGZielCW = PathToDP + "CurrentWeek";
var idHAGZielCM = PathToDP + "CurrentMonth";
! var debug = false;
! var DPArray = [idHAGTotH, idHAGTotD , idHAGTotW, idHAGTotM, idHAGZielH, idHAGZielD, idHAGZielW, idHAGZielM, idHAGZielT, idHAGZielCW, idHAGZielCM];
var DPUnit = "Wh";
! DPArray.forEach(function(wert, index, array) {
var DPType = wert.split(".");
var DPDescr = "Power consumption of " + (DPType[DPType.length - 1]);if(index > 3) DPUnit = "Wh"; createState(wert, 0, { name: DPDescr, desc: DPDescr, type: 'number', unit: DPUnit, role: 'value' });
});
! function haupt (VorId, ZielId, SetN) {
var nVorwert = getState(VorId).val;
var nAktuell = getState(idHAGTotal).val;
var nDiff = ((nAktuell * 10) - (nVorwert * 10)) * 100;
setState(ZielId, nDiff, true);
if(debug) log("Aus: " + nAktuell +" - "+ nVorwert + " = " + nDiff);
if(SetN) {
var shandler = on ({id: ZielId, change: 'any'}, function(data) {
setState(VorId, (nAktuell*10)/10, true);
unsubscribe(shandler);
});
}
}
! // regelmässige Wiederholungen
// -----------------------------------------------------------------------------
! schedule(cronH, function () {
haupt(idHAGTotH, idHAGZielH, true);
haupt(idHAGTotD, idHAGZielT, false);
if(AktWoche) haupt(idHAGTotW, idHAGZielCW, false);
if(AktMonat) haupt(idHAGTotM, idHAGZielCM, false);
});
! schedule(cronD, function () {
haupt(idHAGTotD, idHAGZielD, true);
});
! schedule(cronW, function () {
haupt(idHAGTotW, idHAGZielW, true);
});
! schedule(cronM, function () {
haupt(idHAGTotM, idHAGZielM, true);
});meinen Netzbezug darzustellen. Ich lesen den Wert pregardcounter (Strombezugszähler) vom SMA Energymeter aus. Aber irgendwie mache ich was falsch. :| [5713_bildschirmfoto_2018-02-07_um_19.06.07.png](/assets/uploads/files/5713_bildschirmfoto_2018-02-07_um_19.06.07.png) [5713_bildschirmfoto_2018-02-07_um_19.04.49.png](/assets/uploads/files/5713_bildschirmfoto_2018-02-07_um_19.04.49.png)
-
Hallo a200
irgendwas ist komisch….
Screenshot 2017-02-13 18.21.32.png
warum ist das eine Minus Zahl? Soll das so sein? oder habe ich was falsch gemacht?
Gruß
Adrian `
aus
var idHAGTotal = PathToDP + "smartmeter.0.1-0:1_8_0*255.value"; /Stromverbrauch insgesammt/
mach
var idHAGTotal = "smartmeter.0.1-0:1_8_0*255.value"; /Stromverbrauch insgesammt/
Ein fataler Fehler! Die aktueller Wert konnte nicht ausgelesen werden! Etwas zu viel Cut&Paste
Kopiere vorher den aktuellen Wert in Total-d und Total-h
Danach sollte es gehen. `
Guten Morgen.
Lösche bitte aus der Variablen "idHAGTotal" den PathToDP + . Siehe obiges Zitat.
Ich würde auch
var PathToDP = "javascript.0.scriptEnabled.Netzbezug"/scriptEnabled.Netzbezug/; // Pfad zum Datenpunkt
in zum Beispiel
var PathToDP = "javascript.0.Stromzaehler.Netzbezug"/Stromzaehler.Netzbezug/; // Pfad zum Datenpunkt
ändern.
-
Super Danke. Jetzt klappt es.
Jetzt sollte ich den rest hinbekommen.
-
Tagesertrag via Modbus vom SMA Wechselrichter
-
Netzbezug vom SMA Energymeter
-
Einspeisung vom SMA Energymeter
Daraus kann ich den Eigenverbrauch und den Gesamtstromverbrauch über ein Skript (besp. Blocky) rechnen
und dies dann auch mit Hilfe dieses Skriptes in Tag, Stunde, Monat, anzeigen bzw. errechnen lassen.
5713_bildschirmfoto_2018-02-08_um_16.35.09.png -
-
Hi crissh.
Das freut mich.
Da du jetzt die notwendigen Daten hast, ist der Rest mit der Darstellung in Vis nur noch Kosmetik.
Gruß
Volker
-
Hallo,
für die Überwachung meiner Wärmepumpe möchte ich mir den Verbrauch je Minute in Watt ausrechnen lassen. Da ich aber mit Scripten noch nie was zu tun hatte wollte ich hier mal an fragen ob mir wer sagen kann was ich z.B. an dem Stunden Script anpassen muss, damit ich den Wert minütlich ausgerechnet bekomme.
-
Hallo,
ich bin der neue hier bei ioBroker und ich weiß, dass der Threat schon etwas älter ist, aber bei mir gerade aktuell.
Vor einer Woche habe ich angfangen mit ioBroker zu experimentieren und bin jetzt schon soweit, dass ich mich frage, wieso ich erst jetzt auf diese Software setze. Mit intensiven Lesen hier im Forum und ausprobieren, habe ich alles Rund um meinen SMA-WR und Discovergy-Zähler hinbekommen. Auch das Skript hier aus dem Threat habe ich endlich zu Laufen gebracht.
Nun gibt es aber doch eine Frage.
Wie man sehen kann, werden Daten von Skript erfasst. Bei der Übergabe von TMP in die Objekte für Tag, Woche, Monat, usw. werden 3 Nachkommastellen ohne Trennung angehängt. Das ist natürlich falsch. Wie bekomme ich die richtige Anzeige hin mit 3 Nachkommastellen? Wo muß ich was eintragen? Kann ich das eventuell in den Objekt-Eigenschaften festlegen oder muß dazu etwas ins Skript eingefügt werden?
Vielen Dank im voraus für eure Hilfe und vielen Dank an die Autoren für dieses tolle Programm/Projekt.
-
Hallo,
ich habe das Skript vergessen, welches ich benutze. Hier ist es:
// NEU - Zählerstand vom Anfang der akt. Stunde wird ermittelt v 0.11 // var AktWoche = true; // Berechnung des Wertes: Aktuelle Woche ein-/ausschalten var AktMonat = true; // Berechnung des Wertes: Aktueller Monat ein-/ausschalten var PathToDP = "javascript.0.Stromzähler.Discovergy."; // Pfad zum Datenpunkt var cronH = "0 * * * *"; var cronD = "59 23 * * *"; var cronW = "0 0 * * 1"; var cronM = "0 0 1 * *"; var idHAGTotH = PathToDP + "tmp.Total-h"; var idHAGTotD = PathToDP + "tmp.Total-d"; var idHAGTotW = PathToDP + "tmp.Total-w"; var idHAGTotM = PathToDP + "tmp.Total-m"; var idHAGTotal = "script.js.Strom.Einspeise-Bezug.Werte.Gesamtverbrauch"; /*Stromverbrauch insgesammt*/ var idHAGZielH = PathToDP + "Stunde"; var idHAGZielD = PathToDP + "Tag"; var idHAGZielW = PathToDP + "Woche"; var idHAGZielM = PathToDP + "Monat"; var idHAGZielT = PathToDP + "Heute"; var idHAGZielCW = PathToDP + "AktuelleWoche"; var idHAGZielCM = PathToDP + "AktuellerMonat"; var debug = false; var DPArray = [idHAGTotH, idHAGTotD , idHAGTotW, idHAGTotM, idHAGZielH, idHAGZielD, idHAGZielW, idHAGZielM, idHAGZielT, idHAGZielCW, idHAGZielCM]; var DPUnit = "Wh"; DPArray.forEach(function(wert, index, array) { var DPType = wert.split("."); var DPDescr = "Stromverbrauch " + (DPType[DPType.length - 1]); if(index > 3) DPUnit = "Wh"; createState(wert, 0, { name: DPDescr, desc: DPDescr, type: 'number', unit: DPUnit, role: 'value' }); }); function haupt (VorId, ZielId, SetN) { var nVorwert = getState(VorId).val; var nAktuell = getState(idHAGTotal).val; var nDiff = ((nAktuell * 10) - (nVorwert * 10)) * 100; setState(ZielId, runden(nDiff, 3), true); if(debug) log("Aus: " + nAktuell +" - "+ nVorwert + " = " + nDiff); if(SetN) { var shandler = on ({id: ZielId, change: 'any'}, function(data) { setState(VorId, (nAktuell*10)/10, true); unsubscribe(shandler); }); } } // regelmässige Wiederholungen // ----------------------------------------------------------------------------- schedule(cronH, function () { haupt(idHAGTotH, idHAGZielH, true); haupt(idHAGTotD, idHAGZielT, false); if(AktWoche) haupt(idHAGTotW, idHAGZielCW, false); if(AktMonat) haupt(idHAGTotM, idHAGZielCM, false); }); schedule(cronD, function () { haupt(idHAGTotD, idHAGZielD, true); }); schedule(cronW, function () { haupt(idHAGTotW, idHAGZielW, true); }); schedule(cronM, function () { haupt(idHAGTotM, idHAGZielM, true); });
-
Hallo,
ich habe das Skript vergessen, welches ich benutze. Hier ist es: `
bist du dir sicher, dass du Nachkommastellen überhaupt hast? Was steht bei dir im Datenpunkt: "script.js.Strom.Einspeise-Bezug.Werte.Gesamtverbrauch"Wenn du immer nur ganze Wh Angaben hast, dann können keine Nachkommastellen entstehen. Schau aber erstmal in dem o.g. Datenpunkt.
a200.
-
Also unter dem Datenpunkt wird mit Nachkommastelle in Watt ausgegeben, aktuell z.b. 1143.5W. In den TMPs des Skripts steht es noch richtig.
Ich habe im Skript gesehen, wenn die Differenz zwischen aktuellen und vorhergehenden Wert berechnet wird, dann werden die jeweilen Werte mit 10 multipliziert und das Ergebnis dann nochmal mit 100. Als Ergebnis gibts dann die Monsterzahlen, die eher mWh entsprechen als Wh. Hier der Ausschnitt des Codes:
var nDiff = ((nAktuell * 10) - (nVorwert * 10)) * 100;
Ist das Absicht so? Mir kommt das komisch vor.
Hier mal ein Ausschnitt von Heute mit den Inhalten der Objekte. Da sieht man, dass sie temporär mit Nachkommastellen richtig als Wh abgelegt werden.
Und hier die Quelle, der Gesamtverbrauch.
Da sind jetzt gerade mal viele Nachkommastellen, aber das Komma ist da.
Vielen Dank für deine Hilfe.
-
Also unter dem Datenpunkt wird mit Nachkommastelle in Watt ausgegeben, aktuell z.b. 1143.5W. In den TMPs des Skripts steht es noch richtig.
Ich habe im Skript gesehen, wenn die Differenz zwischen aktuellen und vorhergehenden Wert berechnet wird, dann werden die jeweilen Werte mit 10 multipliziert und das Ergebnis dann nochmal mit 100. Als Ergebnis gibts dann die Monsterzahlen, die eher mWh entsprechen als Wh. Hier der Ausschnitt des Codes:
var nDiff = ((nAktuell * 10) - (nVorwert * 10)) * 100;
Ist das Absicht so? Mir kommt das komisch vor.
Hier mal ein Ausschnitt von Heute mit den Inhalten der Objekte. Da sieht man, dass sie temporär mit Nachkommastellen richtig als Wh abgelegt werden.
Daten.JPG
Und hier die Quelle, der Gesamtverbrauch.
Gesamtverbrauch.jpg
Da sind jetzt gerade mal viele Nachkommastellen, aber das Komma ist da.
Vielen Dank für deine Hilfe. `
das sollte doch eher.
var nDiff = ((nAktuell * 10) - (nVorwert * 10)) / 10;
heißen. Also durch Zehn und nicht mal Hundert. So steht es wenigstens bei mir drin.
Sauberer sollte es aber so sein:
var nDiff = parseFloat(nAktuell) - parseFloat(nVorwert);
Scheint bis jetzt Niemandem aufgefallen zu sein. Habe ich im ersten Posting korrigiert.
-
Hallo a200,
das mit *100 ist so aus deiner 2. Version, als die Punkte für Aktueller Monat und Aktuelle Woche dazu kamen, etwas weiter unten auf der ersten Seite hier. Da hat sich der Fehler wohl schon eingeschlichen.
Den geänderten Code werde ich gleich übernehmen und berichten. Vielen Dank.
-
Jetzt klappt es, es werden keine mWh mehr berechnet.
Etwas verstehe ich aber noch nicht. Wieso wird in dem Skript eine Differenzberechnung durchgehführt? Was hat ein, sich mit der Zeit aufaddierender Wert mit der Differenz zum Vortag zut un? Aktuell führt das nähmlich bei mir zu negativen Werten Bei der Berechnung für Stromverbrauch Heute und Stromverbrauch Aktuelle Woche.
Nach meinem Verständnis fängt doch jeder neue Tag ab 0 Uhr bei Null an. Also müßte bei jedem Durchlauf des Skripts nach einer Stunde der neue Wert auf den alten aufaddiert werden. Im Skript wird aber immer der Vorwert vom aktuellen Wert abgezogen, was dann eben zu negativen Verbrauchsdaten führen kann. Oder habe ich da jetzt einen Denkfehler drin?
Vielleicht greife ich auch die falschen Daten ab. Das Objekt "Gesamtverbrauch" ergibt sich bei mir aus den Echtzeitverbrauchswerten der PV-Anlage und dem Bezug aus dem Netz. Also Daten, die sich sekündlich ändern. Oder muß ich den Zählerstand als Quelle angeben? Dann würde ich die Differenzberechnung verstehen.
-
Jetzt klappt es, es werden keine mWh mehr berechnet.
Etwas verstehe ich aber noch nicht. Wieso wird in dem Skript eine Differenzberechnung durchgehführt? Was hat ein, sich mit der Zeit aufaddierender Wert mit der Differenz zum Vortag zut un? Aktuell führt das nähmlich bei mir zu negativen Werten Bei der Berechnung für Stromverbrauch Heute und Stromverbrauch Aktuelle Woche.
Nach meinem Verständnis fängt doch jeder neue Tag ab 0 Uhr bei Null an. Also müßte bei jedem Durchlauf des Skripts nach einer Stunde der neue Wert auf den alten aufaddiert werden. Im Skript wird aber immer der Vorwert vom aktuellen Wert abgezogen, was dann eben zu negativen Verbrauchsdaten führen kann. Oder habe ich da jetzt einen Denkfehler drin?
Vielleicht greife ich auch die falschen Daten ab. Das Objekt "Gesamtverbrauch" ergibt sich bei mir aus den Echtzeitverbrauchswerten der PV-Anlage und dem Bezug aus dem Netz. Also Daten, die sich sekündlich ändern. Oder muß ich den Zählerstand als Quelle angeben? Dann würde ich die Differenzberechnung verstehen. `
Dein Datenpunkt idHAGTotal muss auf den Gesamtzählerstand zeigen.
Die Berechnung funktioniert wie folgt:
um 13:00 wird der aktueller Gesamtzählerstand (z.B. 15000 kWh) minus der Zählerstand um 12:00 (z.B. 14800 kWh) berechnet. Das ergibt den Verbrauch der letzten Stunde (200 kWh). Der aktueller Gesamtzählerstand wird wieder in den TMP-H Datenpunkt geschrieben, um um 13:00 wieder die Differenz berechnen zu können.
Also wir ziehen immer vom aktuellen Gesamtzählerstand jeweils den Vorstunden-, Vortag-, Vorwoche-, Vormonatwert abgezogen. Das ergibt den Verbrauch in der letzten Stunde, letzten Tag, Woche und Monat.
Ich hoffe, jetzt ist es etwas klarer
-
Ihr wisst dass es inzwischen dafür einen Adapter gibt?
Ich freue mich über jeden Tester!
Ziel ist ihn nächste Woche aus der Beta zu hohlen
Sent from my iPhone using Tapatalk
-
Dann ist alles klar. Ok, dann werde ich umstellen.
Vielen Dank, a200.
Den Adapter schaue ich mir auch mal an.
-
@Dutchman sagte in Auswertung für smartmeter:
Ihr wisst dass es inzwischen dafür einen Adapter gibt?
Ich freue mich über jeden Tester!
Ziel ist ihn nächste Woche aus der Beta zu hohlen
Sent from my iPhone using Tapatalk
Link funktioniert nicht zu den neuen Adapter oder ist dieser überhaupt nicht realisiert worden ?