Skip to content
forked from Qingbao/iris

Iris Recognition Algorithms Comparison between Daugman algorithm and Hough transform on Matlab

License

Notifications You must be signed in to change notification settings

yuxiwang66/iris

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

iris

Iris Recognition Algorithms Comparison between Daugman algorithm and Hough transform on Matlab.

###DESCRIPTION: Iris is one of the most important biometric approaches that can perform high confidence recognition. Iris contains rich and random Information. Most of commercial iris recognition systems are using the Daugman algorithm. The algorithms are using in this case from open sourse with modification, if you want to use the source code, please check the LICENSE.

###Daugman algorithm:

image

where I(x,y) is the eye image, r is the radius to searches over the image (x,y), G(r) is a Gaussian smoothing function. The algorithm starts to search from the pupil, in order to detect the changing of maximum pixel values (partial derivative).

image

image

###Hough transform:

image

The Hough transform is a feature extraction technique used in image analysis, computer vision, and digital image processing. where (xi, yi) are central coordinates, and r is the radius. Generally, and eye would be modeled by two circles, pupil and limbus (iris region), and two parabolas, upper and lower eyelids

Starts to detect the eyelids form the horizontal direction, then detects the pupil and iris boundary by the vertical direction.

image

image

###NORMALIZATION AND FEATURE ENCODING: From circles to oblong block By using the 1D Log-Gabor filter. In order to extract 9600 bits iris code, the upper and lower eyelids will be processed as a 9600 bits mask during the encoding.

image image image

###MATCHING: Hamming distance (HD): image

where Q and R are subjects to compare, which contains 20x480=9600 template bits and 20x480=9600 mask bits, respectively, in order to calculate by using XOR and AND boolean operators.

###Results: CASIA Iris Image Database(version 1.0) (http://biometrics.idealtest.org/dbDetailForUser.do?id=1): 756 iris images form 108 different subjects. High quality of images by using NIR camera.

Resolution of 320*280.

Totally, 756*755/2=285390 pairs of comparison for each algorithm, 2268 for intra-class comparison and 283 122 for inter-class comparison.

###EER: Daugman algorithm: 0.0157 Hough transform: 0.0500

How to run the program

  1. Download the CASIA Iris Image Database(version 1.0) from (http://biometrics.idealtest.org/dbDetailForUser.do?id=1) (Signup requested)

  2. Read all images and extract features using the read_all_images.m and createiristemplate.m. (Templates created)

  3. The templates of each subject will be saved into template.mat and mask.m after you creating the templates. matching.m then calculating the Hamming distance (HD) for the same subject(intra-class) and different subjects (innner-class) and saving the results into HD_diff.mat(different subjucts) and HD_same.m (same subject), from them you can calculate the EER which is the final performance for each algorithm by using EER_*.m

About

Iris Recognition Algorithms Comparison between Daugman algorithm and Hough transform on Matlab

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • MATLAB 100.0%