Skip to content

Story (and code) of building a somewhat portable solar system for use during outdoor events

Notifications You must be signed in to change notification settings

patagonaa/solar-system

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 

Repository files navigation

Solar System

Build thread (german) at https://chaos.social/@patagona/113149877881417810

Batteries

Basically, what drove me to start this project.

Someone was selling three Pylontech battery modules (1x US2000C, 2x US2000, each 15S LiFePo4, 2.4kWh) for really, really cheap (<25€/kWh) because they were water damaged.

So of course, I picked them up and as expected, the BMS PCBs were corroded to the point of not being feasible to repair (mostly due to the half-assed "conformal coating" applied to the PCBs), but the battery cells themselves were fine, albeit still a bit wet, limescale everywhere and a bit unbalanced.

picture of one opened battery pack with limescale on the cell packs and casing

After opening up the packs, letting them dry, cleaning up the limescale/corrosion and balancing them, all of the cells seem to be fine.

Case

For transport, the batteries are mounted in a used flight case. I'm using an Anderson-style connector as interconnect between battery and inverter (and potentially other loads), which I've mounted towards the outside of the case so it can be used with the lids on.

There are two parts two the mount, one that holds the connector (cad/battery-connector-mount/battery-connector-mount.scad) and one for between mount and plug so the mount doesn't get squeezed when tightening the screws (cad/battery-connector-mount/plug-fill-adapter.scad). The latter is pretty generic, the first is specific to the case and could be edited to make a lot stronger if it doesn't have to fit this specific case.

screenshot of the connector mount. it's a box around the connector with flanges with countersunk holes for panel mounting screenshot of a small part with two hex protrusions on a plate photo of the front of the mount (with the connector hole and mounting flanges) lying on the flight case. There are two round cutouts for metal parts of the flight case photo of the flight case with the mounted connector

BMS

To replace the corroded BMS I decided to get DALY 15S 100A "Smart" BMS modules.

Mount

To mount the BMS, I designed some adapter / mounting plates that fit the original mounts / standoffs of the Pylontech battery modules.

the BMS mounted on a laser-cut wooden board screwed to original battery case standoffs

The design files can be found in cad/bms-mount.

Protocol

The BMS has a UART, RS485 and CAN interface. There is already a DALY BMS integration using a UART interface in ESPHome, however that is for the older DALY BMS, not the new H/K/M/S-Series (for which there is already a GitHub issue).

After looking at the Windows software and the protocol documentation provided in the GitHub issue, I implemented the new protocol as an ESPHome integration to (hopefully) upstream in esphome/esphome#7524.

Inverter

I decided to go with a "EASun ISolar-SMH-II-7KW" (which is produced by the OEM "Voltronic", similar/equal devices are also sold under the names "MPPSolar", "PowMr", "Powland", "FSP", ...), mostly because it was cheap and has a lot of output power.

picture of the inverter with two Schuko sockets and thick battery wires hooked up to it

It wouldn't go up to the advertised 6.2kW in my testing (it already showed 99% load at around 5.4kW), but that might be battery current limited due to the relatively low battery voltage (15S LiFe instead of 16S LiFe or lead acid, still 120A!), so in combination with the solar input or with a higher input voltage, it should go even higher.

Protocol

The inverter has a RS232/RS485 interface which can be used to read data from the inverter (using a custom mostly-ASCII-based protocol) and which has been implemented by several people already:

Inverter Box

The inverter is mounted on a plate in a 60x40x22cm euro container for easy transport and (at least minimal) water-resistance, along with all the other necessary support hardware (circuit breakers, etc.).

Files in cad/box.

Front Panel

There is a laser-cut front panel exposing all the important connections (DC, AC, PV) on the short side of the euro container.

Files in cad/frontpanel.

OpenSCAD screenshot of the front panel (see german Mastodon post for better alt text) OpenSCAD screenshot of the front panel OpenSCAD screenshot of the front panel Photo of the laser-cut frontpanel on the side of the euro container with most of the connectors fitted

Air Duct

To prevent overheating, an air duct was designed (in Fusion) and 3D printed to direct the warm air from the inverter fans directly out the Eurobox handle.

Files in cad/air-duct.

Photo of the inside of the Eurobox. Between the inverter and the Eurobox is a neon orange 3D-printed air duct that curves from the fan outlet of the inverter to the Eurobox handle. Second view, the part is positioned with an edge at the top of the inverter and also has a flat area to the left and right of the fans for better sealing. View from the outside, the orange 3D printed part fits perfectly into the Eurobox handle

Lessons Learned

You Get What You Pay For #1: RS485 Transceiver Modules

picture of one of the RS485 transceiver modules

The (pretty common) RS485 transceiver modules I used for inverter communication do have a ground pin on the RS485 side. This does, however not mean it is actually connected to anything meaningful.

Actually, there is no connection between the TTL- and RS485-side ground, which means any stray electric current flows directly into the A/B inputs of the RS485 transceiver.

In some cases (for example, when both the PV input and the MCU are ground-referenced, even just through a Y-capacitor of a PSU) there may be something like 90V AC at 700µA between the two sides of the RS485 transceiver, killing it pretty much instantly.

Running a wire from the TTL-side ground to the RS485-side ground fixes that issue by giving the stray currents a direct path to flow.

You Get What You Pay For #2: Inverter Startup Voltage

At one point, the inverter just stopped working (when switching it on, it turned off itself after a few seconds). Turns out, there is an (undocumented) "cold start" voltage, that is hard-coded to be ~4V above the low-voltage cutoff. Means, when the low voltage cutoff is set to 45V, the inverter will just not start below ~49V.

Also, the battery voltage readout was wrong by around 0.7V, however that could be fixed through a serial command.

You Get What You Pay For #3: BMS Communication

The DALY BMS comes with two TTL UART ports, CAN and RS485. The DALY BMS RS485 protocol is well-documented and also implemented in ESPHome.

However, as it turns out, the new (2023?) lineup of BMS from DALY (H/K/M/S series) use another communication protocol. This new protocol is called "Modbus" internally in the PC software and looks just like regular Modbus.

After some messing around with Modbus software and not getting it to work, I figured out that the reply from the BMS has a different device id than the request, which makes it completely incompatible with all available Modbus software / libraries, so custom software had to be written again (see above).

About

Story (and code) of building a somewhat portable solar system for use during outdoor events

Topics

Resources

Stars

Watchers

Forks