METHOD FOR DETERMINING A MATCH BETWEEN A CANDIDATE FINGERPRINT AND A REFERENCE FINGERPRINT
20220335750 · 2022-10-20
Assignee
Inventors
Cpc classification
G06F21/32
PHYSICS
International classification
Abstract
Provided is a method for determining a match between a candidate fingerprint and a reference fingerprint characterized by minutiae local features. The method includes evaluating a similarity of the candidate fingerprint local feature and the reference fingerprint local feature of a current local feature pair, and determining a match depending on the similarity evaluation and geometric coherence evaluations performed for said current local feature pair. Other embodiments are disclosed.
Claims
1. A method for determining a match between a candidate fingerprint and a reference fingerprint characterized by minutiae local features comprising extracting several minutiae from the candidate fingerprint, computing from said extracted minutiae a plurality of minutiae local features of the candidate fingerprint, for at least one local feature pair, called current local feature pair, among a plurality of local feature pairs comprising each a candidate fingerprint local feature and a reference fingerprint local feature: evaluating the similarity of the candidate fingerprint local feature and the reference fingerprint local feature of the current local feature pair, for each local feature pair of the plurality of local feature pairs other than said current local feature pair, called different local feature pair, evaluating the geometric coherence of the candidate fingerprint local features of the current local feature pair and of the different local feature pair with the reference fingerprint local features of the current local feature pair and of the different local feature pair, determining a match between the candidate fingerprint local feature and the reference fingerprint local feature of the current local feature pair depending on said similarity evaluation and said geometric coherence evaluations performed for said current local feature pair, determining a match between the candidate fingerprint and the reference fingerprint based on matching local feature pairs, depending on the similarity evaluations and geometric coherence evaluations performed for said matching local feature pairs.
2. The method of claim 1, wherein the minutiae local features are a local neighborhood of minutiae.
3. The method of claim 1, wherein the minutiae local features are Delaunay minutiae triangles generated using Delaunay triangulation from extracted minutiae.
4. The method of claim 1, wherein evaluating the geometric coherence comprises: comparing the relative distance and/or the orientation/relative rotation between the candidate fingerprint local features of the current local feature pair and of the different local feature pair with the relative distance and/or the orientation/relative rotation between the reference fingerprint local features of the current local feature pair and of the different local feature pair.
5. The method of claim 4, wherein the local features being Delaunay minutiae triangles: evaluating the similarity of the candidate fingerprint triangle and the reference fingerprint triangle of the current triangle pair comprises: computing a similarity score based on a edge length difference and/or a minutia edge angle difference and/or a minutia type between the candidate fingerprint triangle and the reference fingerprint triangle of the current triangle pair, evaluating the geometric coherence of the candidate fingerprint triangles of the current triangle pair and of the different triangle pair with the reference fingerprint triangles of the current triangle pair and of the different triangle pair comprises: computing a geometric consistency score based on the variation, between the candidate fingerprint and the reference fingerprint, of the distance between the mass centers of the triangles of the current and of the different triangle pairs and/or based on the variation, between the candidate fingerprint and the reference fingerprint, of the relative orientation between the triangles of the current and of the different triangle pairs, determining a match between the candidate fingerprint triangle and the reference fingerprint triangle of the current triangle pair comprises: computing a global coherence weight for the current triangle pair based on said similarity score and said geometric consistency scores computed for said current triangle pair and comparing said computed global coherence weight with a predetermined threshold, determining a match between the candidate fingerprint and the reference fingerprint comprises: computing a final fingerprint matching score based on the similarity scores and global coherence weights of the triangle pairs whose computed global coherence weight is above said predetermined threshold.
6. A computer program product directly loadable into a memory of at least one computer, comprising software code instructions for performing the following steps when said product is run on the at least one computer extracting several minuliae from the candidate fingerprint, computing from said extracted minutiae a plurality of minutiae local features of the candidate fingerprint, for at least one local feature pair, called current local feature pair, among a plurality of local feature pairs comprising each a candidate fingerorint local feature and a reference fingerprint local feature; evaluating the similarity of the candidate fingerprint local feature and the reference fingerprint local feature of the current local feature pair, for each local feature pair of the plurality of local feature pairs other than said current local feature pair, called different local feature pair evaluating the geometric coherence of the candidate fingerprint local features of the current local feature air and of the different local feature pair with the reference fingerprint local features of the current local feature pair and of the different local feature pair, determining a match between the candidate fingerprint local feature and the reference fingerprint local feature of the current local feature pair depending on said similarity evaluation and said geometric coherence evaluations performed for said current local feature pair, and determining a match between the candidate fingerprint and the reference fingerprint based on matching local feature pairs, depending on the similarity evaluations and geometric coherence evaluations performed for said matching local feature pairs.
7. A client device configured for determining a match between a candidate fingerprint and a reference fingerprint characterized by minutiae local features, the device comprising processor a memory couples thereto and an input-output interface coupled thereto configured for: extracting several minutiae from the candidate fingerprint, computing from said extracted minutiae a plurality of minuliae local features of the candidate fingerprint, for at least one local feature pair, called current local feature pair, among a plurality of local feature pairs comprising each a candidate fingerorint local feature and a reference fingerprint local feature; evaluating the similarity of the candidate fingerprint local feature and the reference fingerprint local feature of the current local feature pair, for each local feature air of the plurality of local feature pairs other than said current local feature pair, called different local feature pair, evaluating the geometric coherence of the candidate fingerorint local features of the current local feature pair and of the different local feature air with the reference fingerprint local features of the current local feature pair and of the different local feature pair, determining a match between the candidate fingerorint local feature and the reference fingerprint local feature of the current local feature air depending on said similarity evaluation and said geometric coherence evaluations performed for said current local feature pair, and determining a match between the candidate fingerprint and the reference fingerprint based on matching local feature pairs, depending on the similarity evaluations and geometric coherence evaluations performed for said matching local feature pairs.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0031] The following description and the annexed drawings set forth in detail certain illustrative aspects and are indicative of but a few of the various ways in which the principles of the embodiments may be employed. Other advantages and novel features will become apparent from the following detailed description when considered in conjunction with the drawings and the disclosed embodiments are intended to include all such aspects and their equivalents.
[0032]
[0033]
[0034]
[0035]
[0036]
[0037]
[0038]
[0039]
[0040]
[0041]
DETAILED DESCRIPTION OF EMBODIMENTS OF THE INVENTION
[0042] The invention aims at improving a matching process trying to determine a matching between a candidate fingerprint and a reference fingerprint, both characterized by a set of minutiae and by local features of these minutiae.
[0043] In an embodiment, minutiae local features are a local neighborhood of the minutiae. For example such a local feature may be information about the fingerprint texture around a minutia, or information about the neighboring minutiae.
[0044] In an embodiment, the minutiae local features are Delaunay minutiae triangles generated using Delaunay triangulation from minutiae extracted from the fingerprints. In the rest of the description, it will be assumed that the minutiae local features are Delaunay minutiae triangles, as an example.
[0045] For that purpose, the main idea of the method according to the invention is to take advantage of the fact that the positioning of a local feature of a fingerprint relative to another local feature of the same fingerprint is almost unaffected by fingerprint geometric transformations such as rotation or wrinkling. As a result, when a local feature of a candidate fingerprint is matched to a local feature of a reference fingerprint, erroneous matching may be detected by comparing the positioning of the matched local feature of the candidate fingerprint relative to other local features of the candidate fingerprint with the positioning of the matched local feature of the reference fingerprint relative to other local features of the reference fingerprint. Said differently, when the match is genuine, the relative position of the matched local feature relative to the other local features of the fingerprint is almost the same in the candidate and the reference fingerprint.
[0046] As illustrated on
[0047] The matching device is connected to a storage unit 102 for storing reference fingerprints. This storage unit may be integrated in the matching device. Alternatively, as shown on
[0048]
[0049] The matching device may also include input/output means 207 providing interfaces to an administrator of the matching device, such as one or more screens, loudspeakers, a mouse, tactile surfaces, a keyboard etc. . . . .
[0050] The following paragraphs describe the steps of a method for determining a match between a candidate fingerprint and a reference fingerprint characterized by minutiae local features, performed by the matching device 101 according to a first aspect of the invention as depicted on
[0051] In a first step S1, the matching device extracts several minutiae from the candidate fingerprint. Each minutia may be defined by its coordinates in the fingerprint it is extracted from, by its orientation, and by a type indicating for example whether the minutiae is a ridge ending or a bifurcation.
[0052] In a second step S2, the matching device computes from said extracted minutiae a plurality of minutiae local features of the candidate fingerprint. As described here above, the minutiae local features may be Delaunay minutiae triangles generated using Delaunay triangulation from the extracted minutiae.
[0056]
[0057] In the following paragraphs, minutiae local features are called “local features”; and a set gathering a local feature of a candidate fingerprint and a local feature of a reference fingerprint is called a “local feature pair”.
[0058] The following steps describe the process applied to at least one local feature pair, called current local feature pair, among the plurality of local feature pairs gathering a local feature of the candidate fingerprint and a local feature of the reference fingerprint. Such steps are preferably applied to most of or all of these local feature pairs.
[0059] In a third step S3, the matching device evaluates the similarity of the candidate fingerprint local feature and the reference fingerprint local feature of the current local feature pair.
[0060] When local features are Delaunay minutiae triangles, evaluating the similarity of the candidate fingerprint triangle and the reference fingerprint triangle of the current triangle pair may comprise computing a similarity score based on a edge length difference and/or a minutia edge angle difference and/or a minutia type between the candidate fingerprint triangle and the reference fingerprint triangle of the current triangle pair.
[0061] Such a step may be repeated for all local feature pairs, i.e. such that a similarity score is computed for each triangle of the candidate fingerprint with all the triangles of the reference fingerprint.
[0062] Given two triangles c and r, the similarity score S.sub.t(c,r) may be defined as:
[0063] where S.sub.t.sup.max is a predefined maximum similarity score; C.sub.d, C.sub.α and C.sub.m are feature costs due to feature dissimilarity of two triangles, C.sub.d.sup.max and C.sub.α.sup.max are predefined cost thresholds.
[0064] The function C.sub.d(c,r) computes the edge length difference costs of the triangles, either as absolute values or as a percentage of the total edge length of the reference or candidate triangles, and may be defined as
[0065] where d.sub.i.sup.c and d.sub.i.sup.r are edge length of candidate and reference triangles respectively; THD.sub.i is a predefined maximum allowable edge length difference; C.sub.d.sup.u is a unit cost of edge length difference.
[0066] The function C.sub.α(c,r) computes the minutia edge angle difference costs of the triangles:
[0067] where α.sub.i.sup.c and α.sub.i.sup.r may for example be the mean of minutia edge angles at triangle's vertices of candidate and reference triangles respectively; THD.sub.α is the maximum allowable edge length difference; C.sub.α.sup.u is the unit cost of minutia edge angle difference.
[0068] C.sub.m(c,r) computes a minutiae type difference cost defined as:
C.sub.m(c,r)=sum.sub.i=1,2,3{I(m.sub.i.sup.c,m.sub.i.sup.r)×C.sub.m.sup.u}
[0069] where I(m.sub.i.sup.c,m.sub.i.sup.r) is the identity function, C.sub.m is the unit cost of minutiae type mismatch.
[0070] Examples of similarity scores computed from the Delaunay triangles of
[0071] Using such formulas, when two triangles of a triangle pair are similar, their similarity score is high. On the other hand, when they are not similar, their similarity score is low or zero.
[0072] At the end of this step, a triangle of the candidate fingerprint may have a high similarity score with several triangles of the reference fingerprint. On the other hand, some triangle of the candidate fingerprint may have only null similarity scores with all the triangles of the reference fingerprint.
[0073] In a fourth step S4, the geometric coherence of the current local feature pair with the other local feature pairs is checked. In order to do so, the matching device repeatedly selects the current local feature pair and another local feature pair and checks if the relative position of the two local features is the same in the candidate fingerprint and in the reference fingerprint. More precisely, the matching device evaluates for each local feature pair other than the current local feature pair, called different local feature pair, the geometric coherence of the candidate fingerprint local features of the current local feature pair and of the different local feature pair with the reference fingerprint local features of the current local feature pair and of the different local feature pair.
[0074] Such a geometric coherence evaluation of two local features in the candidate finger print versus two local features in the reference fingerprint may include comparing the relative distance or relative orientation of the two local features in the candidate fingerprint with the relative distance or relative orientation of the two local features in the reference fingerprint. More precisely, it may comprise comparing the relative distance and/or the orientation/relative rotation between the candidate fingerprint local features of the current local feature pair and of the different local feature pair with the relative distance and/or the orientation/relative rotation between the reference fingerprint local features of the current local feature pair and of the different local feature pair.
[0075] When the local features are Delaunay triangles, such a geometric coherence evaluation may include computing a geometric consistency score based on the variation, between the candidate fingerprint and the reference fingerprint, of the distance between the mass centers of the triangles of the current and of the different triangle pairs and/or based on the variation, between the candidate fingerprint and the reference fingerprint, of the relative orientation between the triangles of the current and of the different triangle pairs.
[0076] For example, if we consider a first triangle pair TP.sub.i,u composed of a triangle i in the candidate fingerprint and a triangle u in the reference fingerprint, and a second triangle pair TP.sub.j,v composed of a triangle j in the candidate fingerprint and a triangle v in the reference fingerprint, a geometric consistency score S.sub.g(TP.sub.i,u,TP.sub.j,v) for these two triangle pairs may be defined as:
S.sub.g(TP.sub.i,u,TP.sub.j,v)=S.sub.dp(TP.sub.i,u,TP.sub.j,v)+S.sub.op(TP.sub.i,u,TP.sub.j,v)
and S.sub.g=max(S.sub.g.sup.min,S.sub.g)
where S.sub.g.sup.min is a minimum value of the geometric consistency score.
In this formula, S.sub.dp(TP.sub.i,u,TP.sub.j,v) is a distance consistency score which may be defined as:
S.sub.dp(TP.sub.i,u,TP.sub.j,v)=S.sub.dp.sup.max−DP.sup.d(TP.sub.i,u,TP.sub.j,c)×C.sub.dp.sup.u
and S.sub.dp=max(S.sub.dp.sup.min,S.sub.dp)
[0077] where S.sub.dp.sup.max and S.sub.dp.sup.min are predefined maximum and minimum S.sub.dp scores respectively; C.sub.dp.sup.u is the unit cost of distance difference; and DP.sup.d(TP.sub.i,u,TP.sub.j,v) is a distance difference of the two triangle pairs, which may be defined as
DP.sup.d(TP.sub.i,u,TP.sub.j,v)=abs(d.sub.ij.sup.c−d.sub.uv.sup.r)
[0078] with d.sub.ij.sup.c the distance between the mass centers of the triangles i and j in the candidate fingerprint and d.sub.uv.sup.r the distance between the mass centers of the triangles u and v in the reference fingerprint.
[0079] When the triangles of the current local feature pair truly match and the triangles of the different local feature pair also truly match, the distance between the two local features should be almost the same in the candidate fingerprint and in the reference fingerprint; therefore the distance difference of the two triangle pairs DP.sup.d should be small.
[0080] In the geometric consistency score DP.sup.d (TP.sub.i,u, TP.sub.j,v) formula given above, S.sub.op(TP.sub.i,u,TP.sub.j,v) is an orientation consistency score which may be defined as:
S.sub.op(TP.sub.i,u,TP.sub.j,v)=S.sub.op.sup.max−OP.sup.d(TP.sub.i,u,TP.sub.j,c)×C.sub.op.sup.u
and S.sub.op=max(S.sub.op.sup.min,S.sub.op)
[0081] where S.sub.op.sup.max and S.sub.op.sup.min are predefined maximum and minimum S.sub.dp scores respectively; Coup is the unit cost of distance difference and OP.sup.d(TP.sub.i,u,TP.sub.j,v) is an orientation difference of the two triangle pairs, which may be defined as
OP.sup.d(TP.sub.i,u,TP.sub.j,v)=abs(O.sup.d(T.sub.i.sup.c,T.sub.u.sup.r)−O.sup.d(T.sub.j.sup.c,T.sub.v.sup.r))
where O.sup.d(T.sub.1.sup.c,T.sub.1.sup.r) represents an orientation difference between two triangles and may be defined as the average, among all sides of the triangles, of the difference of orientation of a given triangle side between the two triangles O.sup.d(T.sub.1.sup.c,T.sub.1.sup.r)=avg(α.sub.d1, α.sub.d2, α.sub.d3), with α.sub.di=α.sub.i.sup.r−α.sub.i.sup.c and α.sub.i.sup.r, respectively α.sub.i.sup.c, the orientation of side i in the reference triangle, respectively candidate triangle, relative to a reference direction, as shown on
[0082] When the triangles of the current local feature pair truly match and the triangles of the different local feature pair also truly match, even if a rotation has been applied to the candidate fingerprint, the orientation difference between the two triangles (one in the candidate fingerprint and one in the reference fingerprint) of the current local feature pair will be the same as the one between the two triangles of the different local feature pair and the orientation difference OP.sup.d(TP.sub.i,u,TP.sub.j,v) should be small.
[0083]
[0084] This step may be repeated for all the local feature pairs in order to evaluate the geometric coherence of each local feature pair with all other local feature pairs.
[0085] In a fifth step S5 the matching device determines if the two local features of the current local feature pair truly match based on the evaluations performed in the previous steps.
[0086] More precisely, the matching device determines a match between the candidate fingerprint local feature and the reference fingerprint local feature of the current local feature pair depending on the similarity evaluation and the geometric coherence evaluations performed for the current local feature pair.
[0087] When the local features are Delaunay triangles, such a determination may comprise computing a global coherence weight for the current triangle pair based on the similarity score and the geometric consistency scores computed for the current triangle pair and comparing the computed global coherence weight with a predetermined threshold.
[0088] In a first embodiment, the global coherence weight may be the sum of all the geometric consistency scores computed for the current triangle pair.
[0089] In a second embodiment, the global coherence weight of the current triangle pair TP.sub.i may be a weighted sum of the geometric consistency scores computed for the current triangle pair: Σ(S.sub.g(TPi, TPj)*St(TPj)), using as weight of the geometric score obtained for the set (TPi, TPj) the similarity score of TPj. Such a weighted sum may be computed iteratively.
[0090]
[0091] This step may be repeated in order to determine a global coherence weight for each local feature pair and to determine if the two local features of each pair truly match.
[0092] In a sixth step S6, the matching device determines if the candidate fingerprint matches the reference fingerprint based on the results of the previous steps.
[0093] More precisely, the matching device determines a match between the candidate fingerprint and the reference fingerprint based on matching local feature pairs, depending on the similarity evaluations and geometric coherence evaluations performed for said matching local feature pairs.
[0094] Such a determination may comprise computing a final fingerprint matching score based on the similarity scores and global coherence weights of the triangle pairs whose computed global coherence weight is above said predetermined threshold.
[0095] For example, such a final fingerprint matching score may be defined as
[0096] where W.sub.i is the global coherence weight of local feature pair i, S.sub.i is the similarity score of local feature pair i and M is the total number of triangle pairs. Such a score increases as the number of matching pairs and their similarity score and global coherence weight increases.
[0097] According to a second aspect, the invention is also related to a computer program product directly loadable into the memory of at least one computer, comprising software code instructions for performing the steps of the method according to the first aspect as described above when said product is run on the computer.
[0098] According to a third aspect, the invention is also related to client device 101 configured for determining a match between a candidate fingerprint and a reference fingerprint characterized by minutiae local features and comprising a processor 201, a memory 203, 204, 205 and an input-output interface 207 configured for performing the steps of the method according to the first aspect as described here above.
[0099] As a result, the matching process described above enables to match minutiae despite fingerprint distortion, without performing any alignment of the fingerprint minutiae.