# Elements of Power Electronics PART II: Digital control

#### Fabrice Frébel (fabrice.frebel@uliege.be)

September 16<sup>th</sup>, 2024

(日) (四) (日) (日) (日)

- Chapter 1: Continuous-Time Averaged Modeling of DC-DC Converters
- Chapter 2: The Digital Control Loop
- Hands-on: The complete design process
- Current Mode Control

PART II is based on the reference book [1] with same chapter numbering.

・ロト ・ 四ト ・ 日ト ・ 日下

# Chapter 1: Continuous-Time Averaged Modeling of DC-DC Converters

- Digitally controlled switched-mode converters
- Converters transfer function
  - Solving the time variance problem: averaging
  - Solving the non-linearity problem: converter linearization
  - Transfer function: buck converter example
  - Another example: buck-boost converter
  - Averaged small-signal models of basic converters
  - Boost transfer function and right half-plane zero (RHPZ)

▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□ ● ● ●

- State-space averaging
- The pulse width modulator
- Closed loop system

3/85

- Definition of the loop gain
- Loop including external perturbation
- Closed loop gain
- Relation between phase margin and stability
- Analog control loop design procedure

## Digitally controlled switched-mode converters

Excerpt of [1]:



▲□▶ ▲□▶ ▲□▶ ▲□▶ □ のQで

## Pulse width modulated converter

Excerpt of [1]:



- We have tools to study LTI (Linear Time Invariant) systems but,
- pulse width modulated converter are non-linear (M(D) is often not linear) and time variant (switching).

## Solving the time variance problem: averaging

Excerpt of [1]:



To solve the time variance, we apply the moving average operator with period T:

$$\langle x(t) \rangle_T \triangleq \frac{1}{T} \int_{t-T/2}^{t+T/2} x(\tau) d\tau.$$

The goal is to obtain a model of averaged variables over a switching period, this yields for  $v_o(t)$ :

$$\bar{v}_o(t) \triangleq \langle v_o(t) \rangle_{T_s}.$$

## Converter averaging: buck converter example

Excerpt of [1]:



All variables that are "switched" have to be averaged. For the

buck converter of figure (a), 2 variables have to be considered:

 $ar{v}_{x}(t) pprox d(t)ar{v}_{g}(t), \ ar{i}_{g}(t) pprox d(t)ar{i}_{L}(t).$ 

<sup>1</sup> The resulting averaged model is shown on figure (b).

Note: d(t) is not "switched" and must not be averaged.

## Solving the non-linearity problem: converter linearization

Let us first define circuit variables as follows:

$$\bar{x}(t) = X + \hat{\bar{x}}(t)$$

 $\bar{x}(t)$ :averaged value of variable xX:dc component of variable x (= operating point) $\hat{x}(t)$ :small-signal value of variable x around X

Products of variables (source of non linearities) can be linearized:

$$ar{x}(t)ar{y}(t) = (X+\hat{x}(t))(Y+\hat{y}(t)) 
onumber \ = XY+X\hat{y}(t)+\hat{x}(t)Y+\hat{x}(t)\hat{y}(t) 
onumber \ pprox XY+X\hat{y}(t)+\hat{x}(t)Y.$$

(日)

## Converter linearization: buck converter example



Excerpt of [1]:

The buck converter of figure (b) can then be linearized:

$$ar{v}_{x}(t) = V_{x} + \hat{ar{v}}_{x}(t) 
onumber \ = (D + \hat{d}(t))(V_{g} + \hat{ar{v}}_{g}(t)) 
onumber \ pprox DV_{g} + D\hat{ar{v}}_{g}(t) + \hat{d}(t)V_{g}.$$

Therefore,

$$\hat{ar{v}}_{x}(t)pprox D\hat{ar{v}}_{g}(t)+\hat{d}(t)V_{g}.$$

In the same way,

$$\hat{ar{i}}_g(t)pprox D\hat{ar{i}}_L(t)+\hat{d}(t)I_L.$$

The result of the linearization is shown on figure (c).

#### Transfer function: buck converter example

Excerpt of [1]:



The small-signal transfer function of the buck converter is:

$$egin{aligned} G_{vd}(s) &\triangleq \left. rac{\hat{v}_o(s)}{\hat{d}(s)} 
ight|_{\hat{v}_g=0,\hat{ar{l}}_o=0} = V_g rac{1+sr_CC}{1+s(r_C+r_L)C+s^2LC} \ &= G_{vd0}rac{1+rac{s}{\omega_{ESR}}}{1+rac{s}{Q\omega_0}+rac{s^2}{\omega_0^2}}. \end{aligned}$$

In the previous equation, the constants are defined as follows:

$$G_{vd0} \triangleq V_g,$$
  

$$\omega_{ESR} \triangleq \frac{1}{r_C C},$$
  

$$\omega_0 \triangleq \frac{1}{\sqrt{LC}},$$
  

$$Q \triangleq \frac{1}{r_C + r_L} \sqrt{\frac{L}{C}}$$

◆□▶ ◆□▶ ◆三▶ ◆三▶ 三三 のへぐ

#### Another example: buck-boost converter



To obtain the small-signal model of the buck-boost:

- write averaged values of  $\bar{v}_x(t)$ ,  $\bar{i}_x(t)$  and  $\bar{i}_g(t)$ ,
- linearize the averaged values to get  $\hat{v}_x(t)$ ,  $\hat{i}_x(t)$  and  $\hat{i}_g(t)$ ,
- draw the circuit that matches these linearized relationship.

Write the equations and draw the model

## Summary: averaged small-signal models of basic converters

Excerpt of [1]:









## Boost transfer function and right half-plane zero (RHPZ)



The small-signal transfer function of the boost converter is also obtained by solving the above circuit, but two controlled sources are involved in this case (using superposition is a fast way to find the solution):

$$G_{vd}(s) \triangleq \left. \frac{\hat{\hat{v}}_o(s)}{\hat{d}(s)} \right|_{\hat{\hat{v}}_g=0,\hat{\hat{i}}_o=0} = \frac{\left( \frac{V_o}{D'} - r'_L I_L \right) - sL' I_L}{1 + sr'_L C + s^2 L' C}$$
  
 $\frac{r_L}{D'^2}, \ L' = \frac{L}{D'^2}.$ 

Interpretation with exponential response, step response and frequency domain

14/85 ELEC0055: Elements of Power Electronics - PART II - Fall 2024

 $r'_{1} =$ 

#### State-space averaging: time variant model

State-space averaging is a generalization of the averaged small-signal modeling. Let us consider a converter that evolves between two structures  $S_0$  and  $S_1$ . The structure depends on the switches positions. The state-space equations are:

$$\frac{d\mathbf{x}}{dt} = \mathbf{A}_c \mathbf{x}(t) + \mathbf{B}_c \mathbf{v}(t),$$
  
$$\mathbf{y}(t) = \mathbf{C}_c \mathbf{x}(t) + \mathbf{E}_c \mathbf{v}(t).$$

*x*, *v* and *y* represent respectively the state, input and output vectors. *A<sub>c</sub>*, *B<sub>c</sub>*, *C<sub>c</sub>*, *E<sub>c</sub>* are matrices that model the converter for each switch position  $c \in \{0, 1\}$ . Let us now use define the PWM signal c(t) and its complement c'(t) = 1 - c(t). We can now rewrite the above equations.

Side note: in the LCS course E matrix is named D. We keep here the E notation to avoid confusion with the duty-cycle.

Example: see [1] eq 1.39, 1.40, 1.41, 1.42, 1.43, 1.44

$$\frac{d\mathbf{x}}{dt} = c(t)[\mathbf{A}_1\mathbf{x}(t) + \mathbf{B}_1\mathbf{v}(t)] + c'(t)[\mathbf{A}_0\mathbf{x}(t) + \mathbf{B}_0\mathbf{v}(t)],$$
  
$$\mathbf{y}(t) = c(t)[\mathbf{C}_1\mathbf{x}(t) + \mathbf{E}_1\mathbf{v}(t)] + c'(t)[\mathbf{C}_0\mathbf{x}(t) + \mathbf{E}_0\mathbf{v}(t)].$$

We can apply the averaging operator  $\langle . \rangle_{T_s}$  on both sides of the equation and with the small ripple approximation, we get the **averaged large-signal state-space equations**:

$$\begin{aligned} &\frac{d\bar{\boldsymbol{x}}}{dt} = [d(t)\boldsymbol{A}_1 + d'(t)\boldsymbol{A}_0]\bar{\boldsymbol{x}}(t) + [d(t)\boldsymbol{B}_1 + d'(t)\boldsymbol{B}_0]\bar{\boldsymbol{v}}(t), \\ &\bar{\boldsymbol{y}} = [d(t)\boldsymbol{C}_1 + d'(t)\boldsymbol{C}_0]\bar{\boldsymbol{x}}(t) + [d(t)\boldsymbol{E}_1 + d'(t)\boldsymbol{E}_0]\bar{\boldsymbol{v}}(t). \end{aligned}$$

Thanks to the averaging, the time varying nature of the system has been removed but the equations are still non-linear.

#### State-space averaging: operating point

The operating point can be found by solving the above equations for  $\frac{d\bar{x}}{dt} = 0$ :

$$\mathbf{0} = [D\mathbf{A}_1 + D'\mathbf{A}_0]\mathbf{X} + [D\mathbf{B}_1 + D'\mathbf{B}_0]\mathbf{V},$$
  
$$\mathbf{Y} = [D\mathbf{C}_1 + D'\mathbf{C}_0]\mathbf{X} + [D\mathbf{E}_1 + D'\mathbf{E}_0]\mathbf{V}.$$

With the following definition,

$$\mathbf{A} \triangleq D\mathbf{A}_1 + D'\mathbf{A}_0, \ \mathbf{B} \triangleq D\mathbf{B}_1 + D'\mathbf{B}_0,$$
$$\mathbf{C} \triangleq D\mathbf{C}_1 + D'\mathbf{C}_0, \ \mathbf{E} \triangleq D\mathbf{E}_1 + D'\mathbf{E}_0,$$

we get:

$$\boldsymbol{X} = -\boldsymbol{A}^{-1}\boldsymbol{B}\boldsymbol{V}, \ \boldsymbol{Y} = [-\boldsymbol{C}\boldsymbol{A}^{-1}\boldsymbol{B} + \boldsymbol{E}]\boldsymbol{V}.$$

The above solution is equivalent to apply the inductors volt-second balance and the capacitors charge balance under the small-ripple approximation. Example: see [1] eq 1.45, 1.46, 1.47

#### State-space averaging: small signal model

The state equation can be linearized by defining small signals around the operating point:

$$\hat{oldsymbol{x}}(t) \triangleq oldsymbol{ar{x}}(t) - oldsymbol{X}, \ \hat{d} \triangleq d(t) - D, \ \hat{oldsymbol{ar{v}}}(t) \triangleq oldsymbol{ar{v}}(t) - oldsymbol{V}.$$

Introducing the above definitions in the averaged large-signal state-space equations, we get the **small-signal equations**:

$$\frac{d\hat{\mathbf{x}}}{dt} = \mathbf{A}\hat{\mathbf{x}}(t) + \mathbf{F}\hat{d}(t) + \mathbf{B}\hat{\mathbf{v}}(t),$$
$$\hat{\mathbf{y}}(t) = \mathbf{C}\hat{\mathbf{x}}(t) + \mathbf{G}\hat{d}(t) + \mathbf{E}\hat{\mathbf{v}}(t),$$

where,

$$F \triangleq (A_1X + B_1V) - (A_0X + B_0V),$$
  
$$G \triangleq (C_1X + E_1V) - (C_0X + E_0V).$$

▲□▶ ▲□▶ ▲□▶ ▲□▶ □ のQで

#### State-space averaging: solving the small signal model

We can solve the small-signal equations in the Laplace domain:

$$s\hat{\bar{x}}(s) = A\hat{\bar{x}}(s) + F\hat{d}(s) + B\hat{\bar{v}}(s),$$
  

$$\hat{\bar{y}}(s) = C\hat{\bar{x}}(s) + G\hat{d}(s) + E\hat{\bar{v}}(s),$$
  

$$\Rightarrow \hat{\bar{y}}(s) = (C(sI - A)^{-1}F + G)\hat{d}(s) + (C(sI - A)^{-1}B + E)\hat{\bar{v}}(s)$$

The control transfer matrix is:

$$\boldsymbol{W}(s) \triangleq \frac{\hat{\boldsymbol{y}}(s)}{\hat{d}(s)}\Big|_{\hat{\boldsymbol{y}}(s)=0} = \boldsymbol{C}(s\boldsymbol{I}-\boldsymbol{A})^{-1}\boldsymbol{F} + \boldsymbol{G}.$$

The disturbance transfer matrix is:

$$W_D(s) riangleq rac{\hat{oldsymbol{j}}(s)}{\hat{oldsymbol{v}}(s)} \Big|_{\hat{d}(s)=0} = oldsymbol{C} (soldsymbol{I} - oldsymbol{A})^{-1}oldsymbol{B} + oldsymbol{E}.$$

Example: see [1] eq 1.48, 1.49, the boost transfer function has a RHZ (Right Half-Plane Zero).

Link with the LCS course: each term of *W*(s) and *W<sub>D</sub>*(s) represents the transfer function that models the effect of external inputs (duty-cycle, input voltage....) on outputs. Because there are multiple outputs and multiple inputs the system is called MIMO.

◆□▶ ◆□▶ ◆□▶ ◆□▶ □ のQC

In order to transform the duty-cycle (continuous variable that has a value between 0 and 1) into binary ("ON/OFF") signals that control power switches, we need a building block called "modulator".

There are two main families of PWM modulators:

NSPWM: naturally sampled pulse width modulator. They process a continuous time modulating signal u(t). They are typically used in analog controllers.

USPWM: uniformly sampled pulse width modulator. They process a sampled signal u[k] and generate a PWM signal updated every switching period. They are typically used in digital controllers.

▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶

## Naturally sampled pulse width modulator

Excerpt of [1]:



$$d[k] = \frac{u(t_k)}{V_r} \Rightarrow G_{PWM}(s) \triangleq \frac{\hat{d}}{\hat{u}} = \frac{1}{V_r}$$
(1)

・ロト ・ 理 ト ・ ヨ ト ・

э

500

## Closed loop system

Excerpt of [1]:



The above figure shows a block diagram of a closed loop system.  $G_{PWM}(s)$  is the transfer function of the PWM modulator.  $G_{vd}(s)$ models the converter behavior.  $G_c(s)$  is the compensator function to be designed. H(s) is the output voltage (current) sensor transfer function.

## Definition of the loop gain

Excerpt of [1]:



For the buck converter, we obtain:

$$T_u(s) = \frac{1}{V_r} G_{vd0} \frac{1 + \frac{s}{\omega_{ESR}}}{1 + \frac{s}{Q\omega_0} + \frac{s^2}{\omega_0^2}} H(s).$$

In the LCS course, the system to be controlled is called the plant and has a transfer function P(s). In a power converter, the plant consists of the PWM modulator, the power electronics circuit and the measurement circuit:

$$P(s) = G_{PWM}(s)G_{vd}(s)H(s)$$
(3)

- In the LCS course, the controller has a transfer function C(s) that is named here G<sub>c</sub>(s).
- In the LSC course, the loop gain is called L(s), here it is called T(s).

## Loop including external perturbation

Excerpt of [1]:



A D > A P > A B > A B >

э

- The uncompensated loop phase margin (at the crossover frequency) gives a stability criteria and allows to design the compensator G<sub>c</sub>(s).
- The reference setpoint to the output transfer function is given by:

$$G_{vvref,cl}(s) \triangleq \frac{\hat{\vec{v}}_o(s)}{\hat{\vec{v}}_{ref}} \bigg|_{\hat{\vec{v}}_g(s)=0,\hat{\vec{i}}_o=0} = \frac{1}{H(s)} \frac{T(s)}{1+T(s)},$$

・ロト ・ 四ト ・ 日ト ・ 日下

The sensitivity characteristics to external perturations is reduced by increasing the loop gain. Refering to the figure on the previous slide, the **closed loop** characteristics can be derived from the **open loop** characteristics:

$$\begin{split} G_{vg,cl}(s) &\triangleq \frac{\hat{\bar{v}}_o(s)}{\hat{\bar{v}}_g(s)} \bigg|_{\hat{\bar{v}}_{ref}=0,\hat{\bar{i}}_o=0} \qquad \qquad = \frac{G_{vg}(s)}{1+T(s)}, \\ Z_{o,cl}(s) &\triangleq -\frac{\hat{\bar{v}}_o(s)}{\hat{\bar{i}}_o(s)} \bigg|_{\hat{\bar{v}}_{ref}=0,\hat{\bar{v}}_g=0} \qquad \qquad = \frac{Z_o(s)}{1+T(s)}. \end{split}$$

From the above relations, the goal is to get T(s) as large as possible on a large bandwidth while maintaining a good phase margin.

▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶

## Relation between phase margin and stability

Excerpt of [2]:



For open loop characteristics with a loop gain that falls by -20 dB/decade when T(s) amplitude approaches 1, the phase margin directly affects the quality factor of the closed loop (second order) system response.

## Relation between phase margin and stability

Excerpt of [2]:



The step response of the closed loop (second order) system is directly related to the quality factor. The choice of a phase margin of  $52^{\circ}$  is now explained.

・ コ ト ・ 一 ト ・ ヨ ト ・

- **B** - **b** 

## Analog control loop design procedure

- 1. Determine  $G_{PWM}(s)$  using equation 1.
- Determine H(s) based on the specifications/design of your sensor.
- 3. Detemine the transfer function of your converter with the presented modeling techniques.
- 4. Trace the Bode Plots (MATALB) for  $T_u(s)$  (equation 2) for different operating points (input voltage, load).
- 5. Choose the cross-over frequency  $f_c$  typically 1/10 of the switching frequency.
- 6. Choose the target phase margin  $\phi_m$  typically > 52°.
- 7. Choose your compensator:

31/85

- if DC error has to be canceled, use a PI or PID,
- if phase margin has to be increased, use a PD or PID,
- if phase margin is already 90°, use a P or PI.
- 8. For the integrator term, choose a corner frequency that is 1/10 of the choosen cross-over frequency  $f_c$ .

## Chapter 2: The Digital Control Loop

- Analog vs. digital control
  - Example: digital voltage-mode control
  - A/D conversion
- The digital compensator
  - The digital PID controller (additive form)
  - Bilinear mapping
  - PID transformation with the bilinear mapping

・ロト ・ 四ト ・ 日ト ・ 日下

- PID controller in multiplicative form
- The digital pulse width modulator
- Loop delays
- Digital control loop design procedure
- The integral windup problem
- Unit conversion

Digital control of switched mode converters introduces two differences in comparison to analog control:

Time quantization: the controller samples values of analog variables, processes them to evaluate the modulation (duty-cycle) and apply it for one sampling period.

Amplitude quantization: analog variables are sampled with finite resolution analog-to-digital converters, they are therefore quantized.

There are different approaches to model switching converters. The approach presented here is based on the averaged model.

▲□▶ ▲□▶ ▲□▶ ▲□▶ □ のQで

## Example: digital voltage-mode control

Excerpt of [1]:



The sampled signal is defined by:

$$v_s[k] \triangleq v_s(t_k).$$

The most common choice for the sampling period is :

$$T = T_s$$
, where  $T_s$  is the switching period.

< ∃⇒

# A/D conversion

Excerpt of [1]:



- Sampling process
- Amplitude quantization
- Conversion delay t<sub>A/D</sub>

・ロト ・ 同ト ・ ヨト ・ ヨト

The sampling process moves the modeling problem from the analog to the digital world. The amplitude quantization makes the problem non linear. The delay modifies the dynamics.

Example: show captured data.

# Sampling rate different from $f_s$

Excerpt of [1]:



- Alias of the high frequency content of the analog signal is present in the sampled signal (for example at f<sub>s</sub>).
- Large digital filtering efforts are therefore required.

∍⊳

36/85
# Sampling rate equal to $f_s$

Excerpt of [1]:



- Alias of the high frequency content of the analog signal is present in the sampled signal but only at DC.
- No filtering efforts is needed, only DC compensation is required.

- ▲ 🗇 🕨 🔺 🖻

37/85

#### Sampling strategy to avoid DC alias

Excerpt of [1]:



For triangular waveforms, the most common solution is to sample the analog signal in the middle of the ramp. This suppresses DC aliasing effect.

・ロト ・ 同ト ・ ヨト ・ ヨト

#### Amplitude quantization

Excerpt of [1]:



The A/D converter linear range is divided into  $2^{n_{A/D}}$  bins. Each bin is  $q_{V_s}^{(A/D)}$  volts wide:

$$q_{\nu_s}^{(A/D)} = \frac{V_{FS}}{2^{n_{A/D}}} \qquad (4)$$

where  $V_{FS}$  is the full scale voltage.

The figure shows the quantization characteristic  $Q_{A/D}[.]$ :

$$v_s^\diamond[k] riangleq Q_{A/D}[v_s[k]] = q_{v_s}^{(A/D)} ilde{\mathsf{v}}_s[k]$$

where  $v_s^{\diamond}[k]$  is the quantized signal,  $v_s[k]$  is the analog signal and  $\tilde{v}_s[k]$  is the binary coded signal.

ELEC0055: Elements of Power Electronics - PART II - Fall 2024

39/85

## The controller

Excerpt of [1]:



The analog signal  $v_s(t)$  is sampled and quantized in  $v_s^{\diamond}[k]$ after the  $t_{A/D}$  conversion delay . The compensator uses this sampled signal to generate the new PWM command u[k] after the calculation delay  $t_{calc}$ .

A **linear** and **time-invariant** compensation law is described by a difference equation:

$$u[k] = -a_1 u[k-1] - a_2 u[k-2] - \dots - a_N u[k-N] + b_0 e[k] + b_1 e[k-1] + b_2 e[k-2] + \dots + b_M e[k-M]$$

## The digital PID controller (additive form)

Excerpt of [1]:



The PID law is given by:

$$u_{p}[k] = K_{p}e[k],$$
  

$$u_{i}[k] = u_{i}[k-1] + K_{i}e[k],$$
  

$$u_{d}[k] = K_{d}(e[k] - e[k-1]),$$
  

$$u[k] = u_{p}[k] + u_{i}[k] + u_{d}[k].$$

(4 周) トイラト イラト

The z-transform of the above laws gives the transfer function of the PID compensator:

$$G_{PID}(z) riangleq rac{U(z)}{E(z)} = K_p + rac{K_i}{1-z^{-1}} + K_d(1-z^{-1})$$

How can we determine the digital coefficients  $K_p$ ,  $K_i$  and  $K_d$ ?

#### Bilinear mapping

The coefficients can be determined by using the classical compensation techniques in the s-domain. For that purpose the  $G_{PID}(z)$  function can be transformed using:

$$z = e^{sT} \tag{5}$$

(7)

(日)

This transformation is not adequate because it transforms  $G_{PID}(z)$  in a transcendental function of s. A good approximation is:

$$z(s) = e^{sT} = \frac{e^{+s\frac{T}{2}}}{e^{-s\frac{T}{2}}} = \frac{1+s\frac{T}{2}+\cdots}{1-s\frac{T}{2}+\cdots} \approx \frac{1+s\frac{T}{2}}{1-s\frac{T}{2}}$$
(6)

It is called the bilinear transformation:

$$z(s) \approx \frac{1+s\frac{T}{2}}{1-s\frac{T}{2}} \Leftrightarrow s(z) \approx \frac{2}{T}\frac{1-z^{-1}}{1+z^{-1}}$$

## Bilinear mapping interpretation: trapezoidal approximation



In time domain:

$$\int v(\tau) d\tau = p(t)$$

In s-domain:

$$\frac{1}{s}V(s) = P(s) \Rightarrow V(s) = s P(s)$$

We can write in discrete time:

$$p[k] - p[k-1] = t$$
rapeze surface  $= rac{v[k-1] + v[k]}{2}T$ 

In z-domain:

$$P(z) - z^{-1}P(z) = \frac{z^{-1}V(z) + V(z)}{2}T \Rightarrow V(z) = \frac{2}{T}\frac{1 - z^{-1}}{1 + z^{-1}}P(z)$$

#### Bilinear mapping

The bilinear mapping has the following properties:

- It is a rational transformation.
- Stability limits are conserved: the unit circle (|z| = 1) in the z-domain is mapped on the y axis in the s-domain.
- Some frequency wrapping is introduced (due to the approximation) but it yields less than 10% error for frequencies below  $\frac{1}{6}\frac{1}{T}$ .

Excerpt of [1]:



Application of the bilinear transformation allows us to work in the s-domain and to use the classical analog design tools.

$$G_{PID}(z) riangleq rac{U(z)}{E(z)} = K_p + rac{K_i}{1-z^{-1}} + K_d(1-z^{-1})$$

is transformed to

$$G_{PID}'(s) riangleq rac{U(s)}{E(s)} = K_{
ho} + rac{K_i}{T} rac{1 + rac{s}{\omega_{
ho}}}{s} + K_d T rac{s}{1 + rac{s}{\omega_{
ho}}},$$

where  $\omega_p \triangleq \frac{2}{T}$ . It should be noted that  $\omega_p$  appears when converting  $G_{PID}(z)$  in the s-domain and there is no freedom on the value of  $\omega_p$ .

(ロト (同) (E) (E) (E) (O)(O)

#### PID transformation with the bilinear mapping

- On the previous slide,  $K_i$  is the digital coefficient of the integrator. In the s-domain, it is **divided** by T. This can be explained physically as follows: if T is for example increased, the digital accumulation  $(u_i[k] = u_i[k-1] + K_ie[k])$  will be performed less often due to the larger sampling period T. This is equivalent to a slower integral in the s-domain that is represented by a lower analog integrator gain.
- ▶ In a similar way,  $K_d$  is the digital coefficient for the derivative part. When transformed in the s-domain, it is **multiplied** by T. This can be explained physically as follows: if T is for example increased, the digital derivative term  $(u_d[k] = K_d(e[k] - e[k - 1]))$  will performed on a larger sampling period T. Therefore, the estimation of the error variation will be taken on sample e[k] and e[k - 1] that are more spaced in time. This will amplify the value of e[k] - e[k - 1]which is equivalent to a multiplication by T in the s-domain.
- The multiplicative form of the PID compensator is easier to use and equivalence relation exists (see next slides).

#### PID controller in multiplicative form

$$G'_{PID}(s) = K_p + \frac{K_i}{T} \frac{1 + \frac{s}{\omega_p}}{s} + K_d T \frac{s}{1 + \frac{s}{\omega_p}}$$
(8)

is equivalent to

$$G_{PID}^{\prime}(s)=G_{PI\infty}^{\prime}(1+rac{\omega_{PI}}{s})G_{PD0}^{\prime}rac{1+rac{s}{\omega_{PD}}}{1+rac{s}{\omega_{P}}}$$

with,

$$K_{p} = G'_{PI\infty} G'_{PD0} \left(1 + \frac{\omega_{PI}}{\omega_{PD}} - \frac{2\omega_{PI}}{\omega_{p}}\right), \tag{9}$$

$$K_i = 2G'_{PI\infty}G'_{PD0}\frac{\omega_{PI}}{\omega_p},\tag{10}$$

$$K_d = \frac{1}{2} G'_{PI\infty} G'_{PD0} (1 - \frac{\omega_{PI}}{\omega_p}) (\frac{\omega_p}{\omega_{PD}} - 1).$$
(11)

◆□▶ ◆□▶ ◆三▶ ◆三▶ 三三 のへぐ

#### PID bode plot

Excerpt of [1]:



æ

# PI (lag) compensator in multiplicative form

$$G'_{PI}(s) = K_p + \frac{K_i}{T} \frac{1 + \frac{s}{\omega_p}}{s}$$
(12)

is equivalent to

$$G_{PI}'(s) = G_{PI\infty}'(1+rac{\omega_{PI}}{s})$$

with,

$$K_{p} = G'_{PI\infty} (1 - \frac{\omega_{PI}}{\omega_{p}}), \qquad (13)$$
$$K_{i} = 2G'_{PI\infty} \frac{\omega_{PI}}{\omega_{p}}. \qquad (14)$$

◆□▶ ◆□▶ ◆三▶ ◆三▶ 三三 のへぐ

#### PD (lead) compensator in multiplicative form

$$G_{PD}'(s) = K_p + K_d T rac{s}{1 + rac{s}{\omega_p}}$$

is equivalent to

$$G_{PD}^{\prime}(s)=G_{PD0}^{\prime}rac{1+rac{s}{\omega_{PD}}}{1+rac{s}{\omega_{P}}}$$

with,

(15)

▲□▶ ▲□▶ ▲□▶ ▲□▶ □ のQで

# The digital pulse width modulator

Excerpt of [1]:



Digital modulator are based on a digital counter. The higher the counter clock ( $T_{clk}$ ), the higher the resolution.

The behavior of the digital PWM is given by:

$$T_s = N_r T_{clk}, \qquad (18)$$

$$d[k] = \frac{u[k]}{N_r},\tag{19}$$

$$q_D = \frac{T_{clk}}{T_s} = \frac{1}{N_r}.$$
 (20)

∃⇒

Different delays exist between the sampling of the analog signal up to the generation of the PWM:

- ► Control delay (*t<sub>cntrl</sub>*):
  - ► FPGA based controller: all calculations are performed in //, the processing delay is negligible and the only delay is the A/D conversion delay occuring between the sampling of the analog signal and the availability of the sampled version v<sup>\*</sup><sub>s</sub>[k].
  - DSP (CPU) based controller: several instructions are needed and there is an extra delay to be taken into account.
- Modulation delay (t<sub>DPWM</sub>): the PWM modulator has an intrinsic delay due to the PWM process itself.

The total delay induced by the control process is modeled:

$$t_d = t_{cntrl} + t_{DPWM} \Rightarrow e^{-st_d}$$

(日本)(四本)(日本)(日本)(日本)

## Loop delays

Excerpt of [1]:



A typical software based controller is shown. The A/D sampling and the controller calculations are performed during one switching period ( $= t_{cntrl}$ ). The PWM delay ( $t_{DPWM}$ ) occurs after the control delay.

## DPWM delay

Excerpt of [1]:



The total loop delay is defined by:

$$t_d \triangleq t_{cntrl} + t_{DPWM}.$$

This total delay is modeled in the s-domain with  $e^{-st_d}$ . Before estimating compensation factors, the loop gain is corrected to take this delay into account:

$$T_u^{\dagger}(s) \triangleq T_u(s)e^{-st_d}.$$

イロト 不得 トイヨト イヨト

## Digital control loop design procedure

- 1. Model the loop as in the analog control loop design but with the delay corrected loop gain  $T_u^{\dagger}(s)$ .
- 2. Design the compensation as in the analog control loop design using the chosen compensator (equation 8, 12 or 15).
- 3. Once the controller coefficient are determined, transform them to their digital version (equation 9 to 11, 13 to 14 or 16 to 17).
- 4. Implement the control law in the digital processor.

It should be noted that the above design procedure is valid if the sampled signal is a good representation of the averaged signal. This assumption is the *small-aliasing approximation* expressed mathematically by:

 $v_s[k] \approx \bar{v}_s(t_k).$ 

If it is not the case, discrete-time modeling techniques have to be used.

## The integral windup problem (example)

Excerpt of [1]:



For  $V_{g} = 4V$ , at  $0\mu s$ , the current rises to 10 A. The controller reacts quickly to the induced  $v_o(t)$  change and u[k] quickly reaches its saturation point. However,  $v_o(t)$  is still under the set point and the integrator continues to integrate. When  $v_o(t)$  starts to rise again, the integrator is well above 1 and forces u[k] to stay at 1 and creates an unexpected lag in the reaction of the crontroller finally  $\overline{180}$  creating a  $v_o(t)$  overshoot.

**B b** 

#### Actuator saturation and integral anti-windup

The solution to the windup problem is to:

- Saturate all variables to avoid numeric issues. Especially saturate u[k] between the min/max duty-cycle.
- Stop integration when u[k] reaches its saturation limits:

$$\operatorname{sat}[k] = \left\{ egin{array}{cc} 0 & ext{if } 0 \leq u_{PID}[k] \leq 1, \ 1 & ext{otherwise}. \end{array} 
ight.$$

Excerpt of [1]:



## Unit conversion

Excerpt of [1]:



- *K<sub>p</sub>*, *K<sub>i</sub>* and *K<sub>d</sub>* on slide "The PID compensator (additive form)" have physical units: <sup>1</sup>/<sub>V</sub>.
- In the processor, v<sub>s</sub><sup>◊</sup>[k] and u[k] are represented by integer numbers related to the respective resolutions 2<sup>n<sub>A/D</sub></sup> (equation 4) and N<sub>r</sub> (equation 20).

イロト 不得 トイヨト イヨト

## Unit conversion: from physical to digital representation

|                 | Design (physical unit) | Digital representation                      |
|-----------------|------------------------|---------------------------------------------|
| u[k]            | 0  ightarrow 1         | $0 \rightarrow N_r$                         |
| $v_s[k]$        | $0 \rightarrow V_{FS}$ | $0  ightarrow 2^{n_{A/D}}$                  |
| $K_p, K_i, K_d$ | in $\frac{1}{V}$       | multiply by $\frac{V_{FS}}{2^{n_{A/D}}}N_r$ |

Table: Conversion from physical to digital representation.

- The above table is also valid for current measurements because the current is transformed in a voltage by the measurement device. This is modeled by H(s).
- K<sub>i</sub> is often lower than K<sub>p</sub> yielding to quantification errors. u<sub>i</sub>[k] = u<sub>i</sub>[k − 1] + K<sub>i</sub>e[k] can be performed in two steps:

$$accumulator[k] = accumulator[k - 1] + e[k], \ u_i[k] = K_i accumulator[k]$$

(ロト (同) (E) (E) (E) (O)(O)

#### Unit conversion: example

- ► The PWM generator runs at 16*MHz* and generate a 20*kHz* signal  $\Rightarrow N_r = \frac{16MHz}{20kHz} = 800$ .
- ADC of 8 bits resolution over  $5V \Rightarrow V_{FS} = 5V$  and  $2^{n_{A/D}} = 256$ .

•  $Kp = 0.32/V \Rightarrow$  digital value of  $K_p$  is  $K_p \frac{V_{FS}}{2^{n_A/D}} N_r = 5$ .

```
#define Kp 5  /* 5 <-> 0.32/V  */
...
int16 adVoltage;  /* 256 <-> 5 V  */
int16 refVoltage = 169; /* 256 <-> 5 V => 169 <-> 3.3 V */
int16 e_k;  /* 256 <-> 5 V => 169 <-> 3.3 V */
int16 up_k;  /* 800 <-> 100 % duty-cycle  */
...
/* Calculate up[k] = Kp e[k] */
e_k = refVoltage - adVoltage;
up_k = Kp * e_k;
...
```

 Clearly document the variables regarding their physical meaning.

• Multiplication by  $K_p$ ,  $K_i$ ,  $K_d$  can often be replaced by shift. ELECO055: Elements of Power Electronics - PART II - Fall 2024

#### Controller design (script) with some approximations:

averaging,

linearization.

Controller verification (LTSpice) with a more accurate model:

▲□▶ ▲□▶ ▲□▶ ▲□▶ □ のQで

- time variance,
- non linearities (including quantization).

Current mode control: general principle

- Hysteretic control
  - Principle
  - Operating frequency
- Current programmed control
  - Principle
  - Stability analysis
  - Compensation
- External voltage loop

(日)

# Current mode control: general principle



- The plan to be controlled is a variable structure circuit.
- Current mode control takes advantage of the variable structure nature of the circuit.
- The s(x<sub>s</sub>, ref) function directly changes the circuit structure by acting on the switches state.
- Current mode control is a special case of a sliding mode controller (see [3]).
- The PWM modulator is replaced here by a direct action on the circuit structure based on a function of the state of the system and the reference.

## Hysteretic control: principle



The hysteresis i<sub>ch</sub> - i<sub>cl</sub> is introduced to avoid infinite switching frequency.

< ∃⇒

Example: see 1\_HystereticControl.asc

#### Hysteretic control: operating frequency



- ► The inductor average current  $i_{cl} + \frac{i_{ch} i_{cl}}{2} = \frac{i_{ch} + i_{cl}}{2}$ ⇒ The average current in the inductor is perfectly controlled.
- Bipolar operation is natural (current can be > 0 or < 0).
- The switching period is function of V<sub>g</sub> and D
   The switching frequency varies over a large range.

The variation of the switching frequency can be dangerous because the switching frequency can be equal to the resonance frequency of the input or output filter for some operating point. Dangerous resonance can occur.

Therefore, fixed operating frequency is often preferred.

## Current programmed control: principle



Fixed switching frequency is achieved:

- The switch gate is controlled by a set/reset flip-flop.
- A pulse generator periodically activates the gate at the switching frequency (set).
- The inductor current  $i_L(t)$  is permanently compared to the setpoint  $i_c(t)$ .
- Once inductor current i<sub>L</sub>(t) is higher than the setpoint i<sub>c</sub>(t), the gate is deactivated (reset).

# Current programmed control: stability analysis procedure



Instead of using the average model to analyze the control loop, it is possible to directly work in the z-domain. The procedure is as follows:

- 1. select all state variables  $(i_L(t))$ ,
- 2. select the sampling instant and name it using "k" index  $(i_L[k])$ ,
- express the state evolution (matrix form) from "k" to "k+1" (i<sub>L</sub>[k + 1] as a function of i<sub>L</sub>[k], i<sub>c</sub>[k]),
- 4. apply linearization  $(i_c[k] = I_c + \hat{i}_c[k], i_L[k] = I_L + \hat{i}_L[k]),$
- 5. linearization gives steady-state and small-signal equations,
- 6. apply z-transform to small-signal equation by "replacing" k + 1 by z, k + 2 by  $z^2$ ...
- 7. extract the poles of the z-domain transfer function to access stability,
- 8. trace the step function and the bode plot to evaluate the performances.
- ELEC0055: Elements of Power Electronics PART II Fall 2024

69/85

# Current programmed control: time domain equation



$$i_{c}[k] - i_{L}[k] = d[k] T_{s} \frac{V_{g} - V_{o}}{L} \Rightarrow d[k] = (i_{c}[k] - i_{L}[k]) \frac{L}{T_{s}(V_{g} - V_{o})}, \quad (21)$$
$$i_{L}[k+1] - i_{c}[k] = d'[k] T_{s} \frac{-V_{o}}{L} \Rightarrow i_{L}[k+1] = i_{c}[k] - (1 - d[k]) T_{s} \frac{V_{o}}{L}. \quad (22)$$

Introducing (21) in (22) yields:

$$i_{L}[k+1] = i_{c}[k](1 + \frac{V_{o}}{V_{g} - V_{o}}) - i_{L}[k]\frac{V_{o}}{V_{g} - V_{o}} - T_{s}\frac{V_{o}}{L}.$$
(23)

Let us define:

$$i_c[k] = l_c + \hat{i}_c[k],$$
 (24)

$$i_L[k] = I_L + \hat{i}_L[k].$$
 (25)

Equation (23) becomes:

$$\hat{i}_{L}[k+1] = \hat{i}_{c}[k](1 + \frac{V_{o}}{V_{g} - V_{o}}) - \hat{i}_{L}[k]\frac{V_{o}}{V_{g} - V_{o}}, \\ I_{L} = I_{c}(1 + \frac{V_{o}}{V_{g} - V_{o}}) - T_{s}\frac{V_{o}}{L} - I_{L}\frac{V_{o}}{V_{g} - V_{o}}.$$

Introducing  $D = \frac{V_o}{V_g}$  in the above equations yields:

$$\hat{i}_{L}[k+1] = \hat{i}_{c}[k] \frac{1}{1-D} - \hat{i}_{L}[k] \frac{D}{1-D} , \qquad (26)$$

$$I_{L} = I_{c} - T_{s} \frac{V_{o}}{L} (1 - D).$$
(27)

▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶ ▲□▶

## Current programmed control: stability analysis

Taking the z-transform of equation (26):

$$z\hat{l}_{L}(z) = \hat{l}_{c}(z)\frac{1}{1-D} - \hat{l}_{L}(z)\frac{D}{1-D} , \qquad (28)$$

$$\hat{l}_L(z) = \hat{l}_c(z) \frac{1}{z(1-D)+D}, \ p_z = -\frac{D}{1-D}.$$
 (29)


## Current programmed control: compensation



Cecil W. Deisch (Bell Laboratories, see [4]) observed that this instability was related to the slope of the current.

- At high duty-cycle, the rising slope is "too low" and leads to instabilities.
- A small change in current, creates a large change in duty-cycle.
- Compensation is performed by adding an artificial ramp to the current (or by adding the opposite ramp to the reference point, see dotted box on the figure).

#### Compensation: time domain equation



$$i_{L}[k] + d[k]T_{s}\frac{V_{g} - V_{o}}{L} = i_{c}[k] - d[k]\delta T_{s}\frac{V_{g}}{L}$$
(30)

$$\Rightarrow d[k] = (i_c[k] - i_L[k]) \frac{1}{T_s \frac{V_g - V_o}{L} + \delta T_s \frac{V_g}{L}} , \qquad (31)$$

$$i_{L}[k+1] = i_{c}[k] - d[k]\delta T_{s} \frac{V_{g}}{L} - (1 - d[k]) T_{s} \frac{V_{o}}{L}.$$
(32)

#### 74/85 ELEC0055: Elements of Power Electronics - PART II - Fall 2024

#### Compensation: small signal and steady state

Eliminating d[k] by inserting (31) in (32) yields:

$$i_L[k+1] = i_c[k](1 + \frac{V_o - \delta V_g}{V_g - V_o + \delta V_g}) - i_L[k](\frac{V_o - \delta V_g}{V_g - V_o + \delta V_g}) - T_s \frac{V_o}{L}$$

Using Equation (24) and (25), the previous equation becomes:

$$\hat{i}_{L}[k+1] = \hat{i}_{c}[k]\left(1 + \frac{V_{o} - \delta V_{g}}{V_{g} - V_{o} + \delta V_{g}}\right) - \hat{i}_{L}[k]\frac{V_{o} - \delta V_{g}}{V_{g} - V_{o} + \delta V_{g}} ,$$

$$I_{L} = I_{c}\left(1 + \frac{V_{o} - \delta V_{g}}{V_{g} - V_{o} + \delta V_{g}}\right) - T_{s}\frac{V_{o}}{L} - I_{L}\frac{V_{o} - \delta V_{g}}{V_{g} - V_{o} + \delta V_{g}}$$

Introducing  $D = \frac{V_o}{V_g}$  in the above equations yields:

$$\hat{i}_{L}[k+1] = \hat{i}_{c}[k] \frac{1}{1 - (D - \delta)} - \hat{i}_{L}[k] \frac{D - \delta}{1 - (D - \delta)} , \qquad (33)$$

$$I_{L} = I_{c} - T_{s} \frac{V_{o}}{L} (1 - (D - \delta)).$$
(34)

75/85 ELEC0055: Elements of Power Electronics - PART II - Fall 2024

# Compensation: stability analysis

Taking the z-transform of equation (33):

$$z\hat{l}_{L}(z) = \hat{l}_{c}(z)\frac{1}{1-(D-\delta)} - \hat{l}_{L}(z)\frac{D-\delta}{1-(D-\delta)},$$
(35)

$$\hat{l}_{L}(z) = \hat{l}_{c}(z) \frac{1}{z(1-(D-\delta))+(D-\delta)} , \ p_{z} = -\frac{D-\delta}{1-(D-\delta)}.$$
(36)



76/85

ELEC0055: Elements of Power Electronics - PART II - Fall 2024

# Compensation: discussion



- $\delta$  shifts the poles position,  $\delta > 0.5$  guarantees stability  $\forall D$ .
- Poles show the speed of convergence of the remaining error at each switching cycle.
- Therefore, a real negative pole in the z-domain corresponds to sub-harmonic oscillation.
- In practice, when the system is unstable, chaotic behavior appears because large signal operation is non-linear.

# External voltage loop: principle



- The internal loop is built with the current programmed controller, its setpoint is i<sub>c</sub>(t).
- The external control loop computes the voltage error between the set point voltage v<sub>ref</sub> and the output voltage v(t).

▲ 同 ▶ | ▲ 三 ▶

• 3 •

• The voltage error is used by the compensator to drive  $i_c(t)$ .

78/85 ELEC0055: Elements of Power Electronics - PART II - Fall 2024

#### External voltage loop: simple approximation





Over one switching period, the averaged values are related by d(t) in CCM:

> $\bar{v}_2(t) = d(t)\bar{v}_1(t),$  $\overline{i}_1(t) = d(t)\overline{i}_2(t).$

Т

The current control loop is assumed to be perfect (simple approximation):

$$egin{aligned} &d(t)ar{v_1}(t),\ &d(t)ar{i_2}(t).\ &=ar{i_2}(t)ar{i_2}(t)=ar{i_c}(t).\ &=ar{v_1}(t)ar{i_1}(t)=ar{v_2}(t)ar{i_2}(t)=ar{v_2}(t)ar{i_c}(t)=ar{p}(t) \end{aligned}$$

# Current programmed control: averaged model



The switch is replaced by its averaged model:

- the output port is a controlled current source:  $i_c(t)$ ,
- the input port reflects this current with power preservation:  $\bar{i}_1(t)\bar{v}_1(t) = \bar{i}_c(t)\bar{v}_2(t) = \bar{p}(t).$

 $\Rightarrow$  linearization has to be applied.

Note: similar reasoning can be applied to other topologies yielding similar models.

<日</th><</th>

$$ar{v_1}(t) = V_1 + \hat{v_1}(t), \ ar{i_1}(t) = I_1 + ar{i_1}(t), \ ar{v_2}(t) = V_2 + \hat{v_2}(t), \ ar{i_2}(t) = I_2 + ar{i_2}(t), \ ar{i_c}(t) = I_c + ar{i_c}(t).$$

Power conservation can be rewritten:

$$(V_1+\hat{ec{v}_1}(t))(I_1+\hat{ec{i}_1}(t))=(V_2+\hat{ec{v}_2}(t))(I_c+\hat{ec{i}_c}(t))$$

The input port current is given by:

$$\hat{\vec{i}}_1(t) = \hat{\vec{i}}_c(t) rac{V_2}{V_1} + \hat{\vec{v}}_2(t) rac{I_c}{V_1} - \hat{\vec{v}}_1(t) rac{I_1}{V_1}$$

The output port current is:  $\hat{\vec{i}_2}(t) = \hat{\vec{i}_c}(t)$ 



# Controlled sources function of input and output voltages







ELEC0055: Elements of Power Electronics - PART II - Fall 2024

82/85

#### Current programmed control: transfer functions



$$\begin{split} G_{vc,cpc}(s) &\triangleq \frac{\hat{\bar{v}}(s)}{\hat{\bar{l}}_{c}(s)} \Big|_{\hat{v}_{g}=0} = (R||\frac{1}{sC}) = \frac{R}{1+sRC} \quad \rightarrow 1^{st} \text{ order, easy compensator design,} \\ G_{vg,cpc}(s) &\triangleq \frac{\hat{\bar{v}}(s)}{\hat{\bar{v}}_{g}(s)} \Big|_{\hat{\bar{l}}_{c}=0} = 0 \qquad \rightarrow \text{no sensitivity to input voltage,} \\ Z_{g,cpc}(s) &\triangleq \frac{\hat{\bar{v}}_{g}(s)}{\hat{\bar{l}}_{g}(s)} \Big|_{\hat{\bar{l}}_{c}=0,\hat{\bar{v}}=0} = -\frac{R}{D^{2}} \qquad \rightarrow \text{stability concern.} \end{split}$$

83/85

## Current programmed control: summary of key points

- Output voltage can be controlled by implementing a control loop.
- Theory of chapter 1 and 2 can be applied by replacing:

 $T_u(s) \triangleq G_{PWM}(s)G_{vd}(s)H(s) 
ightarrow T_u(s) \triangleq G_{vc,cpc}(s)H(s)$ 

- Instead of controlling d, the new controller controls i<sub>c</sub>, this is easier because the phase of G<sub>vc,cpc</sub>(s) is 90° higher compared to G<sub>PWM</sub>(s)G<sub>vd</sub>(s).
- Current programmed control is a particular case of sliding mode control, this kind of control reduces by one the order of the controlled system, this explains the "gain" of 90° when comparing to G<sub>vd</sub>(s).
- The above procedure can be applied to other topologies: boost, buck-boost...
- The small-signal negative resistance appears in all high efficiency converters where output power/current is controlled (nearly always the case).
- The small-signal negative resistance affects the stability of the sources powering the converter.
- Bandwidth of current programmed control is excellent yielding to unsurpassed over-current protection.
- 84/85 ELEC0055: Elements of Power Electronics PART II Fall 2024

- P. M. Luca Corradini, Dragan Maksimović and R. Zane, Digital Control of High-Frequency Switched-Mode Power Converters. Wiley-IEEE Press, 2015.
- [2] R. W. Erickson and D. Maksimović, *Fundamentals of Power Electronics*.
   Kluwer Academic Publishers, second ed., 2001.
- [3] Hansruedi Bühler, *Réglage par mode de glissement*. Presses Polytechniques Romandes, 1986.
- [4] C. W. Deisch, "Simple switching control method changes power converter into a current source," in 1978 IEEE Power Electronics Specialists Conference, pp. 300–306, 1978.

(日)