Analysis and FPGA implementation of a single-Bit two-step look-ahead ΔΣ Modulator by Ορφανός, Θανάσης & Orfanos, Thanasis
Εθνικό Μετσόβιο Πολυτεχνείο
Σχολή Ηλεκτρολόγων Μηχανικών & Μηχανικών Υpiολογιστών
Τομέας Εpiικοινωνιών, Ηλεκτρονικής & Συστημάτων Πληροφορικής
Analysis and FPGA Implementation
of a Single-Bit Two-Step Look-Ahead
ΔΣ Modulator
Διpiλωματική Εργασία
Αθανάσιος Σ. Ορφανός
Εpiιβλέpiων Καθηγητής
Παύλος-Πέτρος Σωτηριάδης
Εpiίκ. Καθηγητής Ε.Μ.Π.
Εργαστήριο Ηλεκτρονικής
Αθήνα, Οκτώβριος 2015
2
Εθνικό Μετσόβιο Πολυτεχνείο
Σχολή Ηλεκτρολόγων Μηχανικών & Μηχανικών Υpiολογιστών
Τομέας Εpiικοινωνιών, Ηλεκτρονικής & Συστημάτων Πληροφορικής
Analysis and FPGA implementation of a Single-Bit
Two-Step Look-Ahead ΔΣ Modulator
Διpiλωματική Εργασία
Αθανάσιος Σ. Ορφανός
Εpiιβλέpiων Καθηγητής :
Παύλος-Πέτρος Σωτηριάδης
Εpiίκ. Καθηγητής Ε.Μ.Π.
Εγκρίθηκε αpiό την τριμελή εpiιτροpiή την 15η Οκτωβρίου 2015
(Υpiογραφή) (Υpiογραφή) (Υpiογραφή)
..................... ..................... .....................
Παύλος-Πέτρος Σωτηριάδης Αθανάσιος Παναγόpiουλος Κιαμάλ Πεκμεστζή
Εpiίκ. Καθηγητής Ε.Μ.Π. Εpiικ. Καθηγητής Ε.Μ.Π. Καθηγητής Ε.Μ.Π.
Εργαστήριο Ηλεκτρονικής
Αθήνα, Οκτώβριος 2015
2
(Υpiογραφή)
.....................
Αθανάσιος Σ. Ορφανός
Διpiλωματούχος Ηλεκτρολόγος Μηχανικός και Μηχανικός Υpiολογιστών Ε.Μ.Π.
Copyright c© , Αθανάσιος Σ. Ορφανός, 2015
Με εpiιφύλαξη piαντός δικαιώµατος. All rights reserved.
Αpiαγορεύεται η αντιγραφή, αpiοθήκευση και διανοµή της piαρούσας εργασίας, εξ
ολοκλήρου ή τµήµατος αυτής, για εµpiορικό σκοpiό. Εpiιτρέpiεται η ανατύpiωση,
αpiοθήκευση και διανοµή για σκοpiό µη κερδοσκοpiικό, εκpiαιδευτικής ή ερευν-
ητικής φύσης, υpiό την piροϋpiόθεση να αναφέρεται η piηγή piροέλευσης και να
διατηρείται το piαρόν µήνυµα. Ερωτήµατα piου αφορούν τη χρήση της εργασίας
για κερδοσκοpiικό σκοpiό piρέpiει να αpiευθύνονται piρος το συγγραφέα.
Οι αpiόψεις και τα συµpiεράσµατα piου piεριέχονται σε αυτό το έγγραφο εκ-
φράζουν το συγγραφέα και δεν piρέpiει να ερµηνευθεί ότι αντιpiροσωpiεύουν τις
εpiίσηµες θέσεις του Εθνικού Μετσόβιου Πολυτεχνείου.
1
2
Περίληψη
Στην piαρούσα διpiλωματική εργασία μελετάμε έναν single bit Digital to Digital Con-
verter (DD) . Το σήμα εισόδου του είναι ένα ψηφιακό σήμα, μια ακολουθία αpiοτελού-
μενη αpiό piολλά bits ενώ στην έξοδο του το σήμα αυτό αpiεικονίζεται αpiό μία ακολου-
θία των ενός μόλις bit, {+1,−1}. Το κέρδος αpi αυτή τη διαμόρφωση του σήματος
είναι στη γραμμικότητα piου piροσδίδει η έξοδος {+1,−1}, εpiιτρέpiοντας μας έτσι να
piαραλείψουμε τον multi-bit Digital to Analog Converter (DAC). Η ανάκτηση του
αρχικού σήματος μpiορεί να γίνει μόνο με ένα Lowpass Filter. Καθώς οι multi-bit
DAC έχουν εξ ορισμού piολλά εpiίpiεδα κβαντισμού, οι όpiοιες ατέλειες στο αναλογικό
μέρος (piυκνωτές,αντιστάσεις) θα αλλοιώσουν την τιμή των εpiιpiέδων εισαγάγοντας μη
γραμμικά φαινόμενα και εpiιβαρύνοντας κατ΄ αυτόν τον τρόpiο τον διαμορφωτή. Ωστόσο
με μόλις δύο εpiίpiεδα κβαντισμού το σφάλμα στην αναpiαράσταση του σήματος θα είναι
piολύ μεγάλο. Για την αντιστάθμιση του υψηλού σφάλματος αpiαιτείται piολύ υψηλή
ταχύτητα δειγματοληψίας.
Για την υλοpiοίηση του ΔΣ διαμορφωτή δεν χρησιμοpiοιείται κάpiοια ευρέως διαδε-
δομένη τοpiολογία αλλά ο Multi-Step Look-Ahead (MSLA) ΔΣ διαμορφωτής, μία
νέα piρόταση του διδακτορικού φοιτητή Χάρη Μpiασέτα και του εpiιβλέpiοντα καθηγητή
κ. Σωτηριάδη. Η διαφορά με τον συμβατικό ΔΣ είναι ότι ο υpiολογισμός της εξόδου
{+1,−1} piροκύpiτει αpi την ελαχιστοpiοιήση μιας συναρτησης κόστους κοιτώντας βή-
ματα μpiροστά. Στην piαρούσα εργασία εξετάζεται ο MSLA για δύο βήματα μpiροστά.
Εpiίσης piαρουσιάζεται η βέλτιστη δομή για την εφαρμογή αυτού του διαμορφωτή κα-
θώς εpiίσης γίνεται και μια εκτενής ανάλυση για τον υpiολογισμό του αριθμού των
bits για κάθε σήμα ώστε η εφαρμογή του σε piραγματικό κύκλωμα να είναι αpiοδοτική.
Τέλος υλοpiοιήσαμε τον συγκεκριμένο ΔΣ διαμορφωτή piάνω σε fpga και στον αναλυτή
φάσματος είδαμε τα αpiοτέλεσματα.
Λέξεις Κλειδιά
ΔΣ, ΣΔ, Διαμορφωτής, Υλοpiοίηση, Αριθμός δυφίων, Πλακέτα, Κύκλωμα
3
4
Abstract
In this paper we study a single bit ΔΣ Digital to Digital Converter (DD).
Its input is a digital signal, a sequence consisting of many bits while in its
output this signal is depicted from a sequence of one just bit, {+1,−1}.
The gain from this signal modulation is the given linearity from the output
{+1,−1}, allowing us to forget the multi-bit Digital to Analog Converter
(DAC). Recovery of the original signal can be done with just a lowpass filter.
As multi-bit DAC by definition consists of many quantization levels, any
imperfections in the analog part (capacitors, resistors) will affect the value
of the levels entering nonlinear phenomena and attributing in this way the
modulator. However with just two quantization levels, the error in the signal
representation will be very large. To offset the high error is required very
high sampling rate.
For the implementation of the ΔΣ modulator is not used any widespread
topology but the Multi-Step Look-Ahead (MSLA) ΔΣ modulator, a new pro-
posal by the PhD student Charis Basetas and the assistant prof. Paul-Peter
Sotiriadi. The difference to conventional ΔΣ is that the calculation of out-
put {+1,−1} results from the minimization of a cost function looking steps
ahead. This paper examines the MSLA for two steps ahead. Also shows
the optimal architecture for the implementation of this modulator and also a
comprehensive analysis is made for the calculation of the number of bits for
each signal in order to its application in real circuit to be efficient. Finally we
implemented the specific ΔΣ modulator on fpga and we observed the results
in the spectrum analyzer.
Key Words
ΔΣ, ΣΔ, Modulator, Multi Step Look Ahead, MSLA, Look Ahead, Implemen-
tation, Bits, Bit-width, FPGA , CIDF, Cascade Integrators Distributed Feedback
5
6
Acknowledgement
I would like to thank my assistant prof. Paul-Peter Sotiriadis for our co-
operation and for introducing me to his excellent laboratory team. I would
also like to give special thanks to my supervisor, PhD Charis Basetas for his
continuous and crucial support throughout this year; my thesis is just a part
of his survey and I feel truly thankful working together with such a brilliant
scientist.
7
8
Contents
1 Introduction 11
2 Topologies of Digital to Digital Converter 13
2.1 Delta Modulator . . . . . . . . . . . . . . . . . . . . . . . . . 13
2.2 ΔΣ modulator . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
2.2.1 Special Case . . . . . . . . . . . . . . . . . . . . . . . . 14
2.2.2 General Case . . . . . . . . . . . . . . . . . . . . . . . 15
2.2.3 Error Feedback ΔΣ Modulator . . . . . . . . . . . . . . 16
2.3 Cascade ΔΣ Modulators (MASH) . . . . . . . . . . . . . . . . 17
2.4 Noise Shaping and Oversampling . . . . . . . . . . . . . . . . 18
3 Modeling of Single-Bit Single-Stage ΔΣ Modulators 21
3.1 Linear Modeling of ΔΣ Modulators . . . . . . . . . . . . . . . 21
3.2 Stability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
3.3 Idle Patterns, Dead Zones and Tones . . . . . . . . . . . . . . 25
4 Single-bit Two-Step Look-Ahead Modulator 27
4.1 Analytical Equations of 2-SLA ΣΔ Modulator . . . . . . . . . 27
4.2 Computation of our Examined 2-SLA Modulator . . . . . . . 31
4.3 The Effect of Look-Ahead Steps in Stability . . . . . . . . . . 32
5 Implementation Analysis of 2-SLA Modulator 36
5.1 Cascaded Integrator with Distributed Feedback . . . . . . . . 36
5.2 Scaling Factor for the Fixed Point Representation . . . . . . . 38
5.3 Quantization of the Signals . . . . . . . . . . . . . . . . . . . . 39
5.4 Equivalent System after the Introduction of Gains . . . . . . . 42
5.5 Defining the Number of Bits for each Signal . . . . . . . . . . 44
9
6 FPGA Implementation of 2-SLA Modulator 49
6.1 Verilog Hardware Language . . . . . . . . . . . . . . . . . . . 49
6.2 Output Spectrum . . . . . . . . . . . . . . . . . . . . . . . . . 53
10
Chapter 1
Introduction
Nowadays the tendency is to digitalize each and every analog part of a sys-
tem or an analog signal. The simplicity in processing a digital signal as well
as the reduced noise renders them preferable compared to an analog one. It
is not strange that big effort is made to restrict every analog part of a sys-
tem resulting in the all digital systems. Year by year, the speed and density
of digital integrated circuits (ICs) is increased, enhancing the dominance of
digital methods in almost all areas of communications and consumer prod-
ucts. Therefore always there will be the need for converting the analog signal
in digitalized form and consequently data converters are necessary. As the
speed and capability of Digital Signal Processing (DSP) cores increases, so
too must the speed and accuracy of the converters associated with them.
In fig. 1.1 is depicted the block diagram of a signal processing. The analog
input is driven to an Analog to Digital Converter (ADC), next is inserted in
the DSP core that is the engine that undertook the processing of the signal
and finally through an ADC the analog form of signal is recovered. However
if a single bit Digital to Digital Converted (DDC) replaces the DAC then
just a LPF is adequate to recover the analog signal. A single bit DDC is
preferable compared to the DAC since the latter due to analog mismatches
may introduce no negligible non-linear effects.
In Chapter 2 initially it will be examined some popular topologies of
Modulators. Next it is analysed the noise shaping of Modulators and the
usefulness of Oversampling ratio in the effective operation of them.
In Chapter 3, the linearised model of ΔΣ Modulators for a better sta-
bility examination, is presented. Finally some non-linear phenomenons are
analysed in depth.
11

	



	

Figure 1.1: Digital Signal Processing
In Chapter 4 is given the analytical equations of MSLA Modulator for
step equals two. After that we compute our Modulator i.e. we define its
transfer functions. Finally a comparison with conventional ΔΣ modulators is
presented.
In Chapter 5 is given the architecture of our ΔΣ modulator. Subsequently
we compute the scale factors for each signal in fixed point representation and
next the quantization of signals is made. Finally after calculating the signal
to quantization noise, we determine the bit-width for each and every signal.
In Chapter 6 the results of FPGA implementation are represented as well
as the code of verilog hardware language is given.
12
Chapter 2
Topologies of Digital to Digital
Converter
The analysis is related to DDC but almost the same results are hold for ADC
and DAC. The difference between them is due to different form of input and
ouput (analog/digital). Thus, the suitable transformation has to be taken
place when one is fed back to the other.
2.1 Delta Modulator
Introduction to ADCs begin with an obsolete Modulator which is called Delta
Modulator. The reference to that is made for historical reasons since it was
one of the first ADC converters. A Delta Modulator is illustrated in fig.
2.1a. The presence of the quantizer is responsible renders the system non-
linear which in turn results in difficulties in mathematical analysis. Simple
qualitative understanding of its operation can, however, be gained by using
a linearised model which is depicted in fig. 2.1b. The quantizer has been
replaced with its input plus an error signal which is the difference between
input and output.
V (z) = X(z)−G(z)Y (z) (2.1)
Y (z) = V (z) + E(z) (2.2)
13

 


(a) STF for every k

 




(b) NTF for different N
Figure 2.1: Transfer Functions
Substituting (2.1) into (2.2) it arises :
Y (z) = X(z)−G(z)Y (z) + E(z) (2.3)
Y (z) =
1
1 +G(z)
X(z) +
1
1 +G(z)
E(z) (2.4)
In the right-hand equation the factor of X(z) is the Signal Transfer Func-
tion (STF) since it filters only the input X(z) while the factor of E(z) is the
Noise Transfer Function (NTF) as it filters only the error (or noise) E(z).
Here STF = NTF = 1/(1 + G(z)). That means that filtering of input and
noise for whole band of frequencies is the same.In turn it implies that it is
impossible to attenuate NTF retaining the same time STF close to 1. Due
to this important disadvantage Delta modulators have been abandoned. It
is worth to stress that one of elementary roles of a converter is to pass the
signal as much possible as unchanged. That is we are interested in a mod-
ulator with STF=1 and NTF=0 within the signal band of frequencies that
operates.
2.2 ΔΣ modulator
2.2.1 Special Case
The new suggestion was to change the position of Loopfilter. As shown
in fig. 2.2 the filter instead of lying in feedback path it moved in forward
path resulting in ΔΣ Modulators. The latter is a concurrent and dominant
converter nowadays.
14
 




Figure 2.2: ΔΣ Modulator
Substituting the quantizer with an error source as in fig. 2.1b the de-
scribed equations are given below :
V (z) = (X(z)− Y (z))G(z) (2.5)
Y (z) = V (z) + E(z) (2.6)
Substituting (2.5) into (2.6) it arises :
Y (z) = X(z)G(z)− Y (z)G(z) + E(z) (2.7)
Y (z) =
G(z)
1 +G(z)
X(z) +
1
1 +G(z)
E(z) (2.8)
Now STF = G(z)/(1 +G(z)) and NTF = 1/(1 +G(z)). It is clear that
STF and NTF are different. A suitable choice of G(z) can give desirable
characteristics in STF and NTF within the signal band. However this topol-
ogy is just a case of the general structure of single bit ΔΣ modulator. It was
presented so as to be clear the difference with Delta modulator.
2.2.2 General Case
The general structure of high order single bit ΔΣ modulator is illustrated in
fig. 2.3. Our goal is to express the output of quantizer Y as a function of
input X and its error E in order to specify the STF and NTF. So we have a
system with two inputs (X,V) and one output Y.
V = L0X + L1Y (2.9)
Also applying the linearised model :
Y = V + E (2.10)
15


	 


Figure 2.3: ΔΣ Modulator
,it is obtained :
Y = L0X + L1Y + E (2.11)
Y =
L0
1− L1X +
1
1− L1E (2.12)
For L0 = L1 = G result in the special case that examined above. Back
in general case we see that it gives the absolute freedom in STF and NTF
choice.
2.2.3 Error Feedback ΔΣ Modulator
A very interesting topology is the 1-bit SD error Feedback modulator. It s
shown in fig. 2.4 .








Figure 2.4: Error Feedback
Applying the superposition theorem the input X is filtered by 1+G(z)
and the output of Quantizer Y is filtered by -G(z). Hence L0 = 1 + G(z)
and L1 = −G(z). Having these filters easily is verified that STF = 1 and
16
NTF = 1/(1 +G(z)). Hence
Y (z) = X +
1
1 +G(z)
E (2.13)
As it can be seen STF=1 no matter is the choice of filter G(z). Thus, our
thoughts are eliminated in specification of filter G(z) meaning NTF. This
topology constitutes the basis for the introduction to 1-bit Multi-Step Look-
Ahead (MSLA) ΔΣ Modulator in Chapter 4 which is a new suggestion of ΔΣ
modulators.
2.3 Cascade ΔΣ Modulators (MASH)


	





	 







Figure 2.5: Multi Stage ΔΣ Modulator
Another interesting topology is the multi-stage-noise-shaping Modulator.
It includes a lot of stages instead of just one. The MASH is depicted for two
17
stages, in fig. 2.5. The quantization error of the first stage is inserted in the
second stage and it outputs a quantized estimation of the error. That output
is filtered and added to the filtered output of the first ΔΣ Modulator in order
to eliminate the quantization error. The equation for the first ΔΣ modulator
is :
Y1(z) = STF1(z)X(z) +NTF1(z)E1(z) (2.14)
and for the second one is :
Y2(z) = STF2(z)E1(z) +NTF2(z)E2(z) (2.15)
The output is formed as (z variable is omitted for presentation reasons) :
Y = H1Y1 −H2Y2 (2.16)
Y = H1STF1X + (H1NTF1 −H2STF2)E1 −H2NTF2E2 (2.17)
Consequently the error E1 can be cancelled if H1NTF1 − H2STF2 = 0.
A familiar choice of filters is H1 = STF2 and H2 = NTF1. Then output Y
is gained as :
Y = STF2STF1X −NTF1NTF2E2 (2.18)
Y = STF ·X −NTF · E2 (2.19)
where STF = STF2STF1 and NTF = NTF1NTF2.
If STF2, STF1 is just a delay then |STF | = 1 while if the NTF1, NTF2
is of the form (1 − z−1)Ni ,i=1,2 (where N1,N2 the order of NTF1, NTF2
respectively) then NTF = (1 − z−1)N1+N2 . As it will be seen in the section
2.4 that is desirable because the noise is shifted more in high frequencies
namely a better noise shaping is succeeded (fig. 2.6b).
2.4 Noise Shaping and Oversampling
It should be noted that ΔΣ modulators are working well in the ranges of
frequencies where the absolute value of STF is near 1 and NTF is close to 0.
It can be succeeded by a good noise shaping namely shifting the noise out of
the interested band, keeping it low within the band and high out of that. The
interested band characterize the modulators as lowpass or bandpass when
that band is a low or a zone band of frequencies respectively. Without loss of
18
generality it will be considered that modulators operate in low frequencies.
Then possible choices and widely known classes are :
STF1 = z
−k (2.20)
NTF1 = (1− z−1)N (2.21)
where N is the order of filter L1 and N+k the order of filter L0.
Taking into account the transformation from Laplace to Z domain z = e−jΩ,
z = 1 for Ω = 0. Hence in low frequencies indeed |STF | = 1 and |NTF | = 0
(|STF | = 1 in each and every frequency). In fig. 2.6a,2.6b are plotted 2
diagrams. The first one depict the absolute value of STF which is 1 for every
k and the second one depict the absolute values of NTF for N=1,2,3 both
in function of frequency Ω. For higher order filter the noise is suppressed
more in low frequencies and it is shifted in regions out of the band that ΔΣ
modulator operates.
Normalized frequency x pi rad/s
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
0
0.2
0.4
0.6
0.8
1
1.2
1.4
1.6
1.8
2
—STF—
(a) STF for every k
Normalized frequency x pi rad/s
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
0
1
2
3
4
5
6
7
8
—NTF—
N=1
N=2
N=3
(b) NTF for N=1,2,3
Figure 2.6: Transfer Functions
It will be examined now in what way oversampling affects positively the
lowpass modulators. In fig. 2.6a,2.6b, (2.20) and (2.21) are plotted in func-
tion of frequency Ω. It is clear the closer to 0 for Ω the closer to 1 for STF
and closer to 0 for NTF. Assuming that fb is the frequency bandwidth of in-
put and fs is the sampling frequency, OverSampling Ratio (OSR) is defined
19
as follow :
OSR =
fs
2fb
(2.22)
Assuming that input analog signal x with amplitude A has frequency fb ,
the sampled signal xs will have frequency fb/fs. Writing it by equations we
have:
x = Asin(2pifbt)
xs = Asin
(
2pi
fb
fs
n
)
= Asin
( pi
OSR
n
)
(2.23)
Therefore the frequency of sampled signal is given as :
Ω =
pi
OSR
(2.24)
Obviously the frequency of sampled signal depends exclusively on OSR. In-
creased OSR is equivalent to lower Ω and hence better behaviour of STF and
NTF. It’s worth to note however that if fb is high then it is hard to retain a
high OSR since the sampling frequency fs has to be increased proportionally
(see (2.22)).
20
Chapter 3
Modeling of Single-Bit
Single-Stage ΔΣ Modulators
3.1 Linear Modeling of ΔΣ Modulators
In Chapter 2 for our analysis the quantizer was represented as its input
and an error source. For the latter a white noise approximation was given.
Unfortunately, the quantizers used in ΔΣ modulators hardly ever match the
requirements to validate that approximation:
• The number of quantization levels is usually very small.
• The quantizer can be in overload.
• The input signal of the quantizer is generally not a random (white) signal.
Although adding a dither signal could satisfy the latter requirement, the low
resolution of the quantizers renders the model invalid. A one-bit quantizer
in particular cannot be modeled by the addition of independent noise. A
technique to study more accurately the behaviour of a ΔΣ modulator about
stability is to insert a gain factor as depicted in fig. 3.1.
The equation for NTF is now :
NTF =
1
1− kL1 (3.1)
If the quantization levels of the quantizer are more than two, the gain (k)
of this can be determined uniquely as depicted in fig. 3.2a. The reason is
that a certain gain (k) choice offers the least divergence between quantizer
input and output, giving the minimized error in aforementioned linear model
and restricting that way the non-linear effect due to the quantizer. In other
21


 

	
Figure 3.1: Linear Model
words the linear model is more accurate for a specific value of the gain k.
Notice merely that this gain is embedded in the quantizer operation meaning
when a quantization is happening the gain factor implicitly is applied. In
the other hand when there are only two quantization levels i.e. the quantizer
output is single bit (fig. 3.1) ,the gain cannot be determined directly. The
error minimization depend on the input type into the quantizer. Therefore
for different inputs an alternate k is chosen so as the non-linear effect (the
error sequence) to be restricted. Two lines are plotted in fig. 3.2b, showing
the gain choice is not readily obtained.
-6 -4 -2 0 2 4 6
-5
-4
-3
-2
-1
0
1
2
3
4
5
(a) Easy computation of k
-1 -0.8 -0.6 -0.4 -0.2 0 0.2 0.4 0.6 0.8 1
-1.5
-1
-0.5
0
0.5
1
1.5
(b) k is dependent on input type
Figure 3.2: filters
22
The computation task for the gain is given right now. If the statistical
averages indices of y are known, an optimality criterion for k is to minimize
the mean square value (namely the average power) of the error sequence e.
This is defined as the expected (or mean) value of e2:
y[n] = lim
N→∞
(
1
N
N∑
n=0
a(n)b(n)
)
(3.2)
Since e = v − ky , the average power of e can be written as
σ2e = (e, e) = (v − ky, v − ky) = (v, v)− 2k(v, y) + k2(y, y) (3.3)
Taking the partial derivative, k for minimizing the variance is obtained
ds/dk = 0 =⇒ −2(v, y) + 2k(y, y) = 0 =⇒ k = (v, y)
(y, y)
=
E{|y|}
E{y2} (3.4)
since the output of quantizer is the sign of y(n) it follows v(n)y(n) =
|y(n)|.
A more sophisticate and complicate model for calculating the quantiza-
tion noise was suggested by Ardalan and Paulos. They introduced a sepa-
rate gain for the signal and the quantization noise. Although fitting a more
elaborate model to the non-linear quantizer can result in more accurate pre-
dictions, it does not give significantly more insight in the behaviour of the
single-bit ΔΣ.
3.2 Stability
It is clear that in the feedback path only L1 exists meaning it is nearly the
exclusive factor in stability issues. Once NTF = 1/(1−kL1) the same holds
for NTF. Because of the non-linear behaviour and nature of ΔΣ modulator
an accurate criterion to predict the stability characteristics do not exist. The
linear models are merely ways to approach and study a non-linear system.
Nevertheless a lot of methods in order to ensure stability have been obtained.
The most widely-used criterion is that of Lee which says :
A single-bit modulator is likely to be stable if max(NTF ) < c. Lee’s
authentic criterion says that c = 2 but an edited criterion says that c depends
on the order of NTF and is decreased up to 1.4 as the order of modulator
23
is increased. Another interesting criterion is about computing the mean-
squared value of the magnitude response of the NTF (noise amplification
factor) requiring :
A =
1
2pi
|NTF (ejθ)|2dθ < 2.5 (3.5)
Note that these criteria are neither necessary nor sufficient. Nevertheless,
due to its simplicity, they offer a quick and simple first view about modulator
stability. For more accurate details extensive simulations in environments
such as matlab are necessary.
It should be noted also, the out of band gain does not impact the efficiency
of modulator (as aforementioned) but a high value in the out of band gain
overload the quantizer forcing the system to be unstable. Provided that the
out of band gain is considerable in high order filters (see fig. 2.6b), such
filters cause instability and hence there is a restriction in choosing the order
of a filter.
A ΔΣ Modulator in a stable operation is depicted in fig. 3.3a. The output
density, {+1,−1} is higher at the region around the peaks of the sinusoidal
signal. However this is not occurred in fig. 3.3b meaning that ΔΣ modulator
is in an unstable mode. The result is long sequences of consecutive +1 or
-1, i.e. the output sequence no longer tracks the input signal due to the
overloaded quantizer.
Samples
0 50 100 150 200 250 300 350 400 450 500
Am
pl
itu
de
 (N
orm
ali
se
d t
o q
ua
nti
ze
r fu
ll s
ca
le)
-1
-0.8
-0.6
-0.4
-0.2
0
0.2
0.4
0.6
0.8
1
Input and output of DS Modulator
(a) Stable operation of ΔΣ Modulator
Samples
0 200 400 600 800 1000 1200 1400 1600 1800 2000
Am
pl
itu
de
 (N
orm
ali
se
d t
o q
ua
nti
ze
r fu
ll s
ca
le)
-1
-0.8
-0.6
-0.4
-0.2
0
0.2
0.4
0.6
0.8
1
Input and output of DS Modulator
(b) Instability of the ΔΣ Modulator
Figure 3.3: filters
24
To overcome an unstable mode of ΔΣ modulator a stabilization technique
could be applied. However in that case the Signal to Noise Ratio (SNR)
is significantly decreased requiring concurrently a reasonable time period to
return in the normal mode. Therefore the conclusion is that it is preferable to
ensure that modulator will never become unstable rather than a stabilization
technique to be applied.
3.3 Idle Patterns, Dead Zones and Tones
The repetitive patterns that are founded in the output of the modulator under
zero input signal constitute in substance a limit cycle, termed idling pattern.
To obtain a view of this phenomenon assume a modulator which consists of
just one accumulator for which holds that L0 = L1 = z
−1/(1 − z−1). Lets
x0 where 0 < x0 < 1 be the initial state of the filter. Once the first input
in the quantizer is x0 its output will equal to 1. So its next input will be
x0 − 1 < 0 and therefore its next output will be −1. Its next input now will
be (x0 − 1) + 1 = x0 and hence its output will be again 1 and so on. Thus
the sequence 1,-1,1,-1,.. takes place with frequency fs/2 since every second
sample there is change in sequence. Idle pattern itself is not a problem since
we supposed a zero input. The problem is occurred when input changes to
a non-zero type and the idle pattern cannot be broken. This is happening
for small input amplitudes which is called that belong in the dead zone i.e.
a zone of inputs that modulator cannot decode. As an example consider a
sinusoidal input u[n] = Asin(2pi fb
fs
n) where fb is the frequency bandwidth of
input signal and fs = 1/Ts is the frequency sampling. For numerous samples,
m 1 and for high OSR, fs  fb the following approximation can be done
:
m∑
n=0
u[n] ≈ Ts
∫ mTs
n=0
Asin(2pifbt)dt =
Afs
2pifb
[cos(2pifbTsm)− 1] (3.6)
Clearly the maximum value is
sum max =
Afs
2pifb
> 0 (3.7)
Therefore in order to cancel idle pattern one of 2 following cases must hold :
x0 + sum max < 0 =⇒ sum max < −x0 or (3.8)
(x0 − 1) + sum max > 0 =⇒ sum max > (1− x0) (3.9)
25
Remember that initially x0 > 0 and (x0 − 1) < 0. So the aforementioned
equations ensure that idle pattern is broken avoiding in that way the dead
zone. Provided that sum max, x0 > 0 only (3.9) holds and the worst case is
for x0 = 0. From (3.7),(3.9) for the worst case it arises :
Afs
2pifb
> 1 =⇒ A > 2pifb
fs
=
pi
OSR
(3.10)
The equation gives the minimum value of sinusoidal amplitude so as a
limit cycle to be avoided :
Amin =
2pifb
fs
(3.11)
Notice that a higher fb demands a higher amplitude Amin to overcome the
dead-zone. Consequently dead zone effect is more intense in high frequencies
within the signal band. A similar procedure should be followed for higher
order loop filters. The higher gain in the loop filter gives the ability the
modulator to ′′recognise′′ smaller signals restricting as much the dead-zone
as idle pattern to be considered an ignored and unimportant effect. The
appearance of an idle pattern is translated into tones in frequency domain
and can easily be detected from the human ear or eye in an audio or video
application.
26
Chapter 4
Single-bit Two-Step
Look-Ahead Modulator
4.1 Analytical Equations of 2-SLA ΣΔ Mod-
ulator
To retain our analysis simple we will examine the Multi-Step Look-Ahead
(MSLA) for step k=2. For the remainder of this assignment it will be men-
tioned as 2-Step Look-Ahead (2-SLA) Modulator. However, the general proof
is given in [1]. Moreover the system that examined is about a step k=2, hence
more depth in analysis may confuse the reader. It has been proved that the
optimal 1-bit output sequence for a given input sequence and filter is ob-
tained by Viterbi decoding the input sequence over the convolutional code
generated by the filter. Yet, Viterbi decoding becomes exponentially complex
with the length of the input sequence. It has been also proved that the error-
feedback ΔΣ modulator produces the optimal 1-bit output sequence when a
first-order loop filter is used. Therefore, this ΔΣ modulator topology forms
the basis for the development of the MSLA modulator. Τhe general form of
G(z) is
G(z) =
∑l
i=1 biz
−i
1 +
∑m
i=1 aiz
−m (4.1)
where l,m are the orders of the numerator and the denominator respectively.
Here for the purposes of our system and for reasons of simplicity we
27







Figure 4.1: Error Feedback as an optimization problem
eliminate the order of G(z) to 3. From inspection of fig. 4.1 :
G(z) =
E(z)
X(z)− Y (z) (4.2)
where X(z), Y(z), E(z) and G(z) are the z-transforms of the input, output,
filter output and loop filter impulse response sequences respectively.
From (4.1) and (4.2) with l = m = 3 it arises :
E(z)
X(z)− Y (z) =
b1z
−1 + b2z−2 + b3z−3
1 + a1z−1 + a2z−2 + a3z−3
(4.3)
Hence in time domain easily verified that :
e[n] + a1e[n− 1] + a2e[n− 2] + a3e[n− 3] = b1(x[n− 1]− y[n− 1])
+ b2(x[n− 2]− y[n− 2]) + b3(x[n− 3]− y[n− 3]) (4.4)
This equation will be useful next.
The topology now could be seen as an optimization problem. It is known that
the output is single bit. It means that when the quantizer input (x[n]+e[n])
is positive, the output is 1 and if it is not positive, the output is -1. Con-
sequently every time the negative value of the possible output, −v tends to
bring the sum (x[n]+e[n]) toward zero. By equations it means that consid-
ering the cost function
S = |x[n] + e[n]− v| (4.5)
the role of v = ±1 is to minimize it. The choice of that v is the output y[n].
Therefore :
y[n] = arg min
v∈±1
S (4.6)
28
From 4.6 it is concluded that the output of the error-feedback ΔΣ mod-
ulator is determined by the instantaneous minimization of the quantization
error within the bandwidth of the loop filter. The optimal solution would be
the minimization of the total time-domain quantization error shaped by the
loop filter. The latter would require Viterbi decoding and is impossible for
an infinite input sequence. A compromise between the optimal solution and
hardware complexity is possible if the minimization of the quantization error
is restricted to the current and the next 2 (here) future input samples.
S0 = |x[n− 2] + e[n− 2]− v0| (4.7)
S1 = |x[n− 1] + e[n− 1]− v1| (4.8)
S2 = |x[n] + e[n]− v2| (4.9)
y[n− 2] = arg min
v0∈±1
[
min
v1,v2∈±1
(S0 + S1 + S2)
]
(5) (4.10)
Thus the calculation of y[n−2] requires the knowledge of e[n−2], e[n−1], e[n].
The latter can be expressed in function of previous values if in (4.4) the
suitable timing shift is applied. In addition we must note that the outputs
y[n − 2], y[n − 1] are expressed as v0, v1 respectively since they have not be
defined yet.
e[n− 2] = b1(x[n− 3]− y[n− 3]) + b2(x[n− 4]− y[n− 4])
+ b3(x[n− 5]− y[n− 5])− a1e[n− 3]− a2e[n− 4]− a3e[n− 5] (4.11)
e[n− 1] = b1(x[n− 2]− v0) + b2(x[n− 3]− y[n− 3])
+ b3(x[n− 4]− y[n− 4])− a1e[n− 2]− a2e[n− 3]− a3e[n− 4] (4.12)
e[n] = b1(x[n− 1]− v1) + b2(x[n− 2]− v0)
+ b3(x[n− 3]− y[n− 3])− a1e[n− 1]− a2e[n− 2]− a3e[n− 3] (4.13)
Extensive simulations have shown that keeping the last cost function term
of the sum in 4.10 (S2) does not typically impact performance. In fact,
in many cases it offers superior stability than calculating the output using
29
all terms, while fewer terms lead to lower hardware complexity. Thus, the
following simplification of the decision rule is proposed.
y[n] = arg min
v0∈±1
(
min
v1,v2∈±1
S2
)
(4.14)
Substituting the (4.13) into (4.9) we have :
S2 = |x[n] + b1x[n− 1] + b2x[n− 2] + b3(x[n− 3]− y[n− 3])
− a1e[n− 1]− a2e[n− 2]− a3e[n− 3]− b2v0 − b1v1 − v2| (4.15)
Our goal is to write S2 as linear combination of v0, v1, v2. So e[n−1] from
(4.12) has to be substituted in (4.15) since the first one contains the variable
v0. The (4.11) is useless since this does not contain some of minimized
variable v0, v1, v2.
S2 = |x[n]+b1x[n−1]+(b2−a1b1)x[n−2]+(b3−a1b2)x[n−3]−a1b3x[n−4]
− (b3 − a1b2)y[n− 3] + a1b3y[n− 4]
+ (a1a1 − a2)e[n− 2] + (a1a2 − a3)e[n− 3] + a1a3e[n− 4]
− (b2 − a1b1)v0 − b1v1 − v2| (4.16)
Defining the signal u[n] as
u[n] = x[n]+b1x[n−1]+(b2−a1b1)x[n−2]+(b3−a1b2)x[n−3]−a1b3x[n−4]
− (b3 − a1b2)y[n− 3] + a1b3y[n− 4]
+ (a1a1 − a2)e[n− 2] + (a1a2 − a3)e[n− 3] + a1a3e[n− 4] (4.17)
the (4.16) can be written as
S2 = |u[n]− (b2 − a1b1)v0 − b1v1 − v2| (4.18)
Well now it looks similar to the cost function in (4.5) (namely the Error-
Feedback modulator) with the minimization variables to be 3 instead of 1
i.e. v0, v1, v2.
Taking the z-Transform of (4.17) it gives :
U(z) = (1 + b1z
−1 + (b2 − a1b1)z−2 + (b3 − a1b2)z−3 − a1b3z−4)X(z)
+(−(b3−a1b2)z−3+a1b3z−4)Y (z)+((a1a1−a2)z−2+(a1a2−a3)z−3+a1a3z−4)E(z)
(4.19)
30
Substituting the output filter, E(z) from (4.3) into the (4.19) we have
U(z) = (1 + b1z
−1 + (b2 − a1b1)z−2 + (b3 − a1b2)z−3 − a1b3z−4)X(z)
+ (−(b3 − a1b2)z−3 + a1b3z−4)Y (z)+
((a1a1−a2)z−2+(a1a2−a3)z−3+a1a3z−4) b1z
−1 + b2z−2 + b3z−3
1 + a1z−1 + a2z−2 + a3z−3
(X(z)−Y (z))
(4.20)
Setting
A = ((a1a1−a2)z−2+(a1a2−a3)z−3+a1a3z−4) b1z
−1 + b2z−2 + b3z−3
1 + a1z−1 + a2z−2 + a3z−3
(4.21)
we have :
U(z) = (1 + b1z
−1 + (b2 − a1b1)z−2 + (b3 − a1b2)z−3 − a1b3z−4 + A)X(z)
+ (−(b3 − a1b2)z−3 + a1b3z−4 − A)Y (z) (4.22)
After the trivial algebraic calculations the final equation is simplified. Our
result is about the signal y[n-2], thus replacing Y (z) with z2Y (z) the final
result related to signal y[n] is obtained :
U(z) =
1 + (a1 + b1)z
−1 + (a2 + b2)z−2 + (a3 + b2a1 + b3 − a2b1)z−3
1 + a1z−1 + a2z−2 + a3z−3
X(z)
−(a
2
1b1 − a2b1 − a1b2 + b3)z−1 + (a1a2b1 − a2b2 − a3b1)z−2 + (a1a3b1 − a3b2)z−3
1 + a1z−1 + a2z−2 + a3z−3
Y (z)
(4.23)
4.2 Computation of our Examined 2-SLA Mod-
ulator
Choosing as NTF
NTF = (1− z−1)3 (4.24)
G(z) is readily calculated :
G(z) =
1−NTF
NTF
=
3z−1 − 3z−2 + z−3
1− 3z−1 + 3z−2 − z−3 (4.25)
31
Hence comparing with the general form of G(z) in (4.1) the factors are ob-
tained
b1 = 3, b2 = −3, b3 = 1 (4.26)
a1 = −3, a2 = 3, a3 = −1 (4.27)
Substituting these values into the general form of 2-SLA in (4.23) our exam-
ined 2-SLA ΔΣ Modulator is obtained :
L0(z) =
1
(1− z−1)3 (4.28)
L1(z) = −10z
−1 − 15z−2 + 6z−3
(1− z−1)3 (4.29)
and
STF
′
=
z−3
1 + 7z−1 − 12z−2 + 5z−3 (4.30)
NTF
′
=
(1− z−1)3
1 + 7z−1 − 12z−2 + 5z−3 (4.31)
In fig.4.2 is plotted the absolute values of our STF
′
and NTF
′
in com-
parison with the familiar class of STF = z−k where k is depend on the order
of the filter L0, and NTF = (1 − z−1)3. We observe a better behaviour in
the very low frequencies for |NTF ′| compared to that of |NTF | since the
former is closer to 0.
4.3 The Effect of Look-Ahead Steps in Sta-
bility
In (4.10) it was found the decision rule for 2-SLA modulator. For MSLA
with the number of steps to be k the decision rule is generalized :
y[n] = arg min
v0∈±1
[
min
v1,v2,...,vk∈±1
k∑
j=0
Sj
]
(4.32)
The performance of MSLA modulators has been verified using extensive
MATLAB simulations. It has been observed that in many cases a better
32
Normalized frequency x pi rad/s
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
0
0.2
0.4
0.6
0.8
1 |STF'||STF|
(a) Comparison of Signal Transfer Functions
Normalized frequency x pi rad/s
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
0
0.5
1
1.5
2
2.5
3
3.5
4
|NTF'|
|NTF|
(b) Comparison of Νoise Transfer Functions
Figure 4.2: Transfer Functions
output dynamic range may be obtained when the last or the last two metrics
Sk,n and Sk−1,n in (4.32) are taken into account for the computation of the
output, thus greatly simplifying the hardware complexity at the same time.
Several different loop filters and associated NTFs have been simulated and
results have been obtained, which demonstrate the improvement of the sta-
bility characteristics of the modulator as the number of look-ahead steps k
is increasing. The maximum sinusoidal input amplitude resulting in stable
operation of the modulator is chosen as the stability measure.
NTFs which are stable when employed in a conventional ΔΣ modulator,
remain stable for higher input amplitudes with higher values of k, while
unstable NTFs may offer stable operation when k is increased.
The attained results are shown in Fig. 4.3, while the corresponding fil-
ters are shown in Table 4.1. The stability was determined by MATLAB
simulations of 2 · 106 input samples. For the low-pass filters 1-4 the signal
xn = A sin (2pi · 0.0041482n) was used as the input, whereas for the band-pass
filter 5 the input signal was in the form xn = A sin (2pi · 0.365n). The effect
of the look-ahead steps k in the increase of the maximum stable sinusoidal
input amplitude is evident. Conclusively, the MSLA modulator offers higher
input dynamic range than a conventional ΔΣ modulator with the same NTF.
The main consideration for the selection of the NTF poles are the stability
requirements of the conventional ΔΣ modulator. The NTFs 4-5 do not have
33
xlabel
0 1 2 3 4 5 6
yla
be
l
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
title
Filter 1
Filter 2
Filter 3
Filter 4
Filter 5
Figure 4.3: Maximum stable sinusoidal input amplitude for different look-
ahead steps k and NTFs (shown in Table 4.1)
any poles for the reduction of the out-of-band gain of the corresponding
loop filters and are unstable when used in a conventional ΔΣ modulator.
The obtained simulation results demonstrate that such NTFs may be used
in a MSLA modulator and offer stable operation for a wide range of input
amplitudes when the value of k is sufficiently large (≥ 2). Thus, the design
space of the NTF is greatly increased allowing for the selection of the zeros
and poles of the NTF based on other design criteria apart from stability.
34
Table 4.1: Filter transfer functions of Fig. 4.3
Transfer function
NTF 1 1−3.996z
−1+5.993z−2−3.996z−3+z−4
1−3.131z−1+3.724z−2−1.99z−3+0.4029z−4+3.5·10−5z−5
NTF 2 (1−z
−1)(1−1.994z−1+z−2)
(1−0.5995z−1)(1−1.384z−1+0.5892z−2)
NTF 3 (1−z
−1)(1−2z−1+z−2)
(1−0.6694z−1)(1−1.531z−1+0.6639z−2)
NTF 4 (1− z−1)3
NTF 5 (1− cos (2pi · 0.365)z−1 + z−2)2
35
Chapter 5
Implementation Analysis of
2-SLA Modulator
5.1 Cascaded Integrator with Distributed Feed-
back
In this section we present the structure of our 2-SLA modulator . It is
constructed by cascaded integrators with distributed feedback (CIDF). The
schematic diagram is in fig. 5.1.



 


 


 

Figure 5.1: CIDF architecture for the construction of our 2-SLA Modulator
This architecture offers a lot of positive characteristics. As it is shown
every integrator is related with just prior values and not older than them.
36
In other words each of them needs only one register for memory purposes.
Furthermore no multiplications are required. Provided that V = ±1, the
factors a1,a2,a3 will be either a positive or a negative constant. That is an
”if” statement for choosing the suitable value can be used.
By writing the equations it will be verified that filters with input X or
V and output Y equal (4.28) and (4.29) respectively calculating at the same
time the factors a1,a2,a3.
Assuming V=0 and X the only one input the ratio Y/V will be found.
Y1 = X + Y1z
−1 (5.1)
Y2 = Y1z
−1 + Y2z−1 (5.2)
Y3 = Y2z
−1 + Y3z−1 (5.3)
Y = Y3z
−1 (5.4)
Solving each equation for Y1, Y2, Y3 it arises :
Y1 =
X
1− z−1 (5.5)
Y2 =
Y1z
−1
1− z−1 (5.6)
Y3 =
Y2z
−1
1− z−1 (5.7)
Y = Y3z
−1 (5.8)
With successive substitutions from (5.8) toward (5.5) it arises :
Y =
Y2z
−2
1− z−1 =
Y1z
−3
(1− z−1)−2 =
Xz−3
(1− z−1)−3 (5.9)
Therefore
Y
X
=
z−3
(1− z−1)−3 (5.10)
As it is seen the the above filter equals L0(z) filter of (4.28). The factor z
−3
is just three delays and its existence does impact the filter behaviour.
Assuming now X=0 and V the only one input the ratio Y/V will be found.
Y1 = a1V + Y1z
−1 (5.11)
Y2 = a2V + Y1z
−1 + Y2z−1 (5.12)
Y3 = a3V + Y2z
−1 + Y3z−1 (5.13)
Y = Y3z
−1 (5.14)
37
Solving each equation for Y1(1− z−1), Y2(1− z−1), Y3(1− z−1) it arises :
Y1(1− z−1) = a1V (5.15)
Y2(1− z−1) = a2V + Y1z−1 (5.16)
Y3(1− z−1) = a3V + Y2z−1 (5.17)
Y = Y3z
−1 (5.18)
Multiplying (5.18) with (1− z−1) and combining this with (5.17) we have :
Y (1− z−1) = a3V z−1 + Y2z−2 (5.19)
Multiplying the above equation with (1−z−1) and combining this with (5.16)
we have :
Y (1− z−1)2 = a3V z−1(1− z−1) + a2V z−2 + Y1z−3 (5.20)
Finally we multiply the above equation with (1−z−1) and combine this with
(5.15) :
Y (1− z−1)3 = a3V z−1(1− z−1)2 + a2V z−2(1− z−1) + a1V z−3
Y
V
=
a3z
−1(1− z−1)2 + a2z−2(1− z−1) + a1z−3
(1− z−1)3
Y
V
=
a3z
−1 + (a2 − 2a3)z−2 + (a1 − a2 + a3)z−3
(1− z−1)3 (5.21)
Comparing with L1(z) in (4.29), the factors a1,a2,a3 are calculated :
a3 = −10
a2 − 2a3 = 15 =⇒ a2 = −5
a1 − a2 + a3 = −6 =⇒ a1 = −1
(5.22)
5.2 Scaling Factor for the Fixed Point Rep-
resentation
For the representation of signals the Fixed Point Representation (FPR) is
used. Every signal in this representation is considered to be a fraction where a
scale factor implicitly accompany it. If we multiply the fraction number with
38
the scale factor the actual value of the signal is obtained. In an implemented
system now every signal is a stream of bits which represent the fraction
number. The scale factor (which is almost always power of two) defines the
range of signal while the number of bits of stream defines the precision for
that scale factor. Caution must be given in the choice of the scale factor so
as the whole range of a signal can be represented as well as not having a
high value which results in lower precision. Let’s represent now the 2-SLA of
fig. 5.1 in FPR. A generalized solution would be to examine the maximum
value of all signals, next choose the minimum scale factor which can represent
that value and eventually applying in each and every signal that scale factor.
The maximum value can be found inserting as input the Maximum Stable
Amplitude input for a given frequency (MSA) i.e. the maximum input for
which stability is guaranteed. However, a more efficient solution is to apply in
each of three integrators a different scale factor. Finding the maximum value
for every one the least scale factor is applied to the corresponding integrator.
The widest range for every one arises from theirs outputs y1[n],y2[n],y3[n]
(moreover the range of y1 is smaller than y2 and y2 smaller than y3). By
observing the fig. 5.2a-5.2c, in the first integrator a scale factor SF = 24 is
chosen, in the second integrator a SF = 25 is chosen while in the last one a
SF = 26 is chosen.
Let’s assume now an input to the modulator within the range −1 < x < 1
with a scale factor of 20. Shifting it right 4 bits a scale factor of s1 = 2
4 is
obtained for all signals in modulator. Since the input to second stage has a
scale factor of 24, shifting it right 1 bit a scale factor of s2 = 2
5 is obtained
for all signals in second and third stage. Finally similarly shifting one bit
the input to third stage a scale factor of s3 = 2
6 is obtained for the third
stage. In the fig. 5.3 the CIDF structure with shift operations is given.
This solution is better because in every integrator the minimum scale factor
is applied allowing in that way a higher precision. Notice that in feedback
path the factors are affected (symbolised as a
′
1, a
′
2, a
′
3) due to shifts operations
s1, s2, s3 (namely gains) but it will be discussed in section 5.4.
5.3 Quantization of the Signals
No discussion made for the precision of signals. Lets quantize our system. In
fig. 5.4 the blocks Q1, Q2, Q3 are each of them a Quantizer which truncates
the signal keeping only a certain number of bits for every one. As showed
39
×10 6
0 0.5 1 1.5 2
-5
-4
-3
-2
-1
0
1
2
3
4
5
y1
(a)
×10 6
0 0.5 1 1.5 2
-15
-10
-5
0
5
10
15
y2
(b)
×10 6
0 0.5 1 1.5 2
-20
-15
-10
-5
0
5
10
15
20
25
y3
(c)
Figure 5.2: Maximum Amplitude of each integrator



 


 






Figure 5.3: CIDF architecture with different scale factor for each integrator
40


 

 




 


 


Figure 5.4: CIDF architecture with Quantizers (real system)
in section 3.1 a multi-bit quantizer can be represented by a gain factor plus
an error source (fig. 5.5). Assuming that q1, q2, q3 are the gains of quantizers
Q1, Q2, Q3 respectively then :
p = q12
−4
m = q22
−1
n = q32
−1
(5.23)
where p,m, n are illustrated in fig. 5.5.

























Figure 5.5: CIDF structure. Quantizers replaced by theirs linear model
In a first place we are interested in examining how the introduction of
gains change the range i.e the weight factor of signals in FPR affecting hence
the balance in the whole system and in which way the same analogy between
them could be recovered resulting thus in an equivalent system. In order a
comparison between fig. 5.1 and fig. 5.5 to be achievable, the error sources
41
have to be zeroed. Fortunately the described model of the system is linear,
thus the theorem of superposition can be applied. Firstly error sources are
zeroed, next searching for an equivalent system to that of fig. 5.1 (namely
specifying factors a
′
1, a
′
2, a
′
3 of fig. 5.5) and finally adding the error sources
back.
5.4 Equivalent System after the Introduction
of Gains
The following matrix describe the system of fig. 5.1
 Y1Y2
Y3
 = 1
1− z−1
 0Y1 · z−1
Y2 · z−1
+
 a1a2
a3
 · V +
 10
0
X

while the next matrix describes the fig.5.3 (with now s1 → p, s2 →
m, s3 → n) i.e. takes into consideration the inserted gains from the deter-
mination of scale factor for each integrator as well as from the quantization
of signals. Every signal as well as the gain of amplifiers a1,a2,a3 are chang-
ing value. Symbol ’ after a variable shows that it is a new variable. To
remind that our goal is to calculate the factors a
′
1,a
′
2,a
′
3 in order to acquire
an equivalent architecture with the initial one (fig. 5.1).
 Y ′1Y ′2
Y
′
3
 = 1
1− z−1
 0mY ′1 · z−1
nY
′
2 · z−1
+
 a′1a′2
a
′
3
 · V +
 p0
0
X

We know that Q(Y (z)) = Q(rY (z)) ⇐⇒ Q(Y3(z − 1)) = Q(rY3(z − 1))
where r is a positive integer since the sign remains the same. So our goal
is to show Y
′
3 = rY3. For Y
′
3 = rY3 comparing the third row of first and
second matrix we find that Y
′
2 have to equal Y
′
2 = r/n · Y2 and a′3 = r · a3.
Substituting these values in the second matrix we have : Y ′1(r/n)Y2
rY3
 = 1
1− z−1
 0mY ′1 · z−1
rY2 · z−1
+
 a′1a′2
ra3
 · V +
 p0
0
X

42
Now the values of Y
′
1 and a
′
2 have to be equal to Y
′
1 = r/(nm)Y1 and
a
′
2 = r/n · a2. Substituting these values in the previous matrix we have :
 (r/nm)Y1(r/n)Y2
rY3
 = 1
1− z−1
 0(r/n)Y1 · z−1
rY2 · z−1
+
 a′1(r/n)a2
ra3
 · V +
 p0
0
X

Now the values of p and a
′
1 have to be equal to p = r/(nm) and a
′
1 =
r/(nm) · a1. Substituting these values in the previous matrix we have :
 r/(nm)Y1(r/n)Y2
rY3
 = 1
1− z−1
 0(r/n)Y1 · z−1
rY2 · z−1
+
 r/(nm) · a1(r/n)a2
ra3
 · V +
 r/(nm)0
0
X

That was the proof of equivalence of two systems. Variable r is cancelled and
it implies that Y
′
3 equals Y3. Next, multiplication with knm is made so as to
return in the initial matrix. Therefore :
 kY1kmY2
kmnY3
 = 1
1− z−1
 0kmY1 · z−1
kmnY2 · z−1
+
 ka1kma2
kmna3
 · V +
 k0
0
X

Eventually renaming the variables it arises : Y ′1Y ′2
Y
′
3
 = 1
1− z−1
 0mY ′1 · z−1
nY
′
2 · z−1
+
 k · a1km · a2
kmn · a3
 · V +
 k0
0
X

Therefore the values of a
′
1,a
′
2,a
′
3 in function of a1,a2,a3 and gains k,m,n are
obtained analytically.
a
′
1 = k · a1
a
′
2 = km · a2
a
′
3 = kmn · a3
(5.24)
43
5.5 Defining the Number of Bits for each Sig-
nal
Now the affection of each quantizer Q1, Q2, Q3 to the output of modulator is
studied. As it has been said a quantizer can be replaced by an error source
(see fig. 5.5). Our goal is the calculation of transfer functions for each error
source . In that way we are informed to what extent each source affects the
output of ΔΣ modulator. Applying the principle of superposition inputs X,V
and two error sources are setting every time to zero retaining active only one
error source. This task is repeated for every error source. Fig. 5.6a-5.6c
depicts it.








(a)






(b)




(c)
Figure 5.6: Error sources
Easily can be obtained
H1 =
YE1
E1
=
z−3
(1− z−1)3 (5.25)
H2 =
YE2
E2
=
z−2
(1− z−1)2 (5.26)
H3 =
YE3
E3
=
z−1
1− z−1 (5.27)
44
where YE1 ,YE2 ,YE3 is the output due to each error signal E1, E2, E3 respec-
tively. Comparing to (2.9) the output now is calculated by involving also the
YE1 ,YE2 ,YE3 components in the calculation of Y :
Y = L0 ·X + L1 · V + YE1 + YE2 + YE3 (5.28)
Y = L0 ·X + L1 · V +H1 · E1 +H2 · E2 +H3 · E3 (5.29)
Provided that V = Y + E from (5.29) we have :
V = L0 ·X + L1 · V +H1 · E1 +H2 · E2 +H3 · E3 + E (5.30)
V =
L0
1 + L1
X +
H1
1 + L1
E1 +
H2
1 + L1
E2 +
H3
1 + L1
E3 +
1
1 + L1
E (5.31)
where L0(z),L1(z) are derived from (4.28) and (4.29). As we see the transfer
functions (TF) of E1(z),E2(z),E3(z) are respectively :
TFE1 =
H1
1 + L1
=
z−3
1 + 7z−1 − 12z−2 + 5z−3 (5.32)
TFE2 =
H2
1 + L1
=
z−2(1− z−1)
1 + 7z−1 − 12z−2 + 5z−3 (5.33)
TFE3 =
H3
1 + L1
=
z−1(1− z−1)2
1 + 7z−1 − 12z−2 + 5z−3 (5.34)
These Transfer Functions (TF) give a very useful information. For frequen-
cies Ω near 0 the TF of error E1 equals approximately 1 while TFs of errors
E2, E3 equal roughly 0. However TFE2 has only one zero whilst TFE3 has
two zeroes in DC frequency. Consequently TFE1 amplifies more than TFE2
and TFE2 amplifies more than TFE3 their errors. Hence, the significance
of the errors E1,E2,E3 for an efficient operation of the Modulator is in the
order that are written. Based in this fact, the highest to lowest priority in
determination of bit-widths is X1,X2,X3(see fig.5.4). The method that we
followed is to dedicate the same number of bits for each signal X1,X2,X3 and
calculate the Signal to Quantization Noise Ratio (SQNR) in function of bits.
The latter is given by :
SQNR = 10log10
[
v2ip
(vip − vfp)2
]
(5.35)
45
where vip is the output of 2-SLA Modulator with infinite precision (double
precision of Matlab) while vfp is the finite precision corresponding to given
bits each time. This measure expresses how good is the implemented system
according to the ideal. From this information we are able to choose the bit-
width of the signal with the highest priority i.e. X1. It is plotted in fig.5.7a.
For more than 15 bits we observe a hard converge. Hence, 15 bits is an
adequately good and safe choice. Subsequently keeping the signal X1 in 15
bits and changing the number of bits for signals X2,X3 (same number for
both each time) ,and after examining again the SQNR, the determination
of bit-width for X2 is possible (second in order of priority).It is plotted in
fig.5.7b and 12 bits seems perfect. Eventually since the definition of signals
X1 and X2 is done, the SQNR is plotted in function of the number of bits for
the signal X3 which has the lowest priority fig.5.7c. The calculation task of
bit-widths is completed after the final bit-width choice for signal X3 where 7
bits are good enough.
The final CIDF architecture (ready for implementation on a board!) is
presented in fig. 5.8 including the number of bits for signals as well as the
gains (s1, s2, s3) in every integrator as calculated in section 5.2 . For the
computation of gains (a
′
1, a
′
2, a
′
3) the (5.24) is used. The gains of Quantizers
Q1, Q2, Q3 equal q1 = 2
15, q2 = 2
−3, q3 = 2−5 where the exponential number
15 is given from the bit-width of X1 signal while the exponential numbers
-3 and -5 are obtained by subtracting the bit-width of the output from the
input for Q2, Q3 quantizers respectively (see fig. 5.4 and 5.8). Hence from
(5.23) we have that p = 211,m = 2−4, n = 2−6. Eventually from (5.24) :
a
′
1 = 2
11 · (−1) = −2048
a
′
2 = 2
112−4 · (−5) = −640
a
′
3 = 2
112−42−6 · (−10) = −20
(5.36)
46
number of bits
4 6 8 10 12 14 16 18 20
dB
-10
0
10
20
30
40
50
60
70
80
SQNR
0.05sin(0.049n)
0.25sin(0.049n)
0.45sin(0.049n)
(a)
number of bits
4 6 8 10 12 14 16 18 20
dB
10
20
30
40
50
60
70
80
SQNR
0.05sin(0.049n)
0.25sin(0.049n)
0.45sin(0.049n)
(b)
number of bits
4 6 8 10 12 14 16 18 20
dB
30
35
40
45
50
55
60
65
70
75
80
SQNR
0.05sin(0.049n)
0.25sin(0.049n)
0.45sin(0.049n)
(c)
Figure 5.7: Signal to Quantization Noise in function of bits
47


 


 




 
	
 	 	
	 	 		
 	 	
Figure 5.8: CIDF architecture for the construction of our 2-SLA Modulator
48
Chapter 6
FPGA Implementation of
2-SLA Modulator
6.1 Verilog Hardware Language
Verilog Hardware Language was written in PLANAHEAD program for the
programming of our 2-SLA Modulator on FPGA board. The FPGA model
is Xilinx Spartan xc3s500e. The verilog code is :
‘timescale 1ns / 1ps
module 2SLA (i_data_in,clock4,reset,out);
localparam bits_y1 = 15;
localparam bits_y2 = 12;
localparam bits_y3 = 7;
input reset,clock4;
input [bits_y1-1:0] i_data_in;
output out;
reg signed [3:0] a1 ;
reg signed [4:0] a2 ;
reg signed [5:0] a3 ;
reg out;
49
wire compl ;
wire signed [(bits_y1-1):0] y1_D, y1_D_part ,y1_Q , y1_Q_shift,i_data_in_Q;
wire signed [(bits_y2-1):0] y2_D , y2_Q , y2_Q_shift ,y2_D_part , y1_Q_shift_q ;
wire signed [(bits_y3-1):0] y3_D , y3_D_part, y3_Q , y2_Q_shift_q;
assign compl = ~i_data_in_Q[bits_y1-1];
assign y1_D_part = {a1[3:1], compl ,i_data_in_Q[(bits_y1-1-4):0]};
assign y1_D = y1_D_part + y1_Q ;
assign y2_D_part = {a2 + y1_Q_shift_q[bits_y2-1:bits_y2-5], y1_Q_shift_q[bits_y2-5-1:0]} ;
assign y2_D = y2_D_part + y2_Q;
assign y3_D_part = {a3 + y2_Q_shift_q[bits_y3-1:bits_y3-6] , y2_Q_shift_q[bits_y3-6-1:0]};
assign y3_D = y3_D_part + y3_Q;
Dff #(bits_y1) FFi_data_in (.Q(i_data_in_Q), .D(i_data_in), .reset(reset), .clk(clock4));
Dff #(bits_y1) FFy1 (.Q(y1_Q), .D(y1_D), .reset(reset), .clk(clock4));
Dff #(bits_y2) FFy2 (.Q(y2_Q), .D(y2_D), .reset(reset), .clk(clock4));
Dff #(bits_y3) FFy3 (.Q(y3_Q), .D(y3_D), .reset(reset), .clk(clock4));
assign y1_Q_shift = y1_Q >>>1;
assign y1_Q_shift_q = y1_Q_shift[bits_y1-1:bits_y1-bits_y2];
assign y2_Q_shift = y2_Q >>>1;
assign y2_Q_shift_q = y2_Q_shift[bits_y2-1:bits_y2-bits_y3];
always @ (y3_Q)
begin
out = y3_Q[bits_y3-1];
if (y3_Q[bits_y3-1])
begin
a1 = 4’b0001;
a2 = 5’b00101;
a3 = 6’b001010;
end
else
begin
50
a1 = 4’b1111;
a2 = 5’b11011;
a3 = 6’b110110;
end
end
endmodule
and the verilog code for D flip flop module for the synchronization with
the clock is :
‘timescale 1 ns/ 1 ps
module Dff #(parameter N=8)
(
output reg [N-1 : 0] Q,
input [N-1 : 0] D,
input reset, clk
);
always @ (posedge clk)
begin
if(reset == 1’b1)
Q <= {N-1 {1’b0}};
else
Q <= D;
end
endmodule
The RTL schematic is given below :
51
+a
2[4
]_y
1_
Q_
sh
ift_
q[1
1]_
ad
d_
1
R
TL
_a
dd
_5
u_
5u
ci
n
co
u
t
a
[4:
0]
b[4
:0]
o
[4:
0]
PW
R
_1
_o
_G
ND
_1
_o
_m
ux
_6
R
TL
_m
ux
_4
co
n
d
d0
[3:
0]
d1
[3:
0]
V=
B"
00
01
"
o
[3:
0]
PW
R
_1
_o
_G
ND
_1
_o
_m
ux
_7
R
TL
_m
ux
_5
co
n
d
d0
[4:
0]
V=
B"
11
01
1"
d1
[4:
0]
V=
B"
00
10
1"
o
[4:
0]
PW
R
_1
_o
_G
ND
_1
_o
_m
ux
_8
R
TL
_m
ux
_6
co
n
d
d0
[5:
0]
V=
B"
11
01
10
"
d1
[5:
0]
V=
B"
00
10
10
"
o
[5:
0]
+
a
3[5
]_y
2_
Q_
sh
ift_
q[6
]_a
dd
_3
R
TL
_a
dd
_6
u_
6u
ci
n
co
u
t
a
[5:
0]
b[5
:0]
o
[5:
0]
i_
da
ta
_i
n_
Q[
14
]_I
NV
_1
R
TL
_I
N
V
i
o
+
y1
_D
_p
ar
t[1
4]_
y1
_Q
[14
]_a
dd
_0
R
TL
_a
dd
_1
5u
_1
5u
ci
n
co
u
t
a
[14
:0]
b[1
4:0
]
o
[14
:0]
+
y2
_D
_p
ar
t[1
1]_
y2
_Q
[11
]_a
dd
_2
R
TL
_a
dd
_1
2u
_1
2u
ci
n
co
u
t
a
[11
:0]
b[1
1:0
]
o
[11
:0]
+
y3
_D
_p
ar
t[6
]_y
3_
Q[
6]_
ad
d_
4
R
TL
_a
dd
_7
u_
7u
ci
n
co
u
t
a
[6:
0]
b[6
:0]
o
[6:
0]
FF
i_
da
ta
_i
n
D
ff(N
=1
5)
re
se
t
cl
k
Q[
14
:0]
D
[14
:0]
FF
y1
D
ff(N
=1
5)
re
se
t
cl
k
Q[
14
:0]
D
[14
:0]
FF
y2
D
ff(N
=1
2)
re
se
t
cl
k
Q[
11
:0]
D
[11
:0]
i_
da
ta
_i
n[1
4:0
]
FF
y3
D
ff(N
=7
)
re
se
t
cl
k
Q[
6:0
]
D
[6:
0]
re
se
t
cl
oc
k4
o
u
t
14
3:
1 11
14
,1
0:
0
14
:0
14
,1
4:
11
4:
0
14
:0
11
:0
11
,1
1:
7
11
:05:
0
6
6.2 Output Spectrum
In fig. 6.2a-6.2d are depicted four spectres of our 2-SLA ΔΣ modulator. The
four inputs derived from :
x = 0.45sin
( pi
OSR
n
)
(6.1)
where OSR takes four different values (are given below). The machine that
displays the spectrum is called Spectrum Analyzer (fig 6.1). The Resolution
bandwidth of the output spectrum is 3kHz. If fb is the frequency of the
input signal then easily it can be found from (2.23) :
fb =
fs
2 ·OSR (6.2)
Hence for OSR = 64, 128, 512, 2048 and for fs = 50MHz the input frequency
fb is 390.6, 195.3, 48.8, 12.2 kHz respectively. These values agree with the
frequency of the displayed diracs (Z Transformation of sinusoidal signals) in
the fig. 6.2a-6.2d.
53
Figure 6.1: Spectrum Analyzer Machine
54
(a) Spectrum for OSR=64 (b) Spectrum for OSR=128
(c) Spectrum for OSR=512 (d) Spectrum for OSR=2048
55
Bibliography
[1] Basetas C. , Kanteres A. , Sotiriadis P.P., “Hardware implementation
aspects of Multi-Step Look-Ahead Σ-Δ modulation-like architectures for
all-digital frequency synthesis applications,” in Proc. IEEE Int. Freq.
Control Symp. & the European Freq. and Time Forum (FCS), 2015.
[2] R. Schreier and G. C. Temes, Understanding Delta-Sigma Data Con-
verters, S. V. Kartalopoulos, Ed. Hoboken, New Jersey: John Wiley
& Sons, Inc., 2005.
[3] Jurgen van Engelen,Stability Analysis and Design of Bandpass Sigma
Delta Modulators, 1999.
[4] G. I. Bourdopoulos, A. Pnevmatikakis, V. Anastassopoulos, and T. L.
Deliyannis, Delta-Sigma Modulators: Modeling, Design and Applica-
tions. 57 Shelton Street, Covent Garden, London WC2H 9HE, UK:
Imperial College Press, 2003.
[5] S. H. Ardalan and J. J. Paulos, “An analysis of nonlinear behavior in
Delta-Sigma modulators,” IEEE Trans. Circuits Syst., vol. 34, no. 6,
pp. 593–603, Jun. 1987.
[6] E. Janssen and A. van Roermund, Look-Ahead Based Sigma-Delta Mod-
ulation. Springer, 2011.
[7] R. Huang, N. Lotze, and Y. Manoli, “On design a high speed sigma
delta DAC modulator for a digital communication transceiver on chip,”
in Proc. IEEE 11th Euromicro Conference on Digital System Design
Architectures, Methods and Tools, 2008, pp. 53–60.
56
[8] K. Galanopoulos, C. Basetas, and P. P. Sotiriadis, “Delta-sigma modula-
tion techniques to reduce noise and spurs in all-digital RF transmitters,”
in Proc. IEEE Int. Freq. Control Symp., Taipei, May 19–22 2014.
[9] A. V. Oppenheim and R. W. Schafer, Discrete-Time Signal Processing,
2nd ed. Upper Saddle River, New Jersey 07458: Prentice-Hall, 1999.
57
