The embodiments of the present disclosure are related to a technique of biometrics authentication that uses vein data in order to determine whether or not the subject is a person to be authenticated.
An existing biometrics authentication method for example conducts matching (a matching process) between matching vein data obtained from an image based on photography of the user and registered vein data which has been registered in advance, so as to determine whether or not the user is a person to be authenticated, on the basis of the degree of similarity, obtained by that matching, between the matching vein data and the registered vein data (1:1 authentication).
Besides the 1:1 authentication, another existing biometrics authentication method conducts matching between matching vein data and a plurality of pieces of registered vein data respectively so as to determine whether or not the subject is a person to be authenticated, on the basis of the highest degree of similarity among a plurality of degrees of similarity obtained by the matching (1:N authentication).
In matching that uses a lot of data such as one using vein data, a process takes a long period of time for each case, leading to a situation where an increase in the number of registered cases of pieces of registered vein data (N) lengthens the process time in 1:N authentication.
In view of this, there is a method for reducing a process time in 1:N authentication. As an example, there is a method in which a plurality of pieces of registered vein data are sorted in descending order of degree of similarity between matching feature amounts obtained from matching vein data and registered feature amounts obtained from registered vein data so that matching is conducted between the matching vein data and pieces of registered vein data that are ranked highly in the sorting (for example, Japanese Laid-open Patent Publication No. 2007-249339 and Japanese Patent No. 5363587).
A biometrics information registration method according to an embodiment of the present disclosure is a biometrics information registration method for causing a computer to execute a process including extracting vein data representing a vein image and a feature amount from an image obtained by an image obtainment unit; and making a storage unit store the vein data and the feature amount, wherein the feature amount includes a first feature amount representing a relationship between two of a plurality of segments obtained by vectorizing the vein image.
A biometrics authentication method according to an embodiment of the present disclosure is a biometrics authentication method for causing a computer to execute a process including extracting vein data representing a vein image and a feature amount from an image obtained by an image obtainment unit; narrowing down a plurality of pieces of registered vein data stored in the storage unit on the basis of a comparison result between the extracted feature amount and a registered feature amount stored in the storage unit, and obtaining a degree of similarity between the pieces of registered vein data that were narrowed down and the extracted vein data; and determining whether or not a subject is a person to be authenticated, on the basis of the obtained degree of similarity, wherein the feature amount includes a first feature amount representing a relationship between two of a plurality of segments obtained by vectorizing the vein image.
A biometrics information registration device according to an embodiment of the present disclosure is a biometrics information registration device including a feature amount extraction unit for extracting vein data representing a vein image and a feature amount from an image obtained by an image obtainment unit; and a feature amount registration unit for making a storage unit store the vein data and the feature amount extracted by the feature amount extraction unit, wherein the feature amount includes a first feature amount representing a relationship between two of a plurality of segments obtained by vectorizing the vein image.
A biometrics authentication device according to an embodiment of the present disclosure is a biometrics authentication device including a feature amount extraction unit for extracting vein data representing a vein image and a feature amount from an image obtained by an image obtainment unit; a matching unit for narrowing down a plurality of pieces of registered vein data stored in the storage unit on the basis of a comparison result between the feature amount extracted by the feature amount extraction unit and a registered feature amount stored in the storage unit, and obtaining a degree of similarity between the pieces of registered vein data that were narrowed down and the vein data extracted by the feature amount extraction unit; and a determination unit for determining whether or not a subject is a person to be authenticated, on the basis of the degree of similarity obtained by the matching unit, wherein the feature amount includes a first feature amount representing a relationship between two of a plurality of segments obtained by vectorizing the vein image.
A non-transitory computer-readable record medium according to an embodiment of the present disclosure which records a program for causing a computer to execute a process including extracting vein data representing a vein image and a feature amount from an image obtained by an image obtainment unit; and making a storage unit store the extracted vein data and feature amount, wherein the feature amount includes a first feature amount representing a relationship between two of a plurality of segments obtained by vectorizing the vein image.
A non-transitory computer-readable record medium according to an embodiment of the present disclosure which records a program for causing a computer to execute a process including extracting vein data representing a vein image and a feature amount from an image obtained by an image obtainment unit; narrowing down a plurality of pieces of registered vein data stored in the storage unit on the basis of a comparison result between the extracted feature amount and a registered feature amount stored in the storage unit, and obtaining a degree of similarity between the pieces of registered vein data that were narrowed down and the vein data extracted by the feature amount extraction unit; and determining whether or not a subject is a person to be authenticated, on the basis of the obtained degree of similarity, wherein the feature amount includes a first feature amount representing a relationship between two of a plurality of segments obtained by vectorizing the vein image.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention, as claimed.
A biometrics information registration device 1 shown in
First, the image obtainment unit 2 obtains a picked-up image of the hand of the user (S11). For example, the image obtainment unit 2 is an image pickup device and photographs the hand of the user by using a single-panel image pick-up element and the RGB color filters of a Bayer array. Also, the image obtainment unit 2 casts near-infrared rays on the hand of the user so as to pick up the reflected light. Because hemoglobin in erythrocytes, which flow through veins, absorb near-infrared rays, portions containing veins, which issue reflected light with a lower intensity, are black in a picked-up image as shown in
Next, the feature amount extraction unit 3 extracts vein data, which represents a vein image, and the feature amount from an image obtained by the image obtainment unit 2 (S12). For example, the feature amount extraction unit 3 extracts vein data as shown in
Then, the feature amount registration unit 4 makes the storage unit 5 store the vein data and feature amount extracted by the feature amount extraction unit 3 (S13). For example, as shown in
A biometrics authentication device 6 shown in
First, the image obtainment unit 2 obtains a picked-up image of the hand of the user (S21).
Next, the feature amount extraction unit 3 extracts the vein data and the feature amount from the image obtained by the image obtainment unit 2 (S22).
Next, on the basis of a comparison result between a feature amount extracted by the feature amount extraction unit 3 and a registered feature amount stored in the storage unit 5 in advance, the matching unit 7 narrows down a plurality of pieces of registered vein data stored in the storage unit 5 in advance and obtains the degrees of similarity between the narrowed-down pieces of registered vein data and the vein data extracted by the feature amount extraction unit 3 (S23).
Then, the determination unit 8 determines whether or not the user is a person to be authenticated, on the basis of the degree of similarity obtained by the matching unit 7 (S24).
For example, the matching unit 7 makes the storage unit 5 store, as a score and together with corresponding registered vein data, the absolute value of a difference between a matching feature amount extracted by the feature amount extraction unit 3 and a registered feature amount stored in the storage unit 5. In the example shown in
Next, the matching unit 7 sorts in ascending order the scores stored in the storage unit 5. In the example shown in
Next, the matching unit 7 narrows down the number of pieces of registered vein data to a prescribed percentage from the top of the sorted pieces of registered vein data. In the example shown in
Next, the matching unit 7 obtains the degrees of similarity between matching vein data extracted by the feature amount extraction unit 3 and the narrowed-down pieces of registered vein data. In the example shown in
Next, the matching unit 7 extracts degrees of similarity that are equal to or higher than a threshold from among degrees of similarity corresponding to the narrowed-down pieces of registered vein data, and sorts the extracted degrees of similarity in descending order. In the example shown in
Next, from among the sorted degrees of similarity, the matching unit 7 obtains the highest degree of similarity as the degree of similarity for matching. In the example shown in
Next, the determination unit 8 determines that the user is a person to be authenticated when the degree of similarity obtained by the matching unit 7 is equal to or higher than the threshold.
Next, the feature amount extraction process (S12) shown in
First, the feature amount extraction unit 3 divides an image obtained by the image obtainment unit 2 into a plurality of areas by a prescribed division pattern (S31). When for example the image is divided into three areas horizontally and two areas vertically (division pattern P1), the feature amount extraction unit 3 obtains six areas a through f as shown in
Next, the feature amount extraction unit 3 selects one of the plurality of divisional areas (S32). For example, feature amount extraction unit 3 selects area c from among six areas a through f shown in
Next, from among a plurality of segments obtained by vectorizing the vein image in the selected area, the feature amount extraction unit 3 selects a segment of interest (S33), and selects a paired segment (S34). For example, the feature amount extraction unit 3 selects segment c1 as a segment of interest and selects segment c2 as a paired segment from among segments c1 through c3 in area c as shown in
Next, the feature amount extraction unit 3 calculates the feature amount (S35).
Next, the feature amount extraction unit 3 determines whether or not there are no paired segments near the segment of interest (S36), and when it is determined that there is a paired segment (No in S36), the feature amount extraction unit 3 returns to the process in S34, and when it is determined that there is not a paired segment (Yes in S36), it is determined whether or not there is a segment of interest that has not been selected in the selected area (S37). For example, when distance L between segment of interest c1 and segment c3 is equal to or longer than a threshold as shown in
Next, when it is determined that there is an unselected segment of interest (No in S37), the feature amount extraction unit 3 returns to the process in S33, and when it is determined that there are no unselected segments of interest (Yes in S37), the feature amount extraction unit 3 determines whether or not there is an unselected area (S38). For example, when all of segments c1 through c3 shown in
When it is determined that there is an unselected area (No in S38), the feature amount extraction unit 3 returns to the process in S32, while when it is determined that there are no unselected areas (Yes in S38), the feature amount extraction unit 3 terminates the feature amount extraction process.
Next, explanations will be given for the feature amount calculation process in S35 shown in
First, the feature amount extraction unit 3 selects a divisional segment of interest for a segment of interest (S41).
Next, the feature amount extraction unit 3 selects a paired divisional segment for a paired segment (S42).
Next, the feature amount extraction unit 3 calculates a feature amount that represents the relationship between the divisional segment of interest and the paired divisional segment (S43).
Next, when it is determined that the segment is not the last one of the selectable paired divisional segments (No in S44), the feature amount extraction unit 3 selects the next paired divisional segment (S42), and calculates a feature amount representing the divisional segment of interest and the next paired divisional segment (S43).
Also, when it is determined that the segment is the last one of the selectable paired divisional segments (Yes in S44), the feature amount extraction unit 3 determines whether or not the segment is the last one of the selectable divisional segment of interest (S45).
Next, when it is determined that the segment is not the last one of the selectable divisional segment of interest (No in S45), the feature amount extraction unit 3 selects the next divisional segment of interest (S41), and repeats S42 through S44 to the last paired divisional segment.
When it is determined that the segment is the last one of the selectable divisional segment of interest (Yes in S45), the feature amount extraction unit 3 terminates the feature amount calculation process.
A case is assumed for example in which the image has been divided by division pattern P1 and area c has been selected as shown in
First, the feature amount extraction unit 3 obtains all end points and inflection points of segment of interest c1 and treats these points as points c11 through c16 as shown in
Next, the feature amount extraction unit 3 obtains all end points and inflection points on paired segment c2 as shown in
Next, the feature amount extraction unit 3 calculates θ1=a cos(AB·CD/|AB∥CD|)*(180/π), and thereby obtains angle θ1 between divisional segment of interest AB and paired divisional segment CD as shown in
Next, the feature amount extraction unit 3 obtains hist1_P1[Area][n] as a histogram (frequency distribution) for angle θ1. Note that P1 represents division pattern P1, [Area] represents an area after the division of the image, and [n] represents the number of grades of a histogram. For example, when the angle of 180 degrees is partitioned in units of 6 degrees so as to set 30 angle regions (grades), the counter value of the angle region including angle θ1 is incremented from among counter values sdir(0) through sdir(29) respectively corresponding to the 30 angle regions, and obtains hist1_P1[c][30]={sdir(0), sdir(1), . . . , sdir(29)} as a histogram. When for example angle θ1 calculated then is 30 degrees, the feature amount extraction unit 3 increments counter value sdir(5), which corresponds to the angle region from 30 degrees to 35 degrees, so as to obtain hist1_P1[c][30]={0, 0, 0, 0, 0, 1, 0, . . . , 0}.
Next, as shown in
Next, the feature amount extraction unit 3 calculates angle θ1 between divisional segment of interest AB and next paired divisional segment CD.
Next, the feature amount extraction unit 3 increments the counter value of the angle region including that angle θ1, and obtains hist1_P1[c][30]={sdir(0), sdir(1), . . . , sdir(29)} as a histogram. When for example angle θ1 calculates that time is 43 degrees, the feature amount extraction unit 3 increments counter value sdir(7), which corresponds to the angle region from 42 degrees to 47 degrees, and obtains hist1_P1[c][30]={0, 0, 0, 0, 0, 1, 0, 1 . . . , 0}.
As described above, angle θ1 between divisional segment of interest AB and paired divisional segment CD is repeatedly calculated by referring to point c11 until it becomes impossible to select paired divisional segment CD in paired segment c2. Thereafter, hist1_P1[c][30]={sdir(0), sdir(1), . . . , sdir(29)} is obtained as a histogram for each of such angles θ1.
Next, the feature amount extraction unit 3 treats next point c12 as point A, treats as point B a point distant from point A on segment of interest c1 by linear distance len, treats straight line AB passing through points A and B as next divisional segment of interest AB, treats point c21 as point C, treats as point D a point distant from point C on paired segment c2 by linear distance len, and treats straight line CD passing through points C and D as paired divisional segment CD.
Next, the feature amount extraction unit 3 calculates angle θ1, increments the counter value of the angle region including that angle θ1, and obtains hist1_P1[c][30]={sdir(0), sdir(1), . . . , sdir(29)} as a histogram.
As described above, angle θ1 is obtained for each of all the combinations between selectable divisional segments of interest AB and selectable paired divisional segments CD, so as to obtain hist1_P1[c][30]={sdir(0), sdir(1), . . . , sdir(29)} as a histogram for that angle θ1.
Next, the feature amount extraction unit 3 similarly obtains hist1_P1[a][30], hist1_P1[b][30], hist1_P1[d][30], hist1_P1[e][30] and hist1_P1[f][30] as histograms for other areas a, b, d, e and f of the image shown in
Then, the feature amount extraction unit 3 performs a normalization process on each of hist1_P1[a][30] through hist1_P1[f][30]. For example, the feature amount extraction unit 3 treats, as ALLcnt1, the sum of the total of sdir(0), sdir(1), . . . , sdir(29) of histogram hist1_P1[a][30], the total of sdir(0), sdir(1), . . . , sdir(29) of hist1_P1[b][30], . . . , and the total of sdir(0), sdir(1), . . . , dir(29) of hist1_P1[f][30], expresses the ratios of the counter values by dividing each counter value by sum ALLcnt1 in an integer as described below so as to perform a normalization process, and makes the storage unit 5 store normalized histograms hist1_P1[a][30] through hist1_P1[f][30] as the above matching feature amounts or the above registered feature amounts (first feature amount).
hist1_P1[a][30]={sdir(0)/ALLcnt1, sdir(1)/ALLcnt1, . . . , sdir(29)/A LLcnt1}
hist1_P1[b][30]={sdir(0)/ALLcnt1, sdir(1)/ALLcnt1, . . . , sdir(29)/A LLcnt1}
hist1_P1[c][30]={sdir(0)/ALLcnt1, sdir(1)/ALLcnt1, . . . , sdir(29)/A LLcnt1}
hist1_P1[d][30]={sdir(0)/ALLcnt1, sdir(1)/ALLcnt1, . . . , sdir(29)/A LLcnt1}
hist1_P1[e][30]={sdir(0)/ALLcnt1, sdir(1)/ALLcnt1, . . . , sdir(29)/A LLcnt1}
hist1_P1[f][30]={sdir(0)/ALLcnt1, sdir(1)/ALLcnt1, . . . , sdir(29)/A LLcnt1}
Similarly, the feature amount extraction unit 3 obtains hist1_P2[g][30] through hist1_P2[l][30] corresponding to division pattern P2, and performs a normalization process on each of histograms hist1_P2[g][30]˜hist1_P2[l][30], and makes the storage unit 5 store normalized histograms hist1_P2[g][30] through hist1_P2[l][30] as the above matching feature amounts or the above registered feature amounts (first feature amount).
Next, the matching unit 7 treats, as score11, the sum of the absolute value of a difference between hist1_P1[a][30] as a registered feature amount and hist1_P1[a][30] as a matching feature amount, the absolute value of a difference between hist1_P1[b][30] as a registered feature amount and hist1_P1[b][30] as a matching feature amount, the absolute value of a difference between hist1_P1[c][30] as a registered feature amount and hist1_P1[c][30] as a matching feature amount, the absolute value of a difference between hist1_P1[d][30] as a registered feature amount and hist1_P1[d][30] as a matching feature amount, the absolute value of a difference between hist1_P1[e][30] as a registered feature amount and hist1_P1[e][30] as a matching feature amount, and the absolute value of a difference between hist1_P1[f][30] as a registered feature amount and hist1_P1[f][30] as a matching feature amount.
Also, the matching unit 7 treats, as score12, the sum of the absolute value of a difference between hist1_P2[g][30] as a registered feature amount and hist1_P2[g][30] as a matching feature amount, the absolute value of a difference between hist1_P2[h][30] as a registered feature amount and hist1_P2[h][30] as a matching feature amount, the absolute value of a difference between hist1_P2[i][30] as a registered feature amount and hist1_P2[i][30] as a matching feature amount, the absolute value of a difference between hist1_P2[j][30] as a registered feature amount and hist1_P2[j][30] as a matching feature amount, the absolute value of a difference between hist1_P2[k][30] as a registered feature amount and hist1_P2[k][30] as a matching feature amount, and the absolute value of a difference between hist1_P2[l][30] as a registered feature amount and hist1_P2[l][30] as a matching feature amount.
Then, the matching unit 7 treats the sum of score11 and score12 as score shown in
After narrowing down a plurality of pieces of registered vein data, the biometrics authentication device 6 of an embodiment of the present disclosure has obtained the degrees of similarity between the narrowed-down pieces of registered vein data and the matching vein data, making it possible to suppress an increase in the matching process time compared with a case of obtaining the degrees of similarity between all of the plurality of pieces of registered vein data and the matching vein data.
Also, the biometrics information registration device 1 and the biometrics authentication device 6 according to an embodiment of the present disclosure obtain the angle between two of respective divisional segments among a plurality of segments obtained by vectorizing a vein image for extracting feature amounts from an image for each of all combinations between the two segments, and treats the histograms of these angles as the feature amount (first feature amount), making it possible to reduce variation in the feature amount even when the photography environment or the orientation of the user has changed between the registration of the vein data and the authentication, thereby making it possible to extract a registered feature amount and a matching feature amount highly accurately. This also makes it possible to suppress a decrease in the accuracy of the authentication process.
Incidentally, when the histogram of an angle between two segments is treated as a feature amount and the angle between the two segments shown in
Then, it is possible to obtain the direction of an angle between two segments and treat the histogram of that direction (frequency distribution) as a feature amount.
Explanations will be given for a method of calculating a feature amount when the histogram of the direction of an angle between two segments is treated as that feature amount (second feature amount).
It is assumed for example that the image has been divided by division pattern P1, area c has been selected as shown in
First, the feature amount extraction unit 3 obtains all end points and inflection points of segment of interest c1, treats these points as points c11 through c16 as shown in
Next, the feature amount extraction unit 3 obtains all end points and inflection points of paired segment c2, treats these points as points c21 through c26 as shown in
Next, the feature amount extraction unit 3 obtains direction θ2 of an angle between divisional segment of interest AB and paired divisional segment CD. Specifically, the feature amount extraction unit 3 translates divisional segment of interest AB and paired divisional segment CD in such a manner that points A and C coincide with the origin of the two-dimensional coordinate system as shown in
Next, the feature amount extraction unit 3 obtains hist2_P1[Area][n] as a histogram (frequency distribution) for direction θ2. Note that P1 represents division pattern P1, [Area] represents an area after the division of the image, and [n] represents the number of grades of a histogram. For example, when the angle of 360 degrees is partitioned in units of 8 degrees so as to set 45 angle regions (grades), the counter value of an angle region including direction θ2 is incremented from among counter values ddir(0) through ddir(44) respectively corresponding to the 45 angle regions, and obtains hist2_P1[c][45]={ddir(0), ddir(1), . . . , ddir(44)} as a histogram. When for example direction θ2 calculated then is 15 degrees, the feature amount extraction unit 3 increments counter value ddir(1), which corresponds to the angle region from 8 degrees to 15 degrees, so as to obtain hist2_P1[c][45]={0, 1, 0, . . . , 0}.
Next, the feature amount extraction unit 3 treats next point c22 as point C, treats as point D a point distant from point C on paired segment c2 by linear distance len, and treats straight line CD passing through points C and D as next paired divisional segment CD.
Next, the feature amount extraction unit 3 calculates direction θ2 of the angle between divisional segment of interest AB and paired divisional segment CD.
Next, the feature amount extraction unit 3 increments the counter value of the angle region including that direction θ2 and obtains hist2_P1[c][45]={ddir(0), ddir(1), . . . , ddir(44)} as a histogram. When for example direction θ2 calculated then is 23 degrees, the feature amount extraction unit 3 increments counter value ddir(2) corresponding to the angle region from 16 degrees to 23 degrees so as to obtain hist2_P1[c][45]={0, 1, 1, 0, . . . , 0}.
As described above, direction θ2 of the angle between divisional segment of interest AB and paired divisional segment CD is repeatedly calculated by referring to point c11 until it becomes impossible to select paired divisional segment CD in paired segment c2 and hist2_P1[c][45]={ddir(0), ddir(1), . . . , ddir(44)} is obtained as a histogram for each of such directions 02.
Next, the feature amount extraction unit 3 treats next point c12 as point A, treats as point B a point distant from point A on segment of interest c1 by linear distance len, treats as next divisional segment of interest AB straight line AB passing through points A and B, treats point c21 as point C, treats as point D a point distant from point C on paired segment c2 by linear distance len, and treats straight line CD passing through points C and D as paired divisional segment CD.
Next, the feature amount extraction unit 3 calculates direction θ2, increments the counter value of the angle region including that direction θ2, and obtains hist2_P1[c][45]={ddir(0), ddir(1), . . . , ddir(44)}.
As described above, direction θ2 is obtained for each of all the combinations between selectable divisional segments of interest AB and selectable paired divisional segments CD so as to obtain hist2_P1[c][45]={ddir(0), ddir(1), . . . , ddir(44)} for that direction θ2.
Next, the feature amount extraction unit 3 similarly obtains hist2_P1[a][45], hist2_P1[b][45], hist2_P1[d][45], hist2_P1[e][45] and hist2_P1[f][45] as histograms for other areas a, b, d, e and f of the image shown in
Then, the feature amount extraction unit 3 performs a normalization process on each of hist2_P1[a][45] through hist2_P1[f][45]. For example, the feature amount extraction unit 3 treats, as ALLcnt1, the sum of the total of ddir(0), ddir(1), . . . , ddir(44) of histogram hist2_P1[a][45], the total of ddir(0), . . . , ddir(1), . . . , ddir(44) of hist2_P1[b][45], . . . , and the total of ddir(0), ddir(1), . . . , ddir(44) of hist2_P1[f][45], expresses the ratios of the counter values by dividing each counter value by sum ALLcnt1 in an integer as described below so as to perform a normalization process, and makes the storage unit 5 store normalized histograms hist2_P1[a][45] through hist2_P1[f][45] as the above matching feature amounts or the above registered feature amounts (second feature amount).
hist2_P1[a][45]={ddir(0)/ALLcnt1, ddir(1)/ALLcnt1, . . . , ddir(44)/A LLcnt1}
hist2_P1[b][45]={ddir(0)/ALLcnt1, ddir(1)/ALLcnt1, . . . , ddir(44)/A LLcnt1}
hist2_P1[c][45]={ddir(0)/ALLcnt1, ddir(1)/ALLcnt1, . . . , ddir(44)/A LLcnt1}
hist2_P1[d][45]={ddir(0)/ALLcnt1, ddir(1)/ALLcnt1, . . . , ddir(44)/A LLcnt1}
hist2_P1[e][45]={ddir(0)/ALLcnt1, ddir(1)/ALLcnt1, . . . , ddir(44)/A LLcnt1}
hist2_P1[f][45]={ddir(0)/ALLcnt1, ddir(1)/ALLcnt1, . . . , ddir(44)/A LLcnt1}
Similarly, the feature amount extraction unit 3 obtains hist2_P2[g][45] through hist2_P2[l][45] corresponding to division pattern P2, and performs a normalization process on each of histograms hist2_P2[g][45] through hist2_P2[l][45], and makes the storage unit 5 store normalized histograms hist2_P2[g][45] through hist2_P2[l][45] as the above matching feature amounts or the above registered feature amounts (second feature amount).
Next, the matching unit 7 treats, as score21, the sum of the absolute value of a difference between hist2_P1[a][45] as a registered feature amount and hist2_P1[a][45] as a matching feature amount, the absolute value of a difference between hist2_P1[b][45] as a registered feature amount and hist2_P1[b][45] as a matching feature amount, the absolute value of a difference between hist2_P1[c][45] as a registered feature amount and hist2_P1[c][45] as a matching feature amount, the absolute value of a difference between hist2_P1[d][45] as a registered feature amount and hist2_P1[d][45] as a matching feature amount, the absolute value of a difference between hist2_P1[e][45] as a registered feature amount and hist2_P1[e][45] as a matching feature amount, and the absolute value of a difference between hist2_P1[f][45] as a registered feature amount and hist2_P1[f][45] as a matching feature amount.
Next, the matching unit 7 treats, as score22, the sum of the absolute value of a difference between hist2_P2[g][45] as a registered feature amount and hist2_P2[g][45] as a matching feature amount, the absolute value of a difference between hist2_P2[h][45] as a registered feature amount and hist2_P2[h][45] as a matching feature amount, the absolute value of a difference between hist2_P2[i][45] as a registered feature amount and hist2_P2[i][45] as a matching feature amount, the absolute value of a difference between hist2_P2[j][45] as a registered feature amount and hist2_P2[j][45] as a matching feature amount, the absolute value of a difference between hist2_P2[k][45] as a registered feature amount and hist2_P2[k][45] as a matching feature amount, and the absolute value of a difference between hist2_P2[l][45] as a registered feature amount and hist2_P2[l][45] as a matching feature amount.
Then, the matching unit 7 calculates score=α×(score11+score12)+β×(score21+score22) so as to obtain score shown in
Also, other feature amounts may be used for obtaining score.
First, the feature amount extraction unit 3 removes a thin vein image and a thick vein image from an image obtained by the image obtainment unit 2, and thereafter develops such vein images onto the center of an image of a different size (an image of 256 by 256 for example), and treats that image as f(x,y).
Next, the feature amount extraction unit 3 performs two-dimensional fast Fourier transform on image f(x,y) as expressed by expression 1 so as to obtain spatial frequency component F(u,v). This two-dimensional fast Fourier transform first performs Fourier transform on pixels of each line in the direction of x of image f(x,y), and thereafter performs Fourier transform on the transform result of that line in the direction of y. It is assume that W1=exp(−j2π/M) and W2=exp(−j2π/N) are satisfied, where M and N represent the numbers of pixels in the horizontal and vertical directions, respectively.
Next, the feature amount extraction unit 3 calculates P(u,v)=|F(u,v)|2 so as to obtain power spectrum P(u,v).
Next, the feature amount extraction unit 3 treats power spectrum P(u,v) as power spectrum P(r,θ) of the polar coordinate format and conducts the operation as expressed by expression 2 so as to obtain energy p′(r) in the a doughnut-shaped region having the origin at its center. Note that θ is in the range from 0 through π.
Then, the feature amount extraction unit 3 calculates p(r)=10000*p′(r)/Σp′(r) so as to obtain, as the third feature amount, the energy ratio P(r) of each frequency. Note that “r” represents the radius, which satisfies r=1 through 32 in this example, and “10000” is a correction value for integer-type transform.
As described above, the third feature amount represents directionality and an amount of a vein image by using a frequency component, and can be expressed by the sum of energy in doughnut-shaped regions around the origin in the polar coordinate system power spectrum space as shown in
First, similarly to the third feature amount, the feature amount extraction unit 3 performs Fourier transform on image f(x,y) so as to calculate spatial frequency component F(u,v), and calculates power spectrum P(u,v) from this spatial frequency component F(u,v).
Next, the feature amount extraction unit 3 treats power spectrum P(u,v) as power spectrum P(r,θ) of the polar coordinate format and conducts operations as expressed by expression 3 so as to obtain the energy of the angle. Note that w is the size of the domain of definition of P(u,v) and θ represents the directions obtained by dividing 180 degrees by 12.
Then, the feature amount extraction unit 3 calculates q(θ)=10000*q′ (θ)/Σq′ (θ) so as to obtain, as the fourth feature amount, energy ratio q(θ) of each angle. In other words, the energy ratio in each angle range obtained by the division by 12 is calculated. Note that “10000” is a correction value for an integer-type transform.
As described above, the fourth feature amount represents directionality and an amount of a vein image by using an angle component, and can be expressed by the sum of energy in angle ranges each of which is of 15 degrees as shown in
Note that angle component q(0) is the energy of the angle with θ ranging from 0 through 14, and thus is calculated by expression 4, and is calculated for the 12 directions by changing θ sequentially.
First, the feature amount extraction unit 3 divides the image by division pattern P1 for example as shown in
Next, the feature amount extraction unit 3 obtains all curvature directions of two divisional segments adjacent in a segment obtained by vectorizing a vein image in the selected area, and obtains the fifth feature amount, which represents the histogram (frequency distribution) of those curvature directions. For example, the feature amount extraction unit 3 obtains all end points and inflection points on segment c1 as shown in
Next, the feature amount extraction unit 3 obtains hist3_P1[Area][n] as a histogram for curvature direction θ4. Note that P1 represents division pattern P1, [Area] represents an area after the division of the image, and [n] represents the number of grades of a histogram. For example, when area c is selected and the angle of 360 degrees is partitioned in units of 10 degrees so as to set 36 angle regions (grades), the counter value of an angle region including curvature direction θ4 is incremented from among counter values curv(0) through curv(35) respectively corresponding to the 36 angle regions, and obtains hist3_P1[c][36]={curv(0), curv(1), . . . , curv(35)} as a histogram. When for example direction θ1 calculated then is 330 degrees, the feature amount extraction unit 3 increments counter value curv(33), which corresponds to the angle region from 330 degrees to 339 degrees, so as to obtain hist3_P1[c][36]={0, . . . , 0, 1, 0, 0}. Note that curv(0) represents a value obtained by integrating curvature direction θ4 included in the angle region from 0 degree to 9 degrees, and is calculated by expression 7.
Next, as shown in
Next, as shown in
As described above, curvature direction θ4 is repeatedly calculated until it becomes impossible to select divisional segment AB in segment c1 and hist3_P1[c][36]={curv(0), curv(1), . . . , curv(35)} is obtained as a histogram for each of such curvature directions 04.
The generation of this histogram hist3_P1[c][36] is conducted similarly for other areas a, b, d, e and f.
Then, the feature amount extraction unit 3 treats, as ALLcnt1, the sum of the total of curv(0), curv(1), . . . , curv(35) of histogram hist3_P1[a][36], the total of curv(0), curv(1), . . . , curv(35) of hist3_P1[b][36], . . . , and the total of curv(0), curv(1), . . . , curv(35) of hist3_P1[f][36], expresses the ratios of the counter values by dividing each counter value by sum ALLcnt1 in an integer as described below so as to perform a normalization process, and makes the storage unit 5 store normalized histograms hist3_P1[a][36] through hist3_P1[f][36] as the above matching feature amounts or the above registered feature amounts (fifth feature amount).
hist3_P1[a][36]={curv(0)/ALLcnt1, curv(1)/ALLcnt1, . . . , curv(35)/A LLcnt1}
hist3_P1[b][36]={curv(0)/ALLcnt1, curv(1)/ALLcnt1, . . . , curv(35)/A LLcnt1}
hist3_P1[c][36]={curv(0)/ALLcnt1, curv(1)/ALLcnt1, . . . , curv(35)/A LLcnt1}
hist3_P1[d][36]={curv(0)/ALLcnt1, curv(1)/ALLcnt1, . . . , curv(35)/A LLcnt1}
hist3_P1[e][36]={curv(0)/ALLcnt1, curv(1)/ALLcnt1, . . . , curv(35)/A LLcnt1}
hist3_P1[f][36]={curv(0)/ALLcnt1, curv(1)/ALLcnt1, . . . , curv(35)/A LLcnt1}
Similarly, the feature amount extraction unit 3 obtains hist3_P2[g][36] through hist3_P2[l][36] corresponding to division pattern P2, and performs a normalization process on each of histograms hist3_P2[g][36] through hist3_P2[l][36], and makes the storage unit 5 store normalized histograms hist3_P2[g][36] through hist3_P2[l][36] as the above matching feature amounts or the above registered feature amounts (fifth feature amount).
First, the feature amount extraction unit 3 divides the image by division pattern P1 for example as shown in
Next, the feature amount extraction unit 3 obtains inclinations of all divisional segments in a segment obtained by vectorizing a vein image in the selected area, and obtains the sixth feature amount, which represents the histogram (frequency distribution) of those inclinations. For example, the feature amount extraction unit 3 obtains all end points and inflection points on segment c1 as shown in
Next, as shown in
As described above, inclination θ5 is repeatedly calculated until it becomes impossible to select divisional segment AB in segment c1 and hist4_P1[c][18]={segdir(0), segdir(1), . . . , segdir(17)} is obtained as a histogram for each of such inclinations 05.
The generation of this histogram hist4_P1[c][18] is conducted similarly for other areas a, b, d, e and f.
Then, the feature amount extraction unit 3 treats, as ALLcnt1, the sum of the total of segdir(0), segdir(1), . . . , segdir(17) of histogram hist4_P1[a][18], the total of segdir(0), segdir(1), . . . , segdir(17) of hist4_P1[b][18], . . . , and the total of segdir(0), segdir(1), . . . , segdir(17) of hist4_P1[f][18], expresses the ratios of the counter values by dividing each counter value by sum ALLcnt1 in an integer as described below so as to perform a normalization process, and makes the storage unit 5 store normalized histograms hist4_P1[a][18] through hist4_P1[f][18] as the above matching feature amounts or the above registered feature amounts (sixth feature amount).
hist4_P1[a][18]={segdir(0)/ALLcnt1, segdir(1)/ALLcnt1, . . . , segdir (17)/ALLcnt1}
hist4_P1[b][18]={segdir(0)/ALLcnt1, segdir(1)/ALLcnt1, . . . , segdir (17)/ALLcnt1}
hist4_P1[c][18]={segdir(0)/ALLcnt1, segdir(1)/ALLcnt1, . . . , segdir (17)/ALLcnt1}
hist4_P1[d][18]={segdir(0)/ALLcnt1, segdir(1)/ALLcnt1, . . . , segdir (17)/ALLcnt1}
hist4_P1[e][18]={segdir(0)/ALLcnt1, segdir(1)/ALLcnt1, . . . , segdir (17)/ALLcnt1}
hist4_P1[f][18]={segdir(0)/ALLcnt1, segdir(1)/ALLcnt1, . . . , segdir (17)/ALLcnt1}
Similarly, the feature amount extraction unit 3 obtains hist4_P2[g][18] through hist4_P2[l][18] corresponding to division pattern P2, and performs a normalization process on each of histograms hist4_P2[g][18] through hist4_P2[l][18], and makes the storage unit 5 store normalized histograms hist4_P2[g][18] through hist4_P2[l][18] as the above matching feature amounts or the above registered feature amounts (sixth feature amount).
As shown in for example
Next, the feature amount extraction unit 3 obtains the number of pixels seghist1 corresponding to a vein image in each of the 49 areas obtained by the division based on division pattern P1.
Next, the feature amount extraction unit 3 generates hist5_P1[49]={seghist1(0), seghist1(1), . . . , seghist1(48)} as a histogram for the number of pixels seghist1 in a vein image in each area.
Next, the feature amount extraction unit 3 treats, as ALLcnt1, the sum of seghist1(0), seghist1(1), . . . , seghist1(48) of histogram hist5_P1[49], expresses the ratios of the counter values by dividing each counter value by sum ALLcnt1 in an integer as described below so as to perform a normalization process, and makes the storage unit 5 store normalized histogram hist5_P1[49] as the above matching feature amounts or the above registered feature amounts (seventh feature amount).
hist5_P1[49]={seghist1(0)/ALLcnt1, seghist1(1)/ALLcnt1, . . . , seghist1(48)/ALLcnt1}
Similarly, the feature amount extraction unit 3 obtains hist5_P2[64]={seghist2(0), seghist2(1), . . . , seghist2(63)} as a histogram corresponding to division pattern P2, and performs a normalization process on that histogram hist5_P2[64], and makes the storage unit 5 store normalized histogram hist5_P2[64] as the above matching feature amounts or the above registered feature amounts (seventh feature amount).
Next, the matching unit 7 treats, as score3, the sum of the absolute value of a difference between p(1) as a registered feature amount and p(1) as a matching feature amount, the absolute value of a difference between p(2) as a registered feature amount and p(2) as a matching feature amount, . . . , and the absolute value of a difference between p(32) as a registered feature amount and p(32) as a matching feature amount.
Also, the matching unit 7 treats, as score4, the sum of the absolute value of a difference between q(0) as a registered feature amount and q(0) as a matching feature amount, the absolute value of a difference between q(1) as a registered feature amount and q(1) as a matching feature amount, . . . , and the absolute value of a difference between q(11) as a registered feature amount and q(11) as a matching feature amount.
Next, the matching unit 7 treats, as score51, the sum of the absolute value of a difference between hist3_P1[a][36] as a registered feature amount and hist3_P1[a][36] as a matching feature amount, the absolute value of a difference between hist3_P1[b][36] as a registered feature amount and hist3_P1[b][36] as a matching feature amount, the absolute value of a difference between hist3_P1[c][36] as a registered feature amount and hist3_P1[c][36] as a matching feature amount, the absolute value of a difference between hist3_P1[d][36] as a registered feature amount and hist3_P1[d][36] as a matching feature amount, the absolute value of a difference between hist3_P1[e][36] as a registered feature amount and hist3_P1[e][36] as a matching feature amount, and the absolute value of a difference between hist3_P1[ f][36] as a registered feature amount and hist3_P1[ f][36] as a matching feature amount.
Also, the matching unit 7 treats, as score52, the sum of the absolute value of a difference between hist3_P2[g][36] as a registered feature amount and hist3_P2[g][36] as a matching feature amount, the absolute value of a difference between hist3_P2[h][36] as a registered feature amount and hist3_P2[h][36] as a matching feature amount, the absolute value of a difference between hist3_P2[i][36] as a registered feature amount and hist3_P2[i][36] as a matching feature amount, the absolute value of a difference between hist3_P2[j][36] as a registered feature amount and hist3_P2[j][36] as a matching feature amount, the absolute value of a difference between hist3_P2[k][36] as a registered feature amount and hist3_P2[k][36] as a matching feature amount, and the absolute value of a difference between hist3_P2[l][36] as a registered feature amount and hist3_P2[l][36] as a matching feature amount.
Also, the matching unit 7 treats, as score61, the sum of the absolute value of a difference between hist4_P1[a][18] as a registered feature amount and hist4_P1[a][18] as a matching feature amount, the absolute value of a difference between hist4_P1[b][18] as a registered feature amount and hist4_P1[b][18] as a matching feature amount, the absolute value of a difference between hist4_P1[c][18] as a registered feature amount and hist4_P1[c][18] as a matching feature amount, the absolute value of a difference between hist4_P1[d][18] as a registered feature amount and hist4_P1[d][18] as a matching feature amount, the absolute value of a difference between hist4_P1[e][18] as a registered feature amount and hist4_P1[e][18] as a matching feature amount, and the absolute value of a difference between hist4_P1[f][18] as a registered feature amount and hist4_P1[f][18] as a matching feature amount.
Also, the matching unit 7 treats, as score62, the sum of the absolute value of a difference between hist4_P2[g][18] as a registered feature amount and hist4_P2[g][18] as a matching feature amount, the absolute value of a difference between hist4_P2[h][18] as a registered feature amount and hist4_P2[h][18] as a matching feature amount, the absolute value of a difference between hist4_P2[i][18] as a registered feature amount and hist4_P2[i][18] as a matching feature amount, the absolute value of a difference between hist4_P2[j][18] as a registered feature amount and hist4_P2[j][18] as a matching feature amount, the absolute value of a difference between hist4_P2[k][18] as a registered feature amount and hist4_P2[k][18] as a matching feature amount, and the absolute value of a difference between hist4_P2[l][18] as a registered feature amount and hist4_P2[l][18] as a matching feature amount.
Also, the matching unit 7 treats, as score71, the sum of the absolute value of a difference between seghist1(0) as a registered feature amount and seghist1(0) as a matching feature amount, the absolute value of a difference between seghist1(1) as a registered feature amount and seghist1(1) as a matching feature amount, . . . , and the absolute value of a difference between seghist1(48) as a registered feature amount and seghist1(48) as a matching feature amount.
Also, the matching unit 7 treats, as score72, the sum of the absolute value of a difference between seghist2(0) as a registered feature amount and seghist2(0) as a matching feature amount, the absolute value of a difference between seghist2(1) as a registered feature amount and seghist2(1) as a matching feature amount, . . . , and the absolute value of a difference between seghist2(63) as a registered feature amount and seghist2(63) as a matching feature amount.
Also, the matching unit 7 calculates score=α×(score11+score12)+β×(score21+score22)+γ(score3)+δ×(score3)+ε×(score4)+ζ×(score51+score52)+λ×(score61+score62)+μ×(score71+score72) so as to obtain score shown in
As described above, the biometrics information registration device 1 and the biometrics authentication device 6 of an embodiment of the present disclosure extract seven types of feature amounts (first through seventh feature amounts) from an image obtained by the image obtainment unit 2 so as to use these feature amounts for narrowing down pieces of registered vein data, and thereby can increase the accuracy of the narrowing down and can conduct the matching process more accurately.
Note that there is a possibility for example that the fourth and fifth feature amounts obtained for the segment shown in
As shown in
The control unit 1201 may be implemented by for example a central processing unit (CPU), a multi-core CPU, a programmable device (field programmable gate array (FPGA), programmable logic device (PLD), etc.), and corresponds to the feature amount extraction unit 3 and the feature amount registration unit 4 shown in
The storage unit 1202 corresponds to the storage unit 5 shown in
The recording medium reading device 1203 reads data stored in a recording medium 1207 and writes data to the recording medium 1207 under control of the control unit 1201. Also, recording medium 1207, which is removable, is a non-transitory computer-readable recording medium, and may be implemented by a magnetic recording device, an optical disk, a magneto-optical recording medium, a semiconductor memory, etc. A magnetic recording device may be implemented by for example a hard disk device (HDD) etc. An optical disk may be implemented by for example a digital versatile disk (DVD), a DVD-RAM, a compact disk read only memory (CD-ROM), a CD-R (Recordable)/RW (ReWritable), etc. A magneto-optical recording medium may be implemented by for example a magneto-optical (MO) disk etc. Also, a non-transitory recording medium includes the storage unit 1202.
To the input/output interface 1204, an input/output unit 1208 is connected, and the input/output interface 1204 transmits, to the control unit 1201 and via the bus 1206, information input by the user via the input/output unit 1208. Also, the input/output interface 1204 transmits, to the input/output unit 1208 and via the bus 1206, information transmitted from the control unit 1201.
The input/output unit 1208 corresponds to the image obtainment unit 2 shown in
The communication interface 1205 is an interface for providing connection to a local area network (LAN) or to the Internet. Also, the communication interface 1205 can be used as an interface for providing LAN connection, Internet connection, or wireless connection to other computers, as needed.
By using a computer having the above hardware, the respective process functions performed by the biometrics information registration device 1 or the biometrics authentication device 6 are implemented. In such a case, by making a computer execute a program describing the contents of the respective process functions performed by the biometrics information registration device 1 or the biometrics authentication device 6, the above respective functions (for example, the feature amount extraction unit 3, the feature amount registration unit 4, the matching unit 7, and the determination unit 8) are implemented on the computer. The program describing the contents of the respective process functions can be stored in the storage unit 1202 or the recording medium 1207.
When the program is to be distributed, the program is sold in a state for example that it is stored in the recording medium 1207 such as a DVD, a CD-ROM, etc. It is also possible to record the program in a storage device of a server computer so that the program is transferred to another computer from the server computer via a network.
The computer that executes the program for example stores, in the storage unit 1202, the program recorded in the recording medium 1207 or the program transferred from the server computer. Then, the computer reads the program from the storage unit 1202 so as to execute a process in accordance with the program. Note that the computer may also read the program directly from the recording medium 1207 so as to execute a process in accordance with the program. Also, the computer may execute a process in accordance with a received program each time the program is transferred from the server program.
In the embodiments of the present disclosure, devices that conduct authentication by using a palm vein have been used for the explanations, whereas the scope of the present disclosure is not limited to this and any other portions from which biological features can be detected can be used.
For example, other portions from which biological features can be detected are not limited to veins, and may be a biological blood vessel image, a biological pattern, a biological fingerprint or palm pattern, the bottom of a foot, a toe, a finger, the back of a hand, the top of a foot, a wrist, an arm, etc.
Note that when a vein is used for the authentication, other portions from which biological features can be detected may be any portion that allows the observation of the vein.
Note that portions from which biological features can be detected and which can identify biological information are advantageous for authentication. For example, the palm of a hand or a face allows the identifying of the portion from the obtained image.
The embodiments of the present disclosure can suppress reduction in the authentication accuracy while suppressing an increase in the matching process time in 1:N authentication.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiments of the present invention have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2014-062775 | Mar 2014 | JP | national |
This application is continuation application of International Application PCT/JP2015/059213 filed on Mar. 25 2015 and designated the U.S., the entire contents of which are incorporated herein by reference. This application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2014-062775, filed on Mar. 25, 2014, the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2015/059213 | Mar 2015 | US |
Child | 15266067 | US |