NEWS
Adapter "smartmeter"
-
Danke das mit dem Skript bekomme ich bestimmt hin, Dank eurer Hilfe. Werde mich heute gleich dran machen.
Zum zweiten Lesekopf und dessen Einstellungen verstehe ich nun wieder nur Bahnhof :shock:
Also der Sinn ist mir klar aber wo und wie ich das nun wieder machen hmm :?: `
schau mal unter http://wiki.volkszaehler.org/hardware/c … sb-ausgang
Folgendes Kommando ausführen: (ttyUSB0 ist evtl. anzupassen…) /sbin/udevadm info --query=all --name=/dev/ttyUSB0 In der Ausgabe findet sich eine Zeile “E: ID_SERIAL_SHORT=ABC1234”. ABC1234 ist die Seriennummer des USB-Chips. Nun kann man eine Datei “/etc/udev/rules.d/99-lesekopf.conf” mit folgendem Inhalt anlegen: SUBSYSTEM=="tty", ATTRS{product}=="CP2104 USB to UART Bridge Controller", ATTRS{serial}=="ABC1234", NAME="lesekopf0" Ergänzend ist zu erwähnen, dass je nach Linux Distribution die udev-“Rules”-Datei, also z.B. “/etc/udev/rules.d/99-lesekopf.conf” nicht mit “.conf”, sondern mit “.rules” enden muss, damit der udev-Dienst diese Datei auch berücksichtigt. Dies betrifft unter anderem Ubuntu und Debian. Siehe debian-wiki (en). Nach dem die Datei angelegt wurde noch kurz den udev-Dienst neu starten/laden (z.B. “/etc/init.d/udevd reload”) und man kann über /dev/lesekopf0 auf den Lesekopf zugreifen. Egal, welche anderen ttyUSB Geräte es noch gibt :-) Bei Ubuntu 12.10 folgendes: SUBSYSTEM=="tty", ENV{ID_SERIAL_SHORT}=="ABC1234", SYMLINK+="lesekopf0" legt einen sym. Link “/dev/lesekopf0” auf das eigentliche Device an. den udev-Dienst dann mit sudo udevadm trigger die neue Regel anwenden lassen.
hier ist es gut beschrieben
-
Magst du mir mal deine Datei zur Verfügung stellen?
Dann müsste ich nur noch die Daten der Leseköpfe auslesen und einfügen und die Datei wieder an die richtige Stelle einfügen.
Ich muss nochmal sagen, dass das für mich nicht alles so einfach ist. Da geht's schon los wie bekomme ich die Datei auf die Raspberry und muss ich dann irgendwas Neu Starten. Ihr müsst da leider etwas mehr ausholen. Sorry das ich da so nachhaken muss.
-
Ansonsten zu den SIGSECV bzw SIGABRT … ich hab bei mir auch mal weiter getestet und scheinbar haut es beim Speichermanagement in node da irgendwas durcheinander. Ich tippe auf den Garbage-Collecter der beim Freigeben komische Dinge tut. Werde heute Abend mal mit node 7 testen ob es da auch kaputt geht.
Bei mir passiert es meistens mitten im Lesen von Daten.
Interessanterweise tritt es auf meinem Mac mit nem simulierten seriellen Port und getrenntem Senderprozess nicht auf, sondern nur im "Live-Umfeld" mit dem seriellen Lesekopf dran. `
Super das du dran bleibst
-
Ok das hört sich gut an. Auf welche Zeit hast du im Adapter gestellt?
Meinst du, du kannst mir erklären wo ich das Skript einfügen muss und wie ich es in Betrieb bekomme?
Würde dann heute Abend versuchen wollen das Skript in Betrieb zu bekommen.
Wäre dir wirklich sehr dankbar. `
Kein Thema.1. (Falls noch nicht geschehen) javascript Adapter aktivieren
2. (Falls noch nicht geschehen) In der oberen Leiste auf den Bleistift klicken und über Show Javascript-Tab aktivieren
3. Neues Skript erstellen (oben links neues Blatt-Icon) und auf Typ (oben rechts) Javascript ändern.
4. Per cut & paste mein Skript reinkopieren. Namen Vergeben, Speichern.
5. In dem Tab "Objects" gehen und die Stelle finden wo dein smartmeter den Gesamtwert schreibt sollte in etwa so aussehen: "smartmeter.0.1-0:1_8_0*255.value"
6. Falls der Wert bei dir von meinem abweicht, dann die Zeile:
var idHAGTotal = "smartmeter.0.1-0:1_8_0*255.value";
anpassen.
7. Im Tab "Javascript" auf den "play"-Button klicken - Damit wird das Skript aktiv.
Das wars. Zur nächsten vollen Stunde sollten die Datenpunkte unter "javascript.0.Stromzähler.Hager" angelegt werden. Da ein Sinnvoller Wert erst ab den Zweiten Aufruf erzeugt werden kann, wird der korrekter Wert deines Stundenverbrauchs erst nach der nächsten vollen Stunde geschrieben.
Falls du Fragen hast, dann weißt du, wo du mich erreichen kannst! ;D
! ````
// Datenpunkte für die Auswertung des Stromverbrauchsvar cronH = "0 * * * *";
var cronD = "59 23 * * *";
var cronW = "0 0 * * 1";
var cronM = "0 0 1 * *";! var idHAGTotH = "javascript.0.Stromzähler.Hager.tmp.Total-h";
var idHAGTotD = "javascript.0.Stromzähler.Hager.tmp.Total-d";
var idHAGTotW = "javascript.0.Stromzähler.Hager.tmp.Total-w";
var idHAGTotM = "javascript.0.Stromzähler.Hager.tmp.Total-m";
var idHAGTotal = "smartmeter.0.1-0:1_8_0*255.value"; /Stromverbrauch insgesammt/
var idHAGZielH = "javascript.0.Stromzähler.Hager.Hour";
var idHAGZielD = "javascript.0.Stromzähler.Hager.Day";
var idHAGZielW = "javascript.0.Stromzähler.Hager.Week";
var idHAGZielM = "javascript.0.Stromzähler.Hager.Month";
var debug = false;
! var DPArray = [idHAGTotH, idHAGTotD , idHAGTotW, idHAGTotM, idHAGZielH, idHAGZielD, idHAGZielW, idHAGZielM];
var DPUnit = "kWh";
! 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) {
var nVorwert = getState(VorId).val;
var nAktuell = getState(idHAGTotal).val;
var nDiff = ((nAktuell * 10) - (nVorwert * 10)) * 100;
if(nVorwert > 0) setState(ZielId, nDiff, true); // keinen Wert berechnen, wenn der Vorwert 0 ist.
if(debug) log("Aus: " + nAktuell +" - "+ nVorwert + " = " + nDiff);
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);
});
schedule(cronD, function () {
haupt(idHAGTotD, idHAGZielD);
});
schedule(cronW, function () {
haupt(idHAGTotW, idHAGZielW);
});
schedule(cronM, function () {
haupt(idHAGTotM, idHAGZielM);
});
```` `Braucht man jetzt für alle Werte nur ein Script? es waren ja anfangs 4 Stück Hast du das schon so eingestampft? Tolle Leistung. Welches ist denn das aktuelle Script?
Gruß
Adrian
-
Für jeden Zähler ein Skript.
Das macht dann Stunde, Tag, Woche und Monatswerte.
Wenn man also einen Zähler benötigt man das Skript einmal.
-
Braucht man jetzt für alle Werte nur ein Script? es waren ja anfangs 4 Stück Hast du das schon so eingestampft? Tolle Leistung. Welches ist denn das aktuelle Script?
Gruß
Adrian `
Ja, da alle vier Skripte im Prinzip das gleiche tun, habe ich sie zusammengefasst.var cronH = "0 * * * *"; // Stuendlich var cronD = "59 23 * * *"; // Taeglich um 23:59 var cronW = "0 0 * * 1"; // Montags 00:00 var cronM = "0 0 1 * *"; // Am 1\. eines Monats um 00:00 ````Beschreibt wann welche Berechnung durchgeführt wird. Dann wird die Hauptfunktion aufgerufen nur abhängig von der Zeit mit unterschiedlichen IN und OUT Datenpunkten. Die neuste Version hast gequotet! :) @ralalla -Nein! DOCH! Missverständnis! Simpixo redet von 4 Skripten für Stunde/Tag/Woche/Monat, Du von zwei verschiedenen Zählern. Da hast du Recht! Mann sollte die Datenpunkte für die verschiedenen Zähler auch unterschiedlich benennen! ;)
-
So das Skript ist nun drin und läuft wohl. Muss mal warten bis der erste Wert kommt.
Welche Abfragezeit habt ihr jetzt im smartmeter eingestellt? Ist da aller 300s nicht zu lange für das Skript?
Habe mir jetzt einen zweiten Sensor gekauft, da brauche ich bestimmt nochmal Hilfe wegen dem USB einstellen.
-
Hallo allerseits,
ich habe keine Objekte !!??? Ich habe den Smartester in einer Multihost Umgebung installiert, ich hab meinen Haupt Host iobroker und einen mit garage.
unter Instanzen sehe ich das er auf garage installiert wurde, unter Objekte hab ich aber keine Daten ??!! Im Reiter Zustände sehe ich das Daten kommen, aber wo gehen die hin :shock:
Hat jemand eine Idee was ich falsch gemacht hab…..... ??
1342_bildschirmfoto_2017-02-08_um_15.42.11.png
1342_bildschirmfoto_2017-02-08_um_15.42.32.png
1342_bildschirmfoto_2017-02-08_um_15.45.13.png
1342_bildschirmfoto_2017-02-08_um_15.46.16.png
1342_bildschirmfoto_2017-02-08_um_15.46.42.png -
So das Skript ist nun drin und läuft wohl. Muss mal warten bis der erste Wert kommt.
Welche Abfragezeit habt ihr jetzt im smartmeter eingestellt? Ist da aller 300s nicht zu lange für das Skript?
Habe mir jetzt einen zweiten Sensor gekauft, da brauche ich bestimmt nochmal Hilfe wegen dem USB einstellen. `
Gut zu hören. Die Datenpunkte wurden erzeugt?
Ich frage und speichere den aktuellen und den gesammt Wert alle 60sec. Mehr würde, aus meiner Sicht, unnötig Ressourcen fressen. Seltener wäre auch nicht richtig, weil du dann u.U. 5min alte Daten auswertest.
a200.
-
Hallo allerseits,
ich habe keine Objekte !!??? Ich habe den Smartester in einer Multihost Umgebung installiert, ich hab meinen Haupt Host iobroker und einen mit garage.
unter Instanzen sehe ich das er auf garage installiert wurde, unter Objekte hab ich aber keine Daten ??!! Im Reiter Zustände sehe ich das Daten kommen, aber wo gehen die hin :shock:
Hat jemand eine Idee was ich falsch gemacht hab…..... ?? `
Wie oft liest dein smartmeter die werte? Zeig mal seine Konfiguration.
-
Hallo a200
hier noch meine konfgi, ich glaub nicht das es daran liegt , Daten kommen ja , oder?
1342_bildschirmfoto_2017-02-08_um_16.10.48.png -
Hallo a200
hier noch meine konfgi, ich glaub nicht das es daran liegt , Daten kommen ja , oder? `
Werte kommen rein. Sieht man an den Zuständen.
Schau mal in "Objekte" nochmal rein. ggf. Aktualisieren.
-
Habs gefunden…. ich hab mich selber überlistet, im Reiter adapter war der Host garage ausgewählt, im Host iobroker sind die Werte da... , ist mir beim aktualisieren aufgefallen
-
Hm will doch nicht so richtig.
Was mache ich falsch?
-
Hm will doch nicht so richtig.
Was mache ich falsch? `
und? wie sieht es jetzt aus? In der ersten vollen Stunde sollte der Wert von deinem Smartmeter in tmp.Total-h geschrieben werden. In der zweiten sollte der Wert Hour sich geändert haben.
Ist das jetzt so bei dir?
-
Schaut so aus.
Nimmst du dem Aktuellen Verbrauchswert zur Berechnung oder den Gesamtwert?
Weil die Zahlen stimmen nicht.
-
Schaut so aus.
Nimmst du dem Aktuellen Verbrauchswert zur Berechnung oder den Gesamtwert?
Weil die Zahlen stimmen nicht.
IMG_0433.PNG `
was meinst du mit stimmen nicht? Der erster Wert beim Auslesen ist immer Falsch. Erst beim zweiten Mal kann die Differenz zwischen dem aktuellen Verbrauch und tmp.Total-h berechnet und als Stundenverbrauch abspeichern.
Das sieht nicht schlecht aus.
Was steht jetzt drin?
-
Aso dann wirds gehen sorry. Muss nochmal warten weil ich drin rumgespielt habe.
Danke dann war es nur ein Denkfehler. :?
Hab mir einen zweiten Sensor bestellt, hoffe ihr helft mir bei der Einrichtung.
Könnte man noch einen Vortageswert machen? Also Verbrauch die vorletzten 24h.
-
Aso dann wirds gehen sorry. Muss nochmal warten weil ich drin rumgespielt habe.
Danke dann war es nur ein Denkfehler. :?
Hab mir einen zweiten Sensor bestellt, hoffe ihr helft mir bei der Einrichtung.
Könnte man noch einen Vortageswert machen? Also Verbrauch die vorletzten 24h. `
mein script ermittelt auch die Tageswerte. wenn du dann in einem History adapter speicherst, dann kannst du den Verbrauch von von gestern, vorgstern und und und. allerdings erst ab dann, ab wann du deine werte speicherst. -
jetzt habe ich probleme:
host.minime 2017-02-08 20:28:41.731 error instance system.adapter.smartmeter.0 terminated with code 0 (OK) smartmeter.0 2017-02-08 20:28:41.698 info terminating smartmeter.0 2017-02-08 20:28:41.191 warn Exception: Error: Error while parsing SML message: Error: Wrong TL-Field 0x3b for Choice!: Message: 1b1b1b1b0101010176090109521b010900010162003b01012e620001234201770701003307007f01017e535844010000016 smartmeter.0 2017-02-08 20:28:41.186 error at FSReqWrap.wrapper [as oncomplete] (fs.js:576:17) smartmeter.0 2017-02-08 20:28:41.186 error at SerialPort. (/opt/iobroker/node_modules/iobroker.smartmeter/node_modules/smartmeter-obis/node_modules/serialport/lib/serialport.js:306:7) smartmeter.0 2017-02-08 20:28:41.186 error at SerialPort. (/opt/iobroker/node_modules/iobroker.smartmeter/node_modules/smartmeter-obis/node_modules/serialport/lib/serialport.js:293:14) smartmeter.0 2017-02-08 20:28:41.186 error at SerialPort._emitData (/opt/iobroker/node_modules/iobroker.smartmeter/node_modules/smartmeter-obis/node_modules/serialport/lib/serialport.js:313:18) smartmeter.0 2017-02-08 20:28:41.186 error at SerialPort.module.exports.raw (/opt/iobroker/node_modules/iobroker.smartmeter/node_modules/smartmeter-obis/node_modules/serialport/lib/parsers.js:7:13) smartmeter.0 2017-02-08 20:28:41.186 error at SerialPort.emit (events.js:169:7) smartmeter.0 2017-02-08 20:28:41.186 error at emitOne (events.js:77:13) smartmeter.0 2017-02-08 20:28:41.186 error at SerialPort. (/opt/iobroker/node_modules/iobroker.smartmeter/node_modules/smartmeter-obis/lib/transports/SerialResponseTransport.js:52:41) smartmeter.0 2017-02-08 20:28:41.186 error at SmlProtocol.handleMessage (/opt/iobroker/node_modules/iobroker.smartmeter/node_modules/smartmeter-obis/lib/protocols/SmlProtocol.js:48:15) smartmeter.0 2017-02-08 20:28:41.186 error Error: Error while parsing SML message: Error: Wrong TL-Field 0x3b for Choice!: Message: 1b1b1b1b0101010176090109521b010900010162003b01012e620001234201770701003307007f01017e53584401000001622152620952 smartmeter.0 2017-02-08 20:28:41.177 error uncaught exception: Error while parsing SML message: Error: Wrong TL-Field 0x3b for Choice!: Message: 1b1b1b1b0101010176090109521b010900010162003b01012e620001234201770701003307007f01017e5358440100000 smartmeter.0 2017-02-08 20:27:14.519 info starting. Version 0.2.5 in /opt/iobroker/node_modules/iobroker.smartmeter, node: v4.7.3
Error while parsing SML message: Error: Wrong TL-Field 0x3b for Choice!:
was ist das für ein Feld?