Architecture Design and FPGA Implementation of CORDIC Algorithm for Fingerprint Recognition Applications  by Revathi, P. et al.
 Procedia Technology  6 ( 2012 )  371 – 378 
2212-0173 © 2012 The Authors. Published by Elsevier Ltd. Selection and/or peer-review under responsibility of the Department of Computer Science & 
Engineering, National Institute of Technology Rourkela
doi: 10.1016/j.protcy.2012.10.044 
 
 
 2nd International Conference on Communication, Computing & Security [ICCCS-2012]  
Architecture Design and FPGA Implementation of CORDIC 
Algorithm for Fingerprint Recognition Applications 
aP.Revathi,M.Tech Student,Dept. of ECE,GMRIT,Rajam-532127,India  
bM V Nageswara  Rao, Professor, abG R Locharla , Asst.Prof., Dept. of ECE,GMRIT,Rajam-532127,India* 
Abstract 
Fingerprint recognition is one of the most popular methods used by Biometric identification systems for personnel 
identification. CORDIC algorithm provides wonderful solution to perform the math intensive operations at the cost of few 
components like adder, shifter, multiplexer...Etc. Such math intensive operations are required to perform during the image 
enhancement phase of finger print recognition process.  In this paper CORDIC based architecture is proposed to evaluate 
almost all the trigonometric functions. This is implemented using XILINX ISE 13.2. Performance of the architecture is 
analyzed  in terms of relative error.       
 
© 2012 The Authors. Published by Elsevier Ltd.  
Selection and/or peer-review under responsibility of the Department of Computer Science & Engineering, National Institute 
of Technology Rourkela 
Keywords: FPGA; XILINX 13.2; CORDIC; LUT; FFT; AFIS;Gabor;VerilogHDL; 
1. Introduction 
Fingerprints are completely formed at about seven months of fetus development and finger ridge pattern do 
not change throughout the life of an individual except due to accidents. This property makes fingerprints a very 
attractive biometric identifier.The fingerprint is characterized by minutiae, which are points where a curve track 
finishes, intersect or branches off. Taking a Fingerprint at first we enhanced the quality of that image to make 
the image clearer for easy further operations, because the fingerprint images acquired from sensors or other 
media are not assured with perfect quality. Therefore it is mandate to enhance the raw finger print for 
increasing the contrast between ridges and furrows and for connecting the false broken points of ridges due to 
 
 
* Corresponding  author. Tel.: +91-995-995-7720. 
E-mail address: grlocharla89@gmail.com 
 
Available online at www.sciencedirect.com
© 2012 The Authors. Published by Elsevier Ltd. Selection and/or peer-review under responsibility of the Department of Computer 
Science & Engineering, National Institute of Technology Rourkela Open access under CC BY-NC-ND license.
Open access under CC BY-NC-ND license.
372   P.Revathi et al. /  Procedia Technology  6 ( 2012 )  371 – 378 
insufficient amount of ink, are very useful for keep a higher accuracy to fingerprint recognition. Fast Fourier 
Transform and Gabor Filter are popular for fingerprint enhancement. FFT and Gabor are involves almost 
trigonometric evolutions. Proposed architecture in this paper contributes a CORDIC based module to the image 
enhancement part of AFIS (Automatic Fingerprint Identification System). This module can perform sin, cos, 
arctan, sinh, cosh, arcsinh, arctanh and ex functions. The CORDIC (Coordinate Rotation In Digital Computer) 
algorithm provides very smart solution to evolutes almost all the trigonometric functions with optimal usage of 
the hardware.      
2. Review of CORDIC Algorithm 
CORDIC is a trigonometric algorithm, which computes the trigonometric functions using vector rotations.    
Transformation of the coordinates after rotation is defined by the CORDIC as follows: 
)1...(]2[1
i
iiiii ymdxKx  
)2...(]2[1
i
iiiii xdyKy       
)3(...1 iiii d  
2.1.  Circular functions: ;...3,2,1,0 etci    )221(/1 iiK  )2(tan;
11 iim  
Rotation mode:   ;1;01 otherwiseiifid ;7433.1z  
Vector mode:   ;1;01 otherwiseiyifid  ;7433.1)/(tan 00
1 xy  
2.2. Linear functions: ;...3,2,1,0 etci    ;1iK  
i
im 2;0  
Rotation mode:   ;1;01 otherwiseiifid  1z Vector mode: ;1;01 otherwiseiyifid 00 / xyz  
2.3. Hyperbolic functions: ;,...14,13,13,12...4,4,3,2,1,0 etci    )21(/1 2iiK  )2(
1tanh;1 iim  
Rotation mode: ;1;01 owiifid 1182.1z Vector mode: ;1;01 owiyifid  
;1182.1)/(tanh
00
1 xy  
3. Implementation of CORDIC Algorithm  
Proposed Architecture in this paper is hardware efficient, see Fig 1.   Iteration controller manages the 
pseudo rotations and initialization of ii yx , and iz registers.  En_clk is used to freeze the registers and counters 
when en signal is active low.   
 Table 1. Operating modes of the proposed architecture 
S.No. as at mode Functions performed 
1. 0 0 Rotation sin and cos when  = 0; sinh,cosh otherwise 
2. 0 1 Vector arctan when  = 0; arctanh otherwise 
3. 
4. 
1 
1 
0 
1 
Vector  
N/A 
arcsin when = 0; arcsinh otherwise 
N/A 
 
373 P.Revathi et al. /  Procedia Technology  6 ( 2012 )  371 – 378 
Counter generates the iteration sequence according to  and Arctan ROM provides either )2(tan 1 i or 
)2(tanh 1 i based on . Mux: M1 provides the initial values to be loaded into 0x according to the mode 
described in Table.1. Sign controller generates the signal di according to the mode decided by the control inputs 
as shown in Table.1. Signal di holds logic 1 when id   in equations (1, 2 and 3) has to be -1 and holds logic 0 
otherwise.  
 
 
 
 
 
 
 
 
 
 
 
 
 
Fig. 1. Proposed CORDIC architecture  
4. Performance Analysis   
Performance of the architecture is measured in terms of the relative error. We define the error as the distance 
between the ideal value and the practical value divided by the ideal value: 
)4(.....)()(Re PCCORDICPC FunctionFunctionFunctionerrorlative  
Proposed architecture is implemented in Xilinx ISE 13.2 using Verilog HDL and simulated using ISIM. 
FPGA Simulation outputs are manually taken into MATLAB to compare with theoretical numeric values and 
to compute & plot the relative error in each case, see appendix. A.        
 
 
0.6073 
1.2051 
16 
16 
>>2-i 
16  20 
i 
di di 
>>2-i 
di 
 
   XOR 
y0 
16 
   clk    En Clk 
   4 
  20 
16 
z0 
20  
   En_Clk 
20 
Arch Tan/Tanh 
ROM 
 
zi Counter 
  zi[19] 
 
  
16 
xi yi 
16 
1 
arg 
  yi 
di 
1 
0 
 
at 
at 
16 
arg 
Iteration 
control 
 init 
   done  
   en 
sign 
control 
 {at, as} 
16 
2 
16 
   En_Clk 
M1 
0 
1 
0 
1 
0 
1 0 
1 
0 
1 
M2 
M3 
M4 
 
374   P.Revathi et al. /  Procedia Technology  6 ( 2012 )  371 – 378 
 
 
  
 
 
                                 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Fig.  2. Relative error in the result of following calculations performed by the CORDIC architecture (a) sin ;  ;  (c)sin-1 (arg)   
 
0 10 20 30 40 50 60 70 80 90
0
0.005
0.01
0.015
0.02
0.025
0.03
0.035
0.04
0.045
0.05
theta in degrees, 1 unit = 1 degree
R
el
at
iv
e 
er
ro
r i
n 
si
n 
th
et
a
 
 
Relative error in sin theta
 (a) 
0 10 20 30 40 50 60 70 80 90
0
0.01
0.02
0.03
0.04
0.05
0.06
0.07
0.08
 theta(Angle in degrees), 1 unit = 1 degree
R
el
at
iv
e 
er
ro
r i
n 
co
s 
th
et
a
 
 
Relative error in cos theta
 (b) 
0 5 10 15 20 25 30 35 40 45 50
0
0.02
0.04
0.06
0.08
0.1
0.12
0.14
arg values, 1 unit = 0.02
Re
la
tiv
e 
er
ro
r i
n 
ar
cs
in
 
 
Relative error in arcsin
(c) 
375 P.Revathi et al. /  Procedia Technology  6 ( 2012 )  371 – 378 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
 
 
 
 
 
 
 
 
 
 
 
Fig.  3. Relative error in the result of following calculations performed by the CORDIC architecture (a) arctan(arg);  ;  (c)  
 
 
0 10 20 30 40 50 60 70 80 90 100
0
0.002
0.004
0.006
0.008
0.01
0.012
argument value, 1 unit = 0.02
R
el
at
iv
e 
er
ro
r i
n 
ar
ct
an
 
 
Relative error in arctan
(a) 
0 10 20 30 40 50 60 70
0
0.005
0.01
0.015
0.02
0.025
Theta(Angle in degrees), 1unit = 1degree
R
el
at
iv
e 
er
ro
r i
n 
si
nh
(th
et
a)
 
 
Relative error sinh
(b) 
0 10 20 30 40 50 60 70
0
0.002
0.004
0.006
0.008
0.01
0.012
0.014
0.016
0.018
theta(Angle in degrees), 1unit = 1degree
R
el
at
iv
e 
er
ro
r i
n 
co
sh
(th
et
a)
 
 
Relative error in coshh
(c) 
376   P.Revathi et al. /  Procedia Technology  6 ( 2012 )  371 – 378 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Fig.  4. Relative error in the result of following calculations performed by the CORDIC architecture (a) arcsinh;  (b) arctanh;  (c) ex    
0 5 10 15 20 25 30 35 40 45 50
0
0.002
0.004
0.006
0.008
0.01
0.012
0.014
0.016
0.018
argument, 1unit = 0.0279
R
el
at
iv
e 
er
ro
r i
n 
ar
cs
in
h(
ar
gu
m
en
t)
 
 
Relative error in arcsinh
(a) 
0 5 10 15 20 25 30 35 40 45 50
0
0.05
0.1
0.15
0.2
0.25
argument, 1 unit = 0.0183
R
el
at
iv
e 
er
ro
r i
n 
ar
ct
an
h
 
 
Relative error in arctanh
(b) 
0 10 20 30 40 50 60 70
0
0.002
0.004
0.006
0.008
0.01
0.012
0.014
0.016
0.018
0.02
theta(Angle in degrees), 1 unit = 1degree
R
el
at
iv
e 
er
ro
r i
n 
ex
p
 
 
Relative error in exp
 (c) 
 
377 P.Revathi et al. /  Procedia Technology  6 ( 2012 )  371 – 378 
5. Device Utilization Summery 
Architecture is implemented using Verilog HDL with XILINX ISE 13.2 software.  XC3s500e-4fg320 device 
XST. For RTL schematic of the implementation, see Fig.5.   
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Estimated device utilization summery generated by the XST tool is given in Table 2.   
Table 2. Resource utilization (estimated values for xc3s500e-4fg320 device) summery of the proposed architecture 
Resource Type Used Utilization 
Number of slices 207 4% 
Number of slice flip-flops 123 1% 
Number of LUTs 
Number of bonded IOBs 
386 
94 
4% 
40% 
 
As seen in section.4, performance of the architecture can be appreciated throughout the range specified by the 
algorithm. Proposed architecture can adopt the improved CORDIC techniques without major hardware 
modifications. In addition, latency can also be minimized by applying the pipelined technique to the proposed 
one. Therefore it can be concluded that, proposed CORDIC architecture based IPs can be adopted by the image 
enhancement module of the Automatic Finger print Identification System.  
References 
Ray Andraka. A Survey of CORDIC Algorithms for FPGA based Computers.  Andraka Consulting Group, Inc, North 
 Kingstown, RI02852. 
 
Fig. 5. RTL Schematic of the proposed architecture 
378   P.Revathi et al. /  Procedia Technology  6 ( 2012 )  371 – 378 
Nihel NEJI, Anis BOUDABOUS, Wajdi KHARRAT, Nouri MASMOUDI, TUNISIA. Architecture And Fpga  
 Implementation of  the CORDIC algorithm For Fingerprints Recognition Systems.  2011 8th International Multi-Conference  
 on Systems, Signals & Devices,2011,IEEE. 
P.K. Meher, J. Valls, T.B. Juan, K. Sridharan and K. Maharatna. 50 Years of CORDIC: Algorithms, Architectures and  
 Applications. IEEE Transactions on Circuits And Systems I: regular papers, vol. 56, no. 10, pp. 9, Sept. 2009 M. 
 D.Ercegovac,  and T. Lang. Redundant and On- Line CORDIC: Application to Matrix Triangularization and SVD. 
 IEEE Trans. Comput., vol. 39, no. 6, pp. 725,740, June 1990 
E. Antelo, J. Villalba, J. D. Bruguera, and E. L.Zapata. High performance rotation architectures basedon the radix-4  CORDIC 
 algorithm. IEEE Trans. Comput., vol. 46, no. 8, pp. 855-870, Aug. 1997 
H. Dawid, and H. Meyr. The differential CORDIC  algorithm:constant scale factor redundant implementation without 
 correcting iterations. IEEE Trans. Comput. vol. 45, no. 3, pp.307-318, Mar. 1996 
Mariano López, Enrique Cantó and Mariano Fons, SPAIN. Hardware-Software Co-design of a Fingerprint Image Enhancement 
 Algorithm. 
 Transactions on Computers, Vol. 42, No.7, 1993, pp769-779 
Stefan Lachowicz and Hans-Jorg Pfleiderer. Fast  evaluation of the square root and other nonlinearfunctions in FPGA.4th IEEE 
 international symposium on electronic design, 2008 
Anis BOUDABOUS, Fahmi GHOZZI, M. Wajdi KHARRAT, Nouri MASMOUDI. Function Generator Based CORDIC 
 Algorithm.  Third international conference on systems, signals & devices, vol. 4, March2005 
Gualberto Aguilar, Gabriel Sánchez, Karina Toscano, Mariko Nakano-Miyatake, Héctor Pérez-Meana. Automatic Fingerprint   
 Recognition System Using Fast Fourier Transform and Gabor Filters. Científica Vol. 12 Núm. 1 pp. 9-16, © 2008  
 ESIME-IPN. ISSN 1665-0654. Impreso en México. 
Appendix A.  
A.1. Sample of MATLAB code to generate relative error in sin and cos calculation by the proposed architecture 
 
 
 
 
 
 
 
 
 
A.2. Sample window of ISIM simulation showing the  sin and cos calculation by the proposed implementation 
 
