

# Pre-lab Assignment Shikai Shen.

Welcome to EE 113B/213B! Throughout the semester, we will design, prototype, and validate a maximum power point tracking (MPPT) converter for a PV module. To get started, let's assume we plan to use a synchronous buck topology, shown in Fig. 1. Notice the PV module is modeled as a current source. In this first pre-lab, we will size the converter's components. We will also download and install the Code Composer Studio (CCS) integrated development environment (IDE) as well as the C2000Ware software development kit (SDK).



Figure 1: Synchronous buck converter.

Table 1: Buck Converter Design Specifications

| Specification           | Value       |
|-------------------------|-------------|
| Nominal Input Voltage   | 20 V        |
| Input Voltage Range     | 16-24 V     |
| Output Voltage          | 12 V        |
| Nominal Output Power    | 100 W       |
| Output Power            | 50-100 W    |
| Switching Frequency     | 100 kHz     |
| Input Voltage Ripple    | $\leq 5\%$  |
| Output Voltage Ripple   | $\leq 5\%$  |
| Inductor Current Ripple | $\leq 20\%$ |

## Size Components

Assume your buck converter has the specifications shown in Table 1. For all of the following calculations, you may assume deadtime is negligible. Hint: You are encouraged to write a script for these sizing calculations in case you change your design later.

1. Calculate the duty cycles required for the nominal operating point and all four corner operating points (i.e., all four combinations of highest load, lowest load, highest input voltage, and lowest input voltage).
2. Assuming a peak-to-peak inductor current ripple of no more than 20% at full power, calculate the minimum inductance required for  $L$ .
3. Assuming a peak-to-peak output voltage ripple of no more than 5% for any operating point, calculate the minimum capacitance required for  $C_{out}$ .
4. Assuming a peak-to-peak input voltage ripple of no more than 5% for any operating point, calculate the minimum capacitance required for  $C_{in}$ .
5. Calculate the maximum voltage and current stress for each switch (i.e., each power transistor).
6. How would choosing a higher switching frequency affect your answers for questions 1-5? Explain.

Welcome to EE 113B/213B! Throughout the semester, we will design, prototype, and validate a maximum power point tracking (MPPT) converter for a PV module. To get started, let's assume we plan to use a synchronous buck topology, shown in Fig. 1. Notice the PV module is modeled as a current source. In this first pre-lab, we will size the converter's components. We will also download and install the Code Composer Studio (CCS) integrated development environment (IDE) as well as the C2000Ware software development kit (SDK).



Figure 1: Synchronous buck converter.

①



Size Components

$$T_s = \frac{1}{f_s} = 10^{-5} s$$

Assume your buck converter has the specifications shown in Table 1. For all of the following calculations, you may assume deadtime is negligible. Hint: You are encouraged to write a script for these sizing calculations in case you change your design later.

Table 1: Buck Converter Design Specifications

| Specification           | Value         |
|-------------------------|---------------|
| Nominal Input Voltage   | 20 V          |
| Input Voltage Range     | 16-24 V       |
| Output Voltage          | 12 V          |
| Nominal Output Power    | 100 W         |
| <u>Output Power</u>     | 50-100 W load |
| Switching Frequency     | 100 kHz       |
| Input Voltage Ripple    | $\leq 5\%$    |
| Output Voltage Ripple   | $\leq 5\%$    |
| Inductor Current Ripple | $\leq 20\%$   |

1. Calculate the duty cycles required for the nominal operating point and all four corner operating points (i.e., all four combinations of highest load, lowest load, highest input voltage, and lowest input voltage).

2. Assuming a peak-to-peak inductor current ripple of no more than 20% at full power, calculate the minimum inductance required for  $L$ .

For Buck Converter,  $V_{out} = D \cdot V_{in}$ .

1. Nominal operating point:

$$V_{in}=20V, P_{out}=100W, V_{out}=12V, D=0.6$$

$$2. \frac{di_L}{dt} = \frac{V_i}{L}$$



1.2 highest  $V_{in}$ , highest load  $\Leftrightarrow P_{max}$

$$\Rightarrow V_{in}=24V, P_{max}=100W, V_{out}=12V.$$

$$\Rightarrow D=0.5$$

S2 on:



$$\langle i_L \rangle = D(V_{in}-V_o) + D'( -V_o) = 0$$

$$\langle i_L \rangle = \dots = 0$$

$$\Rightarrow \langle i_L \rangle = I_L = \frac{V_o}{R}$$

1.3 highest  $V_{in}$ , lowest load  $\Leftrightarrow P_{min}$

$$\Rightarrow V_{in}=24V, P_{min}=50W, V_{out}=12V.$$

$$\Rightarrow D=0.5$$

$$20i_L = \Delta i_{L,pp} = \left| \frac{V_i}{L} \cdot D T_s \right| = \left| \frac{V_o - V_i}{L} \cdot D T_s \right|$$

$$\Delta i_{L,pp} \leq i_L \cdot 20\%, \Rightarrow \left| \frac{V_o - V_i}{L} \cdot D T_s \right| \leq \frac{V_o}{R} \cdot 20\%.$$

$$\Rightarrow L \geq \frac{5(V_{in}-V_o) \cdot D T_s}{V_o} \cdot R, \quad R = \frac{V_o^2}{P}$$

$$\Rightarrow L \geq \frac{5(V_{in}-V_o) \cdot D T_s \cdot V_o}{P}$$

MAX

$$\text{when } D=0.5, L \geq \frac{5(24-12) \times 0.5 \times 10^{-5} \times 12}{50} = 3.6 \times 10^{-5} H$$

1.4 lowest  $V_{in}$ , highest load  $\Leftrightarrow P_{max}$

$$\Rightarrow V_{in}=16V, P_{max}=100W, V_{out}=12V$$

$$\Rightarrow D=0.75$$

1.5 lowest  $V_{in}$ , lowest load  $\Leftrightarrow P_{min}$

$$\Rightarrow V_{in}=16V, P_{min}=50W, V_{out}=12V, D=0.75$$

3. Assuming a peak-to-peak output voltage ripple of no more than 5% for any operating point, calculate the minimum capacitance required for  $C_{out}$ .  $\Delta V_c \leq 5\%$
4. Assuming a peak-to-peak input voltage ripple of no more than 5% for any operating point, calculate the minimum capacitance required for  $C_{in}$ .
5. Calculate the maximum voltage and current stress for each switch (i.e., each power transistor).
6. How would choosing a higher switching frequency affect your answers for questions 1-5? Explain.

3.  $\frac{dV_c}{dt} = \frac{\dot{I}_c}{C} \quad . \quad I_c = I_L - \frac{V_o}{R}, \Rightarrow \Delta \dot{I}_c = \Delta \dot{I}_L \text{ (neglect } V_c\text{)}.$  

$$q = C \cdot 2\Delta V_c = \frac{1}{2} \cdot \frac{1}{2} T_s \cdot \Delta \dot{I}_L$$

$$\Rightarrow \Delta V_c = \frac{T_s \cdot \Delta \dot{I}_L}{8C}, \quad (\Delta \dot{I}_L = \left| \frac{V_o - V_{in}}{2L} \cdot D T_s \right| =), \quad 2\Delta \dot{I}_L = 20\% I_L \Rightarrow 2\Delta \dot{I}_L = 20\% \times \frac{100}{12} \text{ or } 20\% \times \frac{50}{12}$$

$$\Rightarrow 2\Delta V_c \leq V_c \cdot 5\% = V_o \cdot 5\% = 12 \cdot 5\% = 0.6V \quad = \frac{5}{3} \text{ or } \frac{5}{6}$$

$$\Rightarrow \frac{T_s \cdot \Delta \dot{I}_L}{8C} \leq 0.3V$$

$$\Rightarrow C \geq \frac{10^{-5} \times \frac{5}{6}}{8 \times 0.3} = 3.47 \mu F$$


---

4.  $\frac{dV_c}{dt} = \frac{\dot{I}_c}{C}, \quad \text{from KCL for small ripples: } * \frac{\Delta \dot{I}_c}{T_s} = D \cdot \Delta \dot{I}_L$  on-state

$$\Rightarrow \Delta V_c = \frac{I_c}{C} \cdot T_s, \quad \Delta V_c \leq \frac{5\%}{2} \times V_o = 0.3V$$

↑  
To simplify calculation

$$\frac{I_c}{C} \cdot T_s \leq 0.3$$

$$\Rightarrow C \geq \frac{D \cdot \Delta \dot{I}_L \cdot T_s}{0.3} = \frac{0.75 \times \frac{5}{3} \times 10^{-5}}{0.3} \approx 4.17 \times 10^{-5} F$$


---

5. Q1:  $V_{stress, Q_1} = V_{in} + \Delta V_{in} = (1+2.5\%) \times V_{in} = 24.6V$   
 $I_{stress, Q_1} = \dot{I}_L + \Delta \dot{I}_L = (1+10\%) \times I_L = 9.17A$

Q2:  $V_{stress, Q_2} = 24.6V$

$I_{stress, Q_2} = 9.17A$

6. when  $f \uparrow, T_s \downarrow, \Rightarrow \text{current/voltage ripples} \downarrow$ ,  
 To maintain the same ripples, smaller L.C are better choices.

GCS(workspace - buck\_control\_starter/main.c - Code Composer Studio)

File Edit View Navigate Project Run Scripts Window Help

Project Explorer X

buck control\_starter [Active - Debug]

- Binaries
- Includes
- cpu1\_src
- Debug
- DeviceDrivers
- GlobalVariables.h
- main.c
- TargetConfiguration.xml [Active/Default]

Getting Started main.c x

```

1/*
2 * AUTHOR: RAHUL IYER (rkiyer@berkeley.edu)
3 *
4 * This project initializes the EPWM and ADC peripherals to interface with a buck converter
5 *
6 * As a starting point for exploring digital control implementation on the C2800, we will implement
7 * the controller in an infinite loop inside the main function.
8 *
9 * The ADC peripheral is configured to periodically sample V_in, V_out, I_in, and I_out once per PWM period.
10 * This setup allows us to avoid writing code to manually start and wait for the ADC conversions inside our
11 * control loop. This sampling setup will also be appropriate for interrupt-driven controller implementations.
12 */
13
14
15 #include "F28x_Project.h" // this includes all headers needed to interact with peripherals (ADC, EPWM, etc.)
16 #include "cpu1_init.h"
17
18 int main(void)
19 {
20     InitSysCtrl(); //Initialize SVSCTL (PLL, Watchdog, etc.)
21
22 #ifdef LAUNCHPAD // include this define in project settings if using a LaunchPad
23     EALLOW;
24     __OcfgRegs.PERCLKDIVSEL.bit.EPWMCLKDIV = 0; // remove /2 clock division for LaunchPad to make calculations consistent with ControlCard
25     EDIS;
26 #endif
27
28     InitGpio(); //Initialize GPIO register states
29
30     configure_GPIO(); // configure GPIO settings
31
32     DINT; // Disable STI INTN
33     IER = 0x0000; // Disable CPU Interrupts
34     IFR = 0x0000; // Clear all CPU interrupt flags
35 }

```

Console x

```

CDT Build Console [buck control starter]
0 errors, 2 warnings, 0 others
F:\TI\css\tools\compiler\ti-gcc-c2800_22.6.1.LTS\bin\c12000 -v28 -m1 -mt --c
Finished building: ".\cpu1_src\cpu1_init.c"

Building target: "buck_control_starter.out"
Invoking: C2800 Linker
F:\TI\css\tools\compiler\ti-gcc-c2800_22.6.1.LTS\bin\c12000 -v28 -m1 -mt --c
<linking>
Finished building target: "buck_control_starter.out"

**** Build Finished ****

```

Problems x Advice Memory Allocation Stack Usage

build finish.

## Digital PWM Calculations

Now calculate the following, referencing the EPWM section of the technical reference manual as needed. You may assume  $f_{EPWMCLK} = 100 \text{ MHz}$  and  $f_{sw} = 100 \text{ kHz}$ .

1. Number of EPWMCLK counts per switching period
2. For a leading-edge carrier, calculate the value of TBPRD. Explain your reasoning.
3. For a trailing-edge carrier, calculate the value of TBPRD.
4. For a triangular carrier, calculate the value of TBPRD. Explain your reasoning. (Hint: the calculation for a triangular carrier is different from that for a sawtooth carrier).

$$1. \text{counts per switching period} = \frac{T_{EPWMCLK}}{f_{sw}} = \frac{100 \text{MHz}}{100 \text{kHz}} = 1000$$

$$2. \text{leading-edge: } \begin{array}{c} \text{---} \\ \diagdown \quad \diagup \\ \text{---} \end{array} \Rightarrow \text{counts} = 1000 = \text{TBPRD} + 1 \\ \Rightarrow \text{TBPRD} = 999$$

$$3. \text{trailing edge: } \begin{array}{c} \text{---} \\ \diagup \quad \diagdown \\ \text{---} \end{array} \Rightarrow \text{TBPRD} = 999$$



- In **GlobalVariables.h** update the value of the preprocessor definition `#define EPWM_TBPRD` with the value you calculated in step 4 (we are using a triangular carrier)
- We want to initialize our code to start PWMs with 50% duty ratio. Update the value of `#define EPWM_CMP_INIT` accordingly (We are using a triangular carrier).
- Draw the carrier, modulating waveform, and resulting duty switching signal corresponding to our initial duty ratio.
- Assume we want 50 nanoseconds of deadtime. Calculate the number of EPWMCLK ticks that elapse in 50 nanoseconds. Update the value of `#define EPWM_DEADTIME` with the value you calculated.

5. ✓

6.  $\frac{\text{TBPRD}}{2}$  -- we need  $\frac{\text{TBPRD}+1}{2}$  counts.  
 $\Rightarrow \text{CMP} = \frac{\text{TBPRD}-1}{2} = \frac{498}{2} = 249$ .



8. 50ns deadtime.

$$\text{EPWM\_DEADTIME} = \frac{50\text{ns}}{t_{\text{EPWMCLK}}} = \frac{50\text{ns}}{\frac{1}{100\text{MHz}}} = 5$$

```
Getting Started main.c GlobalVariables.h ×
1 ifndef GLOBALVARIABLES_H_
2 define GLOBALVARIABLES_H_
3
4 define EPWM_TBPRD 499
5
6 define EPWM_CMP_INIT 249      // initialize with 50% duty ratio
7 define EPWM_DEADTIME 5        // deadtime in EPWMCLK ticks
8
9 define ADC_ACQ_WINDOW 30      // ADC S&H Window Length in SYSCLK cycles
10
11
12 endif /* GLOBALVARIABLES_H_ */
```

9. Maybe  $\approx 3.5$  hours - 4 hours (include some review of E6113).