FAQ
How to Hardware Reset EMS-ESP?~
If you have a GPIO Button configured (enabled by default on all BBQKees boards) pressing this has different actions:
- single press: does nothing
- double press: re-connects the WiFi
- hold for 10 seconds: performs a factory reset. EMS-ESP will restart in Access Point mode
What is an EMS Telegrams?~
Written by @MichaelDvP in this article:
Best overview of known telegrams is from Norberts1 and the EMS-Wiki. In general we can say:
- measurement values are broadcasted periodical 10 sec / 1 min
- settings are only broadcasted after a change
- changing a setting of a device via the UI of thermostat results in a message thermostat -w-> device with only this value
- some devices broadcast fast changing values as single values
- measured temperatures are normally 2 bytes (SHORT) with factor 0.1 (e.g. 01 23 -> 0x0123 -> dez 291 -> 29.1°C)
- air temperature settings are often factor 0.5 as single byte (INT) (e.g. 0x2D -> dez 45 -> 22.5°C)
- water temperature settings are typically single byte (UINT) (e.g. 0x3C -> 60°C), differential values (hysteresis in Kelvin) are signed (INT)
- percent settings are single byte (UINT) (0x64 -> 100%)
- on/off states or settings can be single byte with on/off 0xFF/0x00, or 0x01/0x00 or a single bit in a byte together with 7 other states
- times and energy is typically 3 or 4 bytes with or without factor
For different brands/devices Bosch sometimes use different expressions for the same value, Maybe changing developers or they like to make reverse engineering difficult!
If you search a setting, log the telegrams for the device (log all or watch
Can EMS-ESP simulate a Thermostat?~
Partially. As the folks over at OpenTherm Gateway (OTGW) nicely put it:
Why use a Thermostat?
- The thermostat manufacturers have spent years of research to work out the heating characteristics for the most efficient and comfortable way to heat a house.
- The thermostat provides a control interface that people are familiar with, so other members of the household are still able to adjust the setpoint.
- It provides convenient housing for the room temperature sensor, which is needed unless you use a heating curve based solely on the outside temperature.
As MichaelDvP points out "a thermostat is a clever electronic device. You can put in the desired room temperature and it calculates from some parameters and measurements the required flowtemp for this room temperature and sends it to the boiler. This happens in a control loop and is updated often."
And mtc716 said "A thermostat creates a heat curve that is constantly adapted to the surrounding temperatures and used to estimate which water temperature is necessary in order to bring the room temperature up. There are some good articles in the net about how to setup the heat curve correctly. The main parameters you need are "design temp" which is the heating water temp at minimal outside temp. Furthermore you need the "comfort temp" like explained before and the "temp offset" which causes a parallel shift in the heating curve."
See this article on changing the boiler heating directly, and these issues: Smart control a heating system with HA? and thermostat emulation.
What are Bus protocols and Tx modes?~
Protocol and timing are different things, you pick the tx-mode that works best.
HT3 is the Junkers electronic and HT3 protocol is the same as EMS, only in first byte (sender) the highest bit is set. Each telegram we send starts with 0B in a Buderus system, but with 8B in Junkers. This makes the devices of the different brands incompatible. EMS-ESP checks the bus on start and select the right protocol automatically. Also Junkers uses different telegram numbers/orders. Bosch labeled modules uses the same telegram numbers as Buderus, but addressing like Junkers, so also incompatible. You can't connect Junkers or Buderus modules to a Bosch heating system.
Tx-mode is the send timing: The client devices send by current modulation, the master by voltage modulation. This allows full duplex (Hardware mode), but depending on line impedance drawing current also influences the voltage. When sending, the master repeats every byte sent by the device to publish it to the other devices. With a Tx-mode of "EMS" we wait for the master byte before sending the next. The older Junkers seems to have a lower timeout so we need to start the next byte before the master echo is completed ("HT3"). "EMS+" is less critical and we can wait a bit longer than one byte to allow voltage to be stabilized after the sending.
Can you run multiple instances of EMS-ESP?~
Yes you can. Keep in mind the following settings:
- (Settings->MQTT Settings) MQTT
Entity ID format
is set to "Multiple instances, short name" - (Settings->MQTT Settings) MQTT
Client ID
must be unique to avoid conflicts in the MQTT broker - (Settings->MQTT Settings) MQTT
Base
is unique (just be sure). Usually set this to the hostname. - (Settings->Network Settings)
Hostname
is unique, to avoid network conflicts - (Settings->Application Settings)
EMS BUS ID
are different (not both 0x0B)