A series-stacked architecture with isolated server-to-bus converters for high-efficiency data center power delivery by Zhang, Yizhe
c© 2017 Yizhe Zhang
A SERIES-STACKED ARCHITECTURE WITH ISOLATED
SERVER-TO-BUS CONVERTERS FOR
HIGH-EFFICIENCY DATA CENTER POWER DELIVERY
BY
YIZHE ZHANG
THESIS
Submitted in partial fulfillment of the requirements
for the degree of Master of Science in Electrical and Computer Engineering
in the Graduate College of the
University of Illinois at Urbana-Champaign, 2017
Urbana, Illinois
Adviser:
Assistant Professor Robert Pilawa-Podgurski
Abstract
Series-stacked server power delivery architectures have been proposed recently that
can achieve much higher energy efficiency than conventional power delivery archi-
tectures. When servers are connected in series, differential power processing (DPP)
converters can be used to regulate the server voltages when the servers are con-
suming different amounts of current. Server-to-bus DPP architecture has unique
advantages among several other DPP architectures such as being able to achieve
the minimum power processed in the DPP converters, and having a higher reli-
ability than other DPP architectures. This work presents the development of a
server-to-bus DPP architecture for server power delivery. The hardware prototype
is built with four 4-to-1 isolated DPP converters with GaN switches. Four 12V
120W Dell servers are used in the bench test to validate the operation of server-
to-bus DPP. 98.99% efficiency is achieved while the servers are running a real-life
data center computational load.
ii
To my parents, for their love and support.
iii
Acknowledgments
I would like to thank my parents for all your love and support. Your en-
couragement and wisdom make me a better person and help me get through
the most difficult times in my life. I want to thank my advisor Professor
Robert Pilawa. You not only guide me to be a good electrical engineer and
researcher, but also influence me to become an optimistic and kind man.
Many thanks to all the members of the Pilawa group. You make our office
and lab like a warm home where I wish to stay day and night. I am es-
pecially grateful to Enver Candan, who provided me precious and the most
direct mentoring in my research. I cannot have made such fast progress in
my research project without your strong support. I would also like to thank
Professor Grace Gao, with whom I worked for one semester. Your trust in
me and your kindness really helped me a lot. Moreover, I want to thank
all my friends at UIUC. Your companionship makes my life here more col-
orful and meaningful. Finally I would like to thank the Power Group and
ECE Illinois. I could not have become the person I am now without such a
supportive environment.
iv
Table of Contents
List of Tables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . vi
List of Figures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . vii
Chapter 1 INTRODUCTION . . . . . . . . . . . . . . . . . . . . . . 1
Chapter 2 SERVER-TO-BUS DPP ARCHITECTURE . . . . . . . . 4
2.1 Minimum Total Processed Power . . . . . . . . . . . . . . . . 4
2.2 High Reliability . . . . . . . . . . . . . . . . . . . . . . . . . . 8
Chapter 3 CONTROL FOR SERVER-TO-BUS DPP ARCHITEC-
TURE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
3.1 Voltage Hysteresis Control . . . . . . . . . . . . . . . . . . . . 9
3.2 Optimal String Current Control . . . . . . . . . . . . . . . . . 9
Chapter 4 PROTOTYPE DPP HARDWARE FOR THE SERVER-
TO-BUS ARCHITECTURE . . . . . . . . . . . . . . . . . . . . . . 11
4.1 Key Features of the GaN-Based DPP Converter Operation . . 11
4.2 Power Loss Analysis . . . . . . . . . . . . . . . . . . . . . . . 20
Chapter 5 EXPERIMENTAL VERIFICATION . . . . . . . . . . . . 26
5.1 Testbed . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
5.2 Experimental Results . . . . . . . . . . . . . . . . . . . . . . . 28
Chapter 6 CONCLUSION . . . . . . . . . . . . . . . . . . . . . . . . 34
References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
Appendix A PROTOTYPE DPP HARDWARE COMPONENT
LIST AND PCB LAYOUT . . . . . . . . . . . . . . . . . . . . . . 39
Appendix B KEY MICROCONTROLLER CODE . . . . . . . . . . . 50
v
List of Tables
2.1 Server currents in the example where n is even . . . . . . . . . 7
2.2 Server currents in the example where n is odd . . . . . . . . . 7
4.1 Resistances of the inductor, transformer windings, and the
switches . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
4.2 Conduction loss of the inductor, transformer, and switches . . 20
4.3 Loss breakdown of the DAB converter . . . . . . . . . . . . . 25
5.1 Breakdown of the average input and output powers, the
average power loss, the system-level efficiency and power
conversion efficiency during the experiment . . . . . . . . . . . 29
A.1 The key components of the DPP converter . . . . . . . . . . . 39
vi
List of Figures
1.1 Three DPP architectures. . . . . . . . . . . . . . . . . . . . . 3
2.1 The f(istring), m and (2m− n) in the example where n is even. 7
2.2 The f(istring), m and (2m− n) in the example where n is odd. 8
3.1 Bi-directional hysteresis shape [1]. . . . . . . . . . . . . . . . . 10
4.1 The simplified schematic of the prototype DPP hardware. . . . 12
4.2 The prototype DPP hardware. . . . . . . . . . . . . . . . . . . 12
4.3 The efficiency plot of the GaN-based DAB converter. . . . . . 13
4.4 The schematics of the DAB converter. . . . . . . . . . . . . . 14
4.5 Voltage and current waveforms of the DAB converter under
ideal conditions. . . . . . . . . . . . . . . . . . . . . . . . . . . 15
4.6 Detailed schematic of the first leg of the primary side full
bridge. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
4.7 Detailed schematic of one leg of the secondary side full bridge. 17
4.8 Oscilloscope screenshot of the DAB converter operation in
a real experiment. . . . . . . . . . . . . . . . . . . . . . . . . . 18
4.9 Zoomed-in oscilloscope screenshot of the DAB converter
operation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
5.1 The testbed for the server-to-bus architecture. . . . . . . . . . 27
5.2 NUC on its custom-made daughter-board. . . . . . . . . . . . 28
5.3 NUC’s custom-made motherboard. . . . . . . . . . . . . . . . 28
5.4 Example testbed with four assembled NUC units. . . . . . . . 30
5.5 Current and voltage waveforms during the experiment. . . . . 31
A.1 Schematic of connectors. . . . . . . . . . . . . . . . . . . . . . 40
A.2 Schematic of power stage. . . . . . . . . . . . . . . . . . . . . 41
A.3 Schematic of signal isolation. . . . . . . . . . . . . . . . . . . . 42
A.4 Schematic of logic DC supplies. . . . . . . . . . . . . . . . . . 43
A.5 Schematic of hot-swapping, stack initialization and protection. 44
A.6 Schematic of current sensing. . . . . . . . . . . . . . . . . . . 45
A.7 Top layer of PCB. . . . . . . . . . . . . . . . . . . . . . . . . . 46
A.8 Ground layer of PCB. . . . . . . . . . . . . . . . . . . . . . . 47
A.9 Signal layer of PCB. . . . . . . . . . . . . . . . . . . . . . . . 48
vii
A.10 Bottom layer of PCB. . . . . . . . . . . . . . . . . . . . . . . . 49
viii
Chapter 1
INTRODUCTION
With the prevalence of the Internet as well as the increasing demands for
cloud computing, data centers - the hosts of these services - are becoming
more and more important. As the number and size of data centers continue
to grow, so does the electrical power that they consume. In 2014, data centers
in the U.S. consumed an estimated 70 billion kWh, which is approximately
1.8% of the total national electricity consumption that year [2]. With such
a large energy usage, improving the energy efficiency of data centers has
been a focus of research interest. The key component in data centers is the
server, which operates at low DC voltage, typically 12 V or 48 V. Thus, a
power delivery architecture is required to convert the utility AC voltage to
low DC voltage to provide power for the servers. Increasing the efficiency of
this power delivery architecture is a very crucial step in making data centers
more energy efficient [3, 4, 5].
Current power delivery architectures for servers consist of cascaded power
stages. As a typical example, a central rectifier draws from the utility AC
voltage to regulate a DC bus voltage of 48 V. Then for each server, a DC-DC
converter steps down the 48 V to the server’s nominal input 12 V voltage
and supplies its power [5]. The server has numerous point-of-load converters
to supply low voltages (e.g., 1 V, 3.3 V, etc.) to the various digital loads.
Development of efficient and high-density converters for point-of-load conver-
sion is an active area of research [6, 7, 8, 9, 10]. Each power conversion stage
processes the full load power in this process. The system energy efficiency is
directly limited by the efficiency of each power stage.
The series-stacked power delivery architectures are proposed to address the
limitations of the conventional architectures, and can achieve much higher
power delivery efficiency [11]. In the series-stacked architectures, the servers
are connected in series, and differential power processing (DPP) converters
can be used to compensate for the mismatch in the stacked servers’ currents.
1
Therefore, the bulk power consumed by the servers flows through the series-
stack without being processed by the power conversion stage, and only the
difference in power between servers is processed by the DPP converters. Us-
ing this technique, the amount of power processed, and the corresponding
power loss, can be greatly reduced compared to conventional architectures,
resulting in extremely high efficiency. There are three basic ways to con-
nect the DPP converters: the server-to-server DPP architecture, server-to-
bus architecture and server-to-virtual-bus architecture, which are depicted
in Fig. 1.1(a), 1.1(b) and 1.1(c), respectively. The first architecture has
been explored in [12, 13, 14], and the third architecture has been studied in
[15, 16]. In [17] the hot-swapping operation of the servers is addressed in
detail. There are also hybrid architectures combining the above mentioned
types, as proposed in [11]. The DPP idea also applies to series-connected
solar cells, where the first, second and third architectures are investigated in
[18], [19] and [20], respectively. In this work, we focus on investigating the
server-to-bus DPP architecture for data center servers.
It should be pointed out that for the series-stacked power delivery archi-
tecture, there are also research efforts that investigate using software only
to compensate for the mismatch between the servers’ currents without using
DPP converters [21]. This approach is not within the scope of this thesis.
The remainder of this thesis is organized as follows. Chapter 2 discusses the
unique features of the server-to-bus power delivery architecture. In Chapter
3, two control methods for the DPP converters in the server-to-bus architec-
ture are described. Chapter 4 introduces the prototype DPP hardware used
in this work, and analyzes the power loss of the GaN-based DPP converter
in detail. The experimental testbed of the architecture as well as the bench
test results are presented in Chapter 5. In Chapter 6, the conclusion and
future work are briefly stated.
2
V B
us
i S
tri
ng i S
1 Se
rv
er
1
Se
rv
er
2
Se
rv
er
n
D
C
D
C
D
C
D
C
D
C
D
C
i S
2
i S
nV B
us
i S
1
i D
PP
1
Se
rv
er
1
Se
rv
er
2
Se
rv
er
n
D
C
D
C
i S
2
i S
n
i D
PP
(n-
1)
i D
PP
2
(a
)
S
er
ve
r-
to
-s
er
ve
r
ar
ch
it
ec
tu
re
.
V B
us
i S
tri
ng i S
1
i D
PP
1
Se
rv
er
1
Se
rv
er
2
Se
rv
er
n
D
C
D
C
D
C
D
C
D
C
D
C
i S
2
i S
n
i D
PP
2
i D
PP
n
(b
)
S
er
ve
r-
to
-b
u
s
a
rc
h
it
ec
tu
re
.
V B
us
i S
tri
ng i S
1
i D
PP
1
Se
rv
er
1
Se
rv
er
2
Se
rv
er
n
D
C
D
C
D
C
D
C
D
C
D
C
i S
2
i S
n
i D
PP
2
i D
PP
n
(c
)
S
er
ve
r-
to
-v
ir
tu
a
l-
b
u
s
a
rc
h
it
ec
tu
re
.
F
ig
u
re
1.
1:
T
h
re
e
D
P
P
ar
ch
it
ec
tu
re
s.
3
Chapter 2
SERVER-TO-BUS DPP ARCHITECTURE
As can be seen in Fig. 1.1(b) and 1.1(c), the circuit connections of server-
to-bus and server-to-virtual-bus architectures are very similar. The DPP
converters are isolated DC-DC converters with one side connected to the DC
bus (in the server-to-bus architecture shown in Fig. 1.1(b)) or a capacitor,
virtual-bus (in the server-to-virtual-bus architecture shown in Fig. 1.1(c)),
and the other side connected to the server.
The server-to-bus architecture has certain unique advantages compared
with other DPP architectures. Firstly, it can achieve minimum total pro-
cessed power in the DPP converters, and thus obtain the highest possible
theoretical efficiency in power delivery [22]. Secondly, server-to-bus DPP ar-
chitecture has a higher level of reliability than the other two architectures.
These two points are explained below in greater detail.
2.1 Minimum Total Processed Power
The server-to-bus architecture can achieve the minimum total processed
power in converters for most server load distributions in the series-stack.
The other two DPP architectures cannot guarantee minimum total processed
power in all server load distributions. To better understand this, let us as-
sume that in a certain scenario, the servers are drawing current iS1, iS2, . . . ,
iSn as shown in Fig. 1.1(a), 1.1(b) and 1.1(c).
For the server-to-virtual-bus and server-to-server DPP architecture, each
DPP converter’s output current iDPPk is uniquely determined (there is a
only one feasible combination of the operating points of the DPP convert-
ers). The server-to-bus DPP architecture, however, is an under-determined
system, where the DPP converters’ output currents have infinite feasible com-
binations. In fact, there are n limiting variables (iS1 through iSn), but (n+1)
4
controllable variables (iDPP1 through iDPPn, plus istring), so there is one ex-
tra degree of freedom. For this architecture, string current istring can be set
to any value as long as the DPP converters’ output currents (iDPP1 through
iDPPn) are controlled correspondingly. Furthermore, some istring values will
yield the combinations of iDPP1 through iDPPn with smaller total processed
power in the DPP converters than other combinations. We can thus control
istring to be the optimal value(s) that results in the minimum total processed
power in the converters of the server-to-bus DPP architecture. The following
analysis will derive the value of the optimal string current in the server-to-bus
architecture.
Let us assume, without loss of generality, that the server currents, as shown
in Fig. 1.1(b), have the relationship
iS1 ≤ iS2 ≤ · · · ≤ iSn. (2.1)
Moreover, for simplicity of analysis, assume 100% efficient converters.
Then, the power processed in the k-th DPP converter PDPPk is
PDPPk = |iDPPk| · vSk, (2.2)
where vSk refers to the k-th server voltage. The objective to minimize, the
total processed power in all the DPP converters PDPP,tot, is
PDPP,tot =
n∑
k=1
PDPPk. (2.3)
If it is further assumed that the server voltages are all well regulated around
the nominal input voltage, and thus
vS1 ≈ vS2 ≈ · · · ≈ vSn ≈ Vnominal, (2.4)
then
PDPP,tot ≈ Vnominal
n∑
k=1
|iDPPk|. (2.5)
The new objective function to be minimized is then just the summation
part
∑n
k=1 |iDPPk|, which is defined as f(istring),
5
f(istring) =
n∑
k=1
|iDPPk| =
n∑
k=1
|iSk − istring|. (2.6)
To determine the optimal istring value that will minimize the objective
function in (2.6), we will first simplify this expression and then look at its
derivative. Suppose there are m servers (0 ≤ m ≤ n) whose currents are
smaller than istring. Due to the assumption in (2.1), these servers are just
server 1 to server m. Then f(istring) can be simplified as
f(istring) =
m∑
k=1
(istring − iSk) +
n∑
k=m+1
(iSk − istring), (2.7)
and the derivative is
f ′(istring) = m− (n−m) = 2m− n. (2.8)
To better understand how f(istring) changes with istring, two example cases
with n being even (n = 6) or odd (n = 7) are considered, with the server cur-
rents in both cases listed in Tables 2.1 and 2.2. Example plots for f(istring),
m and (2m−n) in the two example cases are shown in Fig. 2.1 and Fig. 2.2.
It can be seen from the figures that in both cases, as istring increases from 0,
m increases monotonically from 0 to n, and (2m−n), which is also f ′(istring),
increases monotonically from (−n) to n. Moreover, the objective function
f(istring) first decreases and then increases, and reaches the minimum (shown
in red in the plots) when (2m − n) crosses 0. When n = 6, the minimum
happens when m = 3, when iS3 ≤ istring ≤ iS4, or when istring is larger than
the currents of three (half of total) servers. In this case, there is a region
of istring values that are all optimal. When n = 7, the minimum happens
when istring = iS4, or when istring equals to the server current right at the
middle (the ‘median’). In general, when n is even, the optimal string current
istring,opt is any value between iS n
2
and iS(n
2
+1), and when n is odd, the optimal
string current istring,opt is equal to iS n+1
2
, as expressed in Eq. 2.9. For a more
detailed derivation of the optimal string current, readers can refer to [19].
It needs to be pointed out that the currents iSk, istring and voltages vSk are
actually considered in terms of their averaged values in the analysis above.
Due to the switching actions or operations in hysteresis mode of the power
converters as well as the fast-changing nature of computation loads in servers,
6
istring [A]
4 6 8 10
f
(i
st
ri
n
g
)
[A
]
5
10
15
20
25
istring [A]
4 6 8 10
m
an
d
(2
m
!
n
)
-5
0
5
m
2m ! n
iS1 iS2 iS3 iS4 iS5 iS6
iS1 iS2 iS3 iS4 iS5 iS6
Figure 2.1: The f(istring), m and (2m− n) in the example where n is even.
the instantaneous values of these currents and voltages may fluctuate or
ripple. These ripples are assumed to be small compared with the average
values of these quantities within each control time period, so that their effects
are neglected.
istring,opt =
iS n+12 , if n is odd.any value ∈ [iS n
2
, iS(n
2
+1)], if n is even.
(2.9)
Table 2.1: Server currents in the example where n is even
iS1 [A] iS2 [A] iS3 [A] iS4 [A] iS5 [A] iS6 [A]
5 6 7 8 9 10
Table 2.2: Server currents in the example where n is odd
iS1 [A] iS2 [A] iS3 [A] iS4 [A] iS5 [A] iS6 [A] iS7 [A]
5 6 7 8 9 10 11
7
istring [A]
4 6 8 10 12
f
(i
st
ri
n
g
)
[A
]
10
15
20
25
30
istring [A]
4 6 8 10 12
m
an
d
(2
m
!
n
)
-5
0
5
m
2m ! n
iS1 iS2 iS3 iS4 iS5 iS6 iS7
iS1 iS2 iS3 iS4 iS5 iS6 iS7
Figure 2.2: The f(istring), m and (2m− n) in the example where n is odd.
2.2 High Reliability
Another feature of the server-to-bus architecture is that it offers high relia-
bility/availability compared with other DPP architectures. Since the server-
to-bus architecture has one extra degree of freedom (one more control handle
than quantities to be controlled), it can actually deliver power to n servers
with only (n − 1) DPP converters. This indicates that it can tolerate one
converter failure, and can still deliver power to all stacked servers. For ex-
ample, if the DPP converter corresponding to the k-th server fails in the
server-to-bus architecture, we can control the string current istring to be the
k-th server’s current (iSk), and control the other DPP converters to inject
or reject currents equal to the difference between this string current and the
corresponding server currents [23]. For the other two DPP architectures, in
the case of a single failure in the DPP converters, the power delivery can no
longer be fulfilled.
As was quantitatively analyzed in detail in [23], due to the reduced power
processed in the converters of the server-to-bus architecture, the reliability
(characterized by down time over a 10 year time period) of the proposed
series-stacked architecture is comparable to the reliability standard of a con-
ventional power delivery architecture.
8
Chapter 3
CONTROL FOR SERVER-TO-BUS DPP
ARCHITECTURE
In the series-stacked architectures, the DPP converters must be controlled
properly to compensate for the mismatch between server loads. In this work,
two control methods are used. The first one focuses on only the voltage
regulation of the stacked servers which can be achieved by merely voltage
sensing (no current sensing needed for control). One drawback is that the
string current is not always optimized to achieve minimum power processed
in the system. The second control method controls the string current to be
optimal, and minimizes the total processed power. These two methods will
be discussed in this chapter.
3.1 Voltage Hysteresis Control
The first control method used is bi-directional hysteresis control. A similar
control method successfully achieved voltage regulation of stacked servers
for the server-to-virtual-bus DPP architecture [1]. In this control algorithm,
two hysteresis values ε0 and ε1 are pre-defined, as shown in Fig.3.1. If the
server voltage goes higher than the reference voltage Vref plus ε1, the DPP
converter is controlled to deliver current from the server to bus direction,
until the server voltage is lower than (Vref − ε0). After this the converter is
shut down. If the server voltage goes lower than (Vref − ε1), the converter is
controlled to deliver current from the bus to server direction, until the server
voltage is higher than (Vref + ε0). After this the converter is shut down.
3.2 Optimal String Current Control
As was discussed in Chapter 2, only (n − 1) DPP converters are needed to
keep the n server voltages regulated in the server-to-bus architecture. The
9
Current Need
1
0- 1
- 0
Error
0
Injection
Rejection
No Action 
Figure 3.1: Bi-directional hysteresis shape [1].
control for optimal string current makes use of this feature. To control istring
to be the optimal value as shown in Eq. 2.9, we can control the string
current just to follow the (n+1
2
)-th largest server current if n is odd, or the
(n
2
− 1)-th largest server current if n is even. To control the string current
to follow a specific server’s current, we can turn off the single DPP converter
corresponding to that specific server, and keep all other DPP converters
operating as normal with the voltage hysteresis control stated in Section
3.1. In this control method, the server currents are measured, and then
compared to determine which server consumes the (n+1
2
)-th largest current
(if n is odd, or the (n
2
− 1)-th largest if n is even). Then the corresponding
DPP converter is temporarily turned off. In this manner, the string current
is controlled to be optimal in average, and the power processed in the DPP
converters is minimized. In this work, a four-server system is investigated.
Thus the optimal string current is any value between the second and third
largest server current. In the optimal string current control method used in
the experiments, the string current is controlled to follow the second largest
server current.
10
Chapter 4
PROTOTYPE DPP HARDWARE FOR THE
SERVER-TO-BUS ARCHITECTURE
The DPP converter in the server-to-bus architecture, as shown in Fig. 1.1(b),
is required to be bidirectional and isolated. For the experimental testbed of
the four-server system in this work, the primary side of the converter is
rated at 48 V, and the secondary side is rated at 12 V, which is the nominal
server input voltage. The dual active bridge (DAB) topology is chosen for
its symmetrical design and simple modulation [24]. In addition to the DPP
converter, a stack initialization circuitry and hot-swapping circuitry are also
needed. These three parts constitute the prototype DPP hardware used in
the server-to-bus architecture of this work. The simplified schematic of the
DPP hardware is shown in Fig. 4.1 and an annotated photograph of the
prototype is shown in Fig. 4.2.
The stack initialization circuitry is used to achieve the voltage balancing
between the series-stacked hardware prototypes when the DC bus is first
applied to the series-stack. The hot-swapping circuitry provides complete
isolation when the server is swapped out from the series-stack, and also lim-
its the in-rush current caused by charging up the large input capacitor of
the server when it is swapped in. Hot-swapping and initialization circuitries
follow the principles explained in [17], which can also provide further de-
tails for interested readers. The following sections will discuss the operation
characteristics of the DPP converter in greater detail.
4.1 Key Features of the GaN-Based DPP Converter
Operation
This section discusses some key features in the operation of the DAB con-
verter. GaN transistors are used in both the primary and secondary side full
bridges, and the efficiency vs. output power plot of the converter is shown
11
Bus+
Bus-
Series-Stack+
Series-Stack-
Server+
Server-
L
C in Cout
Transformer
Integrated Switching Cell
RSS
Differential Converter
Stack
SwappingInitialization
Hot-
Figure 4.1: The simplified schematic of the prototype DPP hardware.
L
Transformer
Hot-swapping 
switches
Bus 
connector
Series-stack 
connector
Server 
connector
Cin
Integrated 
switching cell
Cout
Figure 4.2: The prototype DPP hardware.
12
0 50 100
Output Power [W]
150 200
Ef
fic
ie
nc
y 
[%
]
80
85
90
95
100
From Bus to Server
From Server to Bus
Figure 4.3: The efficiency plot of the GaN-based DAB converter.
in Fig. 4.3. The key components are listed in Table A.1.
The zero voltage switching (ZVS) feature on all the eight switches, the
impact of the secondary side parasitic inductance on the circuit, and the
impact of the reverse conduction of the eGaN FETs during deadtime will be
introduced below.
4.1.1 Zero Voltage Switching (ZVS)
One important feature of the DAB converter is that ZVS is achieved on all
eight switches in normal operation. To understand this, let us first have a
look at the converter operation in general. Shown in Fig. 4.4 is a detailed
schematic of the DAB converter, and Fig. 4.5 shows the voltage and current
waveforms of the converter under ideal conditions. One period of 5 µs is
shown for the switching frequency fsw of 200 kHz. The converter is operated
with simple phase shift modulation. The primary and secondary side full
bridges generate two 50% duty ratio square waves shifted by a certain phase
value φ. The magnitudes of the two square waves are 48 V and 12 V, which
are just the bus and server side voltages. With a transformer ratio of 4:1, vp
transforms to a 12 V square wave v′p. The voltage across the inductor is just
(v′p − vs), which results in an AC inductor current iL as shown in Fig. 4.5.
The output current of the secondary side full bridge iout can be obtained by
flipping half the period of the inductor current iL waveform when the switches
S6 and S7 are on. Since iout is positive on average, power is delivered from
13
Bus+
Bus-
Server+
Server-
L
C in Cout
Transformer
S1
S2
S3
S4
S5
S6
S7
S8
+
-
vp
+
-
vs
iL
iout
-
vleg1
+ +
vleg3
-
Figure 4.4: The schematics of the DAB converter.
the bus side to the server side in this situation corresponding to Fig. 4.5.
Now let us focus on the switching intervals and see how ZVS is achieved.
Take the switching event occurring at t = 0 in Fig. 4.5 as an example, when
S1 and S4 are turned on, and S2 and S3 are turned off. Let us first take a
detailed look at the leg of S1 and S2 during this process, and the schematic
of this portion is in Fig. 4.6 with the CDS of each transistor shown. At t = 0,
iL is negative as can be seen in Fig. 4.5. With a 4:1 transformer, we have
iTr1 ≈ 1
4
iL. (4.1)
So iTr1 is also negative at t = 0. When switch S2 is turned off, switch S1
is not turned on until after the deadtime. During this deadtime period, the
negative iTr1 charges C2 and discharges C1. When C1 is fully discharged,
D1 starts to conduct the negative iTr1 current. And after the deadtime has
passed, switch S1 is turned on with zero voltage across it, so ZVS turn-on is
achieved. As for the other pair of switches S3 and S4 in the other leg, the
situation is equivalent to this leg. The transformer current charges the CDS
of S3 while it turns off and discharges the CDS of S4 during the deadtime,
and ZVS turn-on is achieved on S4.
At t = 2.5 µs, when S1 and S4 are turned off, and S2 and S3 are turned
on, the situations for the two legs just flip each other - e.g. the leg of S1 and
S2 is what was the leg of S3 and S4 at t = 0, and thus ZVS is also true here.
From the analysis above, we can see that ZVS turn-on is achieved on all four
switches in the primary side.
In the secondary side, the same analysis can be carried out and we can see
that ZVS turn-on is still achieved in all the four switches. At the rising edge
14
0 1 2 3 4 5
v p
[V
]
-50
0
50
0 1 2 3 4 5
v s
[V
]
-20
0
20
0 1 2 3 4 5
i L
[A
]
-20
0
20
Time [7s]
0 1 2 3 4 5
i o
ut
[A
]
-20
0
20
Figure 4.5: Voltage and current waveforms of the DAB converter under
ideal conditions.
Bus+
Bus-
S1
S2
D1
D2
C1
C2
iTr1
Figure 4.6: Detailed schematic of the first leg of the primary side full bridge.
15
of the vs waveform in Fig. 4.5, secondary side switches S5 and S8 turn on,
S6 and S7 turn off, and the inductor current iL is positive. Taking the leg
of S5 and S6 as an example, iL charges the CDS of S6 while it turns off and
discharges the CDS of S5 during the deadtime, and ZVS turn-on is achieved
on S5. At the falling edge of the vs waveform in Fig. 4.5, ZVS turn-on is also
true for both legs in the full bridge.
Therefore we can see that all eight switches have the feature of ZVS turn-
on in the DAB converter in normal operation conditions where the above
mentioned polarities of iL are guaranteed. The ZVS feature for the primary
side switches significantly reduces the corresponding switching loss. For the
secondary side, however, the benefits of ZVS are effectively not gained in the
DAB topology, due to the high current of the secondary side together with
the presence of parasitic inductance, as will be shown next.
4.1.2 Impact of Secondary Side Parasitic Inductance
Since the secondary side of the DAB converter is low voltage and high cur-
rent, the presence of parasitic inductances that are in series with the switches
can have large impact on converter operation. The parasitic inductances can
be introduced by device packaging and PCB layout [25, 26, 24]. Shown in
Fig. 4.7 is the schematic of one leg of the secondary side full bridge with
the parasitic inductances included. The parasitic inductances cause the con-
verter operation to be different from the ideal case shown in Fig. 4.5. Fig-
ure 4.8 is the oscilloscope screenshot of the DAB converter operation in a
real experiment. As can be noticed, there are two places where the actual
waveform differs greatly from the ideal one. One is the large overshoot of
the vleg3 waveform. The other one is the small stair in the voltage of the vleg3
waveform every time before the rising or falling edges. These two phenom-
ena are caused by the secondary side parasitic inductances that are in series
with the switches. Let us first look into the second point, which is easier to
understand.
The stair in voltage of the vleg3 waveform happens when the inductor cur-
rent iL charges fast, or when
diL
dt
has large magnitude. Take the voltage stair
that happens before the first rising edge of the vleg3 waveform for an example.
Before the rising edge, switch S6 has been conducting. We then have:
16
S5
S6
D5
D6
C5
C6
LD,5
LS,5
LS,6
LD,6
Cleg3iL
Server+
Server-
+
-
vleg3
Figure 4.7: Detailed schematic of one leg of the secondary side full bridge.
vleg3 = (LD,6 + LS,6)
diL
dt
. (4.2)
If iL is changing fast, the induced voltage on the parasitic inductances LD,6
and LS,6 can be large, causing vleg3 to be larger than zero, which is a stair
in the waveform. Using the magnitude of the stair in the vleg3 waveform, we
can actually calculate the parasitic inductance value as
(LD,6 + LS,6) =
vstair
diL
dt
. (4.3)
Using vstair = 1 V and
diL
dt
= 0.08633 A/ns as calculated from the waveform,
we get (LD,6 +LS,6) = 11.58 nH. We can further assume that (LD,i +LS,i) =
11.58 nH for i of 5, 7 and 8.
Next let us move on to the overshoot phenomenon in the vleg3 waveform.
We can still take the first rising edge of the waveform as an example. At
this rising edge, switch S6 turns off and switch S5 turns on, and the inductor
current iL is positive. Just before S6 turns off, the parasitic inductances
(LD,6 + LS,6) are conducting the same current as iL, and since iL is quite
large at this low-voltage high-current side, quite a large amount of energy
17
vleg1
vleg3
iL PWM1,4
PWM2,3
PWM5,8
PWM6,7
Figure 4.8: Oscilloscope screenshot of the DAB converter operation in a
real experiment.
is stored in (LD,6 + LS,6). When S6 turns off, the parasitic inductances
(LD,6 + LS,6) start to charge C6 and the current that they conduct starts to
decrease. At the same time, the current starts to increase in the parasitic
inductances (LD,5 + LS,5) corresponding to S5. Since initial current and
energy in (LD,6+LS,6) are quite large, resonance occurs between the parasitic
inductances (LD,6 + LS,6), (LD,5 + LS,5) and the switch output capacitances
C5 and C6, and large overshoot in voltage takes place. All the initial stored
energy in the parasitic inductances is lost as the resonance is damped down by
parasitic resistances in the resonant paths. After the deadtime, switch S5 is
turned on, and the resonance settles to the steady state value. The switching
loss in this process can be very large, and as is calculated in Section 4.2.2, it
is the largest loss in the DAB converter in this operating condition compared
to other losses such as conduction loss or core loss. A zoomed-in version of
the rising edge in the vleg3 waveform is shown in Fig. 4.9, where the deadtime
for the secondary side switches is 24 ns.
18
vleg1
vleg3
iL
PWM1,4
PWM2,3
PWM5,8
PWM6,7
Figure 4.9: Zoomed-in oscilloscope screenshot of the DAB converter
operation.
4.1.3 Impact of the reverse conduction of the eGaN FETs
during deadtime
The switches of the DAB converter used are the eGaN FETs from EPC Inc.
The eGaN transistors offer a lot of advantages over Si transistors, but one
drawback of the eGaN switches is that the forward voltage drop of their
‘body diode’ can be around 2 V, and is higher than that of a Si-based FET.
Actually eGaN transistors do not have a real body diode as in a Si MOSFET.
It provides reverse conduction during deadtime through another mechanism,
but the voltage drop for this reserve conduction is quite high. Therefore, for
designs with the eGaN FETs, the deadtime needs to be optimized in order
to shorten the reverse conduction time and obtain highest efficiency [27].
As shown in Fig. 4.9, following the rising edge of the vleg1 waveform, there
is a hump. This hump of approximately 2 V in magnitude corresponds to the
reverse conduction of the primary side switch during deadtime. This dead-
time of the primary side switches is 60 ns. For the secondary side, the effect
of the reverse conduction during deadtime can be seen in the vleg3 waveform
in Fig. 4.9. In the ringing immediately after the rising edge, the steady state
value of the voltage is actually about 14 V, which is approximately 2 V higher
than the secondary side voltage of 12 V. After the deadtime, the steady state
19
Table 4.1: Resistances of the inductor, transformer windings, and the
switches
RL [mΩ] RTr1 [mΩ] RTr2 [mΩ] RS1 [mΩ] RS2 [mΩ]
0.18 14.4 2.1 3 1.8
Table 4.2: Conduction loss of the inductor, transformer, and switches
PL,cond [W] PTr1,cond [W] PTr2,cond [W] PS1,cond [W] PS2,cond [W]
0.021 0.106 0.247 0.044 0.42
value of the voltage returns to 12 V.
4.2 Power Loss Analysis
In this section, the power loss originating from different parts of the DAB
converter is analyzed and calculated in detail. The operating condition cor-
responding to Fig. 4.8 with the phase shift value of 20◦ is chosen as the
example in the loss calculation. In this case, power is delivered from the
bus side to the server side with the input power P1 being 127.3 W, output
power P2 being 119.1 W. The total power loss Ploss,tot is 8.2 W, and converter
efficiency is 93.5%. The switching frequency is 200 kHz.
4.2.1 Conduction Loss of Inductor, Transformer and Switches
The conduction loss of the inductor PL,cond can be calculated as
PL,cond = I
2
L,rmsRL, (4.4)
where IL,rms, the rms value of iL shown in Fig. 4.8, is calculated as 10.8377 A,
and RL, the resistance of the inductor winding, is listed in Table 4.1, together
with the resistance values of the other components. The calculated PL,cond
value is listed in Table 4.2, together with the conduction loss values of the
other components. It should be pointed out that skin effect and other high-
frequency effects are not taken into account in this calculation.
The conduction loss of the transformer primary and secondary windings
20
PTr1,cond and PTr2,cond can be calculated as
PTr1,cond = (
1
4
IL,rms)
2RTr1 (4.5)
PTr2,cond = I
2
L,rmsRTr2, (4.6)
where RTr1 and RTr2 are the resistance of the primary and secondary wind-
ings of the transformer, respectively, with their values listed in Table 4.1.
Again, skin and proximity effects are not included here. For the calculation
of PTr1,cond in Eq. 4.5, we assume that the current in the primary winding of
the transformer is equal to one-fourth of the current in the secondary wind-
ing. This is assuming the magnetizing inductance of the transformer to be
sufficiently large.
As for the conduction loss of the primary and secondary side switches, since
two switches are connected to the transformer current in each half period,
the losses are calculated as
PS1,cond = (
1
4
IL,rms)
2 × 2RS1 (4.7)
PS2,cond = I
2
L,rms × 2RS2, (4.8)
where RS1 and RS2 are the Rds(on) of the primary and secondary side switches,
respectively.
4.2.2 Switching Loss of the Switches
The switching loss is more complicated than the conduction loss. For the
primary side, since ZVS is achieved, the normal switching loss can be ne-
glected, and the only loss that needs to be considered is the loss from the
reverse conduction voltage drop during deadtime. For the operating condi-
tion corresponding to Fig. 4.8, with the zoomed-in waveforms in Fig. 4.9, the
duration tr-c,1 of the primary side switch reverse conduction is 20 ns. The
conduction current Ir-c,1 is approximately one-fourth of the inductor current
at that moment, which is one-fourth of 8 A. With a reverse conduction volt-
age drop Vr-c,1 of 2 V, the energy lost in one leg of the full bridge during one
switching event is
21
Er-c,1 = tr-c,1Vr-c,1Ir-c,1 = 80 nJ. (4.9)
With a switching frequency of 200 kHz, and two switching event in one
period for each leg of the full bridge, the power loss due to reverse conduction
in the primary side switches is
Pr-c,1 = fswEr-c,1 × 2× 2 = 0.064 W. (4.10)
Thus PS1,sw = Pr-c,1 = 0.064 W.
For the secondary side, the switching loss is equal to power lost in reverse
conduction during deadtime as well as in the parasitic inductance ringing
phenomenon. For reverse conduction loss Pr-c,2, with the duration of conduc-
tion tr-c,2 of 20 ns, conduction current Ir-c,2 of 14 A, and a reverse conduction
voltage drop Vr-c,2 of 2 V, the energy lost in one leg of the full bridge during
one switching event is
Er-c,2 = tr-c,2Vr-c,2Ir-c,2 = 560 nJ. (4.11)
Thus
Pr-c,2 = fswEr-c,2 × 2× 2 = 0.448 W. (4.12)
The energy loss from the parasitic inductances per leg per switching event
Epar can be calculated as [24]
Epar =
1
2
· Lseries · I2par ·
Vpk
Vpk − Vsecondary , (4.13)
where Lseries = LD,5 + LS,5 + LD,6 + LS,6, and Ipar is the current in the
parasitic inductances when the switching event happens, which is 14 A. Vpk
is a parameter given in [24] as 32.7 V, and Vsecondary is the secondary side
voltage, which is 12 V. Epar is calculated as 3.5854 µJ. Therefore the power
loss due to the secondary side parasitic inductances is
Ppar = fswEpar × 2× 2 = 2.868 W. (4.14)
The secondary side switching loss is
Psw,2 = Pr-c,2 + Ppar = 3.316 W. (4.15)
22
4.2.3 Core Loss of the Transformer and Inductor
The core loss of the transformer is determined by the curves given in the
datasheet [28] of core loss vs Bpk. The peak flux density Bpk is calculated
using the formula in the datasheet
Bpk =
KVprimaryDmax
fswNprimary
, (4.16)
where K is the coefficient of (58 × 102), Dmax is the maximum duty cycle,
which is 50% here, and Nprimary is the number of primary turns, which is 8.
Bpk is calculated as 87 mT, and the corresponding core loss PTr,core = 0.3 W.
The core loss of the inductor is calculated using the online inductor loss
calculator provided by the manufacturer. The online calculator, however,
only supports uni-directional inductor current, whereas the DAB converter
inductor has bi-directional current. To still be able to obtain a proper core
loss value, the inductor rms value setting in the online calculator is set as the
actual rms value in the DAB converter, and the current ripple value setting
is tuned until the inductor temperature matches the measured temperature
value of 40.5 ◦C. The final core loss value obtained is PL,core = 0.15 W.
4.2.4 Power Loss from Auxiliary Circuits
The power loss from auxiliary circuits includes the gate driving loss and the
power consumption of the ICs for control. Another source for power loss is
a resistive voltage divider for sensing the server side voltage for protection
purposes. It has an approximately constant power consumption of 0.012 W.
Since all the gate drivers and IC chips are supported by two LDOs (one for
the Bus side, and the other for the Server side), the rest of the auxiliary loss
is just the power delivered into the two LDOs. So we have
Paux = Pvol-dvd + PLDO,in,1 + PLDO,in,2. (4.17)
For LDO, its input and output current are basically equal, so its input
power PLDO,in is
PLDO,in = VLDO,inILDO,out. (4.18)
23
and ILDO,out is just the sum of the current drawn by each of the downstream
ICs.
As for the current drawn by IC chips, most IC datasheets give the typical
current value that the chip draws. One special IC chip is the date driver chip,
as the current that it draws greatly depends on the switch that it drives. The
gate driver chip input current is
IG-dr = PG-dr/VDD,G-dr, (4.19)
where VDD,G-dr=5 V, and
PG-dr = PG-dr-cap + Pbootstrap. (4.20)
The PG-dr-cap is the power loss of charging and discharging the gate capac-
itance of the switch, and Pbootstrap is the power loss of the bootstrap diode in
the gate driver IC. We have
PG-dr-cap = (QG,high-side +QG,low-side)VDD,G-drfsw. (4.21)
And the Pbootstrap is obtained from the curves provided in the datasheet.
The calculated values of the gate driver input currents are IG-dr,1=15.6 mA,
IG-dr,2=11.04 mA. The other ICs draw currents of Iother-IC,1=11.4 mA,
Iother-IC,2=30.5 mA. Thus
PLDO,in,1 = 48 V × (2IG-dr,1 + Iother-IC,1) = 2.0448 W (4.22)
PLDO,in,2 = 12 V × (2IG-dr,2 + Iother-IC,2) = 0.631 W. (4.23)
And
Paux = Pvol-dvd + PLDO,in,1 + PLDO,in,2 = 2.688 W. (4.24)
4.2.5 Summary of the Power Loss Analysis and Design
Considerations for Converter Performance Optimization
From the above power loss analysis, we can get the loss breakdown as shown
in Table 4.3. As can be seen, the power loss on the secondary side switches
24
Table 4.3: Loss breakdown of the DAB converter
PL [W] PTr [W] PS1 [W] PS2 [W] Paux [W]
0.171 0.653 0.108 3.736 2.688
is the largest. Inside this loss, the parasitic inductance generated loss makes
up the majority. Therefore layout of the PCB that minimizes the parasitic
inductances on the second side is one key step for converter efficiency opti-
mization. Other than layout, advanced modulation schemes instead of the
simple phase shift modulation may be employed to minimize the loss from
parasitic inductances. The second largest loss in the table is the auxiliary
circuit loss. This arises largely due to the use of high step-down LDOs. Fu-
ture designs may consider using a switching converter to provide the 5 V
logic power needed. All these above calculated losses add up to 7.356 W,
which is not enough to match the measured value of 8.2 W. The difference
may be due to the high-frequency effects that are not considered in the con-
duction losses of the inductor and transformer, and also may be due to the
loss in the aluminum capacitor ESR, the loss in the current sensing wire for
probing the inductor current, the loss in the RC filter for the PWM signals,
and the loss from PCB trace resistance, etc. Future work may investigate
these possibilities.
25
Chapter 5
EXPERIMENTAL VERIFICATION
This chapter describes the experimental testbed of the server-to-bus DPP
architecture and discusses the test results. These results verify the effective-
ness of both control methods and the high efficiency of the server-to-bus DPP
architecture.
5.1 Testbed
A testbed for the server-to-bus DPP power delivery architecture is devel-
oped with four Dell Optiplex SX280 servers running Linux operating sys-
tems. Each server has a single 12 V motherboard input, and the DC bus
voltage for the four series-stacked system is 48 V, which is provided by a DC
power supply (HP 6674A). The servers’ computational load is represented
by running the standard Linux stress utility [29], or running the Hadoop
software [30]. The voltage and current data in the system are sampled by
a data acquisition unit (DAQ) from National Instruments at 5000 samples
per second. The currents are converted to voltages with sense resistors and
amplifiers (which are calibrated with an Agilent 34461A 6 1/2 digit mul-
timeter) for the DAQ to sample. The control algorithm for the four DPP
converters is implemented on a single off-board microcontroller (TI C2000
Piccolo F28069). Figure 5.1(a) and 5.1(b) show the schematic drawing and
photo of the testbed respectively.
For future experimental work, a new testbed is planned based on a new
model as the server - the Intel Next-Unit-of-Computing (NUC). NUC is a
smaller sized yet more powerful server than the Dell Optiplex servers. The
new server is just a single motherboard, and to connect it inside the series-
stacked architecture, additional custom-made daughter-board and mother-
board are designed and built, as shown in Fig. 5.2 and 5.3 respectively. The
26
AAA
i S
1
i S
tri
ng
i B
us
A
i S
2
A
i S
3
A
i S
4
+ -v
S1 + -v
S2 + -v
S3 + -v
S4
+ -
v
St
ac
k1
+ -
v
St
ac
k2
+ -
v
St
ac
k3
+ -
v
St
ac
k4
V
B
us
D
C
D
C
Se
rv
er
1
Se
rv
er
2
Se
rv
er
3
Se
rv
er
4
D
C
D
C
D
C
D
C
D
C
D
C
(a
)
T
h
e
sc
h
em
at
ic
of
th
e
te
st
b
ed
fo
r
th
e
se
rv
er
-
to
-b
u
s
ar
ch
it
ec
tu
re
.
C
ur
re
nt
 
se
ns
or
 b
oa
rd
M
ic
ro
co
nt
ro
lle
r b
oa
rd
Tw
is
te
d-
pa
ir 
ca
bl
e 
fo
r s
ig
na
ls
Se
rv
er
 
co
nn
ec
to
r
Se
rie
s-
st
ac
k 
co
nn
ec
to
r
B
us
 c
on
ne
ct
or
12
V
 1
20
W
 
se
rv
er
(b
)
T
h
e
p
h
o
to
o
f
th
e
te
st
b
ed
fo
r
th
e
se
rv
er
-t
o
-b
u
s
a
rc
h
it
ec
tu
re
.
F
ig
u
re
5.
1:
T
h
e
te
st
b
ed
fo
r
th
e
se
rv
er
-t
o-
b
u
s
ar
ch
it
ec
tu
re
.
27
Figure 5.2: NUC on its custom-made daughter-board.
Figure 5.3: NUC’s custom-made motherboard.
daughter-board and motherboard are equipped with PCIe edge connectors
through which they are assembled together. An example testbed with four
assembled NUC units is shown Fig. 5.4.
5.2 Experimental Results
The experiment to test the server-to-bus architecture takes 560 seconds in
total, where the servers initialize, operate and execute computation tasks and
finally shut down. When the servers are in operation, the DPP converters
are controlled using both of the above mentioned control methods. These
different situations correspond to nine different time intervals, as shown in the
28
T
ab
le
5.
1:
B
re
ak
d
ow
n
of
th
e
av
er
ag
e
in
p
u
t
an
d
ou
tp
u
t
p
ow
er
s,
th
e
av
er
ag
e
p
ow
er
lo
ss
,
th
e
sy
st
em
-l
ev
el
effi
ci
en
cy
an
d
p
ow
er
co
n
ve
rs
io
n
effi
ci
en
cy
d
u
ri
n
g
th
e
ex
p
er
im
en
t
In
te
rv
al
1
In
te
rv
al
2
In
te
rv
al
3
In
te
rv
al
4
In
te
rv
al
5
In
te
rv
al
6
In
te
rv
al
7
In
te
rv
al
8
In
te
rv
al
9
O
ve
ra
ll
T
im
e
In
te
rv
al
[s
]
0
-
12
5
12
5
-
18
5
18
5
-
24
5
24
5
-
27
5
27
5
-
30
5
30
5
-
36
5
36
5
-
42
5
42
5
-
45
5
45
5
-
56
0
0
-
56
0
<
P
in
>
[W
]
27
9.
59
46
2.
85
47
9.
69
48
4.
96
25
2.
43
41
8.
04
42
2.
88
42
1.
93
24
3.
71
36
1.
29
<
P
o
u
t
>
[W
]
26
8.
71
45
1.
43
46
7.
35
47
2.
42
24
2.
47
39
5.
72
40
1.
88
39
8.
62
23
2.
64
34
7.
15
<
P
lo
ss
>
[W
]
10
.8
7
11
.4
2
12
.3
4
12
.5
4
9.
96
22
.3
1
21
.0
1
23
.3
1
11
.0
7
14
.1
4
η s
y
s
[%
]
96
.3
1
97
.8
3
97
.7
3
97
.7
2
96
.2
2
94
.9
4
95
.3
4
94
.7
5
95
.6
4
96
.3
5
η c
o
n
v
[%
]
97
.2
1
98
.9
9
98
.9
4
98
.9
5
96
.9
7
96
.0
4
96
.7
0
95
.8
5
96
.4
3
97
.4
2
<
i S
1
>
[A
]
6.
06
9.
49
9.
87
9.
93
5.
65
9.
80
9.
91
9.
87
5.
20
7.
88
<
i S
2
>
[A
]
6.
13
9.
48
9.
88
9.
97
5.
72
9.
84
10
.1
6
9.
92
5.
16
7.
92
<
i S
3
>
[A
]
5.
47
9.
48
9.
71
9.
84
4.
14
3.
80
3.
84
3.
75
4.
94
5.
97
<
i S
4
>
[A
]
4.
97
9.
69
10
.0
5
10
.2
1
4.
86
10
.0
2
10
.2
1
10
.1
7
4.
28
7.
55
<
i s
tr
in
g
>
[A
]
6.
17
9.
59
9.
94
10
.0
0
5.
59
8.
77
10
.2
7
8.
73
5.
40
7.
82
29
Figure 5.4: Example testbed with four assembled NUC units.
detailed current and voltage waveforms in Fig. 5.5. Based on the voltage and
current data, the input power to the system Pin is calculated by multiplying
the bus voltage and current, and the output power Pout is calculated by
summing the multiplication of the individual server voltages and currents.
The power loss Ploss is the difference between Pin and Pout.
Ploss = Pin − Pout. (5.1)
There are various sources for the power loss in the system. Firstly, there is
the power loss from the DPP converters, Ploss,conv. Apart from this, there are
power losses from the current sensing resistors, Ploss,meas; from system wiring,
Ploss,wiring; from the hot-swapping switches, Ploss,HS, etc. Based on these
understandings, two types of power delivery efficiencies are calculated: One
is system-level efficiency, ηsys, where the loss from current sensing resistors
is excluded,
ηsys = 1− Ploss − Ploss,meas
Pin
. (5.2)
The other is power conversion efficiency, ηconv, where the power losses from
current sensing resistors, system wiring and the hot-swapping switches are
30
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
IBus[A]
05
1
0
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
IString[A]
05
1
0
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
IS1[A]
05
1
0
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
VS1[V]
1
1
.51
2
1
2
.5
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
IS2[A]
05
1
0
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
VS2[V]
1
1
.51
2
1
2
.5
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
IS3[A]
05
1
0
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
VS3[V]
1
1
.51
2
1
2
.5
T
im
e
[s
]
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
IS4[A]
05
1
0
T
im
e
[s
]
0
1
0
0
2
0
0
3
0
0
4
0
0
5
0
0
VS4[V]
1
1
.51
2
1
2
.5
(4
)
(5
)
(6
)
(2
)
(1
)
(3
)
(7
)
(8
)
(9
)
(4
)
(5
)
(6
)
(2
)
(1
)
(3
)
(7
)
(8
)
(9
)
F
ig
u
re
5.
5:
C
u
rr
en
t
an
d
vo
lt
ag
e
w
av
ef
or
m
s
d
u
ri
n
g
th
e
ex
p
er
im
en
t.
31
excluded,
ηconv = 1− Ploss − Ploss,meas − Ploss,wiring − Ploss,HS
Pin
. (5.3)
A similar calculation is explained in detail in [17]. A breakdown of the
average input and output powers, the average power loss, the system-level
efficiency ηsys and power conversion efficiency ηconv is given in Table 5.1, and
the average current of each server during each interval is also listed at the
bottom of the table.
As can be seen in Fig. 5.5, all server voltages are regulated to their nominal
12 V throughout the entire test. This verifies the effectiveness of both con-
trol methods for the DPP converters. In the first 125-second time interval,
the servers are initialized. The loads are not so balanced during this period,
and the series-stacked system has not yet achieved it highest efficiency. The
system-level efficiency is calculated as 96.31% and the power conversion effi-
ciency is calculated as 97.21%. Then the next three time intervals (Intervals
2, 3 and 4) represent the scenario when the server loads are quite balanced,
which is very advantageous for the series-stacked power delivery architecture.
Here the four servers are all running the Linux Stress computation tasks for
altogether 150 s. In the first 60 s (Interval 2) and last 30 s (Interval 4), the
DPP converters are controlled with the normal voltage hysteresis control,
and in the second 60 s (Interval 3, shaded area in Fig. 5.5), the converters
are controlled with the optimal string current control. The highest efficien-
cies are achieved here, with the power conversion efficiency reaching 98.99%
and system-level efficiency reaching 97.83% in Interval 2. One may notice
that the efficiencies when the optimal string current control is employed are
slightly lower than those with the normal voltage hysteresis control. Actu-
ally, when the four server loads are very balanced (their currents very close),
the string current will settle at the near-optimal region regardless of whether
one uses the normal voltage hysteresis control or the optimal-string current
control method. The advantage of the optimal string current control is not
apparent in this scenario, and its efficiency may be deteriorated by the larger
voltage ripples and thus larger losses in the stack-side capacitors when try-
ing to regulate the four server voltages using just three DPP converters in
this control method. The benefits brought by the optimized string current
become evident when the server loads are quite unbalanced - when the string
32
current with the normal control method may not settle at the optimal value.
This scenario is represented by Intervals 6, 7 and 8, when three servers (server
1, 2 and 4 ) are being stressed while one server is idle (server 3). For the
first 60 s (Interval 6) and last 30 s (Interval 8), the DPP converters are con-
trolled with the voltage hysteresis control, and for the second 60 s (Interval
7, shaded area in Fig. 5.5), the converters are controlled with the optimal
string current control. Now it can be seen that the efficiencies correspond-
ing to the optimal string current control are higher than with the voltage
hysteresis control method. There is a 0.66% boost in power conversion effi-
ciency when changing from the normal hysteresis control (Interval 6) to the
optimal string current control (Interval 7), and a 0.85% efficiency drop when
changing from the optimal string current control (Interval 7) back to the
normal hysteresis control (Interval 8). Also it can be noted that the string
current rises from 8.77 A to 10.27 A when changing from the normal voltage
hysteresis control to the optimal string current control, where the average
string current < istring > is effectively equal to the second largest sever cur-
rent iS2 (< istring > is slightly larger as shown in Table 5.1 because a small
portion of it also flows to power the logic circuits in the DPP converters).
After these three intervals, the servers are shut down in Interval 9. Interval
5 is an interval between the two long computation tasks, during which the
four servers are idle. Over the entire experiment period, the system-level effi-
ciency and power conversion efficiency are calculated as 96.35% and 97.42%,
respectively.
33
Chapter 6
CONCLUSION
This thesis presents the first proof-of-concept experimental demonstration of
a fully operational server-to-bus DPP architecture for data center power de-
livery. The server-to-bus DPP architecture has its unique advantages of being
able to achieve the minimum power processed in the DPP converters, as well
as having higher reliability than other DPP architectures. DAB converters
with GaN switches are used as the DPP converters in the prototype. 98.99%
efficiency is achieved while the servers are running real-life data center op-
eration. This work also shows with experiments that the server-to-bus DPP
architecture can deliver power to n servers with only (n− 1) DPP converters
in operation, which implies that the server-to-bus architecture can tolerate
one converter failure. Future work will include the hot-swapping operations
of the servers as well as optimization of the system to further improve power
delivery efficiency.
34
References
[1] E. Candan, P. S. Shenoy, and R. C. N. Pilawa-Podgurski, “A distributed
bi-directional hysteresis control algorithm for server-to-virtual bus differ-
ential power processing,” in Proc. IEEE 16th Workshop Control Model.
Power Electron., July 2015, pp. 1–8.
[2] A. Shehabi, S. Smith, D. Sartor, R. Brown, M. Herrlin, J. Koomey,
E. Masanet, N. Horner, I. Azevedo, and W. Lintner, “United States
data center energy usage report,” Ernest Orlando Lawrence Berkeley
National Laboratory, Tech. Rep., 2016.
[3] R. Miftakhutdinov, Improving System Efficiency with a New
Intermediate-Bus Architecture, Texas Instruments Inc. Seminar, 2009.
[Online]. Available: http://www.ti.com/download/trng/docs/seminar/
Topic 4 Rais.pdf
[4] N. Rasmussen, “Ac vs. dc power distribution for data centers,” Schneider
Electric Inc., Tech. Rep., 2011.
[5] A. Pratt, P. Kumar, and T. V. Aldridge, “Evaluation of 400V dc distri-
bution in telco and data centers to improve energy efficiency,” in INT-
ELEC 07 - 29th International Telecommunications Energy Conference,
Sept 2007, pp. 32–39.
[6] R. C. N. Pilawa-Podgurski and D. J. Perreault, “Merged two-stage power
converter with soft charging switched-capacitor stage in 180 nm cmos,”
IEEE Journal of Solid-State Circuits, vol. 47, no. 7, pp. 1557–1567, July
2012.
[7] W. C. Liu, P. Assem, Y. Lei, P. K. Hanumolu, and R. Pilawa-Podgurski,
“A 94.2%-peak-efficiency 1.53A direct-battery-hook-up hybrid dickson
switched-capacitor dc-dc converter with wide continuous conversion ra-
tio in 65nm cmos,” in 2017 IEEE International Solid-State Circuits Con-
ference (ISSCC), Feb 2017, pp. 182–183.
[8] Y. Lei, Z. Ye, and R. C. N. Pilawa-Podgurski, “A GaN-based 97% ef-
ficient hybrid switched-capacitor converter with lossless regulation ca-
pability,” in 2015 IEEE Energy Conversion Congress and Exposition
(ECCE), Sept 2015, pp. 4264–4270.
35
[9] M. Schuck, A. D. Ho, and R. C. N. Pilawa-Podgurski, “Asymmetric
interleaving in low-voltage cmos power management with multiple sup-
ply rails,” IEEE Transactions on Power Electronics, vol. 32, no. 1, pp.
715–722, Jan 2017.
[10] S. J. Kim, R. K. Nandwana, Q. Khan, R. Pilawa-Podgurski, and P. K.
Hanumolu, “A 1.8V 30-to-70MHz 87% peak-efficiency 0.32mm2 4-phase
time-based buck converter consuming 3µA/MHz quiescent current in
65nm cmos,” in 2015 IEEE International Solid-State Circuits Confer-
ence - (ISSCC) Digest of Technical Papers, Feb 2015, pp. 1–3.
[11] P. S. Shenoy and P. T. Krein, “Differential power processing for dc
systems,” IEEE Trans. Power Electron., vol. 28, no. 4, pp. 1795–1806,
April 2013.
[12] A. Stillwell and R. C. N. Pilawa-Podgurski, “A resonant switched-
capacitor converter with GaN transistors for series-stacked processors
with 99.8% power delivery efficiency,” in 2015 IEEE Energy Conversion
Congress and Exposition (ECCE), Sept 2015, pp. 563–570.
[13] J. McClurg, R. Pilawa-Podgurski, and P. Shenoy, “A series-stacked ar-
chitecture for high-efficiency data center power delivery,” in Proc. 2014
IEEE Energy Conversion Congr. Expo., Sept 2014, pp. 170–177.
[14] D. Das and P. T. Krein, “Voltage regulation of a series-stacked system
of processors by differential power processing,” in Proc. 2015 IEEE 16th
Workshop Control Modeling Power Electron., July 2015, pp. 1–7.
[15] E. Candan, P. S. Shenoy, and R. C. N. Pilawa-Podgurski, “A series-
stacked power delivery architecture with isolated differential power con-
version for data centers,” IEEE Trans. Power Electron., vol. 31, no. 5,
pp. 3690–3703, May 2016.
[16] E. Candan, P. Shenoy, and R. C. N. Pilawa-Podgurski, “Unregulated
bus operation of server-to-virtual bus differential power processing for
data centers,” in 2017 IEEE Applied Power Electronics Conference and
Exposition (APEC), March 2017, pp. 1632–1639.
[17] E. Candan, D. Heeger, P. S. Shenoy, and R. C. N. Pilawa-Podgurski,
“Hot-swapping analysis and implementation of series-stacked server
power delivery architectures,” IEEE Transactions on Power Electron-
ics, vol. 32, no. 10, pp. 8071–8088, Oct 2017.
[18] S. Qin, S. T. Cady, A. D. Dominguez-Garcia, and R. C. N. Pilawa-
Podgurski, “A distributed approach to maximum power point tracking
for photovoltaic submodule differential power processing,” IEEE Trans-
actions on Power Electronics, vol. 30, no. 4, pp. 2024–2040, April 2015.
36
[19] Y. T. Jeon, H. Lee, K. A. Kim, and J. H. Park, “Least power point
tracking method for photovoltaic differential power processing systems,”
IEEE Trans. Power Electron., vol. 32, no. 3, pp. 1941–1951, March 2017.
[20] R. Bell and R. C. N. Pilawa-Podgurski, “Asynchronous and distributed
maximum power point tracking of series-connected photovoltaic sub-
modules using differential power processing,” in Proc. IEEE 15th Work-
shop Control Model. Power Electron., June 2014, pp. 1–8.
[21] J. McClurg, Y. Zhang, J. Wheeler, and R. Pilawa-Podgurski, “Re-
thinking data center power delivery: Regulating series-connected voltage
domains in software,” in 2013 IEEE Power and Energy Conference at
Illinois (PECI), Feb 2013, pp. 147–154.
[22] P. S. Shenoy, “Improving performance, efficiency, and reliability of dc-dc
conversion systems by differential power processing,” Ph.D. dissertation,
University of Illinois at Urbana-Champaign, 2012.
[23] E. Candan, A. Stillwell, and R. C. N. Pilawa-Podgurski, “A reliability
assessment of series-stacked servers with server-to-bus differential power
processing,” in Proc. IEEE 38th Int. Telecommun. Energy Conf., Oct
2016, pp. 1–7.
[24] F. Krismer and J. Kolar, “Accurate power loss model derivation of a
high-current dual active bridge converter for an automotive application,”
Ind. Electron., IEEE Trans., vol. 57, no. 3, pp. 881–891, March 2010.
[25] D. Costinett, H. Nguyen, R. Zane, and D. Maksimovic, “GaN-FET
based dual active bridge dc-dc converter,” in 2011 Twenty-Sixth Annual
IEEE Applied Power Electronics Conference and Exposition (APEC),
March 2011, pp. 1425–1432.
[26] D. Costinett, D. Maksimovic, and R. Zane, “Design and control for high
efficiency in high step-down dual active bridge converters operating at
high switching frequency,” IEEE Transactions on Power Electronics,
vol. 28, no. 8, pp. 3931–3940, Aug 2013.
[27] J. Strydom and D. Reusch, Dead-Time Optimization for Maximum
Efficiency, Efficient Power Conversion Corporation, 2013. [Online].
Available: http://epc-co.com/epc/Portals/0/epc/documents/papers/
Dead-Time%20Optimization%20for%20Maximum%20Efficiency.pdf
[28] Coilcraft, Document 1280-1 Planar Transformers, 2015. [Online].
Available: http://www.coilcraft.com/pdfs/planar trans.pdf
[29] A. Waterland, Stress POSIX workload generator. [Online]. Available:
http://people.seas.harvard.edu/∼apw/stress
37
[30] Apache Hadoop Project. [Online]. Available: http://hadoop.apache.org
38
Appendix A
PROTOTYPE DPP HARDWARE
COMPONENT LIST AND PCB LAYOUT
Table A.1: The key components of the DPP converter
GaN Switches EPC 2032 (Bus side)
EPC 2030 (Server side)
GaN Gate Drivers TI LM5113
Transformer Coilcraft PL300-100L, 8:2 turns
Inductor Coilcraft SLC1480-201ML, 200 nH
Cin ceramics 8× 1 µF, TDK
aluminum 2× 68 µF SMD, Panasonic
Cout ceramics 8× 4.7 µF, TDK
aluminum 2× 1 mF SMD, Panasonic
39
5 5
4 4
3 3
2 2
1 1
D
D
C
C
B
B
A
A
g
r
o
u
p
:
 
t
o
 
m
i
c
r
o
c
o
n
t
r
o
l
l
e
r
g
r
o
u
p
:
 
t
o
 
m
i
c
r
o
c
o
n
t
r
o
l
l
e
r
g
r
o
u
p
:
 
t
o
 
d
a
t
a
 
a
c
q
u
i
s
i
t
i
o
n
 
u
n
i
t
g
r
o
u
p
:
 
t
o
 
d
a
t
a
 
a
c
q
u
i
s
i
t
i
o
n
 
u
n
i
t
V
_
5
_
B
u
s
V
_
3
_
3
_
B
u
s
V
_
B
u
s
-
V
_
5
_
S
ta
c
k
V
_
S
ta
ck
-
V
_
B
u
s
+
V
_
S
ta
ck
-
V
_
B
u
s
-
V
_
B
u
s
-
V
_
5
_
G
N
D
V
_
G
N
D
V
_
S
e
rv
e
r+
V
_
S
e
rv
e
r-
V
_
S
ta
ck
-
V
_
B
u
s
-
V
_
G
N
D
V
_
S
ta
ck
+
V
_
S
ta
ck
+
V
_
S
ta
ck
-
V
_
B
u
s
-
V
_
S
e
rv
e
r+
V
_
S
e
rv
e
r+
_
H
ig
h
V
_
B
u
s
+
V
_
B
u
s
+
_
D
P
P
V
_
B
u
s
-
V
_
S
e
rv
e
r-
V
_
S
ta
ck
-
V
_
S
ta
ck
+
P
W
M
_
1
L
_
B
u
s
P
W
M
_
1
H
_
B
u
s
P
W
M
_
3
L
_
B
u
s
P
W
M
_
3
H
_
B
u
s
P
W
M
_
2
L
_
B
u
s
P
W
M
_
2
H
_
B
u
s
P
W
M
_
4
L
_
B
u
s
P
W
M
_
4
H
_
B
u
s
P
W
M
_
1
L
_
B
u
s
P
W
M
_
1
H
_
B
u
s
P
W
M
_
3
L
_
B
u
s
P
W
M
_
3
H
_
B
u
s
P
W
M
_
2
L
_
B
u
s
P
W
M
_
2
H
_
B
u
s
P
W
M
_
4
L
_
B
u
s
P
W
M
_
4
H
_
B
u
s
E
N
B
L
_
H
S
_
B
u
s
E
N
B
L
_
L
S
_
B
u
s
E
N
B
L
_
H
S
_
H
R
_
B
u
s
E
N
B
L
_
S
T
A
C
K
_
B
u
s
P
W
M
_
4
L
_
S
ta
c
k
P
W
M
_
4
H
_
S
ta
c
k
P
W
M
_
3
L
_
S
ta
c
k
P
W
M
_
3
H
_
S
ta
c
k
E
N
B
L
_
H
S
_
H
R
_
G
a
te
E
N
B
L
_
S
T
A
C
K
_
G
a
te
E
N
B
L
_
L
S
_
G
a
te
E
N
B
L
_
H
S
_
G
a
te
E
N
B
L
_
H
S
_
H
R
_
S
ta
c
k
E
N
B
L
_
S
T
A
C
K
_
S
ta
c
k
E
N
B
L
_
L
S
_
S
ta
c
k
E
N
B
L
_
H
S
_
S
ta
c
k
I_
M
e
a
s_
S
e
rv
e
r_
V
o
u
t
S
_
P
ro
t_
C
o
m
p
+
I_
M
e
a
s_
S
e
rv
e
r_
V
o
u
t
I_
M
e
a
s_
C
n
v
t_
V
o
u
t
I_
M
e
a
s_
S
e
rv
e
r_
V
re
f
I_
M
e
a
s_
C
n
v
t_
V
re
f
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
1
6
W
e
d
n
e
s
d
a
y
, 
J
u
ly
 0
6
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
1
6
W
e
d
n
e
s
d
a
y
, 
J
u
ly
 0
6
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
1
6
W
e
d
n
e
s
d
a
y
, 
J
u
ly
 0
6
, 
2
0
1
6
B
U
S
_
P
O
W
E
R
1
P
o
w
e
r 
C
o
n
n
e
c
to
r
1 2 3 4
J
8
8
 H
E
A
D
E
R
12345678
D
C
_
L
O
G
IC
S
_
B
U
S
1
P
o
w
e
r 
C
o
n
n
e
c
to
r
1 2 3 4
J
2
1
4
 H
E
A
D
E
R
1 2 3 4
J
4
1
2
 H
E
A
D
E
R1 2 3 4 5 6 7 8 9 1
0
1
1
1
2
D
C
_
L
O
G
IC
S
_
S
T
A
C
K
1
P
o
w
e
r 
C
o
n
n
e
c
to
r
1 2
R
3
0
R
2
0
R
5
0
S
E
R
IE
S
_
S
T
A
C
K
1
P
o
w
e
r 
C
o
n
n
e
c
to
r
1 2 3 4
R
4
6
0
J
2
2
4
 H
E
A
D
E
R
1 2 3 4
J
1
8
 H
E
A
D
E
R
12345678
J
5
8
 H
E
A
D
E
R
12345678
R
4
0
S
E
R
V
E
R
1
P
o
w
e
r 
C
o
n
n
e
c
to
r
1 2 3 4
J
1
8
4
 H
E
A
D
E
R
1 2 3 4
J
3
1
2
 H
E
A
D
E
R
123456789
1
0
1
1
1
2
J
2
1
2
 H
E
A
D
E
R1 2 3 4 5 6 7 8 9 1
0
1
1
1
2
E
X
T
_
5
V
1
P
o
w
e
r 
C
o
n
n
e
c
to
r
1 2
J
1
9
H
e
a
d
e
r 
1
01 2 3 4 5 6 7 8 9 1
0
F
ig
u
re
A
.1
:
S
ch
em
at
ic
of
co
n
n
ec
to
rs
.
40
5 5
4 4
3 3
2 2
1 1
D
D
C
C
B
B
A
A
V
_
5
_
B
u
s
V
_
B
u
s
-
V
_
5
_
B
u
s
V
_
B
u
s
-
V
_
5
_
S
ta
c
k
V
_
S
ta
ck
-
V
_
5
_
S
ta
c
k
V
_
S
ta
ck
-
V
_
B
u
s
+
_
D
P
P
V
_
S
ta
ck
+
V
_
B
u
s
+
_
D
P
P
V
_
S
ta
ck
+
V
_
B
u
s
-
V
_
S
ta
ck
-
V
_
B
u
s
-
V
_
S
ta
ck
-
V
_
B
u
s
-
V
_
B
u
s
-
V
_
S
ta
ck
-
V
_
S
ta
ck
-
P
W
M
_
1
H
_
B
u
s
P
W
M
_
1
L
_
B
u
s
P
W
M
_
2
H
_
B
u
s
P
W
M
_
2
L
_
B
u
s
P
W
M
_
3
H
_
S
ta
c
k
P
W
M
_
3
L
_
S
ta
c
k
P
W
M
_
4
H
_
S
ta
c
k
P
W
M
_
4
L
_
S
ta
c
k
B
ri
d
g
e
_
B
u
s
+
B
ri
d
g
e
_
B
u
s
-
B
ri
d
g
e
_
S
ta
c
k+
B
ri
d
g
e
_
S
ta
c
k-
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
6
6
S
u
n
d
a
y,
 J
u
n
e
 2
6
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
6
6
S
u
n
d
a
y,
 J
u
n
e
 2
6
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
6
6
S
u
n
d
a
y,
 J
u
n
e
 2
6
, 
2
0
1
6
R
2
7
0
C
6
9
1
0
u
F
C
T
4
0
.1
u
F
U
2
6
D
rG
a
N
_
C
a
p
V
D
D
1
H
I
2
L
I
3
A
G
N
D
4
V
IN
5
S
W
6
P
G
N
D
7
C
6
8
1
0
u
F
T
P
3
T
e
st
 P
o
in
t
1
R
2
4
3
0
.9
k
C
6
2
5
u
F
C
6
3
5
u
F
C
6
7
1
0
u
F
C
T
3
0
.1
u
F
T
P
6
T
e
st
 P
o
in
t
1
R
4
1
3
0
.9
k
R
2
6
0
R
2
8
0
C
T
1
0
.1
u
F
C
T
8
0
.1
u
F
R
4
4
3
0
.9
k
T
P
4
T
e
st
 P
o
in
t
1
T
P
1
T
e
st
 P
o
in
t
1
U
2
5
D
rG
a
N
_
C
a
p
V
D
D
1
H
I
2
L
I
3
A
G
N
D
4
V
IN
5
S
W
6
P
G
N
D
7
R
3
0
0
U
2
3
D
rG
a
N
_
C
a
p
V
D
D
1
H
I
2
L
I
3
A
G
N
D
4
V
IN
5
S
W
6
P
G
N
D
7
C
T
2
0
.1
u
F
C
7
1
1
0
u
F
C
T
7
0
.1
u
F
L
1
IN
D
U
C
T
O
R
T
R
1
P
L
3
0
0
.2
2
.3
3
4
4
5
5
.7
7
.8
8
.9
9
.10
10
11
11
C
7
0
1
0
u
F
C
6
5
5
u
F
R
4
2
3
0
.9
k
U
2
4
D
rG
a
N
_
C
a
p
V
D
D
1
H
I
2
L
I
3
A
G
N
D
4
V
IN
5
S
W
6
P
G
N
D
7
R
4
5
3
0
.9
k
C
T
6
0
.1
u
F
R
3
9
3
0
.9
k
R
2
9
0
C
7
7
1
0
u
F
R
3
1
0
C
7
5
1
0
u
F
C
5
4
1
0
u
F
C
7
6
1
0
u
F
C
6
4
5
u
F
C
T
5
0
.1
u
F
C
7
4
1
0
u
F
T
P
9
T
e
st
 P
o
in
t
1
T
P
2
T
e
st
 P
o
in
t
1
R
4
0
3
0
.9
k
C
7
3
1
0
u
F
R
4
3
3
0
.9
k
C
7
2
1
0
u
F
F
ig
u
re
A
.2
:
S
ch
em
at
ic
of
p
ow
er
st
ag
e.
41
5 5
4 4
3 3
2 2
1 1
D
D
C
C
B
B
A
A
V
_
3
_
3
_
B
u
s
V
_
5
_
S
ta
c
k
V
_
B
u
s
-
V
_
S
ta
ck
-
V
_
3
_
3
_
B
u
s
V
_
B
u
s
-
V
_
5
_
S
ta
c
k
V
_
S
ta
ck
-
V
_
5
_
B
u
s
V
_
B
u
s
-
V
_
5
_
V
_
S
e
rv
e
r+
V
_
S
e
rv
e
r+
_
H
ig
h
P
W
M
_
3
L
_
S
ta
c
k
P
W
M
_
3
L
_
B
u
s
P
W
M
_
3
H
_
S
ta
c
k
P
W
M
_
4
H
_
S
ta
c
k
P
W
M
_
3
H
_
B
u
s
P
W
M
_
4
H
_
B
u
s
P
W
M
_
4
L
_
B
u
s
P
W
M
_
4
L
_
S
ta
c
k
S
_
P
ro
t_
C
o
m
p
+
_
S
ta
c
k
E
N
B
L
_
S
T
A
C
K
_
B
u
s
E
N
B
L
_
S
T
A
C
K
_
S
ta
c
k
S
_
P
ro
t_
C
o
m
p
+
E
N
B
L
_
L
S
_
S
ta
c
k
E
N
B
L
_
L
S
_
B
u
s
E
N
B
L
_
H
S
_
S
ta
c
k
E
N
B
L
_
H
S
_
H
R
_
S
ta
c
k
E
N
B
L
_
H
S
_
B
u
s
E
N
B
L
_
H
S
_
H
R
_
B
u
s
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
3
6
W
e
d
n
e
s
d
a
y
, 
J
u
n
e
 2
2
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
3
6
W
e
d
n
e
s
d
a
y
, 
J
u
n
e
 2
2
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
3
6
W
e
d
n
e
s
d
a
y
, 
J
u
n
e
 2
2
, 
2
0
1
6
C
1
4
0
.1
u
F
U
9
S
I8
4
2
3
V
d
d
1
1
A
1
2
A
2
3
G
N
D
1
4
G
N
D
2
5
B
2
6
B
1
7
V
d
d
2
8
C
1
5
0
.1
u
F
C
1
1
0
.1
u
F
U
8
IS
O
7
2
4
1
M
_
D
W
_
1
6
V
C
C
1
1
G
N
D
1
2
IN
A
3
IN
B
4
IN
C
5
O
U
T
D
6
E
N
1
7
G
N
D
1
_
1
8
G
N
D
2
9
E
N
2
1
0
IN
D
1
1
O
U
T
C
1
2
O
U
T
B
1
3
O
U
T
A
1
4
G
N
D
2
_
1
1
5
V
C
C
2
1
6
U
7
IS
O
7
2
4
0
M
_
D
W
_
1
6
V
C
C
1
1
G
N
D
1
2
IN
A
3
IN
B
4
IN
C
5
IN
D
6
N
C
7
G
N
D
1
_
1
8
G
N
D
2
9
E
N
1
0
O
U
T
D
1
1
O
U
T
C
1
2
O
U
T
B
1
3
O
U
T
A
1
4
G
N
D
2
_
1
1
5
V
C
C
2
1
6
C
1
2
0
.1
u
F
C
1
0
0
.1
u
F
C
1
3
0
.1
u
F
F
ig
u
re
A
.3
:
S
ch
em
at
ic
of
si
gn
al
is
ol
at
io
n
.
42
5 5
4 4
3 3
2 2
1 1
D
D
C
C
B
B
A
A
V
_
S
ta
ck
+
V
_
S
ta
ck
-
V
_
5
_
S
ta
c
k
V
_
5
_
B
u
s
_
2
V
_
B
u
s
-
V
_
3
_
3
_
B
u
s
V
_
5
_
V
_
S
e
rv
e
r+
V
_
S
e
rv
e
r+
_
H
ig
h
V
_
5
_
G
N
D
V
_
5
_
B
u
s
V
_
B
u
s
-
V
_
5
_
B
u
s
V
_
5
_
B
u
s
_
2
V
_
5
_
B
u
s
_
2
V
_
5
_
B
u
s
V
_
B
u
s
-
V
_
G
N
D
V
_
5
_
B
u
s
_
2
V
_
B
u
s
+
_
D
P
P
V
_
B
u
s
+
_
D
P
P
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
5
6
W
e
d
n
e
s
d
a
y
, 
J
u
ly
 0
6
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
5
6
W
e
d
n
e
s
d
a
y
, 
J
u
ly
 0
6
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
5
6
W
e
d
n
e
s
d
a
y
, 
J
u
ly
 0
6
, 
2
0
1
6
R
B
1
1
0
k
C
2
6
1
u
F
R
2
1
0
U
2
0
L
T
3
0
1
0
-5
1
1
2
2
3
3
4
4
5
5
6
6
7
7
8
8
9
9
C
B
1
0
.1
u
F
C
C
2
1
0
u
F
C
B
2
0
.1
u
F
C
C
1
1
0
u
F
C
B
4
0
.1
u
F
U
2
1
L
T
3
0
1
0
-5
1
1
2
2
3
3
4
4
5
5
6
6
7
7
8
8
9
9
R
B
2
3
0
.9
k
C
B
3
0
.1
u
F
U
B
1
A
D
U
M
5
2
1
0
B
R
S
Z
V
D
D
1
1
G
N
D
p
1
2
V
IA
3
V
IB
4
G
N
D
p
2
5
G
N
D
p
3
6
P
D
IS
8
V
D
D
p
9
G
N
D
p
4
1
0
G
N
D
is
o
4
1
1
V
is
o
1
2
V
s
e
l
1
3
G
N
D
is
o
3
1
5
G
N
D
is
o
2
1
6
V
O
B
1
7
V
O
A
1
8
G
N
D
is
o
1
1
9
V
D
D
2
2
0
R
B
3
1
0
k
C
2
5
1
u
F
R
2
0
0
C
2
8
1
0
0
n
F
R
3
6
0
L
D
O
_
3
_
3
V
_
B
U
S
1
L
P
2
9
8
5
-3
3
_
D
B
V
_
5
V
IN
1
G
N
D
2
O
N
/*
O
F
F
3
B
Y
P
A
S
S
4
V
O
U
T
5
U
2
2
N
C
V
4
2
6
4
-2
1
1
2
2
3
3
4
4
C
2
4
1
u
F
C
3
0
1
u
F
C
3
2
1
0
n
F
C
2
9
2
2
u
F
C
2
7
1
u
F
C
3
1
2
.2
u
F
F
ig
u
re
A
.4
:
S
ch
em
at
ic
of
lo
gi
c
D
C
su
p
p
li
es
.
43
5 5
4 4
3 3
2 2
1 1
D
D
C
C
B
B
A
A
V
_
S
ta
ck
-
V
_
S
ta
ck
+
V
_
5
_
S
ta
c
k
V
_
S
ta
ck
+
V
_
S
ta
ck
-
V
_
S
ta
ck
-
V
_
5
_
S
ta
c
k
V
_
S
ta
ck
-
V
_
S
ta
ck
-
V
_
5
_
S
ta
c
k
V
_
S
e
rv
e
r+
_
H
ig
h
V
_
S
ta
ck
+
V
_
S
e
rv
e
r-
V
_
S
ta
ck
-
ENBL_STACK_Stack
ENBL_STACK_Gate
S_Prot_Comp+_Stack
ENBL_HS_Gate
E
N
B
L
_
H
S
_
H
R
_
G
a
te
ENBL_HS_Stack
ENBL_HS_HR_Stack
E
N
B
L
_
L
S
_
G
a
te
ENBL_LS_Stack
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
4
6
F
ri
d
a
y,
 J
u
n
e
 2
4
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
4
6
F
ri
d
a
y,
 J
u
n
e
 2
4
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
4
6
F
ri
d
a
y,
 J
u
n
e
 2
4
, 
2
0
1
6
U
1
1
IR
L
S
4
0
3
0
P
b
F
G
1
S
3
D
2
R
1
5
2
0
0
R
1
3
1
0
0
K
U
1
4
IR
L
S
4
0
3
0
P
b
F
G
1
S
3
D
2
D
1
C
D
B
U
0
5
3
0
C
2
0 1
0
p
U
1
2
IR
L
S
4
0
3
0
P
b
F
G
1
S
3
D
2
C
2
3
0
.4
7
u
F
C
1
7 1
0
p
R
1
6
5
.1
K
R
1
4
2
0
0
U
1
9
C
S
D
8
7
5
0
2
Q
2
S
1
1
G
1
2
D
2
3
D
1
6
G
2
5
S
2
4
D1_1
7
D2_1
8
U
1
6
IR
L
S
4
0
3
0
P
b
F
G
1
S
3
D
2
R
1
8 0
C
1
8 1
0
p
R
9
1
0
0
k
R
1
9
2
.5
k
D
3
C
D
B
U
0
5
3
0
U
1
5
IR
L
S
4
0
3
0
P
b
F
G
1
S
3
D
2
R
1
7
1
0
k
C
2
2
1
0
p
C
1
9 1
0
p
T
L
3
3
1
U
1
8
IN
-
1
GND
2
IN
+
3
O
U
T
4
VCC
5
U
1
3
IR
L
S
4
0
3
0
P
b
F
G
1
S
3
D
2
D
2
C
D
B
U
0
5
3
0
U
1
0
IR
L
S
4
0
3
0
P
b
F
G
1
S
3
D
2
R
1
0
1
0
0
k
R
1
1
2
.8
C
1
6 1
0
p
C
2
1 1
0
p
R
1
2
1
0
0
k
U
1
7
R
E
F
3
0
2
5
_
D
B
Z
_
3
IN
1
O
U
T
2
G
N
D
3
F
ig
u
re
A
.5
:
S
ch
em
at
ic
of
h
ot
-s
w
ap
p
in
g,
st
ac
k
in
it
ia
li
za
ti
on
an
d
p
ro
te
ct
io
n
.
44
5 5
4 4
3 3
2 2
1 1
D
D
C
C
B
B
A
A
T
h
e
 
o
u
t
p
u
t
 
a
m
p
l
i
f
i
e
r
 
h
a
s
 
a
 
l
o
w
 
i
m
p
e
d
a
n
c
e
o
u
t
p
u
t
 
a
n
d
 
i
s
 
d
e
s
i
g
n
e
d
 
t
o
 
d
r
i
v
e
 
u
p
 
t
o
 
2
0
0
p
F
 
c
a
p
a
c
i
t
i
v
e
l
o
a
d
s
 
d
i
r
e
c
t
l
y
.
 
C
a
p
a
c
i
t
i
v
e
 
l
o
a
d
s
 
e
x
c
e
e
d
i
n
g
 
2
0
0
p
F
 
s
h
o
u
l
d
b
e
 
d
e
c
o
u
p
l
e
d
 
w
i
t
h
 
a
n
 
e
x
t
e
r
n
a
l
 
r
e
s
i
s
t
o
r
 
o
f
 
a
t
 
l
e
a
s
t
 
1
0
0
O
.
V
_
B
u
s
+
_
D
P
P
V
_
B
u
s
+
V
_
5
_
G
N
D
V
_
G
N
D
V
_
S
e
rv
e
r+
V
_
S
e
rv
e
r+
_
H
ig
h
V
_
5
_
G
N
D
V
_
G
N
D
I_
M
e
a
s_
C
n
v
t_
V
o
u
t
I_
M
e
a
s_
S
e
rv
e
r_
V
o
u
t
I_
M
e
a
s_
S
e
rv
e
r_
V
re
f
I_
M
e
a
s_
C
n
v
t_
V
re
f
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
2
6
S
a
tu
rd
a
y
, 
Ju
n
e
 2
5
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
2
6
S
a
tu
rd
a
y
, 
Ju
n
e
 2
5
, 
2
0
1
6
T
it
le
S
iz
e
D
o
cu
m
e
n
t 
N
u
m
b
e
r
R
e
v
D
a
te
:
S
h
e
e
t
o
f
<
D
o
c
>
<
R
e
v
C
o
d
e
>
<
T
it
le
>
C
u
s
to
m
2
6
S
a
tu
rd
a
y
, 
Ju
n
e
 2
5
, 
2
0
1
6
U
6
B
id
ir
e
ct
io
n
a
l 
C
u
rr
e
n
t 
S
e
n
s
e
 A
m
p
lif
ie
r
V
+
1
V
+
IN
2
V
-I
N
3
V
+
4
G
N
D
5
V
R
E
F
6
V
O
U
T
7
V
S
H
D
N
8
C
2
0
.1
u
F
U
2
B
id
ir
e
ct
io
n
a
l 
C
u
rr
e
n
t 
S
e
n
s
e
 A
m
p
lif
ie
r
V
+
1
V
+
IN
2
V
-I
N
3
V
+
4
G
N
D
5
V
R
E
F
6
V
O
U
T
7
V
S
H
D
N
8
C
9
0
.1
u
F
C
7 1
0
p
T
P
8
T
e
st
 P
o
in
t
1
R
6
7
3
.8
k
U
5
4
p
in
 S
e
n
s
e
 R
e
si
s
to
r
1
1
2
S
2
S
2
2
1
S
1
S
R
4
7
0
U
1
4
p
in
 S
e
n
s
e
 R
e
si
s
to
r
1
1
2
S
2
S
2
2
1
S
1
S
C
1 1
0
p
C
8
0
.1
u
F
R
8
1
5
5
.3
k
C
3
0
.1
u
F
F
ig
u
re
A
.6
:
S
ch
em
at
ic
of
cu
rr
en
t
se
n
si
n
g.
45
F
ig
u
re
A
.7
:
T
op
la
ye
r
of
P
C
B
.
46
F
ig
u
re
A
.8
:
G
ro
u
n
d
la
ye
r
of
P
C
B
.
47
F
ig
u
re
A
.9
:
S
ig
n
al
la
ye
r
of
P
C
B
.
48
F
ig
u
re
A
.1
0:
B
ot
to
m
la
ye
r
of
P
C
B
.
49
Appendix B
KEY MICROCONTROLLER CODE
1 // Sampling s tack v o l t a g e s and s e r v e r cu r r en t s
2
3 i n t e r r u p t void a d c i s r ( void )
4 {
5 // t h i s happens @ every sw i tch ing c y c l e (= 5mus per iod )
6
7 i f ( adc count V >= ( sampling time V − adc d iv ide r V ) ) // l a s t
n measurements , t h i s i f takes ˜300 ns
8 {
9 V4 [ adc i V ] = AdcResult .ADCRESULT1; // V4 / 6
10 V3 [ adc i V ] = AdcResult .ADCRESULT2; // V3 / 12
11 V2 [ adc i V ] = AdcResult .ADCRESULT3; // V2 / 18
12 V1 [ adc i V ] = AdcResult .ADCRESULT4; // V1 / 24
13 adc i V += 1 ;
14 }
15 i f ( adc count I == 399) // every 2000mus
16 {
17 I4 [ a d c i I 1 ] = AdcResult .ADCRESULT0;
18 I3 [ a d c i I 1 ] = AdcResult .ADCRESULT5;
19 I2 [ a d c i I 1 ] = AdcResult .ADCRESULT6;
20 I1 [ a d c i I 1 ] = AdcResult .ADCRESULT7;
21 a d c i I 1 += 1 ;
22 adc count I = 0 ;
23 }
24 e l s e
25 {
26 adc count I += 1 ;
27 }
28 i f ( a d c i I 1 == 10) // c o l l e c t e d f o r 20ms
29 {
30 I 1 f i r s t s u m [ a d c i I 2 ] = 0 ;
31 I 2 f i r s t s u m [ a d c i I 2 ] = 0 ;
32 I 3 f i r s t s u m [ a d c i I 2 ] = 0 ;
50
33 I 4 f i r s t s u m [ a d c i I 2 ] = 0 ;
34 f o r ( a d c i I 1 = 0 ; a d c i I 1 < 10 ; a d c i I 1++)
35 {
36 I 1 f i r s t s u m [ a d c i I 2 ] += I1 [ a d c i I 1 ] ;
37 I 2 f i r s t s u m [ a d c i I 2 ] += I2 [ a d c i I 1 ] ;
38 I 3 f i r s t s u m [ a d c i I 2 ] += I3 [ a d c i I 1 ] ;
39 I 4 f i r s t s u m [ a d c i I 2 ] += I4 [ a d c i I 1 ] ;
40 }
41 a d c i I 2 += 1 ;
42 a d c i I 1 = 0 ;
43 }
44 i f ( a d c i I 2 == 50) // reached the i c o n t r o l per iod o f 1 s
45 {
46 a d c I r e a d y f l a g = 1 ;
47 a d c i I 2 = 0 ;
48 }
49 i f ( adc count V == sampling time V − 1) // reached the v
c o n t r o l per iod o f 500mus
50 {
51 GpioDataRegs .GPBTOGGLE. b i t . GPIO33 = 1 ;
52 adc V ready f l ag = 1 ;
53 adc count V = 0 ;
54 }
55 e l s e
56 {
57 AdcRegs .ADCINTFLGCLR. b i t .ADCINT1 = 1 ; // Clear ADCINT1
f l a g r e i n i t i a l i z e f o r next SOC
58 PieCtr lRegs .PIEACK. a l l = PIEACK GROUP1; // Acknowledge
i n t e r r u p t to PIE
59 adc count V += 1 ;
60 }
61 re turn ;
62 }
63
64
65
66 // Determining which DPP conver t e r to be temporar i ly turned o f f
67
68 void Determine Off Dpp ( )
69 {
70 I s 1 = 0 ;
71 I s 2 = 0 ;
72 I s 3 = 0 ;
51
73 I s 4 = 0 ;
74
75 f o r ( a d c i I 2 = 0 ; a d c i I 2 < 50 ; a d c i I 2++)
76 {
77 I s 1 += ( I 1 f i r s t s u m [ a d c i I 2 ] ) ;
78 I s 2 += ( I 2 f i r s t s u m [ a d c i I 2 ] ) ;
79 I s 3 += ( I 3 f i r s t s u m [ a d c i I 2 ] ) ;
80 I s 4 += ( I 4 f i r s t s u m [ a d c i I 2 ] ) ;
81 }
82
83 I s o r t [ 0 ] = I s 1 ;
84 I s o r t [ 1 ] = I s 2 ;
85 I s o r t [ 2 ] = I s 3 ;
86 I s o r t [ 3 ] = I s 4 ;
87
88 f o r ( j = 0 ; j < 2 ; j++)
89 {
90 f o r ( k = 0 ; k < (3 − j ) ; k++)
91 {
92 i f ( I s o r t [ k ] > I s o r t [ k+1])
93 {
94 swap = I s o r t [ k ] ;
95 I s o r t [ k ] = I s o r t [ k +1] ;
96 I s o r t [ k+1] = swap ;
97 }
98 }
99 }
100
101 i f ( I s 1 == I s o r t [ 2 ] )
102 o f f dpp = 1 ;
103 i f ( I s 2 == I s o r t [ 2 ] )
104 o f f dpp = 2 ;
105 i f ( I s 3 == I s o r t [ 2 ] )
106 o f f dpp = 3 ;
107 i f ( I s 4 == I s o r t [ 2 ] )
108 o f f dpp = 4 ;
109
110 a d c i I 2 = 0 ;
111 }
mcu code.c
52
