Tip
If compiling the source code is too difficult for you, I can provide you a custom firmware
that is easy to install from a web page. You can contact me privately on the DIY solar forum.
ESPHome application to monitor BMS and communicate with inverters supporting CAN bus protocol compatible with Pylontech, GoodWe, SMA, Victron or Luxpower (EG4). |
|
---|---|
Note: Pylontech uses 15S/48V and many others uses 16S/51.2V ! Other battery profiles that utilise the PYLON protocol with different cell countsmay also work, e.g. Alpha Ess Smile, BYD Battery-Box LV Flex Lite. Select the correct battery profile in the inverter to match your battery pack ! The ESP32 communicates with the BMS using the BLE / UART / RS485 protocol and then sends the CAN bus frames to the inverter via the CAN bus transceiver. |
Sends over CAN bus to inverter:
- Battery Voltage
- Battery Current (+charge, -discharge)
- State of Charge (SoC)
SoC 100% will be sent to your inverter only when the battery is fully charged
- State of Health (SoH)
- Max cell V. and ID
- Min cell V. and ID
- BMS temperature
- Charging voltage
- Charging max amps
- Discharge min voltage
- Discharge max amps
- Battery name
- Alarms: Cell over/under voltage, Charge/discharge over current, High/low Temp, BMS fault
Note: this code support multi-BMS
and multi-shunt
connection per inverter with a single ESP32
and should work with inverters that support the CAN bus protocol PYLON
, SMA
, Victron
or LuxPower
(EG4). I'm only testing it with my Deye SUN-6K-SG03-LP1-EU
inverter.
This project is still in development and testing...
Dedicated topic on DIY Solar Forum
You install YamBMS
on a single ESP32 connected to your BMS and your inverter.
- Max 3x BMS BLE
- Max 3X BMS UART
- several RS485 BMS on the same bus
Each BMS/Shunt turns into a modbus server
with its own address.
Important
The max number of UART
BMS/Shunt per ESP32 is 2
(unless you use a UART expander) because you need to keep the last UART
for the RS485
network.
The max number of BLE
BMS/Shunt per ESP32 is 2
, ESP32-S3 / AtomS3 can supervise 3
BLE devices.
YamBMS installs on node1
as a modbus client
to collect information from all your BMS.
The node1
is also connected to your inverter via the CAN bus
.
The BMS/Shunt are connected to other ESP32 nodes connected on a dedicated RS485 bus for YamBMS. Each BMS/Shunt becomes a modbus server
.
The theoretical limit is 256
modbus server (BMS/Shunt) per RS485 bus
but in reality this will depend on the capabilities of node1
(YamBMS) which will have to combine all the BMS/Shunt together.
You can find more information about creating your YAML in this How To.
Tip
If you have a lot of BMS/Shunt
to combine, using an ESP32-S3
or AtomS3
for node1
is recommended.
- Supported devices
- YamBMS behavior
- YamBMS functions
- Charging logic
- CAN bus protocol
- Schematic and setup instructions
- How to create your YamBMS YAML
- Installation procedure
- Troubleshooting
You can simply test the application with a generic ESP32
without compiling and connecting anything on your ESP32.
The DEMO firmware is composed of 3x BMS
and 1x Shunt
(fake) for a 48V LFP
system.
Important
YamBMS_DEMO_ESP32.factory.bin
is intended for a generic ESP32, does not work with ESP32-S3.
If you want to test YamBMS DEMO
with another board you need to compile the firmware with the multi-bms_DEMO.yaml
.
- Download YamBMS_DEMO_ESP32.factory.bin
- Follow the procedure explained in this document.
If you want to add a CAN transceiver
on this DEMO board
here are the GPIOs to connect it to :
tx_pin: 23 # to CAN board CTX
rx_pin: 22 # to CAN board CRX (with 4.7K resistor except for SN65HVD230)
- ESPHome 2024.6.0 or higher
- ESP32 MCU (buying a board with ≥8MB flash is advised if you intend to monitor multiple BMS)
- CAN transceiver (only with TJA1050/TJA1051 => 4.7K resistor for 5V to 3V3 level shifing)
- BMS JK, JBD, Seplos (other BMS brands already integrated with ESPhome can be added easily)
- Inverters supporting CAN PYLON/GoodWe/SMA/Victron Low Voltage protocol
- Optional: 48V to 5V DC-DC converter to power the ESP32 from the JK-BMS VBAT pin (URB4805YMD-10WR3 or VRB4805S-6WR3)
- Optional: JK RS485 adaptor and RS485 to TTL 3V3 adaptor (see schematic section)
- YamBMS 1.5.3 :
- Broadcasting JK-PB settings to all BMS set to OFF by default
- Reorganizing the
board
folder and YAMLs (device_base.yaml moved to board.yaml) device_base.yaml
should no longer be part ofYamBMS_main.yaml
- New
RGB LED status
light effects (red, green, blue, cyan) as anoptions
packages forboard.yaml
- Increased CPU frequency to
240Mhz
as anoptions
packages forboard.yaml
- Added
ESP32 Generic
,LilyGo T-CAN485
,LilyGo T-Connect
andXIAO
boards - Fixed SoC logic (low SoC will be detected at BMS level and no longer at YamBMS level)
- Simplified combination logic (removal of the combine switch) + dashboard update
- Check
Battery Capacity
is> 0
before combining info (see issue #14) - Improved alarm logic with a common
YamBMS errors bitmask
for all BMS models (see OTP vs UTP bug reported by @ChrisG) - Added PR #7547 regarding publishing entities via the API
- Removed
captive_portal
because it increases theloop time
too much PSRAM
will no longer be enabled by default as this has a bad impact onBLE BMS
- YamBMS 1.5.2 :
- Added shunt
Online Status
binary_sensor - Shunt combine condition based on the new binary_sensor
Online Status
- Logger
baud_rate: 0
by default (frees the 3rd UART and avoids some bugs like "WK2168 with canbus" or "BLE client with RS485 modbus") - Changed names of
bms
andshunt
YAMLs for modbusmulti-node
solution - Added shared configuration file to simplify main YAML (centralization of parameters)
- Simplification (fewer options) when importing
BMS / Shunt
YAMLs - New
multi-node
solution usingRS485 modbus
to communicate information to YamBMS - New board
espBerry
with2-CH-CAN HAT
- Added shunt
- YamBMS 1.5.1 :
- The conditions for
combining
BMS and thecharging
anddischarging
instructions no longer have any relation with theerrors_bitmask
sensor, the new system relies on the three binary_sensoronline status
,charging allowed
anddischarging allowed
being linked to the status of alarms and switches. - The BMS combination procedure has been completely rewritten.
- Improved structure and ID names of
bms.yaml
. - The
yambms.yaml
andyambms_combine.yaml
global variable names have been changed for better code reading. - Improved code regarding the CAN bus
esp_light
status for boards without integrated LED. - New
Atom S3R
board andSmartshunt BLE
shunt. - New
JBD
,Seplos V1 V2
,JK-B RS485
(display port) andFAKE
BMS. - New
YamBMS DEMO
YAML and firmware offered to test and discover howYamBMS
works. - New management of temperature sensors (no longer limited to two sensors).
- @Der_Hannes fixed the AtomS3
black screen
issue (with esphome > 2024.7.3) and developed new code for display management based on the ili9xxx platform. Auto CCL/DCL
functions have been fixed to work withJK-PB
andnew JK-B
BMS, see this issue.- The
UVPR
andOVPR
sensors are no longer used and replaced byUVP
andOVP
to ensure operation with all BMS. - @txubelaxu fixed a bug in the
JK-PB RS485
component that could cause a false battery voltage value to be sent, see this issue. - Improved documentation, added a
HowTo
to create its main YAML, warning about galvanic isolation.
- The conditions for
- CANBUS 2.3.7 : If there is no response from the inverter, the time before a new communication test has been reduced from
120s
to60s
, added Victron0x372
nbr. of modulesblocking charge/discharge
. - YamBMS 1.4.5 : Changed the way to configure WiFi/Ethernet network, added
ESP32-C3 ETH01-EVO
ethernet board, reduction of the number of YAML bms files, UARTrx_buffer_size
is set to512
by default for JK-B and JK-PB, new JK-BMS BLE sensors (last commits of @syssi) and new BLEstandard
version - CANBUS 2.3.6 : Sending CAN frames stops immediately if there are no combined BMS
- YamBMS 1.4.4 : Multi-shunt support, Simplified and new YamBMS option
battery chemistry
, slidermin/max
values are automatically configured based on the battery chemistry and cell count, addedYamBMS Fallback Hotspot
, added YamBMSUpdate service
, added PVbrain2 and Atom Matrix board, added PSRAM settings YAML (not enabled by default), new MIN/MAX temperature sensor, added DC current icon, fixed dual sensorCell UVPR (MAX)
bug, Improvedcombine
code, Breaking change : Atom S3GPIOs 1 and 2
reversed - CANBUS 2.3.5 : New MIN/MAX temperature / sensor ID, Improved Victron protocol (online/offline battery modules, installed/available battery capacity)
- CANBUS 2.3.4 : Fixed bug of canbus link validation without inverter connected
- YamBMS 1.4.3 : Added Victron and Junctek KH-F
Shunt
support andRequested Force Charge
function based onSoC start/stop
, newTotal Daily Energy
sensors - CANBUS 2.3.3 : Added
Automatic
BMS name selection andRequested Force Charge
Bit 3/4/5 (PYLON 0x35C) - CANBUS 2.3.2 : Added
LuxPower
protocol with updatedcan_id
0x355, 0x356, 0x359 and 0x35C - CANBUS 2.3.1 : Improved the procedure for sending canbus frames with reduced loop time, rewritten of the canbus link validation code and added
Inverter Heartbeat Monitoring
function - YamBMS 1.4.2 : Added new
Auto CVL Boost V.
andRebulk SoC
functions, new debug.yaml for ESP32 and ESP32-S3, improved code and comments - YamBMS 1.4.1 : Rewriting of the alarm system, bug fixes and improvement of the charging logic (new status
Cut-Off
), icon allocation for each sensor, UART and CANBUS!extend ${vars}
, New sensorYamBMS Delta Cell V.
, ImprovedBattery SOC
logic - YamBMS 1.3.2 : New var
yambms_cell_count
, the BMS charge or discharge switches can be activated separately without causing the decombination of the BMS, newminimal
version of the BMS YAML in order to reduce the loop time - YamBMS 1.3.1 : First multi-BMS version named
YamBMS
- Thanks to @syssi for help and making many BMS components (JK, JBD, Seplos, Pace, etc.)
- Thanks to @txubelaxu for help and making the
JK-PB RS485
component. - Thanks to @uksa007 for making the original CANBUS code.