

# **Enhancing the Dorsal Side of Fingers Using An Image Enhancement Technique with FPGA Output Comparison**

Tan Shu Han<sup>1</sup><sup>1</sup><sup>0</sup><sup>2</sup>, Imran Riaz<sup>1,2</sup><sup>1</sup><sup>2</sup><sup>2</sup>, Ahmad Nazri Ali<sup>\*1</sup><sup>1</sup><sup>2</sup><sup>2</sup>

<sup>1</sup>School of Electrical and Electronic Engineering, Universiti Sains Malaysia, Nibong Tebal, 14300, Penang, Malaysia. <sup>2</sup>Mirpur Institute of Technology, Mirpur University of Science and Technology, Mirpur, 10250, Azad Kashmir, Pakistan.

\*Corresponding Author. ICCDA2023: International Conference on Computing and Data Analytics 2023.

Received 29/12/2023, Revised 19/04/2024, Accepted 21/04/2024, Published 25/05/2024

© 2022 The Author(s). Published by College of Science for Women, University of Baghdad. This is an open-access article distributed under the terms of the <u>Creative Commons Attribution 4.0 International License</u>, which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.

# Abstract

Most of the image enhancement techniques are implemented on CPU and GPU, but there is limited implementation on the FPGA platform. This paper presents a work on an enhancement technique called Histogram Equalization, HE for finger-knuckle images. This project is divided into three phases, which are image acquisition, image enhancement, and evaluation. For image acquisition, a USB webcam is set up as the acquisition device to acquire the image of fingers. For image enhancement, the Histogram Equalization (HE) method is chosen due to the less complex algorithm, especially when evaluating the performance on the FPGA platform. Two processing platforms are considered to complete the study, which are desktop computers that use MATLAB programming and the FPGA DE1-SoC platform. A comparison of the results is carried out between these two processing platforms, where it is found that the results for both platforms have shown identical output in terms of PSNR, which achieved a value of 13.43 dB and MSE with 0.0454.

**Keywords:** Finger-Knuckle-Print (FKP), FPGA, Histogram Equalization (HE), Image Enhancement, Verilog HDL.

# Introduction

Biometric authentication has received significant attention due to its high level of assurance and security. FKP utilizes the crease and texture patterns on the finger knuckles in the recognition process. The global biometric system market is projected to grow from USD 42.9 billion in 2022 to USD 82.9 2027, indicating billion by the increasing significance of biometric authentication<sup>1</sup>. Image enhancement techniques such as Histogram Equalization (HE) have also been explored to improve the accuracy of FKP recognition<sup>2</sup>. For the portable finger vein recognition system based on Xilinx XC7A75T and ARM Cortex-M3 kernel

FPGA using System on Chip (SOC) solution and achieved greater than 97% recognition accuracy<sup>3</sup>. An FPGA-based parallel fingerprint matching with early jump-out control system proposed to accelerate the matching process<sup>4</sup>. A fingerprint matching system using global matching algorithm by implementing Coarse-Grained architecture achieved 9.63 million matches per second<sup>5</sup>.

Researchers have focused on developing efficient algorithms for feature extraction and recognition<sup>6,7</sup>. Even though various existing works showcase the implementation of HE, there are a number of limitations to them. Most of the image enhancement

techniques are implemented on CPU and GPU by using MATLAB and Python. Hence, FPGA-based systems need to be explored to achieve low latency, high throughput, and optimized power efficiency. There are limited previous works on the implementation of Histogram Equalization on the FPGA platform by using Verilog HDL. Aside from having a clear image for the FKP recognition process, a standard image of the dorsal side of the finger acquisition system is very important. A typical image acquisition device should be included with a camera from a fixed distance and try to avoid misplacement of the fingers. The main contributions of this research work are summarized as: (i) An acquisition system is developed that can capture multiple images of dorsal side fingers at once. (ii) The image enhancement technique applied using MATLAB, where this approach aims to evaluate the effectiveness of the algorithm in terms of showing the appropriate image output after the enhancement process. On the FPGA platform, the approach is suggested to evaluate and compare the result when the same algorithm is applied on a hardware-based platform. (iii) Experiments are performed using a real-time self-collected dataset and compared the results of image enhancement from MATLAB with the FPGA platform for the HE algorithm.



Histogram Equalization (HE) is widely used in various fields, including thermal imaging, speech recognition, and radiology. In HE, the difference between objects and background is enlarged by expanding the pixels with significant gray value occurrences to adjacent gray level pixels, and the pixels with minor gray quantity occurrences are squeezed. Authors applied a parallelism approach for local histogram equalization using FPGA and achieved faster image enhancement compared to other conventional methods<sup>8</sup>. Alsuwailem and Aishebeili introduced a unique FPGA-based design for real-time histogram equalization. The design employs non-traditional approaches to compute histogram statistics and equalization in parallel. Counters are used in conjunction with a decoder explicitly created for this reason. The hardware has a low development cost and is faster and more versatile. For a  $256 \times 256$  image, the total time required to execute histogram equalization is 0.262 ms<sup>9</sup>.

Table 1 shows a summary of the comparison of related works in terms of the strengths and limitations of the image acquisition system. In contrast, Table 2 shows an overview of the comparison of related works in terms of strengths and limitations for image enhancement on FPGA.

| <b>_</b>                                         | 8 1 7                          |                          |
|--------------------------------------------------|--------------------------------|--------------------------|
| Methodology                                      | Strength                       | Limitations              |
| Wooden case with camera <sup>10</sup>            | High efficiency in collecting  | Misplacement and finger  |
|                                                  | many images                    | rotation may occur       |
| A finger-knuckle-print acquisition device with a | Prevent misplacement and wrong | High cost and low        |
| triangular block <sup>11</sup>                   | pose of finger                 | efficiency in collecting |
|                                                  |                                | many images              |
| Dorsal finger crease image collection with Logi- | User friendly for image        | Low cost and requires    |
| Tech pro-webcam <sup>12</sup>                    | acquisition                    | efficient pre-processing |
|                                                  |                                | techniques               |

| Tah  | le 1. | Com  | narison          | of  | different | image | acquisition  | systems |
|------|-------|------|------------------|-----|-----------|-------|--------------|---------|
| 1 au | лс 1. | COLL | <b>Jai 15011</b> | UL. | unititutu | mage  | acquistition | Systems |

| Table 2. | Comparison | of related works | on image enhance | ement on FPGA |
|----------|------------|------------------|------------------|---------------|
|          |            |                  |                  |               |

| Methodology                                       | Strength                                                             | Limitations                                                         |
|---------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------|
| HE, AHE, CLAHE on CPU <sup>13</sup>               | Shows that CLAHE is the most suitable technique in general condition | Lower performance<br>compared to FPGA                               |
| Brightness manipulation, threshold operation, and | Implement on FPGA by Verilog                                         | Not an image                                                        |
| invert operation on FPGA <sup>14</sup>            | HDL                                                                  | enhancement technique<br>that improves the<br>contrast of the image |
| HE on Zynq FPGA <sup>15</sup>                     | Implement on FPGA                                                    | Rely on Vivado high<br>level synthesis tool                         |
| CLAHE on FPGA <sup>16</sup>                       | Speedup of about 3.67 times for                                      | Rely on HLS                                                         |
|                                                   | 512×512 images and a speedup of                                      |                                                                     |
|                                                   | about 2.98 times for 1920×1080                                       |                                                                     |
|                                                   | images in FPGA.                                                      |                                                                     |

#### **Materials and Methods**

In this section the proposed methodology is discussed which involves three stages consisting of: (i) development of dorsal side fingers image acquisition, (ii) image enhancement, (iii) and performance evaluation. The overall process of the system is summarized as shown in the flowchart in Fig. 1. In the first stage, the acquisition system is developed with an appropriate camera distance between the camera and the plate for locating the fingers. At this stage, a Python module is developed to capture dorsal side finger images and extract the region of interest. In the second stage, image enhancement techniques are employed and coded using MATLAB. On the FPGA platform, the image is first converted into HEX format and uploaded to the FPGA board for performing the HE algorithm. The output of the processed HE, which is also in HEX format, is exported to MATLAB for producing the image output. The last phase involves evaluating the enhanced images by calculating MSE and PSNR and comparing results between MATLAB and FPGA implementations.

#### Hardware and software setup

The hardware resources used in this project are a USB webcam and a DE1-SoC development board. A



2K HD webcam with panoramic high definition 2560  $\times$  1440p resolution is used. The image sensor used is CMOS, while the frame rate is 30fps. This camera is used in the image acquisition system to capture the image of the dorsal side of the fingers. The proposed system is developed on an FPGA board named the DE-SoC development board. The FPGA device in this board is Cyclone V SoC 5CSEMA5F31 device. The software resources used in this project are Python, MATLAB, ModelSim, and Quartus Prime. Python module with OpenCV library is used in the image acquisition system to control the webcam and pre-process the images captured. MATLAB is used to verify the algorithm before implementing it on the FPGA board as it is relatively simple compared to coding in Verilog. Model Sim is used to verify the Verilog modules as the internal signal of the system can be observed in the waveform. Quartus Prime is used to design and program the algorithm onto the FPGA board. FPGA is implemented using Verilog due to fast processing in term of algorithm. Therefore, with finger knuckle print authentication that need fast response, it contributes better platform in implementing finger knuckle authentication system.





Figure 1. Flowchart of the proposed work

#### **Image acquisition**

In the first stage, the image acquisition device is built to capture the image of the dorsal side of the fingers. The camera lens is then placed on the box that has its upper side open. On the lower side of the box, a guideline is drawn so that the finger can align the finger-knuckle with it. Fig.2 shows the entire image acquisition device with the webcam and the procedure. A Python module controls the webcam to capture images. For this study, ten images are captured with limited rotation of the finger to obtain the correct location of the region of interest.



# Figure 2. Proposed Image acquisition device Image enhancement

The images are converted into grayscale before performing the image enhancement algorithms. For image enhancement implementation on FPGA, a Verilog code for the HE is written, in which Fig. 3



shows the block diagram of HE modules after performing the algorithm. In this study, Verilog is written directly without using any existing modules. Compared to the previous study, most of the research has used VHDL modules using HDL coder or HLS. In implementing the HE on FPGA, the intel format hex is uploaded into the RAM of the FPGA board. The image data in HEX format is processed with the Histogram Equalization Verilog module. The processed data is also in hexadecimal value, and the data is written in a text-based format file. The text file is then transferred into MATLAB for converting it into an image again. The output image is then compared to the original image. The intel hex format file is imported into the FPGA RAM by using the In-System Memory Content Editor. To perform the image enhancement on FPGA, the FPGA board is connected to the desktop computer. The SRAM Object File as .sof file is selected and programmed to the board. The image data is imported to the RAM1. The second RAM (ram2) is then selected and acquires the data continuously from the RAM to the content editor. Then, the HE algorithm is performed. When the process of HE is finished, the new data values are shown in the memory content editor. The data is the enhanced image content that is ready to be exported, which is also in a hex file. The extracted hexadecimal values are then processed to convert into images in the MATLAB platform.



Figure 3. Block diagram of image enhancement using FPGA

#### **Performance evaluation metrics**

The data analysis is carried out in the evaluation phase for the result of the image enhancement process. The image enhancement algorithms are evaluated by calculating the Peak signal-to-noise ratio (PSNR) and Mean Square Error (MSE). In the evaluation phase, the MSE and PSNR modules are written in MATLAB code. The PSNR value is calculated by using Eq. 1:

$$PSNR = 10 \log_{10} \left( \frac{R^2}{MSE} \right)$$
 1

R is the maximum variation in the input image data. For example, if it has an 8-bit data type, R is equal to 255. MSE is the mean square error, which is calculated by Eq. 2:

$$MSE = \frac{\sum_{M,N} [I_1(m,n) - I_2(m,n)]^2}{M,N}$$
 2



Here,  $I_1$  is the original image,  $I_2$  is the enhanced image, while M and N are the height and width of the

# **Results and Discussion**

This section discusses the assessment that has been made from the discussed methodology. For the ROI determination, only manually performed it by setting the coordinated for four ROI points, as shown in Table 3. After that, the ROI image is resized into  $151 \times 133$  pixels purposely to reduce the computation time, particularly on the FPGA platform. An example of the image after performing the ROI process is shown in Fig. 4.

image, m and n represent the pixel of the image in rows and columns.

| Table 3. | Coordinate | values | for | region | of | interest |
|----------|------------|--------|-----|--------|----|----------|
| (ROI) po | oints      |        |     |        |    |          |

| ROI Points | Coordinates |  |  |
|------------|-------------|--|--|
| X1         | 370         |  |  |
| <b>X</b> 2 | 432         |  |  |
| <b>y</b> 1 | 260         |  |  |
| <b>y</b> 2 | 350         |  |  |



Figure 4. Sample images of the extracted ROI

The ROI is then converted into grayscale and then converted into hex data by using the Python PIL library. The output hexadecimal values are stored in a new file with the image filename plus 'hex' in a text file (e.g., c1\_hex.txt). There are a total of 20083 lines to store the information of the image as the image size is  $151 \times 133$  pixels. The output text file is then loaded into the Python module again to convert it into Intel hex format, as in Fig. 5.

|       | - |               |  |
|-------|---|---------------|--|
| 20072 |   | :014E67008AC0 |  |
| 20073 |   | :014E68008BBE |  |
| 20074 |   | :014E69008DBB |  |
| 20075 |   | :014E6A008DBA |  |
| 20076 |   | :014E6B008CBA |  |
| 20077 |   | :014E6C008BBA |  |
| 20078 |   | :014E6D008BB9 |  |
| 20079 |   | :014E6E008AB9 |  |
| 20080 |   | :014E6F008AB8 |  |
|       |   |               |  |

Figure 5. Intel hex format file Image enhancement on FPGA

In FPGA, Model Sim is used to verify the modules before implementing them on the FPGA board. Fig. 6 shows the simulation result of the test bench module of HE. The first input is set, reset, and wr as 1, and the rest remain 0. This activates the process of moving the input data into a RAM with a new address that cancels the delay. The second set of input is to set, reset, rd, and wr1 to 1 to activate the data count module. Then, reset, rd1, and wr2 are set to 1 to calculate the cumulative value. The following input is to set reset, rd2, and wr3 to 1 to perform the calculation of CDF. The last set of information is to set reset, rd, and rd3 to 1 to map the equalized data to the pixel of the image. The HE modules are validated through this simulation. The visual comparison of the enhanced image on FPGA with the original image is shown in Fig. 7.





Figure 6. FPGA Simulation result



Figure 7. Visual comparison of FPGA enhanced image with the original image

As shown in Fig. 7, the image is enhanced, and the finger-knuckle-print can be seen more clearly compared to the original image. In short, the image enhancement algorithm HE is successfully being implemented on the FPGA board. It is found that the quality of the image after performing the HE algorithm is improved. However, there are also some limitations to this methodology. By using on-board memory IP in Quartus, the data stored in the RAM is read address by address. This may require more processing units in designing the Verilog module if a

more complex algorithm than HE is chosen to be processed on FPGA.

#### Image enhancement on MATLAB

In this phase, a similar HE algorithm is performed and written in MATLAB. The original images are loaded into the modules and are changed into grayscale images. The output image is saved as a bitmap image and displayed in a subplot together with the original grayscale image, as in Fig. 8 for the HE method.





Figure 8. Comparison of HE image with the original image



Figure 9. Histogram of the original image and HE image

Compared to the original image, the finger-knuckleprint is more apparent where it can be seen that after applying HE, the histogram of the image has a more uniform distribution of pixel intensities, as shown in Fig. 9. There is a broader range of intensities being utilized as the peaks and valleys have been flattened. The redistribution of the pixels enhanced the overall contrast of the image and improved the visual appearance of the image. In Fig. 9, the histogram presents a more balanced distribution of the pixel intensities, resulting in a better utilization of the available intensity range. The histogram also displays a more significant peak, indicating the presence of distinct intensity levels in the image.

In the phase of evaluation, the values of MSE and PSNR are compared for each image enhancement algorithm on each platform. The higher the PSNR value, the better the quality of the image is preserved.

# Conclusion

In conclusion, the research objectives of this project have been achieved. A dorsal side of the finger image with different image enhancement methods has been

| Table 4. | Table | of M | ISE | and | PSNR | values | for | each |
|----------|-------|------|-----|-----|------|--------|-----|------|
| output i | mage  |      |     |     |      |        |     |      |

| Image<br>enhancement | MSE    | PSNR<br>(dB) |
|----------------------|--------|--------------|
| FPGA - HE            | 0.0454 | 13.43        |
| MATLAB - HE          | 0.0454 | 13.43        |

As shown in Table 4, the MSE value of the FPGA implementation of HE and the MSE value of MATLAB implementation are the same, which is 0.454. The PSNR value for the FPGA implementation is also the same as in MATLAB (13.43dB). This verified that HE can be implemented on FPGA by using proper Verilog modules instead of using HLS.

applied and assessed on both MATLAB and the FPGA platform. From the result, it is found that the chosen technique can be used particularly on the

FPGA platform with appropriate consideration in terms of converting the image into a specific format that can be processed on the FPGA platform without using the HLS. The current research work focused only on image enhancement techniques with FPGA

# Acknowledgment

Acknowledgment to the Ministry of Higher Education Malaysia for the Fundamental Research Grant Scheme with Project Code:

# **Authors' Declaration**

- Conflicts of Interest: None.
- We hereby confirm that all the Figures and Tables in the manuscript are ours. Furthermore, any Figures and images, that are not ours, have been included with the necessary permission for republication, which is attached to the manuscript.
- No animal studies are present in the manuscript.

# **Authors' Contribution Statement**

T. S. H., A. N. A. and I. R. designed and conceptualized the study. T. S. H. performed the experiments for data collection, image enhancement and performed analysis. T. S. H. and I. R. performed

#### References

- 1. Global biometric payments market analysis 2018-2027. Ltd, R.N.P.
- Hana FM, Maulida ID. Analysis of contrast limited adaptive histogram equalization (CLAHE) parameters on finger knuckle print identification. J Phys Conf Ser. 2021 Feb; 1764(1): 12049. https://dx.doi.org/10.1088/1742-6596/1764/1/012049
- Li J, Yang W, Shi Y, Nie Z. Design of Finger Vein Recognition SOC Based on FPGA. In: 2020 7th International Conference on Information Science and Control Engineering (ICISCE) . 2020; p. 2385–9. https://doi.org/10.1109/ICISCE50968.2020.00468
- Jiang RM, Crookes D. FPGA-based minutia matching for biometric fingerprint image database retrieval. J Real-Time Image Process . 2008; 3(3): 177–82. <u>https://doi.org/10.1007/s11554-008-0079-8</u>
- Xu J, Jiang J, Dou Y, Shen X, Liu Z. Coarse-Grained Architecture for Fingerprint Matching. ACM Trans Reconfigurable Technol Syst. 2015 Dec; 9(2): 1-15 <u>https://doi.org/10.1145/279129</u>
- Radhi AM, Mohammed SA. Enhancement Ear-based Biometric System Using a Modified AdaBoost Method. Baghdad Sci J . 2022; 19(6): 1346.

implementations and in future the plan is to develop a complete FPGA based biometric system from data collection to final matching stage with larger database.

FRGS/1/2021/ICT02/USM/02/1 for the financial support of this research.

- The images used in this study are acquired through approval ethical protocol with the study protocol code USM/JEPeM/21100657.
- Ethical Clearance: The project was approved by the local ethical committee at Universiti Sains Malaysia, Malaysia.

simulations experiments. T.S.H. and I.R. wrote the paper with input from all authors. I.R., and A.N.A. reviewed and edited the paper.

https://doi.org/10.21123/bsj.2022.6322

- AL-Jumaili ASA, Tayyeh HK, Alsadoon A. AlexNet Convolutional Neural Network Architecture with Cosine and Hamming Similarity/Distance Measures for Fingerprint Biometric Matching. Baghdad Sci J. 2023; 20(6(Suppl.)): 2559. https://doi.org/10.21123/bsj.2023.8362
- Jamro E, Wielgosz M, Wiatr K. FPGA Implementaton of Strongly Parallel Histogram Equalization. In: 2007 IEEE Design and Diagnostics of Electronic Circuits and Systems. 2007; p. 1–6. https://doi.org/10.1109/DDECS.2007.4295260
- Alsuwailem AM, Alshebeili SA. A new approach for real-time histogram equalization using FPGA. In: 2005 International Symposium on Intelligent Signal Processing and Communication Systems. 2005; p. 397–400.

https://doi.org/10.1109/ISPACS.2005.1595430

 Heidari H, Chalechale A. Biometric authentication using a deep learning approach based on different level fusion of finger knuckle print and fingernail. Expert Syst Appl. 2022; 191: 116278. https://doi.org/10.1016/j.eswa.2021.116278



- 11. Anbari M, Fotouhi AM. Finger knuckle print recognition for personal authentication based on relaxed local ternary pattern in an effective learning framework. Mach Vis Appl . 2021; 32(3): 1–11. https://doi.org/10.1007/s00138-021-01178-6
- Riaz I, Ali AN, Ibrahim H. Circular shift combination local binary pattern (CSC-LBP) method for dorsal finger crease classification. J King Saud Univ Comput Inf Sci . 2023; 35(8): 101667. https://doi.org/10.1016/j.jksuci.2023.101667
- 13. Liu J, Zhou X, Wan Z, Yang X, He W, He R, et al. Multi-Scale FPGA-Based Infrared Image Enhancement by Using RGF and CLAHE. Sensors. 2023; 23(19): 8101(1-24) https://doi.org/10.3390/s23198101
- 14. Chiuchisan I, Cerlinca MC, Potorac AD. Image Enhancement Methods Approach using Verilog

Hardware Description Language. 11<sup>th</sup> international conference on development and application systems Suceava, Romania; 2012. pp. 144-8..

- 15. Soma P, Sravanthi C, Srilakshmi P, Jatoth RK. Implementation of Single Image Histogram Equalization and Contrast Enhancement on Zynq FPGA. Advances in Communications, Signal Processing, and VLSI. Singapore: Springer Singapore; 2021. p. 75–82. <u>https://doi.org/10.1007/978-981-33-</u> 4058-9 7
- 16. Honda K, Wei K, Arai M, Amano H. CLAHE implementation on a low-end FPGA board by highlevel synthesis. In: 2020 Eighth International Symposium on Computing and Networking Workshops (CANDARW). 2020. p. 282–5. <u>https://doi.org/10.1109/CANDARW51189.2020.0006</u> 1

# تحسين الجانب الظهري للأصابع باستخدام تقنية تحسين الصورة من خلال مقارنة مخرجات FPGA

# تان شو هان $^{1}$ ، عمران رياض $^{1\cdot 2}$ ، أحمد نظري علي $^{1}$

1كلية الهندسة الكهربائية والإلكترونية، جامعة سينز ماليزيا، نيبونج تيبال، 14300، بينانج، ماليزيا. 2معهد ميربور للتكنولوجيا، جامعة ميربور للعلوم والتكنولوجيا، ميربور، 10250، آزاد كشمير، باكستان.

#### الخلاصة

يعرض هذا البحث عملاً على تقنية تحسين تسمى معادلة الرسم البياني، HE لصور مفصل الإصبع. وينقسم هذا المشروع إلى ثلاث مراحل، وهي الحصول على الصور، وتحسين الصورة، والتقييم. للحصول على الصور، يتم إعداد كاميرا ويب USB كجهاز الحصول على صورة الأصابع. لتحسين الصورة، يتم اختيار طريقة معادلة الرسم البياني ( (HEسبب الخوارزمية الأقل تعقيدًا، خاصة عند تقييم الأداء على منصة .FPGA ماعتبار منصتي معالجة لإكمال الدراسة، وهما أجهزة الكمبيوتر المكتبية التي تستخدم برمجة MATLAB ومنصة .com منصابع المورة، والتقارية النتائج بين منصتي المعالجة هاتين، حيث وجد أن النتائج لكلا المنصتين أظهرت مخرجات متطابقة من حيث PSNR، والتي حققت قيمة 13.43 ديسيبل وMSE بقيمة MSE.

الكلمات المفتاحية: بصمة مفصل الإصبع (FKP)، FPGA، معادلة الرسم البياني (HE)، تحسين الصورة، Verilog HDL.