



Roberto Zanasi 🕩 and Davide Tebaldi \*🕩

"Enzo Ferrari" Department of Engineering, University of Modena and Reggio Emilia, Via Pietro Vivarelli 10 Int. 1, 41125 Modena, Italy; roberto.zanasi@unimore.it

\* Correspondence: davide.tebaldi@unimore.it

Abstract: When performing AC/DC-DC/AC power conversions, multilevel converters provide several advantages as compared to classical two-level converters. This paper deals with the dynamic modeling, control, and robustness assessment of multilevel flying-capacitor converters. The dynamic model is derived using the Power-Oriented Graphs modeling technique, which provides the user with block schemes that are directly implementable in the Matlab/Simulink environment by employing standard Simulink libraries. The performed robustness assessment has led to the proposal of a divergence index, which allows for evaluating the voltage balancing capability of the converter using different voltage vector configurations for the extended operation of the converter, namely when the number of output voltage levels is increased for a given number of capacitors. A new variable-step control algorithm is then proposed. The variable-step control algorithm safely enables the converter extended operation, which prevents voltage balancing issues, even under particularly unfavorable conditions, such as a constant desired output voltage or a sudden load change. The simulation results showing the good performances of the proposed variable-step control as compared to a classical minimum distance approach are finally provided and commented in detail.

**Keywords:** multilevel flying-capacitor converter; dynamic modeling; robustness assessment; control; voltage balancing capability

# 1. Introduction

The need of performing power conversion is present in a large variety of engineering fields. When focusing on electrical power conversions, the cases of DC/DC [1–3], AC/DC-DC/AC [4–6] power conversions can be distinguished. These types of power conversion find application in many areas, including smart grids [1,4,5], hybrid electric vehicles [7], and many others. The physical modeling of the employed power converter topology is of great importance, as it represents the starting point for understanding its dynamic behavior and developing an effective control strategy. This paper deals with the modeling, control and robustness assessment of multilevel flying-capacitor converters.

Multilevel topologies bring several advantages when compared to classical two-level converters, such as a significant distortion reduction in the output voltage waveform and in the drawn input current, a reduction of the dv/dt effect in the output voltage waveform, and the generation of a lower common-mode voltage [8,9]. Furthermore, transformerless grid-connected multilevel converters are largely used in applications, such as motor drives, solid-state power transformers, and photovoltaic systems, as they provide advantages, such as increased power, voltage ratings, and lower harmonic distortion [10,11]. In this latter type of converters, the development of suitable ground potentials models is important, as high ground potentials represents an issue that may affect the converter operation. This matter is addressed in [10,11], together with the creation of local grounding points limiting ground potentials and blocking ground leakage currents from flowing through the host grid grounding, and together with the testing of grounding circuits for the considered



Citation: Zanasi, R.; Tebaldi, D. Modeling Control and Robustness Assessment of Multilevel Flying-Capacitor Converters. *Energies* 2021, *14*, 1903. https://doi.org/ 10.3390/en14071903

Academic Editor: Juri Belikov

Received: 21 February 2021 Accepted: 24 March 2021 Published: 30 March 2021

**Publisher's Note:** MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.



**Copyright:** © 2021 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (https:// creativecommons.org/licenses/by/ 4.0/). application. A vast array of different multilevel converter topologies have been proposed over the years [8,10–12], including diode-clamped converters, flying-capacitors converters, cascaded H-bridge converters, etc. Together with the advantages and potentialities that are brought by multilevel converters comes the difficulty of having more power electronics devices to control. This has led to the development of different modulation algorithms and techniques having different trade-offs between the pros and cons [13,14].

When dealing with the modeling and control of multilevel converters, the choice of the employed modeling approach represents the first step. In [15], the modeling of the Modular Multilevel Matrix Converter ( $M^{3}C$ ) is addressed in a matrix form defining voltage-current model and a power-capacitor voltage model, whereas, in [16], the modeling of a Modular Multilevel Converter is performed using a state-space model, which is next discretized using a forward Euler approximation. In this paper, we address the dynamic modeling of multilevel flying-capacitor converters using the Power-Oriented Graphs (POG) modeling technique [17], extending the modeling approach that was proposed in [12]. The POG technique is one of the main graphical formalisms for modeling physical systems, together with Bond Graphs [18] and Energetic Macroscopic Representation [18]. The POG technique is deemed effective, as it allows for building block diagrams that can be directly implemented in the Matlab/Simulink environment using blocks that are available in basic libraries, and to effectively control the power flows within the system [18]. The proposed approach provides a very compact continuous-time model of the considered multilevel converter which can be applied to other converter topologies as well, and establishes a straightforward way of computing the capacitor voltages and currents starting from the Insulated Gate Bipolar Transistors (IGBTs) switching states. The Readers are referred to [19] for applications of the POG technique to physical systems modeling in different energetic domains, where a web POG modeling program is presented, together with some examples.

Once the modeling is performed, the next step is represented by the control of the considered multilevel converter topology. The subject of multilevel converters control has been largely treated in the literature, by focusing on different converter topologies and aiming at different objectives, depending on the converter topology. In [20], the authors propose an interesting space-vector based approach for modeling modular multilevel converters for battery electric vehicles, showing that the traditional approach for achieving cell balancing can be seen as a special case of the proposed model. In [21], the control of modular multilevel converters is approached using model predictive control that is aided by disturbance observers with the objective of controlling the AC current and suppressing the circulating current in the converter. An asymmetric cascade H-bridge multilevel converter topology that is equipped with a predictive control strategy is instead proposed in [22]. The purpose of the latter is to minimize the converter commutations, while also exploiting the redundant states to equally distribute the load among the switches, thus equalizing their lifetime expectation. Focusing on multilevel topologies having floating capacitors involved in their operation, an important aspect is represented by the capacitors voltages balancing. If not properly controlled, the floating capacitors voltages may suffer from ripple [23], which would cause output voltage and current distortion, or even voltages trajectory divergence, thus further compromising the converter operation. An important distinction needs to be made between those multilevel converters having full floating capacitors voltage balancing capability and those not having it, due to topology limitations or lack of redundancy. This latter case is addressed in [23], where a new PWM method was proposed to improve the floating capacitors voltage balancing capability. Multilevel flying-capacitor converters have full floating capacitors voltage balancing capability if properly controlled and if the number of output voltage levels *m* equals the number of capacitors n plus one (i.e., the number of floating capacitors plus two). An analytical investigation of the voltage balancing characteristics of the flying capacitor converter while using the phase disposition PWM (PDPWM) modulation technique is presented in [24]. An interesting approach to ensure floating capacitors voltage balancing capability is presented in [25], where a modification of the carrier-redistribution PWM (CRPWM) is

proposed in order to ensure a low output voltage harmonic content and low voltage ripple, thanks to the symmetric disposition of carriers in every fundamental period. However, the main drawback that is associated with open-loop methods is that they aim at keeping the floating capacitors voltages as close to the desired value as possible, but do not consider the case of a voltage unbalance occurring because of some unfavorable conditions, such as a fault, for example. In this latter case, a closed-loop control solution is required, in order to drive the capacitors voltages trajectory back to the desired operating point, thus ensuring the correct operation of the converter. The multilevel flying-capacitor converter having a generic number n of capacitors can actually generate all the way up to  $2^n$  output voltage levels, giving rise to what is called "extended operation" [26,27]. However, if the number of voltage levels m is greater than n + 1, then the multilevel flying-capacitor converter loses the property of full floating capacitors voltage balancing capability, and a suitable closed-loop control technique becomes paramount. An example of closed-loop control technique for the multilevel flying-capacitor converter in such operating condition using a "minimum distance" approach is proposed in [27]. However, to the best of our knowledge, there is no proposal in the literature of a metric allowing for performing the robustness assessment of multilevel flying-capacitor converters against the divergence of the flying capacitors voltage trajectory. This becomes especially crucial with the converter working in extended operation, namely with a number *m* of output voltage levels greater than n + 1 all the way up to  $2^n$ . In this paper, we address: (a) the dynamic modeling of multilevel flyingcapacitor converters; (b) the analysis of all the possible configurations of the converter in terms of capacitors voltage ratio allowing for the converter to work in extended operation; (c) the robustness assessment of multilevel flying-capacitor converters when working in extended operation and controlled using a classical minimum distance approach; (d) the proposal of a divergence index determining the degradation of the converter operation using a minimum distance control as the number of output voltage levels is increased for all of the possible capacitors voltages configurations; (e) the proposal of a new variable-step closed-loop control strategy for guaranteeing the best flying capacitors voltage balance in any extended operating condition; and, (f) the comparison of the proposed variablestep control strategy for multilevel flying-capacitor converters with a classical minimum distance control approach.

The remainder of the paper is organized as follows. Section 2 introduces the characteristics and basic properties of the POG modeling technique. Section 3, and the included subsections, address the dynamic modeling of the multilevel flying-capacitor converter. The main matrices and vectors of the model are introduced and described, together with some interesting properties that they exhibit. The model verification against the PLECS simulator is addressed in Section 3.4. Section 4 deals with the control of the multilevel flying-capacitor converter. In particular, Section 4.1 addresses the minimum distance algorithm, whereas Section 4.2 defines the basic configuration of the multilevel flying-capacitor converter. Section 4.3 describes the robustness assessment of the considered converter in extended mode using a minimum distance algorithm, whereas Section 4.4 proposes the new variable-step control algorithm. The converter simulation in extended mode with different dynamic loads is addressed in Section 5. Section 6 finally provides the conclusions of this work.

#### 2. The POG Modeling Technique

The Power-Oriented Graphs (POG) technique [17,18] is a graphical modeling formalism that is based on the same energetic approach employed by the Bond Graph (BG) technique [18] using a different graphical notation. Power-Oriented Graphs are created using two elementary blocks, namely the elaboration block and the connection block, which are shown in Figure 1. The first block is employed for the modeling of all the physical elements storing and/or dissipating energy, whereas the second one is used for the modeling of all the physical elements performing energy conversion. The elaboration block describes static or dynamic physical elements, and is characterized by the transfer function (or matrix) G(s) of the considered element. If the transfer function G(s) = R is constant, then the considered physical element is static, being characterized by the static relation between the input variable  $v_f$  and the output variable  $v_e$  or viceversa. The dynamic elements can be classified into two types:

- *across elements D<sub>e</sub>*, having a flow variable v<sub>f</sub> as input and an across variable v<sub>e</sub> as output;
- *flow elements*  $D_f$ , having an across variable  $v_e$  as input and a flow variable  $v_f$  as output.

A flow power variable  $v_f$  is always defined in each point of the space, whereas an across power variable  $v_e$  is defined between two points. Table 1 provides a compact description of the dynamic and static elements, together with the across and flow variables, in the four typically considered energetic domains. The crossed circle in the upper part of the elaboration block in Figure 1 is a *summation node*, where the black spot on the right denotes that the power variable entering the summation node from that side has to be subtracted. The connection block is characterized by a coefficient (or matrix) *K*, which completely describes the energy conversion between the energetic domains.



Figure 1. POG elementary blocks: *elaboration block* and *connection block*.

Table 1. Physical elements and power variables in the different energetic domains.

|       | Electrical  | Mechanical<br>Translational | Mechanical<br>Rotational  | Hydraulic                            |
|-------|-------------|-----------------------------|---------------------------|--------------------------------------|
| De    | Capacitor C | Mass M                      | Inertia J                 | Hydraulic Capacitor $C_I$            |
| ve    | Voltage V   | Velocity <i>x</i>           | Angular Velocity $\omega$ | Pressure P                           |
| $D_f$ | Inductor L  | Spring E                    | Rotational Spring E       | Hydraulic Inductor<br>L <sub>I</sub> |
| $v_f$ | Current I   | Force F                     | Torque $	au$              | Volume Flow Rate Q                   |
| R     | Resistor R  | Friction <i>b</i>           | Angular Friction b        | Hydraulic Resistor $R_I$             |

One of the main characteristics of the POG modeling technique is the maintained direct correspondence between the power sections in the POG model, as highlighted by the red ellipses in Figure 1, and the power sections of the actual physical system. The scalar product  $\mathbf{x}^{\mathsf{T}}\mathbf{y}$  of the two power variables  $\mathbf{x}$  and  $\mathbf{y}$  in the considered power section has the physical meaning of *power flowing through the considered section*. The black oriented arrows placed at the top of each power section in the scheme of Figure 1 highlight the positive direction of the power flow through the considered section.

Any physical system that is modeled by means of the POG technique is characterized by the following POG state-space representation:

$$\begin{cases} L \dot{x} = A x + B u \\ y = C x + D u \end{cases}$$

where **L** is the energy matrix, **A** is the power matrix, **B** is the input matrix, **C** is the output matrix, and **D** is the input-output matrix. The energy matrix **L** and power matrix **A** describe the instantaneous energy  $E_s$  stored in the system and the instantaneous power  $P_d$  dissipated in the system, respectively:

$$E_s = \frac{1}{2} \mathbf{x}^{\mathrm{T}} \mathbf{L} \mathbf{x}, \qquad P_d = \mathbf{x}^{\mathrm{T}} \mathbf{A}_s \mathbf{x},$$

where  $A_s$  is the symmetric part of matrix A.

## 3. Modeling of the *n*-Dimensional Multilevel Flying-Capacitor Converter

3.1. Physical System and Configuration Vectors

Let us consider the electric scheme of an *n*-dimensional Multilevel Flying-Capacitor Converter that is shown in Figure 2. The output voltage  $V_{out}$  is a function of the IGBTs activation signals  $T_i \in \{0, 1\}$ , for  $i \in \{1, 2, ..., n\}$ . Let  $\mathbf{V}_c$  and  $\mathbf{T}_j$  denote the capacitors voltage column vector and the IGBTs signal row vectors, defined as follows:

$$\mathbf{V}_{c} = \begin{bmatrix} V_{1} \\ V_{2} \\ V_{3} \\ \vdots \\ V_{n} \end{bmatrix}, \qquad \begin{bmatrix} \mathbf{T}_{0} \\ \mathbf{T}_{1} \\ \mathbf{T}_{2} \\ \mathbf{T}_{3} \\ \vdots \\ \mathbf{T}_{m_{c}-2} \\ \mathbf{T}_{m_{c}-1} \end{bmatrix} = \begin{bmatrix} 0 & \dots & 0 & 0 & 0 \\ 0 & \dots & 0 & 0 & 1 \\ 0 & \dots & 0 & 1 & 0 \\ 0 & \dots & 0 & 1 & 1 \\ \vdots & \ddots & \vdots & \vdots & \vdots \\ 1 & \dots & 1 & 1 & 0 \\ 1 & \dots & 1 & 1 & 1 \end{bmatrix} \qquad n = 3 \qquad \begin{bmatrix} \mathbf{I}_{0} \\ \mathbf{T}_{1} \\ \mathbf{T}_{2} \\ \mathbf{T}_{3} \\ \mathbf{T}_{4} \\ \mathbf{T}_{5} \\ \mathbf{T}_{6} \\ \mathbf{T}_{7} \end{bmatrix} = \begin{bmatrix} 0 & 0 & 0 & 0 \\ 0 & 0 & 1 \\ 0 & 1 & 0 \\ 1 & 0 & 1 \\ 1 & 1 & 0 \\ 1 & 1 & 1 \end{bmatrix}, \qquad (1)$$

where  $j \in \{0, 1, ..., m_c - 1\}$ ,  $m_c = 2^n$ , and  $V_i$  are the voltages across the capacitors  $C_i$ . The electrical schemes that are reported in Figure 3 show how, for the case n = 3, the output voltage  $V_{out}$  is a function of the IGBTs signal vectors  $\mathbf{T}_j$  in the two cases  $\mathbf{T}_j = \mathbf{T}_2 = [0 \ 1 \ 0]$  and  $\mathbf{T}_j = \mathbf{T}_6 = [1 \ 1 \ 0]$ .



Figure 2. Electrical scheme of the *n*-dimensional Multilevel Flying-Capacitor Converter.



**Figure 3.** Electrical schemes showing how the output voltage  $V_{out}$  is obtained as a function of the Insulated Gate Bipolar Transistors (IGBTs) signal vectors  $\mathbf{T}_i$  in the two cases  $\mathbf{T}_j = \mathbf{T}_2 = [0\ 1\ 0]$  and  $\mathbf{T}_j = \mathbf{T}_6 = [1\ 1\ 0]$ .

One can easily verify that the output voltage  $V_{out}$  can always be expressed as follows:

$$V_{out} = \mathbf{S}_j \, \mathbf{V}_c, \tag{2}$$

where  $\mathbf{S}_j = [s_1 \ s_2 \ \cdots \ s_n]$ , for  $j \in \{0, 1, \dots, m_c - 1\}$ , are proper configuration vectors. In the two cases of Figure 3, for example, the output voltage  $V_{out}$  can be expressed as in (2) by using the following two configuration vectors:  $\mathbf{S}_2 = [0 \ 1 \ -1]$  and  $\mathbf{S}_6 = [1 \ 0 \ -1]$ . Table 2 shows the relations between the IGBTs signal vectors  $\mathbf{T}_j$ , the output voltage  $V_{out}$  and the configuration vectors  $\mathbf{S}_j$  for the case n = 3, highlighting the connection between vectors  $\mathbf{T}_j$  and  $\mathbf{S}_j$ . One can verify that the following property holds.

**Table 2.** Relations between the IGBTs signal vectors  $\mathbf{T}_{j}$ , the output voltage  $V_{out}$  and the configuration vectors  $\mathbf{S}_{j}$  when n = 3.

| $\mathbf{T}_{j}$      | [ T <sub>1</sub> T <sub>2</sub> T <sub>3</sub> ] | Vout                                         | [s <sub>1</sub> s <sub>2</sub> s <sub>3</sub> ] | $\mathbf{S}_j$ | $V_{out}$ (5) | $\alpha_i$ |
|-----------------------|--------------------------------------------------|----------------------------------------------|-------------------------------------------------|----------------|---------------|------------|
| $\mathbf{T}_0$        | [ 0 0 0]                                         | $\mathbf{S}_0 \mathbf{V}_c = 0$              | [000]                                           | $\mathbf{S}_0$ | 0             | 0          |
| <b>T</b> <sub>1</sub> | [ 0 0 1]                                         | $\mathbf{S}_1 \mathbf{V}_c = V_3$            | [0 0 1]                                         | $\mathbf{S}_1$ | $V_{in}/3$    | 1          |
| <b>T</b> <sub>2</sub> | [ 0 1 0]                                         | $\mathbf{S}_2\mathbf{V}_c=V_2-V_3$           | [ 0 1 -1 ]                                      | $\mathbf{S}_2$ | $V_{in}/3$    | 1          |
| <b>T</b> <sub>3</sub> | [ 0 1 1]                                         | $\mathbf{S}_3 \mathbf{V}_c = V_2$            | [0 1 0]                                         | $\mathbf{S}_3$ | $2V_{in}/3$   | 2          |
| $T_4$                 | [ 1 0 0]                                         | $\mathbf{S}_4\mathbf{V}_c = V_1 - V_2$       | [ 1 -1 0]                                       | $\mathbf{S}_4$ | $V_{in}/3$    | 1          |
| <b>T</b> <sub>5</sub> | [ 1 0 1]                                         | $\mathbf{S}_5\mathbf{V}_c = V_1 - V_2 + V_3$ | [ 1 -1 1]                                       | $\mathbf{S}_5$ | $2V_{in}/3$   | 2          |
| <b>T</b> <sub>6</sub> | [ 1 1 0]                                         | $\mathbf{S}_6\mathbf{V}_c=V_1-V_3$           | [ 1 0-1]                                        | $\mathbf{S}_6$ | $2V_{in}/3$   | 2          |
| <b>T</b> <sub>7</sub> | [ 1 1 1]                                         | $\mathbf{S}_7 \mathbf{V}_c = V_1$            | [1 0 0]                                         | $\mathbf{S}_7$ | $V_{in}$      | 3          |

**Property 1.** For  $j \in \{0, 1, ..., m_c - 1\}$ , the components  $s_i \in \{-1, 0, 1\}$  of the configuration vectors  $\mathbf{S}_j = [s_1 \ s_2 \ \cdots \ s_n]$  can be obtained from the components  $T_i \in \{0, 1\}$  of the IGBTs signal vectors  $\mathbf{T}_j = [T_1 \ T_2 \ \cdots \ T_n]$ , as follows:

$$s_{i} = \begin{cases} T_{1} & \text{if } i = 1, \\ \overline{T}_{i-1} T_{i} - T_{i-1} \overline{T}_{i} & \text{if } i \in \{2, \cdots, n\}, \end{cases}$$
(3)

or, equivalently, as follows:

$$s_{i} = \begin{cases} 1 & if & T_{i} > T_{i-1}, \\ 0 & if & T_{i} = T_{i-1}, \\ -1 & if & T_{i} < T_{i-1}, \end{cases}$$
(4)

for  $i \in \{1, 2, \dots, n\}$  and  $T_0 = 0$ .

As an example, the Reader can verify that Property 1 holds for all of the configuration vectors  $S_i$  that are reported in Table 2 for the case n = 3. The second last column of Table 2 shows the values of the output voltage V<sub>out</sub> corresponding to the following capacitors voltages V<sub>i</sub>:

$$V_1 = V_{in}, \qquad V_2 = \frac{2V_{in}}{3}, \qquad V_3 = \frac{V_{in}}{3} \qquad \Rightarrow \qquad \mathbf{V}_c = \begin{bmatrix} V_{in} \\ \frac{2V_{in}}{3} \\ \frac{V_{in}}{3} \end{bmatrix}.$$
(5)

The last column of Table 2 shows the normalized values  $\alpha_i$ , as defined in Section 3.3, used for representing the equally spaced values of the output voltage  $V_{out}$  in the case of n = 3capacitors and m = 4 output voltage levels.

Let  $S_M$  denote the matrix containing all of the possible configuration vectors  $S_j$ , for  $j \in \{0, 1, \dots, m_c - 1\}$ :

$$\mathbf{S}_{M} = \begin{bmatrix} \mathbf{S}_{0} \\ \mathbf{S}_{1} \\ \vdots \\ \mathbf{S}_{m_{c}-1} \end{bmatrix}, \quad \text{if } n = 3 \quad \mathbf{S}_{M} = \begin{bmatrix} \mathbf{S}_{0} \\ \mathbf{S}_{1} \\ \mathbf{S}_{2} \\ \mathbf{S}_{3} \\ \mathbf{S}_{4} \\ \mathbf{S}_{5} \\ \mathbf{S}_{6} \\ \mathbf{S}_{7} \end{bmatrix} = \begin{bmatrix} 0 & 0 & 0 \\ 0 & 0 & 1 \\ 0 & 1 & -1 \\ 0 & 1 & 0 \\ 1 & -1 & 0 \\ 1 & -1 & 1 \\ 1 & 0 & -1 \\ 1 & 0 & 0 \end{bmatrix}. \quad (6)$$

Matrix  $\mathbf{S}_M$  can always be rewritten in block matrix form as follows:

defined in (7). Matrix  $\mathbf{S}_{M1}$  can be obtained from matrix  $\mathbf{S}_{M0}$ , as follows:

$$\mathbf{S}_{M} = \begin{bmatrix} \mathbf{0} & \mathbf{S}_{M0} \\ \mathbf{1} & \mathbf{S}_{M1} \end{bmatrix} \qquad \stackrel{\text{if } n = 3}{\rightarrow} \qquad \mathbf{S}_{M} = \begin{bmatrix} 0 & 0 & 0 \\ 0 & 0 & 1 \\ 0 & 1 & -1 \\ 0 & 1 & 0 \\ \hline 1 & -1 & 0 \\ 1 & -1 & 1 \\ 1 & 0 & -1 \\ 1 & 0 & 0 \end{bmatrix}. \tag{7}$$

One can verify that the block matrices  $S_{M0}$ ,  $S_{M1} \in \mathbb{R}^{2^{n-1} \times (n-1)}$  satisfy the following property. **Property 2.** Let  $\mathbf{S}_{M0}^{j}$  and  $\mathbf{S}_{M1}^{j}$  denote the *j*-th row of the block matrices  $\mathbf{S}_{M0}$ ,  $\mathbf{S}_{M1} \in \mathbf{R}^{2^{n-1} \times (n-1)}$ 

$$\mathbf{S}_{M1}^{j} = -\mathbf{S}_{M0}^{2^{n-1}+1-j} \qquad for \qquad j \in \left\{1, 2, \cdots, 2^{n-1}\right\}.$$
(8)

Equation (8) means that the rows of matrix  $\mathbf{S}_{M1}$  are equal, with opposite sign, to the rows of matrix  $\mathbf{S}_{M0}$  considered in reverse order.

From Property (2) and Equations (2) and (7), one can verify that the following property holds.

٦

**Property 3.** If the output value  $V_{out1} = \mathbf{S}_j \mathbf{V}_c$  is obtained using the configuration vector  $\mathbf{S}_j$ , then the following conjugate output value

$$V_{out2} = V_{in} - V_{out1} = \mathbf{S}_{m_c-j} \mathbf{V}_{out2}$$

is obtained by employing the configuration vector  $\mathbf{S}_{m_c-j}$ , for  $j \in \{0, 1, \dots, m_c-1\}$  and  $m_c = 2^n$ .

## 3.2. Dynamic Model of the Multilevel Flying-Capacitor Converter

The dynamic model of the Multilevel Flying-Capacitor Converter shown in Figure 2 can be given by using the Power-Oriented Graphs (POG) scheme reported in Figure 4. The corresponding POG state-space equations are the following:

$$\begin{pmatrix} \mathbf{C} \, \dot{\mathbf{V}}_c = \mathbf{A} \, \mathbf{V}_c - \mathbf{S}_j^{\mathrm{T}} \, I_{out} + \mathbf{B} \, V_{in}, \\ V_{out} = \mathbf{S}_j \, \mathbf{V}_c. \end{cases}$$
(9)



Figure 4. Power-Oriented Graphs (POG) model of the Multilevel Flying-Capacitor Converter.

Matrices **C**, **A** and vectors  $\mathbf{V}_c$ ,  $\mathbf{S}_i^{\mathsf{T}}$  and **B** are defined, as follows:

| C  | $\frac{C_1}{0}$ | $\begin{array}{c} 0 & \cdots & 0 \\ \hline C_2 & \cdots & 0 \end{array}$     |     | $\begin{bmatrix} \frac{-1}{R_{in}} \\ 0 \end{bmatrix}$ | 0 0                                                                                    | $\begin{bmatrix} V_1 \\ V_2 \end{bmatrix}$                                                        | $\begin{bmatrix} s_1 \\ s_2 \end{bmatrix}$                       | $\mathbf{P} = \begin{bmatrix} \frac{1}{R_{in}} \\ 0 \end{bmatrix}$ | (10)   |
|----|-----------------|------------------------------------------------------------------------------|-----|--------------------------------------------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------|--------|
| C= | :<br>0          | $\begin{vmatrix} \vdots & \ddots & \vdots \\ 0 & \cdots & C_n \end{vmatrix}$ | , А |                                                        | $\left \begin{array}{c} \vdots & \ddots & \vdots \\ 0 & \cdots & 0 \end{array}\right $ | $\left \begin{array}{c},  \mathbf{v}_{c} = \begin{bmatrix} \vdots \\ V_{n} \end{bmatrix}\right ,$ | $\mathbf{S}_{j} = \begin{bmatrix} \vdots \\ s_{n} \end{bmatrix}$ | $\mathbf{b} = \begin{bmatrix} \vdots \\ 0 \end{bmatrix}$           | . (10) |

A representation such as the one that is shown in (9) and (10) highlights the following interesting features of the system:

- The energy matrix **C** groups together the dynamic physical parameters  $C_i$  for  $i \in \{1, 2, ..., n\}$ , namely the system capacitors.
- The power matrix **A** and the input matrix **B** contain the static physical parameter *R*<sub>*in*</sub>, which is the system input resistance.
- The *configuration vector*  $\mathbf{S}_{j}$  contains the control signals that directly determine how the output current  $I_{out}$  is going to charge/discharge the capacitors through  $\mathbf{I}_{c_0} = \mathbf{S}_{j}^{\mathsf{T}} I_{out}$  and, at the same time, how the output voltage  $V_{out}$  is going to be generated from the capacitors voltages through (2).

Therefore, the proposed POG state-space model allows for the parameters within the system matrices to maintain their physical meaning, and also allows to emphasize the presence of

the configuration vector  $\mathbf{S}_j$ , representing the output of the two control algorithms that are addressed in Section 4.1 and Section 4.4. The POG block scheme that is shown in Figure 4 presents a graphical representation of the dynamic model of the considered system. The vertical dashed lines  $(0, 2), \ldots$ , and (0, 2) present in the POG scheme describe the system power sections: the product of the two power variables characterizing the power section has the physical meaning of "power flowing through the considered power section". The input power  $P_{in} = V_{in} I_{in}$  flows through power section (0) and the output power  $P_{out} = V_{out} I_{out}$ flows through power section (0). The block scheme in between sections (2) and (2) describes the static equation of the input resistance  $R_{in}$ , the block scheme in between sections (2) and (3) describes the interaction between the input resistance  $R_{in}$  and the capacitors  $C_i$ , and the block scheme in between sections (3) and (4) describes the dynamic equations of the capacitors  $C_i$ . Finally, the block scheme in between the capacitors  $C_i$  and the output power section (3).

**Remark 1.** The first vectorial equation of system (9) can be rewritten as follows:

$$\dot{\mathbf{V}}_{c} = \mathbf{C}^{-1} \mathbf{A} \mathbf{V}_{c} \underbrace{-\mathbf{C}^{-1} \mathbf{S}_{j}^{\mathrm{T}} I_{out}}_{\dot{\mathbf{V}}_{c}^{out}} + \mathbf{C}^{-1} \mathbf{B} V_{in}.$$

Vector  $\dot{\mathbf{V}}_{c}^{out} = -\mathbf{C}^{-1}\mathbf{S}_{j}^{T}I_{out}$  is the component of the velocity vector  $\dot{\mathbf{V}}_{c}$  which is due to the presence of the output current  $I_{out}$ . The direction of vector  $\dot{\mathbf{V}}_{c}^{out}$  is completely defined by the configuration vector  $\mathbf{S}_{i}$  and by the values of the capacitors  $C_{i}$ .

**Remark 2.** *The first scalar equation of system* (9) *can be rewritten as follows:* 

$$R_{in}C_1V_1 = V_{in} - V_1 - R_{in}s_1 I_{out}.$$
(11)

Because the value of the input resistance  $R_{in}$  is typically very low, from (11) it follows that  $V_1 \simeq V_{in}$ , that is the value of voltage  $V_1$  tends to remain close to the input voltage value  $V_{in}$ . Hereinafter, the condition  $V_1 = V_{in}$  will be assumed. This condition holds exactly if  $R_{in} \rightarrow 0$ , or if capacitor  $C_1$  is replaced with a battery providing a constant voltage  $V_{in}$ .

#### 3.3. Calculation of All the Configuration Voltage Vectors

I

An *m*-level Multilevel Converter is characterized by *m* different equally spaced values  $V_{oi}$  of the output voltage  $V_{out}$ :

$$V_{oi} = \frac{i V_{in}}{m-1}$$
 for  $i = \{0, 1, ..., m-1\}.$  (12)

In the following, the values  $V_{oi}$  in (12) will often be referred to by using the symbolic integer values  $\alpha_i$ , defined as follows:

$$\alpha_i = \frac{V_{oi}}{K_m} = i$$
 where  $K_m = \frac{V_{in}}{m-1}$ , (13)

for  $i = \{0, 1, ..., m - 1\}$ . From (13), it follows that the product  $\alpha_i K_m$  directly gives the values of the corresponding equally spaced values  $V_{oi}$  of the output voltage  $V_{out}$ . All of the possible values  $V_{oi}$  of the output voltage  $V_{out}$  that can be obtained using a particular voltage vector  $\mathbf{V}_c$  can be expressed as follows:

$$\mathbf{V}_o = \mathbf{S}_M \mathbf{V}_c,\tag{14}$$

where  $\mathbf{S}_M$  is the matrix defined in (6). The considered Flying-Capacitor system acts properly as a Multilevel Converter only if vector  $\mathbf{V}_o = [V_{o1}, V_{o2}, \dots, V_{om_c}]^{\mathsf{T}}$  contains, among its components  $V_{oi}$ , all of the *m* different equally spaced values  $V_{oi}$  given in (12):

$$\forall i \in \{0, 1, \dots, m-1\}, \ \exists V_{oj} \in \{V_{o1}, V_{o2}, \dots, V_{om_c}\} \ | \ V_{oj} = \frac{i V_{in}}{m-1}.$$
(15)

**Definition 1.** Any voltage vector  $\mathbf{V}_c$  satisfying (14) and (15) will be called a "Configuration Voltage Vector of order m" for the Multilevel Flying-Capacitor Converter.

The problem of finding all the Configuration Voltage Vectors  $\mathbf{V}_c$  of order *m* for the considered Multilevel Flying-Capacitor Converter can be solved as follows. Dividing (14) by constant  $K_m$ , one obtains the following symbolic integer relation:

$$\mathbf{V}_L = \mathbf{S}_M \mathbf{V}_m$$
 where  $\mathbf{V}_L = \frac{\mathbf{V}_o}{K_m}$  and  $\mathbf{V}_m = \frac{\mathbf{V}_c}{K_m}$ . (16)

A vector  $\mathbf{V}_m$  in (16) is a Configuration Voltage Vector of order *m* only if all the components  $V_{Lj}$  of vector  $\mathbf{V}_L = [V_{L1}, V_{L2}, \ldots, V_{Lm_c}]$ , for  $j \in \{1, 2, \ldots, m_c\}$ , are integer values  $V_{Lj} \in \{0, 1, \ldots, m-1\}$  that satisfy the following relation:

unique
$$(\{V_{L1}, V_{L2}, \ldots, V_{Lm_c}\}) = \{0, 1, \ldots, m-1\},$$
 (17)

where "unique(S)" is a function providing a new set containing all the elements of set S which are different from each other.

**Property 4.** In (16), all of the components  $\beta_i$  of a Configuration Voltage Vector  $\mathbf{V}_m$ , for  $i \in \{1, ..., n\}$ , are integer values satisfying  $\beta_i \in \{0, 1, ..., m-1\}$ :

$$\mathbf{V}_{m} = \begin{bmatrix} \beta_{n} \\ \beta_{n-1} \\ \vdots \\ \beta_{1} \end{bmatrix} = \begin{bmatrix} m-1 \\ \beta_{n-1} \\ \vdots \\ \beta_{1} \end{bmatrix}, \qquad (18)$$

where  $\beta_{i+1} \ge \beta_i$  for  $i \in \{1, 2, ..., n-2\}$ . Furthermore, note that the top component  $\beta_n$  of vector  $\mathbf{V}_m$  is always given by  $\beta_n = m - 1$ .

The first statement of Property 4 holds true, because: (1) all of the components  $V_{Lj}$  of vector  $\mathbf{V}_L$  in (16) are integer values, see (17); and, (2) the configuration vectors  $\mathbf{S}_1 = [0 \dots, 0, 0, 1]$ ,  $\mathbf{S}_2 = [0 \dots, 0, 1, 0]$ ,  $\mathbf{S}_3 = [0 \dots, 1, 0, 0]$ ,  $\dots$ ,  $\mathbf{S}_{m_c} = [1, 0 \dots, 0, 0]$  are always present among the rows of matrix  $\mathbf{S}_M$ . The second statement of Property 4 holds true, because the top component  $\beta_n$  of vector  $\mathbf{V}_m$  is always equal to the first component  $V_1$  of vector  $\mathbf{V}_c$  expressed in symbolic integer form:  $\beta_n = V_1/K_m = V_{in}/K_m = m - 1$ , see (13). This relation holds thanks to the assumption  $V_1 = V_{in}$  made in Remark 2.

Thanks to Property 4, all of the Configuration Voltage Vectors  $\mathbf{V}_m$  of order *m* for the considered Multilevel Flying-Capacitor Converter can be found by making an exhaustive research in (18) for  $\beta_i \in \{0, 1, ..., m - 1\}$ , and keeping all of the solutions  $\mathbf{V}_m$  that satisfy (16) and (18). Table 3 reports all of the Configuration Voltage Vectors  $\mathbf{V}_m$  for the case n = 3 and for  $m \in \{4, 5, ..., 8\}$ . The total number  $N_c$  of Configuration Voltage Vectors for the case n = 3 is  $N_c = 24$ . Figure 5 shows a graphical representation of the normalized form

 $\overline{\overline{\mathbf{V}}}_m$  of all the Configuration Voltage Vectors  $\mathbf{V}_m$  for the case n = 3. The normalized form  $\overline{\overline{\mathbf{V}}}_m$  of the Voltage Vectors  $\mathbf{V}_m$  defined in (18) is obtained as follows:

$$\overline{\overline{\mathbf{V}}}_{m} = \frac{\mathbf{V}_{m}(2:\text{end})}{m-1} = \begin{bmatrix} \frac{\beta_{n-1}}{m-1} \\ \vdots \\ \frac{\beta_{1}}{m-1} \end{bmatrix} = \begin{bmatrix} \overline{\overline{V}}_{2} \\ \vdots \\ \overline{\overline{V}}_{n} \end{bmatrix} \quad \text{if } n = 3 \\ \rightarrow \quad \overline{\overline{\mathbf{V}}}_{m} = \begin{bmatrix} \overline{\overline{V}}_{2} \\ \overline{\overline{V}}_{3} \end{bmatrix}, \quad (19)$$

meaning that the last n - 1 components of vector  $\mathbf{V}_m$ , from the second to the last one, are normalized by m - 1. Figure 5 clearly shows a symmetry with respect to the red straight line  $\overline{V}_3 = 1 - \overline{V}_2$ . This symmetry is strictly connected to Property 5 and Property 6, introduced in the following.

**Table 3.** All of the Configuration Voltage Vectors  $\mathbf{V}_m$  for the case n = 3 and  $m \in \{4, 5, \dots, 8\}$ .

| т              | 4 | 4 | 4 | 5 | 5 | 5 | 6 | 6 | 6 | 6 | 6 | 6 | 7 | 7 | 7 | 7 | 7 | 7 | 8 | 8 | 8 | 8 | 8 | 8  |
|----------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|
|                | 3 | 3 | 3 | 4 | 4 | 4 | 5 | 5 | 5 | 5 | 5 | 5 | 6 | 6 | 6 | 6 | 6 | 6 | 7 | 7 | 7 | 7 | 7 | 7  |
| $\mathbf{V}_m$ | 1 | 2 | 2 | 2 | 3 | 3 | 2 | 3 | 3 | 4 | 4 | 4 | 3 | 3 | 4 | 4 | 5 | 5 | 3 | 3 | 5 | 6 | 5 | 6  |
|                | 1 | 1 | 2 | 1 | 1 | 2 | 1 | 1 | 2 | 1 | 2 | 3 | 1 | 2 | 1 | 3 | 2 | 3 | 1 | 2 | 1 | 2 | 4 | 4  |
| Νβ             | 2 | 3 | 4 | 3 | 4 | 5 | 3 | 4 | 5 | 5 | 6 | 7 | 4 | 5 | 5 | 7 | 7 | 8 | 4 | 5 | 6 | 8 | 9 | 10 |



**Figure 5.** All the Configuration Voltage Vectors  $\mathbf{V}_m$ , in normalized form  $\overline{\overline{\mathbf{V}}}_m$ , for the case n = 3.

**Property 5.** For every Configuration Voltage Vector  $\mathbf{V}_m$ , there exists a Conjugate Configuration Voltage Vector  $\mathbf{V}_m^*$ , defined as follows:

$$\mathbf{V}_{m} = \begin{bmatrix} m-1\\ \beta_{n-1}\\ \vdots\\ \beta_{2}\\ \beta_{1} \end{bmatrix} \qquad \Rightarrow \qquad \mathbf{V}_{m}^{\star} = \begin{bmatrix} m-1\\ m-1-\beta_{1}\\ m-1-\beta_{2}\\ \vdots\\ m-1-\beta_{n-1} \end{bmatrix}.$$
(20)

*Furthermore, one can easily verify that*  $(\mathbf{V}_m^{\star})^{\star} = \mathbf{V}_m$ *. This property directly follows from Property 3.* 

**Property 6.** Every Configuration Voltage Vector  $V_m$ , see (20), is characterized by a configuration number  $N_\beta$ , defined as follows:

$$N_{\beta} = \sum_{i=1}^{n-1} \beta_i.$$

*The set* C *of all the Configuration Voltage Vectors*  $\mathbf{V}_m$  *can be divided into three different subsets, which are denoted by*  $C_1$ ,  $C_2$ , and  $C_3$ , *defined as follows:* 

$$C_1 = \{ \mathbf{V}_m \in \mathcal{C} | N_\beta < m-1 \}, \quad C_2 = \{ \mathbf{V}_m \in \mathcal{C} | N_\beta = m-1 \}, \quad C_3 = \{ \mathbf{V}_m \in \mathcal{C} | N_\beta > m-1 \}.$$
(21)

The sets  $C_1$  and  $C_3$  are conjugate to one another: if  $\mathbf{V}_m \in C_1$ , then  $\mathbf{V}_m^* \in C_3$  and vice versa. Furthermore, set  $C_2$  is conjugate to itself: if  $\mathbf{V}_m \in C_2$ , then  $\mathbf{V}_m^* = \mathbf{V}_m$ .

**Note**: Table 3 has been given, for each number of output voltage levels *m*, in ascending order from left to right with respect to the configuration number  $N_{\beta}$ . Additionally, the colors that are present in Table 3 denote the subsets to which the Configuration Voltage Vectors  $\mathbf{V}_m$  belong: green color if  $\mathbf{V}_m \in C_1$ , yellow color if  $\mathbf{V}_m \in C_2$ , and blue color if  $\mathbf{V}_m \in C_3$ . The same color notation has been adopted in Figure 5 to identify the subsets to which the normalized forms  $\overline{\mathbf{V}}_m$  of the Configuration Voltage Vectors  $\mathbf{V}_m$  belong, which are highlighted by the colored ellipses.

The number  $N_c$  of Configuration Voltage Vectors  $\mathbf{V}_m$  for the case n = 4 is  $N_c = 407$ . Figure 6 shows a graphical representation of the normalized form  $\overline{\overline{\mathbf{V}}}_m$  of all the Configuration Voltage Vectors  $\mathbf{V}_m$  for the case n = 4. The considerations that are introduced in Property 5 and Property 6 also apply to the set of all the Configuration Voltage Vectors  $\mathbf{V}_m$  for the cases n = 4, n = 5, etc.

## Normalized Voltage Vectors $\overline{\overline{\mathbf{V}}}_m$



**Figure 6.** All of the Configuration Voltage Vectors  $V_m$ , in normalized form  $\overline{V}_m$ , for the case n = 4.

The number  $N_c$  of the Configuration Voltage Vectors  $\mathbf{V}_m$  increases very rapidly by increasing n, with a rate faster than exponential:  $N_c = 24$  for n = 3,  $N_c = 407$  for n = 4,  $N_c = 14252$  for n = 5,  $N_c = 1044305$  for n = 6, etc.

#### 3.4. Model Verification

The model of the multilevel flying-capacitor converter proposed in Figure 4 has been tested in simulation against one of the most well-known platforms for the simulation of power electronics systems, namely PLECS, in order to perform a model verification. For this comparative simulations, the case n = 4 and  $\mathbf{V}_m = [4 \ 3 \ 2 \ 1]^T$  has been considered to be a case study. Figure 7 reports the PLECS model and the system parameters. The initial and desired voltages for the multilevel converter capacitors can be determined by computing the voltage vector  $\mathbf{V}_c$  starting from the configuration voltage vector  $\mathbf{V}_m$  and using (13) and (16), namely  $\mathbf{V}_c = [100 \ 75 \ 50 \ 25]^T$ . The initial conditions of the RLC load are assumed to be equal to zero. The desired voltage  $V_d$  is assumed to be sinusoidal with an offset equal to  $V_{in}/2$ , a peak-to-peak amplitude equal to  $V_{in}$  and a frequency equal to 50 Hz. The simulation performed using the PLECS model in Figure 7 and the simulation performed using the Matlab/Simulink POG model in Figure 4 have both been performed applying the Minimum Distance Control described in Section 4.1.



**Figure 7.** PLECS implementation and parameters of the n = 4 multilevel flying-capacitor converter.

The results that are given by the PLECS model are shown in Figure 8. The comparison of these results with those given by the Matlab/Simulink POG model is reported in Figure 9.



Figure 8. Simulation results given by the PLECS model: output voltage V<sub>out</sub> (upper subplot) and filtered voltage across C<sub>L</sub> (lower subplot).



**Figure 9.** Comparison of the results given by PLECS and Matlab/Simulink: output voltage  $V_{out}$  (upper subplot) and filtered voltage across  $C_L$  (lower subplot).

The very good matching between the output voltage characteristics that are given by PLECS and by Matlab/Simulink in Figure 9 verifies the correctness of the proposed model of the multilevel flying-capacitor converter.

## 4. Control of the Multilevel Flying-Capacitor Converter

## 4.1. Minimum Distance Control

Figure 10 shows the typical scheme of a closed-loop Minimum Distance Control of a Multilevel Flying-Capacitor Converter. The first block of the scheme is the Output Level Generator. Let us consider the case of m = 6 output voltage levels, which will, therefore, be equally spaced between level "0" and level "m - 1 = 5". The black characteristic in Figure 11 shows the desired normalized voltage  $\tilde{V}_d$  multiplied by m - 1, in order to see it superimposed to the blue characteristic, namely the *desired output voltage level*  $\alpha$ .



Figure 10. Typical scheme of a closed-loop Minimum Distance Control of a Multilevel Flying-Capacitor Converter.



**Figure 11.** Desired output voltage level  $\alpha$  superimposed to normalized desired voltage  $\hat{V}_d$  (m - 1).

The Output Level Generator generates an integer value  $\alpha \in \{0, 1, ..., m-1\}$ , which defines the desired output level to be applied at a certain time instant  $t_k$ :

$$\alpha = \sum_{h=0}^{m-1} (V_d \ge V_{cr_h}),$$

where  $(V_d \ge V_{cr_h}) = 1$  if  $V_d \ge V_{cr_h}$  and  $(V_d \ge V_{cr_h}) = 0$  if  $V_d < V_{cr_h}$ . The second and third blocks in the scheme of Figure 10 are the Control Algorithm and the Multilevel Flying-Capacitor Converter. The latter is modeled using the POG block scheme that is shown in Figure 4. Indeed, it is possible to notice the correspondence between the power sections ① and ⑤ in Figures 4 and 10. The purpose of the Control Algorithm is to properly generate the Configuration Voltage Vector  $\mathbf{S}_j$ , which has a one-to-one correspondence with the IGBTs signal vector  $\mathbf{T}_j$  through Property 1, giving the desired output level  $\alpha$ . This will be accomplished by exploiting the redundance of Configuration Voltage Vectors  $\mathbf{S}_j$  generating the same desired output level  $\alpha$  when available, as described in the remainder of this section. The Control Algorithm shown in Figure 10 is typically a "Minimum Distance Algorithm". Thanks to the assumption  $V_1 = V_{in}$  made in Remark 2, the Minimum Distance algorithm only applies to the components  $V_2, V_3, \ldots, V_n$  of the capacitors voltage vector  $\mathbf{V}_c$ . Let us denote, as  $\overline{\mathbf{V}_c} = \mathbf{V}_c(2:n)$ ,  $\overline{\mathbf{V}_{m0}} = K_m \mathbf{V}_m(2:n) = V_{in} \overline{\overline{\mathbf{V}}_m}$  and  $\overline{\mathbf{S}_{Cj}} = -\mathbf{S}_j(2:n)./\mathbf{C}(2:n)$ , the following reduced vectors:

$$\overline{\mathbf{V}}_{c} = \begin{bmatrix} V_{2} \\ V_{3} \\ \vdots \\ V_{n} \end{bmatrix}, \qquad \overline{\mathbf{V}}_{m0} = \begin{bmatrix} \frac{V_{in}\beta_{n-1}}{m-1} \\ \frac{V_{in}\beta_{n-2}}{m-1} \\ \vdots \\ \frac{V_{in}\beta_{1}}{m-1} \end{bmatrix}, \qquad \overline{\mathbf{S}}_{Cj} = \begin{bmatrix} -\frac{s_{2j}}{C_{2}} \\ -\frac{s_{3j}}{C_{3}} \\ \vdots \\ -\frac{s_{nj}}{C_{n}} \end{bmatrix}, \qquad (22)$$

where  $V_m$  is the considered Configuration Voltage Vector that is introduced in (16), and  $S_j$  is the *j*-th configuration vector defined in (10). The minimum distance algorithm tries to

keep the reduced voltage vector  $\overline{\mathbf{V}}_c$  as close as possible to the desired reduced voltage vector  $\overline{\mathbf{V}}_{m0}$ . Let  $\alpha$  be the desired output level to be applied at time  $t_k$  and let

$$\mathcal{S}_{\alpha} = \left\{ j \mid j \in [0, 1, \dots, m_{c} - 1] \land \mathbf{S}_{j} \mathbf{V}_{c} = \frac{\alpha V_{in}}{m - 1} \right\}$$
(23)

be the set of the indexes *j* of all the configuration vectors  $S_j$ , which, for the considered Configuration Voltage Vector  $V_m$ , provide the output level  $\alpha$ . The Minimum Distance algorithm acts as follows:

- 1. At instant  $t_k$ , read the value of the reduced voltage vector  $\overline{\mathbf{V}}_c(t_k)$ ;
- 2. For any  $j \in S_{\alpha}$ , compute the new position  $\overline{\mathbf{V}}_{cj}(t_k + T_W)$  of the reduced voltage vector  $\overline{\mathbf{V}}_c$  at instant  $t_k + T_W$ , which is due to the application of the configuration vector  $\mathbf{S}_j$ :

$$\overline{\mathbf{V}}_{cj}(t_k + T_W) = \overline{\mathbf{V}}_c(t_k) + \underbrace{\overline{\mathbf{S}}_{Cj} \, I_{out} \, T_W}_{\Delta \overline{\mathbf{S}}_{Cj}} = \overline{\mathbf{V}}_c(t_k) + \Delta \overline{\mathbf{S}}_{Cj}, \tag{24}$$

where  $I_{out}$  is the value of the output current at instant  $t_k$  and  $T_W$  is the time for which the configuration vector  $S_j$  is applied.

3. For any  $j \in S_{\alpha}$ , compute the following distance vectors:

$$\Delta \overline{\mathbf{V}}_{cj} = \overline{\mathbf{V}}_{cj} (t_k + T_W) - \overline{\mathbf{V}}_{m0}$$
<sup>(25)</sup>

between points  $\overline{\mathbf{V}}_{cj}(t_k + T_W)$  and the desired reduced Voltage Vector  $\overline{\mathbf{V}}_{m0}$ .

4. At instant  $t_k$ , apply the configuration vector  $\mathbf{S}_{j^*}$ , with  $j^* \in S_{\alpha}$ , for which the norm of vectors  $\Delta \overline{\mathbf{V}}_{cj}$  is minimized:

$$\mathbf{S}_{j^*}$$
 such that  $|\Delta \overline{\mathbf{V}}_{cj^*}| \le |\Delta \overline{\mathbf{V}}_{cj}|$  for  $j \in \mathcal{S}_{\alpha}$ . (26)

Figure 12 shows a graphical example of how the Minimum Distance algorithm works in the case of n = 3, m = 4,  $\mathbf{V}_m = \begin{bmatrix} 3 & 2 & 1 \end{bmatrix}^T$  when the desired output level is  $\alpha = 1$ . In this case, the distance vector  $\Delta \overline{\mathbf{V}}_{cj}$  in (25) having the minimum norm is  $|\Delta \mathbf{V}_{c4}|$ , highlighted in magenta in the figure.

#### 4.2. Basic Configurations

For any *n*-dimensional multilevel flying-capacitor converter, let us denote, as *Basic Configuration Voltage Vector*, the following Configuration Voltage Vector:

$$\mathbf{V}_{m}^{*} = \begin{bmatrix} m-1 & m-2 & \dots & 2 & 1 \end{bmatrix}^{1},$$
 (27)

occurring when m = n + 1.

**Property 7.** For any given *n*, the basic configuration voltage vector  $\mathbf{V}_m^*$  is the only configuration voltage vector for which the Minimum Distance algorithm is able to keep the reduced voltage vector  $\overline{\mathbf{V}}_c$  in the neighborhood of the desired reduced voltage vector  $\overline{\mathbf{V}}_{m0}^*$ , for any value of the normalized desired voltage  $\tilde{V}_d$  and the output current  $I_{out}$ .

This property holds because the Basic Configuration Voltage Vector  $\mathbf{V}_m^*$  is the only one for which the number of possible configurations  $\mathbf{S}_j$  that are associated to the two adjacent levels of any desired voltage  $V_d$  are sufficient to guarantee that, at each PWM step, the distance between the reduced vector  $\mathbf{V}_c$  and the desired reduced voltage vector  $\mathbf{V}_{m0}^*$  is decreased for any value of the output current  $I_{out}$ . For any other Configuration Voltage Vector  $\mathbf{V}_m$ , it is always possible to find values for  $V_d$  and  $I_{out}$  causing the reduced vector  $\mathbf{V}_c$  to indefinitely diverge from the desired reduced voltage vector  $\mathbf{V}_{m0}$ .



**Figure 12.** Calculations of the Minimum Distance algorithm in the case of n = 3, m = 4,  $\mathbf{V}_m = \begin{bmatrix} 3 & 2 & 1 \end{bmatrix}^T$  when the desired output level is  $\alpha = 1$ .

Figure 13 shows a first example of the validity of Property 7, for the case n = 3 and  $\mathbf{V}_m^* = \begin{bmatrix} 3 & 2 & 1 \end{bmatrix}^T$ . In this figure, a certain number of trajectories in the space  $(V_2, V_3)$  starting from initial conditions that are distant from the desired reduced voltage vector  $\overline{\mathbf{V}}_{m0}$  are shown. Red asterisks in the figure denote the considered initial conditions. The trajectories have been obtained using the Minimum Distance algorithm and using the following input signals:

$$V_d = \frac{V_{in}}{2} + \frac{V_{in}}{2}\sin(800\pi t), \qquad I_{out} = 10\,A, \qquad V_{in} = 1\,V.$$
(28)

The figure clearly shows that all of the trajectories asymptotically tend to the desired reduced voltage vector  $\overline{\mathbf{V}}_{m0} = [0.66 \ 0.33]^{\mathrm{T}}$ .

A second similar example is given in Figure 14 for the case n = 4 and  $\mathbf{V}_m^* = \begin{bmatrix} 4 & 3 & 2 & 1 \end{bmatrix}^{\mathsf{T}}$ . The three-dimensional trajectories in the space  $(V_2, V_3, V_4)$  have been obtained using the same input signals (28) that were used for the previous example. Even in this case, one can notice that all of the trajectories asymptotically tend to the desired reduced voltage vector  $\overline{\mathbf{V}}_{m0} = \begin{bmatrix} 0.75 & 0.5 & 0.25 \end{bmatrix}^{\mathsf{T}}$ .



**Figure 13.** Stability of the Basic Configuration Voltage Vector  $\mathbf{V}_m^* = \begin{bmatrix} 3 & 2 & 1 \end{bmatrix}^T$  for n = 3.



**Figure 14.** Stability of the Basic Configuration Voltage Vector  $\mathbf{V}_m^* = \begin{bmatrix} 4 & 3 & 2 & 1 \end{bmatrix}^T$  for n = 4.

4.3. Robustness Assessment of the Configuration Voltage Vectors

All of the Configuration Voltage Vectors  $V_m$  different from the basic one  $V_m^*$  are characterized by divergent voltage trajectories under particularly unfavorable operating

conditions, as stated in Property 7. In Figures 15 and 16, for example, the voltage trajectories that are associated with two different Configuration Voltage Vectors  $\mathbf{V}_m$  in the space  $(V_2, V_3)$  for the case n = 3 are reported, starting from different initial conditions that are distant from the desired reduced voltage vector  $\overline{\mathbf{V}}_{m0}$ . The considered initial conditions are denoted by red asterisks in the figures. The trajectories shown in Figure 15 have been obtained using  $\mathbf{V}_m = \begin{bmatrix} 5 & 4 & 3 \end{bmatrix}^{\mathrm{T}}$ ,  $\overline{\mathbf{V}}_{m0} = \begin{bmatrix} 0.8 & 0.6 \end{bmatrix}^{\mathrm{T}}$ ,  $V_d = 0.3 \mathrm{V}$  and  $I_{out} = 10 \mathrm{A}$ . The trajectories in Figure 16 have been obtained using  $\mathbf{V}_m = \begin{bmatrix} 5 & 3 & 2 \end{bmatrix}^{\mathrm{T}}$ ,  $\overline{\mathbf{V}}_{m0} = \begin{bmatrix} 0.6 & 0.4 \end{bmatrix}^{\mathrm{T}}$ ,  $V_d = 0.7 \mathrm{V}$  and  $I_{out} = 10 \mathrm{A}$ . In both cases, after a transient, all of the trajectories tend to diverge along a particular direction, which is characteristic of the considered Configuration Voltage Vectors  $\mathbf{V}_m$ . One can verify that the same qualitative behavior is obtained for any  $\mathbf{V}_m$  different from the Basic Configuration Voltage Vector  $\mathbf{V}_m^*$ .



**Figure 15.** Instability of the Configuration Voltage Vector  $\mathbf{V}_m = \begin{bmatrix} 5 & 4 & 3 \end{bmatrix}^T$  when  $V_d = 0.3$  and  $I_{out} = 10$  [A].

From the previous considerations, the need to find a criterion to evaluate the degree of divergence of the different Configuration Voltage Vectors  $\mathbf{V}_m$  arises. For this purpose, a *Vectorial Divergence Function*  $\vec{\mathbf{V}}_m(\tilde{V}_d)$  can be defined for each  $\mathbf{V}_m$ . Before giving the definition of this function, the following preliminary material needs to be introduced.

• Given the Configuration Voltage Vectors  $\mathbf{V}_m = [m-1 \ \beta_{n-1} \ \dots \ \beta_2 \ \beta_1]^{\mathsf{T}}$  and the value of the last *n*-th capacitor  $C_n$ , let us choose the values of the remaining n-1 capacitors  $C_1, C_2, \dots, C_{n-1}$ , as follows:

$$C_1 = \frac{\beta_1 C_n}{m-1}, \qquad C_2 = \frac{\beta_1 C_n}{\beta_{n-1}}, \qquad \dots, \qquad C_{n-2} = \frac{\beta_1 C_n}{\beta_3}, \qquad C_{n-1} = \frac{\beta_1 C_n}{\beta_2},$$
 (29)

namely, each capacitor  $C_i$  is chosen inversely proportional to the components of vector  $\mathbf{V}_m$ .

•

lent form by using the following Matlab-like function " $[\mathbf{S}_i, \Delta \overline{\mathbf{V}}] = \mathbf{MDA}(\Delta \overline{\mathbf{V}}, \alpha, I_{out}, T_W)$ ",



which must be called providing  $\Delta \overline{\mathbf{V}} = \overline{\mathbf{V}}_c(t_k) - \overline{\mathbf{V}}_{m0}$ :

**Figure 16.** Instability of the Configuration Voltage Vector  $\mathbf{V}_m = \begin{bmatrix} 5 & 3 & 2 \end{bmatrix}^T$  when  $V_d = 0.7$  and  $I_{out} = 10$  [A].

```
function [\mathbf{S}_{j}, \Delta \overline{\mathbf{V}}] = \mathbf{MDA}(\Delta \overline{\mathbf{V}}, \alpha, I_{out}, T_{W})

Compute set S_{\alpha} defined in (23);

Compute vectors \overline{\mathbf{S}}_{Cj} defined in (22) using (29);

for j \in S_{\alpha}

Compute \Delta \overline{\mathbf{V}}_{cj} as follows, see (25):

\Delta \overline{\mathbf{V}}_{cj} = \Delta \overline{\mathbf{V}} + \overline{\mathbf{S}}_{Cj} I_{out} T_{W};

end

Find j^{*} \in S_{\alpha} for which the norm of vectors \Delta \overline{\mathbf{V}}_{cj} is minimized, as in (26);

Set \mathbf{S}_{j} = \mathbf{S}_{j}^{*};

Set \Delta \overline{\mathbf{V}} = \Delta \overline{\mathbf{V}}_{cj}^{*};
```

**Definition 2.** Given a Configuration Voltage Vector  $\mathbf{V}_m$ , the corresponding Vectorial Divergence Function  $\overrightarrow{\mathbf{V}}_m(\widetilde{V}_d)$  is defined, by employing a Matlab-like notation, as follows:

| $I_{out} = 1;$                                                                                               | % Function normalized with respect to Iout                                  |
|--------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| $T_{PWM} = 1;$                                                                                               | % Function normalized with respect to time                                  |
| $C_n = 1;$                                                                                                   | % Function normalized with respect to $C_n$                                 |
| <b>for</b> $\tilde{V}_d = (0: 1/N_{Points}: 1)$                                                              | % $N_{Points}$ of variable $\tilde{V}_d \in [0, 1]$                         |
| $V_D = \tilde{V}_d(m-1);$                                                                                    | % $N_{Points}$ of variable $V_D \in [0, m-1]$                               |
| $\alpha_H = ceil(V_D);$                                                                                      | % Upper adjacent level                                                      |
| $\alpha_L = floor(V_D);$                                                                                     | % Lower adjacent level                                                      |
| $d_c = V_D - \alpha_L;$                                                                                      | % Duty cycle of the upper level                                             |
| $\Delta \overline{\mathbf{V}} = 0;$                                                                          | % Zero initial condition                                                    |
| for $h = 1 : N_{Steps}$                                                                                      | % Repeat N <sub>Steps</sub> times                                           |
| $T_W = d_c T_{PWM}$                                                                                          | % Time interval of the upper level                                          |
| $[\sim, \Delta \overline{\mathbf{V}}] = \mathbf{MDA}(\Delta \overline{\mathbf{V}}, \alpha_H, I_{out}, T_W);$ | % Upper level Minimum Distance Algorithm                                    |
| $T_W = (1 - d_c)T_PWM$                                                                                       | % Time interval of the lower level                                          |
| $[\sim, \Delta \overline{\mathbf{V}}] = \mathbf{MDA}(\Delta \overline{\mathbf{V}}, \alpha_L, I_{out}, T_W);$ | % Lower level Minimum Distance Algorithm                                    |
| end                                                                                                          |                                                                             |
| $\overrightarrow{\mathbf{V}}_{m}(\widetilde{V}_{d}) = \Delta \overline{\mathbf{V}} / N_{Steps};$             | % Function $\overrightarrow{\mathbf{V}}_m$ is defined in point $	ilde{V}_d$ |
| end                                                                                                          |                                                                             |

The precision of calculation of function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$  increases if the values of parameters  $N_{Points}$  and  $N_{Steps}$  increase. The Vectorial Divergence Function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$  satisfies the following properties.

**Property 8.** The Vectorial Divergence Function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$  of all the Basic Configuration Voltage Vectors  $\mathbf{V}_m^*$  is zero for any value of variable  $\tilde{V}_d = [0 \ 1]$ :

$$\overrightarrow{\mathbf{V}}_m(\widetilde{V}_d) = 0$$
 for  $\widetilde{V}_d = [0, 1].$ 

This property holds as a direct consequence of Property 7.

**Property 9.** The Vectorial Divergence Function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$  satisfies the following symmetry with respect to the value  $\tilde{V}_d = 0.5$ :

$$\overrightarrow{\mathbf{V}}_m(\widetilde{V}_d) = -\overrightarrow{\mathbf{V}}_m(1-\widetilde{V}_d), \quad for \quad \widetilde{V}_d \in [0, 0.5].$$

This property holds as a direct consequence of Property 3. Property 9 implies the symmetry of the Vectorial Divergence Function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$  with respect to the origin. Figure 17 gives an example showing two different graphical representations of the Vectorial Divergence Function  $\mathbf{V}_m(\tilde{V}_d)$  that is associated with all of the Configuration Voltage Vectors  $V_m$  for the case n = 3,  $N_{Points} = 400$  and  $N_{Steps} = 200$ . The left subplot shows the norm  $|\vec{\mathbf{V}}_m(\tilde{V}_d)|$  of the Vectorial Divergence Function versus  $\tilde{V}_d \in [0, 0.5]$ . The function  $|\vec{\mathbf{V}}_m(\tilde{V}_d)|$  has not been plotted for  $\tilde{V}_d \in [0.5, 1]$ , because of the symmetry defined in Property 9. The right subplot of Figure 17 shows the Vectorial Divergence Function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$  on plane  $(V_2, V_3)$ . This subplot clearly shows the symmetry of function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$ with respect to the origin, as stated in Property 9. The two digit numbers "*m.i*", which are present for each characteristic in the two subplots of Figure 17, denote the number *m* of output levels and the order *i* of the Configuration Voltage Vector  $\mathbf{V}_m$  of the nearby colored line, according to the order and the colors reported in Figure 18. The two subplots of Figure 17 clearly show that the norm  $|\vec{\mathbf{V}}_m(\tilde{V}_d)|$  of the Vectorial Divergence Function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$  tends to increase with the number *m* of the output levels and, therefore, it can be used as a starting point to estimate the degree of divergence and, thus, the degradation of the voltage balancing capability, associated to the corresponding Configuration Voltage Vector  $\mathbf{V}_m$ . For this purpose, let us define the following Divergence Index.



**Figure 17. Left** subplot: Norm  $|\vec{\mathbf{V}}_m(\tilde{V}_d)|$  of the Vectorial Divergence Function vs  $\tilde{V}_d \in [0, 0.5]$ ; **Right** subplot: Vectorial Divergence Function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$  on the plane ( $V_2$ ,  $V_3$ ) for all of the Configuration Voltage Vectors  $\mathbf{V}_m$  in the case n = 3.

**Definition 3.** *The* Divergence Index  $I_M$  *of a Configuration Voltage Vector*  $\mathbf{V}_m$  *is defined as follows:* 

$$I_M = \max\Big(|\overline{\mathbf{V}}_m(\tilde{V}_d)|\Big),$$

namely as the maximum value of the norm  $|\vec{\mathbf{V}}_m(\tilde{V}_d)|$  of the Vectorial Divergence Function  $\vec{\mathbf{V}}_m(\tilde{V}_d)$ .

The larger the Divergence Index  $I_M$ , the less robust is the corresponding Configuration Voltage Vector  $\mathbf{V}_m$ . Therefore, the Divergence Index  $I_M$  is inversely proportional to the degree of robustness of the corresponding Configuration Voltage Vector  $\mathbf{V}_m$ . For all of the Basic Configuration Voltage Vectors  $\mathbf{V}_m^*$ , the Divergence Index  $I_M$  is zero, according to Property 8. Index  $I_M$  can also be used to provide a new sorting for the Configuration Voltage Vectors  $\mathbf{V}_m$  having the same number m of output levels. Figure 18 shows the new sorting, in ascending order of the Divergence Index  $I_M$  for each vector  $\mathbf{V}_m$  having the same number m of output voltage levels. Therefore, the different Configuration Voltage Vectors  $\mathbf{V}_m$  having the same number m of output levels are sorted in decreasing degree of robustness when moving from left to right in Figure 18. The magenta line that is reported in Figure 18 is the Mean Index  $I_m$  of the Configuration Voltage Vectors  $\mathbf{V}_m$ . The Mean Index  $I_m$  is defined as the mean value of the norm  $|\vec{\mathbf{V}}_m(\vec{V}_d)|$  of the Vectorial Divergence Function  $\vec{\mathbf{V}}_m(\vec{V}_d)$ :  $I_m = \text{mean}(|\vec{\mathbf{V}}_m(\vec{V}_d)|)$ . Figure 18 clearly shows a strong correlation between the Divergence Index  $I_M$  and Mean Index  $I_m$ .



**Figure 18.** Configuration Voltage Vectors  $V_m$ , for n = 3, sorted in ascending order with respect to the Divergence Index  $I_M$ .

In order to verify the correctness of the sorting proposed in Figure 18, all of the Configuration Voltage Vectors  $V_m$ , for n = 3, have been tested in simulation using the three types of voltage signals  $V_d$  that are shown in Figure 19 (sinusoidal, triangular, and sawtooth) with  $V_{in} = 1$  V, an offset equal to  $V_{in}/2$ , a peak-to-peak amplitude equal to  $V_{in}$ , a frequency equal to 50 Hz, an output current equal to  $I_{out} = 1$  A, and capacitors  $C_i$ chosen as in (29) with  $C_n = 1$  F. Figure 20 shows the results of these simulations, where the Divergence Index  $I_M$  (red characteristic, left vertical axis) is compared with the maximum norm max( $|\Delta \overline{\mathbf{V}}|$ ) of vectors  $\Delta \overline{\mathbf{V}} = \overline{\mathbf{V}}_c(t) - \overline{\mathbf{V}}_{m0}$  obtained in simulation for the three types of the considered periodical signals (colored characteristics, right vertical axis). Two different reference axes have been used in Figure 20, because the Vectorial Divergence Function  $\overline{\mathbf{V}}_m( ilde{V}_d)$  and corresponding Divergence Index  $I_M$  have been computed using a constant normalized voltage  $\tilde{V}_d \in [0, 1]$ , whereas the maximum norms max $(|\Delta \overline{\mathbf{V}}|)$  have been obtained in simulation using different signals, i.e., periodical normalized signals  $\tilde{V}_d$  with a non-zero frequency of 50 Hz. It can be shown that the two quantities  $I_M$  and max $(|\Delta \overline{\mathbf{V}}|)$ would tend to be comparable only if the frequency of the periodical normalized signals  $\tilde{V}_d$ became equal to zero. Consequently, the Divergence Index  $I_M$  represents an upper boundary for the maximum norm index  $max(|\Delta \overline{V}|)$ , for each Configuration Voltage Vector  $V_m$ . Furthermore, Figure 20 shows the good direct proportionality existing between the Divergence Index  $I_M$  and the maximum norm indices max( $|\Delta \mathbf{V}|$ ) of the three considered signals. This good proportionality shows the effectiveness of using the Divergence Index  $I_M$  for evaluating the divergence characteristics of the different Configuration Voltage Vectors  $\mathbf{V}_m$ , which gives a direct measurement of their degree of robustness.



**Figure 19.** Desired voltage signals  $V_d$  for the comparisons in Figures 20 and 21.

Even for the case n = 4, all the Configuration Voltage Vectors  $\mathbf{V}_m$  have been tested in simulation by employing the same normalized periodical signals  $\tilde{V}_d$  used for the case n = 3, which are shown in Figure 19. Figure 21 reports the results of these simulations and the comparison between the Divergence Index  $I_M$  (red characteristic, left vertical axis) and the maximum norm indices  $\max(|\Delta \overline{\mathbf{V}}|)$  (colored lines, right vertical axis). In this figure, the 407 Configuration Voltage Vectors  $\mathbf{V}_m$  of case n = 4 have been sorted with respect to the Divergence Index  $I_M$ . The upper part of the figure shows, for each  $m \in [5, 6, ..., 16]$ , the Configuration Voltage Vector  $\mathbf{V}_m$  having the minimum Divergence Index  $I_M$ . The simulation results that are reported in Figure 21 show the good direct proportionality existing between the Divergence Index  $I_M$  and the maximum norm indices  $\max(|\Delta \overline{\mathbf{V}}|)$ , even in the case n = 4, and, therefore, the effectiveness of using the Divergence Index  $I_M$  for evaluating the divergence characteristics, i.e., the degree of robustness, of the different Configuration Voltage Vectors  $\mathbf{V}_m$ .



**Figure 20.** Comparison between the Divergence Index  $I_M$  and metric max( $\Delta \overline{\mathbf{V}}$ ), computed from simulation using three different  $\tilde{V}_d$  signals, for the Configuration Voltage Vectors  $\mathbf{V}_m$  in the case n = 3.



**Figure 21.** Comparison between the Divergence Index  $I_M$  and metric max( $\Delta \overline{\mathbf{V}}$ ), computed from simulation using three different  $\tilde{V}_d$  signals, for the Configuration Voltage Vectors  $\mathbf{V}_m$  in the case n = 4.

## 4.3.1. Minimum Distance Control: Stability Issues in Extended Operation

The analysis performed on the basis of the Vectorial Divergence Function  $\overline{\mathbf{V}}_m(\tilde{V}_d)$  has shown that all of the Configuration Voltage Vectors  $\mathbf{V}_m$ , other than the basic one  $\mathbf{V}_m^*$ , are unstable with different degrees of divergence in some unfavorable conditions, such as constant desired voltage  $\tilde{V}_d$ , while using the Minimum Distance algorithm. Moreover, Figures 20 and 21 have shown that, for some periodical desired signal  $\tilde{V}_d$  with an average value equal to 0.5, the maximum distance  $\max(\Delta \overline{\mathbf{V}})$  of the voltage vector  $\overline{\mathbf{V}}_c$  from the desired voltage vector  $\overline{\mathbf{V}}_{m0}$  remains bounded. The amplitude of the maximum distance  $\max(\Delta \overline{\mathbf{V}})$  increases if the output current  $I_{out}$  increases, and it decreases if capacitor  $C_n$  or the frequency of the periodical signal  $\tilde{V}_d$  increase.

If  $\overline{\mathbf{V}}_c$  remains in the vicinity of the desired voltage vector  $\overline{\mathbf{V}}_{m0}$ , then the multilevel converter works properly, providing an output signal  $V_{out}$  switching between equally spaced voltage values. On the contrary, if the maximum distance  $\max(\Delta \overline{\mathbf{V}})$  increases excessively, then the output values  $\mathbf{S}_M \mathbf{V}_c$  of the multilevel converter will no longer be equally spaced and the average value of the output switching signal  $V_{out}$  will no longer be equal to the desired signal  $V_{in} \tilde{V}_d$ . If this situation occurs, the multilevel converter cannot work properly, because it provides output signals that are not equal to the desired ones. The output voltage error  $V_{err} = V_{out} - V_{in} \tilde{V}_d$  remains low and, therefore, acceptable, only if the maximum distance  $\max(\Delta \overline{\mathbf{V}})$  remains sufficiently low. Unfortunately, in practical applications, such as the electric motors control, it can happen that the desired voltage vector  $\tilde{V}_d$  does not have an average value equal to 0.5. In this condition, vector  $\overline{\mathbf{V}}_c$  diverges from the desired voltage vector  $\overline{\mathbf{V}}_{m0}$ , which means that the output voltage error  $V_{err}$  increases excessively and the multilevel converter can no longer work correctly. Another destabilizing condition can be identified in a sudden load change. These two scenarios are considered in the following two simulation case studies:

(A) Let us consider the case of a constant output current  $I_{out} = 1.1$  A and a sinusoidal desired voltage with an average value that is equal to 0.5:  $\tilde{V}_d = 0.5 + 0.5 \sin(393 t)$ . Furthermore, the voltage signal is supposed to remain constant at the value  $\tilde{V}_d = 0.43$  for a short time interval  $t \in [t_1 \ t_2]$ , where  $t_1 \simeq 32 \,\mathrm{ms}$  and  $t_2 \simeq 72 \,\mathrm{ms}$ . Figure 22 shows the simulation results. The red characteristic in Figure 22 is the desired signal  $V_d$ , the gray characteristic is the output switching signal  $V_{out}$ , whereas the blue characteristic is the average value of the output signal  $V_{out}$ . From the figure, it is evident that: (1) in the first part of the simulation, i.e.,  $t < t_1$ , the multilevel converter works correctly, since the output switching levels are equally spaced and, thus, the output voltage error  $V_{err}$  is very low; (2) during the second part of the simulation, i.e.,  $t \in [t_1, t_2]$ , the values of the output switching levels change considerably with respect to the desired ones, and they are no longer equally spaced. Therefore, the average value of the output signal  $V_{out}$  (blue characteristic) is no longer equal to the desired value  $\tilde{V}_d$  (red characteristic); and, (3) in the third part of the simulation, i.e.,  $t > t_2$ , the multilevel converter no longer works correctly, since the output signals (the gray and blue characteristics) are no longer equal to the desired one (the red characteristic). This is due to the fact that the trajectories of the reduced voltage vector  $\overline{\mathbf{V}}_c$ have diverged from the desired value  $\overline{\mathbf{V}}_{m0}$  because of the constant voltage  $\tilde{V}_d$ . Moreover, the Minimum Distance algorithm is not able to force the reduced voltage vector  $\mathbf{V}_c$  to move back towards the desired voltage vector  $\overline{\mathbf{V}}_{m0}$  after divergence has occurred.

(B) Let us consider the case of a sinusoidal desired voltage with an average value that is equal to 0.5:  $\tilde{V}_d = 0.5 + 0.5 \sin(393 t)$ . The load current is supposed to be constant and equal to  $I_{out} = 1$  A for  $t < t_1 = 0.04$  s. Next, a sudden load change causing a current step is supposed to occur, causing  $I_{out}$  to jump from 1 A to 10.5 A for  $t_1 \le t < t_2 = 0.1$  s. The load operating condition giving  $I_{out} = 1$  A is supposed to be reestablished for  $t \ge t_2$ . Figure 23 shows the simulation results. The characteristics color notation is the same as the one adopted in Figure 22. From Figure 23, it is evident that: (1) in the first part of the simulation, i.e.,  $t < t_1$ , the multilevel converter works correctly, since the output switching levels are equally spaced, which means that the output voltage error  $V_{err}$  is very low; (2) for  $t \in [t_1 \ t_2)$ , the values of the output switching levels change with respect to the desired ones, and they are no longer equally spaced; and, (3) for  $t \ge t_2$ , the output voltage levels remain unequally spaced, due to the divergence of the trajectories of the reduced voltage vector  $\overline{V}_c$  from the desired value  $\overline{V}_{m0}$  caused by the sudden load change. Moreover, the Minimum Distance algorithm is not able to force the reduced voltage vector  $\overline{V}_c$  to move back towards the desired voltage vector  $\overline{V}_{m0}$  after the divergence has occurred.

Unfortunately, situations such as those that are shown in Figures 22 and 23 can happen for all of the Configuration Voltage Vectors  $\mathbf{V}_m$ , except for the basic one  $\mathbf{V}_m^*$ . This poses quite a limitation on the operation of the converter in the so-called "Extended Operation", namely for  $\mathbf{V}_m \neq \mathbf{V}_m^*$  allowing to generate a number of output voltage levels m > n + 1for the given n, since unpredictable undesired conditions may compromise the correct functioning of the multilevel converter.



**Figure 22.** Deformation of the output voltage waveform in the extended operation of the converter with the Configuration Voltage Vector  $\mathbf{V}_m = [7 \ 6 \ 2]^T$  caused by the voltage trajectory divergence in presence of a constant output voltage.



**Figure 23.** Deformation of the output voltage waveform in the extended operation of the converter with the Configuration Voltage Vector  $\mathbf{V}_m = [7 \ 6 \ 2]^T$  caused by the voltage trajectory divergence in presence of a sudden load change.

## 4.4. Variable-Step Control of the Multilevel Flying-Capacitor Converter

To cope with the divergence problem described in the previous section, the use of a new solution based on the PWM physical scheme that is shown in Figure 24 is proposed.



Figure 24. PWM physical scheme and Variable-Step Control of the Multilevel Flying-Capacitor Converter.

The basic elements of the new PWM scheme are the following:

- (a) a square wave signal having period  $T_{PWM}$  acting as a clock, which activates the Variable-Step Control and resets the integrator to the zero initial condition when the rising edge occurs;
- (b) an integrator with a constant input  $\frac{1}{T_{PWM}}$  and a reset signal that is timed by the square clock. The output  $V_s$  of the integrator is a sawtooth signal which ranges from 0 to 1 within a time interval  $t \in [t_r, t_r + T_{PWM}]$ , where  $t_r$  is the reset time instant, see the black line in Figure 25;
- (c) the voltage  $V_{dc}$  that is provided by the Variable-Step Control block, defining the duty cycle of the high level of the PWM signal, namely the time interval  $T_H$ , see the green line in Figure 25;
- (d) the value of the signal  $V_{HL} = V_{dc} V_s$  determines the output of the selector and, thus, the configuration vector  $\mathbf{S}_j$ , which is going to be applied to the multilevel converter during the next time interval:  $\mathbf{S}_j = \mathbf{S}_H$  for a time interval  $T_H$  if  $V_{HL} > 0$  and  $\mathbf{S}_j = \mathbf{S}_L$  for a time interval  $T_{PWM} T_H$  if  $V_{HL} < 0$ ;
- (e) at each activation time, the Variable-Step Control reads the input signal  $\tilde{V}_d$  and generates three output signals:  $\mathbf{S}_H$ ,  $V_{dc}$  and  $\mathbf{S}_L$ . Using these signals, the Variable-Step Algorithm can decide the duty cycle  $d_c$  and the two levels  $\mathbf{S}_H \mathbf{V}_c$  and  $\mathbf{S}_L \mathbf{V}_c$  of the next PWM period;
- (f) let  $V_H > V_d$  denote the voltage corresponding to configuration vector  $\mathbf{S}_H$  and  $V_L < V_d$  denote the voltage corresponding to configuration vector  $\mathbf{S}_L$ . The duty cycle  $d_c = T_H / T_{PWM}$  of the next PWM period, that is the ratio between the duration  $T_H$  of the higher level and the duration of the PWM period  $T_{PWM}$ , can be computed, as follows:

$$V_d = V_H d_c + V_L (1 - d_c) \qquad \leftrightarrow \qquad d_c = \frac{V_d - V_L}{V_H - V_L}.$$
(30)

Using (30), the duty cycle  $d_c$  always guarantees that the average value of the PWM output voltage in the next period  $T_{PWM}$  is equal to the desired value  $V_d$ .



**Figure 25.** Scheme for the application of the configuration vectors  $\mathbf{S}_{j_H}$  and  $\mathbf{S}_{j_L}$  associated with the higher and lower level time intervals  $T_H$  and  $T_{PWM} - T_H$ .

Figure 26 provides the basic structure of the Variable-Step Control algorithm by means of a Matlab-like function called "**Multi\_Step\_Algorithm**(···)". This function is called at each activation time providing the following input parameters:  $\Delta \overline{\mathbf{V}}$ ,  $\tilde{V}_d$ ,  $I_{out}$ ,  $T_{PWM}$ ,  $N_s$ ,  $V_{r0}$ . The "Multi\_Step\_Algorithm" attempts to keep the reduced voltage vector  $\overline{\mathbf{V}}_c$  as close as possible to the desired reduced voltage vector  $\overline{\mathbf{V}}_{m0}$ , see (22). The main features of the "Multi\_Step\_Algorithm" are the following:

| function $[\mathbf{S}_{H}, V_{dc}, \mathbf{S}_{L}] = $ <b>Multi_Step_Algorithm</b> $(\Delta \overline{\mathbf{V}}, \tilde{V}_{d}, I_{out}, T_{PWH})$                 | $M_{r}, N_{s}, V_{r0})$                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| 1. $V_D = \tilde{V}_d(m-1);$                                                                                                                                         | % Variable $V_D \in [0, m-1]$                                      |
| 2. $\alpha_{H0} = \operatorname{ceil}(V_D);$                                                                                                                         | % Initial upper adjacent level                                     |
| 3. $V_{dc} = V_D - \text{floor}(V_D);$                                                                                                                               | % Voltage $V_{dc}$ in Figure 24 and Figure 25                      |
| 4. $N_m = \infty$ ;                                                                                                                                                  | % Initialize minimum norm of $\Delta \overline{\mathbf{V}}_{cij}$  |
| 5. <b>for</b> $N_{si} = 1 : N_s$                                                                                                                                     | % $N_{si}$ is the amplitude of the Step                            |
| 6. <b>for</b> $k = 0 : N_{si} - 1$                                                                                                                                   | % k is the up and down Shift                                       |
| 7. $\alpha_H = \alpha_{H0} + k;  \alpha_L = \alpha_H - N_{si};$                                                                                                      | % Current levels $\alpha_H$ and $\alpha_L$                         |
| 8. Compute the new duty cycle $d_c$ ;                                                                                                                                | % <i>As in</i> (30)                                                |
| 9. <b>if</b> $(\alpha_H < m)$ & $(\alpha_L \ge 0)$                                                                                                                   | $\% \alpha_H, \alpha_L$ must not exceed boundaries                 |
| 10. Compute sets $S_{\alpha_H}$ and $S_{\alpha_L}$ ;                                                                                                                 | % Defined in (23)                                                  |
| 11. Compute vectors $\overline{\mathbf{S}}_{CHi}$ and $\overline{\mathbf{S}}_{CLj}$ ;                                                                                | % Defined in (22)                                                  |
| 12. <b>for</b> $i \in S_{\alpha_H}$                                                                                                                                  | % Cycle over indexes in $\mathcal{S}_{\alpha_H}$                   |
| 13. <b>for</b> $j \in S_{\alpha_L}$                                                                                                                                  | % Cycle over indexes in $\mathcal{S}_{\alpha_L}$                   |
| 14. $\Delta \overline{\mathbf{V}}_{cij} = \Delta \overline{\mathbf{V}} + [\overline{\mathbf{S}}_{CHi} d_c + \overline{\mathbf{S}}_{CLj} (1 - d_c)] I_{out} T_{PWM};$ | % Distance vector                                                  |
| 15. <b>if</b> norm $(\Delta \overline{\mathbf{V}}_{cij}) < N_m$                                                                                                      | % If $ \Delta \overline{\mathbf{V}}_{cij}  < current minimum$      |
| 16. $N_m = \operatorname{norm}(\Delta \overline{\mathbf{V}}_{cij});$                                                                                                 | % Set $N_m$ to the current one                                     |
| 17. Set: $\mathbf{S}_H = \mathbf{S}_i$ ; $\mathbf{S}_L = \mathbf{S}_j$ ; $V_{dc} = d_c$ ;                                                                            | % Set the outputs                                                  |
| 18. end                                                                                                                                                              |                                                                    |
| 19. <b>end</b>                                                                                                                                                       |                                                                    |
| 20. end                                                                                                                                                              |                                                                    |
| 21. end                                                                                                                                                              |                                                                    |
| 22. end                                                                                                                                                              |                                                                    |
| 23. <b>if</b> $(N_m < \operatorname{norm}(\Delta \overline{\mathbf{V}}))    (N_m < V_{r0} N_{si})$                                                                   | % $N_m <  \Delta \overline{\mathbf{V}} $ or $<$ hypersphere radius |
| 24. return                                                                                                                                                           | % Exit from the algorithm                                          |
| 25. end                                                                                                                                                              |                                                                    |
| 26. end                                                                                                                                                              |                                                                    |

Figure 26. Matlab-like form of the Variable-Step Control algorithm.

- At each activation time  $t_k$ , the "Multi\_Step\_Algorithm" computes the two configuration vectors  $\mathbf{S}_H$ ,  $\mathbf{S}_L$  and the duty cycle  $V_{dc}$  to be applied in the following PWM time interval  $[t_k \ t_k + T_{PWM}]$ : configuration  $\mathbf{S}_H$  will be applied in the first part of the PWM period when  $V_{HL} = V_{dc} - V_s > 0$ , while configuration  $\mathbf{S}_L$  will be applied in the second part of the PWM period when  $V_{HL} < 0$ , see Figure 25.
- The input  $N_s$  defines the maximum amplitude of the Step to be used in the algorithm, which is the *maximum level-to-level distance*. The **for** cycle at line 5 in Figure 26 defines the current value  $N_{si} \in [1, 2, ..., N_s]$  of the amplitude of the Step, i.e., the current level-to-level distance. The **for** cycle at line 6 defines the current value k of the up and down shift to be considered for the current amplitude  $N_{si}$  of the Step.
- At lines 7 and 8, the current values of the upper level  $\alpha_H$ , the lower level  $\alpha_L$ , and the duty cycle  $d_c$  are computed. If the current values of  $\alpha_H$  and  $\alpha_L$  are admissible, see condition at line 9, then the sets  $S_{\alpha_H}$  and  $S_{\alpha_L}$  of the admissible configuration vectors  $\mathbf{S}_{Hi}$  and  $\mathbf{S}_{Lj}$  and the corresponding vectors  $\mathbf{\overline{S}}_{CHi}$  and  $\mathbf{\overline{S}}_{CLj}$  are computed at lines 10 and 11.
- The two for cycles at lines 12 and 13 are used to compute the distance vector  $\Delta \overline{\mathbf{V}}_{cij}$ for each possible combination of the configuration vectors  $\mathbf{S}_i$  and  $\mathbf{S}_j$  belonging to the two sets  $S_{\alpha_H}$  and  $S_{\alpha_L}$ . At line 14, the distance vector  $\Delta \overline{\mathbf{V}}_{cij}$  is computed starting from the initial condition  $\Delta \overline{\mathbf{V}}$  and adding the two terms  $\overline{\mathbf{S}}_{CHi} d_c I_{out} T_{PWM}$  and  $\overline{\mathbf{S}}_{CLj}(1 - d_c) I_{out} T_{PWM}$ , due to the application of the configuration vectors  $\mathbf{S}_{Hi}$  and  $\mathbf{S}_{Li}$  in the first part  $d_c T_{PWM}$  and in the second part  $(1 - d_c) T_{PWM}$  of the PWM period  $T_{PWM}$ , respectively.
- If the norm of the distance vector Δ V
  <sub>cij</sub> is smaller than the current minimum norm N<sub>m</sub>, see line 15, then the algorithm updates the value of parameter N<sub>m</sub>, see line 16, and it sets the values of the output variables S<sub>H</sub>, S<sub>L</sub> and V<sub>dc</sub> equal to the values S<sub>i</sub>, S<sub>j</sub> and d<sub>c</sub> of the current solution, see line 17.
- The "Multi\_Step\_Algorithm" ends its minimum distance vector search, see line 24, when one of the conditions at line 23 is verified, or when the maximum level-to-level distance  $N_s$  has been achieved. At line 23, the algorithm exits the search if the current minimum distance  $N_m$  is lower than the initial one, or if  $N_m$  is lower than radius  $V_{r0} N_{si}$ , where  $V_{r0}$  is the input basic radius and  $N_{si}$  is the current level-to-level distance. Radius  $V_{r0} N_{si}$  represents the varying radius of an hypersphere in the (n 1)-dimensional space. Figure 27 shows the resulting circumferences with varying radius  $V_{r0} N_{si}$  for the case n = 3.
- The "Multi\_Step\_Algorithm" introduces and uses the new concept of "*variable level-to-level distance*". This concept means that the algorithm can choose a higher level  $\alpha_H$  and a lower level  $\alpha_L$  *that are not adjacent*, see line 7 of the algorithm. The current level-to-level distance is denoted by variable  $N_{si} \in [1, N_s]$ . The new duty cycle  $d_c$  associated with the two levels  $\alpha_H$  and  $\alpha_L$ , computed in line 8, guarantees that the average value of the PWM output voltage in the next PWM period  $T_{PWM}$  will be equal to the desired value  $V_d$ .
- The ability to change the level-to-level distance allows the "Multi\_Step\_Algorithm" to keep the reduced voltage vector  $\overline{\mathbf{V}}_c$  in the vicinity of the desired voltage vector  $\overline{\mathbf{V}}_{m0}$  even in extended operation and in presence of some particularly unfavorable operating conditions, such as normalized desired voltage  $\tilde{V}_d$  having an average value different from 0.5.
- If the unfavorable conditions persist, the algorithm can enlarge the level-to-level distance  $N_{si}$  up to its upper boundary  $N_s = m 1$ . This enlargement increases the number of the configuration vectors  $\mathbf{S}_j$  that the algorithm can use to keep vector  $\overline{\mathbf{V}}_c$  in the vicinity of the desired vector  $\overline{\mathbf{V}}_{m0}$ , and to maintain the correct functioning of the multilevel converter. Furthermore, when the unfavorable conditions no longer occur, the "Multi\_Step\_Algorithm" has the ability to force the converter to go back to work as a normal multilevel converter switching between adjacent levels only, i.e., with a current level-to-level distance  $N_{si}$  equal to one.

• The example reported in Figure 28 shows all the possible combinations of levels  $\alpha_H$  and  $\alpha_L$  that can be obtained when m = 6,  $N_{si} \in \{1, 2, 3, 4, 5\}$  and the desired voltage  $V_D = (m-1)\tilde{V}_d$  is in between levels "2" and "3".



**Figure 27.** Circumference with varying radius  $N_{si} V_{r0}$  in the two-dimensional space for the case n = 3.



**Figure 28.** Possible combinations of higher and lower output voltage levels  $\alpha_H$  and  $\alpha_L$  as a function of the current level-to-level distance  $N_{si}$  for the case m = 6 and a desired voltage  $V_D$  in between "2" and "3".

#### 4.4.1. Variable-Step Control: Solution of the Stability Issues in Extended Operation

Section 4.3.1 has shown that the Minimum Distance Control is not capable of ensuring the correct operation of the multilevel flying-capacitor converter, in extended mode, under particularly unfavorable operating conditions, such as a desired voltage  $\tilde{V}_d$ , with an average value that is different from 0.5 or a sudden load change. Examples of this type are shown in Figures 22 and 23, respectively. On the contrary, the Variable-Step Control that was presented in the previous section is able to ensure the correct functioning of the multilevel converter, even under unfavorable operating conditions. To give some examples, reference is made to Figures 29 and 30, showing the simulation results obtained using the Variable-Step Control under the same operating conditions as those of the simulations in Figures 22 and 23, respectively, when the Minimum Distance Control was used instead. In Figures 29 and 30, the red characteristic is the desired signal  $\tilde{V}_d$ , the gray characteristic is the switching output signal  $V_{out}$ , and the green characteristic is the average value of the output signal  $V_{out}$ .

With reference to Figure 29, it is evident that: (1) in the first part of the simulation, for  $t < t_1$ , the multilevel converter works correctly in extended operation using the minimum level-to-level distance  $N_{si} = 1$  and the output voltage error  $V_{err} = V_{out} - V_{in}V_{di}$ remains low; (2) during the second part of the simulation, for  $t \in [t_1, t_2]$ , the current level-to-level distance  $N_{si}$  increases from 1 to 2, and the gray output variable  $V_{out}$  switches between levels  $V_L = 2/7$  and  $V_H = 4/7$ . In this part of the simulation, the effectiveness of the Variable-Step Control comes into play, which prevents vector  $\overline{\mathbf{V}}_c$  from diverging excessively from the desired reduced vector  $\overline{\mathbf{V}}_{m0}$ , even in the presence of the unfavorable condition of a signal  $\hat{V}_d$  constant and different from 0.5. On the other hand, in the simulation of Figure 22, the Minimum Distance Algorithm was not able to prevent the divergence of the vector  $\mathbf{V}_c$ , therefore compromising the correct functioning of the converter; (3) in the third part of the simulation, for  $t > t_2$ , the operating condition  $N_{si} = 2$  is maintained until the distance between vectors  $\overline{\mathbf{V}}_c$  and  $\overline{\mathbf{V}}_{m0}$  is sufficiently reduced, namely until time instant  $t_3 \simeq 176$  ms; and, (4) in the fourth part of the simulation, for  $t > t_3$ , the converter starts operating as a classical multilevel flying-capacitor converter in extended mode once again, setting the current level-to-level distance  $N_{si}$  back to 1. On the other hand, in the simulation of Figure 22, the Minimum Distance Algorithm was not able to force the vector  $\mathbf{V}_c$  to move back towards the desired vector  $\overline{\mathbf{V}}_{m0}$  after the divergence occurred.

With reference to Figure 30, it is evident that: (1) in the first part of the simulation, for  $t < t_1$ , the multilevel converter works correctly in extended operation using the minimum level-to-level distance  $N_{si} = 1$  and the output voltage error  $V_{err} = V_{out} - V_{in}\tilde{V}_d$  remains low; (2) for  $t \in [t_1 \ t_2)$ , the current level-to-level distance  $N_{si}$  increases from 1 to 2, in order to prevent vector  $\overline{V}_c$  from diverging excessively from the desired reduced vector  $\overline{V}_{m0}$  as a consequence of the undesired sudden load change. On the other hand, in the simulation of Figure 23, the Minimum Distance Algorithm was not able to prevent the divergence of the vector  $\overline{V}_c$ , therefore compromising the correct functioning of the converter; (3) for  $t \ge t_2$ , the operating condition  $N_{si} = 2$  is maintained until  $t = t_3 \simeq 0.1039$  s, namely for the very short time interval that it takes for the distance between vectors  $\overline{V}_c$  and  $\overline{V}_{m0}$  to be sufficiently reduced; and, (4) for  $t \ge t_3$ , the converter starts operating as a classical multilevel flying-capacitor converter in extended mode once again, setting the current level-to-level distance  $N_{si}$  back to 1. On the other hand, in the simulation of Figure 23, the Minimum Distance Algorithm was not able to force the vector  $\overline{V}_c$  to move back towards the desired vector  $\overline{V}_{m0}$  after the divergence occurred.

The simulation results that are reported in Figures 29 and 30 clearly highlight the effectiveness of the proposed Variable-Step Control as compared with the classical Minimum Distance Control. This especially holds in those applications, such as the electric motors control, where it can happen that the desired voltage vector  $\tilde{V}_d$  does not have an average value equal to 0.5, or that an undesired sudden load change occurs. At the same time, it is desirable to have the converter operating in extended mode, because of all the advantages in the output voltage quality coming from a larger number of output voltage

levels without increasing the number of capacitors. The proposed Variable-Step Control aims at enabling the multilevel flying-capacitor converter operation in extended mode any time the operating conditions allow it, and it enlarges the level-to-level distance  $N_{si}$  only when strictly necessary to prevent the divergence of the flying capacitors voltages.

The Reader is invited to refer to the supplementary material in order to test and compare the Minimum Distance Control algorithm and the Variable-Step Control algorithm [28]. The Simulink model "Multilevel\_Flying\_Capacitor\_Converter\_mdl.slx" has been created with Matlab R2020b and it contains the dynamic model of the multilevel flying-capacitor converter with *n* capacitors given in Figure 4, as well as the implementation of both the Minimum Distance Control and the Variable-Step Control. The two algorithms are implemented in the Matlab functions "Distance\_Control\_0.m" and "Distance\_Control\_n.m", respectively. The main script that allows to control the simulations is named "Multilevel\_Flying\_Capacitor\_Converter.m", where the system parameters that the user can set are reported and commented. Note that variables *m* and  $m_{ii}$  in the script "Multilevel\_Flying\_Capacitor\_Converter.m" denote the number *m* of output levels and the order  $m_{ii}$  of the Configuration Voltage Vector  $\mathbf{V}_m$ , according to the orders that are reported in Figure 20 for the case n = 3 and in Figure 21 for the case n = 4.



**Figure 29.** Non-Deformation of the output voltage waveform in the extended operation of the converter with the Configuration Voltage Vector  $\mathbf{V}_m = [7 \ 6 \ 2]^T$ , in the presence of a constant output voltage, thanks to the Variable-Step Control.



**Figure 30.** Non-Deformation of the output voltage waveform in the extended operation of the converter with the Configuration Voltage Vector  $\mathbf{V}_m = [7 \ 6 \ 2]^T$ , in the presence of a sudden load change, thanks to the Variable-Step Control.

## 5. Converter Testing with Dynamic Loads

This section deals with the simulation of the multilevel flying-capacitor converter with n = 3 in extended operation, while using the Configuration Voltage Vector  $\mathbf{V}_m = [5 \ 4 \ 1]^T$ , with several proposed load case studies. The considered load configuration is an RLC circuit, where a capacitor  $C_L$  and a resistor  $R_L$  are connected in parallel, and their parallel configuration is connected in series to an inductor  $L_L$ . The described load can be modeled using the POG block scheme that is shown in Figure 31 on the left. The transfer function H(s) relating the output power variable  $I_{out}$  to the input power variable  $V_{out}$  is the following:

$$H(s) = \frac{I_{out}(s)}{V_{out}(s)} = \frac{sR_LC_L + 1}{s^2R_LC_LL_L + sL_L + R_L}.$$
(31)

The parameters values for the considered load case studies are shown in Figure 31 on the right, together with the converter parameters. As far as loads 1, 2 and 3 are concerned, the desired voltage  $V_d$  is assumed to be sinusoidal with an offset that is equal to  $V_{in}/2$ , a peak-to-peak amplitude equal to  $V_{in}$  and a frequency equal to 50 Hz. As far as load 4 is concerned, the desired voltage  $V_d$  is assumed to be constant and equal to 4.5 V. By focusing on the loads 1, 2, and 3, and using the parameters  $L_L$ ,  $C_L$ , and  $R_L$  given in Figure 31, one can notice that they represent the cases of voltage  $V_{out}$  delayed by  $\pi/4$  with respect to current  $I_{out}$ , current  $I_{out}$  delayed by  $\pi/4$  with respect to voltage  $V_{out}$ , and current  $I_{out}$  in phase with voltage  $V_{out}$ , respectively. The initial conditions of the RLC load are assumed to be equal to zero. Figure 32 shows the simulation results after the transient when the loads 1, 2 and 3 are considered. From the first three rows of subplots on the left-hand side, obtained using the Minimum Distance Control, it is possible to see that the average  $V_{out}$  characteristic exhibits different degrees of deviation from the desired voltage  $V_d$ . This is due to the fact

that the distance between vectors  $\overline{\mathbf{V}}_c$  and  $\overline{\mathbf{V}}_{m0}$  tends to increase, even if the average value of  $\tilde{V}_d$  is equal to 0.5, i.e., the average value of  $V_d$  is equal to  $V_{in}/2$ . This can be explained by recalling that the output current *I*<sub>out</sub> is not constant, as the load is dynamic, which means that the *strength* of the control action applied by the Configuration Vector  $\mathbf{S}_i$  in (24) *changes* in time through *I*<sub>out</sub>, which is a function of *V*<sub>out</sub>. Without a loss of generality, it is possible to state that this makes the Voltage Configuration Vectors  $\mathbf{V}_m$  different from the basic one  $\mathbf{V}_m^*$ loose the full flying capacitors voltage balancing capability, i.e., to become unstable, even when the average value of the desired voltage  $V_d$  is equal to  $V_{in}/2$ . It follows that the distance between vectors  $\overline{\mathbf{V}}_c$  and  $\overline{\mathbf{V}}_{m0}$  will keep increasing, thus causing the output voltage levels to be increasingly unequally spaced. On the other hand, the subplots on the right-hand side show the very good matching between the average V<sub>out</sub> characteristic and the desired voltage  $V_d$  when the converter is controlled using the Variable-Step Control. It follows that the Variable-Step Control is capable of handling the cases of non-constant output current  $I_{out}$  in extended operation as well, by increasing the current level-to-level distance  $N_{si}$ when necessary in order to prevent the divergence of vector  $\overline{\mathbf{V}}_c$  from vector  $\overline{\mathbf{V}}_{m0}$ . As an example of this, the voltage trajectories of the flying capacitors, namely the components of vector  $\overline{\mathbf{V}}_c$ , are shown in Figure 33 for the case "Load 2" when the two different controls are used. From the figure, it is clearly possible to see that the Minimum Distance Control causes the divergence of vector  $\overline{\mathbf{V}}_c$  (blue characteristic) from the desired vector  $\overline{\mathbf{V}}_{m0}$ , which is highlighted by the red spot in the figure. Furthermore, the blue characteristic also shows that the strength of the control action applied by the Configuration Vector  $\mathbf{S}_i$  in (24) is indeed not constant during the simulation, but it is a function of the output current  $I_{out}$ , since the length of the blue voltage trajectories in Figure 33 is not constant. On the other hand, the Variable-Step Control is indeed capable of ensuring the convergence of vector  $\overline{\mathbf{V}}_c$ to the desired vector  $\mathbf{V}_{m0}$ .



Figure 31. On the left: RLC load POG scheme; On the right: RLC load and converter parameters.

The fourth row of subplots presented in Figure 32 shows the case of constant desired voltage  $V_d$  with the load parameters identified by "Load 4" in Figure 31 on the right. The bottom-left subplot shows that the case of constant desired voltage  $V_d \neq V_{in}/2$ , namely  $\tilde{V}_d \neq 0.5$ , is still the most severe one. This can be seen from the fact that the output voltage levels quickly become unequally spaced because of the divergence of vector  $\overline{\mathbf{V}}_c$  from vector  $\overline{\mathbf{V}}_{m0}$ . Furthermore, note that the average output voltage in the bottom-left subplot of Figure 32 tends to decrease, as a consequence of the divergence of the vector  $\overline{\mathbf{V}}_c$  trajectories. Consequently, the output current  $I_{out}$  will also tend to decrease. This situation gives rise to an unstable loop: the more  $V_{out}$  decreases with respect to the desired value  $V_d$ , the lower the output current  $I_{out}$ , the weaker the control action applied by the Configuration Vector  $\mathbf{S}_j$  in (24), the more severe the divergence of the  $\overline{\mathbf{V}}_c$  trajectories from  $\overline{\mathbf{V}}_{m0}$ . However, the bottom-right subplot of Figure 32 shows how the divergence of the  $\overline{\mathbf{V}}_c$  trajectories from  $\overline{\mathbf{V}}_{m0}$  is prevented by the Variable-Step Control, thanks to the increase of the current level-to-level distance  $N_{si}$  from 1 to 2, showing the effectiveness of the proposed Variable-Step Control.



**Figure 32.** Left subplots: simulations using the Minimum Distance Control for  $\mathbf{V}_m = [5 \ 4 \ 1]^T$ ; Right subplot: simulations using the Variable-Step Control for  $\mathbf{V}_m = [5 \ 4 \ 1]^T$ .



**Figure 33.** Voltage trajectories for the "Load 2" case using the Minimum Distance Control (blue) and the Variable-Step Control (green).

## 6. Conclusions

In this paper, the modeling, the control, and the robustness assessment of the multilevel flying-capacitor converter have been addressed. The main contributions of this paper are summarized in the following:

- the Power-Oriented Graphs modeling technique has been exploited to derive the system dynamic model of the *n*-dimensional converter, generating a POG model that can be directly implemented in Matlab/Simulink by employing standard Simulink libraries;
- a procedure for computing all the possible voltage vector configurations **V**<sub>m</sub> providing equally spaced levels of the output voltage *V*<sub>out</sub> has been given;
- the robustness assessment of the converter operating in extended mode when using a Minimum Distance Control has been performed;
- a Divergence Index *I<sub>M</sub>* has been introduced, which can be used as a metric for properly ordering the different Configuration Voltage Vectors on the basis of their voltage balancing capability in extended operation;
- a new Variable-Step Control algorithm has been proposed, allowing for the safe extended operation of the converter even under particularly destabilizing operating conditions, such as a constant desired output voltage or a sudden load change.

The good performances of the proposed control algorithm have finally been tested in simulation and compared with the results that are given by the classical Minimum Distance Control.

The next steps of the research work presented in this paper include the code optimization of the Variable-Step Control, in order to study and address its real-time implementation, as well as the investigation of the other potential benefits that the Variable-Step Control can bring. Additionally, the closed-loop stability analysis through the load can provide important criteria that the load must satisfy in order to ensure closed-loop stability. As far as the modeling part is concerned, the presented modeling procedure can be extended in order to show that it can also be easily applied to other converter topologies, such as the diode-clamped topology. Furthermore, we are planning to address the analysis and the modeling of other multilevel converters, in order to perform their stability analysis and investigate the properties they exhibit, following the outlines introduced in this paper for multilevel flying-capacitor converters.

**Author Contributions:** Data curation, D.T. and R.Z.; Formal analysis, D.T. and R.Z.; Investigation, D.T. and R.Z.; Methodology, D.T. and R.Z.; Software, D.T. and R.Z.; Writing—original draft, D.T. and R.Z.; Writing—review & editing, D.T. and R.Z. All authors have read and agreed to the published version of the manuscript.

Funding: This research received no external funding.

**Data Availability Statement:** The supplementary material related to this study is available at the link provided in [28].

Conflicts of Interest: The authors declare no conflict of interest.

### References

- Zanasi, R.; Cuoghi, S. Model of Soft-Switching Converter and Power Control of Grid-Connected Photovoltaic Systems. In Proceedings of the IECON Annual Conference of the IEEE Industrial Electronics Society, Melbourne, VIC, Australia, 7–11 November 2011; doi:10.1109/IECON.2011.6119518. [CrossRef]
- Wu, H.; Mu, T.; Ge, H.; Xing, Y. Full-Range Soft-Switching-Isolated Buck-Boost Converters With Integrated Interleaved Boost Converter and Phase-Shifted Control. *IEEE Trans. Power Electron.* 2016, *31*, 987–999. [CrossRef]
- 3. Azer, P.; Emadi, A. Generalized State Space Average Model for Multi-Phase Interleaved Buck, Boost and Buck-Boost DC-DC Converters: Transient, Steady-State and Switching Dynamics. *IEEE Access* 2020, *8*, 77735–77745. [CrossRef]
- Zanasi, R.; Cuoghi, S. Model of Soft-Switching Converter and Power Control for Smart Grid Applications. In Proceedings of the IEEE PES Innovative Smart Grid Technologies, Perth, WA, Australia, 13–16 November 2011, doi:10.1109/ISGT-Asia.2011.6167073. [CrossRef]
- Al-Badi, A.H.; Ahshan, R.; Hosseinzadeh, N.; Ghorbani, R.; Hossain, E. Survey of Smart Grid Concepts and Technological Demonstrations Worldwide Emphasizing on the Oman Perspective. *Appl. Syst. Innov.* 2020, 3, 5. [CrossRef]
- 6. Wu, B.; Narimani, M. *High-Power Converters and AC Drives*; Wiley-IEEE Press: Hoboken, NJ, USA, 2017.
- Quraan, M.; Tricoli, P.; D'Arco, S.; Piegari, L. Efficiency Assessment of Modular Multilevel Converters for Battery Electric Vehicles. IEEE Trans. Power Electron. 2017, 35, 2041–2051. [CrossRef]
- 8. Rodrìguez, J.; Lai, J.-S.; Peng, F.Z. Multilevel Inverters: A Survey of Topologies, Controls, and Applications. *IEEE Trans. Ind. Electron.* 2002, *49*, 724–738. [CrossRef]
- Rodrìguez Bernet, J.S.; Wu, B.; Pontt, J.O.; Kouro, S. Multilevel Voltage-Source-Converter Topologies for Industrial Medium-Voltage Drives. *IEEE Trans. Ind. Electron.* 2017, 54, 2930–2945. [CrossRef]
- Saleh, S.A.; Al-Durra, A.; Ahshan, R. Ground Potentials in Transformerless Grid-Connected Multi-Level Power Electronic Converters. In Proceedings of the 56th Industrial and Commercial Power Systems Technical Conference (I&CPS), Las Vegas, NV, USA, 29 June–28 July 2020. [CrossRef]
- 11. Saleh, S.; Al-Durra, A.; Ahshan, R. On the Ground Potentials and Grounding Circuits of Transformerless Grid-Connected Multilevel Power Electronic Converters. *IEEE Trans. Ind. Appl.* **2020**, *56*, 6286-6297. [CrossRef]
- 12. Zanasi, R.; Cuoghi, S. Dynamic Models of Multilevel Converters by using the Power Oriented Graph Technique. In Proceedings of the International Symposium on Power Electronics, Electrical Drives, Automation and Motion, Sorrento, Italy, 20–22 June 2012. [CrossRef]
- 13. Rodrìguez, J.; Franquelo, L.G.; Kouro, S.; Lèon, J.I.; Portillo, R.C.; Prats, M.A.M.; Pèrez, M.A. Multilevel Converters: An Enabling Technology for High-Power Applications. *Proc. IEEE* 2009, *97*, 1786–1817. [CrossRef]
- 14. Corzine, K.A.; Baker, J.R. Multilevel voltage-source duty-cycle modulation: Analysis and implementation. *IEEE Trans. Ind. Electron.* **2002**, *49*, 1009–1016. [CrossRef]
- 15. Diaz, M.; Cardenas, R.; Ibaceta, E.; Mora, A.; Urrutia, M.; Espinoza, M.; Rojas, F.; Wheeler, P. An Overview of Modelling Techniques and Control Strategies for Modular Multilevel Matrix Converters. *Energies* **2020**, *13*, 4678. [CrossRef]
- Liu, M.; Li, Z.; Yang, X. A Universal Mathematical Model of Modular Multilevel Converter with Half-Bridge. *Energies* 2020, 13, 4464. [CrossRef]
- 17. Zanasi, R. The Power-Oriented Graphs Technique: System modeling and basic properties. In Proceedings of the IEEE Vehicle Power and Propulsion Conference (VPPC), Lille, France, 1–3 September 2010. [CrossRef]
- Zanasi, R.; Geitner, G.H.; Bouscayrol, A.; Lhomme, W. Different energetic techniques for modelling traction drives. In Proceedings of the 9th Internation Conference on Modeling and Simulation of Electric Machines, Converters and Systems (ELECTRIMACS), Québec, QC, Canada, 8–11 June 2008.
- 19. Zanasi, R. POG Modeler: The Web Power-Oriented Graphs Modeling Program. In Proceedings of the IFAC World Congress, Berlin, Germany, 11–17 July 2020.

- Brando, G.; Dannier, A.; Spina, I.; Tricoli, P. Integrated BMS-MMC Balancing Technique Highlighted by a Novel Space-Vector Based Approach for BEVs Application. *Energies* 2017, 10, 1628. [CrossRef]
- Liao, Y.; You, J.; Yang, J.; Wang, Z.; Jin, L. Disturbance-Observer-Based Model Predictive Control for Battery Energy Storage System Modular Multilevel Converters. *Energies* 2018, 11, 2285. [CrossRef]
- Gaisse, P.; Muñoz, J.M.; Villalón, A.; Aliaga, R. Improved Predictive Control for an Asymmetric Multilevel Converter for Photovoltaic Energy. Sustainability 2020, 12, 6204. [CrossRef]
- 23. Tian, H.; Li, Y.W. Carrier-Based Stair Edge PWM (SEPWM) for Capacitor Balancing in Multilevel Converters With Floating Capacitors. *IEEE Trans. Ind. Appl.* **2018**, *54*, 3440–3452. [CrossRef]
- 24. McGrath, B.P.; Holmes, D.G. Enhanced Voltage Balancing of a Flying Capacitor Multilevel Converter Using Phase Disposition (PD) Modulation. *IEEE Trans. Power Electron.* **2011**, *26*, 1933–1942. [CrossRef]
- 25. Kang, D.-W.; Lee, B.-K.; Jeon, J.-H.; Kim, T.-J.; Hyun, D.-S. A Symmetric Carrier Technique of CRPWM for Voltage Balance Method of Flying-Capacitor Multilevel Inverter. *IEEE Trans. Ind. Electron.* 2005, *52*, 879–888. [CrossRef]
- 26. Kou, X.; Corzine, K.A.; Familiant, Y.L. Full binary combination schema for floating voltage source multilevel inverters. *IEEE Trans. Power Electron.* 2002, *17*, 891–897. [CrossRef]
- 27. Huang, J.; Corzine, K.A. Extended operation of flying capacitor multilevel inverters. *IEEE Trans. Power Electron.* **2006**, 21, 140–147. [CrossRef]
- 28. Link of the Supplementary Material. Available online: http://dii.unimo.it/~zanasi/Personale/Suppl\_M.zip (accessed on).