1. Field of Invention
The present disclosure relates in general to biometric systems and more particularly, to searching techniques for multiple modalities in a biometric database.
2. Description of Related Art
Biometrics is the science of capturing and analyzing biological data such as, but not limited DNA, fingerprints, eye retinas and irises, voice patterns, facial patterns and hand measurements, for authentication and/or identification purposes. Authentication by biometric verification is becoming increasingly common in corporate and public security systems, consumer electronics and point of sale applications. Identification by biometric matching is increasingly important in law enforcement and national security.
A biometric engine comprises software and/or hardware that controls different components of a biometric system. The biometric engine controls the enrollment, capture, extraction, comparison and matching of biometric data from a user, i.e., client. The biometric engine provides authentication services to client applications and clients, where the identity of one or more clients can be verified or ascertained in a determined population using one or more biometric modalities, e.g., face, finger, retina, palm, voice, etc. A score or probability may be returned by the biometric engine to indicate successful or failed verification or identification without having to send personal information. U.S. Pat. Nos. 7,298,873; 7,362,884; 7,596,246; and 7,606,396; which are all incorporated by reference in their entireties, disclose exemplary biometric systems and biometric engines.
Biometric databases often contain millions of biometric data records. For example, the Integrated Automated Fingerprint Identification System (IAFIS) is a national automated fingerprint identification and criminal history system maintained by the Federal Bureau of Investigation (FBI). IAFIS is the largest biometric database in the world, housing the fingerprints and criminal histories of over 75 million subjects in the criminal master file, 39 million civil prints and fingerprints from 73,000 known and suspected terrorists processed by the U.S. or by international law enforcement agencies. On average, IAFIS receives over 160,000 tenprint fingerprint submissions per day. In large biometric databases, identification of a person needs to be determined in a fast and accurate way, and in real-time. Thus, a need exists for an effective, fast, and efficient technique of database searching in biometric databases.
The present invention provides search techniques for narrower and faster searching of biometric templates in a biometric database. In an embodiment of the invention, a first result set for a first biometric modality in a biometric database is identified, followed by at least a second biometric modality and using the results of the first biometric modality to limit the search scope of the second modality. Searching can also be limited using non-biometric data such as, but not limited to demographic data (e.g., sex, age, and/or any other demographic data) and/or geographic data (city, country, zip code, and/or any other geographic data).
In an embodiment of the invention, a multimodal biometric search method implemented on a biometric engine comprises the steps of: receiving, at a biometric engine, a first biometric probe of a first biometric modality and a second biometric probe of a second biometric modality; comparing the first biometric probe against a set of biometric templates of the first biometric modality; identifying a first subset of matching candidates from the set of biometric templates of the first biometric modality; comparing the second biometric probe against a set of biometric templates of the second biometric modality, wherein the set of biometric templates of the second biometric modality are limited to biometric templates of the second biometric modality associated with the identified first subset of matching candidates from the set of biometric templates of the first biometric modality; and identifying a second subset of matching candidates from the set of biometric templates of the second biometric modality. The method may further comprise the steps of: receiving, at the biometric engine, a third biometric probe of a third biometric modality; comparing the third biometric probe against a set of biometric templates of the third biometric modality, wherein the set of biometric templates of the third biometric modality are limited to biometric templates of the third biometric modality associated with the identified second subset of matching candidates from the set of biometric templates of the second biometric modality; and identifying a third subset of matching candidates from the set of biometric templates of the third biometric modality. The set of biometric templates of the first biometric modality are stored in a first template data cache. The set of biometric templates of the second biometric modality are stored in a second template data cache. The first biometric modality (e.g., fingerprint) is different than the second biometric modality (e.g., iris). The method may further comprise the step of determining the set of biometric templates of the first modality based on a demographic data search, wherein each of the set of biometric templates of the first modality is associated with demographic data. Additionally, the method may further comprise the step of determining the set of biometric templates of the first modality based on a geographic data search, wherein each of the set of biometric templates of the first modality is associated with geographic data. The step of identifying a first subset of matching candidates from the set of biometric templates of the first biometric modality comprises the step of generating a biometric score for each of the set of biometric templates of the first biometric modality and determining whether the biometric score exceeds a predetermined threshold score. The step of identifying a second subset of matching candidates from the set of biometric templates of the second biometric modality comprises the step of generating a biometric score for each of the set of biometric templates of the second biometric modality and determining whether the biometric score exceeds a predetermined threshold score.
The present invention also provides a parallel technique for searching a multi-modal biometric system. Here, biometric inputs (i.e., probes or captures) are acquired for a first and at least a second biometric modality. The first biometric input of a first biometric modality is searched in the biometric database to identify a first subset of the biometric database including one or more matches to the first biometric input. The at least second biometric input of an at least second biometric modality is searched in the biometric database to identify at least second subset of the biometric database including one or more matches to the at least second biometric input. A list is returned of potential biometric matches based on the combination of the first and at least second subset by taking an intersection or union of the at least two subsets.
In another embodiment of the invention, a multimodal biometric search method implemented on a biometric engine comprises the steps of: receiving, at a biometric engine, a first biometric probe of a first biometric modality, a second biometric probe of a second biometric modality, and a third biometric probe of a third biometric modality; comparing the first biometric probe against a set of biometric templates of the first biometric modality; identifying a first subset of matching candidates from the set of biometric templates of the first biometric modality; comparing the second biometric probe against a set of biometric templates of the second biometric modality, wherein the set of biometric templates of the second biometric modality are associated with the set of biometric templates of the first biometric modality; identifying a second subset of matching candidates from the set of biometric templates of the second biometric modality; comparing the third biometric probe against a set of biometric templates of the third biometric modality, wherein the set of biometric templates of the third biometric modality are associated with the set of biometric templates of the first biometric modality; identifying a third subset of matching candidates from the set of biometric templates of the third biometric modality; and identifying a unified set of matching candidates by joining the first subset, second subject, and third subset of matching candidates at intersection points. The steps of identifying a first subset of matching candidates from the set of biometric templates of the first biometric modality, identifying a second subset of matching candidates from the set of biometric templates of the second biometric modality, and identifying a third subset of matching candidates from the set of biometric templates of the third biometric modality are performed in parallel. The method may further comprise storing the set of biometric templates of the first biometric modality in a first template data cache, storing the set of biometric templates of the second biometric modality in a second template data cache, and storing the set of biometric templates of the third biometric modality in a third template data cache. The first, second, and third biometric modalities are different. The method may further comprise determining the set of biometric templates of the first modality based on a demographic data search, wherein each of the set of biometric templates of the first modality is associated with demographic data and/or determining the set of biometric templates of the first modality based on a geographic data search, wherein each of the set of biometric templates of the first modality is associated with geographic data. The step of identifying a first subset of matching candidates from the set of biometric templates of the first biometric modality comprises the step of generating a biometric score for each of the set of biometric templates of the first biometric modality and determining whether the biometric score exceeds a predetermined threshold score. The step of identifying a second subset of matching candidates from the set of biometric templates of the second biometric modality comprises the step of generating a biometric score for each of the set of biometric templates of the second biometric modality and determining whether the biometric score exceeds a predetermined threshold score. The step of identifying a third subset of matching candidates from the set of biometric templates of the third biometric modality comprises the step of generating a biometric score for each of the set of biometric templates of the third biometric modality and determining whether the biometric score exceeds a predetermined threshold score.
The foregoing, and other features and advantages of the invention, will be apparent from the following, more particular description of the preferred embodiments of the invention, the accompanying drawings, and the claims.
For a more complete understanding of the present invention, the objects and advantages thereof, reference is now made to the ensuing descriptions taken in connection with the accompanying drawings briefly described as follows.
Preferred embodiments of the present invention and their advantages may be understood by referring to
As used herein, the following terms have the following definitions:
“Query engine” refers to a system capable of, among other things, comparing biometric templates and returning a biometric score or a biometric fusion score.
“Query router” refers to a device or system that may manage and queue queries in a query engine.
“Biometric fusion score” is any probability score that multiple biometric enrollments of one or more biometric modalities match multiple biometric probes of the same modalities. The scores of each modality are normalized and combined (i.e., fused) to create a single probability score.
“Result set” refers to data returned from a query.
“Biometric data” refers to data that is used to verify or identify a person based on physical traits or behaviors. Examples of biometric data include, but are not limited to digital representations of fingerprints, faces, irises, and other machine-readable data generated by biometric algorithms that are used for biometric enrollment, identity verification, and/or identification.
“Biometric capture” refers to the act of using a biometric input device or system to capture a biometric probe in the form of images, templates, or other form.
“Biometric score (or match score)” refers to a probability score that a given biometric enrollment and a given biometric probe represent the same identity.
“Biometric template” is a piece of binary data generated by a biometric algorithm that is used to compare one biometric against another.
“Metadata” refers to non-biometric data associated with each of the plurality of biometric templates stored in template data cache. Metadata can be used to filter biometric templates that match at least one non-biometric data.
The present invention provides, among other things, a method for nested searching in a multi-modal biometric system. The method includes identifying a first result set for a first biometric modality in a biometric database, followed by the identification of at least a second biometric modality and using the results of the first biometric modality to limit the search scope of the second modality. Searching can also be limited using non-biometric data such as, but not limited to demographic data (e.g., sex, age, and/or any other demographic data) and/or geographic data (city, country, zip code, and/or any other geographic data). A nested search provides a narrower and faster searching process of templates in a biometric database.
The biometric clients 102A-N include computing devices having installed thereon a suitable operating system and a biometric capturing device, the identification and implementation of which is apparent to one of ordinary skill in the art. The biometric clients 102A-N capture one or more biometric probes that may be employed for identity authentication in the real-time biometric system 100.
The biometric clients 102A-N are in communication with the query router 106 via the network 104, which can be accessed through any type of communications protocol such as, but not limited to cellular 3G, cellular 4G, Wi-Fi, WiMax, or landline broadband, among others, the implementation of which are readily apparent to one of ordinary skill in the art. The query router 106 comprises a computer having installed thereon a suitable operating system and biometric software programmed according to the embodiments described herein.
Each query engine 110A-N includes at least one computing device, such as for example a desktop computer, server, or array of computers, each computing device having disk storage, memory, and optionally, processing capabilities, the implementation of all of which are apparent to one of ordinary skill in the art. Each query engine 110A-N includes a respective template data manager software module, herein referred as TDM 112A-N, which manages template data caches 114 where biometric templates are stored and retrieved. Optionally, TDM 112A-N may operate as a separate module of query engines 110A-N. TDM 112A-N may also manage multiple threads to support multiple simultaneous searches and enrollments. The template data manager 112A-N are described in further detail in copending and commonly assigned U.S. patent application Ser. No. 14/254,472, filed on Apr. 16, 2014, and entitled “Real-Time Biometric Database and Template Management,” the disclosure of which is incorporated by reference in its entirety.
In an embodiment of the invention, each query engine 110A-N is associated with one or more template data caches 114, which can be allocated in disk or memory of query engine 110. Each template data cache 114 is operable to store a plurality of biometric templates and associated with a specific type of biometric modality such as fingerprint, iris, or face, among others. In addition, one or more memory maps (not shown) are created in primary memory of query engine 110, where each memory map is associated with one or more template data caches 114. A memory map includes a plurality of biometric templates at any given time, with corresponding primary memory addresses associated with biometric templates copied from template data caches 114.
Following the process, identification (step 206) of a first subset for the first modality is performed. For example, the first subset is identified by comparing each of the submitted biometric probes for the first modality against biometric templates of that modality stored in the biometric database, e.g., template data cache 114, to generate a probability score. Whenever a comparison matches or exceeds a predetermined threshold score, the record is added to the first result set. Subsequently, the first result set from first modality is returned (step 208) in order to continue with the search.
The process 200 continues by identifying (step 210) a second subset for a second modality within the returned first result set. Identification of the second subset is performed by comparing each of the submitted biometric probes for the second modality only against biometric templates of that modality associated with the first result set. Subsequently, the second result set from second modality is returned (step 212).
The process repeats with every single biometric capture, until no more biometric captures are available. Assuming there are a number “n” of modalities, then, identification (step 214) of the “nth” subset for within the “n−1” subset is returned. Subsequently, the last result set or “nth” is returned (step 216), representing a list of potential biometric matches in the nested search.
In an embodiment of the invention, the method of nested searching 200 also combines biometric searches with non-biometric metadata searches. In this modified process, one or more non-biometric characteristics of a person to be identified or verified are identified, followed by developing an index based on the identified one or more non-biometric characteristics. Using non-biometric metadata identifies records to be biometrically searched in the biometric database, by querying the database for records matching the developed index. For example, a first level search is done using fingerprints and a second level search is done using geographic data to narrow the results to a certain country, state, city, zip code and/or any other geographic data. Non-biometric metadata includes, but is not limited to geographic data, demographic data and/or any metadata related to the biometric data.
In another embodiment of the invention, the method of nested searching 200 retains each result set obtained and forwards it into a subsequent result set. In this embodiment, a first step includes retaining the biometric matching results (e.g., probabilities or scores) for each record contained in the first result set (at step 208) of the biometric database, for example by associating the matching results with the second result set (at step 212) or by saving the biometric scoring results (e.g., in memory or a temporary file). Subsequently, the biometric matching results (e.g. probabilities or scores) are retained for each record contained in the second result set of the biometric database, for example by associating the matching results with a subsequent result sets or by saving the biometric scoring results (e.g., in memory or a temporary file). The process may continue for “n” number of modalities within the “n” subset. A final step includes returning the biometric matching results in a single merged result set.
Biometric capture and submission for search 302 begins by capturing (step 202) each biometric modality. The biometric captures, i.e., data, are submitted (step 204) to the biometric engine 116 for search within a defined order of modality search. Biometric engine is preconfigured to determine how to compare (step 312) each biometric modality in a requested order. In another embodiment of the invention, the user or administrator defines the order of modality search.
Subsequently, the search process for biometric modality one 304 begins, where one or more biometric probe templates are created (step 314) using biometric capture for modality one. The biometric probe templates may include 2D face, 3D face, iris, retina, finger vein, palm vein, single fingerprint, fingerprints, scans of the flat of a palm, writers palm, hand geometry, dental records, signature, voice, nuclear DNA, mitochondrial DNA, keystroke, gait, smell, and/or any other biometric feature that can be digitally analyzed.
Continuing the process, all stored templates of type modality one in template data cache 114 are compared (step 316) against the captured biometric probe(s). Query router 106 directs the query to the appropriate query engine 110 for processing depending on the biometric modality. Subsequently, biometric templates in template data cache 114 are compared against the submitted probe(s), resulting in a biometric score for certain templates that meets or exceeds a threshold score. This biometric score along with associated identity is saved (step 208) in the first result set. This first result set from modality one represents possible identity matches. The first result set is returned to the query router 106.
After first result set from modality one is obtained, biometric modality two 306 begins the second search, where one or more biometric probe templates may be created (step 314) using biometric capture for modality two. The biometric probe templates may include 2D face, 3D face, iris, retina, finger vein, palm vein, single fingerprint, fingerprints, scans of the flat of a palm, writers palm, hand geometry, dental records, signature, voice, nuclear DNA, mitochondrial DNA, keystroke, gait, smell, and/or any other biometric feature that can be digitally analyzed. The query router 106 then directs the query to the appropriate query engine 110 for processing depending on the biometric modality.
Continuing the process, the biometric engine retrieves (step 318) a set of modality two biometric templates from template data cache 114, which are limited only to templates of modality two associated with the identities found in first result set. Subsequently, all templates of modality two may be compared against the captured biometric probe(s) for that modality. Whenever a comparison matches or exceeds a predetermined score, the record may be added (step 212) to the second result set. The second result set from modality two is returned and passed to biometric modality three 308 as possible identity matches.
After the second result set from modality two is obtained, biometric modality three 308 begins the process for the third search, where one or more biometric probe templates are created (step 314) using biometric capture for modality three. Biometric probe templates may include 2D face, 3D face, iris, retina, finger vein, palm vein, single fingerprint, fingerprints, scans of the flat of a palm, writers palm, hand geometry, dental records, signature, voice, nuclear DNA, mitochondrial DNA, keystroke, gait, smell, and/or any other biometric feature that can be digitally analyzed. The query router 106 may then direct the query to the appropriate query engine 110 for processing depending on the biometric modality.
Continuing the process, the biometric engine retrieves (step 320) a set of modality three biometric templates from template data cache 114, which are limited only to templates of modality three associated with the identities found in the second result set 212. Subsequently, all templates of modality three are compared against the captured biometric probe(s) for that modality. Whenever a comparison matches or exceeds a predetermined threshold score, the record is added (step 216) to the last result set. The last result set from modality three is returned and passed to completed search 310 module as possible identity matches.
After the last result set is obtained, all possible matches are sorted (step 322) by modality, weight, score or all scores may be fused for each possible identity match and sorted by highest probability, known as biometric fusion score. Finally, matches and final scores are returned (step 324) to query router 106 and to the calling application, respectively.
In this example, the first result set 208 is obtained by comparing the first biometric input modality against biometric templates in template data cache 114 of the same modality. As shown, first result set 208 contains ten records. However, first result set 208 may contain any number of records as long as the query conditions are met. In this example, the first modality to be compared is face and a minimum score of seventy (70) is the threshold score to include a record in first result set 208.
The second result set 212 is obtained by comparing the second biometric input modality against templates of the same modality associated with the identities returned in first result set 208. In this example, second result set 212 contains five records. However, second result set 212 may contain any number of records as long as the query conditions are met. In this example, the second modality to be compared is iris and a minimum score of eighty (80) is the threshold score to include a record in second result set 212. The iris modality is only compared to iris templates associated with the ten identities returned in first result set 208.
Last result set 216 is obtained by comparing the third biometric input modality against templates of the same modality associated with the identities returned in second result set 212. As shown, last result set 216 contains two records. However, last result set 216 may contain any number of records as long as the query conditions are met. The third modality to be compared is finger and a minimum score of ninety (90) is the threshold score to include a record in last result set 216. Finger modality is only compared with finger templates associated with the 5 identities returned in second result set 212.
In another exemplary use of the present invention, an unknown person requires authentication against a biometric database. A first biometric modality for the person is captured and compared against templates of the same modality stored in a biometric database to return a first result set 208 that contains two results. A second level of nested search is applied using demographic/non-biometric data such as sex. A second result set 212 is returned containing a single result that verifies the identity of the person.
The present invention also provides a parallel technique for searching a multi-modal biometric system. Here, biometric inputs (i.e., probes or captures) are acquired for a first and at least a second biometric modality. The first biometric input of a first biometric modality is searched in the biometric database to identify a first subset of the biometric database including one or more matches to the first biometric input. The at least second biometric input of an at least second biometric modality is searched in the biometric database to identify at least second subset of the biometric database including one or more matches to the at least second biometric input. A list is returned of potential biometric matches based on the combination of the first and at least second subset by taking an intersection or union of the at least two subsets.
Continuing the process, a first subset for first modality is identified (step 606). Identification of a first subset is performed by comparing each of the submitted biometric probes for the first modality against biometric templates of that modality stored in template data caches 114 to generate a probability score for each template. Whenever a comparison matches or exceeds a predetermined threshold score, the record is added to a result set for the first modality. In an embodiment of the invention, the result set is a list of “n” number of records with the highest scores. In parallel, identification of a second subset for a second modality is performed (step 608). Identification of the second subset is performed by comparing each of the submitted biometric probes for the second modality against biometric templates of that modality stored in the biometric database to generate a probability score for each template. Whenever a comparison matches or exceeds a predetermined threshold score, the record is added to a result set for the second modality. In an embodiment of the invention, the result sets for each modality may be a list of “n” number of records with the highest scores. The process also identifies (step 610) “n” number of subsets for each of an “n” number of modalities in parallel.
After all modalities have been matched, a unified result set is returned (step 612). The unified result set is formed by joining all the result sets together at their intersection points (e.g., record identification number, unique identifiers, etc.), meaning that if a record exists in all the result sets for each modality, that particular record is added to the unified result set. The unified result set represents a list of potential biometric matches in the biometric search. In another embodiment of the invention, the method of biometric search 600 is also used to exclude individuals from the unified result set, in which case, all other records except the ones that exist in all the result sets for each modality are deleted from the unified result set.
In an embodiment of the invention, the method of biometric searching 600 combines biometric searches with non-biometric metadata searches. In this process, a first step includes the identification of one or more non-biometric characteristics of a person to be identified or verified, followed by developing an index based on the identified one or more non-biometric characteristics. The index is associated with biometric templates stored in template data cache 114 depending on non-biometric traits associated with that biometric template. For example, a biometric template is associated with an index pertaining to a geographic location such as a city or country from where the individual associated with that biometric template lives. Finally, the method of biometric searching 200 using non-biometric metadata identifies records to be biometrically searched in the biometric database, by querying the database for records matching the developed index. For example, a first level search is performed using geographic data to narrow the results to a certain country, state, city, zip code, and/or any other geographic data and a second level search may be done using fingerprints, iris and face. Non-biometric metadata includes geographic data, demographic data, and/or any metadata related to the biometric data.
The conditions or thresholds for each modality matching may be the same or may be vary for each modality.
Subsequently, the search process for biometric modality one 704, biometric modality two 706 and biometric modality three 708 are performed (in parallel), where one or more biometric probe templates may be created (step 714) using biometric capture devices for each modality type. Biometric probe templates may include 2D face, 3D face, iris, retina, finger vein, palm vein, single fingerprint, fingerprints, scans of the flat of a palm, writers palm, hand geometry, dental records, signature, voice, nuclear DNA, mitochondrial DNA, keystroke, gait, smell and/or any other biometric feature that can be digitally analyzed.
Continuing the process, all templates are compared (step 716) against the captured probe(s) for each modality in template data cache 114, resulting in a biometric score for each template. Query router 106 directs the query to the appropriate query engine 110 for processing depending on the biometric modality. If the biometric score meets a certain condition such as a threshold, the score along with associated identity is saved (step 718) in a result set for that modality. The result set is returned to query router 106.
After all modalities are processed, all possible matches are merged (step 720) into a single subset at their intersection points. Finally, matches and final scores are returned (step 722) to query router 106 and to the calling application respectively.
Each record may contain a field that uniquely identifies an individual and their related biometrics (e.g., a unique identification number).
Referring again to
Unified result set 612 is obtained by combining the result sets for all the biometric modalities previously compared at their intersection points.
As another example, an unknown person may require authentication against a biometric database. A first biometric modality for the person is captured and compared against templates of the same modality stored in template data caches 114 to return a first result set that contains two records, with unique identifier numbers of 10 and 15, respectively. The biometric threshold for the first modality is set to return records that score greater than 90. A second biometric modality for the person is captured and compared against templates of that modality stored in a template data cache 114 to return a second result set that contains a single record, with a unique identifier number of 15. The biometric threshold for the second modality is set to return records that score greater than 95. The result sets for both modalities are combined into a unified result set 212 using their intersection points. The unified result set 612 returns the record with ID 15 because it is the only record contained on both of the individual result sets for both modalities.
One of ordinary skill in the art appreciates that the various illustrative logical blocks, modules, units, and algorithm steps described in connection with the embodiments disclosed herein can often be implemented as electronic hardware, computer software, or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular constraints imposed on the overall system Skilled persons can implement the described functionality in varying ways for each particular system, but such implementation decisions should not be interpreted as causing a departure from the scope of the invention. In addition, the grouping of functions within a unit, module, block, or step is for ease of description. Specific functions or steps can be moved from one unit, module, or block without departing from the invention.
The various illustrative logical blocks, units, steps and modules described in connection with the embodiments disclosed herein, and those provided in the accompanying documents, can be implemented or performed with a processor, such as a general purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general-purpose processor can be a microprocessor, but in the alternative, the processor can be any processor, controller, microcontroller, or state machine. A processor can also be implemented as a combination of computing devices, for example, a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
The steps of a method or algorithm and the processes of a block or module described in connection with the embodiments disclosed herein can be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. A software module can reside in RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, a removable disk, a CD-ROM, or any other form of storage medium. An exemplary storage medium can be coupled to the processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium can be integral to the processor. The processor and the storage medium can reside in an ASIC. Additionally, device, blocks, or modules that are described as coupled may be coupled via intermediary device, blocks, or modules. Similarly, a first device may be described a transmitting data to (or receiving from) a second device when there are intermediary devices that couple the first and second device and also when the first device is unaware of the ultimate destination of the data.
The invention has been described herein using specific embodiments for the purposes of illustration only. It will be readily apparent to one of ordinary skill in the art, however, that the principles of the invention can be embodied in other ways. Therefore, the invention should not be regarded as being limited in scope to the specific embodiments disclosed herein.
The present application claims priority to U.S. Provisional Patent Application No. 61/812,589, filed on Apr. 16, 2013, and entitled “Nested Searching for Multi-Modal Biometric Database;” and U.S. Provisional Patent Application No. 61/812,613, filed on Apr. 16, 2013, and entitled “Searching Method for Multi-Modal Biometric Database,” the disclosures of which are herein incorporated by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
5704029 | Wright, Jr. | Dec 1997 | A |
5963136 | O'Brien | Oct 1999 | A |
6014427 | Hanson et al. | Jan 2000 | A |
6095985 | Raymond et al. | Aug 2000 | A |
6112049 | Sonnenfeld | Aug 2000 | A |
6138158 | Boyle et al. | Oct 2000 | A |
6219694 | Lazaridis et al. | Apr 2001 | B1 |
6256666 | Singhal | Jul 2001 | B1 |
6298231 | Heinz | Oct 2001 | B1 |
6333973 | Smith et al. | Dec 2001 | B1 |
6463462 | Smith et al. | Oct 2002 | B1 |
6463464 | Lazaridis et al. | Oct 2002 | B1 |
6487401 | Suryanarayana et al. | Nov 2002 | B2 |
6594349 | Fortman | Jul 2003 | B2 |
6610105 | Martin, Jr. et al. | Aug 2003 | B1 |
6631400 | DiStefano, III | Oct 2003 | B1 |
6721578 | Minear et al. | Apr 2004 | B2 |
6767211 | Hall et al. | Jul 2004 | B2 |
6769009 | Reisman | Jul 2004 | B1 |
6807254 | Guedalia et al. | Oct 2004 | B1 |
6826614 | Hanmann et al. | Nov 2004 | B1 |
6873688 | Aarnio | Mar 2005 | B1 |
6889054 | Himmel et al. | May 2005 | B2 |
6898569 | Bansal et al. | May 2005 | B1 |
6961327 | Niu | Nov 2005 | B2 |
6968178 | Pradhan et al. | Nov 2005 | B2 |
6978118 | Vesikivi et al. | Dec 2005 | B2 |
6987945 | Corn et al. | Jan 2006 | B2 |
7002476 | Rapchak | Feb 2006 | B2 |
7058036 | Yu et al. | Jun 2006 | B1 |
7076244 | Lazaridis et al. | Jul 2006 | B2 |
7113977 | Baker et al. | Sep 2006 | B1 |
7133506 | Smith | Nov 2006 | B1 |
7293019 | Dumais et al. | Nov 2007 | B2 |
7835548 | Langley | Nov 2010 | B1 |
20010037264 | Husemann et al. | Nov 2001 | A1 |
20010047294 | Rothschild | Nov 2001 | A1 |
20010054108 | Lincoln et al. | Dec 2001 | A1 |
20020006793 | Kun-Szabo et al. | Jan 2002 | A1 |
20020006826 | Hansted | Jan 2002 | A1 |
20020015403 | McConnell et al. | Feb 2002 | A1 |
20020021696 | Minborg | Feb 2002 | A1 |
20020032595 | Hundscheidt et al. | Mar 2002 | A1 |
20020034292 | Tuoriniemi et al. | Mar 2002 | A1 |
20020052198 | Savilaakso | May 2002 | A1 |
20020052841 | Guthrie et al. | May 2002 | A1 |
20020054090 | Silva et al. | May 2002 | A1 |
20020055872 | LaBrie et al. | May 2002 | A1 |
20020057678 | Jiang et al. | May 2002 | A1 |
20020065097 | Brockenbrough et al. | May 2002 | A1 |
20020077076 | Suryanarayana et al. | Jun 2002 | A1 |
20020077080 | Greene | Jun 2002 | A1 |
20020077876 | O'Meara et al. | Jun 2002 | A1 |
20020083127 | Agrawal | Jun 2002 | A1 |
20020087596 | Lewontin | Jul 2002 | A1 |
20020087643 | Parsons et al. | Jul 2002 | A1 |
20020091797 | Wallenius et al. | Jul 2002 | A1 |
20020095465 | Banks et al. | Jul 2002 | A1 |
20020099544 | Levitt et al. | Jul 2002 | A1 |
20020099545 | Levitt et al. | Jul 2002 | A1 |
20020107002 | Duncan et al. | Aug 2002 | A1 |
20020107985 | Hwang et al. | Aug 2002 | A1 |
20020115456 | Narinen et al. | Aug 2002 | A1 |
20020119793 | Hronek et al. | Aug 2002 | A1 |
20020123335 | Luna et al. | Sep 2002 | A1 |
20020126708 | Skog et al. | Sep 2002 | A1 |
20020128001 | Shuttleworth | Sep 2002 | A1 |
20020137525 | Fleischer et al. | Sep 2002 | A1 |
20020141560 | Khayatan et al. | Oct 2002 | A1 |
20020142763 | Kolsky | Oct 2002 | A1 |
20020145043 | Challa et al. | Oct 2002 | A1 |
20020155848 | Suryanarayana | Oct 2002 | A1 |
20020159569 | Hasegawa | Oct 2002 | A1 |
20020169604 | Damiba et al. | Nov 2002 | A1 |
20020169605 | Damiba et al. | Nov 2002 | A1 |
20020169611 | Guerra et al. | Nov 2002 | A1 |
20020169613 | Damiba | Nov 2002 | A1 |
20020169614 | Fitzpatrick et al. | Nov 2002 | A1 |
20020173961 | Guerra | Nov 2002 | A1 |
20020174068 | Marsot | Nov 2002 | A1 |
20020174248 | Morriss | Nov 2002 | A1 |
20020174346 | Ting | Nov 2002 | A1 |
20020176379 | Wallenius et al. | Nov 2002 | A1 |
20020184033 | Fitzpatrick et al. | Dec 2002 | A1 |
20020184391 | Phillips | Dec 2002 | A1 |
20020186845 | Dutta et al. | Dec 2002 | A1 |
20020187775 | Corrigan et al. | Dec 2002 | A1 |
20020188443 | Reddy et al. | Dec 2002 | A1 |
20020188451 | Guerra et al. | Dec 2002 | A1 |
20020188714 | Bouthors | Dec 2002 | A1 |
20020191795 | Wills | Dec 2002 | A1 |
20020193997 | Fitzpatrick et al. | Dec 2002 | A1 |
20020194331 | Lewis et al. | Dec 2002 | A1 |
20030003898 | Banerjee et al. | Jan 2003 | A1 |
20030006912 | Brescia | Jan 2003 | A1 |
20030013433 | alSafadi | Jan 2003 | A1 |
20030115152 | Flaherty | Jun 2003 | A1 |
20030135097 | Wiederhold | Jul 2003 | A1 |
20030142039 | Minear et al. | Jul 2003 | A1 |
20040034544 | Fields et al. | Feb 2004 | A1 |
20040133582 | Howard | Jul 2004 | A1 |
20040254836 | Emoke Barabas et al. | Dec 2004 | A1 |
20060031337 | Kim | Feb 2006 | A1 |
20060075019 | Donovan et al. | Apr 2006 | A1 |
20060104485 | Miller | May 2006 | A1 |
20060171571 | Chan | Aug 2006 | A1 |
20060179072 | Eves et al. | Aug 2006 | A1 |
20060240851 | Washburn | Oct 2006 | A1 |
20060256130 | Gonzalez | Nov 2006 | A1 |
20070100648 | Borquez et al. | May 2007 | A1 |
20080159598 | Iasso | Jul 2008 | A1 |
20080181465 | Sauerwein | Jul 2008 | A1 |
20090289760 | Murakami | Nov 2009 | A1 |
20100312763 | Peirce | Dec 2010 | A1 |
20110032076 | Rickman | Feb 2011 | A1 |
20110191329 | Petrov | Aug 2011 | A1 |
20110211735 | Langley | Sep 2011 | A1 |
20120078886 | Dinerstein | Mar 2012 | A1 |
Number | Date | Country |
---|---|---|
02087267 | Oct 2002 | WO |
03015430 | Feb 2003 | WO |
Number | Date | Country | |
---|---|---|---|
20140314283 A1 | Oct 2014 | US |
Number | Date | Country | |
---|---|---|---|
61812589 | Apr 2013 | US | |
61812613 | Apr 2013 | US |