Interferogram decodification on Nios II soft-core by Ramos López, Carlos Alberto et al.
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1704~ 
 
Interferogram decodification on Nios II soft-core 
 
Carlos Alberto Ramos López 




Abimael Jiménez Pérez 




Ángel Sauceda Carvajal 




José Antonio Muñoz Gómez 
Universidad de Guadalajara, Independencia Nacional 151, Autlán, Jalisco, 317-382-5010  
jose.munoz@cucsur.udg.mx 
 
Marco Antonio Gurrola Navarro 
Universidad de Guadalajara, Av. Revolución 1500, Col. Olímpica, Guadalajara, Jalisco, 331-378-5900  
marco.gurrola@cucei.udg.mx 
 
José Mireles Jr. García 





This paper describes the implementation of an interferogram decoding system based on 
a Nios II embedded microprocessor. The interferograms are obtained by using the 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1705~ 
 
classical Michelson Interferometer configured as the four step phase shifting profiler. This 
work includes the phase unwrapping solution implemented with the minimum norm 
method and the SoPC architecture developed with C and Verilog languages. The 
processing system was successfully implemented on the Nios II in a Cyclone IV FPGA. 
We found that the system needs an application specific hardware accelerator to improve 
its performance, but regardless this drawback, its capacity to unwrap is similar to other 
state of the art techniques. 
Keywords: interferometry, Nios II soft-core, optical metrology. 
 
1. Introduction 
In modern industry, especially on micromachining, exists a special interest in techniques 
to perform non-destructive testing (NDT). Such techniques are used to evaluate device 
characteristics, such as planicity, manufacturing defects, rigidity, among others. One of 
the NDT methods is based on optical profilometry, a measuring technique that exploits 
the wave nature of light in order to estimate the surface of an object. 
The key part of the optical profilometry is the interference phenomena which exploits the 
detection of phase change due to the path length traveled by two interfering beams. Thus, 
the relative heights in the sample surface are mapped into phase changes in the 
interfering beams, producing an interferogram; similar to the level curves in topography 
science. This interferograms (images) are captured by a CCD (Charge Coupled Device) 
and processed by the Nios II processor. 
In [1] an opto-mechanical technique was used, joining the interferometry data and a 
nanoindentation technique with a Twyman-Green interferometer for cantilever 
characterization, while in [2] the technique used was white light phase shifting 
interferometry for micro-electro-mechanical systems (MEMS) measurement. 
For most interferometry applications a general purpose system is used, to fully implement 
the capture and processing system or to partially do one or more tasks. In [2], the whole 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1706~ 
 
acquisition, processing and display operations were done in a computer, in [3] a computer 
was used for the fringe processing with Fourier, and in [4] general purpose processor was 
used for image acquisition and 3D profile visualization. 
In this paper, a system for decodification of interferograms on a self-contained Nios II 
based architecture is described. The interferograms contain the information of micrometric 
surfaces of MEMS. The Nios II is embedded on a Cyclone IV FPGA on a DE2-115 board. 
 
2. Interferometry system 
In order to measure surfaces using interferometry, an instrument capable of generating 
the interference and capturing the resulting signal is needed. The instrument, called 
interferometer, can be configured in different setups based on what is to be measured [5]. 
For the present project, a Michelson interferometer was used, and its configuration is 
shown on Fig. 1. 
The interferometer has a coherent monochromatic light source, with wave length λ. The 
fractions of reflected light, 𝐼𝐼′(𝑥𝑥, 𝑦𝑦) and 𝐼𝐼′′(𝑥𝑥, 𝑦𝑦), are captured on the CCD camera, yielding 
a spatial distribution of intensities that form the image or interferogram, which is 
mathematically expressed in (1). 
𝐼𝐼(𝑥𝑥, 𝑦𝑦) = 𝐼𝐼′(𝑥𝑥, 𝑦𝑦) + 𝐼𝐼′′(𝑥𝑥,𝑦𝑦) + 2�𝐼𝐼′(𝑥𝑥,𝑦𝑦)𝐼𝐼′′(𝑥𝑥, 𝑦𝑦)cos (𝜙𝜙(𝑥𝑥,𝑦𝑦)) (1) 
The sample information, contained in the ℎ(𝑥𝑥,𝑦𝑦) argument, is part of the optical path 
difference information encapsulated in the 𝜙𝜙(𝑥𝑥, 𝑦𝑦) argument, as shown in (2). The surface 
information can be extracted from (2) since 𝐿𝐿1 and 𝐿𝐿2 are known lengths. 
𝜙𝜙(𝑥𝑥, 𝑦𝑦) = 4𝜋𝜋
𝜆𝜆
(𝐿𝐿1 − (𝐿𝐿2 − ℎ(𝑥𝑥, 𝑦𝑦))) (2) 
  
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1707~ 
 
 
Fig. 1. Michelson interferometer. 
 
Since there are three unknown variables in (1), a technique called phase shifting 
interferometry (PSI) is used to create equations by collecting a series of images with 
different known phases [5]. The use of PSI for the acquisition of four images, 𝐼𝐼1 to 𝐼𝐼4, leads 
to (3), which contains the data of interest [6]. 
𝜙𝜙(𝑥𝑥, 𝑦𝑦) = 𝑡𝑡𝑡𝑡𝑡𝑡−1 �𝐼𝐼4(𝑥𝑥, 𝑦𝑦) − 𝐼𝐼2(𝑥𝑥, 𝑦𝑦)
𝐼𝐼1(𝑥𝑥,𝑦𝑦) − 𝐼𝐼3(𝑥𝑥,𝑦𝑦)� (3) 
At this point the information of the surface has been acquired but has been wrapped by 
the inverse tangent function. In order to get the surface information of the sample, a 
bidimensional phase unwrapping processing must be done on a computational 
architecture. 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1708~ 
 
 
3. Bidimensional phase unwrapping on Nios II 
The wrapping problem, induced by the inverse tangent on (3), refers to the bounding of 
all values of 𝜙𝜙(𝑥𝑥, 𝑦𝑦) on the (−𝜋𝜋,𝜋𝜋] interval. There are several algorithms for phase 
unwrapping, which still is an open problem, depending on the source of interference, level 
of noise, and other parameters. For instance, on [7] two minimum 𝐿𝐿𝑝𝑝 norm were used 
(PUMA and CUNWRAP), while [8] uses optimization with local weight, and [9] uses a 
minimal discontinuity method. 
In this paper a global optimization method based on minimum 𝐿𝐿𝑝𝑝 norm, with 𝑝𝑝 = 2, is used 
[10]. In this case, the minimum square phase unwrapping problem is reduced to the 
solution of the Poisson equation, defined in (4), where 𝜙𝜙 corresponds to the estimated 
resulting image (surface) and 𝜓𝜓 corresponds to the wrapped image obtained with (3). 
𝜙𝜙𝑥𝑥𝑥𝑥 + 𝜙𝜙𝑦𝑦𝑦𝑦 = 𝜓𝜓𝑥𝑥𝑥𝑥 + 𝜓𝜓𝑦𝑦𝑦𝑦 (4) 
Since the problem is on the discrete domain, (4) is discretized with the finite difference 
method for its implementation on Nios II using mirrored boundary conditions and is 
expressed as (5), 
�𝜙𝜙𝑖𝑖+1,𝑗𝑗 − 2𝜙𝜙𝑖𝑖,𝑗𝑗 +  𝜙𝜙𝑖𝑖−1,𝑗𝑗� + �𝜙𝜙𝑖𝑖,𝑗𝑗+1 − 2𝜙𝜙𝑖𝑖,𝑗𝑗 +  𝜙𝜙𝑖𝑖,𝑗𝑗−1� = 𝜌𝜌𝑖𝑖,𝑗𝑗 , (5) 
where 
𝜌𝜌𝑖𝑖,𝑗𝑗 = 𝑊𝑊�𝜓𝜓𝑖𝑖+1,𝑗𝑗 − 𝜓𝜓𝑖𝑖,𝑗𝑗� −𝑊𝑊�𝜓𝜓𝑖𝑖,𝑗𝑗 − 𝜓𝜓𝑖𝑖−1,𝑗𝑗� + 𝑊𝑊�𝜓𝜓𝑖𝑖,𝑗𝑗+1 − 𝜓𝜓𝑖𝑖,𝑗𝑗� −𝑊𝑊�𝜓𝜓𝑖𝑖,𝑗𝑗 − 𝜓𝜓𝑖𝑖,𝑗𝑗−1�, 
and the 𝑊𝑊 operator assures that all values are on the (−𝜋𝜋,𝜋𝜋] interval. The values 𝑖𝑖, 𝑗𝑗 
determine the position of the pixel on a rectangular grid of 𝑀𝑀 columns and 𝑁𝑁 rows, 
respectively. Based on the equation for each pixel on the image, a total of 𝐾𝐾 = 𝑀𝑀 × 𝑁𝑁 
unknows are obtained. All 𝐾𝐾 equations are organized into a linear system of the form 𝐴𝐴𝑥𝑥 =
𝑏𝑏. 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1709~ 
 
Some properties of the resulting 𝐴𝐴 matrix are: square, sparse, large, and non-symmetric. 
A numeric simulation was performed with the numeric methods present at the MATLAB 
software package, test shown in table 1, and the one that yielded best results in terms of 
iterations and memory usage was the stabilized biconjugate gradient (BiCGSTAB). The 
method with less iterations is bicgstab𝑙𝑙, followed by bicgstab, and the qmr-based. 
However, the bicgstab𝑙𝑙 method requires more memory as the 𝑙𝑙 increases (𝑙𝑙 = 2 doubles 
the memory, and 𝑙𝑙 = 1 equals the bicgstab method). Taking into consideration memory 




Iterations at image dimensión 
256x256 512x512 1024x1024 
bicg 844 1633 3191 
bicgstab 604 1169 2940 
bicgstabl 330 573 1331 
cgs 822 1449 3047 
gmres 11325 53455 156660 
lsqr 19020 38063 38991 
minres 935 1872 3578 
qmr 768 1479 2803 
symmlq 1138 2409 4826 
tfqmr 836 1445 2805 
Table 1. Iteration number comparison. 
 
After the numeric method was chosen, the implementation of the algorithm for phase 
unwrapping with application in optical interferometry was made by coding the solution on 
C language and downloading it into the Nios II architecture. The needed numeric 
representation was set at double-precision floating point because the other 
representations, single precision float and fixed point, did not converge to correct solution. 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1710~ 
 
The software architecture, shown in Fig. 2, was coded using the C language. The 
functions include image reading from SD card, creation of wrapped image from four input 
images, calculation of 𝜌𝜌 vector, the numeric solver, and image display on LCD screen. 
 
 
Fig. 2. Software architecture for phase unwrapping system. 
 
The BiCGSTAB algorithm, and functions related to the image acquisition and processing, 
were programmed in C language since the Nios II embedded processor supports most of 
the language standard. The Nios II is contained within an FPGA that has access to other 
peripherals, e.g. RAM memory, Ethernet port, VGA output, and the communication with 
these devices must be made using a hardware description language (HDL). The hardware 
architecture, described with the Verilog HDL, is shown in Fig. 3 and is deployed in a 
TerASIC VEEK-MT (DE2-115) board with an Altera Cyclone IV FPGA. 
 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1711~ 
 
 
Fig. 3. Hardware architecture for phase unwrapping system. 
 
In the figure the most significant operations are described: exchange of information with 
the instructions stack stored at flash memory, data exchange on the RAM for numeric 
operations, read and write operations of image data, and interface with LCD multi-touch 
screen. 
Figures 2 and 3 describe the complete design of a system-on-programmable-chip (SoPC) 




The solution was coded using C language standard and that gives extra flexibility in terms 
of platform compatibility. With minor changes in the code, the tests were made on a DELL 
T7500 workstation with a four-core Intel Xeon E5620 at 2.4GHZ and on the Nios II 
embedded microprocessor on the Cyclone IV FPGA at 50MHz. Table I shows 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1712~ 
 





64x64 128x128 256x256 512x512 
CPU – Intel Xeon 20ms 190ms 2s 15s 
FPGA – Nios II 207s 1712s 14926s 117037s 
Table 2. Time of convergence comparison between CPU and Nios II. 
 
As shown in table 2, the Intel Xeon CPU performed the phase unwrapping thousands of 
time faster, from three to four orders of magnitude. The qualitative result is shown in Fig. 
4, corresponding to three microlenses samples, first row corresponding to the captured 
wrapped image; second row, the unwrapped surface in two-dimensions; and third row, 
surface plotted in 3D. 
 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1713~ 
 
 
Fig. 4. Unwrapped images. 
 
Test 1 and 3 are successfully unwrapped to the expected result, but test 2 contains 
“bumps” since the image was scaled to half its original size and had aliasing. In both 
architectures, Nios II and CPU, the images were unwrapped on the same iteration number 
and yielded the same residual error. 
 
5. Discussion 
As mentioned on the results section, the CPU performs the phase unwrapping 
approximately four orders of magnitude faster when compared to the Nios II based 
architecture. This result is expected since the FPGA implementation is limited to the Nios 
II output, which contains only one 32-bits ALU operating at 50MHz. 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1714~ 
 
Furthermore, the performance is also reduced by the double precision floating point 
operations required by the numeric method. The Nios II is a 32-bit architecture and all the 
64-bits logic is emulated in software, slowing the system overall performance. 
In related works, as [12] and [13], the processing of the phase unwrapping is avoided on 
the FPGA since it would take most logic space, and is discarded as an option given the 
time it would take to design the linear algebra components needed. 
According to the post-synthesis report, an 8% of the total resources of the FPGA logic 
elements were used, most of them in the Nios II. Therefore, a hardware accelerator for 
the BiCGSTAB method is proposed as future work in order to reduce the processing time 
in the Nios II based system. 
 
6. Conclusion 
As demonstrated on this paper, it is possible to create a SoPC for bidimensional phase 
unwrapping applications and reduce the dimensions from a general purpose computer to 
a DE2-115 board. 
The aim of this project is to create a portable system for micrometric surface 
characterization. On this first iteration, the system was taken from CPU to an FPGA board 
with embedded microprocessor. Future work includes hardware accelerators and physical 
synthesis for ASIC manufacturing. 
 
7. Acknowledgements 
This work has been partially supported by the National Council of Science and Technology 
CONACyT-México under grant 2008-106730, scholarship 478010, and F-PROMEP-
38/Rev-03. 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1715~ 
 
8. References 
[1] K. Krupa, M. Józwik, et al., “Static and Dynamic Characterization of AIN-driven 
microcantilevers using optical interference”. Optics and Lasers in Engineering. 
Volume 47. Number 2. 2009. p211-216. 
[2] S. Jorez, A. Cornet, J.-P. Raskin, “MEMS profilometry by low coherence phase 
shifting interferometry: Effect of the light spectrum for high precision 
measurements”. Optics Communications. Volume 263. Number 1. 2006. p6-11. 
[3] K. Bulut, M. Naci, “Three-dimensional optical profilometry using a four-core optical 
fiber”. Optics & Laser Technology. Volume 37. Number 6. 2005. p463-469. 
[4] G.-C. Jin, N.-K. Bao, “Surface detection and 3D profilometry for microstructure 
using optical metrology”, Optics and Lasers in Engineering. Volume 36. Number 1. 
2001. p1-9. 
[5] D. Malacara, Optical Shop Testing. 3rd edition. 2007. John Wiley & Sons. New 
Jersey. 
[6] D. Malacara, M. Servín, Z. Malacara, Interferogram Analysis for Optical Testing. 
2nd edition. 2007. CRC Press. 
[7] N. Syakrani, T. Mengko, A. Suksmono, E. Baskoro, “Comparison of PUMA and 
CUNWRAP to 2-D phase unwrapping”. Electrical Engineering and Informatics. July 
2011. p1-16. 
[8] R. Hsu, S. Chen, A. Jain, C. Mercer, “Local weight selection for two-dimensional 
phase unwrapping”. Proceedings on ICIP 99. Volume 3. 1999. p871-875. 
[9] H. Zhong, J. Tang, D. Liu, “A fast phase unwrapping algorithm based on minimum 
discontinuity by blocking”. Future Computer and Communication (ICFCC) 2010. 
Volume 1. May 2010. p717-721. 
[10] D. Ghiglia, M. Pritt, Two-dimensional phase unwrapping: theory, algorithms, and 
software. 1998. Wiley. Michigan. 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1716~ 
 
[11] P. Chu, Embedded SoPC design with Nios II processor and VHDL examples. 
September 2011. Wiley. 736 pages. 
[12] R. Couturier, S. Domas, G. Goavec-Merou, M. Favre, M. Lenczer, A. Meister, “A 
cost effective AFM setup, combining interferometry and FPGA”. Thermal, 
Mechanical and Multi-Physics Simulation and Experiments in Microelectronics and 
Microsystems (EuroSimE). April 2013. p1-6. 
[13] S. Braganza, Phase unwrapping on reconfigurable hardware and graphics 




Carlos A. Ramos López received the B.S. degree in mechatronics engineering from 
Universidad Autónoma de Chihuahua, Chihuahua, México in 2012. He is currently 
finishing the master degree in electrical engineering from Universidad Autónoma de 
Ciudad Juarez. His research focused on design, synthesis, and simulation of digital 
systems based soft core and hardware description language.  
Abimael Jiménez Pérez received the B.S. degree in electronics engineering from Instituto 
Tecnológico de Oaxaca, Oaxaca, Mexico, in 1999, and the M.S., and Ph.D. degrees in 
electronics engineering from the Instituto Nacional de Astrofísica, Óptica y Electrónica, 
Puebla, Mexico, in 2002 and 2008, respectively, for his work on modeling and simulation 
of Dynamic Threshold MOSFET (DTMOS). From February 2008 to December 2009, he 
worked as a professor at the Centro Universitario de la Costa Sur of Universidad de 
Guadalajara, Jalisco, Mexico. Since January 2010, he has been with Universidad 
Autónoma de Ciudad Juarez, Chihuahua, Mexico, where he is currently a Professor with 
the Department of Electrical and Computer Engineering, Technology and Engineering 
Institute. He has participated in various research projects in the area of modeling and 
simulation of semiconductor devices and design of digital integrated circuits and FPGAs. 
Ángel Sauceda Carvajal received the Ph.D. degree in optics from the Instituto Nacional 
de Astrofísica, Óptica y Electrónica, Puebla, Mexico, in 1999 for his work on the synthesis 
of diffractive optical elements to extend the focal depth of optical systems. Since August 
2012, he has working with the group of Micro-Electro-Mechanical-Systems (MEMS) 
design of Universidad Autónoma de Ciudad Juarez, Chihuahua, Mexico applying Optical 
interferometry to the characterization and testing of MEMS. In the academic field, he is a 
member of Programa de Mejoramiento al Profesorado (PROMEP), and he is also a 
member of the National System of Researchers. 
Pistas Educativas, No. 108, Octubre 2014. México, Instituto Tecnológico de Celaya. 
 
Pistas Educativas Año XXXV   -   ISSN 1405-1249 
Certificado de Licitud de Título 6216; Certificado de Licitud de Contenido 4777; Expediente de Reserva 6 98 92  ~1717~ 
 
José A. Muñoz Gómez received the Ph.D. degree in Computer Science from the Instituto 
Nacional de Astrofísica, Óptica y Electrónica, Mexico. Since February 2008, he has 
worked as a researcher at the Universidad de Guadalajara, Jalisco, Mexico with the 
Engineering Department. He has participated in various research projects in the areas of 
high performance computing, partial differential equations and radial basis functions. His 
interests include scientific computing and technological development. 
Marco A. Gurrola Navarro received the B.S. degree in Communications and Electronics 
and M.S. degree in hearth science from Universidad de Guadalajara, Jalisco, Mexico in 
1997 and 2003, respectively. He received the Ph.D. degree in electronics with 
specialization on Integrated Circuit Design from the Instituto Nacional de Astrofísica, 
Óptica y Electrónica, Puebla, Mexico in 2009. Since 2009, he has been working at the 
Universidad de Guadalajara. His areas of interest are circuit theory for analog 
implementations of the wavelet transform and technological developments of integrated 
circuits SoC. 
José Mireles Jr. García received the B.S. in electronics engineering from Instituto 
Tecnológico de Chihuahua, Chihuahua, México in 1990. Later, he received M.S. degree 
in electronics from Instituto Tecnológico de Chihuahua, Chihuahua, México in 1996. In 
2002, he received the Ph.D. degree in electrical engineering from the University of Texas 
at Arlington (UTA). He is currently a research professor at the Universidad Autónoma de 
Ciudad Juarez, Chihuahua, Mexico. His research interests include the design, fabrication 
and characterization of MEMS, especially in MEMS accelerometers. He also is a consulter 
in the design and manufacture of MEMS. 
