Any-point bias control of Mach-Zehnder modulators using digital filters by Andrade, Hector
UC Santa Barbara
UC Santa Barbara Electronic Theses and Dissertations
Title
Any-point bias control of Mach-Zehnder modulators using digital filters
Permalink
https://escholarship.org/uc/item/7j22c46n
Author
Andrade, Hector
Publication Date
2017
 
Peer reviewed|Thesis/dissertation
eScholarship.org Powered by the California Digital Library
University of California
UNIVERSITY OF CALIFORNIA 
Santa Barbara 
 
 
Any-point bias control of Mach-Zehnder modulators using digital filters 
 
 
A Thesis submitted in partial satisfaction of the 
requirements for the degree Master of Science 
in Electrical and Computer Engineering 
 
by 
 
Hector Andrade 
 
Committee in charge: 
Professor James Buckwalter, Chair 
Professor Clint Schow 
Professor Jonathan Klamkin 
 
June 2017
  
The thesis of Hector Andrade is approved. 
 
  ____________________________________________  
 Jonathan Klamkin 
 
  ____________________________________________  
 Clint Schow 
 
  ____________________________________________  
 James Buckwalter, Committee Chair 
 
 
June 2017  
  
 iii 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Any-point bias control of Mach-Zehnder modulators using digital filters 
 
Copyright © 2017 
by 
Hector Andrade 
 
 
 
 iv 
ACKNOWLEDGEMENTS 
 
I would like to thank my M.S. and future Ph.D. advisor, Professor James Buckwalter, for 
all his patience and advice these last months. I am also grateful to Dr. Roger Helkey for his 
valuable suggestions, as well as Rui-Lin Chao and Aditya Jain for their assistance with the 
setup.  I am also thankful to my future Ph.D. advisor, Professor Clint Schow and Professor 
Jonathan Klamkin for agreeing to be a part of the thesis committee. 
I would like to dedicate this thesis to my girlfriend Olga for all her encouragement during 
the past two years and to my parents Héctor and María Esther, and my brother Roberto for 
their lifelong support. 
 v 
ABSTRACT 
Any-point bias control of Mach-Zehnder modulators using digital filters 
by 
Hector Andrade 
Feedback control is used to maintain Mach-Zehnder modulators at a desired bias point, 
since heating and aging effects in its electro-optic materials cause a drift in its transfer function 
over time. Considering that the desired bias point in the MZM transfer curve varies among 
different applications, the control method should have an adjustable setpoint. The proposed 
method seeks to achieve this with the minimum number of components possible.  
SIMULINK models were used to obtain a better understanding of MZM biasing. Then, 
after comparing available commercial products and a literature review, it was decided to apply 
a known technique whereby a low-frequency dither signal is applied to the MZM DC input, 
the output of the MZM is measured and a PID controller adjusts the MZM DC voltage to 
maintain a constant ratio of the dither tone’s 2nd harmonic and fundamental. This method is 
independent of optical power and allows the bias to be set to any point in the transfer curve.  
To eliminate the need for standalone filters for each frequency and an additional IC for 
obtaining the power ratio, digital filtering, processing and PID control are all done within a 
microcontroller. A prototype board was built and the bias control measurements are presented.  
The application of this method to Si MZM is also briefly discussed. 
 
 vi 
TABLE OF CONTENTS 
 
1. Introduction ...........................................................................................................................1 
A. Analog optical links .........................................................................................................1 
B. Mach-Zehnder modulator .................................................................................................2 
C. MZM bias control .............................................................................................................3 
2. SIMULINK models ..............................................................................................................8 
A. Time domain model .........................................................................................................8 
B. Frequency domain model ...............................................................................................10 
3. MZM bias control methods ................................................................................................13 
A. “Photonic Analog Link on Si” project objectives  .........................................................13 
B. Literature review  ...........................................................................................................13 
4. Project proposal and setup ..................................................................................................19 
A. Project proposal  .............................................................................................................19 
B. Bias controller setup  ......................................................................................................19 
C. Noise analysis .................................................................................................................22 
5. Digital signal processing and control .................................................................................29 
A. Digital filter implementations  .......................................................................................29 
B. PID control  ....................................................................................................................32 
6. Results, further work and conclusion .................................................................................34 
A. Results  ...........................................................................................................................34 
B. Further work  ..................................................................................................................42 
B. Conclusion  .....................................................................................................................43 
 vii 
 
LIST OF FIGURES 
 
Figure 1. Basic components of an analog fiber optic link [4] ................................................. 1 
Figure 2. Mach-Zehnder modulator [5] ................................................................................... 2 
Figure 3.  MZM power transfer function with common bias points. “Quad” stands for 
“quadrature” [6] ............................................................................................................... 3 
Figure 4. MZM transfer function (purple), and link output power at fundamental (black), 2nd 
harmonic (red) and 3rd harmonic (green) [7] ................................................................... 4 
Figure 5. MZM frequency conversion [8] ............................................................................... 5 
Figure 6. Third-order intermodulation distortion for a Mach-Zehnder conventionally biased 
to 50% and low biased to 5% vs OMD............................................................................ 6 
Figure 7. Picture of distortion generated from two tones. The dashed box indicates the 
relevant components in sub-octave links [10] ................................................................. 6 
Figure 8. Effect of MZM bias drift [11] .................................................................................. 7 
Figure 9. SIMULINK MZM time domain model .................................................................... 8 
Figure 10. MZM time-domain RF input signal (yellow) and optical output signal (blue), at 
peak bias (top), quadrature bias (middle) and null bias (bottom). Units on both axes are 
arbitrary. ........................................................................................................................... 9 
Figure 11. SIMULINK frequency domain model ................................................................. 10 
Figure 12. Simulation of ideal sine dither. Top: time domain simulation of RF signal 
(yellow), LPF output (blue) and MZM output (orange) at quadrature bias (left) and null 
bias (right). Middle: frequency spectrum at quadrature bias. Bottom: frequency 
spectrum at null bias. ..................................................................................................... 11 
 viii 
Figure 13. Simulation of 10-point digital sine dither. Top: time domain simulation of RF 
signal (yellow), LPF output (blue) and MZM output (orange) at quadrature bias (left) 
and null bias (right). Middle: frequency spectrum at quadrature bias. Bottom: frequency 
spectrum at null bias. ..................................................................................................... 12 
Figure 14. Automatic bias control by dither phase comparison ............................................ 14 
Figure 15. Gated-dither bias control of MZM ....................................................................... 15 
Figure 16. Spectrum of data-carrying signal, dither signal and modulation signal ............... 16 
Figure 17.  Simulated ﬁrst-order harmonic (triangle) and average power (circle) from the 
photodiode and their ratio (smooth line) as a function of phase bias angle. ................. 17 
Figure 18. Dither average power ratio MZM bias control setup ........................................... 17 
Figure 19. Simulated 2nd-order harmonic (triangle) and first order (square) signals from the 
photodiode and their ratio (smooth line) as a function of phase bias angle. Negative and 
positive signs of the signals correspond to phase changes relative to the input ............ 18 
Figure 20. 2nd to first harmonic dither ratio bias control setup ............................................ 18 
Figure 21. Schematic of proposed bias control loop ............................................................. 19 
Figure 22. FRDM-KL25Z development platform ................................................................. 20 
Figure 23. Schematic of MZM bias control loop (this project) ............................................. 21 
Figure 24. RF prototype of electrical network for MZM bias controller .............................. 22 
Figure 25. SPICE analysis of electrical network ................................................................... 23 
Figure 26. Ideal N-bit ADC quantization noise ..................................................................... 24 
Figure 27. process gain from oversampling and digital filtering on ADC ............................ 27 
Figure 28. Sources of noise after bandpass digital filter (fc = 2kHz), DC to Nyquist 
frequency. The filter response is shown in purple. ........................................................ 27 
 ix 
Figure 29. A direct form discrete-time FIR filter of order N ................................................. 29 
Figure 30. MATLAB Filter Designer, 958-tap FIR filter ...................................................... 30 
Figure 31. 958-tap FIR filter bias control measurements ...................................................... 31 
Figure 32. Correlation receiver for dither fundamental and 2nd harmonic ........................... 32 
Figure 33. PID controller schematic ...................................................................................... 33 
Figure 34. Bias control measurements. From top to bottom: N = 500, 1500, 2500, 3500. The 
orange curve is the DC voltage value at the DAC output. The blue curve is the bias 
error in degrees. Setpoint is 90° (quadrature). ............................................................... 35 
Figure 35. PID output period (loop cycle time) and bias error vs number of ADC samples. 
The solid orange curve is the measured bias error and the dashed line is the 
extrapolation. The solid blue line is the PID controller cycle time and the dashed line is 
the extrapolation. ........................................................................................................... 36 
Figure 36. Example of 3-bit DAC with analog phase output vs digital input. ...................... 37 
Figure 37. DAC ENOB vs bias error (degrees) ..................................................................... 38 
Figure 38. Distortion measurements setup ............................................................................ 39 
Figure 39. MZM and PD frequency response ....................................................................... 40 
Figure 40. HD2 and HD3 measurements for 10MHz RF tone at different bias setpoints. 
Dither fundamental and 2nd harmonic, and RF fundamental, 2nd and 3rd harmonics are 
shown in different plots. ................................................................................................ 41 
Figure 41. HD2 and HD3 measurements for 500MHz RF tone at different bias setpoints ... 41 
Figure 42. MCF51MM256 series block diagram .................................................................. 43 
 
 
  
 1 
1. Introduction 
A. Analog optical links 
Optical links are used to convey an electrical signal over an optical carrier. Analog optical 
links are those in which optical modulation depth is sufficiently small that small-signal 
analysis is possible, as opposed to digital optical links, where modulation depth approaches 
100% [1]. Although the great majority of fiber optic links in use are digital, there are some 
applications, such as antenna remoting [2] [3], where analog fiber optic links are employed.  
In its simplest form, an analog optical link consists of three elements, an electrical-to-
optical converter, an optical transmission medium and an optical-to-electrical converter, as 
depicted in Figure 1. 
 
Figure 1. Basic components of an analog fiber optic link [4] 
 
Electrical-to-optical converters make use of electro-optic effects, by which changes in the 
refractive index of a material are induced by the application of an external electric field. This 
process is known as modulation of the optical signal, and therefore electrical-to-optical 
converters are commonly known are modulators. 
  
 2 
B. Mach-Zehnder modulator  
One of the most popular modulators is the Mach-Zehnder modulator (MZM), which 
employs interference to convert phase shift into amplitude variation. As shown in Figure 2, 
incoming light is split equally into two arms, across which opposite electric fields are applied. 
This causes a phase difference between the light waves traveling in each arm, which interfere 
when combined at the output. In an ideal MZM the resulting power of the output signal will 
range from 0 to the total input power depending on the magnitude of the electric field. The 
two waves interfere destructively when the phase shift is a multiple of π and constructively 
for multiples of 2π. 
 
Figure 2. Mach-Zehnder modulator [5] 
 
The resulting power transfer function of the MZM is a raised cosine, shown in Figure 3. 
The transfer function in its simplest form can be expressed as 
 
𝑃𝑜𝑢𝑡 =
𝑃𝑜𝑢𝑡,𝑚𝑎𝑥
2
 [1 + 𝑐𝑜𝑠 (𝜃) ] 
 
(1.1) 
where θ is the phase difference between the two interfering light waves. A useful 
parameter is Vπ, the voltage at which the phase difference between the two arms is 90°, and 
 3 
thus the output power of the MZM is 0. 
 
Figure 3.  MZM power transfer function with common bias points. “Quad” stands for “quadrature” 
[6] 
 
C. MZM bias control 
1. MZM biasing 
A DC voltage is usually applied to MZMs to operate at a desired point in the transfer 
curve. It can be observed in Figure 3 that the quadrature (half-power) points, at 90° and 270° 
(π/2 and 3π/2), are the most linear. This is in line with small-angle approximation, since 
cos(π/2) = sin(0) and sin(θ) ≈ θ. In most analog optical link applications, this is the optimum 
bias point, since commonly the objective is to minimize the 2nd order harmonic distortion 
(HD2) and thus maximize the dynamic range of the link. Figure 4 shows the fundamental, 
HD2 and 3rd order distortion (HD3) products at the output of the MZM as a function of bias 
point. It is evident that at 90° (Vπ/2) the fundamental signal is greatest and HD2 is eliminated.  
 
 4 
 
Figure 4. MZM transfer function (purple), and link output power at fundamental (black), 2nd 
harmonic (red) and 3rd harmonic (green) [7] 
 
There are techniques such as frequency conversion, however, that exploit the nonlinearity 
of the MZM at other bias points. Reverting to small-angle approximation, nonlinear behavior 
is attained at the null and peak bias points (0 and π), since cos(0) ≈ 1 - θ2/2. Frequency 
conversion can be employed to reduce front-end hardware complexity of antenna systems and 
efficiently extend link frequency coverage into the millimeter-wave (MMW, 30–300 GHz) 
range [8]. As shown in Figure 5, this is achieved by adding an information-bearing RF signal 
at fRF to a local oscillator signal at fLO. The resulting up-converted signal is then at fIF=fRF±fLO.  
 
 5 
 
Figure 5. MZM frequency conversion [8] 
 
In addition to quadrature and peak/null biasing, there are techniques that require biasing 
at other points in the transfer function. In sub-octave links that can be maintained at the relative 
intensity noise (RIN) limit or detector saturation limit using a lower Mach-Zehnder bias, a 
larger dynamic range can be achieved [9]. Figure 6 depicts third-order intermodulation 
distortion (IM3) curves for an MZM at both 50% bias (quadrature) and 5% bias (18°). It can 
be observed that at lower bias third-order intermodulation (IM3) suppression is higher, and 
that as optical modulation depth (OMD) increases, the noise floor falls relative to the carrier 
signal. The highest dynamic range is then found where the low bias IM3 tone coincides with 
the noise floor, obtaining an improvement of 8.5dB with respect to quadrature biasing. It is 
important to reiterate that this technique is intended for sub-octave links, since it suppresses 
IM3 by operating at a more quadratic region of the transfer curve, which in turn increases 
HD2 terms. Figure 7 illustrates the relevant distortion tones in sub-octave links.  
 
 6 
 
Figure 6. Third-order intermodulation distortion for a Mach-Zehnder conventionally biased to 50% 
and low biased to 5% vs OMD 
 
 
Figure 7. Picture of distortion generated from two tones. The dashed box indicates the relevant 
components in sub-octave links [10] 
  
 7 
2. Feedback control of MZM bias 
Pyroelectric, photorefractive, and photoconductive effects in the MZM's electro-optic 
material cause the MZM transfer function to "drift" to the left or right-as depicted in Figure 8 
[11]. This makes the use of closed-loop control necessary to maintain a desired bias point, 
which is most commonly implemented via proportional-integral-derivative (PID) control [6] 
[12]. The drift is a relatively slow process than can be measured in seconds or even minutes 
and thus the PID loop cycle can be equally lengthy without affecting the performance of the 
analog link. 
 
Figure 8. Effect of MZM bias drift [11] 
 
  
 8 
2. SIMULINK models 
A. Time domain model 
Initially, the time domain model shown in Figure 9 was created to better understand the 
MZM behavior at different bias points. As described in the previous chapter, the input laser 
signal is split, with half of the power going to each MZM arm. The electrical RF signal and 
bias voltage induce an opposite phase shift in each arm and the optical signal is recombined 
at the output and π/2Vπ is effectively the conversion factor from input voltage to phase shift 
in each arm. 
 
Figure 9. SIMULINK MZM time domain model 
 9 
An amplitude modulation (AM) simulation was done at three different bias points. Figure 
10 shows the time domain RF input and optical output. The RF amplitude is 10% of Vπ. 
 
 
 
Figure 10. MZM time-domain RF input signal (yellow) and optical output signal (blue), at peak bias 
(top), quadrature bias (middle) and null bias (bottom). Units on both axes are arbitrary. 
 
At null and peak bias, it can be noticed that the period of the output signal envelope is 
twice that of the RF signal. The fact that the 2nd-order component dominates, agrees with the 
 10 
expected quadratic behavior at these bias points. At quadrature, the modulation is linear and 
there is a 180° phase between RF input and the output signal envelope, which is in line with 
the first quadrature bias point shown in Figure 3. 
B. Frequency domain model 
As will be described in chapter 3, a dither signal is commonly used to perturb the MZM 
bias operating point to determine the location of said point on the transfer function. A model 
(Figure 11)Figure 11. SIMULINK frequency domain model was created to predict the output 
spectrum with different waveforms. A low-pass filter (LPF) was added before the MZM to 
reduce the magnitude of harmonics of the dither signal.  
 
Figure 11. SIMULINK frequency domain model 
 
First, a 1kHz ideal sine wave dither signal was simulated (results shown in Figure 12). 
The continuous time results coincide with the AM simulations shown above. As expected, the 
 11 
MZM produces HD3 and suppresses HD2 at quadrature, and has the opposite effect at null 
bias. 
 
 
 
Figure 12. Simulation of ideal sine dither. Top: time domain simulation of RF signal (yellow), LPF 
output (blue) and MZM output (orange) at quadrature bias (left) and null bias (right). Middle: 
frequency spectrum at quadrature bias. Bottom: frequency spectrum at null bias. 
 
Since the dither signal may be generated using a digital-to-analog converter (DAC), it is 
informative to simulate a discrete sine wave. Figure 13 shows the results for a 10-point digital 
sine wave dither. Although even and odd-order harmonics are introduced, this should not 
 12 
hinder the bias control method, since the output spectrum can be filtered to obtain the desired 
frequency components. However, due to nonlinearities of the MZM, these additional 
components may appear as sidebands within the RF spectrum. 
 
 
 
 
Figure 13. Simulation of 10-point digital sine dither. Top: time domain simulation of RF signal 
(yellow), LPF output (blue) and MZM output (orange) at quadrature bias (left) and null bias (right). 
Middle: frequency spectrum at quadrature bias. Bottom: frequency spectrum at null bias. 
 
  
 13 
3. MZM bias control methods 
A. “Photonic Analog Link on Si” project objectives 
The work described in this thesis was done as part of the “Integrated Photonic Analog 
Link on Si” project at the Institute for Energy Efficiency at UCSB. The success criteria for 
the bias control was to ensure < 0.1° bias point error in a volume of less than 1cm3 and the 
desired bias point was not defined. A comparison of compact commercial off-the-shelf 
(COTS) MZM bias controllers was done to determine if the success criteria could be met. This 
is shown in Table 1. It can be noted that the dimension, bias error and bias point criteria are 
not met by available products. At this point a literature review was done to determine the ideal 
bias control method to employ. 
Table 1. Comparison of compact COTS MZM bias controllers [7] [13] [14]. 
 
B. Literature review 
From the early 1990s closed-loop methods for MZM bias control have been patented and 
published in research articles. 
1. Patents 
The patent “Modulator-based Lightwave Transmitter” [15] describes a closed-loop bias 
Parameter / 
Characteristic
Project goal
Option 1: Photonics 
Systems Inc. PSI-
2011-11
Option 2: Pharad 
MBC-DF-UC-U
Option 3: YY Labs 
Inc. 0090-2
Dimensions <1cm
3
4.2cm x 1.1cm x 
1.3cm = 6cm
3
5.1cm x 6.4cm x 
0.9cm = 29.4cm
3
4.6cm x 2.0cm x 
1.3cm = 12cm
3
Bias point Adjustable
Fixed (Peak/null or 
Quadrature)
Fixed (Peak/null or 
Quadrature)
Fixed (Peak/null or 
Quadrature)
Bias point error <0.1° <1° <1° <3°
Dither/Ditherless Dither Ditherless Dither
 14 
control method for MZMs. In this approach, shown in Figure 14, the controller contains a 
reference signal (dither) that operates as a predetermined frequency which amplitude-
modulates the electrical data signal that goes to the input of the MZM. The MZM output 
optical signal is then sent to a photodetector (PD) and the phase of the reconstructed output 
electrical signal is compared to the phase of the dither signal, with the phase difference being 
zero at the quadrature point. The bias voltage is then continuously corrected by integrating the 
error. This technique demonstrates that it is necessary only to measure the output signal of the 
MZM to determine the phase bias, which is an important advantage of a dither-based 
approach. 
 
Figure 14. Automatic bias control by dither phase comparison 
 
Another patented approach for locking to the half-power point consists in modulating a 
time-varying signal on and off at a modulation frequency fm that is much lower than the 
 15 
frequency components within the spectrum of a time varying signal (dither), such that energy 
within the time varying signal spectrum is recovered at the modulation frequency when the 
modulator is not operating at the half-power point. Due to the second order response of the 
modulator at any point except quadrature, energy within the dither signal spectrum is 
recovered at fm if the modulator is not operating at that point. A phase sensitive demodulator 
retrieves the signal indicative of the modulator optical output signal to provide a DC voltage 
signal value indicative of the half-power point bias error value, which is then integrated to 
obtain the bias voltage value. This method is depicted in Figure 15 and Figure 16. 
 
Figure 15. Gated-dither bias control of MZM 
 
 16 
 
Figure 16. Spectrum of data-carrying signal, dither signal and modulation signal 
 
More recent patents also make use of a dither signal to lock to the desired bias point [16] 
[17]. 
2. Articles 
As is mentioned in the introduction, the desired bias phase will depend on the analog 
optical link where the MZM is to be employed. This means that a bias control method that 
allows for locking at any point on the MZM transfer curve is very advantageous. One such 
approach utilizes the ratio of the first harmonic of a dither signal and the average MZM output 
power [12]. Figure 17 shows a simulation of the output dither magnitude and its average power 
as a function of bias phase, where negative magnitude values refer to the sign of the phase 
with respect to the input dither signal. The ratio (red curve) is injective from 0 to 360°, which 
allows for locking at any point in the transfer function.  As illustrated in Figure 18, a low-
frequency dither is applied to the modulator bias and a small fraction of the output is tapped 
and directed to a low-pass filter (LPF) to eliminate the RF data signal components. The optical 
signal is then sent to a PD, where the DC output is proportional to the average power and the 
AC output is the dither signal. Another benefit of this technique is that it is independent of the 
 17 
MZM input optical power, i.e., laser power fluctuations. 
 
Figure 17.  Simulated ﬁrst-order harmonic (triangle) and average power (circle) from the 
photodiode and their ratio (smooth line) as a function of phase bias angle. 
 
 
Figure 18. Dither average power ratio MZM bias control setup 
 
Another control method for locking to any bias point consists in measuring the ratio of the 
first and second harmonics of a dither tone at the output of the MZM to determine the bias 
error [18]. The simulated values of the first and second harmonics of the dither as a function 
of phase bias can be seen in Figure 19. It can be observed that the ratio is injective for 0 to 
 18 
180°, and thus can be employed as a control process variable for any bias point in that range. 
The setup that was used, shown in Figure 20, employs two bandpass filters and a log amp ratio 
divider to obtain the ratio. A PID controller is implemented within a microcontroller, which 
outputs a DC voltage that is combined with the dither signal before being input to the MZM. 
 
Figure 19. Simulated 2nd-order harmonic (triangle) and first order (square) signals from the 
photodiode and their ratio (smooth line) as a function of phase bias angle. Negative and positive signs of 
the signals correspond to phase changes relative to the input 
 
 
Figure 20. 2nd to first harmonic dither ratio bias control setup 
 
 19 
4. Project proposal and setup 
A. Project proposal 
After the literature review and considering the project goals mentioned in section 2.A, it 
was proposed to employ the known technique that utilizes the ratio of HD2 and fundamental 
of a dither signal. Instead of using standalone filters for each frequency and an additional 
logarithmic amplifier IC as in [18], digital filters would be implemented within a 
microcontroller to minimize the dimensions of the bias controller. A schematic of the 
proposed closed-loop control is shown in Figure 21. 
 
Figure 21. Schematic of proposed bias control loop 
 
B. Bias controller setup 
1. Microcontroller choice 
After an extensive product search, it was decided to implement the bias controller on the 
FRDM-KL25Z development platform (Figure 22) for the NXP MKL25Z128VLK4 
Dither signal
Microcontroller
MZM Photodetector
ADCDAC 
Ratio and 
phase 
calculation
Optical Output 
Tap
DC bias
PID 
controller
Electrical Output
Digital filter
(fundamental)
Digital filter
(2nd harmonic)
 20 
microcontroller, which has integrated 16-bit analog-to-digital converters (ADC) and a 12-bit 
DAC. This evaluation board has a built-in debug interface for flash programming and is 
enabled for the ARM mbed platform, which provides an online C/C++ compiler, all of which 
greatly facilitate the coding process. 
 
Figure 22. FRDM-KL25Z development platform 
 
2. Components 
The bias control loop was set up using commercially available components, which are 
listed in Table 2.  
Table 2. Components used in bias control setup 
 
 
Component Model Description Specifications
MZM JDSU APE
20GHz, 1550nm analog 
intensity modulator
Bias Vπ = 12V
Photodetector THORLABS DET01CFC
Fiber Input  InGaAs Biased 
Detector 
Peak λ = 1550nm
Responsivity at 1550nm = 0.95 A/W
Output voltage = 0 to 10V (High Z)
Laser QDFBLD-1550-100 
Wavelength stabilized single 
mode fiber coupled laser 
diode
45mW @ 1550nm
Laser current 
source
LDX-3500B Series Precision Current Sources Output current range: 200mA
Microcontroller 
development 
platform
FRDM-KL25Z 
Microcontroller board for 
easy access to to I/O
ADC, DAC range: 0 - 3.3V
 21 
3. Electrical network 
Since the MZM Vπ = 12V and the microcontroller’s ADC and DAC range is only 3.3V, it 
was necessary to add an electrical network (Figure 23). A summing amplifier is used to add 
the dither signal to the DC bias voltage generated by the DAC prior to the bias port of the 
MZM. At the MZM output, a LPF reduces noise above the dither’s 2nd harmonic and a high 
pass filter (HPF) removes the DC component. A tunable offset is then added and the signal is 
adjusted to utilize the full scale of the microcontroller’s ADC by another summing amplifier.  
The circuit was built initially using a breadboard and then an RF prototype (Figure 24) 
was constructed on a duroid board with a copper ground plane on one side. Microstrip was 
used for the signal traces and aluminum launcher blocks were used to place SMA connectors. 
These connectors were used to interface with the PD and MZM bias port. An Op Amp IC 
(ALD2702) was used for the summing amplifiers. 
 
Figure 23. Schematic of MZM bias control loop (this project) 
 
 22 
 
Figure 24. RF prototype of electrical network for MZM bias controller 
 
C. Noise analysis 
The average error of the bias phase of the controller is determined by the root mean square 
(RMS) noise of the dither fundamental and 2nd harmonic measurements within the 
microcontroller. The noise analysis was carried out for two sources, the electrical network and 
the quantization noise of the ADC. 
1. Electrical network noise 
Noise analysis of the circuit was done on LTSPICE, which considers shot, thermal and 
flicker noise [19]. The MZM and PD were modeled as a voltage controlled current source, 
with the PD junction capacitance and shunt resistance values taken from the PD datasheet. 
Figure 25 shows the circuit schematic, the transient analysis and the noise analysis. It can be 
seen in the transient analysis that the output signal, which is read by the ADC, utilizes most 
 23 
of the 3.3V range. The integrated spectral noise density Velectricalnoise,RMS is 124.9μV.  
 
 
 
Figure 25. SPICE analysis of electrical network 
 
2. Quantization noise 
Quantization noise in ADCs is a result of rounding errors and thus decreases as resolution 
increases. The quantization error can be approximated by a sawtooth waveform [20], where 
the maximum error value is ± ½ LSB, as illustrated in Figure 26.  
 
 24 
 
Figure 26. Ideal N-bit ADC quantization noise 
 
The sawtooth error is given by: 
 𝑒(𝑡) = 𝑠𝑡, −
𝑞
2𝑠
< 𝑡 < +
𝑞
2𝑠
 
 
(4.1) 
 
And its mean square is: 
 
𝑒2(𝑡)̅̅ ̅̅ ̅̅ ̅ =
𝑠
𝑞
∫ (𝑠𝑡)2𝑑𝑡
+𝑞/2𝑠
−𝑞/2𝑠
 
 
(4.2) 
 
 
𝑒2(𝑡)̅̅ ̅̅ ̅̅ ̅ =
𝑞2
12
 
 
(4.3) 
 
The RMS of the quantization noise is given by: 
 
𝑟𝑚𝑠 𝑞𝑢𝑎𝑛𝑡𝑖𝑧𝑎𝑡𝑖𝑜𝑛 𝑛𝑜𝑖𝑠𝑒 =  √𝑒2(𝑡)̅̅ ̅̅ ̅̅ ̅ =
𝑞
√12
 
 
(4.4) 
 
The RMS SNR for an ideal N-bit converter is: 
 
𝑆𝑁𝑅 = 20𝑙𝑜𝑔
𝑟𝑚𝑠 𝑣𝑎𝑙𝑢𝑒 𝑜𝑓 𝐹𝑆 𝑖𝑛𝑝𝑢𝑡
𝑟𝑚𝑠 𝑣𝑎𝑙𝑢𝑒 𝑜𝑓 𝑞𝑢𝑎𝑛𝑡𝑖𝑧𝑎𝑡𝑖𝑜𝑛 𝑛𝑜𝑖𝑠𝑒
 
 
(4.5) 
 25 
 
𝑆𝑁𝑅 = 20𝑙𝑜𝑔 [
𝑞2𝑁/2√2
𝑞/√12
] = 20𝑙𝑜𝑔2𝑁 + 20𝑙𝑜𝑔√
3
2
 
 
 
𝑆𝑁𝑅 = 6.02𝑁 + 1.76𝑑𝐵, 𝑓𝑟𝑜𝑚 𝐷𝐶 𝑡𝑜
𝑓𝑠
2
 𝑏𝑎𝑛𝑑𝑤𝑖𝑑𝑡ℎ 
 
 
(4.6) 
 
 
 
 
(4.7) 
where FS stands for the full scale of the ADC and fs is the sampling rate (fs/2 is the Nyquist 
frequency). This expression for SNR, however, considers only the quantization error for an 
ideal N-bit ADC. To account for distortion, the signal to noise and distortion ratio (SINAD) 
is used, where the N factor now becomes the effective number of bits (ENOB): 
 𝑆𝐼𝑁𝐴𝐷 = 6.02(𝐸𝑁𝑂𝐵) + 1.76𝑑𝐵 
 
(4.8) 
The ENOB is commonly found on ADC datasheets. For the MKL25Z128VLK4 
microcontroller, the expected ENOB is 11.4. The SINAD is thus: 
 𝑆𝐼𝑁𝐴𝐷 = 6.02(11.4) + 1.76𝑑𝐵 = 70.4𝑑𝐵 
 
4.9) 
It is then possible to calculate the RMS noise voltage, since the dither magnitude is known: 
 
𝑉𝐴𝐷𝐶𝑛𝑜𝑖𝑠𝑒,𝑅𝑀𝑆 =
𝑉𝑑𝑖𝑡ℎ𝑒𝑟,𝑅𝑀𝑆
10𝑆𝐼𝑁𝐴𝐷/20
=
3.3𝑉/√2
3307
= 705.7𝜇𝑉 
 
(4.10) 
 
3. Total RMS noise 
Since the two sources of noise are uncorrelated, the total RMS noise is obtained by 
 
 26 
 
𝑉𝑇𝑜𝑡𝑎𝑙𝑛𝑜𝑖𝑠𝑒,𝑅𝑀𝑆 = √𝑉𝑒𝑙𝑒𝑐𝑡𝑟𝑖𝑐𝑎𝑙𝑛𝑜𝑖𝑠𝑒,𝑅𝑀𝑆
2 + 𝑉𝐴𝐷𝐶𝑛𝑜𝑖𝑠𝑒,𝑅𝑀𝑆
2
= √(124.9𝜇𝑉)2 + (705.7𝜇𝑉)2
= 716.7𝜇𝑉 
 
(4.11) 
 
In root-sum-of-squares operations the larger value dominates, and so it is evident that the 
noise from the electrical network is negligible. This means that implementing an electrical 
network with lower noise would be ineffective in reducing the bias control error. 
4. Noise process gain 
In digital filter applications where the signal of interest occupies a narrower bandwidth 
than the Nyquist bandwidth, a correction factor (called process gain) must be included in the 
equation to account for the resulting increase in SNR (see Figure 27). The process of sampling 
a signal at a rate which is greater than twice its bandwidth is referred to as oversampling. The 
expression for SNR is as follows: 
 
𝑆𝑁𝑅 = 6.02𝑁 + 1.76𝑑𝐵 + 10𝑙𝑜𝑔
𝑓𝑠
2 ∙ 𝐵𝑊
 
 
(4.12) 
 
 27 
 
Figure 27. process gain from oversampling and digital filtering on ADC 
 
As depicted in Figure 28, process gain applies also to noise from the electrical network. 
Only the noise spectrum within the filter passband contributes to the RMS noise at the filter 
output. 
 
Figure 28. Sources of noise after bandpass digital filter (fc = 2kHz), DC to Nyquist frequency. The 
filter response is shown in purple. 
 
 28 
5. Noise analysis conclusion 
The quantization noise analysis and LTSPICE noise simulations indicate that the limited 
resolution of the ADC is the dominating noise source. It can also be concluded that noise 
magnitude increases as the digital filter response widens.  
 
 
 
  
 29 
5. Digital signal processing and control 
A. Digital filter implementations 
For the proposed bias control method, the implementation of two bandpass digital filters 
was necessary to obtain the magnitude and relative phase of each dither signal component.  
1. FIR filters 
Initially, due to ease of implementation, finite impulse response (FIR) filters were 
employed. For an N-order FIR filter, the output is a weighted sum of the current input value 
and the N previous input values, as in: 
 𝑦[𝑛] = 𝑏0𝑥[𝑛] + 𝑏1𝑥[𝑛 − 1] + ⋯ + 𝑏𝑁𝑥[𝑛 − 𝑁]
= ∑ 𝑏𝑖 ∙ 𝑥[𝑛 − 𝑖]
𝑁
𝑖=0
 
 
(5.1) 
 
This is illustrated in Figure 29, where the z-1 operator denotes one unit delay.  
 
Figure 29. A direct form discrete-time FIR filter of order N 
 
The filters were designed on the MATLAB Filter Designer app, which allows the filter 
 30 
coefficients to be exported and easily imported to the microcontroller program. Many different 
filter specifications were tried and the best results were obtained with the 958-tap filter shown 
in Figure 30. A 1kHz dither frequency and 10kHz ADC sample frequency were chosen. The 
filter for the 2nd harmonic is equivalent, with the exception that the center of the passband is 
at 2kHz.  
 
Figure 30. MATLAB Filter Designer, 958-tap FIR filter 
 
Figure 31 shows the bias control measurements vs time (minutes) at quadrature setpoint.  
The red curve represents the DAC output in volts and the blue curve the ratio of the 2nd to the 
fundamental dither tones. It can be seen how the DAC voltage increases, slightly overshoots 
and eventually stabilizes. The ratio drops to the desired setpoint of 0, and has a steady error 
due to noise. After the PID controller stabilizes, the ratio RMS error is 4.76 x 10-4 (-66.4dB), 
 31 
which corresponds to an average bias error of |0.275°| - i.e., the bias error is a distribution with 
a mean of 0 and a standard deviation of 0.275°. 
 
Figure 31. 958-tap FIR filter bias control measurements 
 
Despite obtaining promising results using FIR filters, the large number of taps necessary 
to achieve a low bias error resulted in a PID loop cycle time of 1.54 seconds. At this point it 
was decided to apply a different filtering technique to reduce processing time. 
2. Correlation receiver 
Since only two frequency components need to be measured, correlation is more time-
efficient than FIR filtering. As shown in Figure 32, for each frequency it is necessary to 
correlate with two quadrature signals and then add the time series (integrate). The output is 
“accumulated and dumped” for a desired number of samples. Both phase and magnitude 
information can then be obtained from the four summations. The (white) noise will decrease 
 32 
by √𝑁, where N is the number of ADC samples. The bias control measurements using this 
filtering method are presented in the next chapter. 
 
Figure 32. Correlation receiver for dither fundamental and 2nd harmonic 
 
B. PID Control 
A PID controller is also implemented within the microcontroller. This control algorithm 
is the one most commonly used in industry. The popularity of PID controllers can be attributed 
to their robust performance and functional simplicity. As the name suggests, the PID 
algorithm consists of three coefficients; proportional, integral and derivative, which are tuned 
to get optimal response in terms of settling time, overshoot and steady-state error [21]. The 
variables, as depicted in Figure 33, are as follows: 
• Process value: y(t) = Ratio of 2nd harmonic to fundamental 
• Control variable: u(t) = DC bias voltage (DAC) 
• Setpoint: r(t) = Desired ratio (corresponding to the desired bias point) 
• Error: e(t) = Ratio error 
 33 
• Plant/Process: MZM 
 
 
Figure 33. PID controller schematic 
 
The microcontroller code that contains the correlation receiver and PID controller can be 
found in Appendix A. 
  
 34 
6. Results, further work and conclusion 
A. Results 
1. Bias control measurements 
Bias control measurements were carried out for four different numbers of ADC samples 
(N) per PID loop cycle. As mentioned above, the MZM Vπ is 12V and the 1kHz dither Vp is 
2.5V. The setpoint for this experiment is a ratio of 0, which corresponds to quadrature bias, 
since at this point HD2 should be eliminated. Figure 34 shows the DAC voltage (MZM DC 
bias) and bias error vs time for N=500, 1500, 2500 and 3500. The ratio calculated within the 
microcontroller was used to calculate the bias error as in [18]. The PID controller settling time 
can be noticed at the onset of each test, after which there is a steady error as a consequence of 
noise, as explained above. 
 
 35 
 
 
 
Figure 34. Bias control measurements. From top to bottom: N = 500, 1500, 2500, 3500. The orange 
curve is the DC voltage value at the DAC output. The blue curve is the bias error in degrees. Setpoint is 
90° (quadrature). 
 
 36 
A summary of the results is shown in Table 3 and are plotted in Figure 35. It can be 
observed that as N is increased, the average bias error decreases by √𝑁 and the PID cycle time 
increases linearly. The extrapolated linear time plot intercepts the y-axis at around 0.3 
seconds, which can be interpreted as the microcontroller processing time excluding filtering. 
It is evident that this filtering method is much more time-efficient than using FIR filters, since 
it requires 0.39 seconds compared to 1.54 seconds for a similar bias error.  
Table 3. Bias control measurements summary 
N 
PID cycle 
time 
Average voltage 
ratio error 
Average power 
ratio error [dB] 
Average 
absolute bias 
error [°] 
500 0.39 3.76E-04 -68.5 0.26 
1500 0.54 2.60E-04 -71.7 0.18 
2500 0.68 2.09E-04 -73.6 0.15 
3500 0.82 1.95E-04 -74.2 0.14 
 
 
Figure 35. PID output period (loop cycle time) and bias error vs number of ADC samples. The solid 
orange curve is the measured bias error and the dashed line is the extrapolation. The solid blue line is 
the PID controller cycle time and the dashed line is the extrapolation. 
 
The bias error extrapolation has an asymptote at 0.06°. This is believed to be caused by 
 37 
the DAC resolution limit. For an N-bit DAC, the LSB bias phase is: 
 
𝜙𝐿𝑆𝐵 =
𝜙𝑟𝑎𝑛𝑔𝑒
2𝑁 − 1
 
 
(6.1) 
ΦLSB is twice the maximum phase error, φerror., as can be seen in Figure 36. Approximating 
for high resolution DACs, N can be expressed by: 
 
𝑁 = [𝑙𝑜𝑔2 |
𝜙𝑟𝑎𝑛𝑔𝑒
2𝜙𝑒𝑟𝑟𝑜𝑟
+ 1|] ≈ [𝑙𝑜𝑔2 |
𝜙𝑟𝑎𝑛𝑔𝑒
𝜙𝑒𝑟𝑟𝑜𝑟
| − 1] 
 
(6.2) 
 
 
Figure 36. Example of 3-bit DAC with analog phase output vs digital input. 
 
Figure 37 is a plot of the required DAC ENOB vs bias error in degrees for a DAC range 
of 180° (0 to Vπ). The ENOB for 0.06° error is approximately 10.5. This is a reasonable 
value, considering that the nominal resolution of the microcontroller DAC is 12 bits with ±1-
bit differential non-linearity error [22].  
φrange
φLSB = 2φerror
 38 
 
Figure 37. DAC ENOB vs bias error (degrees) 
 
 
2. HD2, HD3 measurements 
2nd and 3rd harmonic distortion measurements were taken at different setpoints to test the 
modulator bias controller for N=3500. The setup (Figure 38) consisted of the control loop, as 
well as a variable optical attenuator (VOA) for linearity testing, a power splitter, an analog 
signal generator (ASG) and an electrical spectrum analyzer (ESA). 
 
 39 
 
Figure 38. Distortion measurements setup 
 
The linearity of the PD was tested prior to the distortion measurements.  A bias point was 
fixed and the fundamental and 2nd harmonic of an ASG tone were measured. Then, the optical 
signal was attenuated prior to the PD and the measurements were repeated. The magnitude of 
both frequencies decreased by the same amount, and thus it was verified that the PD did not 
introduce additional distortion.  
Next, the link’s frequency magnitude response (Figure 39) was tested to compensate the 
HD2 and HD3 for any variations. The relevant bandwidth is 30MHz, since a 10MHz tone was 
to be input to MZM and the 2nd and 3rd harmonic were to be measured. It can be noted that the 
magnitude response varies only 1.3dB from 10 to 30MHz. The low bandwidth is attributed to 
the PD RL used, which can be adjusted to improve the frequency response if required. 
 
RF INPUT
DC BIAS
OPTICAL 
INPUT
OPTICAL 
OUTPUT
MZM
OPTICAL 
ATTENUATOR
DET01CFC 
PHOTODETECTOR
BIAS CONTROL
LASER
SIGNAL
GENERATOR
RF POWER 
SPLITTER
ELECTRICAL
SPECTRUM 
ANALYZER
 40 
 
Figure 39. MZM and PD frequency response 
 
A 0dBm 10MHz RF tone and 1.25V 1kHz dither tone were input to the MZM and the bias 
control setpoint was varied to different bias points. The dither fundamental and HD2, as well 
as the RF tone fundamental, HD2 and HD3 were measured on the ESA (results in Figure 40). 
The dither’s HD2 to fundamental ratio (74dB) at quadrature setpoint agrees with the results 
shown above, although there is an offset of approximately 0.5° between setpoint and measured 
bias point. For the RF tone the ratio is 85dB. As can be seen in the bottom left plot, there is 
an offset of approximately 1° between the dither signal’s and RF tone’s quadrature points. 
The experiment was then repeated for a 500MHz input RF tone (Figure 41). Unfortunately, 
the HD2 suppression is over 30dB less.  
 
 41 
 
Figure 40. HD2 and HD3 measurements for 10MHz RF tone at different bias setpoints. Dither 
fundamental and 2nd harmonic, and RF fundamental, 2nd and 3rd harmonics are shown in different 
plots. 
 
 
Figure 41. HD2 and HD3 measurements for 500MHz RF tone at different bias setpoints 
  
 42 
B. Further work 
1. Offset and linearity 
The results demonstrate that for the dither signal, the bias control method allows for 
biasing to different points on the MZM transfer function to within an average error of 0.14° 
with a PID controller correction time of 0.82s. The correction time increases linearly with the 
amount of ADC samples, and approximately 10,000 samples would be required to achieve 
<0.1° average error. This can be achieved with a PID controller correction time of less than 2 
seconds, which should be fast enough to compensate the drift in the MZM transfer function.   
However, there is an observable 0.5° offset between the setpoint and the measured bias point 
which requires addressing. It is believed that this is an effect of the nonlinearity of the PD load 
resistor and can be eliminated by employing a transimpedance amplifier (TIA) at the PD 
output. It is considered that this would also reduce the offset between dither (low-frequency) 
bias point and RF (high-frequency) bias point, as well as the HD2 values observed for RF 
tones at quadrature (see Figure 41).  
2. Microcontroller with integrated peripherals 
There are COTS microcontrollers that incorporate peripherals which can further reduce 
the number of components used to employ this bias control method. The NXP 
MCF51MM256/128 (block diagram in Figure 42) has built-in Op Amps and TIAs (TRIAMP). 
For MZMs with Vπ < 3.3V, in theory only a power supply and the microcontroller would be 
required to implement the bias control method. 
 
 43 
 
Figure 42. MCF51MM256 series block diagram 
 
3. Application to Si MZM 
The main challenge of applying a closed-loop bias control method to Silicon MZMs is 
that the loss imbalance between the arms is significant, and the transfer function must now be 
described in terms of a complex effective index [23]. One method that has been simulated 
utilizes VOAs to produce a “loss dither” in addition to the conventional phase dither used in 
LiNbO3 MZMs [24]. This provides the spectral information required to determine the 
imbalance and continually adjust the VOAs. It is the author’s opinion that the implementation 
of that method to the current setup to bias Si MZMs is worth pursuing.  
C. Conclusion 
A theoretical overview of the MZM was provided and the importance of closed-loop 
versatile bias control was established. SIMULINK models were then shown for time and 
frequency-domain analysis. A brief review of MZM bias control patents and publications was 
then provided. A bias control method with digital filters was proposed to minimize circuit 
components. The method was then implemented and bias control was tested over time and 
 44 
distortion measurements were taken at different bias setpoints. In the process, the bias control 
error due to quantization and electrical noise was analyzed and an expected precision as a 
function of ADC samples was given. Further work to reduce the offset between setpoint and 
bias point was discussed, as well as the use of other microcontroller platforms to further 
simplify the bias control circuit and the potential to extend this method to Si MZMs.  
  
 45 
References 
 
[1]  X. Fernando, Radio Over Fiber for Wireless Communications, Chichester: 
John Wiley & Sons, Ltd, 2014.  
[2]  D. M. Fye, "Design of Fiber Optic Antenna Remoting Links for Cellular Radio 
Applications," in 40th IEEE Conference on Vehicular Technology, Orlando, 1990.  
[3]  D. Novak, "Radio-Over-Fiber Technologies for Emerging Wireless Systems," 
IEEE JOURNAL OF QUANTUM ELECTRONICS, vol. 52, pp. 1-11, 2016.  
[4]  C. Cox, Analog Optical Links Theory and Practice, Cambridge: Cambridge 
University Press, 2004.  
[5]  S. Kasap, Optoelectronics and Photonics, Harlow: Pearson, 2013.  
[6]  L. Y, "Slope value detection-based ditherless bias control technique for mach–
zehnder modulator," Opt. Eng, vol. 52, no. 8, 2013.  
[7]  Photonic Systems Inc., "MODULATOR BIAS CONTROLLERS," Photonic 
Systems Inc., 2016. [Online]. Available: 
http://www.photonicsinc.com/modulator_bias_controller.html. [Accessed 20 
October 2016]. 
[8]  S. Pappert, "Photonic link techniques for microwave," in RF Photonic 
Technology in Optical Fiber Links, Cambridge, Cambridge University Press, 2002, 
pp. 293-333. 
 46 
[9]  M. L. Farwell, "Increased Linear Dynamic Range by Low Biasing the Mach-
Zehnder Modulator," IEEE PHOTONICS TECHNOLOGY LETTERS, vol. 5, pp. 
779-782, 1993.  
[10]  J. Buckwalter, Linearity Analysis of Circuits, 2016.  
[11]  Photonics Systems Inc, "Lightwave.com," Lightwave, 1 May 2001. [Online]. 
Available: http://www.lightwaveonline.com/articles/print/volume-18/issue-
5/features/bias-controllers-for-external-modulators-in-fiber-optic-systems-
53469212.html. [Accessed 21 May 2017]. 
[12]  Y. Li, "Any Bias Point Control Technique for Mach–Zehnder Modulator," 
IEEE PHOTONICS TECHNOLOGY LETTERS, vol. 25, no. 24, 2013.  
[13]  Pharad, "Ultra-Compact Dither-Free Modulator Bias Controller," Pharad, 2016. 
[Online]. Available: http://www.pharad.com/ultra-compact-dither-free-modulator-
bias-controller.html. [Accessed 2016]. 
[14]  YY Labs, "Modulator Bias Controllers," YY Labs, 2014. [Online]. Available: 
http://www.yylabs.com/products.php. [Accessed 2016]. 
[15]  M.-L. Kao and Y.-K. Park, "Modulator-based Lightwave Transmitter". United 
States Patent 5,208,817, 4 May 1993. 
[16]  E. I. A. Charles H. Cox, "Modulator bias control". United States Patent US 
7369290 B1, 19 March 2003. 
[17]  A. Tipper, "Automatic bias control for an optical modulator". United States 
Patent 7555226, 7 July 2005. 
 47 
[18]  L. L. Wang, "A Versatile Bias Control Technique for Any-Point Locking in 
Lithium Niobate Mach–Zehnder Modulators," JOURNAL OF LIGHTWAVE 
TECHNOLOGY, vol. 28, no. 11, 2010.  
[19]  T. Hutchison, "LTspice: Noise Simulations," ANALOG DEVICES, 2013. 
[Online]. Available: http://www.linear.com/solutions/1148. [Accessed 2017]. 
[20]  W. Kester, Taking the Mystery out of the Infamous Formula, "SNR = 6.02N + 
1.76dB," and Why You Should Care, Analog Devices, 2009.  
[21]  National Instruments, "PID Theory Explained," National Instruments, 2011. 
[Online]. Available: http://www.ni.com/white-paper/3782/en/. [Accessed 2016]. 
[22]  Freescale Semiconductor, Inc., "NXP.com," 2014. [Online]. Available: 
http://www.nxp.com/assets/documents/data/en/data-sheets/KL25P80M48SF0.pdf. 
[Accessed 2016]. 
[23]  R.-L. Chao, "Forward Bias Operation of Silicon Photonic Mach Zehnder 
Modulators for RF Applications," Optical Society of America, 2016.  
[24]  A. W. MacKay, Complex Phase Biasing of Silicon Mach-Zehnder 
Interferometer Modulators, Toronto: University of Toronto, 2014.  
[25]  F. Littmarck, "Comsol.com," COMSOL, 8 April 2014. [Online]. Available: 
https://www.comsol.com/blogs/optimizing-mach-zehnder-modulator-designs-
comsol-software/. [Accessed 21 May 2017]. 
[26]  J. D. F. David J. Allie, "ELECTRO-OPTIC MODULATOR HAVING 
GATED-DITHER BIAS CONTROL". United States Patent 5,400,417, 21 March 
1995. 
 48 
[27]  W. Kester, "Analog Devices," [Online]. Available: 
http://www.analog.com/media/en/training-seminars/tutorials/MT-001.pdf. 
 
 
 
     
 
 
  
 
 
 
 
 
 
  
 49 
Appendix A - Microcontroller code 
1. #include "mbed.h"   
2. #include "FastAnalogIn.h"   
3.    
4.    
5. // Tickers, timers - used for ensuring fixed times:   
6. Ticker ADCperiod;     //Creates ticker class "Sampletime" used for ADC conversion 
7. Timer DSPtimer; //Creates timer class "DSPperiod" used for DSP time.  
8.    
9. // Serial communication:   
10. Serial pc(USBTX, USBRX); //tx,rx   
11.    
12. //***********************************Pin designations **************************   
13. // ADC pin designation. FastAnalogIn runs ADC in "burst" mode (DMA):   
14. FastAnalogIn adc(PTC2); //float. 0 <=adc <= 1; 0 = 0V, 1.0f = 3.3V   
15. // Other analog inputs are set as digital outputs for better ADC performance:   
16. DigitalOut dig1(PTE22);   
17. DigitalOut dig3(PTE29);   
18. DigitalOut dig4(PTE20);   
19. DigitalOut dig6(PTB0);    
20. DigitalOut dig7(PTB1);    
21. DigitalOut dig8(PTB2);   
22. DigitalOut dig9(PTB3);     
23. DigitalOut dig10(PTC0);    
24. DigitalOut dig11(PTC1);    
25. DigitalOut dig13(PTD1);     
26. DigitalOut dig14(PTD5);    
27. DigitalOut dig15(PTD6);     
28. //DAC pin designation.    
29. AnalogOut dac(PTE30);   //float. 0 <=dac <= 1; 0 = 0V, 1.0f = 3.3V   
30. //****************************************************************************** 
31.    
32. //****************************Constants and variables***************************   
33. //Frequencies and periods:   
34. float sampletime = 0.0001; //ADC sample time [s]. Should be 1/Fs.   
35. float DACtime = 1; //DAC time   
36.    
37. //Sinewave arguments   
38. int s = 10;   //Number of sine arguments   
39. double Sine1_I[] = {0.000000000000000E+00,5.877852522924730E-01,9.510565162951540E-
01,9.510565162951540E-01,5.877852522924730E-01,1.225148454908620E-16,-5.877852522924730E-01,-
9.510565162951540E-01,-9.510565162951540E-01,-5.877852522924730E-01};   
40. double Sine1_Q[] = {1.000000000000000E+00,8.090169943749470E-01,3.090169943749480E-01,-
3.090169943749470E-01,-8.090169943749470E-01,-1.000000000000000E+00,-8.090169943749480E-01,-
3.090169943749480E-01,3.090169943749470E-01,8.090169943749470E-01};   
41. double Sine2_I[] = {0.000000000000000E+00,9.510565162951540E-01,5.877852522924730E-01,-
5.877852522924730E-01,-9.510565162951540E-01,-2.450296909817240E-16,9.510565162951540E-
01,5.877852522924730E-01,-5.877852522924730E-01,-9.510565162951540E-01};   
42. double Sine2_Q[] = {1.000000000000000E+00,3.090169943749480E-01,-8.090169943749470E-01,-
8.090169943749480E-01,3.090169943749470E-01,1.000000000000000E+00,3.090169943749480E-01,-
8.090169943749470E-01,-8.090169943749480E-01,3.090169943749470E-01};   
43.    
44. //ADC parameters:   
45. int N = 3500; //Number of samples per DSP cycle. Must be a multiple of s.   
46. int c;  //Ratio of number of samples to sinewave arguments   
47. float ADC_Array[3500]; //serves as a shift register for the ADC conversions. 
48.    
49. //Correlation:   
50. double Sn1_I, Sn1_Q, Sn2_I, Sn2_Q;   
 50 
51. float pi = 3.14;   
52. double Mag_fund, Mag_2nd, Phase_fund, Phase_2nd;   
53. double ratio, phase;   
54.    
55. //PID controller:   
56. double dspsampletime;  //Stores PID sample size   
57. double setpoint = 0;         //PID controller set point. 0 for quadrature.   
58. double Kp = 1, Ki= 0.5, Kd= 0.1; //PID coefficients   
59. double Pout, Iout, Dout;  //PID outputs   
60. double loop_error, pre_error, errormin = 1e5; //PID errors 
61. double PIDoutput = 0.5;    //PID output. DAC output.   
62. double max = 0.85, min = 0.15; //PID output minimum and maximum values   
63.    
64. //Auxiliary constants   
65. int j, k, l; //used as a counters in for loops                       
66. //******************************************************************************   
67.    
68.    
69. //Function that moves adc value to shift register. Repeats every sample time:   
70. void ADC_register(){   
71.     if (j < N){   
72.         ADC_Array[j] = adc;   
73.         j++;   
74.         }   
75.     }   
76.    
77. //Correlation   
78. void Correlation(){   
79.     Sn1_I = 0;   
80.     Sn1_Q = 0;   
81.     Sn2_I = 0;   
82.     Sn2_Q = 0;   
83.     for (k = 0; k < c; k++){   
84.         for (l = 0; l < s; l++){   
85.             Sn1_I += ADC_Array[s*k+l] * Sine1_I[l];   
86.             Sn1_Q += ADC_Array[s*k+l] * Sine1_Q[l];   
87.             Sn2_I += ADC_Array[s*k+l] * Sine2_I[l];   
88.             Sn2_Q += ADC_Array[s*k+l] * Sine2_Q[l];   
89.             }   
90.         }   
91.     Mag_fund = sqrt(Sn1_I*Sn1_I + Sn1_Q*Sn1_Q);   
92.     Mag_2nd = sqrt(Sn2_I*Sn2_I + Sn2_Q*Sn2_Q);   
93.     Phase_fund = atan2(Sn1_Q,Sn1_I);   
94.     Phase_2nd = atan2(Sn2_Q,Sn2_I);   
95.     phase = 2*Phase_fund - Phase_2nd;   
96.     if ((phase >= (-3*pi) && phase < (-2*pi)) || (phase >= (-
pi) && phase < 0) || (phase >= pi && phase < (2*pi))){    
97.         ratio = -Mag_2nd / Mag_fund;   
98.         }   
99.         else{   
100.             ratio = Mag_2nd / Mag_fund;   
101.             }   
102. }   
103.    
104. //PID controller:   
105. void PID_control(){   
106.     loop_error = setpoint - ratio;   // Calculate error   
107.     if (abs(loop_error) < errormin){   
108.         loop_error = 0;   
109.         }   
110.     Pout = Kp * loop_error;  // Proportional      
 51 
111.     Iout += Ki*(loop_error + pre_error)* 0.5 * dspsampletime;   //Integral 
112.     Dout = Kd*(loop_error - pre_error) / dspsampletime; // Derivative   
113.     PIDoutput = Pout + Iout + Dout; // Calculate total output   
114.     if( PIDoutput > max ){ // Restrict to max/min   
115.         PIDoutput = max;   
116.         }   
117.         else if( PIDoutput < min ){   
118.             PIDoutput = min;   
119.             }   
120.     dac = PIDoutput;    //0 <= biasdc <= 1; 0.0 = 0V, 1.0f = 3.3V   
121.     pre_error = loop_error; // Save error to previous error    
122.     }   
123.    
124.        
125. int main() {   
126.        
127.     ADCperiod.attach(&ADC_register, sampletime);  //Attaches ticker to ADC_read function with a fixed sample 
time "sampletime"   
128.        
129.     c = N/s;   
130.        
131.     while(1) {   
132.                    
133.             if(j == N){  //After ADC values are obtained, dsptime is calculated for PID controller:    
134.                 dspsampletime = DSPtimer.read();   
135.                 DSPtimer.reset();   
136.                 DSPtimer.start();   
137.                      
138.                 Correlation();   
139.                    
140.                 PID_control();   
141.                    
142.                 pc.printf("{TIMEPLOT:Ratio plot|data|Ratio|T|%E}\n",ratio);   
143.                 pc.printf("{TIMEPLOT:Ratio plot|data|dcbias|T|%E}\n",PIDoutput);   
144.                 pc.printf("{TIMEPLOT:Ratio plot|set|title=Ratio}\n");   
145.                 pc.printf("{TIMEPLOT:Ratio plot|set|x-label=Time}\n");   
146.                 pc.printf("{TIMEPLOT:Ratio plot|set|y-label=Ratio}\n");   
147.                    
148.                 wait(0.1);   
149.                    
150.                 j = 0;   
151.                    
152.                 }   
153.                
154.     }   
155.        
156. }   
 
 
 
 
