-
-
Notifications
You must be signed in to change notification settings - Fork 27
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow "CVL reset based on cell voltage diff" to operate independently of Linear or Step Mode #122
Comments
If your battery is unbalanced and you don‘t want to wait for it to balance, you can increase |
I actually do want to wait for the battery to balance. The issue is the amount of time it takes to reach Absorption when using Linear Mode & that is why I use Step Mode. However, using Step Mode forces a fixed Absorption time. A variable Absorption time using "CVL reset based on cell voltage diff" would be the preferred option. |
Can you post your settings and a graph of min/max cell voltage for linear and step mode? So that I can see the difference you are talking about? |
This is Linear Mode This is the Linear config.ini This is Step Mode This is Step config.ini |
Thanks, this is a bit more complex and will take much time to solve, since a lot of testing is needed. I have the same behavior and like also to solve that for the first graph. You could help me to find out, why that hughe difference is happening. Probably the CVL reduction is too much. |
I haven't looked deeper into it, but at a first glance, it looks like an oscilating control problem. In terms of control theory, you have a p-controler with a control loop time of 1 minute. You can see the voltages spike in 1 minute intervalls, so I would guess your control loop is too slow for the fast voltage changes that you want to control. Maybe try with shorter loops, like 10 seconds, or smaler voltage steps. you can also think about introducing a PID-control lib. I use simple-PID with good success for controlling an outdoor water heating. |
for investigating, a shorter loop time would be an easy change to see if it's the right direction |
You can change that with this setting:
Set it to 10 or even 5 seconds. |
Changed to 5 seconds with fewer resets to MAX_CELL_VOLTAGE but duration is similar. You mentioned "Probably the CVL reduction is too much." Looking at battery.py, am wondering if different calculation of control_voltage may improve CVL reduction. venus-os_dbus-serialbattery/dbus-serialbattery/battery.py Lines 783 to 792 in 86ed2e6
Replacing Currently, the starting point for CVL reduction appears to be the sum of the cell voltages (the current battery voltage) rather than the target battery voltage (max.battery_voltage) which is why it closely follows average cell voltage. Also, by including CELL_VOLTAGE_DIFF_KEEP_MAX_VOLTAGE_UNTIL, there is a tolerance for overshoot of max cell voltage. Using the default CELL_VOLTAGE_DIFF_KEEP_MAX_VOLTAGE_UNTIL of 0.010v, a cell would be allowed to reach 3.46v (or 2 cells at 3.455v) before CVL is reduced. CELL_VOLTAGE_DIFF_KEEP_MAX_VOLTAGE_UNTIL is included in the P-Controller for what may be a similar reason. A perhaps simpler change would be to include CELL_VOLTAGE_DIFF_KEEP_MAX_VOLTAGE_UNTIL as follows: What do you think? |
I tried now with Additionally I have a very strange issue with my cells, that I never understood why that happens. Maybe does the balancer kick in too early (@ I made a lot of optimizations and changes in the todays nightly. Now I'm rewriting the part, where you can select a controller to calculate |
Just for testing and not completed at all: 78d567f Any recommendations are very welcome. |
Form what I understand, balancing should only start at the desired charge voltage - 3.5v in your case. The reason being is that prior to that point, the charge current is high and overwhelms any benefit of balancing, may increase cell imbalance at higher voltages (your cells 18 & 9 may show that) & may make balancing time longer than necessary. Do you limit charge current based on cell voltage with CCCM_CV? Have you tried setting start balance at 3.5v? With respect to But 3.53v does not seem an excessive overshoot at CVL of 3.5v - still 120mv away from 3.65v maximum. It depends on what your tolerance is. In my case, I control charge current with CCCM_CV such that CCL is zero at a 30mv overshoot which seems to work quite well. The intent of This is the result of Rather than immediately following Average Cell Voltage, CVL approaches Average Cell Voltage (with no rebounds back to 3.45v) as more cells exceed 3.45v then follows follows Average Cell Voltage. Unfortunately, this calculation never really stabilises at 3.45v because there are too many cells (on average 8 cells) over 3.45v when Average Cell Voltage = 3.45v. Although I didn't let it run for a long time. It will be worse in your installation with 18 cells. In an effort to achieve the desired outcome from the original enhancement request above, I changed battery.py to NOT adjust CVL in Linear Mode with this result: For comparison, this is the current production Linear Mode shared earlier: Time from first cell at 3.45v to Float has reduced from 2h 46m to 30m with 15m Absorption time in both. Less time has elapsed with cells over 3.45v having AH removed during balancing which seems to reduce those cells undershoot after Average Cell Voltage reaches 3.45v. With regard to 78d567f, I think we are playing at the margins of potential improvements with added complexity. Based on other discussions & issues, it seems only you & I are finding this area problematic. |
Yes
Not yet but soon. I tought 3.40 V is high enough, but will see the results soon. I changed it now to
I think the config file is now mucn more clear. Since the default config is the recommended for most systems, users which do not understand the setting should leave them as they are. :-) the most complex part is, if one wants to understand which controller to use. |
Is your feature request related to a problem? Please describe.
Am using Step Mode because Linear Mode takes >3 hours to switch to Absorption after first cell reaches Bulk Voltage (3.45v) in full sun - the 16 cells in battery module are not well matched.
As cell voltage increases, current is gradually reduced by CCCM_CV_ENABLE such that 0 amps is set at 3.48v - this prevents a significant overvoltage condition and significantly reduces time to Absorption compared to Linear Mode.
Consequently, am restricted to using a fixed absorption time (MAX_VOLTAGE_TIME_SEC = 7200) rather than a variable absorption time based on cell voltage difference.
Depending on length of time since last full charge and depth of discharge, time to achieve acceptable cell voltage difference in Absorption can vary between 15 minutes to 2 hours but averages about 30 minutes. This means holding Bulk Voltage for much longer than is needed.
Describe the solution you'd like
Allow "CVL reset based on cell voltage diff" to operate independently of Linear or Step Mode.
Perhaps with another Boolean CVCM_ALWAYS = TRUE (or CVCM_LINEAR = TRUE) to operate CVCM in Linear Mode but defaults to FALSE to not interfere with existing users use of CVCM
Describe alternatives you've considered
Have tried to use Linear Mode but for reasons described above, have found it to be sub-optimal.
Additional context
Linear & Step Mode is great for controlling adjustments to CVL & CCL but, IMO, its use has been extended beyond its original intent reducing the flexibility that users can make of the later enhancements.
The text was updated successfully, but these errors were encountered: