The preprocessing of iris images is a crucial step in the proposed methodology; without it, the method may diverge or yield inconsistent results. It corresponds to the part where we take an image from the HDBIF Dataset and transform it using many algorithms to make it suitable for BSIF iris recognition.
  4.2. Iris Parameters Extraction (Radius, Center)
Obtaining the main parameters of the eye, including its edges, is primordial to extract and unwrap the iris correctly. For that, we will use the Canny algorithm and the Hough transform.
The Canny algorithm [
7], a renowned method in edge detection, identifies precise edges within the image, a critical step for accurate feature extraction. This algorithm not only takes into account the gradient magnitude and direction but also facilitates the extraction of edges with basic functions.
After applying the Canny algorithm, the binary thresholding of the edge image is conducted to isolate significant edge features. The resulting binary image undergoes circle detection executed by the Hough Transform. It is worth noting that there are two variations of the Hough Transform, one designed for lines and another for circles [
13]. For the purpose of this study, our focus will be exclusively on circle detection. The Hough Transform, tailored to identify circular shapes in images, is pivotal in detecting the circular boundaries of both the iris and pupil, as well as the iris and sclera. The Hough transform method, as implemented in the Matlab native function imfindcircles, utilizes specific parameters including sensitivity and the radius range of the circles to detect.
The Canny approach effectively identifies potential boundaries of these anatomical features, considering factors like the partial visibility of the iris due to eyelids or eyelashes, and the typically full visibility of the pupil. Consequently, a higher sensitivity setting is used for detecting the iris circle to account for its possible partial appearance in the image. Detected circles are then visualized on the image with different colors, indicating the boundaries between the iris and pupil, and the iris and sclera. The function also calculates the central coordinates of the iris and determines its inner and outer radii based on the detected circular boundaries.
The gradient magnitude and direction are calculated as usual, as detailed below. Let us consider a 2D isotropic Gaussian filter 
 of standard deviation 
 as in Equation (
1):
 represent the pixel coordinates in the image. First, the smoothed image 
 is obtained by convolution of the original image 
I with the Gaussian 
. Then, the image derivatives 
 and 
 are computed along the 
x and 
y axis in Equation (
2).
        
∗ represents the convolution product. The gradient magnitude 
 and its direction 
 are computed in Equation (
3).
        
Finally, the edges are extracted by computing non-maxima suppression in the gradient direction before applying a threshold to obtain binary images, as illustrated in 
Figure 3b.
In the presented experiments, the Gaussian smoothing in the Canny algorithm takes a standard deviation parameter of .
The Hough transform detects circles by using the equation of a circle with center 
 and a radius of 
R. The equation of a circle is represented in Equation (
4).
        
Our approach innovatively extracts the main parameters of the iris using the Iris Parameters Extraction Algorithm detailed in Algorithm 1. This algorithm introduces several advanced image processing steps to ensure high precision and robustness in iris detection. Initially, adaptive Gaussian and median filtering are applied to enhance image quality by reducing noise while preserving crucial details. This is followed by dynamic histogram normalization to adjust image contrast for better edge detection. For the edge extraction process, we employ the Sobel operator which calculates the gradient magnitude and direction at each pixel, ensuring accurate edge detection by highlighting regions with high spatial frequency. This step is critical as it forms the basis for subsequent edge detection and refinement processes. The algorithm then applies directional non-maximum suppression (NMS) to precisely identify true edge points by suppressing non-maximum gradients. Adaptive thresholding is used to employ local image contrast for more accurate edge detection under varying lighting conditions. Finally, morphological closing is performed to reinforce circular outlines, which is crucial for accurate circle detection.
These steps culminate in the Hough Transform applied for precise pupil and iris detection, even under challenging conditions with partial occlusions from eyelashes or varying illumination. As shown in 
Figure 3c, the inner and outer circles, marked in blue and red, respectively, have centers that are equal to within a few pixels, as defined in the code by a margin of error: 
. This robust detection process distinguishes our method by significantly improving the accuracy and consistency in extracting iris parameters.
        
| Algorithm 1 Iris parameters extraction | 
| Input:     HDBIF database image imgOutput:     Iris inner and outer radius rint, rout     Circles center coordinates (xint, yint), (xout, yout)
 1:Image smoothing using Gaussian and median filters2:Histogram normalization3:Gradient calculation with Sobel operator4:Apply directional Non-Maximum Suppression (NMS)5:Adaptive thresholding based on local image contrast6:Deleting non-circular components7:Morphological closing     ▹ Reinforce circular outlines8:Hough transform for pupil detection9:if  then  ▹ Pupil and image center distance tolerance10:    if  then11:        12:        13:    else14:        Increase sensitivity and repeat detection15:    end if16:end if17:Crop the image according to pupil size     ▹ Keep iris and avoid error detection18:Hough transform for iris detection19:if  then  ▹ Iris and pupil center distance tolerance20:    if  then21:        22:        23:    else24:        Increase sensitivity and repeat detection25:    end if26:end if27:if max sensitivity reached and no iris found then28:    Define  based on iris size estimation29:end if30:Round  and  coordinates     ▹ For future use
 | 
The innovative combination of these techniques ensures that the detected parameters of the iris are precise and reliable, setting a solid foundation for subsequent biometric analysis.
  4.4. Iris Unwrapping
The final script in the preprocessing stage is the unwrapping process. This script transforms the circular iris region into a rectangular form, permitting the application of Binary Statistical Image Features (BSIF) [
8] in the recognition stage. The unwrapping process ensures that the features of the iris are presented in a consistent and analyzable format. In the second part of the process, we will apply a double threshold to the image to create a binarized mask that will define the pixels analyzed by the matching code part of the second module.
Initially, the length of a rectangle, intended to encapsulate the unwrapped iris, is determined based on the iris’s radius. Coordinate arrays are created to define the spatial points of this rectangle. Central coordinates of the eye are specified, and an angle vector is initialized to assist in generating perimetric points, both inner and outer, around the eye’s circumference. These points are then used to create the lines of the rectangle using linear interpolation, showcased in 
Figure 5, effectively unwrapping the iris into a flat, rectangular image. This image is displayed and resized to a new dimension for compatibility with a specific filter.
Furthermore, a mask is constructed by setting thresholds on the pixel values of the iris image, creating a binary representation that highlights certain features of the iris. This mask is visualized, converted to a logical array for filter compatibility, and then stored as an image file. The combination of geometrical calculations, image preprocessing techniques, and visualization tools allows for a comprehensive approach to iris feature extraction and representation.
Each of these scripts, detailed in Algorithm 3, contributes significantly to the preprocessing stage, ensuring that the iris images are optimally prepared for accurate and efficient recognition.
        
| Algorithm 3 Iris unwrapping | 
| Input:     Extracted iris     Inner and outer radius of the iris      Coordinates of the center of the circles Output:     Unwrapped iris      Mask of the unwrapped iris 
 1:Unwrapped iris rectangle: 2:Generation of perimetric points:3:for  to length(rect) do4:    5:end for6:Generation of rectangle lines using interpolation:7:numPoints = 8:for  to length of the rectangle do9:    (, ) ← linspace(, , numPoints)10:    ← linspace(, , numPoints)11:    Linearly interpolate pixel values in positions given by  and 12:    Assign interpolated pixel values to  column in unwrapped iris image 13:end for14:Double thresholding to obtain iris mask:15:Calculate  pixel value of the unwrapped iris image.16:(, ) ← (, )17:Find pixels in unwrapped iris image where  is within threshold range:18:if  <  <  then19:     ← 1.20:end if
 |