STATE-OF-CHARGE BALANCING WITH PARALLEL AND SERIES OUTPUT CONNECTED BATTERY POWER MODULES

Information

  • Patent Application
  • 20220393485
  • Publication Number
    20220393485
  • Date Filed
    November 18, 2021
    3 years ago
  • Date Published
    December 08, 2022
    2 years ago
Abstract
An apparatus includes a battery pack with N battery bricks, each with a DC output voltage. The output of each brick is connected in series providing a bus voltage. Each brick includes battery power modules (“BPMs”) connected in parallel and each connected to a battery cell. Each BPM charges/discharges the connected battery cell. Each brick has a battery brick controller that provides a control signal to each brick's BPMs. A control signal of a BPM is derived from a BPM error signal that includes a battery cell current of the battery cell of BPM subtracted from a summation of an average current signal, a local droop current and a balancing current. The balancing current is based on a current SOC of the battery cell connected to the BPM and a desired SOC for the battery cell connected to the BPM. A BMS derives the balancing current for the BPMs.
Description
FIELD

This invention relates to parallel and series output connected battery power modules and more particularly relates to state-of-charge balancing with parallel and series output connected battery power modules.


BACKGROUND

Lithium-Ion battery cells and other similar batteries have a relatively low terminal voltage compared to typical high-voltage (“HV”) applications. A typical battery pack often utilizes groups of parallel and series connected cells to increase the overall capacity and voltage. However, non-uniform heat distribution and intrinsic cell mismatches contribute to unequal state-of-health (“SOH”) degradation among the cells, where the role of a battery management system (“BMS”) and state-of-charge (“SOC”) balancing algorithms are critical. Thus, battery packs often employ balancing circuits to control the cells' SOCs.


SUMMARY

An apparatus for modulating battery cell current includes a battery pack that includes a plurality of N battery bricks (“bricks”). An output of each of the N bricks of the battery pack includes a direct current (“DC”) output voltage. Output terminals of each of the N bricks are connected in series and provide a bus voltage. Each of the N bricks includes a plurality of m battery power modules (“BPMs”). Each of the m BPMs has a DC output voltage. Terminals of each of the m BPMs is connected in parallel and together provide the output voltage of each of the N bricks and each of the m BPMs of a jth brick of the N bricks has an input connected to a battery cell. Each of an ith BPM of the m BPMs is controllable to charge and discharge the battery cell connected to the ith BPM. The apparatus includes a battery brick controller for each of the N bricks. The battery brick controller for each of a jth brick of the N bricks is configured to provide a control signal to each of the m BPMs of the jth brick. A control signal of an ith BPM of the m BPMs of the jth brick is derived from a BPM error signal that includes a battery cell current of the battery cell connected to the ith BPM subtracted from a summation of an average current signal, a local droop current and a balancing current. The balancing current is based on a current SOC of the battery cell connected to the ith BPM and a desired SOC for the battery cell connected to the ith BPM. The apparatus includes a BMS configured to derive the balancing current for each of the m BPMs of the N bricks of the battery pack.


Another apparatus for modulating battery cell current includes a battery pack with a plurality of P modular subsystems. Each modular subsystem k of the P modular subsystems includes a plurality of N battery bricks (“bricks”). An output of each of the N bricks of the battery pack includes a DC output voltage. Output terminals of each of the N bricks are connected in series and provide a bus voltage. Each of the N bricks includes a plurality of m BPMs. Each of the m BPMs has a DC output voltage. Output terminals of each of the m BPMs are connected in parallel and together provide the output voltage of each of the N bricks and each of the m BPMs of a jth brick of the N bricks has an input connected to a battery cell. Each of an ith BPM of the m BPMs is controllable to charge and discharge the battery cell connected to the ith BPM. The apparatus includes a battery brick controller for each of the N bricks of the P modular subsystems. The battery brick controller for each of a jth brick of the N bricks is configured to provide a control signal to each of the m BPMs of the jth brick. A control signal of an ith BPM of the m BPMs of the jth brick is derived from a BPM error signal that includes a battery cell current of the battery cell connected to the ith BPM subtracted from a summation of an average current signal, a local droop current and a balancing current. The balancing current is based on a current state-of-charge (“SOC”) of the battery cell connected to the ith BPM and a desired SOC for the battery cell connected to the ith BPM. The apparatus includes a BMS configured to derive the balancing current for each of the m BPMs of the N bricks of the P modular subsystems the battery pack.


Another apparatus for modulating battery cell current includes a battery pack with a plurality of N bricks. An output of each of the N bricks of the battery pack has a DC output voltage and output terminals of each of the N bricks are connected in series and provide a bus voltage. Each of the N bricks has a plurality of m BPMs. Each of the m BPMs has a DC output voltage. Output terminals of each of the m BPMs is connected in parallel and together provide the output voltage of each of the N bricks and each of the m BPMs of a jth brick of the N bricks has an input connected to a battery cell, wherein each of an ith BPM of the m BPMs is controllable to charge and discharge the battery cell connected to the ith BPM. The apparatus includes a battery brick controller for each of the N bricks, the battery brick controller for each of a jth brick of the N bricks is configured to provide a control signal to each of the m BPMs of the jth brick. A control signal of an ith BPM of the m BPMs of the jth brick is derived from a BPM error signal that includes a battery cell current of the battery cell connected to the ith BPM subtracted from a summation of an average current signal, a local droop current and a balancing current, the balancing current based on a current SOC of the battery cell connected to the ith BPM and a desired SOC for the battery cell connected to the ith BPM.


The apparatus includes a BMS configured to derive the balancing current for each of the m BPMs of the N bricks of the battery pack. For each BPM of the m BPMs of the N bricks, the BMS derives the balancing current for an ith, BPM of the m BPMs of the N bricks of the battery pack from current and voltage measurements from the battery cell connected to the ith BPM, the bus voltage, and a target SOC of the battery pack. The local droop current is a product of a droop conductance and an error signal derived from an average voltage subtracted from the output voltage of the jth brick of the N bricks controlled by the battery brick controller. The average voltage comprises the bus voltage divided by the number of bricks N. The average current signal is a product of a SOC compensator and a difference between an average SOC and a SOC reference signal. The average SOC is a total of the SOC for each battery cell connected to a BPM of the m BPMs of the N bricks of the battery pack divided by the number of BPMs mN of the battery pack and the SOC reference signal is derived from a target SOC of the battery pack.





BRIEF DESCRIPTION OF THE DRAWINGS

In order that the advantages of the invention will be readily understood, a more particular description of the invention briefly described above will be rendered by reference to specific embodiments that are illustrated in the appended drawings. Understanding that these drawings depict only typical embodiments of the invention and are not therefore to be considered to be limiting of its scope, the invention will be described and explained with additional specificity and detail through the use of the accompanying drawings, in which:



FIG. 1 is a schematic block diagram illustrating different architectures for a high voltage battery pack where (a) is typical approach with a central DC/DC converter, (b) is battery pack utilizing N series output connected BPMs, and (c) is battery pack employing N series output connected battery bricks with m paralleled BPMs in each;



FIG. 2 is a schematic block diagram illustrating one embodiment of a system-level diagram with (a) a battery pack controller (BMS), and (b) a battery pack with N battery bricks in series;



FIG. 3 is a diagram illustrating one embodiment of a desired droop characteristic for (a) charging behavior, and (b) discharging behavior;



FIG. 4 is a diagram illustrating one embodiment of a desired balancing current relationship vs iall for (a) polarity dependent characteristics for the series output connected bricks, (b) a linear relationship with the common input current reference iall for the series output connected bricks, (c) fixed positive current offset characteristics for the parallel output connected BPMs, and (d) a linear relationship with the modulus of iall for the parallel output connected BPMs;



FIG. 5 is a schematic block diagram of an experimental prototype with (a) four-switch buck-boost converter forming a BPM, (b) three parallel output BPMs forming a brick;



FIG. 6 is a schematic block diagram of an experimental setup and the probed signals depicted in FIG. 7;



FIG. 7 is a diagram of experimental results for the probed signals R(1) to R(5), which is output voltage across the five series output connected bricks vo1 to vo5, probed signal R(6), which is the DC bus voltage vbus, and the probed signal R(7), which is the battery pack output current io;



FIG. 8 is a diagram with experimental results of the bricks with (a) estimated SOCs, and (b) average input currents;



FIG. 9 is a diagram with experimental results of brick 1 with (a) estimated SOCs, and (b) individual BPM currents;



FIG. 10 is a diagram with experimental results of the battery pack with 15 BPMs/battery cells with (a) estimated SOCs, and (b) input currents; and



FIG. 11 is a schematic block diagram illustrating one embodiment of a battery pack with (a) a modular subsystem P, (b) a high voltage battery pack with modular subsystems in series, and (c) a high capacity battery pack with modular subsystems in parallel.





DETAILED DESCRIPTION

Reference throughout this specification to “one embodiment,” “an embodiment,” or similar language means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. Thus, appearances of the phrases “in one embodiment,” “in an embodiment,” and similar language throughout this specification may, but do not necessarily, all refer to the same embodiment, but mean “one or more but not all embodiments” unless expressly specified otherwise. The terms “including,” “comprising,” “having,” and variations thereof mean “including but not limited to” unless expressly specified otherwise. An enumerated listing of items does not imply that any or all of the items are mutually exclusive and/or mutually inclusive, unless expressly specified otherwise. The terms “a,” “an,” and “the” also refer to “one or more” unless expressly specified otherwise.


Furthermore, the described features, structures, or characteristics of the invention may be combined in any suitable manner in one or more embodiments. In the following description, numerous specific details are provided, such as examples of programming, software modules, user selections, network transactions, database queries, database structures, hardware modules, hardware circuits, hardware chips, etc., to provide a thorough understanding of embodiments of the invention. One skilled in the relevant art will recognize, however, that the invention may be practiced without one or more of the specific details, or with other methods, components, materials, and so forth. In other instances, well-known structures, materials, or operations are not shown or described in detail to avoid obscuring aspects of the invention.


The schematic flow chart diagrams included herein are generally set forth as logical flow chart diagrams. As such, the depicted order and labeled steps are indicative of one embodiment of the presented method. Other steps and methods may be conceived that are equivalent in function, logic, or effect to one or more steps, or portions thereof, of the illustrated method. Additionally, the format and symbols employed are provided to explain the logical steps of the method and are understood not to limit the scope of the method. Although various arrow types and line types may be employed in the flow chart diagrams, they are understood not to limit the scope of the corresponding method. Indeed, some arrows or other connectors may be used to indicate only the logical flow of the method. For instance, an arrow may indicate a waiting or monitoring period of unspecified duration between enumerated steps of the depicted method. Additionally, the order in which a particular method occurs may or may not strictly adhere to the order of the corresponding steps shown.


As used herein, a list with a conjunction of “and/or” includes any single item in the list or a combination of items in the list. For example, a list of A, B and/or C includes only A, only B, only C, a combination of A and B, a combination of B and C, a combination of A and C or a combination of A, B and C. As used herein, a list using the terminology “one or more of” includes any single item in the list or a combination of items in the list. For example, one or more of A, B and C includes only A, only B, only C, a combination of A and B, a combination of B and C, a combination of A and C or a combination of A, B and C. As used herein, a list using the terminology “one of” includes one and only one of any single item in the list. For example, “one of A, B and C” includes only A, only B or only C and excludes combinations of A, B and C.


An apparatus for modulating battery cell current includes a battery pack that includes a plurality of N battery bricks (“bricks”). An output of each of the N bricks of the battery pack includes a direct current (“DC”) output voltage. Output terminals of each of the N bricks are connected in series and provide a bus voltage. Each of the N bricks includes a plurality of m battery power modules (“BPMs”). Each of the m BPMs has a DC output voltage. Terminals of each of the m BPMs is connected in parallel and together provide the output voltage of each of the N bricks and each of the m BPMs of a jth brick of the N bricks has an input connected to a battery cell. Each of an ith BPM of the m BPMs is controllable to charge and discharge the battery cell connected to the ith BPM. The apparatus includes a battery brick controller for each of the N bricks. The battery brick controller for each of a jth brick of the N bricks is configured to provide a control signal to each of the m BPMs of the jth brick. A control signal of an ith BPM of the m BPMs of the jth brick is derived from a BPM error signal that includes a battery cell current of the battery cell connected to the ith BPM subtracted from a summation of an average current signal, a local droop current and a balancing current. The balancing current is based on a current SOC of the battery cell connected to the ith BPM and a desired SOC for the battery cell connected to the ith BPM. The apparatus includes a BMS configured to derive the balancing current for each of the m BPMs of the N bricks of the battery pack.


In some embodiments, for each BPM of the m BPMs of the N bricks, the BMS derives the balancing current for an ith BPM of the m BPMs of the N bricks of the battery pack from current and voltage measurements from the battery cell connected to the ith BPM, the bus voltage, and a target SOC of the battery pack. In other embodiments, the local droop current includes a product of a droop conductance and an error signal derived from an average voltage subtracted from the output voltage of the jth brick of the N bricks controlled by the battery brick controller. The average voltage is the bus voltage divided by the number of bricks N.


In some embodiments, the average current signal is a product of a SOC compensator and a difference between an average SOC and a SOC reference signal. The average SOC is a total of the SOC for each battery cell connected to a BPM of the m BPMs of the N bricks of the battery pack divided by the number of BPMs mN of the battery pack and the SOC reference signal is derived from a target SOC of the battery pack. In other embodiments, the SOC reference signal scales linearly with the bus voltage over a first voltage range for charging of the battery cells of the battery pack and scales linearly with the bus voltage over a second voltage range for discharging of the battery cells of the battery pack. The first voltage range is below the second voltage range and the first voltage range and the second voltage range are within an overall voltage regulation range of the bus voltage.


In some embodiments, the balancing current for an ith BPM of a jth brick is derived from scalar configured to limit output current of the BPMs, the average current signal, a SOC of the battery cells connected to the m BPMs of the jth brick, and a SOC of the battery cell connected to the ith BPM. In other embodiments, the average current signal is positive for discharging the battery cells of the battery pack and negative for charging the battery cells of the battery pack and the balancing current for the ith BPM of the m BPMs connected in parallel of a jth brick of the N bricks is positive when the average current signal is positive and negative. In other embodiments, the balancing current scales linearly with the average current signal. In other embodiments, the balancing current of a DPMij ΔIij is:








Δ


I

i

j



=



α
·

i

a

l

l






δ


SOC
j



SOC

brick
,
max




+


α
·



"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"






δ


SOC

i

j




SOC


Max

Cell

,
j







j

N





,


m





where:

    • α is the scalar;
    • iall is the average current signal;





δSOCj=SOCj−SOCavg∀j∈N;

    • SOCj is the SOC for brick j of the N bricks of the battery pack;
    • SOCavg is an average SOC of all battery cells of the battery pack;
    • SOCbrick,max an absolute maximum difference between the SOC of brick j of the N bricks and the average SOC;





δSOCij=SOCij−SOCj∀j∈N,i∈m;

    • SOCij is the SOC of the battery cell connected to BPM i of m BPMs of the brick j; and
    • SOCMaxCell,j is the absolute maximum difference between the SOC of a battery cell connected to BPM i of m BPMs of the brick j and SOCj.


In some embodiments, each BPM is a DC-to-DC converter with switches and the control signal comprises a duty cycle for the switches. In other embodiments, the battery pack also includes P modular subsystems where each modular subsystem includes N bricks and the P modular subsystems are connected in one of series or parallel.


Another apparatus for modulating battery cell current includes a battery pack with a plurality of P modular subsystems. Each modular subsystem k of the P modular subsystems includes a plurality of N battery bricks (“bricks”). An output of each of the N bricks of the battery pack includes a DC output voltage. Output terminals of each of the N bricks are connected in series and provide a bus voltage. Each of the N bricks includes a plurality of m BPMs. Each of the m BPMs has a DC output voltage. Output terminals of each of the m BPMs are connected in parallel and together provide the output voltage of each of the N bricks and each of the m BPMs of a jth brick of the N bricks has an input connected to a battery cell. Each of an ith BPM of the m BPMs is controllable to charge and discharge the battery cell connected to the ith BPM. The apparatus includes a battery brick controller for each of the N bricks of the P modular subsystems. The battery brick controller for each of a jth brick of the N bricks is configured to provide a control signal to each of the m BPMs of the jth brick. A control signal of an ith BPM of the m BPMs of the jth brick is derived from a BPM error signal that includes a battery cell current of the battery cell connected to the ith BPM subtracted from a summation of an average current signal, a local droop current and a balancing current. The balancing current is based on a current state-of-charge (“SOC”) of the battery cell connected to the ith BPM and a desired SOC for the battery cell connected to the ith BPM. The apparatus includes a BMS configured to derive the balancing current for each of the m BPMs of the N bricks of the P modular subsystems the battery pack.


In some embodiments, for each BPM of the m BPMs of the N bricks of the P modular subsystems, the BMS derives the balancing current for an ith BPM of the m BPMs of the N bricks of the P modular subsystems of the battery pack from current and voltage measurements from the battery cell connected to the ith BPM, the bus voltage, and a target SOC of the battery pack. In other embodiments, the local droop current is a product of a droop conductance and an error signal derived from an average voltage subtracted from the output voltage of the jth brick of the N bricks controlled by the battery brick controller. The average voltage is the bus voltage divided by NP when the P modular subsystems are connected in series and is the bus voltage divided by N when the P modular subsystems are connected in parallel.


In some embodiments, the average current signal is a product of a SOC compensator and a difference between an average SOC and a SOC reference signal. The average SOC is a total of the SOC for each battery cell connected to a BPM of the m BPMs of the N bricks of the P modular subsystems of the battery pack divided by the number of BPMs mNP of the battery pack and the SOC reference signal is derived from a target SOC of the battery pack. In other embodiments, the SOC reference signal scales linearly with the bus voltage over a first voltage range for charging of the battery cells of the battery pack and scales linearly with the bus voltage over a second voltage range for discharging of the battery cells of the battery pack. The first voltage range is below the second voltage range and the first voltage range and the second voltage range are within an overall voltage regulation range of the bus voltage.


In some embodiments, the balancing current for an ith BPM of a jth brick of a kth modular subsystem is derived from scalar configured to limit output current of the BPMs, the average current signal, a SOC of the battery cells connected to the m BPMs of the jth brick of the kth modular subsystem, and a SOC of the battery cell connected to the ith BPM. In other embodiments, the average current signal is positive for discharging the battery cells of the battery pack and negative for charging the battery cells of the battery pack and the balancing current for the ith BPM of the m BPMs connected in parallel of a jth brick of the N bricks of a kth modular subsystem is positive when the average current signal is positive and negative. In other embodiments, the balancing current of the ijkth DPM ΔIijk is:








Δ

I


i

j

k


=

{







α

i

all





SOC
k

-

SOC
avg




max

k

P




{



"\[LeftBracketingBar]"



SOC
k

-

SOC
avg




"\[RightBracketingBar]"


}




+

α


i
all





SOC
jk

-

SOC
k




max

j

N




{



"\[LeftBracketingBar]"



SOC
jk

-

SOC
k




"\[RightBracketingBar]"


}












+
α





"\[LeftBracketingBar]"


i
all



"\[RightBracketingBar]"






SOC
ijk

-

SOC
jk




max

i

m




{



"\[LeftBracketingBar]"



SOC
ijk

-

SOC
jk




"\[RightBracketingBar]"


}




,

Series


modular


subsystems








α




"\[LeftBracketingBar]"


i
all



"\[RightBracketingBar]"






SOC
k

-

SOC
avg




max

k

P




{



"\[LeftBracketingBar]"



SOC
k

-

SOC
avg




"\[RightBracketingBar]"


}




+

α


i
all





SOC
jk

-

SOC
k




max

j

N




{



"\[LeftBracketingBar]"



SOC
jk

-

SOC
k




"\[RightBracketingBar]"


}












+
α





"\[LeftBracketingBar]"


i
all



"\[RightBracketingBar]"






SOC
ijk

-

SOC
jk




max

i

m




{



"\[LeftBracketingBar]"



SOC
ijk

-

SOC
jk




"\[RightBracketingBar]"


}




,

Parallel


modular


subsystems










where:

    • α is the scalar;
    • iall is the average current signal;
    • SOCk is the SOC for modular subsystem k of the P modular subsystems of the battery pack;
    • SOCjk is the SOC for the jth brick of the kth modular subsystem of the battery pack;
    • SOCijk is the SOC of the battery cell connected to the ith BPM of jth brick of the kth modular subsystem;
    • SOCavg is an average SOC of all battery cells of the battery pack;
    • maxk∈P{|SOCk−SOCavg|} is an absolute maximum difference between the SOC of the kth modular subsystem and the average SOC;
    • maxj∈N{|SOCjk−SOCk|} is an absolute maximum difference between the SOC of the jth brick of the kth modular subsystem and the SOC of the kth modular subsystem; and
    • maxi∈m{|SOCijk−SOCjk|} is the absolute maximum difference between the SOC of the battery cell connected to the ith BPM of the jth brick of the kth modular subsystem and SOC of the jth brick of the kth modular subsystem.


Another apparatus for modulating battery cell current includes a battery pack with a plurality of N bricks. An output of each of the N bricks of the battery pack has a DC output voltage and output terminals of each of the N bricks are connected in series and provide a bus voltage. Each of the N bricks has a plurality of m BPMs. Each of the m BPMs has a DC output voltage. Output terminals of each of the m BPMs is connected in parallel and together provide the output voltage of each of the N bricks and each of the m BPMs of a jth brick of the N bricks has an input connected to a battery cell, wherein each of an ith BPM of the m BPMs is controllable to charge and discharge the battery cell connected to the ith BPM. The apparatus includes a battery brick controller for each of the N bricks, the battery brick controller for each of a jth brick of the N bricks is configured to provide a control signal to each of the m BPMs of the jth brick. A control signal of an ith BPM of the m BPMs of the jth brick is derived from a BPM error signal that includes a battery cell current of the battery cell connected to the ith BPM subtracted from a summation of an average current signal, a local droop current and a balancing current, the balancing current based on a current SOC of the battery cell connected to the ith BPM and a desired SOC for the battery cell connected to the ith BPM.


The apparatus includes a BMS configured to derive the balancing current for each of the m BPMs of the N bricks of the battery pack. For each BPM of the m BPMs of the N bricks, the BMS derives the balancing current for an ith BPM of the m BPMs of the N bricks of the battery pack from current and voltage measurements from the battery cell connected to the ith BPM, the bus voltage, and a target SOC of the battery pack. The local droop current is a product of a droop conductance and an error signal derived from an average voltage subtracted from the output voltage of the jth brick of the N bricks controlled by the battery brick controller. The average voltage comprises the bus voltage divided by the number of bricks N. The average current signal is a product of a SOC compensator and a difference between an average SOC and a SOC reference signal. The average SOC is a total of the SOC for each battery cell connected to a BPM of the m BPMs of the N bricks of the battery pack divided by the number of BPMs mN of the battery pack and the SOC reference signal is derived from a target SOC of the battery pack.


In some embodiments, the balancing current of a DPMijΔIij is:









Δ

I


i

j


=



α
·

i

a

l

l







δ

SOC

j


SOC

brick
,
max




+


α
·



"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"







δ

SOC


i

j



SOC


Max

Cell

,
j







j

N





,


m





where:

    • α is the scalar;
    • iall is the average current signal;





δSOCj=SOCj−SOCavg∀j∈N;

    • SOCj is the SOC for brick j of the N bricks of the battery pack;
    • SOCavg is an average SOC of all battery cells of the battery pack;
    • SOCbrick,max an absolute maximum difference between the SOC of brick j of the N bricks and the average SOC;





δSOCij=SOCij−SOCj∀j∈N,i∈m;

    • SOCij is the SOC of the battery cell connected to BPM i of m BPMs of the brick j; and
    • SOCMaxCell,j is the absolute maximum difference between the SOC of a battery cell connected to BPM i of m BPMs of the brick j and SOCj.


I. Introduction


FIG. 1(a) shows N series-connected cells that form a battery pack that is interfaced to a high voltage DC (“HVDC”) bus through a DC/DC converter. The kth cell current is the superposition of two components, i.e., ik=ibat+ibk. The common battery current ibat flows into the DC/DC converter. However, ibk is a unique current for each cell that flows into the balancing circuits to regulate the SOC of the cell SOCk. The balancing circuits can be categorized as dissipative or non-dissipative. Dissipative balancing is relatively simple, inexpensive, and inefficient, where the highest SOC cell dissipates energy in a resistor. However, excess energy is conserved with non-dissipative balancing that is more efficient and expensive.


A battery power module (“BPM”) is a DC/DC converter that interfaces an individual battery cell to the DC bus, where the entire cell current flows through the converter, enabling individual cell-level control and non-dissipative balancing. Series output connected BPMs are an emerging solution to replace the HV DC/DC converters in a large battery packs, as shown in FIG. 1(b). SOC balancing between the N series output connected BPMs has been presented, where the BMS regulates the output voltages of the modules. However, the battery pack and the individual BPMs appear as voltage sources that degrade the overall design modularity and paralleling capabilities. A decentralized solution is presented, where all BPMs regulate their output currents. However, the BPMs require output current sensing, and system operation is susceptible to the DC bus disturbances.


Increasing the battery pack capacity is feasible by employing m parallel output connected BPMs that form a brick, where N series output connected bricks achieve the desired HV bus, as shown in FIG. 1(c). Balancing between the m parallel and N series output connected BPMs is demonstrated, as shown in FIG. 1(c). The BMS balances the N series output connected bricks by regulating their output voltages. Within a brick, the m paralleled BPMs utilize a common output voltage loop that generates a reference duty cycle dvN; however, m distinct SOC balancing compensators scale the reference duty cycle dvN to achieve balancing between the BPMs.


The present application presents a simple solution to achieve individual cell SOC control with m parallel and N series output connected BPMs. The balancing strategy relies on differential input current regulation in all BPMs until SOC balancing is achieved. The input current references in the bricks are introduced to track the average SOC of the entire battery pack SOCavg, ensuring SOC balancing among the N series connected battery bricks. However, the current references within the bricks ensure that the BPMs track the average SOC of the brick. Consequently, hierarchical SOC balancing between the series and parallel BPMs is achieved. Therefore, the battery pack behaves as a variable current source, which improves modularity and the paralleling capabilities of the entire battery system. Moreover, the SOC balancing approach relies on the input current sensing circuit that the BMS balancing algorithms utilize. The SOC balancing approach relies on the input current sensing circuit, reducing the system cost and complexity.


II. System Description and Control Architecture


FIG. 2 illustrates a battery pack consisting of N series output connected bricks with a BMS controller. Each battery brick consists of m parallel output connected BPMs, as shown in FIG. 2(b), where the total number of the BPMs in the battery pack is mN. Overall system control functions are distributed between the N bricks and the central controller, as shown in FIG. 2(a) and FIG. 2(b). SOC balancing between all BPMs is achieved by continuously tracking the average SOC of the battery pack SOCavg, which is enabled by regulating the input current of all BPMs. However, the desired current references for the individual BPMs are unique, which are generated in the central controller, as shown in FIG. 2(a).


A. Battery Pack Controller Roles

The battery pack controller (BMS) is responsible for system-level control and cell balancing algorithms, as shown in FIG. 2(a). The BMS acquires all battery cell voltages, currents, and temperatures from the brick controllers through an isolated Controller Area Network (“CAN”) communication bus (dashed lines) at a 1 Hz rate. in some embodiments, the BMS implements a sigma-point Kalman filter (“SPKF”) for SOC estimation. By definition, the N series output connected battery bricks share the same output current. Therefore, balancing between the N battery bricks is feasible as the battery charges or discharges into the HVDC bus. Thus, loads or sources in the DC bus dictate charging or discharging modes that govern an average state-of-charge SOCavg. Consequently, the BMS monitors the bus voltage vbus and utilizes a SOC compensator Gsoc to track the desired (target) average SOC SÕCref that depends on the target application. The SOC compensator output is the common (average) input current reference (average current signal) ĩall in all BPMs to regulate the pack average SOCavg:





{tilde over (τ)}=GSOC(SÕCavg−SÕcref).  (1)


B. Brick Controller Roles

Each of the N bricks, in some embodiments, utilizes a single controller board that enables control and modulation of the m paralleled BPMs, as shown in FIG. 2(b). Each brick controller hosts m independent input current loop compensators Gci to regulate the individual input port currents of the m BPMs. The N brick controllers receive two identical quantities from the BMS, (1) the common input current reference (average current signal) ĩall, and (2) the averaged bus voltage vavg=vbus/N.


Practically, even for balanced SOCs, there are mismatches between the battery cell voltages. Therefore, with a common input current reference in all BPMs in equation (1) the power of each bricks is different, where output voltage mismatches between the N battery bricks introduce a system-level instability. Droop control is utilized, in some embodiments, to stabilize the overall system by sharing the output voltage between the bricks around vavg. Consequently, the jth battery brick controller establishes a local input current reference iref,j, which is obtained by adding a local droop current idj to iall for output voltage-sharing:





{tilde over (ι)}ref,j={tilde over (ι)}all+{tilde over (ι)}dj,  (2)





{tilde over (ι)}dj=Gd({tilde over (v)}avg+{tilde over (v)}oj),  (3)


where Gd is a droop conductance and {tilde over (v)}oj is the jth brick output voltage. At equilibrium, the output current is identical for the N battery bricks. At steady-state, all bricks' output voltages are equal to vavg, where the droop currents are nullified:














j

N




i

d

j


(
t
)


=
0

.




(
4
)







However, each BPM requires a unique differential input current reference ΔIij (e.g. balancing current) to control the individual SOC, which is the backbone for SOC balancing that is discussed below. Therefore, the input current reference of the ith BPM within the jth brick ĩij,ref is:





{tilde over (ι)}ref,ij={tilde over (ι)}ref,j+ΔIij,  (5)


where ĩref,j is the common input current reference in the jth brick, and ΔIij is a differential input current (e.g. balancing current) for SOC control. The input current compensator Gci of the ith BPM within the jth brick adjusts the control command ũij to track the desired battery cell current reference ĩref,ij equation (5). The control command ũij in some embodiments is a duty cycle. The settling times for SOC balancing is significantly longer than the settling times of the current regulation loops.


III. Hierarchical SOC Balancing Mechanism

This section develops the mathematical foundation of the hierarchical SOC balancing strategy between the mN BPMs. Balancing between the mN BPMs, in some embodiments, is achieved in two steps: (1) within each brick, the m paralleled BPMs are balanced when the SOCs of the individual BPMs are equal to the average SOC of the brick, i.e., SOC1j=SOC2j . . . SOCmj, and (2) SOC balancing among the N battery bricks is achieved when the average SOC in each brick is equal to the average SOC in the entire battery pack SOCavg, i.e., SOC1=SOC2 . . . SOCN=SOCavg. In other embodiments, balancing is achieved for all BPMs in a single step. The SOC of any BPM can be expressed in terms of the input current, and cell capacity Q that is assumed equal in all BPMs:












SOC

i

j


(
t
)

=


S

O


C


i

j

,
0



+



δ

SOC


i

j


(
t
)



,




(
6
)
















δ

S

OC


i

j


(
t
)

=

-

1
Q





0
t




i

i

j


(
t
)


dt




,




(
7
)







where SOCij,0, iij, are the initial SOC and input current of the ith BPM in the jth brick, respectively. Within the jth brick, the average SOC of the brick SOCj is determined by the m paralleled BPMs as in equation (8). Similarly, SOCavg is formulated in terms of the initial SOCs of the N series connected battery bricks SOCj,0 and the change in the SOC if the individual battery bricks δSOCj(t) as in equation (10).











SOC
j

(
t
)

=





1
m






i

m



SOC

ij
,
0







SOC

j
,
0



+





1
m






i

m





-
1

Q





0
t




i
ij

(
t
)


dt











δ

SOC


j

(
t
)


.






(
8
)














SOC

a

v

g


(
t
)

=


SOC


a

v

g

,
0


+




δ

SOC


a

v

g


(
t
)

.






(
9
)














SOC

a

v

g


(
t
)

=





1
N






j

N



SOC

j
,
0








SOC


a

v

g

,
0




+








-
1

N






j

N





δ

SOC

j



(
t
)











δ

SOC



a

v

g


(
t
)







(
10
)







Ideally, from equations (7) and 8), SOC balancing between the m paralleled BPMs is possible while keeping the average SOC in the brick SOCj constant, i.e., δSOCj(t)=0, which can be achieved with circulating currents between the BPMs. However, from equations (8) and (10), the change in the SOCs of the N bricks is feasible as SOCavg varies through loads or sources at the HVDC bus. Assuming that all BPMs regulate their input currents with zero steady-state error by following the current reference in the brick, from equation (2), the change in the SOCs in a brick is evaluated:













δSO



C
j

(
t
)


=



1
m






i

M





-
1

Q





0
t




i

ref
,
ij


(
t
)


dt











=




-
1

Q





0
t




i

ref
,
j


(
t
)


dt









=







-
1

Q





0
t



i

a

l

l




(
t
)


dt









δ

SOC



a

v

g


(
t
)



+






-
1

Q





0
t



i
dj



(
t
)


d

t









δ

SOC


dt

(
t
)










(
11
)







by substituting from equations (4) and (11) into equation (10), the change in the average SOC of the entire battery pack δSOCavg is evaluated:












δ

SOC


a

v

g


(
t
)

=




-
1

N






j

N



δ

S

O



C
j

(
t
)




=



-
1

Q





0
t




i

a

l

l


(
t
)



dt
.









(
12
)







From equation (12), it is clear that the change in SOCavg is directly dependent on iall. Moreover, the change in the average SOC of each brick depends on iall, and the droop current that is critical for voltage sharing in equation (3), as expressed in equation (11). However, equal voltage sharing between the N series connected bricks counters SOC balancing because all bricks inject or absorb equal powers. Therefore, the average input current references in the N bricks must be different for individual SOC control. As a result, the change in the average SOC of a brick δSOCj(t) is unique:











δ

S

O



C
j

(
t
)


=




δ

SOC


a

v

g


(
t
)

+




δ

SOC

dj

(
t
)

-

1
Q





0
t


δ



i
j

(
t
)


dt





,




(
13
)







where δij is the input current offset in the jth brick to achieve SOC balancing between the N series output connected bricks.


Within the jth brick, the change in the SOCs of the m BPMs will be equal because δij is introduced to the m paralleled BPMs. Therefore, the current offsets in the m BPMs must be different for individual SOC control. For example, the change in the SOC of the ith BPM within the jth brick δSOCij, is controlled by introducing a current offset δiij. As a result, the change in the average SOC of a BPM is unique:












δ

SOC


i

j


(
t
)

=




δ

SOC

j

(
t
)

-

1
Q





0
t


δ



i

i

j


(
t
)



dt
.








(
14
)







IV. Input Current Offset Restrictions

The previous section has explained the roles of the common input current reference and balancing currents for SOC balancing. This section discusses restrictions in the input current offsets to achieve SOC balancing. The brick controller roles subsection II-B above has discussed the droop loops, which ensure that the N bricks share the DC bus voltage equally at Vavg. Consider the steady-state droop characteristics Vo Io of a two-brick system during charging and discharging modes, as shown in FIG. 3(a) and FIG. 3(b), respectively. At a given output current Io, the characteristics of the two bricks overlap in the middle lines, where the voltage across each brick is equal to Vavg.


With the goal of balancing the average SOCs of the bricks, the balancing current offsets±ΔI must ensure that the highest SOC brick max (SOCj) carries the lowest voltage during charging and the highest voltage during discharging, as shown in FIG. 3(a) and FIG. 3(b), respectively. Therefore, during charging, the current offset in the highest SOC brick ΔImax(socj) is negative, while the current offset in the lowest SOC brick is positive, as shown in FIG. 3(a). However, during discharging, the current offset in the highest SOC brick is positive, while the current offset in the lowest SOC brick is negative, as shown in FIG. 3(b). This behavior is achieved by incorporating the polarity of the common input current reference iall in the desired input current offset for the highest SOC brick, as shown in FIG. 4(a). Furthermore, the rate of change of a brick SOC is proportional to the average input current in the brick, as expressed in equation (13). Thus, to decrease the balancing time, the input current offsets scale linearly with iall instead of utilizing fixed balancing currents, as shown in FIG. 4(b).


On the other hand, the individual current offsets in the m paralleled BPMs within a brick change the individual output currents of the BPMs. In an ideal BPM, the input and output powers are equal:






V
in
I
in
=I
o
V
o,  (15)


where Vo is the output voltage at a given output current Io, Iin is the input current, and Vin is the battery cell voltage across the BPM. If the output voltage is held constant and neglecting the change in the battery cell voltage, the input current offset changes the BPM's output current ΔIo:











Δ

I


i

n


=



V
o


V

i

n






Δ

I

o






(
16
)







where the change in the output port current and the input current offset has the same polarity, i.e., sgn(ΔIo)=sgn(ΔIin). The balancing current offsets in the m paralleled BPMs within a brick ensure that the output current from the highest SOC BPM is the largest in the entire brick during discharging. However, during charging, the absolute value of the output current from the highest SOC BPM is the smallest in the entire brick. Thus, for balancing the m paralleled BPMs within a brick, the input current offset of the highest SOC BPM ΔImax(SOCi,j) is always positive, as shown in FIG. 4(c). Finally, to decrease the balancing time, the input current offsets scale linearly with |iall| instead of utilizing fixed balancing currents, as shown in FIG. 4(d).


V. Balancing

The balancing algorithm calculates the individual current offsets to achieve SOC balancing between the mN BPMs. The balancing algorithm relies on the SOC estimations to achieve SOC balancing in three main steps.


For step one, the algorithm determines the differences in SOCs between the average SOC of the N bricks relative to SOCavg in equation (17):





δSOCj=SOCj−SOCavg∀j∈N.  (17)


Similarly, the algorithm calculates the difference between the SOCs of the m paralleled BPMs relative to their parent brick SOC in equation (18):





δSOCij=SOCij−SOCj∀j∈N,i∈m.  (18)


For step two, the balancing algorithm minimizes the balancing time by a penalizing the brick with the absolute maximum difference in SOC from SOCavg, which is achieved by converting equation (17) to a per-unit quantity:










Δ

p


u
j


=




SOC
j

-

SOC

a

v

g





max

j

N




{



"\[LeftBracketingBar]"



δ

SOC

j



"\[RightBracketingBar]"


}







j


N
.








(
19
)







Similarly, in each of the N bricks, the balancing algorithm utilizes the BPM with the absolute maximum difference in SOC from the brick's average SOC. i.e., SOCj to convert equation (18) to a per-unit quantity:











Δ

p


u

i

j



=




SOC

i

j


-

SOC
j




max

i

m




{



"\[LeftBracketingBar]"



δ

SOC


i

j




"\[RightBracketingBar]"


}







j

N




,

i


m
.






(
20
)







For step three, considering the desired input current offsets' polarities that are discussed in input current offset restrictions, the balancing algorithm converts Δpuj and Δpuij into balancing currents for the individual cells ΔIij:














Δ

I


i

j


=



α
·

i

a

l

l


·


Δ

pu

j


+

α
·



"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"


·


Δ

pu


i

j











=




α
·

i

a

l

l







δ

SOC

j


SOC

brick
,
max




+


α
·



"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"







δ

SOC


i

j



SOC


Max

Cell

,
j







j

N





,


m

,







(
21
)







where α<1 is a scalar that is limited by the ratings of the converters; Thus, the balancing currents are limited to ΔImax as the common current reference approaches ±Imax.


VI. Experimental Results

A 1.5 kilowatt-hours (“kWh”) 1 C-rate battery pack prototype consisting of 15 parallel and series output connected BPMs has been developed. A single BPM employs a 100 watts (“W”) four-switch buck-boost DC/DC converter, as shown in FIG. 5(a). The individual BPMs are connected across 25 amp-hours (“Ah”) battery cells. Moreover, each group of three BPMs forms a battery brick by paralleling the converter outputs. Therefore, the overall battery pack consists of five series output connected battery bricks, as illustrated in FIG. 5(b). Table I summarizes the prototype parameters.









TABLE 1







Experimental Prototype Parameters










Parameter
Value







Battery pack prototype capacity
1.5 kWh



Power rating of the prototype
1.5 kW



Number of BPMs nN
15



Number of battery bricks
5



Number of BPMs in a brick m
3



Battery cell capacity
25 ± 5% Ah



Maximum common current Iall,max
±25 A



Maximum balancing current ΔImax
6 A



Minimum droop gain Gd,min
2 A/V



Maximum droop gain Gd,max
14 A/V










Each battery brick utilizes a Piccolo TMS320F280049 microcontroller for modulation and control of the individual DC/DC converters. The switching frequency of the individual BPMs is 200 kilohertz (“kHz”). During the battery pack startup, all BPMs regulate the cell currents and operate in buck mode to allow a soft-starting mechanism. However, the BPMs operate in boost mode during normal operation. Therefore, the brick controller implements three identical current PI compensators Gci for individual cell current regulation. Each of the three compensators takes the form:











G

c

i


=


K
p

+


K
i

s



.




(
22
)







The input current loop compensator G is designed to achieve a phase margin of 84 degrees and a crossover frequency of 1 kHz, when the three BPMs supply a 300 W resistive load and operate with differential balancing currents at M (D)=2.5. The PI current compensator gains are:











K
i

=
2

,


K
p

=


.001
π

.






(
23
)







A battery pack prototype and a BMS board were created that utilizes a Piccolo® TMS320F280049 microcontroller for system-level control and SOC estimation. The micro-controllers in the BMS and brick controllers establish an isolated CAN communication bus. The BMS communicates with the bricks and acquires the sampled currents, voltages, and temperatures from all BPMs to run the SOC estimation algorithm at 1 Hz rate. Charging and discharging the battery pack is determined by sources and loads at the output terminal, where the BMS determines the target SOC, i.e., SOCref according to the bus voltage:











SOC
ref

[
%
]

=

{




0
,






v
bus


24

,







50


(


v
bus

-
24

)


,





24
<

v
bus


26

,







50


(


v
bus

-
26

)


,





26
<

v
bus


28

,






100
,




28
<

v
bus


32.









(
24
)







Moreover, the BMS computes the average SOC of the battery pack SOCavg, and hosts the average SOC compensator Gcsoc to track SOCref in equation (24). The average SOC compensator Gcsoc takes the form:











G

c

s

o

c


=


(


K

P

s

o

c


+


K
Isoc

s


)



(

1
+

s

2

π


f

p

1





)



(

1
+

s

2

π


f

p

2





)




,




(
25
)







resulting in in a phase margin of 100 degrees and a crossover frequency of 45 Hz, when the three BPMs supply a 300 W resistive load and operate at M(D)=2.5. The gains of the compensator are:











K
Isoc

=

2

0

0


,


K

P

s

o

c


=


1

0

π


,


f

p

1


=

1

0

0

0


,


f

p

2


=

2
0.






(
26
)







The SOC compensator output is the common input current reference iall, which is transmitted to the 15 BPMs over the isolated CAN bus at 2 kHz along with the averaged bus voltage vavg. Finally, the BMS runs the balancing algorithm and transmits the computed current offsets at 1 Hz rate.


An experimental setup was created where a bidirectional supply is connected across the battery pack. The bidirectional supply operates in positive and negative constant current mode with a voltage limit to emulate sources and loads to allow charging and discharging of the battery pack. In this section, a positive battery pack output current is associated with discharging, and a negative battery pack output current is associated with charging.


A. Balancing Between the Series Output Connected Bricks


FIG. 6 depicts the probed voltages and currents in the experiment. The scope captures are depicted in a single figure by using TekScope™ software. FIG. 7 shows the scope traces for the output voltages across the five series output connected bricks, the DC bus voltage vbus, and the output current io. Moreover, FIG. 8 summarizes the individual brick results as acquired through the CAN bus at 1 sec rate. Initially, the individual brick SOCs are 55.1%, 54.2%, 54.6%, 51.6%, and 59.6%, as shown in FIG. 8(a). At the beginning of the test, brick #5 has the highest SOC, and brick #4 has the lowest SOC, where the difference in SOC between the two bricks is 8%.


At 30 s, the battery pack output is enabled by discharging into a 10 amperes (“A”) constant current load, where the DC bus voltage is 25 volts (“V”) that is distributed equally across the five series output connected bricks, as shown in FIG. 7. At 60 s, the SOC balancing algorithm introduces individual brick average input current offsets to achieve SOC balancing between all BPMs. Therefore, the average input current in each brick is different, as shown in FIG. 8(b). as shown in FIG. 8(b). Thus, the output voltages across the five bricks are different and inject different powers while maintaining the same DC bus voltage, as shown in FIG. 7. Therefore, the rates of change in the SOCs between the bricks are different, as shown in FIG. 8(a). The SOC in the 5th brick SOC5 is the highest in the entire battery pack, as shown in FIG. 8(a); thus, the output voltage vo5 is the highest among the five bricks to inject the greatest power into the DC bus, on the other hand, the output voltage vo4 is the lowest among the five bricks to inject the lowest power into the DC bus, as shown in FIG. 7. At 90 s, the bidirectional supply is set to 15 A load, where the average input current reference in all bricks and the input current offsets increase, as shown in FIG. 8(b).


However, at 231 seconds (“s”), the bidirectional supply is set to 5 A with 30 V as a voltage limit in source mode. At 423 s, the bidirectional current in increased to 50 A in source mode. As a result, all BPMs charge from the DC bus, which is held at approximately 27.25 V between 231 s and 423 s interval. Moreover, the input current references and the current offsets are negative to charge the battery cells, as shown in FIG. 8(b). In contrast to the discharging case, the output voltage vo5 is the lowest among the five bricks to absorb the lowest power from the DC bus, whereas the output voltage vo4 is the highest among the five bricks to absorb the highest power from the DC bus, as shown in FIG. 7. At 638 s, the absolute maximum difference in SOC between the lowest and highest SOC bricks is 5.4%.


Between 638 s and 1025 s and 1445 s and 2005 s, the bidirectional source is set to 55 A load, where the battery pack discharges into the DC bus; however, between 1025 s and 1445 s the bidirectional source is set to 30 A in source mode with a 30 V as a maximum voltage limit, as shown in FIG. 7. The balancing current offsets between 638 s and 1025 s and 1445 s and 2005 s are larger than the current offsets between 1025 s and 1445 s because the average input current in the bricks is higher in the discharging intervals, as shown in FIG. 8(b). Moreover, the output voltage vo5 is the highest among the five bricks to during the discharging intervals, whereas the output voltage vo4 is the highest among the five bricks to during the charging intervals, as shown in FIG. 7. Consequently, at 2005 s, the absolute maximum difference in SOC between the lowest and highest SOC bricks is approximately 0.4%.


Between 2005 s and 2693 s, the bidirectional source is set to 50 A in source mode with a 30 V as a maximum voltage limit, which charges the battery pack. Despite the mismatches between the cells capacities, the SPKF algorithm continuously updates the individual cell SOCs; at approximately 2100 s the estimated SOCs in the bricks are updated, where the input current offsets slightly change the average input currents in the bricks, as shown in FIG. 8(b). However, the absolute maximum difference in SOC between the lowest and highest SOC bricks remains within 0.4%. However, the bidirectional source settings are continuously changed to allow charging and discharging the battery pack; thus, SOC balancing among the individual BPMs is achieved. For example, between 2693 s to 2970 s and 3045 s to 3156 s, the bidirectional source is set to 55 A load with 24 V as a minimum DC bus voltage. At 3141 s, regulation is disabled, where the battery pack output current is zero, and the DC bus is held constant at 24 V by the bidirectional source, where the average SOCs in the bricks are balanced within 0.2%. In conclusion, the analysis presented in the previous sections is validated by balancing the series-output connected bricks experimentally.


The particular implementation of the battery pack described above and depicted in FIGS. 5(a) and 5(b) are a single implementation intended to show that the embodiments described herein are feasible. One of skill in the art will recognize that other implementations and designs will use other DC-to-DC converter types, different numbers of BPMs in a brick, different numbers of bricks in series, etc. One of skill in the art will recognize that the DC-to-DC converter of a BPM could be of various topologies, such as a buck-type topology, a boost-type topology, a resonant DC-to-DC converter, or any other converter that is able to convert the voltage of a battery cell into a voltage of a brick. The number of BPMs of a brick varies based on power level of each battery cell, power requirements of the battery pack, and the like. The number of bricks in series, in some embodiments, is selected based on a desired output voltage. One of skill in the art will be able to select various parameters and topologies for battery packs based on available battery cells, a desired bus voltage and power requirements of a load.


VII. Cell-Level SOC Balancing


FIG. 9 shows experimental results for the three BPMs within brick #1 as acquired through the CAN bus at 1 second rate. The initial SOCs for cells #11, #21, and #31 are 52.8%, 51.8%, and 60.8%, respectively. Thus, the absolute difference in SOCs within the brick is 9.1%, and the average SOC in brick #1, i.e., SOC1 is approximately 55.1%, as shown in FIG. 9(a). The average SOC in the brick SOC1 is lower than the average SOC in cell #31, SOC31; however, the average SOC in the brick SOC1 is higher than the estimated SOC in cell #11, SOC11, and cell #21 SOC21, respectively. Therefore, the balancing algorithm introduces the current offsets to the individual cells such that the input current in cell #31, i31 is higher than the average current in the brick i1 during discharging, as shown in FIG. 9(b). However, the balancing algorithm ensures that the absolute value of the current i31 is higher than the absolute value of the average current in the brick i1 during charging, as shown in FIG. 9(b).


Similarly, the input current in cell #11 i11, and the input current in cell #21 i21 are lower than i1 during discharging to inject lower power into the output terminal of the brick. However, i11 and i21 are higher than i1 during charging to absorb more power from the output terminals of the brick. The balancing algorithm introduces the current offsets to the cells until balancing is achieved; thus, at 2005 s the absolute difference in SOCs within the brick is 0.3%. Moreover, the SPKF algorithm continues to update the SOC estimates for all BPMs in the system. Therefore, at 3015 s the absolute difference in SOCs within the brick is 0%, where the input currents in all BPMs within Brick #1 are equal, as shown in FIG. 9(b).



FIG. 10 summarizes the experimental results for the 15 BPMs and all battery cells, which are acquired through the CAN bus at 1 sec rate. At the beginning of the test, the absolute maximum difference in SOC between all battery cells is approximately 10%, as shown in FIG. 10(a). Regulation is enabled at t=2 minutes, where all battery cells tracked the common current reference iall, as shown in FIG. 10(b).However, balancing is enabled at t=3 minutes, where individual current offsets are transmitted to all BPMs, as shown in FIG. 10(b). Therefore, the absolute maximum difference in SOCs between all battery cells is controlled. After t=12 minutes in the test, the absolute maximum difference in SOCs between all battery cells is approximately 8.3%, as shown in FIG. 10(a). The common current reference is significantly low between t=14 and 24 minutes, as shown in FIG. 10(b). As a result, the absolute maximum difference in SOCs between all battery cells remains approximately 7.3% after t=24 minutes. However, between t=24 and 38 minutes, the current in all cells is relatively higher. As a result, at t=38 minutes the absolute maximum difference in SOCs between all battery cells is approximately 2%, as shown in FIG. 10(a). The SPKF algorithm continuously updates the individual cell SOCs for the balancing algorithm. Thus, the balancing algorithm updates the individual cell current offsets to achieve SOC balancing between all cells. At the end of the test, the absolute maximum difference in SOCs between all battery cells is approximately 0.9%, as shown in FIG. 10(a).


VII. SOC Balancing with Parallel and Series Output Connected Battery Modules


The balancing strategy can be applied on higher voltage and capacity battery systems. For instance, FIG. 11(a) depicts a modular battery subsystem with m parallel and N series output connected battery power modules. The total number of BPMs and cells in a modular subsystem is mN. A fully modular battery pack can consist of groups of modular subsystems. Assuming that the number of modular subsystems is P, the number of BPMs and battery cells in the battery pack is mNP. The subsystems can be connected in series to increase the overall output voltage of the battery pack, as shown in FIG. 11(b). Moreover, subsystems can be connected in parallel to increase the overall capacity of the battery pack, as shown in FIG. 11(c). The balancing concept in the original document is still applicable. However, minor modifications are needed according to the system configuration.


Thus, the current reference for the ith BPM within the jth brick and the kth subsystem is:






i
ref;ijk
=i
all+idjk+ΔIijk  (27)


where idjk is droop current in the jth brick and the kth subsystem and ΔIijk is current offset for the ith BPM in the jth brick and the kth subsystem.


A. Modification of the Droop Current

The BMS now averages the entire bus voltage based on the number of bricks connected in series. If the subsystems are connected in series as shown in FIG. 11(b), the average is Vavg=Vbus/(NP). On the other hand, if the subsystems are connected in parallel, as shown in FIG. 11(c), the average is Vavg=Vbus/(N). Thus, the droop current reference for the jth brick and the kth subsystem is:










i
djk

=

{






G
d

(



v
bus

NP

-

v
ojk


)

,

Series


connected


subsystems









G
d

(



v
bus

N

-

v
ojk


)

,

parallel


connected


subsystems










(
28
)







B. Modification of the Cell Balancing Current Offsets

The BMS finds the average SOC in the overall battery pack, in the P subsystems, and the N bricks in each subsystem. The balancing algorithm can be modified to accommodate for balancing as follows:










SOC

a

v

g


=


1
mNP






k
=
1

P





j
=
1

N





i
=
1

m


SOC
ijk









(
29
)







where the average SOC in the subsystem is the average of all cells:










SOC

a

v

g


=


1
P






k
=
1

P


SOC
k







(
30
)







where the average SOC in the subsystem is the average in all subsystems:










SOC
P

=


1
N






j
=
1

N


SOC

j

P








(
31
)







where the average SOC in the subsystem is evaluated for the N bricks in this subsystem:










SOC
NP

=


1
m






i
=
1

m


SOC
iNP







(
32
)







where the average SOC in Brick #N in subsystem #p is evaluated for the BPMs within this brick. Steps for cell balancing, in some embodiments, are as follows:


Step 1

The algorithm determines the differences in SOCs between the average SOC of the P subsystems relative to the average SOC in the entire battery pack SOCavg, where:





δSOCk=SOCk−SOCavg∀k∈P  (33)


(how far is the specific brick from the average in the specific subsystem). Similarly, the algorithm determines the differences in SOCs between the average SOCs in the relative to the average SOC in the subsystem, where they belong:





δSOCjk=SOCjk−SOCk∀j∈N,k∈P  (34)


(how far is this specific brick from the average in the specific subsystem). Similarly, the algorithm determines the differences in SOCs between the SOCs in the individual BPMs to the average SOC in the brick, where they belong:





δSOCijk=SOCijk−SOCj∀i∈m,j∈N,k∈P  (35)


(how far is this specific BPM from the average in the specific brick).


Step 2

The balancing algorithm minimizes the balancing time by penalizing the subsystem with the absolute maximum difference in SOC from SOC average:










Δ

p


u
k


=




SOC
k

-

SOC

a

v

g





max

k

P



{



"\[LeftBracketingBar]"



SOC
k

-

SOC

a

v

g





"\[RightBracketingBar]"


}







k

P







(
36
)







The balancing algorithm minimizes the balancing time by penalizing the brick with the absolute maximum difference in SOC from the average SOC in the subsystem where it belongs:











Δ

p


u

j

k



=




SOC

j

k


-

SOC
k




max

j

N



{



"\[LeftBracketingBar]"



SOC

j

k


-

SOC
k




"\[RightBracketingBar]"


}







j

N




,

k

P





(
37
)







The balancing algorithm minimizes the balancing time by penalizing the BPM with the absolute maximum difference in SOC from the average SOC in the brick where it belongs:











Δ

p


u
ijk


=




SOC
ijk

-

SOC

j

k





max

i

m



{



"\[LeftBracketingBar]"



SOC
ijk

-

SOC

j

k





"\[RightBracketingBar]"


}







i

m




,

j

N

,

k

P





(
38
)







Step 3

Considering the desired input current offsets' polarities that are discussed in Section IV, the balancing algorithm converts Δpuk, Δpujk, and Δpuijk into balancing currents for the individual cells ΔIijk. However, the configuration of the subsystems is critical in this step:










Δ


I
ijk


=

{






α


i

a

l

l



Δ

p


u
k


+

α


i

a

l

l



Δ

p


u

j

k



+

α




"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"



Δ


pu

i

j

k




,

Series


connected


subsystems









α




"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"



Δ


pu
k


+

α


i

a

l

l



Δ

p


u

j

k



+

α




"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"



Δ


pu
ijk



,

Parallel


connected


subsystems










(
39
)














i

m


,

j

N

,

k

P












Δ


I
ijk


=

{





α


i

a

l

l






SOC
k

-

SOC

a

v

g





max

k

P



{



"\[LeftBracketingBar]"



SOC
k

-

SOC

a

v

g





"\[RightBracketingBar]"


}




+

α


i

a

l

l






SOC

j

k


-

SOC
k




max

j

N



{



"\[LeftBracketingBar]"



SOC

j

k


-

SOC
k




"\[RightBracketingBar]"


}




+







α




"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"






SOC
ijk

-

SOC

j

k





max

i

m



{



"\[LeftBracketingBar]"



SOC
ijk

-

SOC

j

k





"\[RightBracketingBar]"


}




,
Series







α




"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"






SOC
k

-

SOC

a

v

g





max

k

P



{



"\[LeftBracketingBar]"



SOC
k

-

SOC

a

v

g





"\[RightBracketingBar]"


}




+

α


i

a

l

l






SOC

j

k


-

SOC
k




max

j

N



{



"\[LeftBracketingBar]"



SOC

j

k


-

SOC
k




"\[RightBracketingBar]"


}




+







α




"\[LeftBracketingBar]"


i

a

l

l




"\[RightBracketingBar]"






SOC
ijk

-

SOC

j

k





max

i

m



{



"\[LeftBracketingBar]"



SOC
ijk

-

SOC

j

k





"\[RightBracketingBar]"


}




,
Parallel









(
40
)







This application focuses on state-of-charge balancing with parallel and series output connected battery power modules (BPMs) in active battery management systems. In contrast to the existing SOC balancing schemes that rely on output voltage regulation, this application employs current regulation instead to enhance modularity and paralleling capabilities in large battery packs. In addition, the proposed method relies on the cell current sensors for balancing, eliminating the need for additional output current sensing circuitry. The BMS regulates all cell currents to a common current reference for average SOC regulation. The BMS balances the individual battery cells by introducing unique current offsets to all BPMs for SOC balancing. The balancing current offsets depend on the common current reference, and the BPMs ratings. The approach is validated experimentally using a 1.5 kWh 1 C-rate active BMS consisting of 15 parallel and series output connected BPMs for a 24 V system. Experimental results prove successful SOC balancing between the 15 battery cells.


The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.

Claims
  • 1. An apparatus comprising: a battery pack comprising a plurality of N battery bricks (“bricks”), an output of each of the N bricks of the battery pack comprising a direct current (“DC”) output voltage, wherein output terminals of each of the N bricks are connected in series and provide a bus voltage, wherein each of the N bricks comprises a plurality of m battery power modules (“BPMs”), each of the m BPMs comprising a DC output voltage, wherein output terminals of each of the m BPMs is connected in parallel and together provide the output voltage of each of the N bricks and each of the m BPMs of a jth brick of the N bricks has an input connected to a battery cell, wherein each of an ith BPM of the m BPMs is controllable to charge and discharge the battery cell connected to the ith BPM;a battery brick controller for each of the N bricks, the battery brick controller for each of a jth brick of the N bricks is configured to provide a control signal to each of the m BPMs of the jth brick, wherein a control signal of an ith BPM of the m BPMs of the jth brick is derived from a BPM error signal comprising a battery cell current of the battery cell connected to the ith BPM subtracted from a summation of an average current signal, a local droop current and a balancing current, the balancing current based on a current state-of-charge (“SOC”) of the battery cell connected to the ith BPM and a desired SOC for the battery cell connected to the ith BPM; anda battery management system (“BMS”) configured to derive the balancing current for each of the m BPMs of the N bricks of the battery pack.
  • 2. The apparatus of claim 1, wherein, for each BPM of the m BPMs of the N bricks, the BMS derives the balancing current for an ith BPM of the m BPMs of the N bricks of the battery pack from current and voltage measurements from the battery cell connected to the ith BPM, the bus voltage, and a target SOC of the battery pack.
  • 3. The apparatus of claim 1, wherein the local droop current comprises a product of a droop conductance and an error signal derived from an average voltage subtracted from the output voltage of the jth brick of the N bricks controlled by the battery brick controller, wherein the average voltage comprises the bus voltage divided by the number of bricks N.
  • 4. The apparatus of claim 1, wherein the average current signal comprises a product of a SOC compensator and a difference between an average SOC and a SOC reference signal, the average SOC comprising a total of the SOC for each battery cell connected to a BPM of the m BPMs of the N bricks of the battery pack divided by the number of BPMs mN of the battery pack and the SOC reference signal is derived from a target SOC of the battery pack.
  • 5. The apparatus of claim 4, wherein the SOC reference signal scales linearly with the bus voltage over a first voltage range for charging of the battery cells of the battery pack and scales linearly with the bus voltage over a second voltage range for discharging of the battery cells of the battery pack, wherein the first voltage range is below the second voltage range and the first voltage range and the second voltage range are within an overall voltage regulation range of the bus voltage.
  • 6. The apparatus of claim 1, wherein the balancing current for an ith BPM of a jth brick is derived from scalar configured to limit output current of the BPMs, the average current signal, a SOC of the battery cells connected to the m BPMs of the jth brick, and a SOC of the battery cell connected to the ith BPM.
  • 7. The apparatus of claim 6, wherein the average current signal is positive for discharging the battery cells of the battery pack and negative for charging the battery cells of the battery pack and the balancing current for the ith BPM of the m BPMs connected in parallel of a jth brick of the N bricks is positive when the average current signal is positive and negative.
  • 8. The apparatus of claim 7, wherein the balancing current scales linearly with the average current signal.
  • 9. The apparatus of claim 6, wherein the balancing current of a DPMij ΔIij is:
  • 10. The apparatus of claim 1, wherein each BPM comprises a DC-to-DC converter with switches and the control signal comprises a duty cycle for the switches.
  • 11. The apparatus of claim 1, wherein the battery pack further comprises P modular subsystems, each modular subsystem comprises N bricks, wherein the P modular subsystems are connected in one of series or parallel.
  • 12. An apparatus comprising: a battery pack comprising a plurality of P modular subsystems, each modular subsystem k of the P modular subsystems comprising a plurality of N battery bricks (“bricks”), an output of each of the N bricks of the battery pack comprising a direct current (“DC”) output voltage, wherein output terminals of each of the N bricks are connected in series and provide a bus voltage, wherein each of the N bricks comprises a plurality of m battery power modules (“BPMs”), each of the m BPMs comprising a DC output voltage, wherein output terminals of each of the m BPMs are connected in parallel and together provide the output voltage of each of the N bricks and each of the m BPMs of a jth brick of the N bricks has an input connected to a battery cell, wherein each of an ith BPM of the m BPMs is controllable to charge and discharge the battery cell connected to the ith BPM;a battery brick controller for each of the N bricks of the P modular subsystems, the battery brick controller for each of a jth brick of the N bricks is configured to provide a control signal to each of the m BPMs of the jth brick, wherein a control signal of an ith BPM of the m BPMs of the jth brick is derived from a BPM error signal comprising a battery cell current of the battery cell connected to the ith BPM subtracted from a summation of an average current signal, a local droop current and a balancing current, the balancing current based on a current state-of-charge (“SOC”) of the battery cell connected to the ith BPM and a desired SOC for the battery cell connected to the ith BPM; anda battery management system (“BMS”) configured to derive the balancing current for each of the m BPMs of the N bricks of the P modular subsystems the battery pack.
  • 13. The apparatus of claim 12, wherein, for each BPM of the m BPMs of the N bricks of the P modular subsystems, the BMS derives the balancing current for an ith BPM of the m BPMs of the N bricks of the P modular subsystems of the battery pack from current and voltage measurements from the battery cell connected to the ith BPM, the bus voltage, and a target SOC of the battery pack.
  • 14. The apparatus of claim 12, wherein the local droop current comprises a product of a droop conductance and an error signal derived from an average voltage subtracted from the output voltage of the jth brick of the N bricks controlled by the battery brick controller, wherein the average voltage is the bus voltage divided by NP when the P modular subsystems are connected in series and is the bus voltage divided by N when the P modular subsystems are connected in parallel.
  • 15. The apparatus of claim 12, wherein the average current signal comprises a product of a SOC compensator and a difference between an average SOC and a SOC reference signal, the average SOC comprising a total of the SOC for each battery cell connected to a BPM of the m BPMs of the N bricks of the P modular subsystems of the battery pack divided by the number of BPMs mNP of the battery pack and the SOC reference signal is derived from a target SOC of the battery pack and wherein the SOC reference signal scales linearly with the bus voltage over a first voltage range for charging of the battery cells of the battery pack and scales linearly with the bus voltage over a second voltage range for discharging of the battery cells of the battery pack, wherein the first voltage range is below the second voltage range and the first voltage range and the second voltage range are within an overall voltage regulation range of the bus voltage.
  • 16. The apparatus of claim 12, wherein the balancing current for an ith BPM of a jth brick of a kth modular subsystem is derived from scalar configured to limit output current of the BPMs, the average current signal, a SOC of the battery cells connected to the m BPMs of the jth brick of the kth modular subsystem, and a SOC of the battery cell connected to the ith BPM.
  • 17. The apparatus of claim 16, wherein the average current signal is positive for discharging the battery cells of the battery pack and negative for charging the battery cells of the battery pack and the balancing current for the ith BPM of the m BPMs connected in parallel of a jth brick of the N bricks of a kth modular subsystem is positive when the average current signal is positive and negative.
  • 18. The apparatus of claim 16, wherein the balancing current of the ijkth DPM ΔIijk is:
  • 19. An apparatus comprising: a battery pack comprising a plurality of N battery bricks (“bricks”), an output of each of the N bricks of the battery pack comprising a direct current (“DC”) output voltage, wherein output terminals of each of the N bricks are connected in series and provide a bus voltage, wherein each of the N bricks comprises a plurality of m battery power modules (“BPMs”), each of the m BPMs comprising a DC output voltage, wherein output terminals of each of the m BPMs is connected in parallel and together provide the output voltage of each of the N bricks and each of the m BPMs of jth brick of the N bricks has an input connected to a battery cell, wherein each of an ith BPM of the m BPMs is controllable to charge and discharge the battery cell connected to the ith BPM;a battery brick controller for each of the N bricks, the battery brick controller for each of a jth brick of the N bricks is configured to provide a control signal to each of the m BPMs of the jth brick, wherein a control signal of an ith BPM of the m BPMs of the jth brick is derived from a BPM error signal comprising a battery cell current of the battery cell connected to the ith BPM subtracted from a summation of an average current signal, a local droop current and a balancing current, the balancing current based on a current state-of-charge (“SOC”) of the battery cell connected to the ith BPM and a desired SOC for the battery cell connected to the ith BPM; anda battery management system (“BMS”) configured to derive the balancing current for each of the m BPMs of the N bricks of the battery pack,wherein, for each BPM of the m BPMs of the N bricks, the BMS derives the balancing current for an ith BPM of the m BPMs of the N bricks of the battery pack from current and voltage measurements from the battery cell connected to the ith BPM, the bus voltage, and a target SOC of the battery pack,wherein the local droop current comprises a product of a droop conductance and an error signal derived from an average voltage subtracted from the output voltage of the jth brick of the N bricks controlled by the battery brick controller, wherein the average voltage comprises the bus voltage divided by the number of bricks N, andwherein the average current signal comprises a product of a SOC compensator and a difference between an average SOC and a SOC reference signal, the average SOC comprising a total of the SOC for each battery cell connected to a BPM of the m BPMs of the N bricks of the battery pack divided by the number of BPMs mN of the battery pack and the SOC reference signal is derived from a target SOC of the battery pack.
  • 20. The apparatus of claim 19, wherein the balancing current of a DPMij ΔIij is:
CROSS-REFERENCES TO RELATED APPLICATIONS

This is a continuation-in-part application of and claims priority to U.S. patent application Ser. No. 17/350,880 entitled “VOLTAGE SHARING OF SERIES CONNECTED BATTERY MODULES IN A PLUG-AND-PLAY DC MICROGRID” and filed on Jun. 17, 2021 for Mohamed Ahmed Kamel Ahmed et. al., which claims priority to U.S. Provisional Patent Application No. 63/040,431 entitled “VOLTAGE SHARING OF SERIES CONNECTED BATTERY MODULES IN A PLUG-AND-PLAY DC MICROGRID” and filed on Jun. 17, 2020 for Mohamed Ahmed Kamel Ahmed et. al., which are incorporated herein by reference.

GOVERNMENT RIGHTS

This invention was made with government support under contract #N00014-16-1-2986 awarded by the Office of Naval Research. The government has certain rights in the invention.

Provisional Applications (1)
Number Date Country
63040431 Jun 2020 US
Continuation in Parts (1)
Number Date Country
Parent 17350880 Jun 2021 US
Child 17529962 US