NEWS
Stromzähler per Sonoff ESP8266 auslesen
-
@Jaschkopf Vielen Dank für die schnelle Antwort. Jetzt verstehe ich auch diese Zeilen. Habe alles geändert. Beim Versuch des Uploads mit "Upload to remote device" ALT+CMD+R gibt es allerdings eine Fehlermeldung: "Platformio failed to run Command: remote" und weiter "Please make sure that "build" Package ist installed and activated.
Im Verzeichnis buid_output/Firmware ist allerdings ein Binary vorhanden mit heutigen Erstellungsdatum:
Keine Ahnung was da läuft.
-
Seltsam. Versuch mal Atom und platformio neu zu installieren. Der Setup von platformio dauert mit unter sehr lange und beim 1. Build werden nochmal Pakete runter geladen.
-
@Jaschkopf Mach ich. Habe das bin jetzt mit FlashESP286.exe geflasht. Hier das Ergebnis:
Das Skript habe ich auch mal so eingestellt. Bei mir arbeitet ein Zähler von der Firma:
Ich hoffe, das passt so mit dem Skript.
Bleibt nur noch ein letztes Problem: Ich habe den Sensor von ELV, da der Volkszähler nicht erhältlich ist. GND und +5V(das braucht wohl der Sensor von ELV) habe ich schon gefunden.
Ich tippe auf Pin6
Bliebe für mich der Anschluss an +5V, GND und RX am ESP?!
-
@RalfTh der Lesekopf den du da hast ist dazu da um Blinkimpulse der s0 Schnittstelle auszuwerten. Damit kann ich dir leider nicht weiter helfen. Ich habe aber noch Volkszähler Bausätze hier liegen falls du Interesse hast. So lange du keine Werte angezeigt bekommst stimmt etwas noch nicht. Du kannst aber in der Konsole die Rohwerte anzeigen lassen. Der Befehl "sensor53 d1" aktiviert die Debug Ausgabe des 1. Zählers.
Gruß Jascha
-
@Jaschkopf Ich habe dir da einen falschen Schaltplan gepostet. Ich habe diesen Bausatz
mit Infrarot Sender und Empfänger.Ich hätte Interesse an einem Bausatz des Volkszählers. Was soll der denn Kosten?
-
@RalfTh Ob der Lesekopf von ELV überhaupt mit einer NodeMCU funktioniert kann ich dir nicht sagen. Hab dazu keinen Schaltplan gefunden. Wegen einem Volkszähler Lesekopf schreib mir doch einfach eine PN.
Gruß Jaschkopf
-
@Jaschkopf
in Deiner Anleitung steht:Zeile 454:
ALT:
NEU: #define USE_SML_Mjedoch in der orig. my_user_config.h steht in Zeile 454:
// #define USE_DISPLAY_ILI9488
// [DisplayModel 8] [I2cDriver38] (Touch)einfach Zeile anfügen oder Zeile ersetzen?
-
@mkrobe Die Zeile muss neu erstellt werden. Bei mir beginnt in Zeile 453 der Bereich "Serial Sensors" mit einem Kommentar. In dem Bereich muss die Zeile eingefügt werden. Je nachdem was vorher in der Datei geändert wird können sich die Zeilennummern verschieben. Bei mir sieht das so aus:
// -- Serial sensors ------------------------------ #define USE_SML_M #define USE_MHZ19 // Add support for MH-Z19 CO2 sensor (+2k code) #define USE_SENSEAIR // Add support for SenseAir K30, K70 and S8 CO2 sensor (+2k3 code) #define CO2_LOW 800 // Below this CO2 value show green light (needs PWM or WS2812 RG(B) led and enable with SetOption18 1) #define CO2_HIGH 1200 // Above this CO2 value show red light (needs PWM or WS2812 RG(B) led and enable with SetOption18 1) #define USE_PMS5003 // Add support for PMS5003 and PMS7003 particle concentration sensor (+1k3 code) //#define PMS_MODEL_PMS3003 // Enable support of PMS3003 instead of PMS5003/PMS7003 (needs the USE_PMS5003 above) #define USE_NOVA_SDS // Add support for SDS011 and SDS021 particle concentration sensor (+1k5 code) #define STARTING_OFFSET 30 // Turn on NovaSDS XX-seconds before tele_period is reached //#define USE_HPMA // Add support for Honeywell HPMA115S0 particle concentration sensor (+1k4) #define USE_SERIAL_BRIDGE // Add support for software Serial Bridge (+0k8 code) //#define USE_MP3_PLAYER // Use of the DFPlayer Mini MP3 Player RB-DFR-562 commands: play, volume and stop #define MP3_VOLUME 10 // Set the startup volume on init, the range can be 0..30(max) //#define USE_AZ7798 // Add support for AZ-Instrument 7798 CO2 datalogger (+1k6 code) //#define USE_PN532_HSU // Add support for PN532 using HSU (Serial) interface (+1k8 code, 140 bytes mem) // #define USE_PN532_CAUSE_EVENTS // Cause event execution for PN532_UID= and PN532_DATA=[if defined] (+ 30 bytes code) // #define USE_PN532_DATA_FUNCTION // Add sensor40 command support for erase, setting data block content (+1k7 code, 388 bytes mem) // #define USE_PN532_DATA_RAW // Allow DATA block to be used by non-alpha-numberic data (+ 80 bytes code, 48 bytes ram) //#define USE_RDM6300 // Add support for RDM6300 125kHz RFID Reader (+0k8) //#define USE_IBEACON // Add support for bluetooth LE passive scan of ibeacon devices (uses HM17 module)
Gruß Jaschkopf
-
@Jaschkopf Der Lesekopf ist montiert. Das Skript hab meines AZ-Delivery D1 mini habe ich folgendermaßen mit dem Volkszähler verbunden:
Gnd, +3,3V und Rxd des Volkszählers an GPIO13(D7) des D1 Mini angeschlossen.
Leider bekomme ich nichts angezeigt.
Die Zeile 2 des Zählers wechselt regelmäßig zwischen den einzelnen, möglichen Ausgabewerten. Mache ich da noch was verkehrt?
-
@RalfTh sagte in Stromzähler per Sonoff ESP8266 auslesen:
@Jaschkopf Der Lesekopf ist montiert. Das Skript hab meines AZ-Delivery D1 mini habe ich folgendermaßen mit dem Volkszähler verbunden:
Gnd, +3,3V und Rxd des Volkszählers an GPIO13(D7) des D1 Mini angeschlossen.
Leider bekomme ich nichts angezeigt.
Die Zeile 2 des Zählers wechselt regelmäßig zwischen den einzelnen, möglichen Ausgabewerten. Mache ich da noch was verkehrt?
Hast du schon ein Skript erstellt? Was für eine Zähler hast du? Ggf muss der mit einem Pin freigeschaltet werden bevor er Daten ausgibt. Oder manche Zähler benötigen eine Startsequenz damit sie Daten senden. Das solltest du noch in Erfahrung bringen.
-
@Jaschkopf Das Skript sieht so aus, wie du es oben beschrieben hast. Ich habe einen Zähler von EMH, Typ HW8E2A5L0EK2P (siehe mein Post vom 22.01.) Das Protokoll ist SML und die Baudrate 9600Bd. PIN habe ich erhalten und eingegeben. Deshalb kann ich ja die Werte in der zweiten Zeile des Zählers abrufen.
-
@RalfTh gib mal "sensor53 d1" in die Konsole ein. Damit aktiviert du das debuging und kannst die rohwerte in der Konsole sehen. Der Zähler sollte seine Daten 1x pro sek ausgeben. Wenn du in der Konsole keine Werte siehst stimmt mit der Hardware etwas nicht.
-
@Jaschkopf Hier das LOG:
-
@RalfTh also außer das alle 10sek die Daten per mqtt gesendet werden passiert da nichts. Ggf sind bei deinem Zähler sende und Empfangs led umgedreht. Prüf das mal mit deiner Handykamera ob dein Zähler überhaupt Daten ausgibt und wenn ja auf welcher Seite. Ich muss meine Lesekopf auch um 180° verdreht aufsetzen (Kabel nach oben) damit er funktioniert.
-
@Jaschkopf OK, danke.Ich werde das morgen mal probieren. Bei mir ist links der Lichtsensoreingang und rechts die Datenschnittstelle. Habe dazu ein Bild meines Energieversorgers erhalten.
-
@RalfTh ich meine bei mir ist die Schnittstelle genauso angeordnet. Probier mal den Lesekopf um 180° mit dem Kabel nach oben aufzusetzen
-
@RalfTh mir ist gerade noch was eingefallen. Wenn du das Skript 1:1 übernommen hast, muss RXD auf Pin 13 liegen. Du bist aber auf GPIO13, was Pin 7 entspricht. Einen Pin 13 hat der D1 ja garnicht. Versuch mal im Skript in Sektion >M die Zeile für die Zählerdefinition zu ändern auf Pin 7:
>M +1,7,s,1,9600,SML
PS: Wenn du das Debugging mit "sensor53 d1" aktiviert hast wird die Werteausgabe über das Webinterface gestoppt. Wenn du auf der Startseite wieder Werte haben willst musst du entweder den D1 neustarten oder mit "sendor53 d0" das Debugging wieder ausschalten.
Gruß Jaschkopf
-
@Jaschkopf Oh, das hatte ich übersehen, bzw. falsch interpretiert. Ist schon ein bisschen verwirrend mit den PINs und deren Bezeichnung. Habe jetzt das Skript hier geändert.
Jetzt lässt es sich nicht mehr aktivieren??!!
Muss ich das Ganze jetzt noch mal in Atom.io machen? Das kann doch eigentlich nicht sein.!? -
@RalfTh Ok jetzt hab ich mich selbst verwirrt. D7 am D1 war schon richtig als GPIO13 im Skript. Musste selbst nochmal nachschlagen gerade.
Aber das sich dein Skript immer wieder deaktiviert ist nicht richtig. Ich hatte den Fall bei mir auch mal und musste die Firmware neu flashen. Scheint ein Bug zu sein. Vergiss nur nicht den CFG_HOLDER zu verändern bevor du neu compilierst, wie in der Anleitung beschrieben.
Gruß Jaschkopf
-
Kann mir jemand sagen wo das problem bei mir liegt?
19:57:34 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:34","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0xD87B604E"}} 19:57:35 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:35","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0x70E7939E"}} 19:57:36 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:36","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0xDDE94BCF"}} 19:57:37 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:37","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0x49A6AF84"}} 19:57:37 RSL: tele/tasmota/STATE = {"Time":"2020-02-06T19:57:37","Uptime":"0T00:29:07","UptimeSec":1747,"Heap":24,"SleepMode":"Dynamic","Sleep":50,"LoadAvg":19,"MqttCount":0,"Wifi":{"AP":2,"SSId":"FRITZ!Box 7590 CJ","BSSId":","Channel":1,"RSSI":100,"Signal":-47,"LinkCount":1,"Downtime":"0T00:00:06"}} 19:57:37 RSL: tele/tasmota/SENSOR = {"Time":"2020-02-06T19:57:37","OBIS":{"Total_in":0.0000,"Total_out":0.0000,"Power_curr":0,"Meter_number":""}} 19:57:38 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:38","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0x41150F2B"}} 19:57:39 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:39","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0x70E7939E"}} 19:57:40 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:40","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0xCE7EA1E4"}} 19:57:41 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:41","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0x4A92522B"}} 19:57:42 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:42","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0x41150F2B"}} 19:57:43 RSL: tele/tasmota/RESULT = {"Time":"2020-02-06T19:57:43","IrReceived":{"Protocol":"UNKNOWN","Bits":50,"Hash":"0x29724952"}}
bekomme zwar daten gelesen aber werden nicht umgewandelt?
Zähler(MT691) ist freigeschaltet
20:01:37 CMD: sensor53 d1 20:01:37 RSL: stat/tasmota/RESULT = {"Time":"2020-02-06T20:01:37","SML":{"CMD":"dump: 1"}}