## CHALMERS

## UNIVERSITY OF TECHNOLOGY



## Design of a high switching frequency interleaved step-up converter with digital interface for Power Factor Correction applications

A Master of Science thesis in which a step-up converter, capable of supplying 1 kW at 400 VDC using 230 VAC while operating at a switching frequency of 1 MHz , has been developed

Alnervik, Mattias
Erkenstam, Carl

# Design of a high switching frequency interleaved step-up converter with digital interface for Power Factor Correction applications 

A Master of Science thesis in which a step-up converter, capable of supplying 1 kW at 400 VDC using 230 VAC while operating at a switching frequency of 1 MHz , has been developed

M. Alnervik \& C. Erkenstam



CHALMERS
UNIVERSITY OF TECHNOLOGY

Department of Energy and Environment
Division of Electric Power Engineering
Chalmers University of Technology
Gothenburg, Sweden 2017

# Design of a high switching frequency interleaved step-up converter with digital interface for Power Factor Correction applications <br> A Master of Science thesis in which a step-up converter, capable of supplying 1 kW at 400 VDC using 230 VAC while operating at a switching frequency of 1 MHz , has been developed <br> Mattias Alnervik \& Carl Erkenstam 

© Mattias Alnervik \& Carl Erkenstam, 2017.

Supervisor: Kristoffer Berntsson, i3tex
Examiner: Torbjörn Thiringer, Department of Energy and Environment

Department of Energy and Environment
Division of Electric Power Engineering
Chalmers University of Technology
SE-412 96 Gothenburg
Telephone +46 317721000

Cover: Close up photo of the assembled converter with mounted test points.

Typeset in ${ }^{\mathrm{EA}} \mathrm{T}_{\mathrm{E}} \mathrm{X}$


#### Abstract

Power Factor Correction (PFC) circuits can be used to mitigate problems with harmonics associated with rectifying AC to drive a DC load. A two channel step-up converter with correctly controlled switches can be used as a PFC. High frequency switching gives the advantage of physically small boost stage inductors and filters. The purpose of this thesis was to investigate the possibilities of utilizing high switching frequencies while maintaining a high efficiency.

A short literature study about the subject was made which was followed by component choices based upon the studies and relating calculations. This was succeeded by the design and manufacturing of a circuit board. All surface mounted components were attached and the verification of the circuit was carried out by systematically mounting the remaining through hole components and writing testing software. Performance evaluation was the last thing to be done.

The main result is a working dual channel step-up converter capable of providing 1 kW at 400 V using 1 MHz switching frequency, however at the expense of the efficiency which dropped to just above $94 \%$. More work, especially software related work, is needed before the device can be used as a PFC and there are also possible improvements that can be implemented in order to increase the efficiency.

Given that the switching frequency aimed for was reached and that there are possible improvements to the efficiency, smaller boost stage inductors and filter components are possible which can increase the power density of devices utilizing PFCs.


Keywords: PFC, step-up converter, boost converter, high frequency, SiC, interleaved, digital control

## Acknowledgements

We wish to thank Kristoffer Berntsson, i3tex, for being a great supervisor and for showing commitment to our work. Thank you Mikael Duvander and i3tex for giving us the opportunity to do this master thesis project. We are grateful to our examiner Torbjörn Thiringer, Chalmers, for support and feedback along the way. Last but not least we would like to thank everyone else at i3tex for support, encouragement and for showing interest in our project. We really appreciate you.

Mattias Alnervik and Carl Erkenstam, Gothenburg, may 2017

## Contents

1 Introduction ..... 1
1.1 Background ..... 1
1.2 Aim/Purpose ..... 2
1.3 Problem description ..... 2
1.4 Scope ..... 2
2 Theory ..... 3
2.1 Issues with AC rectification and solution using PFC ..... 3
2.2 Interleaved step-up booster circuit ..... 5
2.3 Inductor design ..... 6
2.3.1 Inductance value needed based on allowed ripple ..... 6
2.3.2 Core choice ..... 8
2.3.3 Core loss ..... 10
2.3.4 Wire dimensioning ..... 12
2.3.5 Heating considerations ..... 13
2.4 MOSFET design considerations ..... 13
2.4.1 Voltage rating ..... 13
2.4.2 Current rating ..... 13
2.4.3 Loss calculation switch ..... 14
2.4.4 Loss calculation driver ..... 16
2.4.5 Parasitic source inductance ..... 17
2.5 Boost diode design considerations ..... 18
2.5.1 Current rating of the boost diode ..... 18
2.5.2 Losses attributed to the boost diode ..... 18
2.6 Conducted EMI filter design ..... 19
2.7 Ceramic capacitors ..... 20
3 Method ..... 23
3.1 Overview ..... 23
3.2 Input protection and EMI filters ..... 24
3.3 Diode bridge rectifier ..... 25
3.4 Boost inductors ..... 25
3.4.1 Inductor size calculations ..... 25
3.4.2 Evaluation of possible cores ..... 26
3.4.3 Core loss ..... 26
3.4.4 Wire dimensioning ..... 27
3.4.5 Heating of the inductor ..... 27
3.4.6 Considerations regarding core choice ..... 28
3.4.7 Other cores ..... 28
3.5 Boost MOSFETs and driver ..... 29
3.5.1 Voltage and current rating ..... 29
3.5.2 Parasitic source inductance mitigation ..... 29
3.5.3 MOSFET losses ..... 29
3.5.4 Driver circuitry design ..... 31
3.6 Boost diodes ..... 33
3.7 Smoothing and loop capacitors ..... 34
3.7.1 Bulk capacitance value ..... 34
3.7.2 Ripple RMS and $\tan \delta$ ..... 34
3.8 Calculated suppression of inductor ripple ..... 36
3.9 Bleeder circuit ..... 38
3.10 Low voltage supply ..... 39
3.11 Input voltage dividers ..... 40
3.12 Output voltage divider ..... 41
3.13 Current measuring circuits ..... 42
3.14 Digital Signal Processor ..... 43
3.14.1 PWM output pins ..... 43
3.14.2 Overcurrent protection ..... 44
3.14.3 USB interface ..... 46
3.15 Summation of component losses ..... 46
3.16 Heat mitigation ..... 46
3.16.1 MOSFET and boost diode footprints ..... 46
3.16.2 MOSFET and boost diode heat sink ..... 48
3.16.3 Thermally conductive isolation pad ..... 49
3.16.4 Diode bridge rectifier heat sink ..... 49
3.17 PCB design ..... 49
3.17.1 General component placement and routing strategy ..... 49
3.17.2 Board size ..... 50
3.18 Encapsulation and connectors ..... 50
3.19 Functionality verification ..... 50
4 Results ..... 57
4.1 Verification and assembly ..... 57
4.2 PCB ..... 57
4.3 Final Assembly ..... 59
4.4 Measurements and gathered data ..... 60
4.4.1 Efficiency ..... 60
4.4.2 Switching speeds ..... 61
4.4.3 Current measurements to find inductance value ..... 65
4.4.4 Device temperatures under load ..... 66
4.4.5 Hold up time ..... 67
4.5 Outcomes versus requirements ..... 68
5 Discussion ..... 69
6 Conclusion ..... 71
6.1 Future work ..... 71
A Circuit schematic ..... I
B PCB layout ..... VII
C Bill of Materials ..... XV
D Code for microprocessor ..... XIX
D. 1 BoostControl.c ..... XIX
D. 2 LEDblink.c ..... XXVI

## 1

## Introduction

### 1.1 Background

Power electronics are used in many common appliances today. Common household products such as computers, TVs and mobile phone chargers but also modern light bulbs, stoves and fridges all use power electronics. The use of power electronics have brought more efficient, smaller and cheaper products to the market. However, many electronic devices run on direct current, DC , in contrast to alternating current, AC , which is available in the household outlets. To be able to connect a DC powered device to the grid, a rectifier along with a smoothing capacitor are commonly used [1].

A simple rectifier with a smoothing capacitor can consume current containing high levels of harmonics. If the grid's source impedance is non zero, the distorted current will inject harmonics onto the grid voltage, which can propagate to other grid connected devices and in the worst case cause them to malfunction [1]. Harmonics can create heating problems in the transmission system and interfere with small-signals [1]. Currents with high levels of harmonics will also increase the need for greater current handling capabilities in components and thus decreasing device power density.

One solution to these issues is spelled Active Power Factor Correction, APFC hereby only PFC, which is a power electronic device which is connected between the problematic load and the rectified grid. The job of the PFC is to control the current in such a way that it resembles the sine wave of the grid voltage. This is, in this case, done by controlling two switches of boost stages.

Boost inductors as well as EMI filter, bulk capacitors etc. takes up significant space which in turn reduces the power density of the power electronic device that the PFC is installed in [2]. An increased switching frequency allows for smaller boost inductance values as well as smaller EMI filters. It is therefore highly relevant and interesting to study if it is possible to increase the switching frequency of a PFC module without compromising other performance aspects.

A quick investigation shows that there are many integrated PFC controllers available
on the market where the vast majority are designed to operate at frequencies of 500 kHz or below. The use of an integrated controller is however less flexible than using a microprocessor which can be programmed to operate exactly as the designer want it to do. This is convenient in the design process when different operation modes are tested, but it is also useful in the manufacturing stage where changes and fixes quickly can be implemented.

### 1.2 Aim/Purpose

The purpose of this project is to develop and build the hardware to a digital active PFC which should operate at a switching frequency of 1 MHz and shall be able to deliver 1 kW of power at a voltage level of 400 VDC . The main functionality of the PFC is controlled by a digital microprocessor.

The project is done in order to investigate if it is possible to operate such a PFC hardware at the stated switching frequency, built by as of today commercially available components. The result of the project will be a printed board assembly, PBA, complete with an enclosure and interface.

### 1.3 Problem description

The digital active PFC should provide 1 kW of power at a voltage 400 VDC using a single phase 230 V 50 Hz input while maintaining a power factor above 0.98 . However, the hardware will only be tested with various DC input voltages as the PFC software needs to be ready in order to test with AC voltage. The efficiency should not drop below $96 \%$. The switching frequency of the boost circuit should be 1 MHz and the layout should be a two channel interleaved design. The circuit should be cooled using air. In case of power supply interruptions of 20 ms the output voltage should not drop below 300 V . A test code for the processor will have to be written in order to test the hardware.

### 1.4 Scope

In order to be able to finish the thesis in time it is important to clarify what will not be done or investigated. Only one PFC topology will be investigated in order quickly start the design process. The printed circuit board, PCB, will have no size restrictions since it will not be designed as a commercial product and therefore does not have to compete on the market. A important design delimitation is that the PFC only needs to be able to handle 230 VAC as input and that the final construction does not need to pass a conducted EMI test as it only is a prototype and not a commercial product. The software that the microprocessor need in order to operate as a PFC will be investigated but not fully implemented.

## 2

## Theory

### 2.1 Issues with AC rectification and solution using PFC

To illustrate the problems with only using a rectifier and smoothing capacitor to power a DC load, the simple circuit and wave forms presented in figure 2.1 and 2.2 are to be analysed. The rectifier will only conduct when a pair of diodes is forward biased, thus the shape of the current can not be one pure sine wave and harmonics are therefore introduced into the system. This can be seen by investigating the current, red waveform, and one can easily confirm that it deviates from a sine wave. Because of the introduced harmonics and a non zero equivalent Thevenin impedance $\left(Z_{t h}\right)$ the voltage at the connection $\left(V_{S}^{\prime}\right)$ point will deviate from the 50 Hz sine $\left(V_{S}\right)$ as depicted by the blue lines in figure 2.2.


Figure 2.1: A simple AC rectification circuit connected to the grid with a non zero Thevenin equivalent source impedance.

The resulting power factor (PF) can be calculated by investigating the harmonic content of the current and using [1]

$$
\begin{equation*}
P F=\frac{1}{\sqrt{1+T H D^{2}}} D P F \tag{2.1}
\end{equation*}
$$

where THD is the Total Harmonic Distortion and DPF is the Displacement Power Factor. The THD can in turn be calculated as [1]


Figure 2.2: Corresponding current and voltage waveforms to the simple rectifying solution.

$$
\begin{equation*}
T H D=\frac{\sqrt{\sum_{h=2}^{\infty} I_{h}}}{I_{1}} \tag{2.2}
\end{equation*}
$$

where subscript $h$ indicates the order of the harmonic. As mentioned in the introduction it is possible to control the current drawn by a load by implementing a boost stage in series in between the load and the rectified grid voltage. The operation of a boost converter is off course well known to the reader but the main point in this case is that the current can be controlled and actively shaped by operating the switch and taking advantage of the inductors inherent resistance to change of current. This is demonstrated in figure 2.3 which depicts the same circuit as shown in figure 2.1, but with an implemented boost stage. The waveforms with the new implementation is shown in figure 2.4.


Figure 2.3: Implementation of a boost stage between the Grid and the simple rectifier and load.

Closing and opening of the switch corresponds to the indicated positive and negative slopes respectively and by timing the switch correctly it is possible to mimic a sine wave with a superimposed high frequency ripple. The switching speed of the boost


Figure 2.4: Corresponding current and voltage waveforms to the simple rectifying solution with boost stage.
switch will hereafter only be referred to as switching frequency $\left(f_{s}\right)$. The higher the switching frequency, the lower the high frequency ripple amplitude will be. If the ripple is allowed to be constant the inductance can instead be reduced. An increased switching frequency also allows for smaller values, and therefore size, of the filter components used for filtering the ripple [2].

### 2.2 Interleaved step-up booster circuit

A booster which is designed to work in interleaved operation have two (or several) channels. This is done by adding another switching stage in parallel with the original stage. One stage consists of an inductor, a diode and a switch. Such a booster configuration is depicted in figure 2.5 . Even though the complexity of the circuit


Figure 2.5: Simple sketch over a dual interleaved boost converter.
increases when two channels are used, it also implies several advantages: The two switches are operating $180^{\circ}$ out of phase from each other, which allows the stages to divide the load current evenly between them. This gives a more distributed heat dissipation which decreases the requirements of active cooling. The power handling requirements of the solid state components are not as narrow as if only one channel is used. Two smaller inductors can be used instead of one large and as the peak current per inductor is lower than using only one inductor increases the possibilities of core material choice. The use of two channels also decreases the current ripple from the input source.

### 2.3 Inductor design

One important component in any step-up converter is the inductor. It needs to be able to handle the peak current while still have low losses and (depending on requirements) be as physically small as possible. It may not be possible to buy a suitable power inductor 'off the shelf' as the requirements can vary a lot. In that case it is necessary to design an inductor from scratch. But in any case the necessary inductance needs to be calculated first.

### 2.3.1 Inductance value needed based on allowed ripple

A single channel step-up converter of a PFC circuit assuming ideal rectification and components can be drawn according to figure 2.6.


Figure 2.6: KVL in boost stage in order to find inductance value design equations.

Applying KVL when the switch is open results in the following expression,

$$
\begin{equation*}
V_{L}+V_{D}+V_{o}-\left|V_{s}\right|=0 \tag{2.3}
\end{equation*}
$$

where

$$
\begin{equation*}
V_{L}=L \frac{d i_{L}}{d t}=-L \frac{\Delta i_{L}}{\Delta t}=-L \frac{\Delta i_{L} f_{s}}{1-D} \tag{2.4}
\end{equation*}
$$

The maximum inductor ripple $\left(\Delta i_{L}\right)$ occurs on the peak of the input voltage [3]. Knowing this, ignoring the diode voltage drop and combining (2.3) and (2.4) gives

$$
\begin{equation*}
L=\frac{V_{o}-\sqrt{2} V_{s, R M S \min }}{\Delta i_{L}} \frac{1-D}{f_{s}} \tag{2.5}
\end{equation*}
$$

where $D$ is the duty cycle of the step-up converter and $V_{s, R M S \min }$ is the RMS voltage of the grid during low line operation. Low line operation is the lowest RMS grid voltage that can occur on the line without being considered as a fault. So in order to find the inductance needed the duty cycle of a two channel step-up converter needs to be investigated. The duty cycle impact on the output/input voltage for a single channel step-up converter is depicted in figure 2.7 and the duty cycle at the peak of the supply voltage can be calculated using

$$
\begin{equation*}
D=\frac{V_{o}-\sqrt{2} V_{s, R M S \min }}{V_{o}} \tag{2.6}
\end{equation*}
$$



Figure 2.7: Voltage boosting characteristics of a single channel step-up converter.

The inductor ripple in the single channel step-up converter is the same as the input ripple ( $\Delta i_{s}$ ) but when using two channels the input ripple as a function of the duty cycle can be written as [3]

$$
\begin{equation*}
\Delta i_{s}=\Delta i_{L} \frac{1-2 D}{1-D} \quad \text {, for } D \leq 0.5 \tag{2.7}
\end{equation*}
$$

$$
\begin{equation*}
\Delta i_{s}=\Delta i_{L} \frac{2 D-1}{D} \quad \text {, for } D>0.5 \tag{2.8}
\end{equation*}
$$

since operating the two channels $180^{\circ}$ phase shifted from each other leads to partial/full ripple cancellation of the ripple. This is one of the benefits of using two channels instead of one and the duty cycle dependence between the input and inductor ripple is depicted in figure 2.8.


Figure 2.8: Two channel step-up converter ripple reduction as a function of the duty cycle.

One way to design the inductors in the PFC is to state a maximum percentage input ripple of the nominal peak input current that is allowed during low line operation, this can be expressed in the following way

$$
\begin{equation*}
\Delta i_{s}=\frac{\sqrt{2} P_{o}}{\eta V_{s, R M S m i n}} \Delta i_{\%, \text { Design }} \tag{2.9}
\end{equation*}
$$

in which $\eta$ is the efficiency of the converter and $P_{o}$ is the output power.

### 2.3.2 Core choice

The correct choice of core is essential for the inductor's performance. There are many unknown parameters regarding the cores, and the design work needs to take on an iterative approach. As there are many different types of cores available on the
market, the selection range have to be narrowed down in order to be able to find a core to begin to design around.

The first step is to determine the amount of current the inductor needs to be able to handle. The RMS value of the current going through the circuit at full load can be determined by

$$
\begin{equation*}
I_{r m s}=\frac{P_{o}}{\eta V_{s, R M S m i n}} \tag{2.10}
\end{equation*}
$$

Since there are two channels each inductor only carries half the total RMS current, i.e. $I_{L, r m s}=I_{r m s} / 2$. The peak of the inductors' RMS current is given by

$$
\begin{equation*}
\hat{I}_{L, 50 H z}=\sqrt{2} I_{L, r m s} \tag{2.11}
\end{equation*}
$$

where $\hat{I}_{L, 50 \mathrm{~Hz}}$ is the peak of the pure sinusoidal current that ideally would be drawn from the grid. The current peak in the inductor $\left(\hat{I}_{L}\right)$ in absolute values is given by

$$
\begin{equation*}
\hat{I}_{L}=\hat{I}_{L, 50 H z}+\frac{\Delta I_{L, \max }}{2} \tag{2.12}
\end{equation*}
$$

where $\Delta I_{L, \max }$ is the maximum ripple current in the inductor. This is the minimum current that the inductor needs to be dimensioned for.

The amount of energy that should be stored in the inductor is a fundamental property affecting the choice of core and which indicates how physically large the inductor will be. Core manufacturers may provide guides for the core size needed for different materials. The stored energy $(E)$ in the inductor is given as

$$
\begin{equation*}
E=\frac{L \hat{I}_{L}^{2}}{2} \tag{2.13}
\end{equation*}
$$

although core manufactures tend to omit the division and compensate for it in their charts.

Each core material have different properties which impacts the characteristics of the inductor. As this PFC circuit utilize a high switching frequency, only good performing metal powder and ferrite materials can be used. Iron cores would have to large eddy current losses at the particular operating frequency. Ferrite cores have the advantage of low core losses which is crucial at high frequency operation, but they have low saturation limit [1] which limits the current handling capability. There is also a material called VitroPerm which offers very high relative permeability which allows for low copper losses due to few turns, but it has too have low saturation limit. Metal powder cores on the other hand, have higher core losses but can generally handle a higher current per volume unit than the ferrite cores.

As the core losses solely depends on the frequency and the current ripple magnitude [4] it may be a good choice to pick a core material with a positive temperature coefficient, which means that the core permeability increases with temperature within the
core's operation range. If the inductor temperature rises, the inductance will also increase which in turn decreases the current ripple magnitude and thus decreases also the losses and temperature. Not all core materials have this property.

The shape of the core affect the behaviour of the core such as thermal properties and shielding. Good shielding is important as it limits electromagnetic interference, EMI. By picking a core shape that emits low EMI, one can mitigate the need of other shielding components such as a metal encapsulation. Cores with good shielding properties are for example toroids and pot cores [5]. Toroids have better heat dissipation performance than pot cores, but are on the other hand more expensive to wind in series production [5].

The number of turns of wire, $N$, required to reach the desired inductance is given by

$$
\begin{equation*}
N=\sqrt{\frac{L}{A_{L}}} \tag{2.14}
\end{equation*}
$$

where $A_{L}$ is a magnetic property with unit $\frac{n H}{t^{2}}$ defined by the core manufacturer for each core. This will give the correct inductance at no load state.

The permeability of the core material will decrease as the current through the inductor increases, why the inductance also must be calculated at full load. This is done by

$$
\begin{equation*}
H_{\max }=\frac{N \hat{I}_{L}}{l_{e}} \tag{2.15}
\end{equation*}
$$

where $H_{\max }$ is the magnetic field strength with unit ampereturns per centimeter, $A t / \mathrm{cm}$, and $l_{e}$ is the core's magnetic path length with unit cm . By investigating the core datasheet information about how much the permeability will roll off in percentage for the current bias level can be found. The roll off multiplied with the no load inductance will give the full load inductance [4]. If the deviation is too large, the number of turns must be increased. By dividing the initial number of turns by the percentage roll off, a new suitable amount of turns is found. The process is then iterated from (2.15) until the full load inductance is high enough [4]. The permeability also depends on the frequency of the current going through the inductor, which is why a similar procedure needs to be conducted if the core material has a significant roll off at the operating frequency.

### 2.3.3 Core loss

The losses in the core depends on the switching frequency and the magnetic flux swing within the core [4], thus the current ripple. The flux swing $\left(B_{p k}\right)$ is given by

$$
\begin{equation*}
B_{p k}=\frac{\Delta B}{2} \tag{2.16}
\end{equation*}
$$

where $\Delta B$ is the difference between the highest and lowest core flux. The core flux depends non-linearly on the magnetic field strength, $B=f(H)$. The flux difference can be expressed as

$$
\begin{equation*}
\Delta B=f\left(H_{\max }\right)-f\left(H_{\min }\right) \tag{2.17}
\end{equation*}
$$

where $H_{\max }$ is the maximum field strength as calculated in (2.15) and $H_{\text {min }}$ is the local minimum field strength. $H_{\text {min }}$ is given by a slightly modified version of (2.15) as

$$
\begin{equation*}
H_{\min }=\frac{N \check{I}_{L}}{l_{e}} \tag{2.18}
\end{equation*}
$$

where $\check{I}_{L}$ is the local minimum of the peak current, given by

$$
\begin{equation*}
\check{I}_{L}=\hat{I}_{L, 50 H z}-\frac{\Delta I_{L, \max }}{2} \tag{2.19}
\end{equation*}
$$

The function $f$ is sometimes given by a magnetization curve in the core datasheet, but can also be approximated by

$$
\begin{equation*}
f(H)=H \mu_{0} \mu_{i} \%_{\text {rolloff }} \tag{2.20}
\end{equation*}
$$

where $\mu_{0}$ is the absolute permeability, $\mu_{i}$ is the intrinsic relative permeability of the core and $\%_{\text {rolloff }}$ is the permeability roll off of the core at the DC bias and frequency level. At no load, $\%_{\text {rolloff }}$ is 100 .
$B_{p k}$ gives the core loss density $\left(P_{L}\right)$ which can be extracted from the core datasheet. $P_{L}$ have unit $m W / \mathrm{cm}^{3}$. The core loss, $P_{\text {core }}$, with unit $m W$, can be calculated by

$$
\begin{equation*}
P_{\text {core }}=P_{L} A_{e} l_{e} \tag{2.21}
\end{equation*}
$$

where $A_{e}$ is the equivalent magnetic area of the core. This calculation is however based on the maximum current ripple and is therefore the worst case scenario and most of the time the core loss will be lower.

### 2.3.4 Wire dimensioning

The inductor needs of course a wire that is wound around the core. The wire dimension depends on how large the power loss in the wire is allowed to be along with the available space given by the core shape and dimensions. By using a thick wire the copper losses $\left(P_{c u}\right)$ will be low but on the other hand the core might not be able to accommodate the necessary number of turns. As a starting point the copper loss may be set to a reasonable value, like 500 mW . To be able to calculate a suitable cross section area of the wire, the length of the wire $\left(l_{w}\right)$ must first be known. Assuming a toroid core, the winding circumference $\left(O_{w}\right)$ of the core is given by

$$
\begin{equation*}
O_{w}=\varnothing_{o}-\varnothing_{i}+2 H_{t} \tag{2.22}
\end{equation*}
$$

where $\varnothing_{o}$ is the outer diameter of the core, $\varnothing_{i}$ is the inner core diameter and $H_{t}$ is the core height. If the amount of turns require the wire to be wound in several layers around the core, the turn mean length increases.

The required cross section area of the wire $\left(A_{w}\right)$ can be calculated by

$$
\begin{equation*}
A_{w}=\frac{\rho_{c u} l_{w} I_{L, r m s}^{2}}{P_{c u}} \tag{2.23}
\end{equation*}
$$

where $\rho_{c u}$ is the resistivity for copper, which is $\rho_{c u}=1,68 * 10^{-8} \Omega m$ at room temperature. The resistance in the wire does however increase with temperature. The resistance increases with about $30 \%$ [6] if the temperature is increased to $100{ }^{\circ} \mathrm{C}$, so the cross section area should be increased with the same percentage to make sure the losses are kept under control when the wire temperature increases.

The skin effect at switching frequencies as high as 1 MHz is significant. This means that only the outer part of the wire will conduct current, why the effective resistance off the wire increases significantly. To mitigate this problem a litz wire should be used. A litz wire is a wire consisting of many small strands, each isolated from the others. The skin depth $(\delta)$ is big compared to the diameter of each strand, resulting in a more well distributed current and a DC like resistance. The effective cross section area of the litz wire needs to be equal to the calculated needed cross section area which only is valid for DC.

The skin depth can be calculated by using

$$
\begin{equation*}
\delta=\frac{1}{\sqrt{f \mu_{0} \mu_{r, c u} \pi \rho_{c u}^{-1}}} \tag{2.24}
\end{equation*}
$$

where $f$ is the frequency and the relative copper permeability $\left(\mu_{r, c u}\right)$ is 1 [6]. $\delta$ is calculated to $65,2 \mu m$ given $f=1 \mathrm{MHz}$. The skin effect can be neglected if $\varnothing_{w} \leq 2 \delta$, where $\varnothing_{w}$ is the diameter of the wire [1]. The diameter of each strand in the litz wire should therefore not exceed $2 \delta$.

### 2.3.5 Heating considerations

The temperature rise in the inductor is important. Not only does it affect the inductance, the core and the litz wire have also specifications for maximum allowed operating temperature. The exact steady state temperature can not easily be calculated as it is dependent on unknown environment variables such as air flow rate, air temperature, humidity, air pressure and so on. The temperature rise in completely still air can however be estimated and used for designing purposes. The temperature rise of the inductor $\left(\Delta T_{L}\right)$ can be calculated as

$$
\begin{equation*}
\Delta T_{L}=\left(\frac{P_{c u}+P_{\text {core }}}{S_{\text {component }}}\right)^{0.833} \tag{2.25}
\end{equation*}
$$

where $S_{\text {component }}$ is the total surface area of the whole inductor given in square centimeter, and the power losses are given in milliwatt [4]. The total surface area of the component depends on the number of turns wound around the core as many turns give a physically larger component. In this case the core-fill is very low so the total surface area can be approximated by the surface area of the core $\left(S_{c}\right)$ itself. The core area is calculated by

$$
\begin{equation*}
S_{c}=\frac{\pi}{2}\left(\varnothing_{o}^{2}-\varnothing_{i}^{2}\right)+\pi H_{t}\left(\varnothing_{o}+\varnothing_{i}\right) \tag{2.26}
\end{equation*}
$$

### 2.4 MOSFET design considerations

### 2.4.1 Voltage rating

Because of parasitic inductances in the so called critical loop of the boost converter, shown looped in red in figure 2.9 where the parasitic inductances are named $L_{P 1}-L_{P 5}$, an overvoltage will occur at turn-off of the switch $[1,7]$.

During turn-off when the diode starts carrying the current KVL can be applied in the critical loop as depicted in the figure which yields the following expression assuming that all the parasitic inductances can be lumped together as $L_{p}$ and that the forward diode voltage drop is zero.

$$
\begin{equation*}
V_{S W}=V_{o}-L_{p} \frac{d i}{d t} \tag{2.27}
\end{equation*}
$$

### 2.4.2 Current rating

Assuming that the PFC will meet the specifications of requirement the power factor will be close to $1(0.98)$. The peak of the current through the switches ( $I_{S W, \max }$ )


Figure 2.9: KVL applied in the critical loop of the boost converter which contains parasitic inductances.
are therefore half the nominal peak current during low line operation plus half the current ripple of the inductor, which can be expressed as

$$
\begin{equation*}
I_{S W, \text { max }}=\sqrt{2} \frac{P_{o}}{2 \eta V_{s, R M S \min }}+\frac{\Delta i_{L}}{2} \tag{2.28}
\end{equation*}
$$

### 2.4.3 Loss calculation switch

The total losses off the switch is the sum of the conduction losses $P_{M O S F E T, \text { conduction }}$, the switching losses $P_{\text {MOSFET,switching }}$ and the losses dissipated in the drain-source channel because of the intrinsic output capacitance $P_{\text {MOSFET,Coss }}$ of the MOSFET. The conduction losses can be calculated using

$$
\begin{equation*}
P_{M O S F E T, \text { conduction }}=I_{D S, R M S}^{2} R_{D S, \text { on }} \tag{2.29}
\end{equation*}
$$

where $R_{D S, \text { on }}$ is the on state resistance of the switch.
The switching losses in turn can be written as

$$
\begin{equation*}
P_{M O S F E T, \text { switching }}=\left(E_{o n}+E_{o f f}\right) f_{s} \tag{2.30}
\end{equation*}
$$

where $E_{o n}$ and $E_{o f f}$ are the turn-on and turn-off energies lost during one switching cycle. These energies can be approximated using [8]

$$
\begin{gather*}
E_{o n}=\frac{1}{2} V_{D S} I_{D S} t_{c(o n)}  \tag{2.31}\\
E_{o f f}=\frac{1}{2} V_{D S} I_{D S} t_{c(o f f)} \tag{2.32}
\end{gather*}
$$

where $t_{c(o n)}$ and $t_{c(o f f)}$ are the cross over times when the current and voltage across the switch is non zero simultaneously. These times can be determined by investigating the MOSFET switching waveforms. Figure 2.10 depicts a simple piecewise linear model of the turn-on patterns of a MOSFET with an inductive load [9].


Figure 2.10: Piece wise linear model of a MOSFET turn-on waveforms.
The cross over times can be calculated using [1]

$$
\begin{align*}
& t_{c(o n)}=t_{r i}+t_{f v}  \tag{2.33}\\
& t_{c(o f f)}=t_{r v}+t_{f i} \tag{2.34}
\end{align*}
$$

where $t_{r i}$ and $t_{f v}$ are indicated in figure and $t_{r v}$ and $t_{f i}$ can be found by investigating the same waveforms reversed.

The voltage $V_{D D}$ indicated in the figure is the gate driver operating voltage. Voltage $V_{P L}$ is the so called plateau voltage, or Miller voltage, and $I_{P L}$ is the current during the Miller plateau.

Given the gate charge characteristic, which can be found in the data sheet of the MOSFET, it is possible to calculate the rise and fall times using [9]

$$
\begin{align*}
& t_{r i}=\frac{Q_{G S 2}}{I_{G, t r i}}  \tag{2.35}\\
& t_{f v}=\frac{Q_{G D}}{I_{G, t f v}}  \tag{2.36}\\
& t_{r v}=\frac{Q_{G D}}{I_{G, t r v}}  \tag{2.37}\\
& t_{f i}=\frac{Q_{G S 2}}{I_{G, t f i}} \tag{2.38}
\end{align*}
$$

where $I_{G}$ for the different times is the current into the gate during the different times of the transitions. The charges $Q_{G S 2}$ and $Q_{G D}$ can be extracted from the gate charge characteristics which is shown in figure 2.11 [9].

The output capacitance $C_{\text {oss }}$ will be discharged through the channel once every switching cycle during turn-on [10]. The energy stored in $C_{\text {oss }}$ can be read from the graphs in the data sheets and is named $E_{\text {oss }}$ which varies with $V_{D S}$. The resulting loss can be written as [8]

$$
\begin{equation*}
P_{M O S F E T, C o s s}=E_{\text {oss }} f_{s} \tag{2.39}
\end{equation*}
$$

### 2.4.4 Loss calculation driver

The gate is charged and discharged every switching cycle. The amount of charges injected into the gate can be read from the gate charge characteristics. Current is defined as Coulomb per second, which means that the average driver gate current ( $I_{\text {driver }}$ ) can be calculated using [9]

$$
\begin{equation*}
I_{\text {driver }}=Q_{G, \max } f_{s} \tag{2.40}
\end{equation*}
$$



Figure 2.11: Example of a MOSFET gate charge characteristic with indicated voltages and corresponding charge level.
where $Q_{G, \text { max }}$ is the gate charge at the driver operating voltage. The driver current times the driver voltage gives the power loss of the driver, hence

$$
\begin{equation*}
P_{M O S F E T, \text { driver }}=V_{D D} Q_{G, \max } f_{s} \tag{2.41}
\end{equation*}
$$

### 2.4.5 Parasitic source inductance

Because of the non zero length of the conduction paths involved there will be a resulting inductance between the source of the switch to the ground. When the switch is turned off, the source inductance will induce a negative voltage since $V_{L}=$ $L \frac{d i}{d t}$. Depending on the fall time of the current, the negative voltage at the source might trick the MOSFET to start to conduct since the gate voltage is kept low and induced negative voltage at the source effectively gives a positive $V_{G S}$, which might be above the threshold voltage.

Take a TO-220 package for example where the inductance of the pins are between $10-20 \mathrm{nH}[10]$. Since the switching frequency is going to be high, the $d i / d t$ can in this case exceed $0.5 \mathrm{~A} / \mathrm{ns}$ resulting in an induced source voltage of -5 V given the inductance of only the pin. This is already unacceptable since the resulting $V_{G S}$ would be 5 V which is above the threshold voltage of many MOSFETs.

### 2.5 Boost diode design considerations

### 2.5.1 Current rating of the boost diode

The peak current through the diode will be the same as for the MOSFET, because of the layout of the step-up converter, and the peak current rating can be calculated using (2.28).

### 2.5.2 Losses attributed to the boost diode

The boost diode contributes to two kinds of losses. Conduction losses $P_{\text {Dconduction }}$ which are dissipated in the diode and the switching losses $P_{\text {Dswitching }}$ associated with capacitive charge $\left(Q_{C}\right)$ or reverse recovery charge $\left(Q_{r r}\right)$ [8].

The conduction losses can be expressed as [8]

$$
\begin{equation*}
P_{D, \text { conduction }}=I_{D, a v g} V_{f} \tag{2.42}
\end{equation*}
$$

where $V_{f}$ is the forward voltage drop and $I_{D, \text { avg }}$ is the average current trough the diode which, in this case with two channels, can be calculated as $I_{D, a v g}=P_{o} / 2 V_{o}$ under the assumption that the output capacitor is large enough to keep the output voltage constant.

The switching losses occur because of the trapped charge in the diode which in this case can be expressed as [8].

$$
\begin{equation*}
P_{D, \text { switching }}=\frac{1}{2} V_{o} Q_{c} f_{s} \tag{2.43}
\end{equation*}
$$

During hard commutation, the switching losses of the diode will be dissipated in the diode and its corresponding switch. The distribution of these losses depend on the times $t_{a}$ and $t_{b}$, represented in figure 2.12, which makes up the reverse recovery time $t_{r r}$ [11].

The switching/commutation loss dissipated in the diode is directly proportional to $t_{b}$. This means that most of the switching/commutation losses will be dissipated in the switch if the diode is snappy. The snappiness is defined as $\frac{t_{a}}{t_{b}}$.

Additionally, extra losses will occur in the switch because of the diode reverse recovery current. Since a current will flow in the "wrong" direction during the reverse recovery time which, because of the layout, will be conducted through the switch when it opens causing losses.


Figure 2.12: Reverse recovery current of a diode.

### 2.6 Conducted EMI filter design

A conducted EMI filter is depicted in figure 2.13 [12].


Figure 2.13: An EMI filter.

The filter will appear different for common mode (CM) noise than differential mode (DM) noise and the equivalent circuits for the different noises forms second order LC-filters with corner frequencies $\left(f_{c, C M}\right)$ and $\left(f_{c, D M}\right)$ calculated as [12]

$$
\begin{align*}
f_{c, C M} & =\frac{1}{2 \pi \sqrt{\left(L_{C M}+\frac{1}{2} L_{D M}\right) 2 C_{C M}}}  \tag{2.44}\\
f_{c, D M} & =\frac{1}{2 \pi \sqrt{\left(2 L_{D M}+L_{\text {leakage }}\right) C_{D M}}} \tag{2.45}
\end{align*}
$$

given that $C_{D M}=C_{X 1}=C_{X 2}, C_{C M}=C_{Y 1}=C_{Y 2}, C_{D M} \gg C_{D M}$ and $L_{\text {leakage }}$ is the leakage inductance of the common mode choke. The leakage inductance is practically between $0.5 \%$ and $2 \%$ and can therefore be utilized as DM choke [12].

Capacitor $C_{X 1}$ and $C_{X 2}$ are often refereed to as X-capacitors, while $C_{Y 1}$ and $C_{Y 2}$ are called Y-capacitors. Special considerations regarding safety should be considered while choosing these capacitors. The Y-capacitors are grounded and if they fail as a short circuit the ground could assume dangerous voltages. The X-capacitors are connected across the AC line and presents a fire hazard if they fail [13]. Therefore there are capacitors especially designed for these applications, and there are different sub classes of these capacitors, namely X1, X2, X3, Y1, Y2, Y3 and Y4 where a lower index corresponds to a higher level of safety [14].

### 2.7 Ceramic capacitors

There are several different kinds of capacitors (electrolytic, tantalum, ceramic and polymeric capacitors) to choose from when designing. The properties of the capacitors used need to be understood in order to make correct design choices. Electrolytic capacitors are appropriate when large capacitance are needed, but because of their high series resistance (ESR) and series inductance (ESL) they may not be suitable for applications like de-coupling, bypass or filter capacitors where low ESR and ESL may be required. Tantalum capacitors have medium-high ESR and low ESL and has a high capacitance density but they can fail explosively and are therefore not used for this design. Polymeric capacitors may have the highest capacitance density and has low ESR and ESL but are expensive. The ceramic capacitors has the lowest cost and ESR, have low ESL and there are many manufacturers to choose from. Because of this, ceramic capacitors will be extensively used for this project. In order to make the correct design choices it is important to recognize that the capacitance is influenced by the voltage [15].

The capacitance of the ceramic capacitor will change when a DC-voltage is applied to it and the capacitance at the operating point may therefore be much lower than the nominal value. The characteristic change in capacitance as a result of applied voltage is called DC bias characteristic and may be provided in the data sheets. Figure 2.14 illustrates an example of DC bias characteristics for a ceramic capacitor.


Figure 2.14: Example of a DC bias characteristic for a ceramic capacitor.

The change of capacitance occurs because the dielectric relative permittivity decreases as the electric field strength increases [16].

Large ceramic package sizes may also cause audible noise because of their piezoelectric nature. Even cracking can occur as the PCB flexes because of the capacitor. One way to mitigate this is to mount metallic terminals to the capacitor so that the capacitor is lifted up from the $\operatorname{PCB}[15,16]$.

## 3

## Method

### 3.1 Overview

Texas Instruments have developed a demo project for a digital active PFC around one of their Digital Signal Processors, DSP. The demo project is called ILPFC [17] and is freely available together with their developing suite. The processor family used is called Piccolo and is well suited for the fast operation that is required for a high frequency PFC. The built hardware will therefore be based on this demo project and utilize the very same processor.

The processor is the heart of the PFC's control system. It has the purpose of measuring voltages and currents in the circuit, generate the PWM signals and control the duty cycle so that the input current follow the input voltage waveform while keeping the output voltage at a fairly constant level. In order to get a good power factor of the PFC it is more important that the current has the correct shape than that the output voltage is stable. The current control loop therefore needs to be faster than the output voltage control loop. In the default software developed for the ILPFC project this is solved by sampling and running the current control loop at 100 kHz while the output voltage control loop runs at 50 kHz . The default switching frequency of the demo project is 200 kHz and some tweaking is therefore needed before the processor is able to control the PFC at a frequency as high as 1 MHz . The PWM signals that are generated by the processor drives two MOSFET transistors through a gate driver. The DSP needs a USB-interface for communication with a computer in order to upload firmware and for debugging.

Other sub circuits and components that needs to be developed/chosen includes:

- Power supply for DSP and peripherals
- The switching stages including boost inductors, transistors, diodes and filtering capacitors
- EMI filters
- Current and voltage measuring circuits
- DC bulk and bleeder circuit
- Temperature monitoring circuit
- Encapsulation and cooling

Furthermore a simple software needs to be developed in order to enable test and verification of the hardware.

As can be seen from the bullet list, the circuit will consist of several components and at the end of the circuits life time it will probably be recycled or end up in a land fill. The components and all the parts making up the device will fall under the RoHS directive. RoHS stands for: directive on the restriction of the use of certain hazardous substances in electrical and electronic equipment certified, which limits the use of certain hazardous materials such as lead and mercury. From an ecological point of view, this is done in order to promote sustainable development as the heavy metals are dangerous to the environment and can harm living creatures. Heavy metals are also dangerous for humans as it may end up in our food in in our proximity. Arguments can therefore be made that it is unsustainable from a ethical and social point of view to not use RoHS components, as it could be deemed morally wrong to, by extension, poison our fellow man.

As a designer of new products or scientist working on new research you personally are in some way, by extension, morally tied to the outcome. And the person performing the work should think through the ethical consequences of results yielded by the work and make sure that he or she is morally comfortable with this. As in this case, where a device operating with lethal voltages is built without warning signs or operation manuals, the immediate question regarding possible human harm must be examined. Moral comfort is found in that the result of this thesis is a prototype which only will be handled by well-grounded engineers.

### 3.2 Input protection and EMI filters

The requirement of specifications does not specify allowed conducted EMI noise level, and the base line of the conducted EMI is difficult to predict in the initial design phase. Therefore the filter is designed by comparing a similar filter implemented in another two phase interleaved PFC operating at a lower switching frequency. The chosen values for the X-capacitors are $C_{D M}=C_{X 1}=C_{X 2}=0.33 \mu F$, while the Ycapacitors are $C_{C M}=C_{Y 1}=C_{Y 2}=4.7 n F$. The Y-capacitors contribute to a leakage current of $I_{\text {leak }}=\omega C_{C M} V=340 \mu A$ [18]. The common mode choke 7448040707 from Würth Electronics Inc. is chosen, which has a inductance of $L_{C M}=7 \mathrm{mH}$ and in accordance with the reasoning of section [12] the differential mode inductance is approximated to $L_{D M}=7 \mathrm{mH} * 0.01=70 \mu F$. The corner frequencies of the filter can be calculated using (2.44) and (2.45) to

$$
\begin{gather*}
f_{c, C M}=\frac{1}{2 \pi \sqrt{2 L_{C M} C_{C M}}}=\frac{1}{2 \pi \sqrt{2 * 7 m H * 4.7 n F}} \approx 20 \mathrm{kHz}  \tag{3.1}\\
f_{c, D M}=\frac{1}{2 \pi \sqrt{L_{D M} C_{D M}}}=\frac{1}{2 \pi \sqrt{70 \mu H * 0.33 \mu \mathrm{~F}}} \approx 33 \mathrm{kHz} \tag{3.2}
\end{gather*}
$$

The DC-output will also have a similar filter.
Because of the output bulk capacitance there will be a large inrush when the PFC is connected to the grid. The amplitude of the inrush current would probably blow the fuse and damage the circuitry of the PFC. In order to limit this initial current, a NTC thermistor is placed in series with the input. The chosen thermistor has part number SL2250004 from Ametherm and which, according to the data sheets, is able handle bulk capacitance up to $1300 \mu F$ at 240 VAC. This component has $50 \Omega$ at room temperature which will limit the inrush current to $\frac{230 V * \sqrt{2}}{50 \Omega}=6.5 \mathrm{~A}$. The thermistor will initially consume large amounts of power and will therefore heat up, since it is a NTC the resistance will decrease and ideally go down to zero once the bulk capacitors are charged. This is however not the case, the resistance of this thermistor will drop to $0.44 \Omega$ causing unacceptable losses during normal operation. A relay is therefore connected in parallel which will short the thermistor once the bulk capacitors are charged. The coil of the relay consumes 20 mA and will be driven by the 12 V rail via a NPN bipolar transistor controlled by the DSP.

### 3.3 Diode bridge rectifier

The full bridge diode rectifier will carry the full input current of the PFC. Assuming that the current is fully sinusoidal the input RMS current will be 5.03 A during low line operation and an efficiency of $96 \%$. The average current is therefore $I_{F_{\text {avg }}}=$ $0.9 * 5.03 A=4.53 A$. The full bridge rectifier MP1010G-G is therefore used, it can handle a current of 10 A and a reverse voltage of 1000 V . The package of the rectifier makes the heat sink choice easy because of its shape. The voltage drop across one of the diodes at 4.53 A can be read from the data sheet to $V_{F}=0.9 \mathrm{~V}$. The diodes in the bridge rectifier conducts in pair so the loss in the diode rectifier $\left(P_{F B D R}\right)$ is approximated as

$$
\begin{equation*}
P_{F B D R}=2 V_{F} I_{F, a v g}=2 * 0.9 \mathrm{~V} * 4.53 \mathrm{~A} \approx 8.2 \mathrm{~W} \tag{3.3}
\end{equation*}
$$

### 3.4 Boost inductors

### 3.4.1 Inductor size calculations

It is possible to dimension the inductance of the boost inductors to $35 \mu H$ for the PFC using (2.5), (2.6), (2.7) and (2.9) given the following design criteria: $V_{s, R M S \min }=0.9 * 230 V, V_{o}=400 \mathrm{~V}, f_{s}=1 \mathrm{MHz}, P_{o}=1 \mathrm{~kW}, \eta=0.96$ and $\Delta i_{\%, \text { Design }}=20 \% \Longrightarrow 1.42 A$. This results in an inductor ripple of $40 \%$.

### 3.4.2 Evaluation of possible cores

To be able to design a, for this application, proper inductor it is necessary to pick a suitable inductor core.

The manufacturer Magnetics have several core materials optimized for power inductors as well as a good documentation of their cores and the design steps. Using (2.10), $I_{r m s}$ equals 5.03 A. The RMS current for each inductor is thus $I_{L, r m s}=2.52 \mathrm{~A}$.

Applying (2.11) and (2.12) concluding that $I_{L, \max }=4.27 \mathrm{~A}$, which is the minimum current the inductor needs to be able to handle without saturating.

A first try is the Magnetics AmoFlux core material. AmoFlux is a metal powder material which is developed for PFC applications and is therefore able to handle both high fluxes and frequencies. The material is currently only available in toroid shaped cores. As Magnetics does not provide any recommendation chart for size versus energy capability for AmoFlux cores a good sizing guess is appropriate. Core 0088894A7 is picked as it is the smallest available. The properties of the chosen core are shown in table 3.1.

Table 3.1: Properties of AmoFlux 0088894A7

| Physical properties [mm] |  |  |  |
| :---: | :---: | :---: | :---: |
| Outer diameter, $\varnothing_{0}$ | Inner diameter, $\varnothing_{i}$ |  | kness, $H_{t}$ |
| 27.69 | 14.1 |  | 12.0 |
| Magnetic properties |  |  |  |
| Permeability, $\mu$ | $A_{L}\left[n H / t^{2}\right]$ | Area, $A_{e}\left[\mathrm{~mm}^{2}\right]$ | Path length, $l_{e}[\mathrm{~mm}]$ |
| 60 | $75 \pm 8 \%$ | 65.4 | 63.5 |

Using (2.14) $N$ is computed for the worst case $A_{L}$, which is the nominal value minus the margin of error of eight percent, to $22.5 \approx 23$ turns.

By (2.15) is in this case $H_{\max }=15.5 \mathrm{At} / \mathrm{cm}$. The datasheet of the core [19] indicates that the permeability will remain unaffected for this drive level. The permeability roll off due to the switching frequency can also be neglected.

### 3.4.3 Core loss

Using equations (2.16), (2.17), (2.18) and (2.19) with the datasheet [19], $B_{p k}$ is calculated to 0.01 T .

The core loss density for the calculated flux swing and switching frequency is extracted from an extrapolated figure in the core datasheet [19] to be $P L \approx 90 \mathrm{~mW} / \mathrm{cm}^{3}$,
which by (2.21) gives $P_{\text {core }}=374 \mathrm{~mW}$. These loss calculations are deemed to be to good to be true given the uncertainty of the data extrapolation. The core is therefore dismissed as a possible candidate.

### 3.4.4 Wire dimensioning

As the selected core is a toroid, (2.22) is used to calculate the winding circumference along with the data in table 3.1. This sets the required wire length to 37.6 mm per turn. Assuming that the amount of turns only requires a single layer, the total wire length, $l_{w}$ will be approximately 86.5 cm . For convenience this is rounded to 1 m . (2.23) sets the cross section area of the wire to $0.23 \mathrm{~mm}^{2}$. The actual wire should however be slightly thicker to compensate for increased resistance at high temperature.

The maximum thickness of the strands in a litz wire is calculated by (2.24) to about 0.130 mm . One litz wire that should be sufficient for this purpose is the Block CLI $200 / 60$ which have an effective cross section area of $0.471 \mathrm{~mm}^{2}$. The diameter for such a wire is about $\varnothing_{w}=0.78 \mathrm{~mm}$. The number of turns available for a single wire layer on the core can be approximated by

$$
\begin{equation*}
N=\frac{\pi \varnothing_{i}}{\varnothing_{w}} \tag{3.4}
\end{equation*}
$$

With this wire, the core will be able to fit about 57 turns which is a lot more than the needed number of 23 turns. The calculated length of copper wire of 1 meter is therefore correct. The actual power loss in the wire can, by using (2.23), be calculated to $P_{c u}=236 \mathrm{~mW}$ at $100{ }^{\circ} \mathrm{C}$.

### 3.4.5 Heating of the inductor

$S_{\text {component }}$ is by (2.26) calculated to $2.5 \mathrm{~cm}^{2}$. The temperature rise is then calculated to $\Delta T=97.4^{\circ} \mathrm{C}$ using (2.25). Adding the room temperature of about $25^{\circ} \mathrm{C}$ gives an inductor temperature of $122^{\circ} \mathrm{C}$. This value is within both the wire's and the core's operating temperature. It is however very likely that the actual temperature will be lower than this for two reasons:

1. The calculated core loss is the maximum loss that can occur, the mean will be lower.
2. The air will not be completely still. If cooling is an issue, a fan can be added.

### 3.4.6 Considerations regarding core choice

The chosen core is shown to be a viable option for the application as long as the estimated core loss is reasonably correct. However the core might be unnecessary large as only a few turns are required to reach the defined inductance. It is therefore reasonable to iterate and redo the calculation process with a smaller core size and/or another core material.

### 3.4.7 Other cores

Due to the uncertainty of losses of the core picked in the calculation example, further investigation are made. The company Micrometals released, in late 2016, a new series of cores, High Frequency Sendust, specifically developed for applications utilizing high power and have documentation for frequencies up to about 5 MHz . The iterative method already presented is used to compare a few cores of the series. Micrometals does not specify the connection between the magnetic field strength and magnetic flux in their datasheets[20], thus the approximation from (2.20) is used. A set of working inductors is shown in table 3.2. To get a feeling of the physical inductor size, the material volumes are presented in the table. This parameter is calculated by adding the volume of the core and the volume of the copper wire together. The litz copper wire used is the Block 200/60, the very same as is used above, and has a physical cross section area of $0.519 \mathrm{~mm}^{2}$.

Table 3.2: Inductor comparison based on Micrometals Sendust High Frequency core series, sorted by volume.

| Core part number | Permeability | Turns | Material volume $\left[\mathrm{cm}^{3}\right]$ | Losses $[\mathrm{W}]$ |
| :---: | :---: | :---: | :---: | :---: |
| SH-050026-2 | 26 | 81 | 1.72 | 2.17 |
| SH-068060-2 | 60 | 44 | 1.99 | 2.25 |
| SH-068026-2 | 26 | 51 | 2.09 | 1.63 |
| SH-065026-2 | 26 | 60 | 2.10 | 1.90 |
| SH-080026-2 | 26 | 58 | 2.55 | 1.96 |
| SH-090060-2 | 60 | 37 | 3.01 | 2.17 |
| SH-090026-2 | 26 | 48 | 3.19 | 1.59 |

The smallest one, SH-050026-2, have a bit too high losses to be a reasonable option. The large amount of turns needed can also make the inductor difficult to wind. The second smallest, SH-068060-2, have the highest losses of them all why it also is an unsuitable option. The SH-068026-2 is however the most viable core choice as it is small but have also low losses.

The core samples ordered from Micrometals are thus SH-068026-2 as well as the

SH-080026-2 and the SH-090060-2. The reason for the choice of core SH-080026-2 is that it is one step larger than the SH-068026-2 and can thus handle more turns or a thicker wire if it is deemed necessary. The SH-090060-2 is an option that only will need one layer of wire wound around the core. This can be useful to keep a minimum isolation distance between the core input and output. Care has to be taken in order not to place wires, with possibly 400 V , next to each other since this could lead to a breakdown of the insulation. Using a single layer mitigates the need of conductors with large potential difference to be near each other.

### 3.5 Boost MOSFETs and driver

### 3.5.1 Voltage and current rating

The overvoltage peak is dependent on the parasitic inductance and fall time of the current during switch off as described in section 2.4. Low fall time is preferred because it reduces the switching losses, hence the minimization of the parasitic inductance is therefore important. The needed breakdown voltage of the switch is difficult to precisely calculate at this point because of the uncertainties of the parasitic inductance introduced by the layout of the PCB , so 400 V and enough room for overvoltages caused by parasitic inductances are the requirements at this point. Snubbers can be implemented if the overvoltages are too severe. The peak current that the switches should be able to withstand during normal operation is the same as the used inductor peak current which is 4.27 A .

### 3.5.2 Parasitic source inductance mitigation

In order to mitigate problems due to parasitic source inductance, as discussed in section 2.4, a MOSFET with a so called Kelvin-source will be used. This is a fourth pin on the MOSFET which is connected directly to the source substrate of the transistor inside the casing. This separates the driving source from the power source early, thus partially avoiding the inductance of the source pin which carries fast changing high currents.

### 3.5.3 MOSFET losses

The switches finally chosen is called IPT65R195G7 and are from Infineon Technologies. The following data can be found in the data sheet: internal resistance $R_{G i}=1.2 \Omega$, Miller plateau voltage $V_{p l}=5.4 V$ and a threshold voltage of $V_{t h}=3.5 \mathrm{~V}$. Assuming no switching constrains such as maximum driver current or $d V / d t$-ratings and with $V_{D D}=13 \mathrm{~V}$ together with a gate resistance of $R_{G}=10 \Omega$
(which is the test case used in the data sheets) the gate current for a turn-on and turn-off event (initialized after time $t_{5}$ ) can be depicted as in figure 3.1.


Figure 3.1: Gate current of the G7 MOSFET for a turn-on event and turn-off event starting at time $t_{5}$.

The indicated currents in the figure are:

- $I_{p k+}=1300 m A$
- $I_{t h+}=950 \mathrm{~mA}$
- $I_{p l+}=760 \mathrm{~mA}$
- $I_{t h-}=-350 m A$
- $I_{p l-}=-540 m A$
- $I_{p k-}=-1300 m A$

The current rise time $\left(t_{r i}\right)$ and voltage fall time $\left(t_{f v}\right)$ correspond to times indicated as $t_{2}$ and $t_{3}$ respectively. In the same way, $t_{7}$ and $t_{8}$ correspond to the voltage rise time $t_{r v}$ and current fall time $t_{f i}$. To calculate the crossover times, the gate charge characteristic has to be investigated. Using the method presented in figure 2.11 the charge levels are extracted as $Q_{G S 2}=1.9 n C$ and $Q_{G D}=6.3 n C$. Calculating the average gate current for the rise and fall times and using (2.33) to (2.38) yields the crossover times $t_{c(o n)}=10.5 \mathrm{~ns}$ and $t_{c(o f f)}=15.9 \mathrm{~ns}$. The switching losses can then be calculated using (2.30) to (2.32) to

$$
\begin{equation*}
P_{G 7, \text { switching }}=\frac{400 V * 2.27 A}{2} * 1 M H z *(10.5 \mathrm{~ns}+15.9 \mathrm{~ns})=12.0 \mathrm{~W} \tag{3.5}
\end{equation*}
$$

where 2.27 A is used as the average drain-source current, which is equal to the
average inductor current [8], which is half the average input current during low line operation. The loss in the driver can be calculated as

$$
\begin{equation*}
P_{G 7, \text { driver }}=V_{D D} Q_{G, 13 V} f_{s}=13 V * 25 \mathrm{nC} * 1 \mathrm{MHz}=0.33 \mathrm{~W} \tag{3.6}
\end{equation*}
$$

The loss because of $C_{\text {oss }}$ discharging through the channel can be calculated as

$$
\begin{equation*}
P_{G 7, C o s s}=E_{\text {oss }} f_{s}=2.3 \mu \mathrm{~J} * 1 \mathrm{MHz}=2.3 \mathrm{~W} \tag{3.7}
\end{equation*}
$$

The maximum conduction losses can be calculated as

$$
\begin{equation*}
P_{G 7, \text { conduction }}=I_{D S, R M S}^{2} R_{D S, \text { on }}=(2.52 A)^{2} * 0.195 \Omega=1.24 \mathrm{~W} \tag{3.8}
\end{equation*}
$$

The total losses for the IPT65R195G7 MOSFET and driver can be calculated to

$$
\begin{equation*}
P_{G 7, l o s s}=P_{G 7, \text { switching }}+P_{G 7, \text { driver }}+P_{G 7, \text { Coss }}+P_{G 7, \text { conduction }}=15.9 \mathrm{~W} \tag{3.9}
\end{equation*}
$$

### 3.5.4 Driver circuitry design

A generic MOSFET drive circuit is shown in figure 3.2.


Figure 3.2: Generic gate driver circuitry and MOSFET.

As depicted in the figure, the driver circuitry consists of a driver with internal MOSFETs arranged in a totem pole configuration. The resistances $R_{s r c}$ and $R_{s n k}$ are parasitic resistances, while $R_{e x 1}$ and $R_{e x 2}$ are actual physical resistances, $R_{f b}$ is the DC-resistance of the ferrite bead and $R_{g i}$ is the internal gate resistance of the MOSFET. $R_{f}$ and $C_{f}$ creates a filter for the input voltage. The diode $D_{o f f}$ makes it possible to effectively have different values for the turn-off and turn-on.

The resulting turn-on and turn-off gate resistances can be calculated as:

$$
\begin{gather*}
R_{o n}=R_{s r c}+R_{e x 1}+R_{f b}+R_{g i}  \tag{3.10}\\
R_{o f f}=R_{g i}+R_{f b}+\frac{R_{e x 1}+R_{e x 2}}{R_{e x 1} R_{e x 2}}+R_{s n k} \tag{3.11}
\end{gather*}
$$

As discussed in [10] the driver and switch layout depicted in figure 3.2 results in lower gate oscillations compared to using a PNP transistor to pull the gate low during turn-off. One of the drawbacks of using the proposed layout is that the turn-off might take a longer time since the current that flows out from the gate is limited by high resistance in the driver. In order to try to mitigate this problem a driver with low output sinking resistance is required. To avoid problems with unstable/changing ground potential an isolated driver is also preferred. The chosen driver circuit is UCC21521 from Texas Instruments. This is an isolated, dual channel gate driver with an output sinking resistance of $R_{s n k}=0.55 \Omega$.

The external components presented in figure 3.2 are designed by investigating MOSFET switching patterns and the data sheets of the relevant components. The circuit might be designed in such a way that the turn-on and turn-off resistances are equal. In this case the external resistor $R_{e x 2}$ and the diode $D_{o f f}$ can be removed which can be beneficial since it results in lower loop inductance because of a physically shorter loop. If the turn-on and turn-off resistances of the circuitry are to be equal/similar using only one gate resistor, the internal output resistances of the driver must also be equal. Unfortunately the data sheets lists a sinking resistance of $R_{\text {snk }}=0.55 \Omega$ and a sourcing resistance of $R_{\text {src }}=5 \Omega$. Luckily there is an internal pull-up MOSFET in parallel with the driver totem pole P-channel MOSFET which should start to conduct during the Miller-plateu. The resistance of the parallel pull-up is stated to be approximately $1.47 \Omega$ which brings the effective sourcing and sinking resistances closer together. In order not to fall below a total gate resistance of $10 \Omega$ the external resistor $R_{e x 1}$ should not have a higher value than $R_{e x 1}=R_{o n / o f f}-R_{f b}+R_{g i}+R_{s n k}=10-0-1.2-0.55=8.25 \Omega$, under the assumption that $R_{f b}=0 \Omega$.

The manufacturer of the MOSFET recommends the usage of a ferrite bead close the the gate pin for fast switching applications in order to reduce any gate ringing. The ferrite bead should not saturate during operation and provide high resistance for high frequencies but not alter the PWM signal too much. The chosen bead is

BLM18KG121TH1D from Murata which saturates at 3 A and provides $120 \Omega$ at 100 MHz and low DC-resistance. The saturation limit is chosen to be 3 A in order to have some room to change the gate resistors without saturating the bead. The capacitance $C_{f}$ is chosen to be one $10 \mu F$ and one $220 n F$, which is the same as the values presented in one design example of the driver data sheet. Worth noting is that the ground connection of $C_{f}$ is made to the Kelvin-source pin. The resistor $R_{f}$ is set to $15 \Omega$ which allows for much more than the needed driver current of about 25 mA .

A $10 \mathrm{k} \Omega$ resistor is also added in parallel to the gate and Kelvin source in order to keep the MOSFETS turned off when the circuit is initially powered on. Additionally, a $220 n F$ decoupling capacitor is placed at the 3.3 V driver supply voltage pins. The driver schematic is shown in figure 3.3


Figure 3.3: Gate drive circuitry.

### 3.6 Boost diodes

Because of the reasons described in section 2.5 the diode used should have a low forward voltage drop and a low reverse recovery charge in order to keep the losses down. To mitigate the problem with current flowing in the "wrong" direction at turn-off, a Schottky diode can be used. One of the problems with regular Schottky diodes are that they have low breakdown voltage, luckily there are Schottky SiC diodes that can withstand higher breakdown voltages, which makes them a good choice for this application.

The 5 A, 650V SiC Schottky diode C3D03065E from CREE has a forward voltage drop $V_{F}=1.25 V$ at 1.25 A , which is the average current through the diode, and
$Q_{C}=7.6 \mathrm{nC}$. The losses of this component can be be calculated using (2.42) and (2.43) to $P_{D, \text { conduction }}=1.56 \mathrm{~W}$ and $P_{D, \text { switching }}=1.52 \mathrm{~W}$.

### 3.7 Smoothing and loop capacitors

### 3.7.1 Bulk capacitance value

The output capacitor, or bulk capacitors, of a PFC can be dimensioned based on the required hold up time and minimum output voltage. In this case, the output voltage does not need to be investigated since the size of the capacitor is based on the hold up time. This is often high enough to keep any output voltage ripple low enough to have insignificant effect on the power factor [21].

Assume that there is no energy storage in the PFC components and that the load will consume the rated output power during the hold up time. The losses in the capacitor is also assumed to be zero. Thus, energy in the capacitor can thus be written as $E_{C}=\frac{1}{2} C V^{2}$ and the the needed bulk capacitance $\left(C_{o}\right)$ can therefore be written as

$$
\begin{equation*}
C_{o}=\frac{2 P_{o} T_{\text {hold }}}{V_{\text {initial }}^{2}-V_{\text {min }}^{2}} \tag{3.12}
\end{equation*}
$$

where $T_{\text {hold }}$ is the designing hold up time, $V_{\text {initial }}$ is the voltage before the supply interruption and $V_{\min }$ is the voltage after the interruption has ended. To fulfill the requirements of specifications the minimum size of the capacitor is $572 \mu F$.

### 3.7.2 Ripple RMS and tan $\delta$

The capacitor can not handle infinite ripple amplitudes because of losses. Therefore the ripple into the bulk capacitors is investigated.

Figure 3.4 shows a simplified version of the ripple in the bulk capacitors. The simplifications made during this plot is that the amplitude of the inductor ripple is constant throughout the whole period of the 100 Hz wave. This means that the amplitude of the ripple only holds true at the two peaks at times 0.25 and 0.75 in the figure. A lower switching frequency is used for illustrative purposes. As the ripple height is the same, the figure is useful for dimensioning the required ripple capacity of the capacitors. As can be seen in the figure there are ideally two kinds of ripple: one with the twice the grid frequency and one with twice the switching frequency.

The low frequency ripple $I_{C l o, R M S}$ can be calculated as

$$
\begin{equation*}
I_{C l o, R M S}=R M S\left(I_{D 1, l o}+I_{D 2, l o}-I_{L o a d}\right) \tag{3.13}
\end{equation*}
$$

where $I_{D 1, l o}$ and $I_{D 2, l o}$ simplified as half the input current during low line operation and $I_{\text {Load }}$ as the load current corresponding to 1 kW at 400 V results in $I_{C l o, R M S}=$ 2.99 A . The high frequency ripple amplitude can not exceed the maximum inductor ripple which is 1.42 A .


Figure 3.4: Graph depicteing a simplified summation of the PFC diode currents.

The ESR of a electrolytic capacitor is frequency dependent and is defined as the sum of all the dielectric and connection resistance and can be calculated as [22]

$$
\begin{equation*}
R_{C}=\frac{\tan \delta}{2 \pi f C} \tag{3.14}
\end{equation*}
$$

where $\tan \delta$ is given in the data sheets, $f$ is the ripple frequency and $C$ is the capacitance of the given capacitor.

Rubycon QXW series specifies tan $\delta=0.24$ for their 450 V electrolytic capacitors. Four $180 \mu F$ capacitors satisfies the minimum bulk capacitance requirement. The ripple capacity for the bulk capacitors at $60 \mathrm{~Hz}(100 \mathrm{~Hz}$ not specified) is 3.5 A . With a tan $\delta$ of 0.24 the ESR of the bulk capacitors can be found using (3.14) to be $530 \mathrm{~m} \Omega$ resulting in a loss of $2.99^{2} A^{2} * 0.530 \Omega=4.7 \mathrm{~W}$.

As previously stated it is important to minimize the high frequency, high current loops. This can be done by placing a ceramic capacitor directly to ground after the Schottky diodes. This capacitor will act like a bypass capacitor. The PCB layout is at this stage not decided and it is possible that the Schottky diodes will be placed
far apart in order to minimize parasitic inductances for the switches and drivers. Because of this two capacitors are used, one for each channel. The voltage ripple can be calculated as $\Delta V=\frac{\Delta Q}{C}$, assuming that all the ripple flows through the capacitors and that the average current through the diodes are $\frac{P_{o}}{2 V_{o}}$. The maximum change in charge $\Delta Q$ would be if $D=1$ (or 0 ) and the high frequency voltage ripple could therefore be estimated as

$$
\begin{equation*}
\Delta V_{o u t, H F}=\frac{P_{o}}{2 V_{o} C_{o, H F} f_{s}}, \tag{3.15}
\end{equation*}
$$

where $C_{o, H F}$ is the capacitance of the bypass capacitor used for high frequency bypass. TDK CKG57KX7T2J474M335JH7 $0.47 \mu F, 630 V D C$ can be used for the high frequency ripple. This one is selected because of its small size and its good DC-bias characteristics. At 400 VDC bias and neglecting temperature, the remaining capacitance is $0.188 \mu F$, leading to a voltage ripple less than 7 V . The ESR at 1 MHz can be read from the data sheet to $20 \mathrm{~m} \Omega$ so the losses can be neglected and a low impedance path for the high frequency ripple is provided.

Another bypass capacitor is added after the diode bridge rectifier to provide a shorter path for the high frequency ripple. The capacitor used will be the stacked ceramic capacitor TDK CKG57NX7T2J105M500JH $1 \mu F, 630 V D C$. This capacitor forms a LC filter together with the boost inductors which will have a positive impact on the conducted EMI.

### 3.8 Calculated suppression of inductor ripple

The ripple in the inductors are attenuated in several stages of the design. Firstly the bypass capacitor which forms an LC filter with the inductors. Secondly, the ripple is attenuated by the EMI filter. In addition to this, some of the ripple cancels out because of the interleaved operation.

Given that the EMI filter is designed in such a way that $C_{X 1}=C_{X 1}=C_{D M}$ the equivalent circuit for attenuation of differential mode voltage noise can be drawn as depicted in figure 3.5 [12]. The differential noise voltage source $V_{S, D M}$ caused by the inductor ripple can be represented as shown in figure 3.6.

The inductors are charged and discharged during each switching period. Assuming that all energy is provided by the $1 \mu F$ bypass capacitor it is possible to relate the inductor ripple to a voltage ripple across the capacitor. The maximum ripple energy that is stored in the inductor occurs at the peak of the input current which during low line operation is 7.12 A . The differance in energy in the inductor because of the 1.42 A ripple can be calculated as


Figure 3.5: Circuit representation of DM noise attenuation of the EMI filter.


Figure 3.6: DM noise source circuit representation.

$$
\begin{equation*}
\Delta E_{L}=\frac{1}{2} L \hat{I}_{L}^{2}-\frac{1}{2} L \check{I}_{L}^{2} \tag{3.16}
\end{equation*}
$$

where the currents are calculated using (2.12) and (2.19) which, using $\mathrm{L}=35 \mu \mathrm{H}$, yields $\Delta E_{L}=177 \mu \mathrm{~J}$.

In the same manner, if the resulting voltage change across the bypass capacitor is small, the DC-bias effect of the voltage ripple of the capacitor is also negligible. So if the voltage across the capacitor $V_{C, \text { bypass }}$ is approximated to be constant 325 V the $1 \mu \mathrm{~F}$ capacitor will effectively only have 450 nF . The resulting voltage change because of $\Delta E_{L}$ can be found by solving

$$
\begin{equation*}
\frac{1}{2} C_{\text {bypass }} V_{C, \text { bypass }}^{2}=\Delta E_{L}+\frac{1}{2} C_{\text {bypass }}\left(V_{C, \text { bypass }}-\Delta V_{C, \text { bypass }}\right)^{2} \tag{3.17}
\end{equation*}
$$

for $\Delta V_{C, \text { bypass }}$. Given $C_{\text {bypass }}=450 \mathrm{nF}, V_{C, \text { bypass }}=325 \mathrm{~V}$ and $\Delta E_{L}=177 \mu \mathrm{~J}$ the equation can be solved, resulting in $\Delta V_{C, \text { bypass }}=1.21 \mathrm{~V}$.

Since there are two channels the frequency of the ripple will be 2 MHz and the differential mode noise voltage source is therefore simplified as $V_{S, D M}=\frac{1.21}{2} \sin (2 \pi t *$ $2 * 10^{6}$ ) V.

The cut-off frequency of the DM noise of the EMI filter is 33 kHz and the attenuation of $V_{S, D M}$ is therefore equal to $40 \log \left(\frac{2 * 10^{6}}{33 * 10^{3}}\right)=71.3 \mathrm{~dB}$. The differential mode noise, caused by the inductor ripple, after the EMI filter have thus an amplitude of $V_{O, D M}$ $=\frac{1.21}{2} * 10^{\frac{-71.3}{20}}=165 \mu \mathrm{~V}$. This is the maximum possible noise without cancellation caused by two channel operation.

### 3.9 Bleeder circuit

In order to ensure a safe handling of the device it is important to discharge the bulk capacitors when the unit is turned off. If no load is attached to the output and no discharging resistors are incorporated in the circuit the output would carry lethal voltage long after the device is disconnected from the grid. Bleeder resistors are therefore necessary to use.

A suitable choice are four $4.7 \mathrm{k} \Omega$ resistors connected in series. Calculating a worst case scenario with a bulk capacitor voltage of 450 V , a bulk capacitance of $720 \mu F+20 \%$ and a bleeder resistance of $18.8 k \Omega+5 \%$ gives a discharging time of about 34 seconds, i.e. until a safe DC-voltage of 60 V is reached. The use of four bleeder resistors provides a spread of heat dissipation and ensures that the breakdown voltage for each of the resistors is not exceeded.

If the bleeder resistors are connected directly to the bulk capacitors an extra power loss is introduced in the circuit, generating heat and reducing the efficiency. One way around this issue is to implement a transistor circuit that only is enabled when the device is turned off. Such a circuit can look like depicted in figure 3.7. The four bleeder resistors are here lumped together as one $18.8 k \Omega$ resistor. When the device is powered from the grid the 12 V supply will be available and drive the gate of Q1 high, which in turn drives the gate at Q2 to ground so no current will flow through the bleeder resistor. When the 12 V supply disappears at power off the voltage over the bulk capacitors drive the gate of Q2 high and thus activate the discharging of the bulk capacitors. The zener diode ensures that the gate voltage is kept at a, for the transistor, suitable level.


Figure 3.7: Bleeder circuit that is disabled when the power is on.

### 3.10 Low voltage supply

In order to supply the needed 3.3 V the AC-line voltage is converted to 5 V using a 5 W PCB mounted $\mathrm{AC} / \mathrm{DC}$ converter. In order to decrease the voltage further and to decrease any ripple, a linear regulator is used. A so called Low Drop Out (LDO) regulator is preferred because the voltage supplied from the AC/DC converter is 5 V , which is close required 3.3 V . Some LDOs requires an output capacitor with relatively high ESR, like electrolytic capacitors, since its control system is designed for that [23]. A parallel ceramic capacitor could effectively lower the output resistance so that the LDO control system malfunctions. Ceramic capacitors will be used as decoupling capacitors for several ICs supplied with 3.3 V which is why a LDO specifically designed for ceramic capacitors is required. A suitable regulator is LP2989 which is able to provide 500 mA at 3.3 V . According to its data sheet the input capacitor should not drop below $1.5 \mu F$ and the output capacitor should not drop below $2.2 \mu F$. The output capacitor used will be ceramic so it is important to consider its DC-bias behaviour. In order to limit the effect of the DC-bias ceramic X7R capacitors rated for 25 V in 1206 SMD package is used. The chosen value for both input and output capacitor is $4.7 \mu F$. Another one of these regulator setups are used for the isolated USB supply voltage as well. The current requirements is presented in table 3.3 and table 3.4 and it can be concluded that the 500 mA provided by the regulator is enough.

The 12 V supply is used by the driver and a fan which consumes 2.45 W . The 12 V supply is supplied via a 5 W PCB mounted AC/DC converter. The energy provided by the low voltage supplies can be seen as losses. The specified typical efficiency of the $\mathrm{AC} / \mathrm{DC}$ converters is $70 \%$ and losses because of the 3.3 V supply is approximated as $\frac{(153+60+30+0.006) m A * 5 V}{0.7} \approx 1.74 \mathrm{~W}$. This means that the total loss because of the low voltage supplies can be estimated as $1.74 W+\frac{2.45}{0.7} W=5.24 W$.

Table 3.3: 3.3V board current requirements

| Discription | Part no. | Requirement [mA] |
| :--- | :--- | :--- |
| Digital isolator | ISO7240 | 25 |
| Digital isolator | ISO7242 | 24 |
| DSP | TMS320F28035PNS | 153 |
| 2x OP-amps | OPA2365 | $\sim 60$ |
| Gate driver | UCC21512 | 30 |
| 4x Signal LEDs | - | 80 |
| Linear active thermistor | MCP9700AT-E/LT | 0.006 |
| Total |  | $\sim 372$ |

Table 3.4: Isolated 3.3V USB current requirements

| Discription | Part no. | Requirement [mA] |
| :--- | :--- | :--- |
| Digital isolator | ISO7240 | 11 |
| Digital isolator | ISO7242 | 24 |
| UART/FIFO | FT2232HL | 210 |
| EEPROM | 93LC56BT | 2 |
| LED | - | 20 |
| Total |  | $\sim 267$ |

### 3.11 Input voltage dividers

The circuit that scales down the input voltage to a, by the DSP, measurable voltage is presented in figure 3.8.


Figure 3.8: Circuit for measuring the input voltage.

The circuit is essentially a resistive voltage divider where the resistors $R_{1}$ and $R_{2}$ values are chosen with respect for the current drawn by the sensing pin as to minimize the distortion of the signal. The reason why two resistors is used for the high side
of the divider is to increase the voltage rating of the divider. $432 k \Omega, 500 \mathrm{~V}$ SMD resistors are used for $R_{1}$ and $R_{2}$. The package of these resistors are 1206 and the distance between the leads of the solder pattern will be therefore be 1.6 mm . This is in accordance with the IPC-2221 standard for electrical conductor spacing which require a minimum of 0.8 mm separation of the conductors in this application. The low side resistor, $R_{3}$, is chosen to be $7.15 k \Omega$ if the signal VinSense is to be kept below 3 V at normal operation. The diodes are protecting the sense pin by limiting the voltage that can occur over it. If an error causes the voltage on the sense pin to go above 3.3 V or below 0 V the diodes will conduct and thus protect the processor from being destroyed.
$C_{F}$ together with the resistances of the divider forms a low pass filter in which -3 dB is reached at

$$
\begin{equation*}
f_{c}=\frac{1}{2 \pi \frac{\left(R_{1}+R_{2}\right) R 3}{R_{1}+R_{2}+R_{3}} C_{F}} \approx 5.8 \mathrm{kHz} \tag{3.18}
\end{equation*}
$$

### 3.12 Output voltage divider

The circuit used to sense the output voltage is shown in figure 3.9.


Figure 3.9: Circuit for measuring the output voltage.

The same reasoning as applied in section 3.11 applies to this divider. The values of $R_{1}$ and $R_{2}$ are $1 M \Omega, R_{3}$ is $10 k \Omega$ and capacitor $C_{F}$ is 7.8 nF (two 3.9 nF capacitors are used). No protective Schottky diodes are needed here as the output voltage is controlled by the processor.

### 3.13 Current measuring circuits

The current through the two switches is measured as one measurement. The current is passed through a $20 \mathrm{~m} \Omega$ current sense resistor. The peak of the current through this resistor occurs at the peak of the input current during low line operation and when the inductor ripple reaches its maximum. The current at this point is 8.6 A which will result in a voltage of 172 mV across the sense resistor. However it is good to be able to measure an even larger current so the PWM can be controlled even at an overcurrent state. The DSP's ADC can measure a voltage between 3.3 and 0 V. To optimally utilize this window an operation amplifier, OP-amp, in differential configuration is used to amplify the measured voltage. With a gain of 10 the highest measurable voltage is 330 mV and thus 16.5 A . The chosen OP-amp, OPA2365, can output voltages close to the supply voltage rails but not exactly, which is why the linearity is reduced at the limits. At the upper current limit, this is not a big problem but it is important that currents close to zero also can be measured accurately. This issue is mitigated by raising the positive leg of the OP-amp by a small fixed voltage offset. The lowest output voltage of the OP-amp is now the offset voltage and the nonlinear tendencies are therefore avoided. This comes at a cost of decreased resolution due to a smaller measuring window, which is deemed to be an acceptable tradeoff.

The sensor voltage amplified by the OP-amp should be low pass filtered to get rid of any unwanted noise. This is done by adding a couple of capacitors to the differential amplifier to form a Butterworth filter. The complete current measuring circuit is shown in figure 3.10. The gain is given by $R_{3} / R_{1}=10$. The cutoff frequency for the differential low pass filter is given by $\frac{1}{2 \pi R_{3} C_{1}}$ which in this case is about 2 MHz . The voltage follower provides the voltage offset via the voltage divider. The chosen values of $R_{5}$ and $R_{6}$ gives an offset voltage of 96 mV , while the capacitor $C_{3}$ only acts as a filter.

The maximum current that can be measured when voltage offset and swing are taken into consideration is given by

$$
\begin{equation*}
I_{\text {sense }, \text { max }}=\frac{V_{\text {supply }}-V_{\text {offset }}-V_{\text {satmargin }}}{R_{\text {sense }} G} \tag{3.19}
\end{equation*}
$$

where $V_{\text {supply }}$ is 3.3 V , $V_{\text {offset }}$ is the offset voltage calculated above, $V_{\text {satmargin }}$ is the difference between the high/low rail voltage and the maximum/minimum output voltage, $R_{\text {sense }}$ is the value of the sense resistor and $G$ is the amplifier gain. For the OPA2365, $V_{\text {satmargin }}$ is in the range of 10 mV , but say 20 mV to be on the safe side. This gives a maximum sense current of 15.9 A before the OP-amp saturates which is good enough.

The DSP's ADC has a resolution of 12 bits, which equals to 4096 levels. The lowest


Figure 3.10: Current measuring circuit.
detectable current is calculated as

$$
\begin{equation*}
I_{\text {resolution }}=\frac{V_{\text {supply }}}{4096 R_{\text {sense }} G} \tag{3.20}
\end{equation*}
$$

which in this case is 4.3 mA .
Place holders are pre-emptivly added to the PCB in order to make it possible to easily add a similar current measuring circuit in order to measure the output current if that is deemed necessary.

### 3.14 Digital Signal Processor

The DSP used for measurements, signal processing and PWM generation will be a Piccolo TMS320F28035 [24].

### 3.14.1 PWM output pins

The clock frequency of the DSP is 60 MHz . As a consequence the resolution of the duty cycle is poor since the switching period only can be divided into 60 parts when
using 1 MHz switching frequency. The resulting duty cycle resolution is $1.7 \%$. The DSP has a functionality called High Resolution PWM, HRPWM for short, which means that the DSP is able to divide the system clock into smaller time steps for these HRPWM-pins [25]. The improved resolution of the duty cycle is $0.018 \%$, and therefore these pins will be used for the PWM signal to the MOSFET drivers.

### 3.14.2 Overcurrent protection

To be able to safely operate the PFC circuit, some kind of overcurrent protection is needed. This is especially important in an early developing state where bugs can cause the transistor switching to malfunction - resulting in damaging currents. The protection needs to have a very short response time as any prolonged short circuit would immediately destroy the transistors and possible other components as well. A simple fuse is therefore not sufficient as it reacts too slow.

The most reliable way to protect the components is to rapidly turn off the PWM switching. This can be done in the DSP software as the current is measured by the DSP. The DSP can turn off the PWM output if the current is measured to be above a certain value. However, the current will most certainly not be sampled at the switching frequency but probably around one tenth of the switching frequency. This means that a lot can happen between the current samples and the transistors can have been blown into smoke before the overcurrent is detected. To get an asynchronous and quick enough disabling of the PWM, analogue circuits are needed.

The DSP have built-in analogue comparators connected to some of the analogue inputs [26]. The comparator can compare the analogue level at the input with a reference value from an internal DAC. The reference value is set in software but the comparison is purely analogous. The output of the comparator is fed to one of the pins of the DSP. This signal can be connected to the Enable-inputs on the transistor drivers. The voltage over the current sense resistor can thus be fed to one comparator input and if the current is too high, the voltage will be higher than the defined reference, the comparator trips and disables the drivers and therefore the transistors. This is all done within a few nanoseconds. The drivers would however turn on again when the current once again is within nominal range. But an overcurrent is a serious issue and the drivers must be kept disabled until a manual reset is done. This can be done by setting a very quick latch between the comparator output of the DSP and the drivers' Enable. Figure 3.11 illustrates a D-latch with a manual reset possibility. When the reset button is pushed, Q goes high and enables the drivers. If the output from the DSP's comparator goes high due to an overcurrent, Q immediately goes low and disables the drivers. At the same time a LED lights up to show that an overcurrent event occured and a reset is needed. The reset feature may also be implemented in software by connecting another DSP pin to the D-input of the latch.

There are however other ways to implement the overcurrent protection as well. The


Figure 3.11: Overcurrent protection circuit with manual reset.
output of the DSP's comparator can internally be connected to the PWM generating stage and there directly turn off the outputs. This can also be done asynchronously, leading to very short propagation times. This method is slightly more complicated and requires a bunch of registers and multiplexers to be set but does not on the other hand require any external hardware [24, 26, 27]. The internal signal path is shown in figure 3.12 where only the relevant registers and signals are included. When the signal passes the TZSEL-switch, the signal takes both an asynchronous


Figure 3.12: Internal processor path for overcurrent protection.
and synchronous path to the Trip logic-block. The asynchronous path makes the PWM output pin to go low immediately, but for the pin to stay low the latch needs also be set. The latch will be set if the fault is longer than at least three clock cycles, which for 60 MHz is 50 ns . If the latch is set high, a LED connected to the DSP can be turned on by software. The latch can be reset by setting the OST in the TZCLR register.

### 3.14.3 USB interface

To be able to upload firmware to the DSP and debug it, the DSP is equipped with both a serial and a JTAG interface. These interfaces are connected through isolation circuits to an USB FTDI chip, which provides a USB interface for communication with a PC. The isolation circuits ensures an electrical isolation between the USB connected computer and the DSP, provides equipment protection and user safety. These isolated interfaces, which are located in one of the corners of the PCB, are marked in the silk. The schematics can be found in the appendix A.

### 3.15 Summation of component losses

The calculated losses are summarized and presented in table 3.5.
Table 3.5: Calculated losses of the system, sorted by loss contribution

| Discription | Loss/component [W] | Loss [W] |
| :--- | :--- | :--- |
| Boost MOSFET | 15.9 | 31.8 |
| Rectifier | 8.2 | 8.2 |
| Boost diode | 3.1 | 6.2 |
| LV-supply | 5.2 | 5.2 |
| Bulk capacitors | 4.7 | 4.7 |
| Boost inductor | 2.2 | 4.4 |
| Total loss |  | 58.8 W |
| Expected efficiency |  | $94.4 \%$ |

### 3.16 Heat mitigation

According to relevant data sheets and the result of the loss calculations, presented in table 3.5, the following components will need cooling: the MOSFETs Q2 and Q3, the boost diodes D4 and D5, and the diode bridge rectifier U4. The boost inductors may also need active cooling depending on their performance and the air flow in the encapsulating box.

### 3.16.1 MOSFET and boost diode footprints

The MOSFETs and boost diodes are cooled through the tabs which are located on the bottom side of the components. This means that the cooling have to be done through the PCB. The thermal conductivity of the MOSFET footprint on a standard FR4 PCB is about $66 \mathrm{~K} / \mathrm{W}$ [28]. 17.4 W is dissipated in each MOSFET
and the resulting temperature increase because of the PCB would theoretically be $17.4 W * 66 K / W \approx 1150{ }^{\circ} \mathrm{C}$, which of course would be impossible. The thermal resistance of the PCB needs to be decreased in order to not burn the switches. This can be done by implementing footprints with thermal vias. A thermal via is just a regular via, which essentially is a plated hole in the PCB, used for its thermal conductivity purposes. [28] recommends hole sizes of $0.3-0.5 \mathrm{~mm}$ with a separation distance of $0.5-1 \mathrm{~mm}$. The thermal resistance of one thermal via can be calculated as [28]

$$
\begin{equation*}
R_{t h, V i a}=\frac{h_{P C B}}{\lambda \pi s\left(\varnothing_{v i a}+s\right)} \tag{3.21}
\end{equation*}
$$

where $h_{P C B}$ is the thickness of the PCB, $\lambda$ is the specific thermal conductivity of copper, $s$ is the thickness of the copper plating in the hole and $\varnothing_{\text {via }}$ is the hole diameter. Thermal vias are implemented for the MOSFET and boost diode footprints and the footprint of the MOSFETs are depicted in figure 3.13.


Figure 3.13: MOSFET footprint with thermal vias for reduced thermal resistance.

The via are placed in two overlapping matrices shifted 0.5 mm in which the space between the centre of the holes are 1 mm . This results in a pattern in which, given that the hole diameter is 0.3 mm , the distance between the edges of the via holes are $407 \mu \mathrm{~m}$. This is above the specified minimum distance of $400 \mu \mathrm{~m}$ for the considered PCB manufacturer. The thermal conductivity of one via can be calculated using (3.21) to $\sim 155 \mathrm{~K} / W$ given a 1.6 mm thick PCB , a hole diameter of 0.3 mm and that the plating is $25 \mu \mathrm{~m}$. The MOSFET footprint implements 142 vias while only 60 vias fits in the boost diode footprint. This means that the thermal
resistance of the footprints are $R t_{\text {Qvia }}=\frac{155 \mathrm{~K} / \mathrm{W}}{142}=1.1 \mathrm{~K} / \mathrm{W}$ for the MOSFET and $R t_{\text {Dvia }}=2.6 \mathrm{~K} / \mathrm{W}$.

A common thickness for PCBs are 1.6 mm but thinner PCBs are possible. The observation that the thermal resistance of the via is directly proportional to the PCB thickness can easily be made given (3.21). Steady state thermal performance for the different thicknesses can quickly be made by simulating the corresponding thermal circuitry which is presented in figure 3.14.


Figure 3.14: Thermal circuit comparison of different PCB thicknesses.

The thermal circuit analysis assumes $25^{\circ} \mathrm{C}$ ambient temperature, a heat sink with a thermal resistance of $0.5 \mathrm{~K} / \mathrm{W}$ like a CPU cooler or similar and specific isolation pads[29]. It can be noted, at the MOSFET TP, that there is a temperature difference of about $7{ }^{\circ} \mathrm{C}$ between the different PCB thicknesses. Considering the price difference, the increased operating temperature of the 1.6 mm PCB is deemed acceptable.

A thermal sensor is added close to the two boost channels in order to add some thermal protection. The thermal sensor consists of the linear active thermistor MCP9700/9700A and is thermally connected to the heat sink through vias.

### 3.16.2 MOSFET and boost diode heat sink

Given that the MOSFETs and boost diodes will be located close together to minimize the high frequency loops it is possible to use a heat sink with a relatively small contact area like a CPU cooler. The chosen heat sink is a low profile construction with a fan mounted on top. The total height is 37 mm . The fan will be placed in such a way that fresh air is pulled from the outside of the encapsulating box.

### 3.16.3 Thermally conductive isolation pad

Since the boost MOSFETs and diodes share the heat sink it is necessary to add a electrical insulator in between the heat sink and the PCB. This insulator needs to have a low thermal resistance in order to keep the components from being damaged. The thermal heat sink pad Hi-Flow 300P with a thermal impedance of $0.84 \mathrm{~cm}^{2} K / W$ from Bergquist is used and has a thickness of $102 \mu \mathrm{~m}$ and a breakdown voltage of 5 kVAC . The pad is delivered in sheets which are cut to cover the contacting part of the heat sink which is $40 \times 40 \mathrm{~mm}$. The PCB area that will contact the heat sink will have no solder mask in order to try to improve the interface between the component footprints and thermal pad.

### 3.16.4 Diode bridge rectifier heat sink

The full bridge rectifier will have a separate heat sink since it is cooled via the top of the component. The heat sink chosen is 6222BG by Aavid Thermalloy which has a thermal resistance of $9.4 \mathrm{~K} / \mathrm{W}$ without forced cooling, resulting in a maximum temperature increase of $77^{\circ} \mathrm{C}$. Worth noting is that the air inside the box will likely not be totally still because of the setup of the CPU cooler.

### 3.17 PCB design

### 3.17.1 General component placement and routing strategy

The PCB is drawn using the software Altium. Firstly, the components are placed and connected in small groups consisting of for example one linear regulator with its associated resistances and capacitances. Secondly, these small groups of routed components are placed together to form larger component clusters, i.e the USB interface, in order to get more manageable pieces to work with in order to structure the PCB layout. Finally the clusters are connected. Digital signals are kept away from analog signals in order to try to avoid noise problems.

Components can be placed on both sides of the board in all areas except the area covered by the heat sink interface. Also, THT components placed close to the heat sink must not violate the minimum isolation distance. On this PCB almost all components are placed on the top side. The PCB is a four layer $70 \mu m$ copper board with most of the signal routing on the top layer, while power routing and grounding is done on layer two and three. The last layer is used when signals need to cross and to connect the few bottom side mounted components.

Decoupling capacitors are placed in such a way that the routing length is minimized. The decoupling capacitors are often connected to the second and third layer and this
is done using vias. The via is placed directly to the side of the capacitor pads in order to minimize the inductance to the decoupling capacitor [30].

### 3.17.2 Board size

There are no board size restrictions in the specification of requirement, so the clusters are placed to form a rectangular board. The size of the board directly relates to the price, which is why some effort was made in order to minimize the size. The final dimensions on the PCB is $125 \times 220 \mathrm{~mm}$.

### 3.18 Encapsulation and connectors

In order to choose a suitable box, the final height of the printed board assembly needs to be established. The limiting component on the bottom side is the heat sink which builds 37 mm and the deciding component on the top side is the electrolytic capacitors which has a height of 46 mm . Since the PCB is 1.6 mm thick the minimum inner box height is $\sim 85 \mathrm{~mm}$. A suitable box is Hammond RM20295L, mounting holes in the PCB are made to fit the mounting inside the box. The heat sink fan rests on the bottom of the box which has a hole for the air intake. Bumpers are therefore added to elevate the box in order to not hinder the air flow. According to the requirements of specifications the finished build should have generic input/output connectors. A flush mounted IEC-60320-C14 mains socket is mounted for the input. Black and red 4 mm safety banana jacks are mounted for the output. Both input and output connectors are connected using FASTON since this is used on the PCB.

### 3.19 Functionality verification

The verification has to be done in small steps which minimizes the risk of component damage as there are no delusions regarding the initial functionality of the product. This is why a plan of verification is made, which consist of a series of preplanned hands-on tests.

1. Test of low voltage supply before soldering
(a) Connect the LV supplies using alligator clips to a DC power supply.
(b) Ramp the voltage until they start.
(c) Connect appropriate loads and investigate the voltage.
(d) Establish a minimum working voltage under which both power supplies
are able to supply a load at an appropriate voltage level. This voltage level will be called mains in this list.
2. Construction of boost inductors
(a) Cut litz wire at about 1.2 times the estimated length. Dip both ends in the tin boiler. Measure the resistance in the wire which, depending on the wire length, should be under $100 \mathrm{~m} \Omega$. This indicates correct lead termination.
(b) Wind two cores of the same size with appropriate number of turns. Start with the largest one as it is the easiest to wind and test the other cores when the hardware is fully working. Keep in mind voltage/turn and isolation distance between different turns.
(c) Use a LCR meter to check that the inductance value of the wound inductors are correct. The values should correspond to the following values since there is no DC-bias.
i. $51 \mu \mathrm{H}$ for SH-090060, approximately 36 turns.
ii. $43 \mu \mathrm{H}$ for $\mathrm{SH}-080026$, approximately 58 turns.
iii. $45 \mu \mathrm{H}$ for SH-068026, approximately 51 turns.
(d) Cut excess litz wire and re-solder the leads and use hot glue to fix the ends of the wire. Check the resistance again to make sure that the new terminations are properly done.
3. Verification of 12 V auxiliary power supply
(a) Ohm meter TP1 (12 V), TP2 (5 V) and TP3 (3.3 V) to GND, should not be shorted.
(b) Connect 12 V through TP1 and GND using a current limited power supply.
(c) Measure 0 V at the gates of the boost switches, at start up. The voltage across C12 and C13 should be 12 V . Detach 12 V .
(d) Attach connector J1-J7,J9-J12 and J14. Also solder the diodes D8-D10.
(e) Connect heat sink fan and connect 12 V again. The fan should spin. Test both 12 V connectors.
(f) Attach 20 V , with an ampere meter in series, via test pins to one of the electrolytic capacitor pads. When 12 V is applied to U 1 output pads, the ampere meter should show 0 mA . When 12 V is absent, the current should be 1 mA , which flows through the $18,8 \mathrm{k} \Omega$ bleeder resistors.
(g) Ohm meter J4 and J5 should show OL.
(h) Solder U1.
(i) Connect J4 and J5 to mains and measure TP1 (12 V), should show 12V.
(j) Remove mains.
4. Verification of 3.3 V auxiliary power supply
(a) Connect a current limited power supply at the TP2 (5 V) and GND, use 4 V . Incrementally increase the power supply output to 5 V while measuring the voltage at TP3 (3.3 V), which should remain steady at 3.3 V.
(b) Mount U2.
(c) Attach mains.
(d) Measure TP3 (3.3 V), should show 3.3 V. Measure TP2 (5 V), should show 5 V .
(e) Turn on pin 3 on S1, D6 should light up.
(f) Remove mains.
5. Verification of 3.3 V analogue
(a) Attach mains.
(b) Measure 3.3 V at C 5 .
(c) Measure 96 mV at TP16 (Isense) and TP24 (IoutSense).
(d) Measure around 750 mV at TP26 (Temp). This indicates room temperature.
(e) Remove mains.
6. USB interface and basic DSP operation
(a) Solder J14, C71 and C72.
(b) Connect USB cable, D10 should light up.
(c) Measure U18 output voltage by measuring voltage across C57, should be 3.3 V .
(d) Connect mains to LV supplies.
(e) Program the FTDI chip to emulate the Texas Instruments XDS100v2 interface, using the Blackhawk Control Panel utility.
(f) Upload test firmware to the DSP, LEDblink.c - found in appendix D.2. Ensure that all DSP connected LEDs (D6-D9) can light up.
(g) Unplug USB cable and mains.
7. Verification of mains input
(a) Solder relay K1 and NTC R5. Connect mains to J4 and J5, relay should not short R5 and 50 Ohms should still be measured across it.
(b) Connect USB cable, set Rel_bypass pin high through DSP. The relay should click, 0 ohms should show over the NTC.
(c) Disconnect mains and USB connector.
(d) Solder F2, attach fuse cartridge. Solder R6, L2, C7 and C8.
(e) Ohm meter at J9 and J10. No short circuit.
(f) Use the jumpers to short J4-J6 and J5-J7. Also connect J10 to GND and a volt meter between VACS-L and GND.
(g) Short the NTC resistor R5 using alligator clips.
(h) Apply mains to J9 and J10. J9 should be connected to minus and J10 to plus.
(i) Volt meter on TP7 (VACS_L), which should show $492.6 \pm 9.8 \mathrm{mV}$.
(j) Upload the BoostControl program, from appendix D.1, with the PWM configs commented out, to the DSP. Use the expressions window to read the values. Check that VacL is reasonable.
(k) Disconnect the applied voltage.
(1) Swap the terminals J9 and J10, set the GND testpoint to J9.
(m) Volt meter on TP13 (VASC_N), which should show $492.6 \pm 9.8 \mathrm{mV}$.
(n) Run the boost test program again and check that VacN is reasonable.
(o) Read the Temp value on the DSP. Should show around room temperature.
(p) Disconnect all voltages.
8. Current and voltage measurement circuitry verification
(a) Solder L12. Ohm meter between TP5 and J12, should show slightly above $40 \mathrm{~m} \Omega$.
(b) Connect J12 to plus and TP5 to minus of a current limited (2 A) Power supply. Do not turn on, turn voltage knob to minimum. Attach a volt meter to TP16.
(c) Connect 230 V to J4 and J5, the voltage shown should be 96 mV . Ramp up the current, 1 amp should equal 200 mV increase.
(d) Check the Isense variable on the DSP so the read value is reasonable.
(e) Disconnect all voltages and move measuring equipment to TP24 and repeat the above steps from 8 .
(f) Disconnect all voltages.
(g) Connect the multimeter to TP25.
(h) Connect J11 to plus and J12 to minus of a 60 V power supply, use caution when ramping the voltage.
(i) Check that the values are reasonable and check corresponding Vout variable on the DSP.
(j) Disconnect all voltages.
9. PWM and overcurrent protection verification
(a) Activate both PWM outputs, synchronous but phase shifted 180 degrees, at $50 \%$ duty cycle. Read the signals at TP22 and TP23. Check that the signals behaves as expected. Measure also on the gates to verify that the PWM signals are propagating to the transistors.
(b) The overcurrent protection is tested by applying a low voltage to TP16. However, the circuit has a low resistive path to ground when doing so and therefore the protection must be set to a much lower voltage than usual. Set the DAC value to 155 , which corresponds to 0.5 V on the pin or 2.5 A through the sense resistor. Slowly ramp up the voltage to 0.5 V . The PWMs should turn off and remain off when the voltage is decreased. LED D9 should be illuminated.
(c) Reset the device and set the DAC value back to 639 .
(d) Apply a voltage at TP25. Slowly ramp up the voltage to 2.11 V , which correspond to a voltage of 425 V over the bulk capacitors. The overvoltage protection should trip the PWM outputs and remain off when the voltage is decreased. LED D9 should be illuminated.
10. Power (overcurrent and overvoltage protection must be implemented and controlled, inspect using thermal camera)
(a) Disconnect all cables.
(b) Solder bulk capacitors and boost inductors as well as any remaining components. Allow for probe connection on pin 2 of the inductor.
(c) Program DSP to output 50 kHz with $\mathrm{D}=0.20$ for one channel. The other channel should be off.
(d) Connect an oscilloscope to TP16 and GND using a voltage probe and a multimeter from TP25 to GND.
(e) Connect a electric load to J11 and J12 and set the resistance to $20 \Omega$, attach a power supply to J9 and J10.
(f) Connect LV-supplies.
(g) Ramp up the voltage to 32.5 V while watching the output voltage. There should now be 40 V at the output, CCM. The peak value of the input current should be around 5 A .
(h) Inspect the drain-source voltage of the switch by connecting a probe to pin 2 of the inductor and PGND at TP19.
(i) Inspect the gate voltage after the ferrite bead.
(j) Redo 10a-10i for the second channel.
(k) Incrementally increase the switching frequency and voltage in accordance with the following approach:
i. Voltage and switching frequency should be increased using Vin $=\mathrm{Kv}$ $* 32.5 \mathrm{~V}, \mathrm{D}=0.2=>$ Vout $=\mathrm{Kv} * 40.6 \mathrm{~V}$ and $f_{s w}=\mathrm{Kf} * 100 \mathrm{kHz}$. Kf and Kv are just constants to track progress and are between 1 and 10 .
ii. Keep $\mathrm{Kv}=1$, Rload $=40 \Omega$ and incrementally increase Kf until Kf $=10$ while measuring and saving Vds, Ids and Vgs. Redo for second channel.
iii. Set $\mathrm{Kf}=\mathrm{Kv}$ and incrementally step their value until $\mathrm{Kf}=\mathrm{Kv}=10$ while inspecting and saving the waveform data. Keeping $\mathrm{Kf}=\mathrm{Kv}$ BCM will be reached at a load current of $750 \mathrm{~mA} * 2=1.5 \mathrm{~A}$.
iv. Increase the load to 1 kW . Document the input power indicated by the voltage and input current.
(l) When 1 MHz operation with full load, duty cycle 0.2 , is verified, decrease the voltage and increase the duty cycle to about 0.425 . Increase the voltage and fine tune the duty cycle until an input current of 4.54 A , as used in calculation (3.5), is measured while maintaining the output voltage of 400 V and 1 kW load. The losses in the circuit should now be close to what is expected during low line AC operation and the efficiency can therefore be estimated. Measure the efficiency.
(m) Now it is possible to do other hardware measurements like current ripples and brown out withstanding.
11. To test and evaluate the Texas Instruments ILPFC software, refer to the ILPFC documentation [17].

## 1

## Results

### 4.1 Verification and assembly

The verification process began with testing the low voltage power supplies in accordance with verification specification task 1 in order to determine their lowest working voltage. The five volt supply was found to be able to fully function at an input voltage of 60 VDC . At a load of 3.93 W the output voltage is 4.69 V . As the calculated maximum power requirement at the five volt rail is 1.74 W the given 60 V input will be sufficient for use under testing.

At 60 V input the 12 V power supply works to satisfaction, where it can supply 4.2 W at 12.16 V . The 12 V supply does actually start to function earlier than the five volt supply, but since the 5 V supply sets the worst case input level, a supply voltage of 60 VDC is used.

The linear regulators did not initially perform as intended as they were oscillating heavily. The problem was solved by removing the bypass capacitors C2 and C45. The capacitors are not required for the LDOs to operate but should decrease any voltage ripple further. However, the requirements on the capacitors are very narrow and the malfunctioning behaviour was probably caused by too poor capacitors. Once the 3.3 V supply was operational, 95 mV was measured at IOUTSense and Isense while 760 mV was read at Temp. The measured values are close to the expected values and the part of the verification is therefore deemed passed.

The measured voltage at VACS_L is 492.6 mV when 60 V is applied as described in point 7 in the verification list. The measured voltage is within the accepted range and the input voltage circuits are therefore deemed to be working as intended.

### 4.2 PCB

The top side of the PCB is presented in figure 4.1 and a close up of the footprints for the boost stages is presented in figure 4.2. They are of special importance and the thermal vias are clearly shown. Images depicting the Gerber files of the copper
layers are found in appendix B.


Figure 4.1: Top side of the PCB.


Figure 4.2: Close up of crucial footprints.

The bottom side of the PCB, which is shown in figure 4.3, does not have a lot of footprints. Notice that the solder mask is removed where the heat sink will meet the PCB.


Figure 4.3: The bottom side of the PCB.

### 4.3 Final Assembly

The final PBA is presented in figure 4.4 and in figure 4.5 where the top and the bottom side of the PBA are shown respectively. All the used components and the schematics are found in appendix A and C.


Figure 4.4: Top side of the PBA.


Figure 4.5: Bottom side of the PBA.

### 4.4 Measurements and gathered data

### 4.4.1 Efficiency

The verification process of the switching capabilities is described in section 3.19 and the switching frequency and input voltage are increased accordingly. The final test utilizing a frequency of $1 \mathrm{MHz}, 400 \mathrm{~V}$ and 1 kW output with an input current of 4.54 A is the most interesting test and the measurement acquired is presented in this section.

The PBA is connected to two power supplies, an electronic load and a desktop computer. The input and output voltages and current can be read directly from the apparatus and the data are presented in table 4.1.

Table 4.1: Testing conditions during the final test

| $V_{\text {in }}$ | 229.0 V |
| :--- | :--- |
| $V_{\text {inLV }}$ | 61.0 V |
| $V_{\text {out }}$ | 400.3 V |
| $I_{\text {in }}$ | 4.61 A |
| $I_{\text {inLV }}$ | 0.075 A |
| $I_{\text {out }}$ | 2.50 A |
| $D$ | 0.375 |

The efficiency can be calculated to $94.5 \%$ given the data presented in the table. Since a DC power supply is used as input instead of the main grid, the efficiency presented is expected to go down by a small amount as there are no losses in the
bulk capacitors due to the absence of the 100 Hz ripple. The losses in the bulk capacitors are calculated to be another 4.7 W . Adding these extra losses to the efficiency calculation gives the final efficiency to drop to $94.1 \%$. This value is close to the expected $94.4 \%$ efficiency presented in table 3.5.

### 4.4.2 Switching speeds

A large portion of the total losses are switching losses and some effort has been made in order to investigate and predict these losses in order to design the PCB. The current fall and rise times are difficult to measure because of the design, but the voltage fall and rise times can be measured and compared to what the calculations yields. The times should be $t_{f v}=9.5 \mathrm{~ns}$ and $t_{r v}=11.7 \mathrm{~ns}$ using (2.36),(2.37), the method used in section 3.5.3 and given the driver configuration. The measured voltage waveforms are presented in figure 4.6 which shows $V_{V D S}$ for a couple of cycles. A zoom for the edges are shown as well in order to clearly depict the $10 \%$ and $90 \%$ times, which of course are used to find the rise and fall times of the voltage.

Inspection of the figure yields measured rise and fall times of $t_{f v M e a s u r e d}=49.5 \mathrm{~ns}-$ $43.2 \mathrm{~ns}=6.3 \mathrm{~ns}$ and $t_{\text {rvMeasured }}=59.1 \mathrm{~ns}-42.4 \mathrm{~ns}=16.7 \mathrm{~ns}$. To compare them with the calculated values, the theoretical times are multiplied with 0.8 since the $10 \%-90 \%$ method was used in the measurements, while the calculations are based on figure 2.10 and the corresponding mathematics.

Table 4.2: Measured and expected rise and fall times during switching

| Unit | Measured | Expected (compensated) |
| :--- | :--- | :--- |
| $V_{f v}$ | 6.3 ns | 7.6 ns |
| $V_{r v}$ | 16.7 ns | 9.3 ns |

The measured fall time is close to the expected value and deviates by $21 \%$. The expected result was that the real fall time would, if anything, be larger than calculated values because of the driver output resistances. Data regarding these resistances was given for a low output current, and the real values were therefore suspected to be higher.

The rise time on the other hand deviates by $80 \%$ and is longer than the expected value. Possible explanations are, again, uncertainties regarding the output resistances of the driver.

The switching behaviour is strongly dependent on the voltage across the gate. One more possible explanation for the deviating rise and fall times might be found by investigating the gate voltage waveforms. The waveforms are also interesting in order to investigate gate ringing.

The change in voltage across the gate of one of the MOSFET during one turn-on and turn-off cycle is shown in figure 4.7 together with $V_{D S}$. The measurement is


Figure 4.6: Boost MOSFET $V_{D S}$ with zoom on the edges.
done at an output voltage of 300 V because of probe limitations. The measurement was done as close as possible to the MOSFET, with the probe hat off and very short GND-loops using ground springs in order to minimize distortion because of
inductance to ground. The probing setup used is shown in figure 4.8 and 4.9 where the probing for measuring $V_{G S}$ and $V_{D S}$ are shown respectively.


Figure 4.7: $V_{G S}$ for one turn-on and turn-off event. The PWM is set high at time 12 ns and is then switched off after about 180 ns .


Figure 4.8: Probe setup for the $V_{G S}$ measurements depicted in figure 4.7.


Figure 4.9: Probe setup for the $V_{D S}$ measurements depicted in figure 4.7.

During turn-on, the gate voltage waveform looks like the used model, as figure 2.10. The Miller plateau is clearly visible. The fall time of $V_{D S}$ does however not correspond to the whole Miller plateau time, this is not a surprise as the $V_{D S}$ fall time can be divided into distinct times with different fall speeds as described in [1].

The gate voltage during the turn-off does not look like the model and can be the reason why the predictions regarding the rise time of $V_{D S}$ is off by $80 \%$. Why reality
deviates from the model is unclear and deemed to be outside the scope of the thesis but can be an interesting topic for another work.

Yet another important aspect of the switching is that the $\mathrm{dV} / \mathrm{dt}$ rating is not exceeded. The data points of the slopes presented in figure 4.6 can be analyzed for the purpose of investigating the $\mathrm{dV} / \mathrm{dt}$. The data set consists of 2500 data points which is divided into 100 sections. In each section, the $\mathrm{dV} / \mathrm{dt}$ is estimated as the difference between the starting and end voltage of the section, divided by the time step. The acquired data are plotted against the slopes as orange stars in figure 4.10.


Figure 4.10: Visualization of $d V_{D S} / d t$ during both on and off switching.

Because of the low resolution of the measured drain source voltage along with too few data points of the set, the results are quite noisy but are still deemed useful for the $\mathrm{dV} / \mathrm{dt}$ inspection. Upon studying the figure one quickly realizes that there is room for improving the cross over times and therefore the efficiency since the maximum measured $\mathrm{dV} / \mathrm{dt}$ is below $30 \mathrm{~V} / \mathrm{ns}$ at turn-off while the maximum allowed is $100 \mathrm{~V} / \mathrm{ns}$. This can be done by modifying the gate driver circuitry by changing the gate resistance or the gate ferrite. One might also increase the gate driver voltage but this would only shorten the fall time, which already is quick.

Another observation that can be made by inspecting figure 4.6 and figure 4.10 is that there is little to no overvoltage at turn-off. This is not true. Overvoltages, some 30 V at 300 V out, shows up in measurement 4.7 as the slow differential probe
was not used for this measurement. As the faster probe cannot measure 400 V the same measurements cannot be made for the 400 V case.

### 4.4.3 Current measurements to find inductance value

The boost inductors are shown mounted on the PCB in figure 4.4. They are the toroidal inductors in the middle of the PCB, not be be mistaken for the common mode chokes located at the edges of the PCB. Their common current are measured as a voltage at the test point named ISense and is depicted in figure 4.7.


Figure 4.11: Current through both boost inductors during 1 MHz switching frequency, measured at ISense test point.

The signal is noisy even though measures to minimize the GND loop of the probe using ground springs are made. The data are intended to be used for boost inductance verification. Processing of this data yields unexpectedly large inductance values of $\sim 100 \mu \mathrm{H}$. The measurement is therefore deemed invalid and the probable cause is that the signal from ISense is a filtered signal with a cut off frequency of 2 MHz which is the same as the fundamental frequency of the ripple. The peaks of the inductor current is therefore not truthfully shown.

Since the measurement of the inductor current via the ISense test point does not yield good data, another measurement needs to be conducted. The current can be measured using a Rogowski coil clamped around one leg of an inductor. The coil was positioned as far away from the switches as possible as they generate high $\mathrm{dV} / \mathrm{dt}$ which interferes with the measurement [31]. The sensitivity of the Rogowski coils is $20 \mathrm{mV} / \mathrm{A}$ and the resulting current in the inductor is depicted in blue in figure 4.12.

The parameters during the test is: Input voltage 232 V , input current 4.5 A , output voltage 412 V . The Rogowski coil does not measure DC, which is why the current is


Figure 4.12: Current through one inductor during 1 MHz switching frequency, measured using a Rogowski coil.
centered around zero. As shown by the figure the measurement is quite noisy and there are four large spikes at times $\sim 0,0.45,1$ and $1.45 \mu \mathrm{~s}$. These spikes occur at the peak of the expected triangle wave, which is at the same time as the MOSFET switches. The spikes are therefore deemed to be measurement errors. In order to find the slope, which will yield the inductance, a first order approximation using the least square method of the data points between the dashed black lines is made. The resulting slope is shown in red. The slope is $4.5 \mathrm{~A} / \mu \mathrm{s}$ which gives an inductance of $\frac{232 V}{4.5 \mathrm{~A} / \mu s} \approx 52 \mu \mathrm{H}$ which deviates from the intended $35 \mu H$. The inductance is about $50 \%$ higher than designed value. This was not unexpected given the relatively simple hand calculations based on worst case scenarios, measurement errors and that "off the shelf" industrial manufactured inductors often specifies inductance deviations of $20 \%$.

### 4.4.4 Device temperatures under load

The temperatures of the PBA was inspected using a thermal camera. The temperatures settles after about 15 minutes and a thermal image focusing on the inductors are shown in figure 4.13 which was captured after 15 minutes of supplying a 1 kW load.

It was difficult to get a good picture of both the inductors and the switches so a thermal close up of the switches are shown in figure 4.14. This image is also captured after about 15 minutes.


Figure 4.13: Thermal image of the PBA during $\mathrm{Kf}=\mathrm{Kv}=10$ with focus on the boost inductors, maximum inductor temperature indicated.


Figure 4.14: Thermal close up image of the switches during $\mathrm{Kf}=\mathrm{Kv}=10$, with maximum transistor casing temperature indicated.

### 4.4.5 Hold up time

The hold up time is measured by investigating the output voltage of the step-up converter using an oscilloscope. The electronic load connected to the output is set to consume a constant power. To simulate a voltage interruption, the power supply is simply turned off. The fall in output voltage is presented in figure 4.15 where the times corresponding to 400 V and 300 V are indicated. The hold up time is the difference between $t_{400}$ and $t_{300}$ and is equal to 22.8 ms , thus greater than the
requirement of 20 ms .


Figure 4.15: Measurement of the output voltage at disconnection of the power supply.

### 4.5 Outcomes versus requirements

The final comparison between the specifications of requirements and final results is presented in table 4.3.

Table 4.3: Presentation of the specifications and the results of the design process

| Requirement | Result | Pass/Fail | Verification method |
| :---: | :---: | :---: | :---: |
| $f_{\text {sw }}=1 \mathrm{MHz}$ | 1 MHz | Pass | Measured |
| 1 kW output power | 1 kW | Pass | Measured |
| $96 \%$ efficiency | $94.1 \%$ | Fail | Measured <br> calculated |
| 400 VDC output | 400 VDC | Pass | Measured |
| 230 VAC input | - | - | Not tested |
| Generic connectors | Safety banana plugs <br> C14 plug <br> USB mini-B | Pass | Design |
| Air cooled design | Air cooled | Pass | Design |
| 20 ms hold up time | 22.8 ms | Pass | Measured |

## 5

## Discussion

This thesis was performed in order to investigate if it was possible to design a high frequency two channel interleaved step-up converter intended for PFC applications. The method used to answer this research question was to make calculations on relevant power components, and to design and build a PCB for physical testing and verification.

The key results of the study is that it is possible to design a device intended for PFC that utilizes a very high switching frequency using commercially available components whilst maintaining a sensible efficiency, even though it was lower than the initial goal.

This was made possible partly because the MOSFETs used were the best found at the time and also because the boost inductors were custom designed. As discussed before, the boost inductors can be made smaller with a higher switching frequency. A volume comparison can be made with a design example from Infineon [8] where they design an inductor for a single channel 1.2 kW PFC with generic input operating at a switching frequency of 100 kHz . The cores chosen for the design example are two toroids stacked together with 61 turns of copper wire. The total iron volume of their inductor can be calculated to $27 \mathrm{~cm}^{3}$. Given the data regarding the diameter of copper wire used and the DC resistance, the volume of the copper wire can be calculated to $4.5 \mathrm{~cm}^{3}$ which means that the their total inductor material volume is $31.5 \mathrm{~cm}^{3}$. The total material volume for the inductors used in this design is $3 \mathrm{~cm}^{3}$ which brings the total inductor volume to $6 \mathrm{~cm}^{3}$.

The step-up converter with all its peripherals has only been investigated using a DC-power supply as input while driving a resistive load. This puts limitations on the study as the PFC capabilities has not been tested. The behavior of the device whilst supplying different inductive and capacitive loads is also unknown as these measurements has not been made.

The step-up converter did not meet the efficiency specified, however this was expected based on the calculations. It might be possible to reduce the losses in the MOSFETs, which in this device is the main source of the losses, by tinkering with the gate driver resistor, ferrite and voltage in order to decrease the cross over times. This should be possible based on the measured $d V_{D S} / d t$.

It should also be possible to decrease the losses in the inductors by constructing and testing the smaller inductors that have been designed but not yet constructed. The inductor size was determined by a designing ripple amplitude of $20 \%$. The ripple allowed could be higher and inductors corresponding to for example $40 \%$ ripple could be made in order to make them even smaller.

In order to investigate the performance of the circuit as a PFC, the software must be implemented. This is an important aspect that has to be done in order to investigate the circuit when it uses 230 VAC as input. Future relevant implementations also includes making the device able to run on a generic input i.e $110 \mathrm{VAC} 60 \mathrm{~Hz} / 230$ VAC 50 Hz .

No EMI measurements has been conducted. The assumption, because of the nature of the circuit operation, is that the circuit will not conform to limiting standards and it is very possible that EMI suppression has to be improved.

Future research regarding the switching wave forms of the MOSFET needs to be pursued in order to understand why the gate voltage and corresponding cross over time at turn-off deviates from the models used.

## 6

## Conclusion

The purpose of this thesis was to build a high frequency dual channel step-up converter intended for PFC applications. The aim was to reach a switching frequency of 1 MHz while maintaining $96 \%$ efficiency supplying a output power of 1 kW at a voltage of 400 V using single phase 230 VAC input. The developed prototype is able to supply 1 kW at a voltage of above 400 V using 1 MHz switching frequency, but the efficiency drops to $94.5 \%$. The input used during the tests was 230 VDC as the control needs to be implemented before grid operation. During grid operation the efficiency is calculated to drop to $94.1 \%$. As the $\mathrm{dV} / \mathrm{dt}$ measurements indicates that faster switching may be possible, the losses can probably therefore be reduced to try to bring the efficiency closer to the goal. Winding and implementation of the smallest designed inductor saves another calculated 1 W . Implications, given the possibility of higher switching frequency, is that future designs may be built using smaller boost inductors and smaller filters. The consequence of this is probably cheaper filters and boost inductors, and maybe also that the PFC weighs less and takes up less space. Given that PFC are used in conjunction with loads, smaller PFC circuits might by extension lead to less bulky power tools using DC, smaller power supplies etc.

### 6.1 Future work

The device developed is a prototype and some further work is needed before it can be used as a PFC. There are also work to be done tweaking the circuit for higher efficiency and some tests, such as EMI measurements, that are of interest. A small bullet list of future steps regarding future work is therefore presented.

- Tweak the gate resistance and ferrite in order to fully utilize the high dv/dt rating of the switches and implement the smaller inductors to reduce losses.
- Perform EMI measurements and verify against regulations.
- Design equipment to control the air flow from existing fan in order to cool warm components.
- Finish the software and investigate the PFC performance.


## Bibliography

[1] N. Mohan, T. M. Undeland, and W. P. Robbins, Power electronics. John Wiley \& Sons, 1 ed., 2003.
[2] C. Wang, M. Xu, B. Lu, and F. Lee, New Architecture for MHz Switching Frequency PFC. Center for Power Electronics Systems Virginia Polytechnic Institute and State University, 2008.
[3] Michael O'Loughlin, "Ucc28070 300-w interleaved pfc pre-regulator design review." http://www.ti.com/lit/an/slua479b/slua479b.pdf, 2008. Online; accessed 2017-05-17.
[4] Magnetics, "Powder cores." https://www.mag-inc.com/Media/Magnetics/ File-Library/Product\%20Literature/Powder\%20Core\%20Literature/ 2015-Magnetics-Powder-Core-Catalog.pdf?ext=.pdf, 2015. Online; accessed 2017-02-13.
[5] Magnetics, "Magnetic cores for switching power supplies." https://www. mag-inc.com/Media/Magnetics/File-Library/Product\ Literature/ General\%20Information/ps-01.pdf?ext=.pdf, 1999. Online; accessed 2017-02-10.
[6] Elfa AB, "Faktasidor." http://www.ee.kau.se/utbildning/OrCAD/ faktasidor_ELFA.pdf, 2007. Online; accessed 2017-02-14.
[7] Jeff Falin, "Minimizing ringing at the switch node of a boost converter." http: //www.ti.com/lit/an/slva255/slva255.pdf, 2006. Online; accessed 2017-05-18.
[8] S. Abdel-Rahman, F. Stückler, and K. Siu, PFC boost converter design guide. Infineon Technologies AG, 1 ed., 2016.
[9] Mark Dennis, "An-6069 applicatin review and comparative evaluation of lowside gate drivers." https://www.fairchildsemi.com/application-notes/ AN/AN-6069.pdf, 2007. Online; accessed 2017-05-18.
[10] W. Choi, S. Dong-kook and M. Hallenberger, "An-9005 driving and layout design for fast switching super-junction mosfets." https://www.fairchildsemi.
com/application-notes/AN/AN-9005.pdf, 2013. Online; accessed 2017-0518.
[11] P. Haaf and J. Harper, "Understanding diode reverse recovery and its effect on switching losses." https://www.fairchildsemi.com/technical-articles/ Understanding-Diode-Reverse-Recovery-and-Its-Effect-on-Switching-Losses. pdf. Online; accessed 2017-01-27.
[12] F.-Y. Shih, D. Y. Chen, Y.-P. Wu, and Y.-T. Chen, "A procedure for designing emi filters for ac line applications," IEEE Transactions on Power Electronics, vol. 11, pp. 170-181, Jan 1996.
[13] Kemnet, "X and y capacitors." http://www.kemet.com/Lists/Filestore/ EvoxRifaRFIandSMD.pdf, 2007. Online; accessed 2017-05-18.
[14] Kemnet, "900 series safety disc capacitors." http://www.kemet.com/Lists/ FileStore/900\%20Series\%20Product\%20Training\%20Module.pdf. Online; accessed 2017-05-18.
[15] Alan Martin et.al , "Capacitor selection for dc/dc converters: what you need to know to prevent early failiures, and reduce switching noise." http://www.kemet.com/Lists/TechnicalArticles/Attachments/5/ Avnet2012PowerForum_CapacitorsSelection.pdf. Online; accessed 2017-0522.
[16] Murata, "Ceramic capacitors faq." http://www.murata.com/en-us/support/ faqs/products/capacitor/mlcc/char/0012. Online; accessed 2017-05-22.
[17] Texas Instruments, "Digitally controlled, 2-phase interleaved power factor correction (ilpfc) converter using c2000 piccolo-a microcontroller." http://www. ti.com/lit/ug/sprui55/sprui55.pdf. Online; accessed 2017-05-19.
[18] Schaffner EMV AG, "Leakage currents in power line filters." www.astat. com.pl/download.php?file=pliki/schaffner_dt_an10_gb.pdf. Online; accessed 2017-05-22.
[19] Magnetics, "Amoflux." https://www.mag-inc.com/ getattachment/Products/Powder-Cores/AmoFlux-Cores/ Learn-More-About-AmoFlux-Cores/Magnetics-AmoFlux-Bulletin.pdf? lang=en-US. Online; accessed 2017-02-10.
[20] Micrometals, "High frequency sendust datasheets." http:// www.micrometalsarnoldpowdercores.com/products/materials/ sendust-high-frequency. Online; accessed 2017-04-12.
[21] Z. Z. Ye and M. M. Jovanovic, "Implementation and performance evaluation of dsp-based control for constant-frequency discontinuous-conduction-mode boost pfc front end," IEEE Transactions on Industrial Electronics, vol. 52, no. 1,
pp. 98-107, 2005.
[22] Illinois capacitor, Inc., "Impedance, dissipation factor and esr." http: //www.illinoiscapacitor.com/pdf/papers/impendance_dissipation_ factor_esr.pdf. Online; accessed 2017-01-23.
[23] Jeff Falin, "Esr, stability, and the ldo regulator." http://www.ti.com/lit/an/ slva115/slva115.pdf. Online; accessed 2017-05-23.
[24] Texas Instruments, "Tms320f2803x piccolo ${ }^{\mathrm{TM}}$ microcontrollers." http://www. ti.com/lit/ds/sprs584k/sprs584k.pdf. Online; accessed 2017-05-23.
[25] Texas Instruments, "Tms320x2802x, 2803x piccolo high resolution pulse width modulator (hrpwm)." http://www.ti.com/lit/ug/spruge8e/spruge8e.pdf. Online; accessed 2017-05-23.
[26] Texas Instruments, "Tms320x2802x, 2803x piccolo analog-to-digital converter (adc) and comparator." http://www.ti.com/lit/ug/spruge5f/spruge5f. pdf. Online; accessed 2017-05-23.
[27] Texas Instruments, "Tms320x2802x, 2803x piccolo enhanced pulse width modulator (epwm) module." http://www.ti.com/lit/ug/spruge9e/spruge9e. pdf. Online; accessed 2017-05-23.
[28] Infineon, "An_201605_pl52_019." http://www.infineon.com/dgdl/ Infineon-ApplicationNote_650V_CoolMOS_C7_Gold_TOLeadless. pdf-AN-v01_01-EN.pdf?fileId=5546d46253f65057015495adbf15197d. Online; accessed 2017-05-23.
[29] D. Rutter, "Cpu coolers compared!!" http://www.dansdata.com/coolercomp. htm. Online; accessed 2017-05-23.
[30] P. Magnusson and G. Karlström, "Avkoppla rätt." http://axotron.se/ articles/decoupling/Avkoppling_100524.pdf. Online; accessed 2017-0523.
[31] C. Hewson and W. R. Ray, "The effect of electrostatic screening of rogowski coils designed for wide-bandwidth current measurement in power electronic applications," in 2004 IEEE 35th Annual Power Electronics Specialists Conference (IEEE Cat. No.04CH37551), vol. 2, pp. 1143-1148 Vol.2, June 2004.


Circuit schematic


|  | $\begin{array}{r} \text { customer } \\ \text { istex } \end{array}$ | $\underset{A}{\text { Rev. }}$ | Page $1 / 5$ | Designed by CAER |
| :---: | :---: | :---: | :---: | :---: |
|  | Project Digital Active PFC |  |  |  |
|  | Board name | Date |  | $\begin{array}{\|l} \text { Approved by } \\ \text { KRBE } \end{array}$ |
|  | PBA1597 | 2017-04-10 |  |  |
| Page tite | Customer part number | Doc. no. |  |  |
| MainOverview.SchDoc | PBA1597 | SCH_PBA1597 |  |  |







## PCB layout

The four PCB layers are shown from top to bottom along with the assembly drawings.






|  |  |  | A | CAER |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |
|  |  | Board name | 2017-04-10 | KRBE |
| Printed 2017-05-11 08:51:04 | SCALE: 1.00 | PBA1597 | 2017-04-10 |  |
| ${ }^{\text {THUE }}$ Top Assembly Drawing |  | Customer part number <br> PBA1597 | Doc. no. <br> AD PBA15 |  |



## i3tex

## C

## Bill of Materials

| Bill of materials |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Project: <br> PBA: <br> Doc. Number: <br> Revision: <br> Date: | Digital Active PFC |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  | PBA1597 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  | BOM_PBA1597 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  | A |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  | 2017-04-24 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  | Descripition | Value | Ratiogs |  |  |  |  | Manuractur | Part Number | Mounting | Supplier 1 |  |  |
|  | thange | Designator | auantiy |  |  | Tolerance | Voliage | Dialactic | Temperatur range |  |  |  |  |  | Supplier Part Number 1 | Note |
|  | Y | C1, C33, C34, C36, C37, C38, C40, C41, | 13 |  | 100p | 5\% | $1{ }^{16 \mathrm{~V}}$ | COG, NPO |  | P402 |  |  | SMD |  |  |  |
|  | Y | C2, 44 | 2 |  | $1{ }^{10 n}$ | 5\% | $1{ }^{162}$ | COG, NPO |  | 1063 |  |  | SMD |  |  |  |
|  | r | ${ }^{\text {C3, C4, C5, C49, C51, , 56, }}$, $57, \mathrm{C60}$ | 8 |  | 4.70 | 10\% | ${ }^{25 V}$ | X7R |  | 1206 |  |  | SMD |  |  |  |
|  | Y | C6, C9, C14, C74 | 4 | Cap, safely, Y2, ceramic, SMD, 22200(5750) | 4.7n | 10\% | $2{ }^{250 V A C}$ | X7R |  | 2220(5750) | Murata | GA3550R76F472KW0 | SMD | Dig-key | 900-3882-1.ND |  |
|  | Y | C7, $88, \mathrm{C73}$ | 3 | Film capacitor, metallized polypropylene, $\chi_{2}$, | 0.33u | 10\% | ${ }^{\text {310VVAC }}$ | Metalized |  | Radial 12.5mm pith | Wurth | 890334024003 | ${ }_{\text {THT }}$ | Dig-key | ${ }^{\text {732-5339-ND }}$ |  |
|  | r | C10, C11, C61, C65, C75 | 5 | CAP CER 3900PF 50V X7R 0402 | 3.9n | 10\% | 25 V | X7R |  | 0402 |  |  | SMD |  |  |  |
|  | Y | C12, C13 | 2 |  | 100 | 10\% | 25V | XR |  | 1206 |  |  | SMD |  |  |  |
|  | Y | C15, C16, C21, C35, C62, C78 | 6 |  | ${ }^{220 n}$ | 10\% | 16 V | X ${ }^{\text {R }}$ |  | 10402 |  |  | SMD |  |  |  |
|  | Y | C17, C18, C19, C22, C23, C24, C25, C77, | 9 |  | ${ }^{2.24}$ | 10\% | 10 V | X ${ }^{\text {R }}$ |  | 10603 |  |  | SMD |  |  |  |
|  | Y | C20, C39, C43, C44, C46, C47, c48, C50, | ${ }^{17}$ |  | 1000 | 10\% | ${ }^{16 \mathrm{~V}}$ | X7R |  | 10402 |  |  | SMD |  |  |  |
|  | Y | C26, C27, C28, C29 | 4 | Electroytic cap, 180uF. 450V, diam 18mm, | ${ }^{1804}$ | 20\% | 450V | Aluminum |  | Radial, 7.5mm | Nichicon | UCP2W181MHD | THT | Dig-key | ${ }^{493-13663-\mathrm{NO}}$ |  |
|  | Y | C30 | 1 | Cap, ceramic, high voltage, XTT, 630 V , stacked | 14 | 20\% | 1630 V | XTT |  | 2220(5650) | TOK | CK657NXTT2105M50 | SMD | Dig-Key | 445-7110-1-ND |  |
|  | Y | C31, ${ }^{\text {c32 }}$ | 2 | Cap, ceramic, high voltage, XTT, 630V | 4700 | 20\% | ${ }^{630 \mathrm{~V}}$ | X7T |  | 2220(5650) | TоК | CK657\%X7T2 4774 M 33 |  | Dig-Key | ${ }^{445-7104}$-1-ND |  |
|  | Y | c69, C70 | 2 | CAP CER 30PF 50V NPO 0603 | 30p | 5\% | 25 V | COG, NPO |  | 0603 |  |  | SMD |  |  |  |
|  | Y | C77, ${ }^{\text {c72 }}$ | 2 | Ceramic disc capacatior, 220pF, X760 | ${ }^{220 p}$ | 10\% | ${ }^{760 \mathrm{VAC}}$ | Y5s |  | Radial, Disc | Vishay | WY1221 K31 Y5S663V0 | THT | Dig-key | BC2370-NO |  |
|  | Y | 01 | 1 | Schotity Diode, 400, 3A, SMA, SMD | MBRA34073G |  |  |  |  | SMA | On Semiconductor | MBRA34073G | SMD | Dig-Key | MBRA34073GOSTR-ND |  |
|  | Y | D2, D3 | 2 | Schothy Diode, dualininine , 200mA, 30V, | BAT54S |  |  |  |  | SOT-23 | Fararchid | BAT54S | SMD | Dig-key | BAT54SFSCT-ND |  |
|  | Y | D4, D5 | 2 | DIODE SCHOTTKY 6500 3A TO252-2 | ${ }^{\text {c30303065E }}$ |  |  |  |  | TO-235-2_VIAS | CREE | C3003065E | SMD | Dig-Key | C3030665E-ND |  |
| 1 | Y | D6, 07, D8, 09, D10 | 5 | LED 3 mm | 3 mm |  |  |  |  | 3 mm |  | 3 mm | THT |  |  |  |
|  | Y | 011 | 1 | Zener diode, 10V, 0.5 SW | MMSZ2240B |  |  |  |  | SOD-123 | Farchild | MMS25240B | SMD | Dig-key | MMSZ25240BFSCT-ND |  |
|  | r | F2 | 1 | FUSE BLOK CARTRIDEE 250V 10 A PCB |  |  |  |  |  |  | Lituefuse inc. | 65600001009 | THT | Dig.-Key | WK624-ND |  |
|  | Y | FB1, FB3, FE4, F85, FB7, FB8, F89, FB10 | ${ }^{8}$ | Ferrite bead, 330 ohm@100MHz, 500 mA , | 330 |  |  |  |  | 0603 | Murata | BLM 8 EG331TN1D | SMD | Dig-key | ${ }^{490-5913-1 / N D}$ |  |
|  | Y | FB2, FB6 | 2 | Ferrit bead inductor | 1200hm@ |  |  |  |  | 1063 | Murata | BLM18KG121TH1D | SMD | Dig-Key | 490-13261-1-ND |  |
|  | Y | HS1 | 1 | CPU cooler NHLTO |  |  |  |  |  |  | NOCTUA | NHLL9 |  |  |  |  |
| 2 | Y | ${ }^{11,32, ~} 3$ | 3 | Standard 4-pin processor fan coonector |  |  |  |  |  |  | ${ }^{\text {Molex }}$ | 47053-1000 | THT | Dig-Key | WM4330-ND |  |
|  | Y | J4, J5, J6, J7, 99, J10, J11, J12 | 8 | Tab, FASTON, 6.35 Sx 0.81 mm , with sodder | ${ }^{12178661-1}$ |  |  |  |  | Custom | TE | 1217861-1 | THT | Dig-rey | A100452CT-ND |  |
| ${ }^{2}$ | Y | ग4 | 1 | USB minit tye B, trough-hole, vericical | 651005136421 |  |  |  |  | Custom |  | 651005136221 | THT | Farnell | 184175 |  |
|  | r | K1 | 1 | RELAY GEN PURPOSE SPST 10A 12 V | P8134012 |  |  |  |  |  | TE Comectivit Poter | PB134012 | THT | Dig-Key | PB768-ND |  |
|  | Y | L2, L12 | 2 | n 7 mH @ 10kHz 2 Line Common Mode Choke | 7448040707 |  |  |  |  | Custom | Würh | 7488040707 | THT | Dig.key | 732-5889-ND |  |
| ${ }^{3}$ | Y | ${ }^{\text {L3, L4 }}$ | 2 | 2 PPILLPFC Inductor 1 , Master thesis iogtal | ${ }^{354}$ |  |  |  |  |  |  | 2 2PHLPFC_INOUCTO |  |  |  |  |
| 3 | r | ${ }^{10}$ | 1 | SMD common mode choke | 900hm |  |  |  |  | Dual 1206 | Würh | 744232990 | SMD | Digi-Key | ${ }^{732-1469-1-N D}$ |  |
| 3 | Y | ${ }^{\text {a1 }}$ | 1 | BJT NPN 80V 0.5A Sot-23 |  |  |  |  | -5510+150C | SOT23 | Farchild | MMBTAO6 | SMD | Digi-key | MMBTAO6FSCTT-ND |  |
|  | Y | Q2, Q3 | 2 | MOSFET N-Channel, 650V, 14 A A 195 mohm | \|1PT65R19567 |  |  |  | -55-+150 | TOLL | Infineon | \|PT656R19567 | SMD | Mouser | 726-1PT65R19567xTMA1 | C7 CoolMos Gold eation |
| ${ }^{3}$ | Y | ${ }^{\text {a }}$ | 1 | MOSFET N-channel, $600 \mathrm{~V}, 2$ 20mA ${ }_{\text {, }}$ | STSTNK60Z |  |  |  | -5510 150 | Solc-8 | ST | STSTNK60Z | SMD | Dig-key | 497-12798-1-ND |  |
|  | Y | Q5 | 1 | MOSFET N-Channel, $60 \mathrm{~V}, 115 \mathrm{~mA}$, 1.70hm | 2 2N002 |  |  |  | $-5510150^{\circ} \mathrm{C}$ | SOT-23 | Farchild | 2N7002 | SMD | Dig-Key | 2NTOO2NTR-ND |  |
| ${ }^{3}$ | Y | R1, R15 | 2 | Resistor | 15 | 1\% | 50 V |  |  | 10603 |  |  | SMD |  |  |  |
|  | Y | R2, R49, R50, R61 | 4 | Thick film, 1 kohm, $50 \mathrm{~V}, 0402,62.5 \mathrm{~mW}, \pm 1 \%$ |  | 1\% | 50V |  |  | 10402 |  |  | SMD |  |  |  |
| ${ }^{\text {a }}$ | Y | R3, R7, R8, R10, R11, R44 | 6 | Resistor | ${ }^{432 \mathrm{k}}$ | 1\% | 500 V |  |  | 1206 |  |  | SMD |  |  |  |
|  | Y | R4, R17, R20, R21, R27, R47, R48, R52, | 10 | Resisior | 10k | 1\% | 50 V |  |  | 10402 |  |  | SMD |  |  |  |
|  | Y | R5 | 1 |  | SL2250004 | +20\% |  |  |  | Disc 2387 mm | Amethem |  | THT | Dig-key | 570-1051-NO |  |
| 4 | r | R6 | 1 | Metal Oxide Varistor (MOV), disct type, 12 mm | B7221050271 10 |  |  |  |  |  | TOK | B72210S027 1 K101 | THT | Dig-Key | ${ }^{\text {495-3786-ND }}$ |  |
|  |  | R9, R12 | 2 | Resistor | ${ }^{7} 115 \mathrm{Kk}$ | 1\% | 50 V |  |  | 10402 |  |  | SMD |  |  |  |
| 4 | Y | R13, R16, R58, R60 | 4 | Resisior | $1{ }^{19}$ | 1\% | 500 V |  |  | 1206 |  |  | SMD |  |  |  |
|  | Y | R14, R18, R19, R29, R30, R31, , 332, R33, | 10 | Resistor | 10 | 1\% | 50 V |  |  | 0402 |  |  | SMD |  |  |  |
| 4 | Y | R22, R62 | 2 | Current sense resisior, 2pin, 0830 (2075), 2W, | ${ }^{20 \mathrm{~m}}$ | 1\% |  |  |  | 0830 (2075) | Susumu | RL7520WT-R020-F | SMD | Dig-rey | RL75WT.02FCT-ND |  |
|  | Y | R23, R26, R41, , 42, R63, R66 | 6 | Resistor | ${ }^{787}$ | 0.1\% | 25 V |  |  | 0603 |  |  | SMD |  |  |  |
| 4 | Y | R24, R25, R64, R65 | 4 | Resisior | ${ }^{46.4}$ | 0.1\% | 25V |  |  | 0603 |  |  | SMD |  |  |  |
|  | Y | R28, R68 | 2 | Resistor | 300 | 1\% | 25 V |  |  | 1063 |  |  | SMD |  |  |  |
| 4 | Y | R33, R40, R43, ,45, ${ }^{\text {R } 54}$ | 5 | ${ }_{\text {Resistor }}$ | ${ }^{2.22}$ | 1\% | $\frac{50 \mathrm{~V}}{5}$ |  |  | 0402 |  |  | SMD |  |  |  |
|  | Y | R36, R37, R38, R39, R46 | 5 | Resistor | ${ }^{47}$ | 1\% | ${ }^{25 \mathrm{~V}}$ |  |  | 0603 |  |  | SMD |  |  |  |
| 5 | Y | ${ }^{\text {R51 }}$ |  | Resistor | ${ }^{12 \mathrm{k}}$ | 0.1\% | ${ }^{255}$ |  |  | 0402 |  |  | ${ }_{\text {SMD }}$ |  |  |  |
|  | Y | R55, R56, R57, R59 | ${ }^{4}$ | Ressisor | ${ }^{4.7 \mathrm{k}}$ | 5\% | 250 V |  |  | 2512 |  |  | SMD |  |  |  |
|  | Y | ${ }^{\text {S1 }}$ | 22 | Swich, DIP, 4 positions, 1.27 mmp plich, top | ${ }^{218}$ |  |  |  |  |  | cTs | ${ }^{218.4 L P S T}$ | $\frac{\text { SSDD }}{\text { SHHT }}$ | Dig-Key | CT2184LPST-ND |  |
| ${ }_{5}^{5}$ | Y | ${ }^{\text {TP1, }{ }^{\text {TP6, TP9 }} \text {, TP3, TP4, TP5, TP7, TP8, TP10, }}$ | $\frac{22}{2}$ |  | ${ }^{\text {TP }}$ [mTPRing |  |  |  |  |  |  | ${ }_{\text {5mmTPRing }}$ | $\frac{\mathrm{THT}}{\mathrm{THT}}$ |  |  |  |
| ${ }_{5}$ | $\bigcirc$ | ${ }^{\text {P1 }}$ | 1 | ${ }^{\text {ACITDC Converter, }}$ | ${ }^{5 m m(T-214-005-112}$ |  |  |  |  | \|VT-214-4P/N | \|Vigortonix | ${ }_{\text {VTXX-214-005-112 }}$ | ${ }_{\text {THT }}$ | Farmell | ${ }^{2401044}$ | Altemative part Myra 47154 |



| Change |  |
| :---: | :---: |
| $\mathbf{X}$ | Changed in this revision |
| Y | Added in this sevision |
| $Z$ | Adeleted in this revision |



Bill of Material
Project Name: Digital Active PFC
Document Name: BOM-DEV1406
Date: 2017-04-20
Rev: PA1

| $\begin{gathered} \text { Chang } \\ \text { es } \end{gathered}$ | pos | Amount | Article no. | Description | Manufacturing no | Manufacturer | Distributor | Distributor no | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Y | 1 | 1 | PBA1597_R1A | Main board |  | i3tex |  |  |  |
| Y | 2 | 1 |  | Enclosure | RM2095L | Hammond | Digi-Key | HM1101-ND |  |
| Y | 3 | 1 |  | Flush mounted C14 | 6162.0058 | Schurter | Effa | 143-49-923 |  |
| Y | 4 | 1 |  | Thermal pad | HF300P-0.0015-00-4/4 | Bergquist | Farnell | 8783683 |  |
| Y | 5 | 1 |  | 4 mm banana safety jack, black | CT2238-0 | Cal Test Electronics | Digi-Key | BKCT2238-0-ND |  |
| Y | 6 | 1 |  | 4 mm banana safety jack, red | CT2238-2 | Cal Test Electronics | Digi-Key | BKCT2238-2-ND |  |
| Y | 7 | 12 |  | FASTON female crimp connector | 3-350819-2 | TE Connectivity AMP | Digi-Key | A27824CT-ND | Order a few more for spare and verification |
| Y | 8 | 1 |  | Mains cable, Schuko - C13 | SP-230-06-S | Maxxtro | Elfa | 143-52-591 | Order one extra for verification |
| Y | 9 | 4 |  | Bumper | SJ-5514 (BLACK) | 3M | Digi-Key | SJ5514-O-ND |  |
| Y | 10 | 1 |  | Litz wire | CLI 200/60 | Block | Elfa | 155-16-547 | For inductor manufacturing |
| Y | 11 | 2 |  | Inductor core, Sendust HF |  | Micrometals | Micrometals |  | Part number TBD |
| Y | 12 | 6 |  | Slot screw, M3, 60 mm | BN 330SLOT 4,8 M3X60MM | Bossard | Elfa | 110-76-331 | PCB fastening and support |
| Y | 13 | 15 |  | Nut, M3 | M6MS M3 / CLL629 MUTTER A4 | Bossard | Elfa | 148-00-081 |  |
| Y | 14 | 32 |  | Plain washer, plastic, $3,2 \mathrm{~mm}$ | 003030500001 | Richco | Elfa | 148-49-246 |  |
| Y | 15 | 4 |  | Torx screw, M $3,8 \mathrm{~mm}$ | BN 15857 M 3 Х8MM | Bossard | Elfa | 148-42-391 | Heat sink fastening |
| Y | 16 | 1 |  | Fuse, glass $5 \times 20 \mathrm{~mm}, 6,3 \mathrm{~A}, 250 \mathrm{~V}$ | 0034.1524 | Schurter | Digi-Key | 486-1241-ND |  |
| Y | 17 | 3 |  | Torx screw, M3, 16 mm | BN 4851 M3X16MM | Bossard | Elfa | 148-87-224 | Rectifier heat sink and C14 connector fastening |
| Y | 18 | 1 |  | Bridge rectifier heat sink | 6222BG | Aavid Thermalloy | Digi-Key | 6222BG-ND |  |
| Y | 19 | 1 |  | Screw, M2.5, 10 mm |  |  |  |  | Fuse holder fastening |
| Y | 20 | 1 |  | Nut, M2.5 |  |  |  |  | Fuse holder fastening |


| $N A$ | Not Available | Rev | Date/Signature | Change |
| :--- | :--- | :--- | :--- | :--- |
| NM | Not Mounted | PA1 | 2017-04-11/MAAL | First release |
| $\mathbf{X}$ | Changed in this revision |  |  |  |
| $Y$ | Added in this revision |  |  |  |
| $Z$ | Deleted in this revision |  |  |  |



# Code for microprocessor 

## D. 1 BoostControl.c

```
    1//To watch the ADC variables in realtime, add the following to
    //Expressions in Watch window:
    3 //
    4 //Temp
    5 //Isense
    6 //IoutSense
    7//VacL
    7//VacL
    8//VacN
    9 //Vou
    0 //DutyCycle
    11 //
    12 //The duty cycle can be edited in realtime. The data type for
    13 // all variables are fixed point, Q 18.
    *
    15 #include "DSP2803x_Device.h" // DSP2803x Headerfile
    16 #include "DSP2803x_Examples.h" // DSP2803x Examples Headerfile
    17 #include "DSP2803x_EPwm_defines.h" // useful defines for initialization
    18 #define GLOBAL_Q 18 // Sets standard Q value
    19 #include "IQmathLib.h" //Library for fixed point math
XIX
21 void PWM1_Config(Uint16,_iq) ;
22 void PWM2_Config(Uint16, __iq);
```

__interrupt void adc_isr (void) ;
24
25 Uint16 readIsense;
26 Uint16 readIoutSense
27 Uint16 readTemp
28 Uint16 readVout
${ }^{2}$ Uint16 readVout
29 Uint16 readVacL
30 Uint16 readVacN
31 Uint16 pwmPeriod
32 _iq Isense;
33 _iq IoutSense;
4 _iq Temp
5 _iq Vout;
36 _iq VacL
37 -iq VacN
8 __iq DutyCycle
void main (void)
41 \{
42 // Initialize System Control:
43 // PLL, WatchDog, enable Peripheral Clocks
44 // This example function is found in the DSP2803x_SysCtrl.c file
InitSysCtrl();
47 // Enable Gpio for EPWM1 and EPWM2
48 // These functions are in the DSP2803x EPwm.c file
InitEPwm1Gpio () ;
InitEPwm2Gpio () ;
52 // Clear all interrupts and initialize PIE vector table:
53 // Disable CPU interrupts
DINT;
56 // Initialize the PIE control registers to their default state.
57 // The default state is all PIE interrupts disabled and flags
58 // are cleared
59 // This function is found in the DSP2803x PieCtrl.c file
6 InitPieCtrl() ;
2 // Disable CPU interrupts and clear all CPU interrupt flags:
$3 \quad \mathrm{IER}=0 \times 0000$
$4 \mathrm{IFR}=0 \times 0000$
65
66 /
// Initialize the PIE vector table with pointers to the shell Interrupt Service Routines (ISR).

```
This function is found in DSP2803x__PieVect.c
    InitPieVectTable();
// Initialize all the Device Peripherals:
    EALLOW;
    SysCtrlRegs.PCLKCRO. bit.TBCLKSYNC = 0;
    PieVectTable.ADCINT1 = &adc_isr; //Enable ADC interrupt
    PieV
    InitAdc();
    AdcOffsetSelfCal() ;
// Enable ADCINT1 in PIE
    PieCtrlRegs.PIEIER1.bit.INTx1 = 1; // Enable INT 1.1 in the PIE
    IER |= M_INT1; // Enable CPU Interrupt 1
    EINT; // Enable Global interrupt INTM
    ERTM; // Enable Global realtime interrupt DBGM
    EALLOW;
    AdcRegs.ADCCTL1.bit.INTPULSEPOS = 1; //ADCINT1 trips after AdcResults latch
    AdcRegs.INTSEL1N2.bit.INT1E 
    AdcRegs.INTSEL1N2.bit.INT1CONT = 0; // Disable ADCINT1 Continuous mode
    AdcRegs.INTSEL1N2.bit.INT1SEL = 2; //setup EOC2 to trigger ADCINT1 to fire
    AdcRegs.ADCSOC0CTL.bit.CHSEL = 4; // set SOC0 channel select to ADCINA4(dummy sample for rev0 errata workaround)
    AdcRegs.ADCSOC1CTL.bit.CHSEL = 4; // set SOC1 channel to Isense input (ADCINA4)
    AdcRegs.ADCSOC2CTL. bit.CHSEL = 0xB; //Temperature
    AdcRegs.ADCSOC3CTL.bit.CHSEL = 6; //Ioutsense
    AdcRegs.ADCSOC4CTL.bit.CHSEL = 0; //VacL
    AdcRegs.ADCSOC5CTL.bit.CHSEL = 8; ///VacN
    AdcRegs.ADCSOC6CTL.bit.CHSEL = 2; //Vout
    // set SOCx start trigger on EPWM4A
    AdcRegs.ADCSOCOCTL. bit.TRIGSEL = 0xB
    AdcRegs.ADCSOC1CTL.bit.TRIGSEL = 0xB
    AdcRegs.ADCSOC2CTL.bit.TRIGSEL = 0xB
    AdcRegs.ADCSOC3CTL. bit.TRIGSEL = 0xB;
    AdcRegs.ADCSOC4CTL. bit.TRIGSEL = 0xB;
    AdcRegs.ADCSOC5CTL. bit.TRIGSEL = 0xB
    AdcRegs.ADCSOC6CTL.bit.TRIGSEL = 0xB
    // set SOCx S/H Window to 7 ADC Clock Cycles, (6 ACQPS plus 1)
    AdcRegs.ADCSOCOCTL. bit.ACQPS = 6
    AdcRegs.ADCSOC1CTL.bit.ACQPS = 6;
    AdcRegs.ADCSOC2CTL.bit.ACQPS = 6
    AdcRegs.ADCSOC3CIL.bit.ACQPS = 6
```

```
AdcRegs.ADCSOC4CTL.bit.ACQPS =6
AdcRegs.ADCSOC5CTL. bit.ACQPS }=
AdcRegs.ADCSOC6CTL.bit.ACQPS = 6
```

EDIS;
//ePWM initialization
// Assumes ePWM4 clock is already enabled in InitSysCtrl()
EPwm4Regs.ETSEL. bit. SOCAEN $=1$; // Enable SOC on A group
EPwm4Regs.ETSEL. bit.SOCAEN $=1 ; \quad / / \quad$ Enable SOC on A group
EPwm4Regs.ETSEL. bit.SOCASEL $=4 ; \quad / /$ Select SOC from from CPMA on upcount
EPwm4Regs.ETPS. bit.SOCAPRD $=1 ; \quad / /$ Generate pulse on 1 st event
EPwm4Regs.CMPA. half.CMPA $=0 \times 0080 ; / /$ Set compare A value
EPwm4Regs.TBPRD $=$ OxFFFF; // Set period for ePWM4, 916 Hz
EPwm4Regs.TBCTL. bit.CTRMODE $=0 ; \quad / /$ count up and start
//Activate PWM outputs (Period, Duty cycle)
$/ /$ pwmPeriod $=$ Sysclock freq / PWM output freq, $60 \Rightarrow 1 \mathrm{MHz}$
//Duty cycle as fixed point value
DutyCycle = _IQ(0.18);
$\begin{aligned} \text { DutyCycle } & =-1 Q \\ \text { pwmPeriod } & =60 ;\end{aligned}$
PWM1_Config(pwmPeriod, DutyCycle) ; //Ch 1
PWM2_Config(pwmPeriod, DutyCycle); //Ch 2

## EALLOW;

SysCtrlRegs.PCLKCRO. bit.TBCLKSYNC $=1$;
//Overvoltage protection. Enables software to trip PWMs EPwm1Regs.TZSEL. bit. OSHT1 $=1$. EPwm2Regs. TZSEL. bit.OSHT1 $=1$;
EPwm1Regs.TZCTL. bit.TZA = TZ_FORCE_LO; // EPWM1A will go low EPwm2Regs.TZCTL.bit.TZA $=$ TZ_FORCE_LO; // EPWM2A will go low
//Overcurrent protection. Trips PWMs asyncronously when an overcurrent is detected
EPwm1Regs.DCTRIPSEL.bit.DCAHCOMPSEL = DC_COMP2OUT; //Set Digital Comparator to use Comparator 2 EPwm1Regs.DCACTL. bit.EVT1SRCSEL = DC EVT1; //Use DCAEVT1
EPwm1Regs.DCACTL. bit.EVT1FRCSYNCSEL = DC EVT ASYNC; //Asynchronous propagation to DCAEVT1.force EPwm1Regs.DCACCL. bit.EVTIFRCSYNCSEL = DC_EVI_ASYNC; //Asynchronous propaga
EPwm1Regs.TZSEL.bit.DCAEVT1 $=1$; //Let DCEVT1 trigger One Shot (OSHT)
EPwm1Regs.TZCTL.bit.TZA = TZ_FORCE_LO; //Set EPWMxA low when tripped

EPwm2Regs.DCTRIPSEL.bit.DCAHCOMPSEL = DC_OOMP2OUT; //Set Digital Comparator to use Comparator 2

## EPwm2Regs.DCACTL. bit.EVT1SRCSEL = DC_EVT1; //Use DCAEVT1

EPwm2Regs.DCACTL. bit.EVT1FRCSYNCSEL=DC_EVT_ASYNC; //Asynchronous propagation to DCAEVT1.force
EPwm2Regs.TZDCSEL.bit.DCAEVT1 = TZ_DCAH_HI; //Activate when Comp 2 is HIGH
EPwm2Regs.TZSEL.bit.DCAEVT1 $=1$; //Let DCEVT1 trigger One Shot (OSHT)
EPwm2Regs.TZCTL.bit.TZA $=$ TZ_FORCE_LO; //Set EPWMxA low when tripped
AdcRegs.ADCCTL1. bit.ADCBGPWD $=1$; //Turns ADC block on. Already done if InitAdc() have been called
Comp2Regs. COMPCTL. bit.OOMPDACEN $=1$; //Enables Comparator 2
Comp2Regs.OOMPCTL. bit.COMPSOURCE $=0 \times 0 ; / /$ Set comparator 2 to use DAC as input
Comp2Regs.DACCTL. bit.DACSOURCE $=0 \times 0$; //Set DAC to use defined value
Comp2Regs.DACVAL. bit.DACVAL $=639$; //Tripping current. $10 \mathrm{~A} \Rightarrow 639$
//Initialize red LED D9
GpioCtrlRegs.GPBMUX1. bit. GPIO40 $=0$
GpioCtrlRegs.GPBDIR. bit. GPIO40 $=1$;
/ Activate relay bypass
GpioCtrlRegs.GPAMUX2. bit. GPIO17 $=0$;
GpioCtrlRegs.GPADIR. bit. GPIO17 $=1$
GpioDataRegs.GPASET. bit. GPIO17 $=1$
EDIS;
while (1) //Infinite loop
\{

GpioDataRegs.GPBSET. bit.GPIO40 = EPwm1Regs.TZFLG.bit.OST; //Red light if tripped
//Conversion of ADC values into something human friendly
Temp $=\_$IQmpy $\left(\_\operatorname{IQdiv}\left(\_\right.\right.$IQ $($readTemp $), \_$IQ $\left.(4096.0)\right), \_$IQ (330.0) $)-\_$IQ (50.0) ;
Isense $=$ _IQmpy (__IQdiv (_IQ(readIsense) , $\mathrm{IQ}(8190)$ ),_IQ(33)) - _IQdiv(_IQ(11),_IQ(21));
IoutSense = _IQmpy (_IQdiv (_IQ(readIoutSense), _IQ(8190)), _IQ(33)) - _ IQdiv(_IQ(11), IQ(21))
$\operatorname{VacL}=\_$IQmpy $\left(\_\mathrm{IQ}(\operatorname{readVacL}), \_\mathrm{IQ}(0.09816)\right)$;
$\operatorname{VacN}=$ - IQmpy $\left(\_\mathrm{IQ}(\right.$ readVacN $\left.),{ }_{\mathrm{I}} \mathrm{IQ}(0.09816)\right)$;
Vout $=$-_IQmpy (_IQ (readVout),$\_$IQ (0.16194) ) ;
if (readVout $>=2624)\{/ / T u r n$ off PWM if voltage is too high. $425 \mathrm{~V} \Rightarrow 2624$ EALLOW;
EPwm1Regs.TZFRC. bit. OST $=1$
EPwm2Regs.TZFRC. bit.OST $=1$
EDIS;
\}

```
< <
l/Update duty cycle if changed through Watch window 
    }
}
03 }
void PWM1_Config(Uint16 period, _iq duty)
{
    EPwm1Regs.TBCTL.bit.PRDLD = TB_IMMEDIATE; // set Immediate load
    EPwm1Regs.TBPRD = period - 1;
    EPwm1Regs.CMPA. half.CMPA = _IQint(_IQmpy(_IQ(period), (_IQ(1.0) - duty))); // Sets duty cycle
    EPwm1Regs.TBPHS.all = 0; //Phase zero
    EPwm1Regs.TBCTR = 0;
    EPwm1Regs.TBCTL.bit.CTRMODE = TB_OOUNT_UP;
    EPwm1Regs.TBCTL. bit.PHSEN = TB DISABLE;
    EPwm1Regs.TBCTL. bit.SYNCOSEL = TB CTR ZERO;
    EPwm1Regs.TBCTL. bit.HSPCLKDIV = TB_DIV1;
    EPwm1Regs.TBCTL.bit.HSPCLKDIV = TB_DIV1;
    EPwm1Regs.CMPCTL. bit.LOADAMODE = CC_CTR_ZERO;
    EPwm1Regs.CMPCTL. bit.SHDWAMODE = OC_SHADOW; //Use shadow registers
    EPwm1Regs.AQCTLA. bit.ZRO = AQ CLEAR; // PWM toggle low/high
    EPwm1Regs.AQCTLA. bit.CAU = AQ SET;
}
void PWM2_Config(Uint16 period, _iq duty)
29 {
EPwm2Regs.TBCTL. bit.PRDLD = TB_IMMEDIATE; // set Immediate load
    EPwm2Regs.TBPRD = period - 1;
    // PWM frequency = 1 / period
    EPwm2Regs.CMPA.half.CMPA = IQint(IQmpy(_IQ(period), (_IQ(1.0) - duty))).
    EPwm2Regs.TBPHS.half.TBPHS = (period -1)/2; //Phase shift 180 degrees
    EPwm2Regs.TBPCTS
    EPwm2Regs.TBCTL. bit.CTRMODE = TB_COUNT_UP;
    EPwm2Regs.TBCTL. bit.PHSEN = TB_ENABLE;
    EPwm2Regs. TBCTL bit.SYNCOSEL = TB SYNC IN, //EPwm1 is the Master
    lit.HSPCLKDIV //Synchronize with EPwm1
    EPwm2Regs.TBCTL.bit.CLKDIV = TB_DIV1;
```

```
EPwm2Regs.CMPCTL. bit.LOADAMODE = CC_CTR_ZERO;
EPwm2Regs.CMPCTL. bit .SHDWAMODE = OC_SHADOW;
EPwm2Regs.AQCTLA. bit.ZRO = AQ CLEAR; // PWM toggle low/high
EPwm2Regs.AQCTLA. bit.CAU = AQ SET;
252 //Save all ADC data to variables
```

248
${ }_{251}^{250}$ \{
254
255
256
257
258
258
259
260
261
262

## D. 2 LEDblink.c

```
#include "DSP28x_Project.h" // Device Headerfile and Examples Include File
2
3
___interrupt void cpu__timer0_isr(void);
5 Uint32 lastTime = 0;
6 Uint32 currentTime = 0
7 Uint32 lastTimeRelay = 0.
8 Uint32 currentTimeRelay = 0
10 Uint32 millis(){
    return CpuTimer0.InterruptCount;
2 }
void setup(){
    // This example function is found in the DSP2803x_SysCtrl.c file
        InitSysCtrl();
    // Clear all interrupts and initialize PIE vector table:
    // Disable CPU interrupts
        DINT;
    // This function is found in the DSP2803x_PieCtrl.c file.
        InitPieCtrl();
    // Disable CPU interrupts and clear all CPU interrupt flags
        IER = 0x0000;
        IFR}=0\times000
    // This function is found in DSP2803x__PieVect.c
        InitPieVectTable();
    // Interrupts that are used in this example are re-mapped to
    // ISR functions found within this file
        EALLOW;
        PieVectTable.TINT0 = &cpu_timer0 isr
        EDIS;
    // This function can be found in DSP2803x_CpuTimers.c
        InitCpuTimers(); //Only initialize the Cpu Timers
41 // Configure CPU-Timer 0 to interrupt every millisecond:
```

```
// 60 MHz CPU Freq, 1 ms period in us
    ConfigCpuTimer(&CpuTimer0, 60, 1000)
    CpuTimer0Regs.TCR.all = 0x4001; // Use write-only instruction
                                    // to set TSS bit = 0
    EALLOW;
    //Configure the LED pins to outputs
    GpioCtrlRegs.GPBMUX1. bit.GPIO34 = 0;
    GpioCtrlRegs.GPBDIR. bit.GPIO34=1;
    GpioCtrlRegs.GPAMUX2. bit.GPIO31=0;
    GpioCtrlRegs.GPADIR. bit.GPIO31 = 1;
    GpioCtrlRegs.GPBMUX1. bit.GPIO40 = 0;
    GpioCtrlRegs.GPBDIR. bit.GPIO40 = 1;
    GpioCtrIRegs.GPBMUX1.bit.GPIO41 = 0
    GpioCtrlRegs.GPBDIR. bit.GPIO41 = 1;
    EDIS;
    // Enable CPU INT1 which is connected to CPU-Timer 0:
    IER |= M_INT1;
    // Enable TINT0 in the PIE: Group 1 interrupt 7
    PieCtrlRegs.PIEIER1.bit.INTx7 = 1;
    // Enable global Interrupts and higher priority real-time debug events:
    EINT; // Enable Global interrupt INTM
    ERTM; // Enable Global realtime interrupt DBGM
void continous(){ //Toggle between the LEDs that are on
    currentTime = millis();
    currentTimeRelay = millis()
    if(! GpioDataRegs.GPBDAT. bit.GPIO34){
        if (currentTime - lastTime >= 2000){
            lastTime = currentTime;
            GpioDataRegs.GPBSET. bit.GPIO34 = 1;
            GpioDataRegs.GPACLEAR.bit.GPIO31= = 1
            GpioDataRegs.GPACLEAR. bit.GPIO31 = 
            GpioDataRegs.GPBCLEAR. bit.GPIO41 = 1;
        }
}else{
    if(currentTime - lastTime >= 500)
```

```
III\LambdaXX
8 lastTime = currentTime
GpioDataRegs.GPBCLEAR. bit.GPIO34 = 1;
GpioDataRegs.GPASET. bit.GPIO31 = 
    GpioDataRegs.GPBSET. bit.GPIO41 = 1;
    GpioDataRegs.GPBCLEAR.bit.GPIO40 = 1;
    }
}
void main(void)
96 {
setup(); //Run once
    for (;;) {
    continous(); //Run forever
}
101 }
1 0 3
04 {
105 CpuTimer0.InterruptCount++
106 // Acknowledge this interrupt to receive more interrupts from group 1
l}10
    PieCtrlRegs.PIEACK. all = PIEACK_GROUP1;
08 }
```

