Tests:
Query the cell voltages and the status of pylontech or pytes batteries via the console. I'm not affiliated.
Please note that everything you build or connect is always your responsibility. The developer of this adapter assumes no liability for any damage!
This adapter is used to determine the health status and functions of a Pylontech or Pytes array, which can consist of one or up to fifteen batteries. This adapter is not used to control the battery. This is the part of a charging and power unit or an inverter. The batteries have a console connection that provides a RS232 or V24 interface. This adapter is connected to it via a serial interface. The first battery provides all the data and asks the others via the uplink. Attention, it is not possible to connect a Raspberry or ESP directly. The RS232 interfaces do not have a TTL level and are not designed for 3 volts or 5 volts. A level converter is required for connection. You will find construction instructions below.
A cable and a serial converter are required for connection. A serial connection requires three lines rxd, txd and ground.
Rxd and Txd must be crossed. so that what one sends (Txd) can be received (Rxd) by the other. Ground is needed so that a voltage can be built up and an electrical current can be started.
Pylontech has changed the RJ plugs on the batteries over time. In the beginning there were was a RJ11 plugs like on the telephone. Now it is an RJ45 like on the network connection. The following drawings show a standard nine pin D-SUB female connector on the cable. This cable can be easily connected via the USB port with a RS232 to USB adapter or to an RS232 to LAN or WIFI converter. Only the first battery in the array provides all information. You only need a cable and a serial port
You can assemble such a cable yourself with a configurable plug. This is available with an RJ45 connector and a female D-SUB9 plug. You simply connect a patch cable to it. But be careful to insulate the remaining cables well so that they do not touch each other. Not all batteries have the remaining pins unused. In principle, you can also connect an RJ11 cable to such an adapter. But I find it very wobbly and always think it doesn't make good contact.
Or ready-made cables contact in the forum.
RJ45 | signal | DSUB | signal |
---|---|---|---|
3 | TxD | 2 | RxD |
6 | RxD | 3 | TxD |
8 | Ground | 5 | Ground |
The RJ11 and RJ12 connectors are the same size. The RJ11 has only four contacts, the RJ12 has six contacts. The contacts of the RJ11 are in the middle of the plug, which is why they are counted differently. Physically the contacts are in the same place.
RJ11 | RJ12 | signal | DSUB | signal |
---|---|---|---|---|
1 or 4 | 2 or 5 | Ground | 5 | Ground |
3 | 4 | TxD | 2 | RxD |
2 | 3 | RxD | 3 | TxD |
RJ45 | signal | DSUB | signal |
---|---|---|---|
3 | TxD | 2 | RxD |
4 | Ground | 5 | Ground |
6 | RxD | 3 | TxD |
max. baud | max. length |
---|---|
2400 | 900m |
4800 | 300m |
9600 | 152m |
19.200 | 15m |
57.600 | 5m |
115.200 | 2m |
If there is no USB port nearby, you can build a serial to WiFi adapter with an ESP.
These adapters speak a kind of Telnet and essentially extend the serial interface through the WiFi. Here it is important to install a driver module for the serial interface. E.g. the MAX3232. Please pay attention to the voltages but most of them are 3V.
Since the Raspberry also offers a TTL interface with 3V, you can also connect a MAX3232 here.
Under Linux it is possible to set a link to the port on which the USB-serial converter is connected. It is then possible to assign descriptive names to the devices.
$ ls -l /dev
crw-rw---- 1 root dialout 188, 0 29. Sep 21:32 ttyUSB0
lrwxrwxrwx 1 root root 7 29. Sep 21:32 ttyUSB_pylontech -> ttyUSB0
The serial number can be determined for this if the USB converter has it.
$ udevadm info -a /dev/ttyUSB0 | grep ATTRS{serial}
ATTRS{serial}=="thisisit"
If there is no serial number here, you have lost. Please make sure to adapt the device ttyUSBx.
Create a new config file. Use the editor of your choice, VI is also possible.
sudo nano /etc/udev/rules.d/20_pylontech.rules
With the following content
# File: /etc/udev/rules.d/20_pylontech.rules
# FTDI USB <-> Serial
SUBSYSTEM=="tty", \
ATTRS{serial}=="thisisit", \
SYMLINK+="ttyUSB_pylontech"
Then you should restart the udev and disconnect and reconnect the device once.
sudo /etc/init.d/udev restart
You can find a unique name for each device. It doesn't change with FTDI or something like that. This can also be entered into the adapter.
$ ls -l /dev/serial/by-id
lrwxrwxrwx 1 root root 13 10. Okt 11:37 usb-ftdi_usb_serial_converter_ftDZ0DGP-if00-port0 -> ../../ttyUSB0
so the device is /dev/serial/by-id/usb-ftdi_usb_serial_converter_ftDZ0DGP-if00-port0
Instead of local connect:
+--------+ comport +----------+
| DEVICE | ~~~~~~~~~~ | ioBroker |
+--------+ +----------+
Does this adapter also support network connect:
+--------+ comport +--------+ network +----------+
| DEVICE | ~~~~~~~~~~ | SERVER |========....==========| ioBroker |
+--------+ +--------+ +----------+
There are several projects that connect ESP or ESP32 to Telnet. Please remember the MAX. If the MAX gets hot then either the signal level of 5V is too high because you got a 3.3V model or you have connected a 3.3V version to 5V operating voltage.
Here are some examples:
ESP-LINK: https://github.com/jeelabs/esp-link
ESP-Serial-Bridge: https://github.com/yuri-rage/ESP-Serial-Bridge
Serial Port Over WiFi: https://www.instructables.com/Serial-Port-Over-WiFi/
Tasmota Caused problems because blocks were not transferred in order and should therefore not be used at the moment: https://tasmota.github.io/docs/Serial-to-TCP-Bridge/
Only the following or self-compiled ones can be used as bin, otherwise the TCP server is not included:
The Gipos must be set beforehand. One each on TCP Rx and TCP Tx.
TCPBaudRate 115200
TCPStart 23
Rule1 ON System#Boot do TCPStart 23 endon
Rule1 1
It works because a transparent TCP server is provided on, for example, port 23. The port can be selected, simply exchange 23 for 9000, for example. And of course solder a MAX2323 between the Gipos and the RJ/DSUB plug!!!!
You can use ser2net to share the port of a PC or mini Raspi over the network.
sudo apt-get ser2net #install
sudo vim /etc/ser2net.conf #configure
ser2net #run service
The configuration line (for /etc/ser2net.conf) that corresponds to windows setup above
7000:telnet:0:/dev/ttyUSB0:115200 8DATABITS NONE 1STOPBIT remctl
RFC Here are the settings of the above config. The device port is 7000.
More information can be found here: https://gist.github.com/DraTeots/e0c669608466470baa6c
There is ready-made hardware that can be connected via wifi and/or lan. As long as it uses a transparent TCP server it should work.
Example:
Another tip: there are cheap and expensive USB serial converters. Converters with CHxxx PLxxx and CPxxx in the name have no identifying features. If you connect two of them and then swap the ports or boot for the first time, you no longer know who is who. Therefore it is better to take the good ones with FTDI and serial number. There are also good serial converters without an FTDI chip that have a serial number.
I'm still at the beginning. What was tested:
Communication hardware | Type | Is working | Comments |
---|---|---|---|
Serial to USB | local | yes | There is a large selection of chips for the adapters. Depending on the model, identification problems can occur if the adapters do not have a serial number and more than one is connected. Windows already assigns one COM port for each USB plug. |
LogiLink AU0034 | local | yes | |
ESP-LINK | network | yes | Assign the device an IP in the network. Check transmission speed 115200 8 N 1. Everything else left unchanged. Remember to use a converter like the MAX |
Tasmota | network | no | With Tasmota on an ESP8266, blocks were not transferred in the correct order, resulting in incorrect objects and data. Tasmota is therefore not recommended. |
Waveshare RS232/485 TO ETH (for EU) | network | yes | Assign the device an IP in the network. Check transmission speed 115200 8 N 1. Everything else left unchanged. Use the RS232 SUBD Port. |
Waveshare RS232/485/422 TO POE ETH | network | yes | Assign the device an IP in the network. Check transmission speed 115200 8 N 1. Everything else left unchanged. Use the RS232 SUBD Port. The converter can be supplied with power via POE. If POE is available, you do not need a power supply near the batteries. |
Elfin EW10A | network | yes | Make sure that there is enough bandwidth and signal strength on your WiFi so that the connection is stable. Check transmission speed 115200 8 N 1. |
Elfin EW10A-0 | network | yes | Make sure that there is enough bandwidth and signal strength on your WiFi so that the connection is stable. Check transmission speed 115200 8 N 1. |
Elfin EE10-A | network | yes | Assign the device an IP in the network. Check transmission speed 115200 8 N 1. Everything else left unchanged. |
Pylontech model | Model | Firmware | Is working | Comment |
---|---|---|---|---|
US5000 | US | V1.3 22-08-10 | fine | |
US2000C | US | V2.6 21-09-26 | fine | |
US2000C | US | V2.1 | fine | |
US2000C | US | V2.8 | fine | |
US2000 (US2KBPL) | US | V2.8 21-04-29 | fine | Temperatures only in one degree increments |
Force H2 | Force | V1.5 21-06-18 | fine | Attention: in some Force manuals only the RX and TX connections are listed in the connector description. The ground is on PIN 8 and must also be connected. |
Pytes model | Model | Firmware | Is working | Comment |
---|---|---|---|---|
E-BOX-4850P | US | V1.3 22-12-20 | fine | Thanx to kletternaut for the test data |
E-BOX-48100V-D | US | V1.10 23-10-13 | fine | Adapter version >=0.0.9 . "Download the battery cells state of health" and "Download the battery statistics data" should be switched off. (soh -n- and stst -n- are not supported) |
If you use hardware, please write to me in the forum or in Github as an issue. We would be happy to continue this list.
ioBroker forum: https://forum.iobroker.net/topic/68707
Only the first Accu in the array provides all information. If you connect this adapter to one of the following accus, it will no longer work because this accu cannot answer all requests.
Please note: The RS485 and Canbus interfaces are not for this adapter. They speak a different language.
At the Force there is also a terminal.
The settings in the IoBroker admin interface:
You can choose between a local device, i.e. an interface connected locally to the computer, e.g. a USB converter, or a TCP-IP network server as an interface.
Options:
The following fields are only displayed if Local device has been selected in Connection via.
If "local device" was selected, the path or port must be set. NodeJs thinks in Linux, so path not found is also reported if the specified windows device is not found. The standard devices are searched for by the adapter and offered as a selection list, but this only works when the adapter is running because this requires communication with the instance. Only devices are offered, no alternative device identifiers and no unicnames, but these can be entered manually. See the local interfaces section.
The transmission speed can be set here. This is set to 115200 on newer models. For older models it is 1200. If no connection is established you can try whether the adapter runs at 1200. If this is the case, the speed can be set to 115200 using the status "pylontech. -n- . config.set_speed". The adapter speed must then be set back to 115200.
The following fields are only displayed if network device has been selected in Connection via. No encrypted network connections can be established yet.
Enter the name of the com server here. No http or anything like that at the beginning of the name. IP addresses can be entered or names such as ESP-LINK.FRITZ.BOX. For DHCP devices, pay attention to the fact that the IP address can change.
In order to establish communication, the port under which the server provides communication must be specified. For ESP-Link, for example, it is 23.
The speed must be set on the network device.
The cycle time can be set here. Personally I think 5 minutes is enough to get an idea if the batteries are working well. Please note that the batteries should primarily communicate with the inverter and not the debugger.
Here you can select the model. You can currently choose between US and Force. You can't destroy anything. So feel free to test which setting your Pylontech is running on. There are also some listed at the top of the compatibility list. If it doesn't work, you can contact me via the ioBroker forum and we can see why the data cannot be read.
ioBroker forum: https://forum.iobroker.net/topic/68707
If errors occur because the adapter requests data that the batteries do not provide, the request can be stopped here. The adapter was built on the basis of re-engineering, so I may have to make improvements. If there are too many objects for you, you can also reduce the data here.
The command “bat -n-” is only written to the console if this is set here.
The command “soh -n-” is only written to the console if this is set here.
The command “info -n-” is always written to the console. Here you will find information about which serial number the individual batteries have. It is needed for the object tree. If this is switched off, the information will not be transmitted to the ioBroker.
The command “log” is only written to the console if this is set here.
The "pwr" command is always written to the console. The command “pwr -n-” is only written to the console if this is set here. Here you will find information about the positions of the individual batteries. It is needed for the object tree. If this is switched off, the information from the "pwr" command is not transferred to the ioBroker and the "pwr -n-" command is not issued.
The command “stat -n-” is only written to the console if this is set here.
The command “time” is only written to the console if this is set here.
If errors occur because the adapter requests data that the batteries do not provide, the request can be stopped here. The adapter was built on the basis of re-engineering, so I may have to make improvements. If there are too many objects for you, you can also reduce the data here.
The command “bat” is only written to the console if this is set here.
The command “soh” is only written to the console if this is set here.
The command “info” is only written to the console if this is set here.
The command “log” is only written to the console if this is set here.
The command “pwr” is only written to the console if this is set here.
The command “stat” is only written to the console if this is set here.
The command “sysinfo” is only written to the console if this is set here.
The command unit” is only written to the console if this is set here.
The command “time” is only written to the console if this is set here.
Almost all measurements are stored here in milli (one part in a thousand).
Most of the values have to be divided by thousands to view.
The information of the following commands is stored here
The information of the following command is stored here
The information of the following commands is stored here
The information of the following command is stored here
todo
You can write the “set_speed” status to “true” without confirmation. On older models, a command is sent to the battery that corrects the speed. With newer models an error message comes back. Ack is set to true when the command is written.
Is true if the adapter was able to establish communication
Set to true when the battery is found.
Contains the barcode (serial number) to track which battery is installed at which point in the stack.
The log channel contains 31 channels with the last 31 log information. The neuset is always in 31 and is then pushed down when there are new messages.
The time read from the inverter is stored here. On the US3000 it is called RTC and on the old VS2000 it is called ds3231. If you write to the time, your time will be transferred to the battery and the battery time will be adjusted.
If true without ack is written to set, the current time is sent to the Pylontech. When the command has been executed, the status is set to ack = true.
Is true if the adapter was able to establish communication
The log channel contains 31 channels with the last 31 log information. The neuset is always in 31 and is then pushed down when there are new messages.
The time read from the inverter is stored here. On the US3000 it is called RTC and on the old VS2000 it is called ds3231. If you write to the time, your time will be transferred to the battery and the battery time will be adjusted.
If true without ack is written to set, the current time is sent to the Pylontech. When the command has been executed, the status is set to ack = true.
MIT License
Copyright (c) 2024 PLCHome
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.