-
Notifications
You must be signed in to change notification settings - Fork 7
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Tibber Pulse IR data format (only Germany?) #6
Comments
I got a reply from Tibber today that the ebz DD3 ODZ1 meter is definitely supported. So I hope to see data soon. A firmware update was installed on the Pulse IR today, version 1001-b6715572 |
Hi Johannes, nice to hear that your meter is supported. If you still don't get any data make sure you did not "misconfigure" your pulse by setting it up as "1000 impulse/kWh" with your LED-experiment. Under the node-tab there is a configure-link. Usually it is set to autoprobe. Concerning your issue with not blocking the meter with the pulse this project might be interesting: And this ist what I use to receive the mqtt-data and ingest in home assistant By the way: if someone knows how to decode the SML-MQTT directly in home assistant - pleas leave a note. Regards |
Yes I've set it back to autoprobe |
Any news? |
Stumbled upon this here. I have another variation of a script that pulls data from the bridge via http and publishes decoded values over mqtt. https://github.com/christiankratzer/pulse2mqtt I use this to poll the tibber bridge every 10s for the latest value. I do get the occasional corrupted sml packet from the bridge that I throw away. Also you could poll every second using the http interface but would have frequent collisions with duplicate data. I use the transactionid to dedup. |
Finally got the pulse to like my eBZ :) It has to sit on the top port, the front port doesn't work.
The Tibber app shows my current power consumption. I'll now try to generate the message myself along with the metrics and see how that goes |
The metrics now look like this.
So now meter_pkg_count_recv and meter_reading_count_recv are >0 And the wifi bridge TJH01 sends every 2 minutes:
Here pubcnt > 0 I reckon the various uptimes should also be plausible. They are in 1s resolution. |
I have successfully sent data to tibber! I found the topic you need to send to contains the eui, dc8e95fffeb82bfe in my case. So the full topic is $aws/rules/ingest_tibber_bridge_data/tibber-bridge/xxx/publish/TFD01/dc8e95fffeb82bfe/obis_stream Due to my guerilla solar I have negative power and tibber doesn't like that. But I don't want to modify the meter string. I wonder if the original pulse somehow handles this. It is very unreliable, if it just moves by 1mm the data is already destroyed, i.e. you only get part of the string. UPDATE: never mind this. While in the Apps home screen the data seems to freeze on negative values, they are being correctly recorded in the historic data |
And more updates. After like 15 minutes the joy was over. The data froze and the icon disappeared in the app. I plugged in the original bridge and the icon reappeared. I'm thinking there is some kind of hand shake that I failed to do Update2: it is now running stable since 20h. In one metric I still send "yyy" as id, that was not appreciated ;) |
I have published my code and instructions here: https://github.com/jsphuebner/esp-egycounter/tree/main/battery-control/tibber (tibbersend.py is in parent directory) |
Hi @jsphuebner However whatever I try that script won't connect successfully to tibber's MQTT (double checked all settings). Have you experienced anything like this? Maybe there is an additional check on what the pulse reports to tibber during pairing/first setup? Maybe any additional (hardware) info that is cross-checked? I also tried having the pulse report to my local MQTT but it seems that clearing the ca_cert via console isn't successful and replacing it with my own CA seems to always truncate/garbage the cert value stored on the bridge... I have now built a hardware proxy that is palced between the smartmeter IR interface and the pulse. It is an ESP that reads the IR signal via a photodiode and puts out plain SML via an IR led (which the pulse then receives). At the same time it also decodes SML and reports current power for my own usage. Works but that is not really a elegant solution... |
I never had that issue. I did go through the entire setup procedure in the Tibber app and verified the original pulse was (somewhat) working. Then I switched over to tibbersender Indeed, once you have removed the cert info it is impossible to get it back in (probably by resetting the bridge and starting over). |
Interesting, I tried to connect to tibber's MQTT broker with all the details (CA, Cert, key), client ID. And I don't even get a successful connection with mqtt client (cancels even before any subscription)... |
Who said you can subscribe to the topics on their broker. I assume you can only publish with those credentials. Also you should not have the pulse connected and try to connect at the same time with the same clientId. If people keep messing with their broker without knowing what they are doing this will lead to tibber eventually closing this up for everybody. Just let the pulse submit and consume from the pulses http server. |
@christiankratzer I understand your concern regarding "messing" with the broker. But I also gave tibber that feedback that they should offically support the custom submit of data (without the need of an expensive, battery-operated IR reader) for people that are already getting the data in another way. (like it is possible in Norway i.e). |
Hi @jsphuebner I am struggling as well with my EBZ - ODZ1 as well, I set the INF=ON PIN=OFF via the 4 digit pin. But I get not get the Pulse to work in the front and also not on the top either. I even have the Tibber adapter for the eBZ ... I can see the infrarot light pulsing via my smartphone camera, but the pulse does not read any data. Do you have any tips how you placed the pulse at the top? I even got a replacement hardware already but still not working ... |
It's a long time ago. I think I omitted the mechanical adapter and placed the head on top free-style until it worked. The final missing piece of a software update of the Pulse. Before it didn't seem to support the data format above |
Hi @reinhard-brandstaedter - I'm in a similiar but worse situation, I'd like to use tibber as well but my power meter is locked in a sealed cage by the meter supplier. The last time we had a certified electrician here, he did me a favor and mounted my Hichi Wifi (based on tasmota 12.3.1) onto the IR Port of my DVS7612.2 energy meter and unlocked it via the PIN for me. |
I have sort of misused issue #1 for discussing the pulse data format. The goal is to use your own meter reading setup and "spoof" tibber into thinking you're sending data from the Pulse. This is useful if your meter is not supported by tibber or the port is already blocked by your own reader. Some say the Pulses data rate is not usable for running zero export controllers.
Thought it might be a good idea to recollect this in a new issue.
At first @Kristian-R found you need to empty the encryption keys by nulling the respective parameters, e.g.
param_set ca_cert \
Then we got some messages. The topic pattern is
$aws/rules/ingest_tibber_bridge_data/tibber-bridge/xxx/publish/TJH01/yyy where xxx is a long "Tibber ID" and yyy is the device ID. There are two device IDs, one for the bridge, one for the Pulse IR.
So far we have seen 3 topics:
An event message looks like this:
A metric dump looks like this (Bridge):
or that (Pulse IR):
And finally an impulse message looks like this:
{"$type": "imp_data", "timestamp_ms": 34652489,"delta_ms": 11782,"kw":0.030555, "kwh": 0.8297}
A test run with pulses generated from the actual meter power yielded no display in the app though. Maybe tibber has disabled this method.
So if someone could intercept real data from a meter talking either in the binary SML or the ASCII IEC-62056-21 format that would greatly help in writing a tibber export script
The text was updated successfully, but these errors were encountered: