University of Wollongong

Research Online
Faculty of Informatics - Papers (Archive)

Faculty of Engineering and Information
Sciences

2011

FPGA based filter design for self-mixing interferometry signals
Yuan Sun
University of Wollongong

Yanguang Yu
University of Wollongong, yanguang@uow.edu.au

Wenbing Fan
Zhengzhou University

Jiangtao Xi
University of Wollongong, jiangtao@uow.edu.au

Follow this and additional works at: https://ro.uow.edu.au/infopapers
Part of the Physical Sciences and Mathematics Commons

Recommended Citation
Sun, Yuan; Yu, Yanguang; Fan, Wenbing; and Xi, Jiangtao: FPGA based filter design for self-mixing
interferometry signals 2011.
https://ro.uow.edu.au/infopapers/3832

Research Online is the open access institutional repository for the University of Wollongong. For further information
contact the UOW Library: research-pubs@uow.edu.au

FPGA based filter design for self-mixing interferometry signals
Abstract
Self-mixing interferometry (SMI) signals are observed from a sensing system consisting of a laser diode
with external optical feedbacks. SMI signals carry the information associated to both of the displacement
and parameters of the SL. To retrieve the information precisely, pre-processing of SMI signals is the first
key step. For achieving real-time, and high quality sensing, this paper proposes a Field-programmable
gate arrays (FPGA) based filtering and normalizing processing for SMI signals. According to the noise
features contained in SMI signal, a median filter and a wavelet transform based filter are combined for our
design. Hardware co-simulation verified that the performance for this FPGA used filter design.

Disciplines
Physical Sciences and Mathematics

Publication Details
Y. Sun, Y. Yu, W. Fan & J. Xi, "FPGA based filter design for self-mixing interferometry signals," in 2011
International Conference on Optical Instruments and Technology: Optical Sensors and Applications, 2011,
pp. 819909-1-819909-7.

This conference paper is available at Research Online: https://ro.uow.edu.au/infopapers/3832

FPGA based Filter Design for Self-mixing Interferometry Signals
Yuan Suna, Yanguang Yu*a, Wenbin Fanb, Jiangtao Xia
a
School of Electrical, Computer and Telecommunications Engineering, University of Wollongong,
Northfields Ave, Wollongong, NSW, 2522, Australia;
b
School of Information Engineering, Zhengzhou University, P. R. China
ABSTRACT
Self-mixing interferometry (SMI) signals are observed from a sensing system consisting of a laser diode with external
optical feedbacks. SMI signals carry the information associated to both of the displacement and parameters of the SL. To
retrieve the information precisely, pre-processing of SMI signals is the first key step. For achieving real-time, and high
quality sensing, this paper proposes a Field-programmable gate arrays (FPGA) based filtering and normalizing
processing for SMI signals. According to the noise features contained in SMI signal, a median filter and a wavelet
transform based filter are combined for our design. Hardware co-simulation verified that the performance for this FPGA
used filter design.
Keywords: self-mixing interferometry, pre-processing, field programmable gate arrays, wavelet transform,
normalization

1. INTRODUCTION
The optical feedback self-mixing interferometry（SMI） technique has been an attractive research field in the last two
decades1. Sensors based on this effect are extensively used to measure distance2, displacement and vibrations3-5. The
SMI effect happens when the reflected or backscattered laser light from a distant target ahead of the laser, re-enters the
laser cavity, resulting in the variance of both the amplitude and the frequency of the lasing field. The modulated laser
power, called SMI signal, is detected by a photodiode (PD). SMI signals carry the information associated to both the
displacement4 and parameters of SLs7-9.
To retrieve the information precisely, pre-processing of SMI signals is an important step. In 2007, according to noise
features, Yu et.al proposed a filtering method combined by a median filter and a band-pass filter based on Kaiser
window function6. And Wei presented a neural network interpolation technique for the noise elimination of SMI
signals10. However, both of the two methods can change the positions of sharp transitions of SMI signals and this change
can decrease SMI sensing accuracy. And our recent work proposes a wavelet transform based filtering method which can
solve above problem24. This algorithm24 was implemented using Matlab.
As for real-time high-quality sensing in industrial applications, a compact SMI system is important. That is a small-size
high-integration chip is needed to replace a PC for signal processing. Recent years, digital signal processing
accomplished on Field-programmable gate arrays (FPGAs) is widely used for high-speed, real-time signal processing,
because FPGAs are advantageous on merging digital signal processing algorithms with other control logic. It can provide
a feasible processing without scarifying accuracy or suffering extra communication latency11.Therefore, combining
FPGA with SMI system is a good solution for the real-time sensing.
This paper proposes a FPGA based filtering and normalizing processing for SMI signals. The sensing signal acquired
from the SMI system is sent into the FPGA board and processed. This FPGA based SMI system is demonstrated in
Figure 1. This paper is organized as following. Basic theory of SMI effect is presented in Section 2. Section 3 depicts the
FPGA design for the filters and the normalization unit. Section 4 shows the real-time simulation implemented by cohardware simulation method. Conclusion is given in Section 5.

2011 International Conference on Optical Instruments and Technology: Optical Sensors and Applications,
edited by Brian Culshaw, YanBiao Liao, Anbo Wang, Xiaoyi Bao, Xudong Fan, Proc. of SPIE Vol. 8199,
819909 · © 2011 SPIE · CCC code: 0277-786X/11/$18 · doi: 10.1117/12.906577
Proc. of SPIE Vol. 8199 819909-1
Downloaded From: http://proceedings.spiedigitallibrary.org/ on 07/28/2013 Terms of Use: http://spiedl.org/terms

EXGLU

IUGL1m

CA

J9LI
bbOV
bLocGi
Figure 1. Basic structure of the FPGA based SMI system

2. BASIC THEORY
The basic theoretical model for SMI systems is developed from Lang and Kobayashi15, and this model is re-presented as
the following equations 3, 4, 9-11:

φF [n] = φ0 [n] − C sin(φF [n] + arctan[α ])
P[n] = P0 (1 + m × g[n])
g (n) = cos(φF (n))
φ0 (n) = 4π L(n) / λ0

n

discrete time index

φF

external light phase of a LD with feedback

φ0

external light phase of a free running LD

P[n]

laser intensity with feedback

P0
m
g[n]
C
L[n]

laser intensity without feedback
modulation index
an SMI signal
feedback level factor
linewidth enhance factor
external cavity length

λ0

emitted laser wavelength without feedback

α

(1)
(2)
(3)
(4)

Table 1. Meanings of parameters in Equations (1)-(4)

SMI signals, which have a fringe pattern similar to the traditional interference signals, have been widely studied on in
depth4, 12-13. When feedback level is increasing, the behavior of SLs can be classified into different feedback regimes14.
The waveforms of the SMI signals are sinusoid-like, in weak optical feedback regime, while the signals exhibit
hysteresis and the waveforms are saw-tooth shaped in both the moderate and strong feedback regimes. For the
convenience of the description for FPGA design, we plot a simulated SMI signal waveform using Equations (1)-(4) with
C =3, α =3 based on this model in Figure 2. There are characteristic points in the SMI signal waveform, such as sharp
transitions, zero-crossing points and peak points, which include information related to the parameters of LDs9 and the
moving information of the external target16. According to Equation (3), a normalized SMI signal varies in the range of [1, 1]. All those characteristic points in SMI signals should be accurately selected so that a high-quality sensing can be
achieved9. However, due to inevitable noise existing in a practical SMI system, these important points are contaminated.

Proc. of SPIE Vol. 8199 819909-2
Downloaded From: http://proceedings.spiedigitallibrary.org/ on 07/28/2013 Terms of Use: http://spiedl.org/terms

In our recent work24, we proposed a wavelet transform based method which is able to effectively remove the noise
affection on these points. In Section 3, we implement this method based on FPGA design.
Peaks

1

Sharp
transitions

0.8
0.6
0.4

g[n]

0.2
0
-0.2
Zero-crossing
points

-0.4
-0.6
-0.8
-1
0

500

1000

1500

2000

2500

n

Figure 2. A simulated SMI signal with C =3, α =3 in the moderate optical feedback regime.

3. FPGA DESIGN
The FPGA based pre-processing unit contains two parts, a de-noising part and a normalization part. The de-noising
method24 is employed for the FPGA design. The basic structure is as shown in Figure 3. The FPGA based SMI system is
shown as in Figure 3. Since the values of the SMI signal power detected from the sensing system are always signed real
numbers and main part of the algorithm is digital processing, system generator for Digital Signal Processing (DSP) is
utilized for the design for convenience. This tool is a leading high-level tool for designing high-performance DSP
systems using FPGAs, whose key feature is DSP modeling: build and debug a high-performance DSP system in
Simulink using the Xilinx Blockset22. This filtration system is built in Simulink and some blocks that Xilinx does not
provide are implemented using Blackbox, which is an interface between source Hardware Description Language (HDL)
codes and Simulimk models. After the completion of the design, it is converted to Verilog HDL codes and can be
operated in Xilinx ISE.

g[ n]

bL0G2
g f [ n]
g p [n]
J4oTJJJ1p

Figure 3. Basic structure of FPGA based SMI signal pre-processing

3.1 Median filter FPGA based design
The length of the sparkles in these SMI signal obtained in our experiment set-up is usually no more than 5 sampling
points, so a 5-points median filter is applied. Before passing data into a median filter, a data acquisition block is needed
to import 5 subsequent data points, and 5 registers can be used for this. The flow chart of a median filter is shown as

Proc. of SPIE Vol. 8199 819909-3
Downloaded From: http://proceedings.spiedigitallibrary.org/ on 07/28/2013 Terms of Use: http://spiedl.org/terms

below in Figure 4. Rij represents registers and Cij denotes compare-swappers. The basic principle of this median filter is
to sort the 5 points and pick the median value to replace the current processed point. The five points obtained from the
acquisition block are sent into C11 and C12 in pairs and R11 at the first level. The compare-swappers compare their values
and send the smaller output into the comparison block below at the next level, the larger one into the comparison block
above, just as that C11 puts its smaller output into C21 and the other one into C22 . After 5 level’s comparison, the 5
points is being descended and the median value is easily picked out.
g[k ]
g[k + 1]

C11

C21

R41

C31
g[k + 2]
g[k + 3]

C12

C51

C22

C41

g[k + 4]

R11

R21

R31

Figure 4. The flow chart of the design of the median filter, g[k ] is a data point in SMI signals.

3.2 Wavelet transform filter realization FPGA based design
This part describes the FPGA implementation of the wavelet transform based filter proposed in our recent work24. For
the convenience of depicting the design, the process of this wavelet transform based filtering method is simply
summarized as following steps:
1.

Discrete wavelet transform is applied on SMI signals;

2.

Single level reconstruction is applied on each frequency component;

3.

High frequency content is spatially filtered with the positions of sharp transitions detected by a differential unit. In
this step, the transitions in the high frequency content are preserved and noise is filtered.

4.

Filtered high frequency component is combined with low frequency component to reconstruct a processed SMI
signal.

The core blocks of the wavelet transform based filter, low- and high-pass filters, are accomplished using Distribute
Arithmetic (DA). An output of an N-order FIR can be derived as linear convolution:
N −1

y[n] = ∑ H [k ]g[n − k ]

(5)

k =0

and where g[n] is an input signal and H [k ] are the coefficients of a FIR filter. A hardware realization using traditional
multiplier-accumulator (MAC) costs N multiplication and (N-1) addition. It is a waste of both of resources and time. DA
is an efficient algorithm to realize sum of products which has a parallel processing structure. And this equation can be
redistributed as below according to DA23:
N −1

B−2

N −1

k =0

b =0

k =0

y[n] = −2 B −1 ∑ H [k ]g B −1[n − k ] + ∑ 2b ∑ H [k ]gb [n − k ]

(6)

where g b [n − k ] represents the bth bit position of the number’s binary representation. The key is to realize that the second
summation can be mapped to a Look Up Table (LUT). The coefficients are known and the values are either 1 or 0 then
each multiplication is just a combination of the coefficients for which a true table can be constructed.

Proc. of SPIE Vol. 8199 819909-4
Downloaded From: http://proceedings.spiedigitallibrary.org/ on 07/28/2013 Terms of Use: http://spiedl.org/terms

g B −1[n]

g 0 [n]

g B −1[n]

g 0 [n]

g B −1[n]

g 0 [n]

g B −1[n]

g 0 [n]

+

Fill

R

Figure 5. DA for low- and high-pass filter.

After passing the low- and high-pass filters, down- and up-sampling are applied to all frequency parts to reconstruct the
frequency component at different scales. This down-sampling operation is to discard odd terms, and up-sampling can be
completed by interpolating zeros between two adjacent terms in the down-sampled frequency content. Since an operation
of up-sampling is taken just after the down-sampling, these two operations can be accomplished by using the same firstin-first-out (FIFO) Intellectual Property (IP) core provided by Xilinx. The design of this part is shown in Figure 6. After
the data obtained from an FIFO block, a multiplexer (MUX) is employed to make the oven terms been kept and odd
terms changed into zeros, which accomplishes down- and up-sampling at the same time. The MUX is controlled by a
counter which only has two states, 0 or 1, to select to pass the terms or make them as zeros.
cofliJG

EIEO

Figure 6. Design of down- and up-sampling using FIFO. Meanings of ports and blocks in this design: clk, clock of this
part; rst_n, reset signal; data_in, input of data; r_en and w_en are the reading and writing enable pin, respectively.

A sharp detection block is the key to this filter. A differential unit is employed to detect the positions of sharp transitions
in SMI signals. This detection block is simply realized by subtractions between two adjacent points in SMI signals. A
pulse train is obtained after this detection, which contains the information of sharp transitions. However, this pulse train
has varying magnitude. Thus, a threshold should be pre-set. Considering the difference of the magnitudes between pulses
and noises, half of the magnitude of the first pulse is set as a threshold and is stored in a register. The following
magnitudes of each differential value should be compared with this threshold. The ones bigger than the threshold are
seen as transitions and others are seen as noise. Combining this information with the reconstructed high frequency
component, the signals are processed.

3.3 Normalization FPGA based design
After filtering SMI signals, their normalization is no longer affected by the sparkle-like noise. In this situation, the key to
normalization is to remove the direct current component. This normalization can be derived from the following equations:

Proc. of SPIE Vol. 8199 819909-5
Downloaded From: http://proceedings.spiedigitallibrary.org/ on 07/28/2013 Terms of Use: http://spiedl.org/terms

g p [n] = (( g f [n] − min( g f [n])) / (max( g f [n]) − min( g f [n])) − 0.5) × 2

(7)

In Equation (7), g f [n] is a filtered SMI signal and g p [n] represents the normalized signal. min( g f [n]) and
max( g f [n]) are the minimum and the maximum values of g p [n] , respectively. Maximum and minimum values can be

found out using a register. The first come-in value of a segment in g f [n] is stored as an extreme value, and the next
value compares with the stored one. The next point replaces the stored extreme value if it is larger than the maximum
value or smaller than the minimum value.

4. CO-SIMULATION OF THE DESIGN
This whole design of pre-processing unit is implemented on a Xilinx ® Spartan-3E FPGA (XC3S500E-4FG320C)
Development Board. The main features of this board is listed as following22: 10478 logic elements (LEs); 232 maximum
user I/O pins; 20 multiplier; 2-input serial peripheral interface (SPI) based Analog-to-Digital Converter (ADC) and 4output SPI-based Digital-to-Analog Converter (DAC); on-board Universal Serial Bus (USB) based download/debug
interface.
The design proposed in Section 3 is completed in System Generator and converted into Verilog HDL code. The Verilog
code is synthesized and downloaded into the FPGA board. Then hardware co-simulation is carried out and processed
data is exported into Matlab and plotted as in Figure 7. An experimental SMI signal is as shown in Figure 7(a). Figure 7
(b) demonstrates the signal de-noised by a median filter and a wavelet transform based filter. The filtered signal after
normalization is illustrated in Figure 7(c). From this diagram, it can be seen that the FPGA based pre-processing works
well for SMI signals.
(a)

g[n]

10
0
-10

0

500

1000

1500
(b)

2000

2500

3000

0

500

1000

1500
(c)

2000

2500

3000

0

500

1000

1500
n

2000

2500

3000

gf[n]

5
0
-5

gp[n]

1
0
-1

Figure 7. Filtering result for an experimental SMI signal: (a) an original experimental SMI signal; (b) the filtered SMI
signal; (c) the normalized SMI signal

5. CONCLUSION
This paper presents a FPGA based pre-processing design for SMI signals. Based on the features of SMI signals, this
FPGA based pre-processing includes two parts, a de-noising part and a normalization part. In the de-noising part, a
wavelet filter and a median filter are employed. The de-noising part reduces the high-frequency and sparkle-like noise
and the normalization part makes SMI signals into the range of [-1, 1]. By implementing this method on a Xilinx Spartan
3E board, hardware co-simulation is carried out to verify the performance of this FPGA based pre-processing method.

ACKNOWLEDGMENT
The work was supported by Australian Research Council on ARC Linkage International (LX0561454) and by National
Natural Science Foundation of China (NSFC ID: 60871031

Proc. of SPIE Vol. 8199 819909-6
Downloaded From: http://proceedings.spiedigitallibrary.org/ on 07/28/2013 Terms of Use: http://spiedl.org/terms

REFERENCES
[1]
[2]
[3]
[4]
[5]

[6]
[7]
[8]
[9]

[10]

[11]
[12]
[13]
[14]
[15]
[16]
[17]
[18]
[19]
[20]
[21]
[22]
[23]
[24]

Bosch, T., “An Overview of Self-Mixing Sensing Applications,” Optoelectronic and Microelectronic Materials and
Devices, 2004 Conference on , vol., no., pp.385-392, 8-8(2004).
Bosch, T. and Lescure, M., “Selected Papers on Laser Distance Measurements,” SPIE Milestone Series, vol. MS
115 (1995).
Wang, W. M., Grattan, K. T. V., Palmer, A. W. and Boyle, W. J. O., “Self-mixing interference inside a single-mode
diode laser for optical sensing applications,” J. Lightwave Technol., vol. 12, pp. 1577–1587(1994).
Donati, S., Giuliani, G. and Merlo, S., “Laser diode feedback interferometer for measurement of displacements
without ambiguity,” IEEE J. Quantum Electron., vol. 31, pp. 113–119 (1995).
Bosch, T., Servagent, N. and Boyer, F., “Vibrations measurements with a self-mixing type laser displacement sensor
for modal analysis,” Instrumentation and Measurement Technology Conference, 1996. IMTC-96. Conference
Proceedings. 'Quality Measurements: The Indispensable Bridge between Theory and Reality'., IEEE , vol.1, no.,
pp.648-653 vol.1(1996).
Yu, Y., Xi, J. and Chicharo, J. F., “Improving the Performance in an Optical feedback Self-mixing Interferometry
System using Digital Signal Pre-processing.” WISP, 1-6 (2007).
Yu, Y., Giuliani, G. and Donati, S., “Measurement of the linewidth enhancement factor of semiconductor lasers
based on the optical feedback self-mixing effect,” IEEE Photonics Technology Letters, vol. 16, pp.990-992(2004).
Xi, J., Yu, Y., Chicharo, J. F. and Bosch, T., “Estimating the parameters of semiconductor lasers based on weak
optical feedback interferometry,” IEEE Journal of Quantum Electronics, vol.41, No.8, pp.1058-1064(2005).
Yu, Y., Xi, J., Chicharo, J. F. and Bosch, T., “Toward Automatic Measurement of the Linewidth Enhancement
Factor Using Optical Feedback Self-Mixing Interferometry With Weak Optical Feedback,” Quantum Electronics,
IEEE Journal of 43, 527-534 (2007).
Wei, L., Chicharo, J.F, Yu. Y., Xi, J., “Pre-Processing of Signals Observed from Laser Diode Self-mixing
Intereferometries using Neural Networks,” Intelligent Signal Processing, 2007. WISP 2007. IEEE International
Symposium on , vol., no., pp.1-5, 3-5 (2007).
Rose. J, Gamal, A. El and Sangiovanni-Vincentelli, A, “Architecture of field-programmable gate arrays,”
Proceedings of the IEEE, 81(7), 1013-1029 (1993).
K. Peterman, Laser diode modulation and noise, Dordrecht, TheNetherlands: Kluwer, 1988
G. Giuliani, M. Norgia, S. Donati, T. Bosch “Laser diode self-mixing technique for sensing applications,” J .Opt. A:
Pure Appl. Opt., vol. 4, No. 6, pp. S283-S294, 2002.
Tkach, R. and Chraplyvy, A., “Regimes of feedback effects in 1.5-_mdistributed feedback lasers,” IEEE Journal of
Lightwave Technology, vol.4, no. 11, pp. 1655–1661(1986).
Lang, R. and Kobayashi, K., “External optical feedback effects on semiconductor injection laser properties,” IEEE J.
Quantum Electron., vol. QE-16, pp. 347–355(1980).
Fan, Y., Yu, Y., Xi, J. and Chicharo, J. F., “Improving the measurement performance for a self-mixing
interferometry-based displacement sensing system,” Appl. Opt. 50, 5064-5072 (2011)
Weaver, J. B., Xu, Y., Healy .Jr, D. M. and Cromwell, L. D., “Filtering noise from images with wavelet transforms,”
Magn. Reson. Med. vol. 21, no. 2, pp. 288-295(1991).
Xu, Y., Lu, J., Healy, Jr., D. M. and J. B. Weaver, “Filtering MR images with wavelet transforms,” in Proc. 10th
Ann. Mtg. SMRM (San Francisco), p. 199(1999).
J. Lu, Y. Xu, Weaver, J. B. and D. M. Healy, Jr., “Noise reduction by constrained reconstructions in the wavelet
transform domain,” in Proc. 7th IEEE SPS MDSP Workshop (Lake Placid, NY), p. 1.9(1991).
Xu, Y., Weaver, J. B., Healy, Jr., D. M. and Lu, J., “Wavelet transform domain filters a spatially selective noise
filtration technique,” IEEE Trans Image Processing, 3(6) 747-758(1994).
Daubechies, I., [Ten lectures on wavelets], CBMS, SIAM(1994).
Xilinx, [Spartan-3E FPGA Starter Kit Board User Guide], (2008).
Yu，D.and Dong, H., “ FPGA-based high-speed FIR digital filter design,” [J]. Space Electronics, 2008(2):47-51.
Sun, Y., Yu, Y. and Xi, J., “Wavelet Transform Based Noise Reduction Technique for Self Mixing Signal”,
(submitted to) APOS2012 conference, (2012).

Proc. of SPIE Vol. 8199 819909-7
Downloaded From: http://proceedings.spiedigitallibrary.org/ on 07/28/2013 Terms of Use: http://spiedl.org/terms

