Skip to content

How to use

Torsten Oltmanns edited this page Dec 29, 2024 · 52 revisions

How to use

Requirements

This project explicitly supports Java 8 because its the latest version with 32-bit JDK 8 support that many microcontrollers support. If you're using a Raspberry PI 3B, 4B or above I recommend to use a 64-bit Java JDK and 64-bit operating system like Raspian OS or Ubuntu.

  • JDK 8 or above (see https://jdk.java.net/) (JDK 8 is only recommended for 32-bit microcontroller otherwise JDK 21+ is recommended)
  • A PC or microcontroller running a Linux derivate like Raspian OS or Ubuntu (for CAN/RS485/ModBus/Serial support) or Windows (for only RS485/Modbus/Serial support)
  • Communication adapters to use CAN, RS485, Modbus or Serial depending on your battery management system (BMS) and/or inverter

NOTE: USB CAN adapters have been found to not function well with the application unless they create a proper CAN device and not just a ttyUSB device. Recommended are CAN hats like the Waveshare RS485-CAN or Waveshare 2CH-CAN hats.

Download the Configurator

Download the Configurator application and start it:

java -jar configurator.jar

This will start the configurator. You can do this on any platform that has a Java JDK 17+ installed. It does not necessarily need to be the target platform where you will run the bms-to-inverter application.

General settings

image

Please first select the installation folder for your application, e.g. bms-to-inverter by clicking the Choose button. If necessary create a folder where the application is to be installed. You can also choose an existing installation folder if you just want to update your configuration or installation.

Then choose the OS platform of the * target * device, e.g.:

  • AARCH64 for Raspberry Pi 2Bv1.2/3A+/3B/3B+/4B/5 or Mac M1/M2/M3 running a 64bit OS
  • X86 32bit (Unix) for a Linux/MacOS system running on Intel/AMD x86_32 bit
  • X86 64bit (Unix) for a Linux/MacOS system running on Intel/AMD x86_64 bit
  • ARM7 for a Raspberry PI 2B running 32bit OS
  • etc.

NOTE: if you select Windows as your target platform you will NOT be able to use the CAN protocol to communicate to your BMS(es) or inverter.

Also choose the log-level for the application. Recommended is to leave it at info level for your first installation. You can change it anytime later (debug if you run into problems, warning or even only error if everything is running smoothly).

BMS configuration

Next you need to configure your BMS(es) on the BMS tab.

image

The poll interval on the buttom configures the delay (in seconds) between each reading round of BMS data.

Click the Add button to add and configure a BMS. This will open the following BMS configuration dialog:

image

Select your type of BMS, e.g. Daly, JK, Pylon, Seplos, etc. with their corresponding protocol (CAN or RS485 (UART, RS232)). For example, select DALY_CAN if you have a Daly BMS using the CAN protocol, select DALY_RS485 if you have a Daly BMS using the RS485, UART or RS232 protocol.

You can also select NONE as BMS, i.e. if you want to simulate a BMS using the SimulatedBatteryPackPlugin. Please read the usage of the plugin carefully!

Assign an ID for the BMS. Usually this starts with ID 1 and increments with each additional BMS. Often the ID is also configured on the BMS hardware via a DIP switch or manufacturers software setting. If you're not sure start with ID 1.

Next enter the port which the BMS is connected to, e.g. /dev/ttyUSB0, can0, com3, or similar. Please check the manual of your CAN or RS485 hardware module manufacturer.

If your baudrate differs from the default, then you can change the value to the BMS specific value.

The delay after no bytes can help to solve problems if the BMS is too slow to put data on the wire. So if no data was available when reading, it will wait the configured milliseconds before reading again.

If you have multiple BMSes configured on the same port using the same bus, you can just select the BMS and click the Duplicate button.

image

Use the Edit button or double click to make changes to a BMS. The Remove button will delete the BMS from the list.

Configure inverter

On the Inverter tab you can configure your inverter.

image

Select NONE if you only want to read your BMS(es) values. Otherwise select your inverter brand. If your brand is not in the list but supports the PlyonTech CAN protocol you can try the PYLON_CAN (PylonTech).
(If you have problems or need an implementation of a missing Bms or inverter - just contact me!)

Next enter the port which the inverter is connected to, e.g. /dev/ttyUSB0, can0, com3, or similar. Please check the manual of your CAN or RS485 hardware module manufacturer.

If your baudrate differs from the default, then you can change the value to the inverter specific value.

The send interval defines in what intervals (in seconds) the BMS data is sent to the inverter.

Configure optional BMS or inverter plugins

The plugins tab provides configuration of optional plugins you might want to use to manipulate the BMS data or inverter data.

image

Currently these 3 plugins (for inverters) available:

  1. PresetBatteryPackDataPlugin will check if a SOC has already been read from the BMS. If not, it will set the preset values which can be configured when adding or editing the plugin:

image

Use this if the inverter reports errors upon starting the application to deliver data until the BMS binding has read real data.

  1. SimulatedBatteryPackPlugin can be used in combination with the BMS binding NONE (the dummy BMS) to test the inverter binding communication.
    IMPORTANT: If you use the dummy BMS (NONE) binding together with the inverter plugin SimulatedBatteryPackPlugin you MUST (!!!!!!!!!!) disconnect any load and PV DC input to prevent possible damage as the inverter will try charging/discharging!!! Some basic battery data values can be set when adding or editing the plugin:

image

  1. ManipulateBatterPackDataPlugin can be used to manipulate the data that is acquired from the BMS to adjust core values like max-/minimum voltage limits, max-/minimum dis-/charge currents, etc.

image

Configure optional services

The Services tab provides multiple optional services that you can activate.

image

Email notification

If you like to be notified when there are alarms or warnings from you BMS, you can have them sent as email. Configure the properties according to your email provider.

MQTT producer

Use the MQTT producer to connect to external MQTT brokers, e.g. Home Assistant, Mosquitto, etc. to send BMS data.

MQTT producer

Use the MQTT broker to provide BMS data to external MQTT clients so that they can connect to the topic and receive BMS data.

Webserver

If you like to monitor all your BMS(es) data like voltages, currents, balancing, warnings and alarms, you can select this option. If you use the webserver service you can specify which ports the HTTP and HTTPS will run on set a username and password for the login. You can then connect to the webserver like http://<my_ip>:<http_port> or https://<my_ip>:<https_port>, e.g. https://localhost:8080. The http connector will automatically be forwarded to the https connector.

Installation

If you're just editing your configuration you only need to click the Update Configuration button.
If you're installing for the first time or want to update the application you can create a fresh installation using the current configuration by pressing the Clean install button.

image

When you see the succesfull message you will have everything you need in your installation folder. If you need to transfer this to your target machine, e.g. like a Raspberry PI you can use something like WinSCP to copy the installation folder to your target machine. If your installing directly on the target system you will not need to do anything, but if you copy the files from a Windows system to a Linux system (like the PI) you need to change the file permissions of the start scripts in your installation folder:

chmod 744 start.sh
chmod 744 configurator.sh

That's it - now you're ready to go!

Starting the application

You can now start the application from your installation folder by calling:

./start.sh

To re-configure or update the application call:

./configurator.sh

On windows call the respective file with the .cmd file ending.

Starting the application at boot time

You might want to consider to start the BMS-to-Inverter application automatically when your PI boots up. The following steps assume you have a 2CH-CAN-HAT and installed the application as user pi in the /home/pi/bms-to-inverter folder. To achive this do the following steps:

  1. Create a bash script file (e.g. /home/pi/startcan.sh) that will pull up your interfaces (CAN or RS485), e.g. for 2CH-CAN-HAT:
#!/usr/bin/env bash
sudo ip link set down can0
sudo ip link set down can1
sudo ip link set can0 type can bitrate 500000 restart-ms 100 fd off
sudo ip link set can1 type can bitrate 500000 restart-ms 100 fd off
sudo ifconfig can0 txqueuelen 65536
sudo ifconfig can1 txqueuelen 65536
sudo ip link set up can0
sudo ip link set up can1
  1. Give the proper permissions to the file:
sudo chmod 755 /home/pi/startcan.sh
  1. Open the rc.local file to add the calls to start the application
sudo nano /etc/rc.local
  1. Add the following two calls at the end of the rc.local file but before the exit 0:
cd /home/pi/bms-to-inverter
/home/pi/startcan.sh
/home/pi/bms-to-inverter/start.sh &
  1. Save and exit nano with Ctrl+X and confirm saving with Y and reboot.

That's all and the application should now be running (check the logs or the webapp).


Notes

If you have questions or need support feel free to contact me or raise an issue or discussion. If you like to support me testing the application on all different BMSes and inverters please contact me!

========>>>>>>> Finally, if you like this project and like to support my work please consider sponsoring this project Sponsor button on the right :)