Digital implementation of the feedforward loop of the asymmetrical half-bridge converter for LED lighting applications by Arias Pérez de Azpeitia, Manuel et al.
Digital Implementation of the Feedforward Loop of 
the Asymmetrical Half-Bridge Converter for LED 
Lighting Applications 
Manuel Arias, Marcos Fernández, Jose Evelio Rodríguez, Diego G. Lamar, Javier Sebastián 
Universidad de Oviedo, Electronic Power Supply Systems group 
Edificio 3, Campus de Viesques s/n, 33204 Gijón, SPAIN, 
 
Abstract.— The Asymmetrical Half Bridge converter 
(AHBC) has proven to be a promising candidate for LED 
lighting applications. It provides high efficiency, galvanic 
isolation and it can be easily built without electrolytic 
capacitor. On the other hand, its main drawback is its poor 
attainable bandwidth. In any two-stage ac-dc LED driver 
based on the AHBC, the first stage is a Power Factor 
Corrector (PFC) converter which has to be also implemented 
without electrolytic capacitor. As a consequence, its output 
voltage (input voltage of the AHBC) presents a low-frequency 
ripple. Due to the poor bandwidth of the AHBC, this voltage 
ripple will be transferred to the converter output voltage, 
leading to flickering. Due to the complex and non-linear 
transfer function of the AHBC, any analog feedforward loop 
has to be tuned for a given operating point, leading to a poor 
performance when the AHBC moves away from that point. In 
this paper, a digital feedforward loop is proposed in order to 
solve this problem. The digital implementation allows the 
feedforward loop to perfectly cancel the ripple under any 
condition (e.g., output voltage variation due to dimming). 
Besides, this digital feedforward loop has been designed and 
simplified considering the specific purpose of cancelling 
flickering in the emitted light. In this way, it can be easily 
implemented in small-size microcontrollers. Experimental 
results with a 40-W prototype prove the usefulness of the 
proposed feedforward loop. 
Keywords: Asymmetrical Half Bridge, Complementary 
Control, Feedforward loop, LED Lighting, Flickering. 
I. INTRODUCTION 
The advantages of LEDs in lighting applications are well-
known [1], [2]. Their luminous efficacy is very high. 
Moreover, their theoretical efficacy (not reached yet) is the 
highest one. Regarding reliability, the lifetime of LEDs is as 
long as 50,000 h or even higher. Besides, LEDs also have 
other advantages that make them the growing trend in 
lighting. For example, they are environmentally friendly, 
they are shock resistant [3], precise control of the color and 
temperature of light [4], etc. 
Nevertheless, LED strings cannot be directly connected 
to the grid [5]. Hence, one of the main issues regarding 
LEDs is developing power supplies with the same features 
that LEDs have so that the couple LEDs plus converter 
keeps all the advantages of those. As a consequence, many 
topologies with high efficiency and high reliability (i.e., 
long lifespan [6]) have been proposed in order to supply 
different kind of LED lamps (retrofit, street lighting, 
commercial or industrial, etc.). Besides, other common 
requirements imposed to these power supplies are Power 
Factor (PF) correction [7], [8] and galvanic isolation [9], 
[10]. Any lighting device connected to the grid has to 
comply with Energystar or IEC 61000-3-2 Regulations. The 
galvanic isolation may be a customer’s requirement or 
something established by local regulations. Obviously, cost 
is a feature that cannot be set aside. As a consequence, it is 
possible to classify all the LED drivers depending on the 
number of stages. 
One-stage and integrated two-stage topologies [11]-[17] 
are used when the cost of the lamp is of primary concern, 
rather than efficiency or lifetime. On the other hand, two-
stage [18], [19] and three-stage [20], [21] topologies 
(optimized for reaching very high efficiency in spite of the 
number of power conversions) are preferred when the 
saving that represents a higher efficiency and a longer 
lifespan is more important than the saving that represents 
the cost per unit. 
In [22], the use of a two-stage topology is proposed as 
LED driver for a street-lighting application. The first stage 
is a PFC boost converter with an efficiency as high as 97%-
98%. As it is implemented without electrolytic capacitor, its 
output voltage is affected by a 15% low-frequency ripple. 
The second stage, as a consequence, is in charge of avoiding 
that this ripple reaches the load. The topology chosen for 
this second stage is the Asymmetrical Half Bridge converter 
(AHBC) [23]-[25]. This topology is a promising candidate 
for LED lighting applications, overcoming the 
disadvantages of the Flyback topology as postregulator. The 
voltage withstood by its primary switches is clamped to the 
input voltage. Its output filter is very small, so it can be 
easily implemented without electrolytic capacitor. Besides, 
it provides galvanic isolation and its efficiency is very high 
(it reaches 94%) because Zero Voltage Switching (ZVS) 
can be easily obtained. Its main problem is that the feedback 
loop of the AHBC cannot be fast enough to cancel the low-
frequency ripple of the PFC boost converter. In [22], a 
feedforward technique is proposed in order to overcome this 
problem. This technique effectively reduces the output-
voltage low-frequency ripple without affecting stability, but 
it presents two problems: 
• The feedforward loop generates a sinusoidal 
variation of the control voltage (i.e., sinusoidal 
variation of the duty cycle) for canceling the 
sinusoidal low-frequency ripple. Due to the non-
linear static transfer function of the converter, this is 
not always the most suitable waveform for this 
purpose. 
• The feedforward loop is tuned for a given operating 
point. Again, due to the non-linearity, the ripple 
cancelation is far from being the optimum one when 
dimming is applied and the AHBC is not in the 
aforementioned operating point. 
In this paper, a digital feedforward loop is presented. The 
digital implementation is the most suitable one in order to 
deal with this kind of non-linear systems if they change 
their operating point (for instance, due to dimming). 
Nevertheless, the use of high-performance digital systems 
(such as FPGAs or DSPs) is not always a valid option in 
many lighting applications due to several reasons (cost, size, 
fixed operating point, etc.). Microcontrollers (µC), on the 
other hand, are usually used in order to carry out several 
tasks, such as communication with the DALI standard or 
interaction with other devices [26]-[28]. 
The proposed digital feedforward loop is simplified so it 
fits into a small-size, low-cost µC. This simplification is 
based on placing the output-voltage ripple of the LED driver 
in a frequency range high enough so that it does not involve 
flickering problems (i.e., it is not perceived by human eyes 
and, consequently, does not affect human’s health). As the 
ripple is not cancelled, but only moved, the algorithm is 
strongly simplified. 
There is an additional issue regarding digital control of 
the AHBC that should be considered. The delays (i.e., dead 
times) that have to be introduced in the control signals of 
the AHBC’s MOSFETs in order to achieve Zero-Voltage 
Switching (ZVS) are not equal and change depending on the 
operating point of the converter [29]. Therefore, digital 
control is highly recommendable in this converter as it can 
be used for dynamically calculating the necessary delays for 
each situation (increasing its efficiency). The feedforward 
loop, due to the aforementioned simplification, can be 
included in the system used to implement these dynamic 
calculation of the necessary dead times (microcontroller, 
FPGA or DSP) without a significant increase in the needed 
resources. 
Finally, the proposed loop is valid not only for the 
AHBC, but for any converter with a non-linear relation 
between the control variable and the output voltage or 
current (e.g., the boost converter). 
This paper is organized as follows. A brief description of 
the AHBC topology is provided in section II, including the 
analysis of the analog feedforward loop and its limitations. 
The description of the proposed digital feedforward loop is 
presented in section III while its optimization for 
minimizing the flickering is explained in section IV. 
Experimental results are provided in section V. Finally, 
conclusions will be presented in section VI. 
II. REVIEW OF THE AHBC AND THE ANALOG FEEDFORWARD 
LOOP 
This section only pretends to give a brief description of 
the AHBC, presenting the equations that will be used later 
in the analysis of the feedforward loop. A deep analysis can 
be easily found in literature [23]-[25], [29]-[31]. The main 
issue regarding the AHBC (see Fig. 1) is that the driving 
signals of the primary-side switches are complementary (the 
AHBC is also known as HB with complementary control 
[30], [31]). Due to this, the static transfer function of the 
AHBC can be expressed as: 
O in 1 2V V ·(n n )·D·(1 D)= + − , (1)   
where VO is the output voltage, n1 and n2 are the turns ratios 
of the center-tapped transformer and D is the duty cycle. As 
can be seen, the relation between the input and the output 
voltage is linear (for a constant duty cycle). Nevertheless, 
the relation between the output voltage and the duty cycle is 
not linear. This has a great impact on the implementation 
and range of usefulness of any analog feedforward loop. 
The input voltage of the AHBC is provided by a PFC 
converter (in this case a boost converter). Therefore, the 
average value of this input voltage can be considered 
regulated under any condition and equal to Vin_nom. As the 
PFC converter is implemented without electrolytic capacitor 
in order to increase its lifespan, its output voltage (input 
voltage of the AHBC) can be expressed as: 
[ ]in in _ nomv (t) V · 1 r·sin(2· ·2·f·t)= + pi
, 
(2)  
where r is the relative peak value of the ripple and f is the 
line frequency. If the desired output voltage of the AHBC 
has to be constant and the input voltage is affected by a low 
frequency ripple, (1) can be rewritten as: 
( ) ( )O in _ nom 1 2v (t) V · 1 r·sin(2· ·2·f·t) ·(n n )·d(t)· 1 d(t)= + pi + −
, 
(3)  
where d(t) is the time-varying duty cycle, whose value 
changes in order to counteract the input-voltage ripple and 
keep the output voltage constant. Hence, considering (1), (2) 
and that n1 and n2 are designed according to nominal 
conditions (Dnom, VO_nom and Vin_nom), (3) can be used for 
obtaining the required duty cycle that keeps the output 
voltage constant: 
[ ]
O nom nom
O _ nom
4·V ·D ·(1 D )1 1
1 r·sin(2· ·2·f·t) ·V
d(t)
2
−
− −
+ pi
=
. 
(4)   
As can be seen in Fig. 1, the control voltage vc(t) 
satisfies: 
c c _ ff c _ fbv (t) v (t) v (t)= +
, 
(5)   
where vc_ff(t) is the control voltage coming from the output 
of the feedforward loop and vc_fb(t) is the control voltage 
Fig. 1. Schematic of the AHBC, including the standard feedback and feedforward loops. 
defined by the feedback loop. Consequently, the converter 
duty cycle will verify: 
ff fbd(t) d (t) d (t)= + , (6)   
where dfb(t) is the component of the duty cycle determined 
by the feedback loop and dff(t) is the variation in the duty 
cycle introduced by the feedforward loop. It should be taken 
into account that the feedback loop will determine the value 
of the duty cycle for obtaining a given average output 
voltage defined by vref (see Fig. 1), whereas the feedforward 
loop will introduce a variation in the duty cycle in order to 
attenuate the effect of the input-voltage ripple. The variation 
of the parameters of LEDs (dynamic resistance, knee 
voltage, light-current ratio) is defined by their warming-up 
and, therefore, it is a slow process. Besides, the variation of 
the output voltage due to dimming (i.e., vref) has slight 
requirements regarding dynamic response. LED lamps can 
be then considered as very slow load. Therefore, the duty 
cycle defined by the feedback loop can be considered 
constant in each ripple period although it may change along 
time in a very slow way. 
The value of the dfb(t) can be easily obtained from (4) and 
(6) cancelling the effect of the input voltage ripple, as 
follows: 
O nom nom
O _ nom
fb
4·V ·D ·(1 D )1 1
V
d (t)
2
−
− −
=
. 
(7)   
The duty cycle variation that should be introduced by the 
feedforward loop can be obtained from (4), (6) and (7): 
[ ]
O nom nom
O _ nom
ff O
O nom nom
O _ nom
4·V ·D ·(1 D )1
V
d (t, V , r, f )
2
4·V ·D ·(1 D )1
1 r·sin(2· ·2·f·t) ·V
2
−
−
=
−
−
+ pi
−
, 
(8)   
which represents dff as a function of the input voltage ripple, 
the output voltage and the line frequency, which are the 
main variables that define it. 
Fig. 2 shows the optimum duty cycle variation that 
should be introduced by any feedforward loop (equation 
(8)) and also the duty cycle variation generated by the 
analog feedforward loop proposed in [22]. The transfer 
function of this loop is linear and it uses the sinusoidal 
input-voltage ripple as input variable (see Fig. 1). As a 
consequence, its output signal dff is also sinusoidal. 
Nevertheless, as can be seen in Fig. 2, the optimum 
waveform is not sinusoidal. Therefore, it is easy to see the 
first problem of the analog feedforward loop. Even when 
the gain of this loop is different for each half-period (see 
[22]), there is going to be a mismatch with the optimum 
waveform of dff(t), as shown in Fig. 2. This mismatch leads 
to just a partial cancelation of the ripple and, as a 
consequence, to some flickering (see Fig. 3). 
Besides, (8) has some parameters that are not going to 
change (Dnom, VO_nom). Nevertheless, VO, r and f are not 
necessarily constant. VO may change due to dimming, 
something very common in LED lighting applications, 
while r may change due to the PFC converter operation, 
depending on the demanded power or the capacitor 
degradation, for instance. Besides, f is defined by the grid 
and the corresponding tolerances. The analog feedforward 
loop may partially compensate variations in r and f since it 
uses Vin as input variable (see Fig. 1). Nevertheless, its 
transfer function is optimized for a given value of VO. As a 
consequence, its effect for different dimming states (i.e., 
different values of VO) is nothing but optimal (see Fig. 3). 
Digital control is a perfect candidate in this application in 
order to reach the maximum ripple rejection. Due to the 
complex expression presented in (8), the most suitable 
devices for implementing the feedforward loop are FPGAs 
or DSPs. Nevertheless, including this kind of devices in 
LED drivers may be excessively expensive due to the cost 
limitation in many lighting applications. On the other hand, 
the inclusion of a µC in LED drivers is a more extended 
practice due to the new range of functionalities that are 
being included in them (communication under DALI 
standard, dimming depending on the amount of light, hour 
and/or presence of people, etc.). Therefore, the proposed 
digital feedforward loop will be specifically designed for its 
implementation in a pre-existing µC. The main problems 
that the design will have to face are mainly two: 
• The calculation of (8) in a reasonable period of time 
is impossible for a low-cost µC. Therefore, look-up 
tables will be the most suitable option. 
• Memory is limited in this kind of devices. Therefore, 
the number and size of the look-up tables will have 
to be thoughtfully analyzed. 
It should be taken into account that the objective of 
implementing the feedforward loop in a low-cost µC does 
not prevent it from being used with FPGAs or DSPs. 
In the next section, the proposed feedforward loop will be 
described. Nevertheless, the optimization of its design, 
trying to minimize the output-voltage low-frequency ripple 
will be presented in section IV. 
III. LOW-FREQUENCY RIPPLE ATTENUATION TECHNIQUE 
Fig. 4 shows the schematic of the proposed control 
(section VII presents a simplified block diagram of the code 
implemented in the µC). For the sake of simplicity, the 
feedback loop is not included in the µC because the duty 
cycle dfb defined by this loop can be considered constant in 
each period of the ripple and, consequently, does not affect 
Fig. 2. Representation of dff(t) according to equation (8) (optimum 
feedforward) and according to the analog circuit proposed in [22] 
(analog feedforward). Dnom=0.33, VO_nom=21 V, r=0.1. 
Fig. 3. Output voltage ripple for different dimming states when the 
analog feedforward loop is used.Dnom=0.33, VO_nom=21 V, Vin_nom=385 
V, r=0.1, n1=0.177, n2=0.07. 
the feedforward loop analysis. Moreover, the feedback loop 
is not fast enough to be affected by the changes introduced 
by the feedforward loop (this is represented by the low-pass 
filter that senses the output voltage in Fig. 4). Therefore, the 
stability of the system (provided by the feedback loop) is 
not affected by the digital feedforward one. In any real 
implementation, both loops can be easily included in the µC 
code. 
In broad outline, the µC converts both the average output 
voltage (set by the feedback loop) and the input-voltage 
ripple (sensed with a band-pass filter and a peak voltage 
detector) to digital format (vO_ADC and rADC). Both 
conversions are carried out by the standard analog-to-digital 
converter (ADC) that most of the µCs include. The µC also 
senses the ripple frequency by detecting the zero-crossing of 
the sensed input-voltage ripple. This detection helps the µC 
to generate a feedforward signal synchronized with the 
ripple. Depending on the value of these three variables, the 
feedforward loop will choose one of the look-up tables. 
Each of these tables stores the information needed to 
compute vc_ff for different grid angle intervals (i.e., for 
obtaining the vc_ff waveform during a ripple period). 
Obviously, the values stored in each table have been pre-
calculated according to given conditions (rµC, VµC). 
Each look-up table stores Nτ values (from τ1 to τNτ). 
These values are used in combination with the PWM 
module of the µC (different from the PWM module of the 
converter) in order to construct the required vC_ff signal. 
Each value τx of the look-up table defines a certain duty 
cycle of the µC PWM module. The output signal of this 
module, vC_ff_PWM, is filtered and its average value is vC_ff in 
the feedforward loop (see Fig. 4): 
x
c _ ff x PWM _ C
PWM _ C
v (t ) ·V
T µµ
τ
=
, 
(9)   
where VPWM_µC and TPWM_µC are the amplitude and the 
period of the PWM signal generated by the µC. Obviously, 
the frequency of the PWM module of the µC has to be 
considerably higher than the ripple frequency. 
From Fig. 4, it can be easily seen that: 
c _ ff
ff
m
v
d
V
=
, 
(10)  
where Vm is the amplitude of the sawtooth waveform of the 
converter PWM (different from the µC PWM module). 
According to (8), dff depends on the output voltage Vo, 
the line frequency f and the input voltage ripple r. 
Therefore, vc_ff also depends on these variables. As a 
consequence, it is mandatory to have different look-up 
tables for different values of VO, f and r. As the number of 
possible look-up tables NT is limited by the size of the µC 
memory, a reduced number of look-up tables can be stored 
in it: 
T v r fN N ·N ·N= , (11)  
NV being the number of tables calculated for different 
values of VO and constant values of r and f, Nr being the 
number of tables calculated for different values of r and 
constant values of VO and f, and Nf being the number of 
tables calculated for different values of f and given values 
of r and VO. Actually, the variations of the line frequency, 
and consequently, of the ripple frequency, are limited by the 
corresponding regulations. Therefore, they are very small in 
practice and its influence in the whole analysis is very low. 
As a consequence and for the sake of simplicity, Nf can be 
considered equal to one. Therefore, (11) becomes: 
T v rN N ·N= , (12)   
The memory of the µC is then organized as an array of 
look-up tables, as shown in Fig. 4. This array has NV 
columns and Nr rows. Each column (e.g., column j) 
corresponds to look-up tables whose values (τx) are 
calculated from (8), (9) and (10) for a given value of VO 
(e.g., VµC_j). In the same way, each row (e.g., row i) 
corresponds to look-up tables whose values are calculated 
for a given value of r (e.g, rµC_i). 
Finally, the available memory size M must verify: 
T V rM N ·N N ·N ·Nτ τ= = . (13)   
IV. OPTIMIZED DESIGN OF THE FEEDFORWARD LOOP FOR 
LIGHTING APPLICATIONS 
In this section, the optimization of the digital feedforward 
loop will be presented for the particular case of lighting 
applications. This optimization is focused on reducing only 
the ripple that produces harmful flickering, moving it to a 
frequency range that does not affect human’s health.  
It should be taken into account that the values of VO and r 
have to be sensed by the µC. This means that two analog-to-
digital conversions have to be carried out (as has been said, 
the resulting values of the ADC that correspond to VO and r 
are VO_ADC and rADC, as presented in Fig. 4). Due to the slow 
variations of these variables, each conversion can be carried 
out once in each period of the ripple (half the line period) 
and the resulting values can be used in the calculation and 
construction of the whole dff waveform that is going to be 
used in the next ripple period. 
Every conversion involves an error due to the limited Fig. 4. Schematic of the proposed control (feedforward loop). 
vC_ff_PWM vC_ff
Ton= i Ton= i+1
(a)
vPWM_µC
TPWM_µC TON TON
PFC Boost 
converter
AHB 
converter
ADC
µC code 
feedforward
LUT
1,1
LUT 
1,2
LUT 
1,Nv
PWM
+ +
+
-
feedback
Vref
evC_fb
µC
vgrid
vin vO
vC_ff
* LUT-Look-Up Table
+
- Vm
dff+dfb
Synchr.
rADC
VO_ADC
ADC
LUT
2,1
LUT 
2,2
LUT 
2,Nv
LUT
Nr,1
LUT 
Nr,2
LUT 
Nr,Nv
rµC_1,VµC_1 rµC_1,VµC_2 rµC_1,VµC_Nv
rµC_2,VµC_1 rµC_2,VµC_2 rµC_2,VµC_Nv
rµC_Nr,VµC_1 rµC_Nr,VµC_2 rµC_Nr,VµC_Nv
LUT 
1,3
LUT 
2,3
LUT 
Nr,3
rµC_1,VµC_3
rµC_2,VµC_3
rµC_Nr,VµC_3
vc
vC_ff_PWM
See (a)
resolution of the ADC (i.e., quantization noise). As will be 
explained, this error can be neglected in this particular case 
due to its small magnitude in comparison to other sources of 
error derived from the simplified design of the proposed 
feedforward loop. 
The first important error is due to the fact that the number 
of look-up tables that can be stored in the µC memory is 
limited to Nr·NV. That means that only Nr values of input-
voltage ripple and NV values of output voltage can be 
discriminated. The mathematical representation of this error 
can be expressed as (see Fig. 5): 
O _ max O _ max O _ ADC
C V
V V O _ max
V V V
V ·round _ low ·N
2·N N Vµ
 
= +   
  , 
(14)  
max max ADC
C r
r r max
r r r
r ·round _ low ·N
2·N N rµ
 
= +  
 
, 
(15)  
where VµC and rµC are the values discriminated by the µC 
according to the look-up tables defined in the system and to 
the digital variables VO_ADC and rADC. Round_low represents 
a function that provides the greatest integer lower than the 
argument. The maximum error in each variable is (see P1 in 
Fig. 5): 
O _ max
V C
V
V
e
2·Nµ
=
, 
(16)  
max
r C
r
r
e
2·Nµ
=
. 
(17)  
Considering realistic values of M and taking into account 
(13), the quantization noise due to the ADC can be 
disregarded and only the error due to the limited value of Nr 
and NV (eVµC and erµC) is going to be considered. 
In order to take into account this first source of error, VO 
and r in (8) must be replaced with VµC and rµC: 
C nom nom
O _ nom
ff C C
C nom nom
C O _ nom
4·V ·D ·(1 D )
1
V
d (t, V , r )
2
4·V ·D ·(1 D )
1
1 r ·sin(2· ·2·f·t) ·V
2
µ
µ µ
µ
µ
−
−
=
−
−
 + pi 
−
. 
(18)  
The value of dff(t,VO,r) according to (8) (i.e., the desired 
evolution of dff to ideally cancel the ripple) and the value of 
dff(t,VµC,rµC) according to (18) (i.e., the evolution of dff 
obtained so far with the proposed method) have been 
represented in Fig. 6 (dff(tµC,VµC,rµC) will be explained 
later). This figure shows the discrepancies between 
dff(t,VO,r) and dff(t,VµC,rµC) due to the finite number of look-
up tables. In this example, the amplitude of dff(t,VO,r) is 
higher than the amplitude of dff(t,VµC,rµC) because rµC is 
lower than r (see P2 in Fig. 5). 
As has been already explained, the µC will choose one of 
the look-up tables according to the value of VµC and rµC in 
order to build the signal dff during the grid period. The way 
the signal is built has also been explained and is based on 
the use of the PWM module of the µC. Each value τx of the 
look-up table will define the value of vc_ff during a certain 
period of time TµC. It can be easily seen that TµC=1/(2·f·Nτ). 
As a consequence, vc_ff is made of a series of echelons or 
steps (see dff(tµC,VµC,rµC) in Fig. 6) whose length depends on 
the size of the look-up table (Nτ). A discrete time variable 
tµC can be defined according to this explanation: 
C Ct n·Tµ µ=
, 
(19)   
where n changes from 1 to Nτ. From (18) and (19): 
( )
C nom nom
O _ nom
ff C C C
C nom nom
C C O _ nom
4·V ·D ·(1 D )
1
V
d (t ,V , r )
2
4·V ·D ·(1 D )
1
1 r ·sin 2· ·2·f·t ·V
2
µ
µ µ µ
µ
µ µ
−
−
=
−
−
 + pi 
−
. 
(20)   
Obviously, the higher Nτ, the shorter each echelon and 
the higher the accuracy. Besides, the error due to the limited 
number of look-up tables is already included in (14) and 
(15) and, therefore, in (20). Hence, it mathematically 
describes the two sources of error that have to be taken into 
account (see Fig. 6). 
From (3), (6), (7) and (20), the effect of the digital 
feedforward loop in the output-voltage ripple can be 
expressed as: 
[ ]
( )
O C C C in _ nom 1 2
fb ff C C C fb ff C C C
v (t, t , V , r ) V · 1 r·sin(2· ·2·f·t) ·(n n )·
· d (t) d (t , V , r ) · 1 d (t) d (t , V , r )
µ µ µ
µ µ µ µ µ µ
= + pi +
  + − +    , 
(21)   
Fig. 7 shows the output voltage when no feedforward 
loop is implemented, when only the first source of error is 
considered (Nτ=∞) and when both sources of error are taken 
into account (Nτ=12). As can be seen, the second and the 
third waveforms are equal in average value, the difference 
are the echelons that the third one presents. 
Before calculating the optimum number of NV, Nr and Nτ 
for a given value of M, it would be interesting to compare 
the proposed digital control and the analog control proposed 
in [22]. In Fig. 8a, the resulting output voltage for both 
methods is shown when dimming is applied and the output 
voltage is reduced to 80% of its nominal value. As can be 
seen, the ripple in the case of using the digital feedforward 
loop is due to the two aforementioned reasons. 
Fig. 5. Representation of the influence of the 
low number of discrete values of r when Nr=4 
and rmax=10%. 
step
rmax/Nr
erµC
P1
P2
2 4 6 8 rADC
(%)
rµC
(%)
2
4
6
8
rµC
Fig. 6. Error in dff due to tabulation of r and VO. Dnom=0.33, 
VO_nom=21 V, r=0.1. 
Nevertheless, this ripple is considerably lower than the 
ripple in the case of using the analog one. In this last case, 
the ripple is due to the difference between the average value 
of VO used when tuning the loop and the actual average 
value of VO. Nevertheless, when the value of VO is the 
nominal one, results are not so easy to analyze. As can be 
seen in Fig. 8b, when the value of VO is the one used in the 
design of the analog feedforward loop (VO_nom), this loop 
seems to offer better results, mainly due to the lack of 
echelons in its dff signal. Therefore, at first sight, the analog 
feedforward loop is better in nominal conditions. 
Nevertheless, dimming is a very common feature in any 
LED driver. Besides, it should be taken into account that the 
purpose of any feedforward loop in this kind of applications 
is not exactly reducing the output voltage/current ripple, but 
to reduce the light flickering that may affect humans. 
Hence, it is acceptable to have high-frequency ripple (i.e., 
high-frequency flickering) in the emitted light as long as it 
does not affect human’s health. In fact, this is the idea 
beneath the widely-used PWM-mode dimming used in LED 
lighting [3]. Therefore, the purpose of the proposed digital 
feedforward loop is not providing a constant output 
voltage/current to the LED lamp, but to translate all the 
flickering to a frequency range that does not affect people. 
With this straightforward approach to the flickering 
problem, it is possible to simplify the digital feedforward 
loop. As a consequence, this loop can be implemented in a 
small-size µC while obtaining better results than with the 
analog one for the whole duty cycle range (i.e., dimming 
range). This idea is valid not only for the AHBC proposed 
in this paper, but also for any other converter used in LED 
lighting applications and with a non-linear transfer function. 
As has been said, only the harmonics that may affect 
human’s health should be taken into account (i.e., relevant 
flickering). Therefore, only the harmonics below a limit 
frequency flmt will be considered in the ripple/flickering 
analysis. Nevertheless, human eye does not behave as an 
ideal low-pass filter with an infinite slope when the cut-off 
frequency (i.e., flmt) is reached. Human eye is a complex 
system and, consequently, an analysis in which different 
weights are given to different harmonic components should 
be carried out. This especial treatment to flickering in LEDs 
is the result of the fast response in converting electrical 
energy into light. As presented in [32] and [33], the use of 
LEDs in lighting makes the redefinition of flickering 
analysis something mandatory. Unfortunately, although the 
first steps have been taken in this direction, there is not a 
precise regulation regarding flickering in LED lighting yet. 
Besides, the purpose of this paper is not providing a value 
for these weights, but to compare the results obtained with 
the analog loop and the results obtained with the proposed 
digital one. Therefore, to ease this comparison, all the 
weights will be equal to one for frequencies lower than flmt. 
Although this is considering the human eye as an ideal low-
pass filter, it is also the worst situation for the digital loop 
analysis. 
The situation depicted in Fig. 8 turns into the one shown 
in Fig. 9 when only the harmonic components lower than 
flmt are taken into account. As can be seen, now the results 
obtained with the digital feedforward loop are considerably 
better than with the analog one, even when dimming is not 
applied. The reason is that with the digital loop all the 
strong harmonic components are placed in a frequency 
range with no associate flickering problems. Nevertheless, 
this can only be achieved when the variables Nτ, NV and Nr 
are wisely chosen.  
Once the digital loop has proven to be more effective 
Fig. 7. Output voltage ripple when no feedforward is implemented 
and when the proposed digital feedforward is used (with one source 
of error and with both). Dnom=0.33, VO_nom=21 V, Vin_nom=385 V, 
r=0.1, n1=0.177, n2=0.07. 
Fig. 8. Output voltage without feedforward, with analog feedforward 
loop and with digital feedforward loop when a) dimming is applied 
(VO=80% of VO_nom); b) no dimming is applied. Dnom=0.33, VO_nom=21 
V, Vin_nom=385 V, r=0.1, n1=0.177, n2=0.07. 
Fig. 9. Output voltage with analog and digital feedforward. In this case, 
only harmonics below flmt=400 Hz (relevant harmonics) have been 
taken into consideration. Dnom=0.33, VO_nom=21 V, Vin_nom=385 V, 
r=0.1, n1=0.177, n2=0.07. 
Analog 
feedforward
Digital 
feedforward
flmt=400 Hz
Full load (no dimming)
19.8
19.6
19.4
0.002 0.004 0.006 0.008 t(s)
Digital 
feedforward
flmt=400 Hz
Analog 
feedforward
80% Full load
VO (V) (only components below flmt)
16
15
14
0.002 0.004 0.006 0.008 t(s)
a)
b)
VO (V) (only components below flmt)
than the analog one, the proposed design guideline of the 
digital feedforward loop will be presented by means of an 
example. In this example, the AHBC has an input voltage of 
385 V with a maximum ripple of 20% (peak to peak), an 
output voltage of 20 V and a nominal power of 40 W. The 
turn ratios of the transformer are 0.177 and 0.07 (n1 and n2 
respectively). The nominal duty cycle is 33% and the 
memory size available for storing the look-up tables is 
1kword. The frequency limit, flmt, is set at 400 Hz. This is a 
common frequency for PWM dimming because it is 
assumed to be far from the frequency range that implies 
harmful flickering. 
The final purpose of the design guideline is optimizing 
the value of the three variables involved in the definition of 
dff (NV, Nr, Nτ) for a given value of M. For doing that, (13), 
(14), (15), (20) and (21) must be taken into account. The 
design should be based on the analysis and reduction of the 
relevant output-voltage ripple (i.e., only the harmonics 
below flmt) for the worst possible situation. That means 
considering always the greatest possible errors in VµC and 
rµC when selecting the most suitable look-up table (see Fig. 
5 and equations (15) and (16)). 
The optimum value of Nτ can be obtained considering 
that it has to assure that the first strong harmonic component 
of the resulting output-voltage ripple has a frequency higher 
than flmt. Besides, as can be seen in Fig. 6, when the zero-
crossing of the input voltage ripple (positive or negative) is 
centered in one of the steps of dc_ff, the value that should be 
introduced by the feedforward loop is zero. By making the 
first and last steps half the length of the rest steps (see Fig. 
6), the corresponding zero-crossing will be always centered 
in the step that both half-steps conform. As a consequence, 
this value of the look-up table is always zero and that 
implies that, actually, there is no need of storing it. This 
reduces the size of all the look-up tables stored in the 
available memory, something very important due to its 
small size. 
Due to the proposed digitalization and implementation of 
VC_ff, the harmonic analysis of vO shows that the frequency 
corresponding to its first strong harmonic component 
(fstrong_1) satisfies: 
strong _1f (N 1)·2·fτ= −
. 
(22)  
For instance, when Nτ=6 and f=50 Hz, then fstrong_1 is 500 
Hz and, consequently, higher than flmt=400 Hz. 
From (22) and taking into account that Nτ is an integer 
value, the optimum value of Nτ that guarantees that 
fstrong_1>flmt is: 
lmt
_ opt
f 2·fN 1
2·fτ
+
= +
. 
(23)   
The relative value of the output voltage ripple (peak-to-
peak value) when only the relevant harmonics are 
considered can be obtained from (21). This value has been 
labeled as rvo_relevant (different from r, which represents the 
input voltage ripple) and it has been represented in Fig. 10 
as a function of kN (defined as kN=NV/Nr) for the 
aforementioned worst situation. As can be seen, this figure 
validates the previous optimization of Nτ, as the minimum 
value of rvo_relevant is obtained when Nτ satisfies (23) (i.e., in 
the proposed example, Nτ=6 because flmt=400 Hz). Besides, 
this figure shows that the optimum value of kN is around 4 
for this particular example. It should be taken into account 
that this optimum ratio varies depending on the value of the 
variables that define the equations used in the design 
process. For instance, a reduction in the nominal input-
voltage ripple will increase the value of the optimum kN as 
the value of the optimum Nr will decrease. In other words, 
the lower the maximum input voltage ripple, the lower the 
value of Nr for obtaining the same accuracy in the process 
of selecting the most suitable look-up table. 
Fig. 10 also clearly shows that the influence of Nτ is 
considerably higher than the influence of kN. This will be 
deeply discussed in section V. 
To sum up, this example shows the way the proposed 
equations should be used for optimizing the digital 
feedforward loop of any design. The resulting figures will 
allow us to decide which the most suitable values of Nτ_opt 
and kN_opt are. Once they are determined, NV_opt and Nr_opt 
can be easily calculated with (13). 
V. EXPERIMENTAL RESULTS 
A prototype has been built in order to verify the 
mathematical model (see Fig. 11). The nominal input and 
output voltage, as well as the nominal power are Vin=385 V, 
VO=20 V and P=40 W. The transformer is built with an 
ETD34 core and the output inductor with an E30 core. Their 
inductances are 3.1 mH (magnetizing inductance) and 80 
µH, respectively. The turns ratios of the transformer are 
0.177 and 0.07. The output capacitor is implemented with 6 
MKP capacitors of 3.7 µF each. The input capacitors are 
270-nF MKP ones. The digital feedforward loop is 
implemented in a PIC12F683 µC from Microchip. It has 8 
pins and 2 kwords of program memory (Harvard structure). 
One kword is left apart for housekeeping code and the 
feedforward code (PWM, ADC, etc.) and the other 1 kword 
is used for storing the look-up tables. 
In Fig. 12, the influence of Nτ is analyzed. Therefore, for 
the sake of clarity NV and Nr are forced to be equal. The 
three figures include the results obtained with the 
mathematical model (both, considering all the harmonic 
components and only those located at a frequency lower 
than flmt). As can be seen, the predicted results 
(mathematical model) are close to the real ones. The only 
significant differences occur when the signal dff generated 
Fig. 11. Photograph of the prototype. 
Fig. 10. Peak to peak value of the relevant ripple for different values of kN 
when the available memory is 1 kword. 
by the feedforward loop changes from one value to the next 
one. The mathematical model does not take into account the 
dynamic of the output filter and, as a consequence, the 
variations of the output voltage in the model are a little bit 
faster than in the prototype. Nevertheless, this difference is 
very small. Therefore, the mathematical model is validated 
and can be used for optimizing the digital feedforward loop 
as has been explained in previous sections. As can be seen 
in Fig. 12c, when the number of different values (Nτ) used 
in the construction of dff is lower than flmt/f+2 (Nτ=5 in this 
case), at least one strong harmonic component is lower than 
(or equal to) flmt and, consequently, the amplitude of the 
relevant ripple is higher than in Fig. 12b or Fig. 12a. On the 
other hand, the amplitude of the relevant ripple in Fig. 12a 
is slightly higher than in Fig. 12b. In this case, the reason 
can be found in the lower value of NV and Nr (both equal to 
12), which makes the error when sensing the input variables 
greater. Besides, the advantage of a higher value of Nτ 
(Nτ=7) when NV=Nr=12 is not a real advantage as the 
relevant harmonic components are already higher than flmt in 
Fig. 12b, when Nτ is equal to 6 (and NV=Nr=13). 
Nevertheless, it should be mentioned that this difference is 
very small. Therefore, a very important issue when 
optimizing the feedforward loop is always taking into 
account (23) so that the strong harmonic components are 
always higher than flmt and, consequently, outside the 
harmful-flickering range. 
In Fig. 13, the influence of NV and Nr is studied. 
Consequently, the value of Nτ is the optimum one. In Fig. 
13a, the values of NV and Nr are the optimum ones while in 
Fig. 13b they are not. The relevance of optimizing NV and 
Nr can be seen when comparing both figures. In the latter, in 
which the values of NV and Nr are not the optimum ones, 
the ripple is 50% higher than when these two variables are 
optimized. 
In Fig. 14, the output voltage ripple is shown when 
dimming is applied and the optimum values of NV, Nr and 
Nτ are chosen (i.e., NV=28, Nr=6 and Nτ=6). As can be seen, 
the proposed digital feedforward loop reduces the ripple 
under any dimming condition as it adapts its output signal 
(dff) to the operating conditions. Moreover, the effect of the 
non-linear transfer function has no effect as the calculation 
of the values stored in the look-up tables of the digital 
feedforward loop always takes this into account. This 
represents the main advantage of the proposed loop in 
comparison to the standard analog one (even with different 
gains for each half period of the ripple, as explained in 
[22]). 
Finally, Fig. 15 presents three different output voltages 
for three different input-voltage ripples. The output voltage 
is shown including the dc value in order to clearly verify 
that the proposed digital feedforward loop effectively 
reduces the output-voltage ripple. As can be seen, the output 
voltage is nearly constant, even considering all harmonic 
components and not only those located at a frequency lower 
than flmt. 
VI.  CONCLUSIONS 
The AHBC has proven to be a promising option as 
second stage of any two-stage ac-dc LED driver (in 
comparison to other topologies, such as the Flyback 
converter). Its only drawback is its poor dynamic response 
due to the resonance between the magnetic inductance of 
the transformer and the input capacitors. This is a problem 
when the feedback loop has to compensate the effect of the 
low-frequency ripple that appears in its input voltage. The 
solution proposed in this paper is the implementation of a 
digital feedforward loop in a small-size µC. Due to the 
limited size of the available memory and the limitations in 
the mathematical operations that the µC can carry out, the 
proposed feedforward loop is based on cancelling not all the 
ripple, but only the one that may lead to harmful flickering. 
With this specific design the feedforward loop can be 
strongly simplified, although it has to focus on issues 
different from the traditional ones (e.g., the quantization 
noise can be disregarded). The proposed feedforward loop is 
based on look-up tables. The first key point in the design is 
calculating the number of different values stored in these 
tables. This number should assure that the resulting 
harmonic components are not going to generate flickering in 
a frequency range that may affect humans (e.g., when the 
Fig. 13. Output voltage ripple (experimental and mathematical model) a) 
when NV=28, Nr=6, M=1024, flmt=400 Hz; b) under same conditions but 
NV=6 and Nr=28. 
Fig. 12. Output voltage ripple (experimental results and mathematical 
model) when a) NV=Nr=12, Nτ=7; b) NV=Nr=13, Nτ=6; c) NV=Nr=14, Nτ=5. 
In all cases, M=1024 words and flmt=400 Hz 
a)
Mathematical 
model
Mathematical 
model (<flmt)
Experimental result
1 V/div
1 ms/div
0.721 V
b)
Mathematical 
model
Mathematical 
model (<flmt)
Experimental result
1 V/div
1 ms/div
0.688 V
c)
Mathematical 
model
Mathematical 
model (<flmt)
Experimental result
1 V/div
1 ms/div
1.435 V
Fig. 14. Output voltage ripple (experimental and mathematical model) 
when NV=28, Nr=6, Nτ=6, M=1024, D=0.22 and flmt=400 Hz 
Mathematical 
model
Mathematical 
model (<flmt)
Experimental 
result
1 V/div
1 ms/div
harmful flickering is limited to frequencies lower than 400 
Hz, the optimum number is six). The digital loop takes, as 
input variables, the input voltage ripple and the average 
output voltage. The second key point is then defining the 
number of different values that the loop can discriminate in 
these two variables. Experimental results show that the 
proposed digital feedforward loop presents a lower ripple 
than the analog one. This improvement is more remarkable 
when dimming is applied; situation in which the digital 
feedforward loop still reduces the ripple nearly to zero while 
the analog one, rather than reducing it, increases it. 
VII. ANNEX 
A simplified block diagram of the code implemented in 
the µC is shown in Fig. 16. As can be seen, it corresponds to 
the explanation given in section III. 
After the configuration of all the pins and peripherals that 
will be used, the code of the digital feedforward loop waits 
for a zero-crossing in the input-voltage ripple to start. At the 
beginning of each ripple period, the LUT that will be used 
during this period is selected according to the values of i 
and j. These values are defined according to the results 
obtained in the previous ripple period from the AD 
conversion of the input voltage ripple and output voltage. 
Also, the variables x and Count are set to zero. 
The selected LUT, along with variable x (actually, x is the 
index of the LUT), is used to obtain the value of τx (a full 
description of this concept is provided in section III). This 
value is used to define the duty cycle of the PWM module 
of the µC, which will define the feedforward-loop signal 
once it is filtered (see Fig. 4b). 
Every time a period of the µC PWM module is finished 
(different from the PWM module of the converter), variable 
Count is incremented and compared to Count_limit. This 
allows the system to identify when the duty cycle of the µC 
PWM module has to be updated with a new τx (according to 
x, which is also incremented); in other words, when the 
signal of the feedforward loop has to change. 
When the input voltage ripple reaches its peak value, the 
system launches an AD conversion of this parameter. It 
should be taken into account that a peak detector is 
implemented in the hardware, so the conversion does not 
need to be precisely launched when the peak of the ripple 
takes place. As can be seen, the ADC interrupt allows the 
system to update the value of i and j, which will be used at 
the beginning of the next ripple period in order to select the 
LUT that will be used. 
Finally, it should be said that the system also detects the 
end of a ripple period and restarts the generation of the 
feedforward signal. 
REFERENCES 
[1] B. Lehman and A. Shteynberg, "Professional Education Seminars: 
LED lighting: trends, standards, optics and power electronics," in 
b)
80 Vpp
17 Vdc
a)
20 Vdc
80 Vpp
Vin (ripple)
(20 V/div)
VO (dc+ac)
(5 V/div)
1 ms/div
80 Vpp
15 Vdc
c)
1 ms/div 1 ms/divVin (ripple)
(20 V/div)
Vin (ripple)
(20 V/div)
VO (dc+ac)
(5 V/div) VO (dc+ac)
(5 V/div)
e)
17 Vdc
d)
20 Vdc
40 Vpp
15 Vdc
f)
1 ms/div 1 ms/div 1 ms/div
VO (dc+ac)
(5 V/div)
Vin (ripple)
(10 V/div)
Vin (ripple)
(10 V/div)
Vin (ripple)
(10 V/div)
VO (dc+ac)
(5 V/div)
VO (dc+ac)
(5 V/div)
40 Vpp 40 Vpp
h)
20 Vpp
17 Vdc
g)
20 Vdc
20 Vpp 20 Vpp
15 Vdc
i)
1 ms/div 1 ms/div 1 ms/div
VO (dc+ac)
(5 V/div)
Vin (ripple)
(10 V/div)
Vin (ripple)
(10 V/div)
Vin (ripple)
(10 V/div)
VO (dc+ac)
(5 V/div)
VO (dc+ac)
(5 V/div)
Fig. 15. Output voltage (dc+ac) and input voltage ripple when NV=28, Nr=6, Nτ=6, M=1024 for different values of input voltage ripple 
and output voltage. 
Applied Power Electronics Conference and Exposition (APEC), Fort 
Worth, 2011. 
[2] M. Arias, A. Vázquez, and J. Sebastián, "An Overview of the AC-
DC and DC-DC Converters for LED Lighting Applications," 
AUTOMATIKA – Journal for Control, Measurement, Electronics, 
Computing and Communication, vol. 53, pp. 156-172, 2012. 
[3] S. Tan, "General ƞ-Level Driving Approach for Improving 
Electrical-to-Optical Energy-Conversion Efficiency of Fast-
Response Saturable Lighting Devices," Industrial Electronics, IEEE 
Transactions on , vol.57, no.4, pp.1342,1353, April 2010. 
[4] K. H. Loo, Y. M. Lai, S. C. Tan, C. K. Tse, "On the Color Stability 
of Phosphor-Converted White LEDs Under DC, PWM, and Bilevel 
Drive," Power Electronics, IEEE Transactions on, vol.27, no.2, 
pp.974-984, Feb. 2012 
[5] J. G. Kassakian, T. M. Jahns, "Evolving and Emerging Applications 
of Power Electronics in Systems," Emerging and Selected Topics in 
Power Electronics, IEEE Journal of , vol.1, no.2, pp.47,58, June 
2013 
[6] L. Gu; X. Ruan; M. Xu; K. Yao, "Means of Eliminating Electrolytic 
Capacitor in AC/DC Power Supplies for LED Lightings," Power 
Electronics, IEEE Transactions on , vol.24, no.5, pp.1399,1408, May 
2009. 
[7] J. Zhang; H. Zeng; T. Jiang, "A Primary-Side Control Scheme for 
High-Power-Factor LED Driver With TRIAC Dimming Capability," 
Power Electronics, IEEE Transactions on , vol.27, no.11, 
pp.4619,4629, Nov. 2012. 
[8] W. Chen; S.Y.R. Hui, "Elimination of an Electrolytic Capacitor in 
AC/DC Light-Emitting Diode (LED) Driver With High Input Power 
Factor and Constant Output Current," Power Electronics, IEEE 
Transactions on , vol.27, no.3, pp.1598,1607, March 2012. 
[9] R. Zhang, H. Shu-Hung Chung, “Transformer-Isolated Resonant 
Driver for Parallel Strings With Robust Balancing and Stabilization 
of Individual LED Current,” Power Electronics, IEEE Transactions 
on, vol.29, no.7, pp. 3694-3708, July 2014 
[10] M. S. Roedgaard, M. Weirich, M. A. E. Andersen, “Forward 
Conduction Mode Controlled Piezoelectric Transformer-Based PFC 
LED Drive,” Power Electronics, IEEE Transactions on, vol.28, 
no.10, pp. 4841-4849, Oct. 2013 
[11] J. Kim; J. Lee; G. Moon, "Isolated Switch-Mode Current Regulator 
With Integrated Two Boost LED Drivers," Industrial Electronics, 
IEEE Transactions on , vol.61, no.9, pp.4649,4653, Sept. 2014. 
[12] Y. Li; Chen, Ch. Chen, "A Novel Single-Stage High-Power-Factor 
AC-to-DC LED Driving Circuit With Leakage Inductance Energy 
Recycling," Industrial Electronics, IEEE Transactions on , vol.59, 
no.2, pp.793,802, Feb. 2012. 
[13] Y. Hu, L. Huber, M. M. Jovanović, "Single-Stage, Universal-Input 
AC/DC LED Driver With Current-Controlled Variable PFC Boost 
Inductor," Power Electronics, IEEE Transactions on, vol.27, no.3, 
pp.1579-1588, March 2012 
[14] Y. Li; Ch. Chen, "A Novel Primary-Side Regulation Scheme for 
Single-Stage High-Power-Factor AC–DC LED Driving Circuit," 
Industrial Electronics, IEEE Transactions on , vol.60, no.11, 
pp.4978,4986, Nov. 2013. 
[15] J. Zhang; Jianfeng Wang; X. Wu, "A Capacitor-Isolated LED Driver 
With Inherent Current Balance Capability," Industrial Electronics, 
IEEE Transactions on , vol.59, no.4, pp.1708,1716, April 2012 
[16] D.G. Lamar; M. Arias; A. Rodriguez; A. Fernandez; M.M. 
Hernando; J. Sebastian, "Design-Oriented Analysis and Performance 
Evaluation of a Low-Cost High-Brightness LED Driver Based on 
Flyback Power Factor Corrector," Industrial Electronics, IEEE 
Transactions on , vol.60, no.7, pp.2614,2626, July 2013. 
[17] N. Chen; Chung, H.S.-H., "A Driving Technology for Retrofit LED 
Lamp for Fluorescent Lighting Fixtures With Electronic Ballasts," 
Power Electronics, IEEE Transactions on , vol.26, no.2, pp.588,601, 
Feb. 2011. 
[18] Q. Hu; R. Zane, "Off-line LED driver with bidirectional second 
stage for reducing energy storage," Energy Conversion Congress 
and Exposition (ECCE), 2011 IEEE , vol., no., pp.2302,2309, 17-22 
Sept. 2011. 
[19] H. Ma; J. Lai; Q. Feng; W. Yu; C. Zheng; Z. Zhao, "A Novel 
Valley-Fill SEPIC-Derived Power Supply Without Electrolytic 
Capacitor for LED Lighting Application," Power Electronics, IEEE 
Transactions on , vol.27, no.6, pp.3057,3071, June 2012. 
[20] M. Arias, D. Lamar, D. Balocco, A. Diallo, and J. Sebastian, "High-
Efficiency LED Driver without Electrolytic Capacitor for Street 
Lighting," Industry Applications, IEEE Transactions on, vol. PP, pp. 
1-1, 2012. 
[21] D. Bailey, "An Idea to Simplify LED Lighting Purchase Decisions," 
Bodo's Power, p. 18, July 2011 2011. 
[22] M. Arias, M. Fernández, D. G. Lamar, D. Balocco, A. Aguissa 
Diallo, J. Sebastián, "High-Efficiency Asymmetrical Half-Bridge 
Converter Without Electrolytic Capacitor for Low-Output-Voltage 
AC-DC LED Drivers," Power Electronics, IEEE Transactions on, 
vol. 28, pp. 2539-2550, 2013. 
[23] J. A. Cobos, O. Garcia, J. Sebastian, J. Uceda, and F. Aldana, 
"Optimized Synchronous Rectification Stage for Low Output 
Voltage (3.3 V) DC/DC Conversion," presented at the Power 
Electronics Specialists Conference, 1994. PESC '94 Record., 25th 
Annual IEEE, Taipei (Taiwan), 1994. 
[24] P. Imbertson and N. Mohan, "Asymmetrical Duty Cycle Permits 
Zero Switching Loss in PWM Circuits with No Conduction Loss 
Penalty," Industry Applications, IEEE Transaction on, vol. 29, p. 
121, January 1993. 
[25] H. Kim, J. Jung, and J. Baek, "Analysis and Design of a Multi-
output Converter using Asymmetrical PWM Half-bridge Flyback 
Converter Employing a Parallel-series Transformer," Industrial 
Electronics, IEEE Transactions on, vol. PP, pp. 1-1, 2012. 
[26] H. Zeng, T. Jiang, and J. Zhang, "A primary side control Scheme for 
Triac dimmable LED driver based on indirect output current 
sensing," in Energy Conversion Congress and Exposition (ECCE), 
2012 IEEE, 2012, pp. 3249-3256. 
[27] D. Tran; Y. Tan, "Sensorless Illumination Control of a Networked 
LED-Lighting System Using Feedforward Neural Network," 
Industrial Electronics, IEEE Transactions on , vol.61, no.4, 
pp.2113,2121, April 2014. 
[28] L. Xingming and Z. Jing, "An intelligent driver for Light Emitting 
Diode Street Lighting," in Automation Congress, 2008. WAC 2008. 
World, 2008, pp. 1-5. 
[29] M. Arias, D.G. Lamar, F.F. Linera, D. Balocco, A. A. Diallo, J. 
Sebastián, "Design of a Soft-Switching Asymmetrical Half-Bridge 
Fig. 16. Simplified block diagram of the feedforward loop code 
Wait for zero-
crossing in 
ripple
x=0
Count=0
Initial configuration of 
peripherals, pins, etc.
Launch ADC
(output voltage)
Choose LUT according 
to i and j
µC
PWM module 
period 
finished?
Count++
Count
=
Count_limit?
Count=0 x++
¼ ripple period 
reached?
Launch ADC
(input voltage ripple)
Ripple period 
finished?
Search in LUTi,j
Indexth element≈          τxx
Update µC PWM 
module with           τxx
Interrupt (ADC)
ADC of output 
voltage or input 
ripple?
Update i value         Update j value         
End Interrupt (ADC)
No
Yes
No
Yes
No
Yes
Yes
No
Converter as Second Stage of an LED Driver for Street Lighting 
Application," Power Electronics, IEEE Transactions on , vol.27, 
no.3, pp.1608,1621, March 2012 
[30] O. Garcia, J. A. Cobos, J. Uceda, and J. Sebastian, "Zero voltage 
switching in the PWM half bridge topology with complementary 
control and synchronous rectification," in Power Electronics 
Specialists Conference, 1995. PESC '95 Record., 26th Annual IEEE, 
1995, pp. 286-291 vol.1 
[31] J. Sebastian, J. A. Cobos, O. Garcia, and J. Uceda, "An overall study 
of the half-bridge complementary-control DC-to-DC converter," in 
Power Electronics Specialists Conference, 1995. PESC '95 Record., 
26th Annual IEEE, 1995, pp. 1229-1235 vol.2. 
[32] A. Wilkins, J. Veitch, and B. Lehman, "LED lighting flicker and 
potential health concerns: IEEE standard PAR1789 update," in 
Energy Conversion Congress and Exposition (ECCE), 2010 IEEE, 
2010, pp. 171-178. 
[33] B. Lehman, A. Wilkins, S. Berman, M. Poplawski, and N. Johnson 
Miller, "Proposing measures of flicker in the low frequencies for 
lighting applications," in Energy Conversion Congress and 
Exposition (ECCE), 2011 IEEE, 2011, pp. 2865-2872. 
 
 
