Wiki source code of 3.5 Battery control
                  Last modified by Admin on 2025/08/11 16:34
              
      Show last authors
| author | version | line-number | content | 
|---|---|---|---|
| 1 | (% data-numbered-headings-start="3" style="--numbered-headings-start: 2;font-size: 0px;color: rgba(0, 0, 0, 0.0);margin-bottom: 0px; margin-top: 0px;" %) | ||
| 2 | = Configuration = | ||
| 3 | |||
| 4 | (% data-numbered-headings-start="5" style="--numbered-headings-start: 4;font-size: 0px;color: rgba(0, 0, 0, 0.0);margin-bottom: 0px; margin-top: 0px;" %) | ||
| 5 | == Battery control == | ||
| 6 | |||
| 7 | === Charging control === | ||
| 8 | |||
| 9 | There are two relays that serve charging the battery: a charging relay and an allow charging relay. With the help of the allow charging relay, the BMS commands the charger to start or stop charging. | ||
| 10 | |||
| 11 | The board supports two charge control algorithms: | ||
| 12 | |||
| 13 | * charging is always allowed; | ||
| 14 | * charging is allowed when there is a signal “Charger connected”. | ||
| 15 | |||
| 16 | If you select the "charging is always allowed" algorithm, the charging relay and the allow charging relay are always closed. If at least one of the errors appears: | ||
| 17 | |||
| 18 | * Overvoltage; | ||
| 19 | * Overcurrent; | ||
| 20 | * High temperature; | ||
| 21 | * Low temperature; | ||
| 22 | * HYG offline (optional); | ||
| 23 | * Combilift offline (optional); | ||
| 24 | * Spirit offline (optional); | ||
| 25 | * Spirit charger error (optional); | ||
| 26 | * Short circuit (optional); | ||
| 27 | * Contactor high temperature (optional); | ||
| 28 | * CH contactor cycles error; | ||
| 29 | * Critical error, | ||
| 30 | |||
| 31 | both relays are open (no current flows). | ||
| 32 | |||
| 33 | When the algorithm "charging is allowed when there is a signal “Charger connected”" is selected, the relay control is performed as follows: | ||
| 34 | |||
| 35 | * If there is a signal “Charger connected” and there are no errors (see the list above), then through the delay time T,,on,, the charging relay and the allow charging relay close; | ||
| 36 | * If the signal “Charger connected” disappears, the allow charging relay opens and after the delay time T,,off,, the charging relay opens; | ||
| 37 | * If in the process of charging the voltage on the cell exceeds the EV level, the allow charging relay opens (while the charging relay remains closed); | ||
| 38 | * If errors in the list above occur the charging relay and allow charging relay open. | ||
| 39 | |||
| 40 | (% class="box infomessage" %) | ||
| 41 | ((( | ||
| 42 | **Note:** When errors occur in the system, the charging relay opens either immediately or with the delay T,,off,, (depends on the settings described below). | ||
| 43 | ))) | ||
| 44 | |||
| 45 | When the power down request occurs, the allow charging relay opens immediately and the charging relay opens after the delay T,,off,,. Reclosing the charging relay and allow charging relay is performed if the power down request is removed. | ||
| 46 | |||
| 47 | To change the parameters of the battery charge control algorithm, select the menu "Cells → Charging control": | ||
| 48 | |||
| 49 | [[image:1754929673129-253.png||data-xwiki-image-style-alignment="center" data-xwiki-image-style-border="true" height="755" width="450"]] | ||
| 50 | |||
| 51 | In this section: | ||
| 52 | |||
| 53 | * Enable – a flag to activate the charge control; | ||
| 54 | * Charging algorithm: | ||
| 55 | ** Always on – charging is always allowed; | ||
| 56 | ** On charger connected – charging is allowed when there is a signal “Charger connected”; | ||
| 57 | ** On charge request – charging is allowed when there is a signal “Charge request”; | ||
| 58 | * Allow charging only when the "Ready to charge" signal is set; | ||
| 59 | * Current indicating charging – a current level to generate the "Charging current present" signal, A; | ||
| 60 | * Current indicating no charging – a current level to clear the "Charging current present" signal, A; | ||
| 61 | * Delay before starting charging – a time delay T,,on,, before closing the charging relay and the allow charging relay, second; | ||
| 62 | * Delay before stopping charging – a time delay T,,off,, before opening the charging relay, second; | ||
| 63 | * Use specific delays before stopping charging (on errors) – a flag to enable manual settings of time delays T,,off,, for specific errors; | ||
| 64 | * Switch off the charging relay on errors without delay – a flag to protectively open the charging relay without delay. In the opposite case, when an error is detected, the charging relay opens always with the delay “Delay before stopping charging”; | ||
| 65 | * Control the precharging relay – a flag to enable control of the precharging relay at charge; | ||
| 66 | * Finish precharge if the battery current is negative – a flag to finish precharge if discharging current occures; | ||
| 67 | * Use actual voltage to generate the "Ready to charge" signal – a flag to disable voltage correction for "Ready to charge" signal; | ||
| 68 | * Use actual voltage to generate the "Ready to charge" signal if the current is negative – a flag to disable voltage correction for "Ready to charge" signal only at discharging current; | ||
| 69 | * Voltage to clear the “Ready to charge” (hence, the “Allow charging”) signal – a threshold U,,ocv,, (corrected due to current and cell resistance) voltage level on the cell, V; if the voltage of any cell is above this level, the “Ready to charge” signal is cleared; | ||
| 70 | * Voltage to reset the “Ready to charge” (hence, the “Allow charging”) signal – a tolerant U,,ocv,, (corrected due to current and cell resistance) voltage level on the cell, V; if all cell voltages are below the tolerant level, the “Ready to charge” signal is set; | ||
| 71 | * Delay before recharging – a time after which the previously opened the allow charging relay closes again, minute; to disable the operation by timeout set "Delay before recharging" to 0. | ||
| 72 | |||
| 73 | (% class="box infomessage" %) | ||
| 74 | ((( | ||
| 75 | **Note:** The "Allow charging" signal appears under two independent conditions: | ||
| 76 | 1) the voltage on the cells reaches the Voltage to reset the “Ready to charge" level and | ||
| 77 | 2) the "Delay before recharging" time has passed since the opening of the allow charging relay. | ||
| 78 | ))) | ||
| 79 | |||
| 80 | === Discharging control === | ||
| 81 | |||
| 82 | The board has a discharging relay to connect battery to the load. | ||
| 83 | |||
| 84 | The board supports two algorithms to control battery discharging: | ||
| 85 | |||
| 86 | * load is always connected; | ||
| 87 | * load is connected when there is no signal “Charger connected”. | ||
| 88 | |||
| 89 | When the algorithm "load is always connected" is selected, the discharging relay is always closed. If at least one of the errors appears: | ||
| 90 | |||
| 91 | * Undervoltage; | ||
| 92 | * Overvoltage (optional); | ||
| 93 | * Overcurrent; | ||
| 94 | * High temperature; | ||
| 95 | * Low temperature (optional); | ||
| 96 | * HYG offline (optional); | ||
| 97 | * Combilift offline (optional); | ||
| 98 | * Spirit offline (optional); | ||
| 99 | * Spirit charger error (optional); | ||
| 100 | * Short circuit (optional); | ||
| 101 | * Contactor high temperature (optional); | ||
| 102 | * DCH contactor cycles error; | ||
| 103 | * Critical error | ||
| 104 | |||
| 105 | the discharging relay opens. | ||
| 106 | |||
| 107 | If you select the algorithm "load is connected when there is no signal “Charger connected”" control relay is as follows: | ||
| 108 | |||
| 109 | * if there is no signal “Charger connected”, the charging relay is opened and there are no errors (see the list above), then through the delay time T,,on,, the discharging relay closes; | ||
| 110 | * If the signal “Charger connected” appears or errors occur (see the list above), then after the delay time T,,off,, the discharging relay opens. | ||
| 111 | |||
| 112 | (% class="box infomessage" %) | ||
| 113 | ((( | ||
| 114 | **Note:** In case of errors in the system operation, the opening of the discharging relay is performed either immediately or with a delay T,,off,, (depends on the settings described below). | ||
| 115 | ))) | ||
| 116 | |||
| 117 | The board supports controlling the precharging relay. The duration of switching on the precharging relay and precharge current threshold before closing the discharging (load) relay are adjustable. | ||
| 118 | |||
| 119 | When the power down request occurs, the discharging relay opens after delay T,,off,,. Reclosing the discharging relay is performed if the power down request is removed. | ||
| 120 | |||
| 121 | To change the parameters of the battery discharge control algorithm, select the menu "Cells → Discharging control": | ||
| 122 | |||
| 123 | [[image:1754929793688-400.png||data-xwiki-image-style-alignment="center" data-xwiki-image-style-border="true"]] | ||
| 124 | |||
| 125 | In this section: | ||
| 126 | |||
| 127 | * Enable – a flag to activate the discharge control; | ||
| 128 | * Discharging algorithm: | ||
| 129 | ** Always on – load is always connected; | ||
| 130 | ** On charger disconnected – load is connected when there is no signal “Charger connected”; | ||
| 131 | ** On discharge request – load is connected when there is a signal “Discharge request”; | ||
| 132 | * Allow discharging only when the "Ready to discharge" signal is set; | ||
| 133 | * Current indicating discharging – a current level to generate the "Discharging current present" signal, А; | ||
| 134 | * Current indicating no discharging – a current level to clear the "Discharging current present" signal, А; | ||
| 135 | * Delay before starting discharging – a time delay T,,on,, before closing the discharging relay, second; | ||
| 136 | * Delay before stopping discharging – a time delay T,,off,, before opening the discharging relay, second; | ||
| 137 | * Use specific delays before stopping discharging (on errors) – a flag to enable manual settings of time delays T,,off,, for specific errors; | ||
| 138 | * Switch off the discharging relay on errors without delay – a flag to protectively open the discharging relay without delay. In the opposite case, when an error is detected, the discharging relay opens always with the delay “Delay before stopping discharging”. | ||
| 139 | * Control the precharging relay – a flag to enable precharge at discharging; | ||
| 140 | * Delay before current measurement – a delay before first current measurement after closing precharge, millisecond; | ||
| 141 | * Precharge time – a duration of closing the precharge relay before closing the discharging relay, millisecond; | ||
| 142 | * Precharge current threshold to start discharging – a minimum current value to finish precharging and start discharge, A; | ||
| 143 | * Keep the precharging relay closed until precharge is finished – a flag to ignore the Precharge time and wait precharging to finish before open precharge relay; | ||
| 144 | * Finish precharge if the battery current is positive – a flag to finish precharge if charging current occures; | ||
| 145 | * Delay before clearing the "Precharge error", second; | ||
| 146 | * Lock the "Precharge error" until the device is reset; | ||
| 147 | * Use actual voltage to generate the "Ready to discharge" signal – a flag to disable voltage correction for "Ready to discharge" signal; | ||
| 148 | * Use actual voltage to generate the "Ready to discharge" signal if the current is positive – a flag to disable voltage correction for "Ready to discharge" signal only at charging current; | ||
| 149 | * Voltage to clear the “Ready to discharge” signal – a threshold U,,ocv,, (corrected due to current and cell resistance) voltage level on the cell, V; if the voltage of any cell is below this level, the “Ready to discharge” signal is cleared; | ||
| 150 | * Voltage to reset the “Ready to discharge” signal – a tolerant U,,ocv,, (corrected due to current and cell resistance) voltage level on the cell, V; if all cells voltages are above the tolerant level, the “Ready to discharge” signal is set. | ||
| 151 | |||
| 152 | === Discharging (AUX) control === | ||
| 153 | |||
| 154 | The BMS Main 2.x board can control the power supply of external equipment using the auxiliary (AUX) discharging relay. An example of external equipment can be an inverter that converts DC to AC to power a service laptop and other devices. | ||
| 155 | |||
| 156 | The power supply circuit of the external equipment using the auxiliary (AUX) discharging relay is independent of the battery load circuit. The closing and opening of the auxiliary (AUX) discharging relay is performed according to its program. | ||
| 157 | |||
| 158 | If the power supply function of the external equipment is enabled, the auxiliary (AUX) discharging relay closes. The opening of this relay occurs on three independent conditions: | ||
| 159 | |||
| 160 | * the battery has low SOC; | ||
| 161 | * the battery voltage is out of range; | ||
| 162 | * the battery system errors are detected. | ||
| 163 | |||
| 164 | To change the parameters of the powering of external equipment, select the menu "Cells → Discharging (AUX) control": | ||
| 165 | |||
| 166 | [[image:1732208939544-710.png||data-xwiki-image-style-alignment="center" data-xwiki-image-style-border="true" height="397" width="445"]] | ||
| 167 | |||
| 168 | In this section: | ||
| 169 | |||
| 170 | * Enable – a flag to activate the auxiliary discharge control; | ||
| 171 | * Switch off the discharging (AUX) relay at when the battery SOC is low: | ||
| 172 | ** Minimum SOC – a minimum SOC value, when reached, the auxiliary (AUX) discharging relay opens, %; | ||
| 173 | ** Tolerant SOC – a permissive SOC value, upon reaching which the auxiliary (AUX) discharging relay re-closes, %; | ||
| 174 | * Switch off the discharging (AUX) relay when the cell voltage is low: | ||
| 175 | ** Minimum cell voltage – a minimum cell voltage, when reached, the auxiliary (AUX) discharging relay opens, %; | ||
| 176 | ** Tolerant cell voltage – a permissive cell voltage, upon reaching which the auxiliary (AUX) discharging relay re-closes, %; | ||
| 177 | * Switch off the discharging (AUX) relay if the battery voltage is out of the range: | ||
| 178 | ** Minimum battery voltage – minimum battery voltage, V; | ||
| 179 | ** Maximum battery voltage – maximum battery voltage, V; | ||
| 180 | * Switch off the discharging (AUX) relay on errors – the auxiliary (AUX) discharging relay opens if the following errors occur: Undervoltage, Overcurrent, High temperature (discharging), Short circuit, Critical error. | ||
| 181 | |||
| 182 | === Charging/Discharging control === | ||
| 183 | |||
| 184 | BMS Main 2.x allows to control charging/discharging contactor that combines algorithms of charging and discharging contactor. It behaves as [[charging>>doc:||anchor="HChargingcontrol"]] contactor when «Charge request» or «Charger connected» are set, otherwise – as [[discharging>>doc:||anchor="HDischargingcontrol"]] contactor. | ||
| 185 | |||
| 186 | To change the parameters of the charging/discharging algorithm, select the menu "Cells → Charging/Discharging control": | ||
| 187 | |||
| 188 | [[image:1732209044117-558.png||data-xwiki-image-style-alignment="center" data-xwiki-image-style-border="true" height="102" width="259"]] | ||
| 189 | |||
| 190 | In this section: | ||
| 191 | |||
| 192 | * Enable – a flag to enable Charging/Discharging contactor controller. | ||
| 193 | |||
| 194 | === Main contactor === | ||
| 195 | |||
| 196 | The BMS Main 2.x has a relay to control the main contactor. The main contactor is usually placed in the common (minus) battery line for opening the charge and discharge circuits in a case of sealing of the charging or discharging contactor. | ||
| 197 | |||
| 198 | The Main contactor algorithm supports the following modes: | ||
| 199 | |||
| 200 | * Always on; | ||
| 201 | * Automatic; | ||
| 202 | * On demand. | ||
| 203 | |||
| 204 | In “Always on” mode main contactor closes if all the following is true: | ||
| 205 | |||
| 206 | * Other contactors are open; | ||
| 207 | * There are no errors from the list below: | ||
| 208 | ** Overcurrent; | ||
| 209 | ** Undervoltage; | ||
| 210 | ** Overvoltage; | ||
| 211 | ** High temperature (charging); | ||
| 212 | ** High temperature (discharging); | ||
| 213 | ** Unallowable charging; | ||
| 214 | ** Critical error. | ||
| 215 | |||
| 216 | In “Always on” mode main contactor opens if all the following is true: | ||
| 217 | |||
| 218 | * Other contactors are open; | ||
| 219 | * There is an error from the the list above. | ||
| 220 | |||
| 221 | In “Automatic” mode, the main contactor closes and opens by internal algorithms at the same time with other contactors. | ||
| 222 | |||
| 223 | In “On demand” mode, the main contactor closes by external the “Close Main contactor” request. | ||
| 224 | |||
| 225 | To change the parameters of the main contactor, select the menu "Cells → Main contactor": | ||
| 226 | |||
| 227 | [[image:1739958553206-813.png||data-xwiki-image-style-alignment="center" data-xwiki-image-style-border="true" height="179" width="410"]] | ||
| 228 | |||
| 229 | In this section: | ||
| 230 | |||
| 231 | * Enable – a flag to enable the main contactor control; | ||
| 232 | * Algorithm – main contactor control algorithm: | ||
| 233 | ** Always on – contactor is always closed; | ||
| 234 | ** Automatic – contactor closes by internal charge and discharge algorithms; | ||
| 235 | ** On demand – contactor is closed by an external request; | ||
| 236 | * Delay before opening the contactor – a time which is used to detect conditions for opening the contactor, second; | ||
| 237 | * Keep the contactor open until the device is reset – a flag for keeping the main contactor opened until the system be reset. | ||
| 238 | |||
| 239 | === Power down control === | ||
| 240 | |||
| 241 | The BMS Main 2.x can command the BMS Power Control board to shut down the battery system if the battery voltage is low or the battery is idle for a long time. The BMS Main 2.x interacts with the BMS Power Control using the “Power down request” and the “Acknowledgement of power down” discrete signals. | ||
| 242 | |||
| 243 | Shutting down the battery system is performed according to the following conditions: | ||
| 244 | |||
| 245 | * the battery voltage is below the minimum level; | ||
| 246 | * the “Charger connected” signal is cleared for 60 seconds. | ||
| 247 | |||
| 248 | The BMS Main 2.x also shuts down the battery if it stays in the “Charging OFF”, “Discharging OFF”, “Relaxed (after charging)” or “Relaxed (after discharging)” for the set time. | ||
| 249 | |||
| 250 | To change the parameters of the power down control, select the menu "Cells → Power down control": | ||
| 251 | |||
| 252 | [[image:1732211675123-235.png||data-xwiki-image-style-alignment="center" data-xwiki-image-style-border="true" height="198" width="402"]] | ||
| 253 | |||
| 254 | In this section: | ||
| 255 | |||
| 256 | * Enable – a flag to enable the power down control; | ||
| 257 | * Minimum voltage – a minimum voltage level of the battery below which the BMS commands to shut down the battery, V; | ||
| 258 | * Idle time – a time of battery inactivity after which the battery is shut down, second; | ||
| 259 | * Wait the "Power up/down request" signal is cleared (on startup) – a flag to enable delay for clearing the “Power up/down request” signal while starting the BMS. | 
 
  