===== MQTT 2R-Stromzähler (Zweirichtung) / Verbrauchsmessung eines Ferraris-Stromzählers ===== In einigen Haushalten findet sich noch ein Ferraris-Stromzählers, welcher bei verwendung eines Balkonkraftwerkes oder eine Mini-PV-Analage auch mal rückwärts laufen kann.\\ Dies führt in der Regel zu einer Verfälschung der Verbrauchsanzeige. Dieser 2R-Stromzähler hat zwei Sensoren und kann durch das intelligente Script erkennen, in welche Richtung der Zähler dreht.\\ Bitte beachten, dass hier ein anlaloges Zählwerk in eine digetale Anzeige mit Hilfe von IR-Sonsoren gewandelt wird. Es kann immer mal zu Abweichungen kommen. Bedeutet, dass man gelegntlich den Wert des Zählerstandes auch mal anpassen muss.\\ \\ \\ {{:public:verdrathung.jpg?400|}} === Grundeinstellungen === Folgende Grundeinstellungen sind bereit bei Auslieferung vorgenommen.\\ **TelePeriod** = Intervall für das Senden von MQTT-Nachrichten\\ **CounterDebounce** = Zeit in Millisekunden, die vergehen müssen, um ein Prellen der Sensoren zu verhindern.\\ TelePeriod 60 CounterDebounce 600 === Konsolen Script === In folgenden, auf dem Zähler bereits vorhandenen Script (Konsolen > Script konfigurieren) sind folgende Variablenwerte anzupassen.\\ Und zwar die Zählerkonstante (zk), welche am Stromzähler aufgedruckt und mit der Einheit (U/kWh) angegegben ist und die Mindestumlaufzeit (mu) der Aluminium-Drehscheibe.\\ - zk (Zählerkonstante) - mu (Mindest Umlaufzeit der Scheibe) - latitude - longitude \\ Für **zk** ist standardmäßig ein Wert von 75 U/kWh hinterlegt. Bitte diesen Wert mit der Angabe auf dem eigenen Stromzähler abgleichen.\\ Für **mu** ist ein Standardwert von 10 Sekunden voreingestellt.\\ Für **latitude** Ist der Breitengrad des Standortes anzugeben.\\ Für **longitude** Ist der Längengrad des Standortes anzugeben.\\ \\ Der Wert für mu kann zunächst beibehalten werden. Wer eine genauere Einstellung wünscht, kann einen oder mehrere starke Verbraucher (z. B. Wasserkocher, Föhn) einschalten und mit einer Stoppuhr messen, wie viele Sekunden die Aluminium-Drehscheibe für eine vollständige Umdrehung benötigt. Dieser gemessene Wert – oder etwas weniger – sollte dann als mu verwendet werden.\\ :!: Hinweis: Danach unbedingt prüfen, ob der Wert für CounterDebounce noch passend ist.\\ Der Wert **mu** beeinflusst maßgeblich die Berechnung der aktuellen Leistung und die Erkennung der Zählrichtung (vorwärts oder rückwärts). Dennoch kann der voreingestellte Wert mu = 10 für den Anfang problemlos verwendet werden.\\ >D p:zs=0 p:s1=0 p:total=0 p:e2=0 p:e3=0 fl1=0 fl2=0 rt="unbekannt" ph="unbekannt" c1=0 c2=0 c1old=0 c2old=0 c1ts=0 c2ts=0 c1tsold=0 c2tsold=0 zk=75 mu=12 hr=0 dy=0 sec=0 power=0 h1=0 e1=0 >B =>sensor53 l255 latitude 50.0555 longitude 8.8008 >F h1=zs-s1 e1=h1/(2*zk) if sunrise>0 and sunset>0 and time>sunrise and time(c1ts+mu) then fl1=0 endif if fl2==1 and upsecs>(c2ts+mu) then fl2=0 endif // links if c1!=c1old then c1ts=upsecs if fl2==1 and time>sunrise and timec1old and upsecs>(c1tsold+mu) then c1ts=upsecs sec=c1ts-c1tsold if sec>0 then power=3600000/(sec*zk) else power=0 endif c1tsold=c1ts endif if c1ts>(c1tsold+540) then sec=c1ts-c1tsold power=0 else endif c1old=c1 c2old=c2 ' Historische Werte hr=hours dy=day if chg[hr]>0 and hr==0 and min==0 and sec<2 then s1=zs e3=e2 e2=e1 svars endif ' MQTT if upsecs%tper==0{ =>Publish tele/%topic%/main/energytotal %total% =>Publish tele/%topic%/main/actpower %0power% =>Publish tele/%topic%/main/today_kwh %2e1% =>Publish tele/%topic%/main/yd_kwh %2e2% =>Publish tele/%topic%/main/dbyd_kwh %2e3% =>Publish tele/%topic%/json {"energytotal": "%total%", "actpower": "%0power%", "today_kwh": "%2e1%", "yd_kwh": "%2e2%", "dbyd_kwh": "%2e3%",} } >T c1=Counter#C1 c2=Counter#C2 total=zs/zk >W ZS: {m} %0zs% Zählerstand: {m} %total% kWh Richtung: {m} %rt% Leistung: {m} %0power% W Sensor L: {m} %0fl1% Sensor R: {m} %0fl2% Phase : {m} %ph% ========= Verbrauch: Heute : {m} %2e1% kWh Gestern : {m} %2e2% kWh Vorgestern: {m} %2e3% kWh === Zählerstand einstellen === Der auf dem Stromzähler bereits erfasste Zählerstand wird folgendermaßen in TASMOTA per Konsole übertragen:\\ Kommando: **script >zs= (ZS x ZK)**\\ Die Berechnung richtet sich nach der im Skript definierten Zählerkonstante (zk), die angibt, wie viele Zählerumdrehungen einer verbrauchten Kilowattstunde entsprechen.\\ \\ //ZS = Zählerstand (kWh)//\\ //ZK = Zählerkonstante (U/kWh)//\\ \\ Beispiel: 44717,3 kWH * 75 script >zs=3353797,5