PROCESS FOR UPDATING TEMPLATES USED IN FACIAL RECOGNITION
Templates used for a facial recognition process for authentication of a user to use a device may be updated by the device as features of the user change over time. Features of the user may gradually change over time due to changes such as facial hair changes, haircuts, gaining/losing weight, and/or aging. Updating the templates used for the facial recognition process may allow the user to continue being authenticated as features of the user change without the need for additional enrollments of the user.
This patent claims priority to U.S. patent application Ser. No. 15/881,261, filed Jan. 26, 2018, now U.S. Pat. No. 10,503,992, which claims priority to U.S. Provisional Patent Application No. 62/539,739 to Mostafa et al., entitled “ONLINE LEARNING TO UPDATE TEMPLATES USED IN FACIAL RECOGNITION FOR CHANGES IN THE USER”, filed Aug. 1, 2017 and to U.S. Provisional Patent Application No. 62/556,850 to Mostafa et al., entitled “PROCESS FOR UPDATING TEMPLATES USED IN FACIAL RECOGNITION”, filed Sep. 11, 2017, both of which are incorporated by reference in their entirety.
BACKGROUND 1. Technical FieldEmbodiments described herein relate to methods and systems for face detection and recognition in images captured by a camera on a device.
2. Description of Related ArtBiometric authentication processes are being used more frequently to allow users to more readily access their devices without the need for passcode or password authentication. One example of a biometric authentication process is fingerprint authentication using a fingerprint sensor. Facial recognition is another biometric process that may be used for authentication of an authorized user of a device. Facial recognition processes are generally used to identify individuals in an image and/or compare individuals in images to a database of individuals to match the faces of individuals.
For authentication using facial recognition, the facial recognition system generally struggles to adapt to changes in the authorized user's facial features over time so that the user may continue to access the device using facial recognition even as facial features of the user change and create differences in images of the user. For example, the user's facial features may change over time due to facial hair changes, haircuts, gaining/losing weight, and/or aging. The facial recognition system, however, needs to remain secure. Thus, challenges balancing the need to adapt to the changes while also ensuring that the differences are recognized as changes in the user and not differences between the user and another person to inhibit unwanted access to the device generally preclude adaptation.
SUMMARYTemplates for facial recognition may be generated from enrollment images of the user obtained by a camera associated with a device. Images to be used for enrollment may be selected from the images captured during an enrollment process based on having certain acceptable criteria (e.g., pose is proper, not much occlusion of user, user in field of view, eyes are not closed, etc.). The selected enrollment images may be encoded to generate templates, where the templates include feature vectors to describe the facial features of the user.
When the user attempts to gain access to the device using facial recognition authentication, a captured image of the user may be encoded to generate feature vectors for an “unlock” image (e.g., an image captured to unlock the device). The feature vectors for the unlock image may be compared to the templates to determine if the unlock image matches the user's image represented by the templates. For example, a matching score may be assessed by comparing the feature vectors generated from the unlock image to the feature vectors in the templates. The matching score may be higher the less distance there is between the feature vectors for the unlock image and the feature vectors in the templates in the feature space (e.g., the matching score is higher when the feature vectors are more similar). If the matching score is above a threshold value, the device is unlocked.
In certain embodiments, when the device is unlocked, the features vectors of the unlock image are added as a temporary template in an additional (e.g., backup) storage space of the device. In some embodiments, the temporary template is only added if the matching score for the unlock image is above a second threshold value that is above the unlock threshold (e.g., adding the temporary template requires a closer match than unlocking the device).
Once the temporary template is stored in the storage space, it may be compared to additional unlock images obtained during attempted unlocking of the device. If the temporary template continues to match the additional unlock attempt images for a certain number or percentage of unlock attempts, the temporary template may be added to the templates (e.g., the template space) created from the enrollment images based on the confidence in the temporary template.
Features and advantages of the methods and apparatus of the embodiments described in this disclosure will be more fully appreciated by reference to the following detailed description of presently preferred but nonetheless illustrative embodiments in accordance with the embodiments described in this disclosure when taken in conjunction with the accompanying drawings in which:
While embodiments described in this disclosure may be susceptible to various modifications and alternative forms, specific embodiments thereof are shown by way of example in the drawings and will herein be described in detail. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the embodiments to the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents and alternatives falling within the spirit and scope of the appended claims. The headings used herein are for organizational purposes only and are not meant to be used to limit the scope of the description. As used throughout this application, the word “may” is used in a permissive sense (i.e., meaning having the potential to), rather than the mandatory sense (i.e., meaning must). Similarly, the words “include”, “including”, and “includes” mean including, but not limited to.
Various units, circuits, or other components may be described as “configured to” perform a task or tasks. In such contexts, “configured to” is a broad recitation of structure generally meaning “having circuitry that” performs the task or tasks during operation. As such, the unit/circuit/component can be configured to perform the task even when the unit/circuit/component is not currently on. In general, the circuitry that forms the structure corresponding to “configured to” may include hardware circuits and/or memory storing program instructions executable to implement the operation. The memory can include volatile memory such as static or dynamic random access memory and/or nonvolatile memory such as optical or magnetic disk storage, flash memory, programmable read-only memories, etc. The hardware circuits may include any combination of combinatorial logic circuitry, clocked storage devices such as flops, registers, latches, etc., finite state machines, memory such as static random access memory or embedded dynamic random access memory, custom designed circuitry, programmable logic arrays, etc. Similarly, various units/circuits/components may be described as performing a task or tasks, for convenience in the description. Such descriptions should be interpreted as including the phrase “configured to.” Reciting a unit/circuit/component that is configured to perform one or more tasks is expressly intended not to invoke 35 U.S.C. § 112(f) interpretation for that unit/circuit/component.
In an embodiment, hardware circuits in accordance with this disclosure may be implemented by coding the description of the circuit in a hardware description language (HDL) such as Verilog or VHDL. The HDL description may be synthesized against a library of cells designed for a given integrated circuit fabrication technology, and may be modified for timing, power, and other reasons to result in a final design database that may be transmitted to a foundry to generate masks and ultimately produce the integrated circuit. Some hardware circuits or portions thereof may also be custom-designed in a schematic editor and captured into the integrated circuit design along with synthesized circuitry. The integrated circuits may include transistors and may further include other circuit elements (e.g. passive elements such as capacitors, resistors, inductors, etc.) and interconnect between the transistors and circuit elements. Some embodiments may implement multiple integrated circuits coupled together to implement the hardware circuits, and/or discrete elements may be used in some embodiments.
The scope of the present disclosure includes any feature or combination of features disclosed herein (either explicitly or implicitly), or any generalization thereof, whether or not it mitigates any or all of the problems addressed herein. Accordingly, new claims may be formulated during prosecution of this application (or an application claiming priority thereto) to any such combination of features. In particular, with reference to the appended claims, features from dependent claims may be combined with those of the independent claims and features from respective independent claims may be combined in any appropriate manner and not merely in the specific combinations enumerated in the appended claims.
DETAILED DESCRIPTION OF EMBODIMENTSThis specification includes references to “one embodiment” or “an embodiment.” The appearances of the phrases “in one embodiment” or “in an embodiment” do not necessarily refer to the same embodiment, although embodiments that include any combination of the features are generally contemplated, unless expressly disclaimed herein. Particular features, structures, or characteristics may be combined in any suitable manner consistent with this disclosure.
The present disclosure further contemplates that the entities responsible for the collection, analysis, disclosure, transfer, storage, or other use of such personal information data will comply with well-established privacy policies and/or privacy practices. In particular, such entities should implement and consistently use privacy policies and practices that are generally recognized as meeting or exceeding industry or governmental requirements for maintaining personal information data private and secure. For example, in the case of unlocking and/or authorizing devices using facial recognition, personal information from users should be collected for legitimate and reasonable uses of the entity and not shared or sold outside of those legitimate uses. Further, such collection should occur only after receiving the informed consent of the users. Additionally, such entities would take any needed steps for safeguarding and securing access to such personal information data and ensuring that others with access to the personal information data adhere to their privacy policies and procedures. Further, such entities can subject themselves to evaluation by third parties to certify their adherence to widely accepted privacy policies and practices.
Despite the foregoing, the present disclosure also contemplates embodiments in which users selectively block the use of, or access to, personal information data. That is, the present disclosure contemplates that hardware and/or software elements can be provided to prevent or block access to such personal information data. For example, the present technology can be configured to allow users to select to “opt in” or “opt out” of participation in the collection of personal information data during registration for services.
Camera 102 may be used to capture images of the external environment of device 100. In certain embodiments, camera 102 is positioned to capture images in front of display 108. Camera 102 may be positioned to capture images of the user (e.g., the user's face) while the user interacts with display 108.
In certain embodiments, camera 102 includes image sensor 103. Image sensor 103 may be, for example, an array of sensors. Sensors in the sensor array may include, but not be limited to, charge coupled device (CCD) and/or complementary metal oxide semiconductor (CMOS) sensor elements to capture infrared images (IR) or other non-visible electromagnetic radiation. In some embodiments, camera 102 includes more than one image sensor to capture multiple types of images. For example, camera 102 may include both IR sensors and RGB (red, green, and blue) sensors. In certain embodiments, camera 102 includes illuminators 105 for illuminating surfaces (or subjects) with the different types of light detected by image sensor 103. For example, camera 102 may include an illuminator for visible light (e.g., a “flash illuminator) and/or illuminators for infrared light (e.g., a flood IR source and a speckle pattern projector). In some embodiments, the flood IR source and speckle pattern projector are other wavelengths of light (e.g., not infrared). In certain embodiments, illuminators 105 include an array of light sources such as, but not limited to, VCSELs (vertical-cavity surface-emitting lasers). In some embodiments, image sensors 103 and illuminators 105 are included in a single chip package. In some embodiments, image sensors 103 and illuminators 105 are located on separate chip packages.
In certain embodiments, image sensor 103 is an IR image sensor used to capture infrared images used for face detection and/or depth detection. For face detection, illuminator 105A may provide flood IR illumination to flood the subject with IR illumination (e.g., an IR flashlight) and image sensor 103 may capture images of the flood IR illuminated subject. Flood IR illumination images may be, for example, two-dimensional images of the subject illuminated by IR light. For depth detection or generating a depth map image, illuminator 105B may provide IR illumination with a speckle pattern. The speckle pattern may be a pattern of light spots (e.g., a pattern of dots) with a known, and controllable, configuration and pattern projected onto a subject. Illuminator 105B may include a VCSEL array configured to form the speckle pattern or a light source and patterned transparency configured to form the speckle pattern. The configuration and pattern of the speckle pattern provided by illuminator 105B may be selected, for example, based on a desired speckle pattern density (e.g., dot density) at the subject. Image sensor 103 may capture images of the subject illuminated by the speckle pattern. The captured image of the speckle pattern on the subject may be assessed (e.g., analyzed and/or processed) by an imaging and processing system (e.g., an image signal processor (ISP) as described herein) to produce or estimate a three-dimensional map of the subject (e.g., a depth map or depth map image of the subject). Examples of depth map imaging are described in U.S. Pat. No. 8,150,142 to Freedman et al., U.S. Pat. No. 8,749,796 to Pesach et al., and U.S. Pat. No. 8,384,997 to Shpunt et al., which are incorporated by reference as if fully set forth herein, and in U.S. Patent Application Publication No. 2016/0178915 to Mor et al., which is incorporated by reference as if fully set forth herein.
In certain embodiments, images captured by camera 102 include images with the user's face (e.g., the user's face is included in the images). An image with the user's face may include any digital image with the user's face shown within the frame of the image. Such an image may include just the user's face or may include the user's face in a smaller part or portion of the image. The user's face may be captured with sufficient resolution in the image to allow image processing of one or more features of the user's face in the image.
Images captured by camera 102 may be processed by processor 104.
In certain embodiments, processor 104 includes image signal processor (ISP) 110. ISP 110 may include circuitry suitable for processing images (e.g., image signal processing circuitry) received from camera 102. ISP 110 may include any hardware and/or software (e.g., program instructions) capable of processing or analyzing images captured by camera 102.
In certain embodiments, processor 104 includes secure enclave processor (SEP) 112. In some embodiments, SEP 112 is involved in a facial recognition authentication process involving images captured by camera 102 and processed by ISP 110. SEP 112 may be a secure circuit configured to authenticate an active user (e.g., the user that is currently using device 100) as authorized to use device 100. A “secure circuit” may be a circuit that protects an isolated, internal resource from being directly accessed by an external circuit. The internal resource may be memory (e.g., memory 106) that stores sensitive data such as personal information (e.g., biometric information, credit card information, etc.), encryptions keys, random number generator seeds, etc. The internal resource may also be circuitry that performs services/operations associated with sensitive data. As described herein, SEP 112 may include any hardware and/or software (e.g., program instructions) capable of authenticating a user using the facial recognition authentication process. The facial recognition authentication process may authenticate a user by capturing images of the user with camera 102 and comparing the captured images to previously collected images of an authorized user for device 100. In some embodiments, the functions of ISP 110 and SEP 112 may be performed by a single processor (e.g., either ISP 110 or SEP 112 may perform both functionalities and the other processor may be omitted).
In certain embodiments, processor 104 performs an enrollment process (e.g., image enrollment process 200, as shown in
In some embodiments, camera module 102 captures multiple pairs of images for a facial recognition session. Each pair may include an image captured using a two-dimensional capture mode (e.g., a flood IR image) and an image captured using a three-dimensional capture mode (e.g., a depth map image). In certain embodiments, ISP 110 and/or SEP 112 process the flood IR images and depth map images independently of each other before a final authentication decision is made for the user. For example, ISP 110 may process the images independently to determine characteristics of each image separately. SEP 112 may then compare the separate image characteristics with stored template images for each type of image to generate an authentication score (e.g., a matching score or other ranking of matching between the user in the captured image and in the stored template images) for each separate image. The authentication scores for the separate images (e.g., the flood IR and depth map images) may be combined to make a decision on the identity of the user and, if authenticated, allow the user to use device 100 (e.g., unlock the device).
In some embodiments, ISP 110 and/or SEP 112 combine the images in each pair to provide a composite image that is used for facial recognition. In some embodiments, ISP 110 processes the composite image to determine characteristics of the image, which SEP 112 may compare with the stored template images to make a decision on the identity of the user and, if authenticated, allow the user to use device 100.
In some embodiments, the combination of flood IR image data and depth map image data may allow for SEP 112 to compare faces in a three-dimensional space. In some embodiments, camera module 102 communicates image data to SEP 112 via a secure channel. The secure channel may be, for example, either a dedicated path for communicating data (i.e., a path shared by only the intended participants) or a dedicated path for communicating encrypted data using cryptographic keys known only to the intended participants. In some embodiments, camera module 102 and/or ISP 110 may perform various processing operations on image data before supplying the image data to SEP 112 in order to facilitate the comparison performed by the SEP.
In certain embodiments, processor 104 operates one or more machine learning models. Machine learning models may be operated using any combination of hardware and/or software (e.g., program instructions) located in processor 104 and/or on device 100. In some embodiments, one or more neural network modules 114 are used to operate the machine learning models on device 100. Neural network modules 114 may be located in ISP 110 and/or SEP 112.
Neural network module 114 may include any combination of hardware and/or software (e.g., program instructions) located in processor 104 and/or on device 100. In some embodiments, neural network module 114 is a multi-scale neural network or another neural network where the scale of kernels used in the network can vary. In some embodiments, neural network module 114 is a recurrent neural network (RNN) such as, but not limited to, a gated recurrent unit (GRU) recurrent neural network or a long short-term memory (LSTM) recurrent neural network.
Neural network module 114 may include neural network circuitry installed or configured with operating parameters that have been learned by the neural network module or a similar neural network module (e.g., a neural network module operating on a different processor or device). For example, a neural network module may be trained using training images (e.g., reference images) and/or other training data to generate operating parameters for the neural network circuitry. The operating parameters generated from the training may then be provided to neural network module 114 installed on device 100. Providing the operating parameters generated from training to neural network module 114 on device 100 allows the neural network module to operate using training information programmed into the neural network module (e.g., the training-generated operating parameters may be used by the neural network module to operate on and assess images captured by the device).
In certain embodiments, process 200 is used when device 100 is used a first time by the authorized user and/or when the user opts to enroll in a facial recognition process. For example, process 200 may be initiated when device 100 is first obtained by the authorized user (e.g., purchased by the authorized user) and turned on for the first time by the authorized user. In some embodiments, process 200 may be initiated by the authorized user when the user desires to enroll in a facial recognition process, update security settings for device 100, and/or re-enroll.
In certain embodiments, process 200 begins with authenticating the user in 202. In 202, the user may be authenticated on device 100 using a non-facial authentication process. For example, the user may be authenticated as an authorized user by entering a passcode, entering a password, or using another user authentication protocol other than facial recognition. After the user is authenticated in 202, one or more enrollment (e.g., reference or registration) images of the user are captured in 204. The enrollment images may include images of the user illuminated by flood illuminator 105A (e.g., flood IR images) and/or images of the user illuminated by speckle illuminator 105B (e.g., depth map images). As described herein, flood IR images and depth map images may be used independently and/or in combination in facial recognition processes on device 100 (e.g. the images may independently be used to provide an authentication decision and the decisions may be combined to determine a final decision on user authentication).
The enrollment images may be captured using camera 102 as the user interacts with device 100. For example, the enrollment images may be captured as the user follows prompts on display 108 of device 100. The prompts may include instructions for the user to make different motions and/or poses while the enrollment images are being captured. During 204, camera 102 may capture multiple images for each motion and/or pose performed by the user. Capturing images for different motions and/or different poses of the user where the images still have a relatively clear depiction of the user may be useful in providing a better variety of enrollment images that enable the user to be authenticated without having to be in a limited or restricted position relative to camera 102 on device 100.
After the multiple enrollment images are captured in 204, selection of enrollment images for further image processing may be made in 206. Selection of enrollment images 206, and further processing of the images, may be performed by ISP 110 and/or SEP 112. Selection of enrollment images for further processing may include selecting images that are suitable for use as template images. For example, the selection of images that are suitable for use as template images in 206 may include assessing one or more selected criteria for the images and selecting images that meet the selected criteria. The selected images may be used as template images for the user. Selected criteria may include, but not be limited to, the face of the user being in the field of view of the camera, a pose of the user being proper (e.g., the user's face is not turned to far in any direction from the camera (i.e., the pitch, yaw, and/or roll of the face are not above certain levels) a distance to the face of the user being within a certain distance, the face of the user having occlusion below a minimum value (e.g., the user's face is not occluded (blocked) more than a minimum amount by another object), the user paying attention to the camera (e.g., eyes of the user looking at the camera), eyes of the user not being closed, and proper lighting (illumination) in the image. In some embodiments, if more than one face is detected in an enrollment image, the enrollment image is rejected and not used (e.g., not selected) for further processing. Selection of images suitable for further processing may be rule based on the images meeting a certain number of the selected criteria or all of the selected criteria. In some embodiments, occlusion maps and/or landmark feature maps are used in identifying features of the user (e.g., facial features such as eyes, nose, and mouth) in the images and assessing the selected criteria in the images.
After images are selected in 206, features of the user in the selected (template) images may be encoded in 208. Encoding of the selected images may include encoding features (e.g., facial features) of the user to define the features in the images as one or more feature vectors in a feature space. Feature vectors 210 may be the output of the encoding in 208. A feature space may be an n-dimensional feature space. A feature vector may be an n-dimensional vector of numerical values that define features from the image in the feature space (e.g., the feature vector may be a vector of numerical values that define facial features of the user in the image).
As shown in
Static templates 216 may thus be enrollment templates (or reference templates) generated by enrollment process 200. After enrollment process 200 is completed, a selected number of static templates 216 are stored in static portion 222 of template space 220. The number of static templates 216 stored in static portion 222 after enrollment process 200 may vary depending on, for example, the number of different feature vectors obtained during the enrollment process, which may be based on the number of images selected to be suitable for use as template images, or a desired number of templates for the device. After enrollment process 200, static templates 216 include feature vectors 210 (e.g., the enrollment or reference feature vectors) that can be used for facial recognition of the authorized user. Template space 220 may then be used in a facial recognition authentication process.
In 252, camera 102 captures an image of the face of the user attempting to be authenticated for access to device 100 (e.g., the camera captures an “unlock attempt” image of the user). It is to be understood that the unlock attempt image may be a single image of the face of the user (e.g., a single flood IR image or single depth map image) or the unlock attempt image may be a series of several images of the face of the user taken over a short period of time (e.g., one second or less). In some embodiments, the series of several images of the face of the user includes pairs of flood IR images and depth map images (e.g., pairs of consecutive flood IR and depth map images). In some implementations, the unlock attempt image may be a composite of several images of the user illuminated by the flood illuminator and the speckle pattern illuminator.
Camera 102 may capture the unlock attempt image in response to a prompt by the user. For example, the unlock attempt image may be captured when the user attempts to access to device 100 by pressing a button (e.g., a home button or virtual button) on device 100, by moving the device into a selected position relative to the user's face (e.g., the user moves the device such that the camera is pointed directly at the user's face), and/or by making a specific gesture or movement with respect to the device. It is to be understood that, as described herein, unlock attempt images may include either flood IR images or depth map images, or a combination thereof. Further, the unlock attempt images may be processed in association with their corresponding template (e.g., flood IR images with a template for flood IR enrollment images) independently or in combination as needed.
In 254, the unlock attempt image is encoded to define the facial features of the user as one or more feature vectors in the feature space. In some embodiments, one feature vector is defined for the unlock attempt image. In some embodiments, more than one feature vector is defined for the unlock attempt image. Unlock feature vector(s) 256 may be the output of the encoding of the unlock attempt image in 254.
In certain embodiments, in 258, unlock feature vector(s) 256 are compared to feature vectors in the templates of template space 220 to get matching score 260 for the unlock attempt image. Matching score 260 may be a score of the differences between feature vector(s) 256 and feature vectors in template space 220 (e.g., feature vectors in static templates 216 and/or other dynamic templates 226 added to the template space as described herein). The closer (e.g., the less distance or less differences) that feature vector(s) 256 and the feature vectors in template space 220 are, the higher matching score 260 may be. For example, as shown in
In some embodiments, comparing feature vector(s) 256 and templates from template space 220 to get matching score 260 includes using one or more classifiers or a classification-enabled network to classify and evaluate the differences between feature vector(s) 256 and templates from template space 220. Examples of different classifiers that may be used include, but are not limited to, linear, piecewise linear, nonlinear classifiers, support vector machines, and neural network classifiers. In some embodiments, matching score 260 is assessed using distance scores between feature vector(s) 256 and templates from template space 220.
In 262, matching score 260 is compared to unlock threshold 264 for device 100. Unlock threshold 264 may represent a minimum difference (e.g., distance in the feature space) in features (as defined by feature vectors) between the face of the authorized user and the face of the user in the unlock attempt image that device 100 requires in order to unlock the device (or unlock a feature on the device). For example, unlock threshold 264 may be a threshold value that determines whether the unlock feature vectors (e.g., feature vectors 256) are similar enough (e.g., close enough) to the templates associated with the authorized user's face (e.g., static templates 216 in template space 220). As further example, unlock threshold 264 may be represented by circle 265 in feature space 212, depicted in
As shown in
In some embodiments, in 270, a number of unlock attempts is counted (e.g., the number of attempts to unlock device 100 with a different unlock attempt image captured in 252). If the number of unlock attempts in 270 is below a selected value (e.g., a threshold), then process 250 may be run again with another unlock attempt image (e.g., a new image of the user is captured (e.g., a flood IR image or a depth map image)). In some implementations, device 100 automatically captures the new image of the user's face without prompting the user. In some embodiments, the user attempting to unlock device 100 may have additional image(s) of his/her face captured by camera 102.
If the number of unlock attempts is above the selected value, then device 100 is locked from further attempts to use facial authentication in 272. In some embodiments, when the device is locked in 272, an error message may be displayed (e.g., on display 108) indicating that facial recognition authentication process 250 has failed and/or the desired operation of device 100 is restricted or prevented from being performed. Device 100 may be locked from further attempts to use facial authentication in 272 for a specified period of time and/or until another authentication protocol is used to unlock the device. For example, passcode unlock 274 may be used to unlock device 100. Passcode unlock 274 may include using a passcode, a password, pattern entry, a different form of biometric authentication, or another authentication protocol to unlock device 100. In some embodiments, passcode unlock 274 includes providing a “use passcode/password/pattern” affordance that, when selected causes display of a passcode/password/pattern entry user interface, or a passcode/password/pattern entry user interface, or a “use fingerprint” prompt that, when displayed, prompts the user to place a finger on a fingerprint sensor for the device. In some embodiments, after device 100 is unlocked using the passcode in 274, unlock feature vectors 256 and matching score 260 are provided to second template update process 400, shown in
Process 300 may begin by assessing 302 if matching score 260 is above threshold 304. Threshold 304 may be a threshold score for determining if feature vector(s) 256 are similar (e.g., close) enough to feature vectors 210 (from static templates 216) that feature vector(s) 256 may potentially be used as another template (e.g., the threshold score may determine if feature vectors 256 are within a certain distance of feature vectors 210). In certain embodiments, threshold 304 is greater than unlock threshold 264 (e.g., threshold 304 requires a higher matching score than unlock threshold 264). Thus, the threshold for feature vector(s) 256 becoming a template may be stricter than the threshold for unlocking the device. Threshold 304 may be set during manufacturing and/or by the firmware of device 100. Threshold 304 may be updated (e.g., adjusted) by device 100 during operation of the device as described herein.
In some embodiments, if matching score 260 is below threshold 304, then process 300 is stopped and feature vector(s) 256 are deleted from device 100. In some embodiments, if matching score 260 is below threshold 304, then process 300 continues with template update sub-process 300A, described in
If suitable qualifications are met in 308, then process 300 continues, in 310, with storing feature vector(s) 256 in a backup space in the memory of device 100. The backup space in the memory may be, for example, a second space or temporary space in the memory that includes readable/writable memory and/or short term memory. Feature vector(s) 256 may be stored in the memory as temporary template 312.
In certain embodiments, after temporary template 312 is stored in the backup space in the memory, process 300 continues by comparing the temporary template to feature vectors for additional unlock attempt images captured by device 100 for the authorized user. In 314, additional unlock attempt images are captured of the user (or users if unauthorized access is attempted) as the user(s) during additional (future) unlocking attempts of device 100. The features of the face of the user in the additional unlock attempt images are encoded in 316 to generate feature vectors 318. In 320, feature vectors 318 are compared to temporary template 312 to get matching score 322.
Matching score 322 may then be compared in 324 to threshold 326. In some embodiments, threshold 326 is unlock threshold 264. In some embodiments, threshold 326 is threshold 304. If matching score 322 is above threshold 326 in 324, then a successful attempt is counted in 328. If matching score 322 is below threshold 326 in 324, then an unsuccessful attempt is counted in 330. Counts 328 and 330 may be continued until a desired number of unlock attempts are made (e.g., a desired number of comparisons of matching score 322 and threshold 326). Once the desired number of attempts is made, the number of successful attempts in 328 out of the total number of unlock attempts (e.g., the sum of counts 328 and 330) may be used to assess confidence score 332 for temporary template 312. For example, there may be 45 successful attempts out of 50 total unlock attempts so confidence score 332 is 45/50 or 90%. Confidence score 332 may be used to assess whether or not template 312 is added as dynamic template 226 to template space 220, shown in
As described above, initially after enrollment, the enrollment templates (e.g., static templates 216, shown in
In certain embodiments, temporary templates 312 generated by process 300, shown in
In certain embodiments, if, in 336, confidence score 332 is greater than confidence score 334, then temporary template 312 is added, in 338, as dynamic template 226 in dynamic portion 224. For example, if temporary template 312 has 45 successful unlock attempts out of 50 total unlock attempts while one static template 216 only has 40 successful unlock attempts out of the same 50 total unlock attempts, then temporary template 312 may be added to dynamic portion 224 as one of dynamic templates 226. If, in 336, confidence score 332 is less than confidence score 334, then temporary template 312 is ignored or deleted in 340. Temporary templates 312 may be added until a maximum number of allowed dynamic templates 226 are stored in dynamic portion 224.
Once dynamic portion 224 reaches its maximum number of dynamic templates 226 in dynamic portion 224, temporary template 312 may replace one of dynamic templates 226 in 338. For example, temporary template 312 may replace one of dynamic templates 226 if the temporary template is less of an outlier than one of dynamic templates 226. In certain embodiments, statistical analysis of the feature vectors that represent dynamic templates 226 and temporary template 312 is used to assess if temporary template 312 is less of an outlier than one of dynamic templates 226. Statistical analysis may include, for example, classification algorithms operated on feature vectors for the templates.
Statistical analysis of the feature vectors in the feature space correlating to template space 220 may generate a circle (e.g., circle 342) that most closely defines a maximum number of the feature vectors. As shown in
In certain embodiments, when temporary template 312 replaces dynamic template 226′ in template space 220, one or more thresholds for device 100 may be recalculated. As temporary template 312 is less of an outlier than dynamic template 226′ recalculation of the threshold(s) may further restrict the thresholds (e.g., raise the threshold for matching scores to require closer matching). In some embodiments, the unlock threshold (e.g., unlock threshold 264, shown in
In sub-process 300A, one or more qualities in the unlock attempt image are assessed in 350. Assessing qualities of the unlock attempt image in 350 may be substantially similar assessing qualities in 306 and 308, as shown in
If there is no room in the backup space (“N”), then the unlock attempt image (and its corresponding feature vectors) may be subject to delete policy 354, as shown in
If there is room in the backup space (“Y”), then the feature vectors for the unlock attempt image are added to the backup space as a temporary template (e.g., temporary template 312) in 356. Once the temporary template from sub-process 300A is added to the backup space in 356, the temporary template may be processed substantially as temporary template 312 (e.g., compared to additional unlock attempt images as shown in
As described above, first template update process 300 may be used to update a user's enrollment profile (e.g., templates in the template space) when device 100 is unlocked or accessed using facial authentication recognition process 250. First template update process 300 may be used, for example, to update a user's enrollment profile in response to gradual changes in the user's appearance (e.g., weight gain/loss).
In some embodiments, however, facial features of an authorized user (e.g., the user's facial appearance) may have changed drastically, or at least to a large enough extent, that the user may encounter difficulty unlocking or accessing features (e.g., operations) on device 100 using facial authentication recognition process 250, depicted in
As shown in
Second template update process 400 may begin by assessing 402 if matching score 260 is above threshold 404. Threshold 404 may be a threshold score for determining if feature vector(s) 256 are similar (e.g., close) enough to feature vectors 210 (from static templates 216) that feature vector(s) 256 may potentially be used as another template. In certain embodiments, threshold 404 for process 400 is below unlock threshold 264. Threshold 404 may be below unlock threshold 264 (e.g., more distance allowed between feature vectors and the templates) because the passcode (or other authentication) has been entered prior to beginning process 400. Thus, the threshold for feature vector(s) 256 becoming a template in process 400 may be less strict than the threshold for unlocking the device and the threshold for process 300, shown in
Process 404 may be stopped and feature vector(s) 256 are deleted from device 100 if matching score 260 is below threshold 404. If matching score 260 is above threshold 404, then process 400 is continued. In some embodiments, after assessing 404, one or more qualities in the unlock attempt image are assessed in 406. For example, pose (e.g., pitch, yaw, and roll of the face), occlusion, attention, field of view, and/or distance in the unlock attempt image may be assessed in 406. In some embodiments, pose and/or occlusion in the unlock attempt image are assessed using the landmark and/or occlusion maps described herein. In 408, if suitable qualifications (as described above) are not met, then process 400 may be stopped.
If suitable qualifications are met in 408, then process 400 continues in 410, with storing feature vector(s) 256 in a backup space in the memory of device 100. The backup space in the memory for process 400 may be a different backup space than used for process 300. For example, the backup space in the memory for process 400 may be a temporary space in the memory that includes readable/writable memory partitioned from backup space used for process 300. Feature vector(s) 256 may be stored in the memory as temporary template 412.
In certain embodiments, after temporary template 412 is stored in the backup space, temporary template 412 may be compared to feature vectors for additional images from failed facial recognition authentication unlock attempts of device 100. For example, in process 400 additional unlock failed attempt images may be captured in 414. If the correct passcode is entered in 416, then feature vectors for the images captured in 414 may be encoded in 418 to generate feature vectors 420.
In certain embodiments, in 422, feature vectors 420 are compared to the feature vector(s) for temporary template 412. Comparison of feature vectors 420 and the feature vector(s) for temporary template 412 may provide matching score 424. Matching score 424 may be compared in 426 to threshold 428. Threshold 428 may be, for example, a similarity threshold or a threshold that defines at least a minimum level of matching between the feature vector(s) for temporary template 412 and feature vectors 420 obtained from the additional images from failed facial recognition authentication attempts that are followed by entering of the passcode for device 100. Thus, threshold 428 may be set at a value that ensures at least a minimum amount of probability that the change in the user's features that caused the failed unlock attempt and generated temporary template 412 is still present in the images from additional failed unlock attempts using facial recognition authentication.
If matching score 424 is above threshold 428 in 426, then a successful match is counted in 430. If matching score 424 is below threshold 428 in 426, then an unsuccessful match is counted in 432. Counts 430 and 432 may be continued until a desired number of failed unlock attempts are made using facial recognition authentication (e.g., a desired number of comparisons of matching score 424 and threshold 428). Once the desired number of attempts is made, the number of successful matches in 430 out of the total number of failed unlock attempts (e.g., the sum of counts 430 and 432) may be used to assess confidence score 434 for temporary template 412. For example, there may be 18 successful matches (e.g., comparisons) of matching score 424 and threshold 428 out of 20 total failed unlock attempts. Confidence score 434 may be used to assess whether or not template 412 is added as dynamic template 226 to template space 220, shown in
In some embodiments, it may be assumed that if a step change occurs in the facial features of the authorized user, the step change may remain for a number of successive unlock attempts using facial recognition authentication. For example, if the user shaved a beard, then the step change should remain for at least some length of time (e.g., at least a week). In such embodiments, if a successful unlock attempt (or a desired number of successful unlock attempts) using facial recognition authentication occurs before a selected number of successive unlock attempts is reached (e.g., 10 or 15 unlock attempts), then temporary template 412 may be deleted from the backup space in the memory. In some embodiments, the assumption that the step change may remain for a number of successive unlock attempts may not apply (e.g., if the user's step change was due to temporary application of makeup).
In certain embodiments, in 436, confidence score 434 is compared against threshold 438 to assess if the confidence score is greater than the threshold. Threshold 438 may be a threshold selected to ensure a minimum number of successful comparisons of matching score 424 and threshold 428 are reached before allowing template 412 to be added to template space 220. In 436, if confidence score 434 is greater than threshold 438, then, in 440, temporary template 412 may be added to template space 220 or temporary template 412 may replace a template in the template space 220 (e.g., replace one of dynamic templates 226). If confidence score 434 is less than threshold 438, then temporary template 412 may be ignored or deleted in 442.
As described above, temporary template 412 generated by process 400 may be added to dynamic portion 224 of template space 220 as one of dynamic templates 226, shown in
If the maximum number of allowed dynamic templates 226 in dynamic portion 224 has been reached, then temporary template 412 may replace one of dynamic templates 226 in the dynamic portion. As the passcode (or other authentication) has been used to verify temporary template 412 is for the authorized user, the temporary template may replace one of dynamic templates 226 in dynamic portion 224 even if the temporary template is more of an outlier than each of dynamic templates 226. In certain embodiments, temporary template 412 replaces the largest outlier of dynamic templates 226 regardless of the relative lie (e.g., outlie) of the temporary template. In some embodiments, temporary template 412 may replace a dynamic template that is redundant (e.g., most redundant) to the existing dynamic templates even if the temporary template is more of an outlier than each of the dynamic templates.
Statistical analysis of the feature vectors in the feature space correlating to template space 220 may generate a circle (e.g., circle 444) that most closely defines a maximum number of the feature vectors. As shown in
In some embodiments, a temporary template (e.g., either temporary template 312 or temporary template 412) may be used to unlock device 100 for a selected period of time while the temporary template is in the backup space of the memory (e.g., before the temporary template is added to template space 220). The temporary template may be used to unlock device 100 after the passcode (or other user authentication protocol) is used in combination with the temporary template. For example, for temporary template 412, the passcode has been entered to unlock device 100 before temporary template 412 is generated and stored in the backup space of the device memory. Temporary template 412 may then be used to allow unlocking of device 100 using facial recognition authentication for a selected time period (e.g., a few days or a week). After the selected time period expires, if temporary template 412 has not been added to template space 220, the user may be prompted for the passcode if facial recognition authentication of the user fails.
In some embodiments, multiple enrollment profiles are generated on device 100. Multiple enrollment profiles may be generated, for example, to enroll multiple users on device 100 and/or to enroll multiple looks for a single user. Multiple looks for a single user may include looks that are substantially different and cannot be recognized using a single enrollment profile (e.g., user wears lots of makeup or has other drastic changes at different times of day/week). For example, a single user can execute the enrollment process a first time to create first enrollment profile while wearing glasses and execute the enrollment process a second time to create a second enrollment profile while not wearing glasses.
In embodiments with multiple enrollment profiles, image enrollment process 200 may be used to generate each enrollment profiles as a separate enrollment profile on device 100. For example, process 200 may be used to create separate templates of enrollment images for each enrollment profile. The separate templates may be stored in different portions of the memory of device 100 (e.g., partitioned portions of the memory space used for storing the templates).
With multiple enrollment profiles stored in device 100, facial recognition authentication process 250 may compare features in unlock attempt images to each of the different profiles (e.g., all the templates stored in memory). In certain embodiments, if a match is determined for any one of the enrollment profiles (e.g., the matching score is above the unlock threshold), then device 100 is unlocked. In some embodiments, if multiple enrollment profiles are stored on device 100, the unlock threshold is increased (e.g., the requirement for matching is made more strict). In some embodiments, when a new enrollment profile is generated, the amount unlock threshold is increased is based on the distance in feature space between the feature vectors associated with the templates for the new enrollment profile and the feature vectors associated with templates in existing enrollment profile(s) (e.g., the more distance there is between feature vectors in the template for the new enrollment profile and feature vectors in existing enrollment profiles, the more the unlock threshold is increased). In some embodiments, the new unlock threshold may also be adjusted based on a match history of the existing enrollment profiles (e.g., the more matches in the history of the existing profiles, the more strict the threshold may be).
When multiple enrollment profiles are stored in device 100, each enrollment profile may be associated with its own template update processes (e.g., each enrollment profile operates with its own first template update process 300 and second template update process 400). In embodiments when device 100 is unlocked with a match determined using facial recognition authentication process 250, the enrollment profile that is matched with the unlock attempt image in process 250 may be processed (e.g., updated) using its corresponding first template update process 300. If multiple enrollment profiles are determined to match with the unlock attempt image using facial recognition authentication process 250, then each of the matching enrollment profiles may be processed (e.g., updated) using its respective first template update process 300. In embodiments when device 100 is unlocked using a passcode (or another secondary authentication method) because facial recognition authentication process 250 could not determine a match, the enrollment profile that has feature vectors closest (e.g., least distance) to the feature vectors of the unlock attempt image may be processed (e.g., updated) using its corresponding second template update process 400.
In certain embodiments, one or more process steps described herein may be performed by one or more processors (e.g., a computer processor) executing instructions stored on a non-transitory computer-readable medium. For example, process 200, process 250, process 300, and process 400, shown in
Processor 512 may be coupled to memory 514 and peripheral devices 516 in any desired fashion. For example, in some embodiments, processor 512 may be coupled to memory 514 and/or peripheral devices 516 via various interconnect. Alternatively or in addition, one or more bridge chips may be used to coupled processor 512, memory 514, and peripheral devices 516.
Memory 514 may comprise any type of memory system. For example, memory 514 may comprise DRAM, and more particularly double data rate (DDR) SDRAM, RDRAM, etc. A memory controller may be included to interface to memory 514, and/or processor 512 may include a memory controller. Memory 514 may store the instructions to be executed by processor 512 during use, data to be operated upon by the processor during use, etc.
Peripheral devices 516 may represent any sort of hardware devices that may be included in computer system 510 or coupled thereto (e.g., storage devices, optionally including computer accessible storage medium 600, shown in
Turning now to
Further modifications and alternative embodiments of various aspects of the embodiments described in this disclosure will be apparent to those skilled in the art in view of this description. Accordingly, this description is to be construed as illustrative only and is for the purpose of teaching those skilled in the art the general manner of carrying out the embodiments. It is to be understood that the forms of the embodiments shown and described herein are to be taken as the presently preferred embodiments. Elements and materials may be substituted for those illustrated and described herein, parts and processes may be reversed, and certain features of the embodiments may be utilized independently, all as would be apparent to one skilled in the art after having the benefit of this description. Changes may be made in the elements described herein without departing from the spirit and scope of the following claims.
Claims
1-20. (canceled)
21. A method, comprising:
- obtaining an image of a face of a user using a camera located on a device in response to an authentication attempt initiated by the user, the device comprising a computer processor and a memory;
- encoding the image to generate a first feature vector representing one or more features of the user in the image;
- authorizing the user in the image as an authenticated user of the device based on a matching score between the first feature vector and one or more reference templates stored in the memory being above a first threshold, wherein the one or more reference templates include at least one static template; and
- storing the first feature vector as a dynamic template in the memory in response to the matching score being above a second threshold, wherein: when a number of dynamic templates stored in the memory is below a predetermined number of dynamic templates allowed in the memory, the first feature vector is stored as a new dynamic template in the memory; and when the number of dynamic templates stored in the memory is at the predetermined number of dynamic templates allowed in the memory, the first feature vector replaces an existing dynamic template in the memory when the first feature vector is a closer match to the one or more reference templates and existing dynamic templates in the memory as compared to the existing dynamic template being replaced.
22. The method of claim 21, wherein the second threshold is higher than the first threshold.
23. The method of claim 21, wherein the first feature vector is a closer match when the first feature vector is less of an outlier than the existing temporary dynamic template being replaced.
24. The method of claim 23, further comprising determining whether the first feature vector is less of the outlier based on statistical analysis of the first feature vector, the one or more reference templates, and the existing dynamic templates.
25. The method of claim 21, further comprising:
- obtaining one or more reference images of the face of the user using the camera;
- encoding facial features of the user from the one or more reference images to generate one or more reference feature vectors; and
- storing the one or more reference feature vectors as the one or more reference templates in the memory of the device.
26. The method of claim 21, wherein the at least one static template includes a template that is not deleted or changed in the memory of the device until the device is reset or a user determines to replace the one or more reference templates in the memory of the device.
27. The method of claim 21, further comprising:
- obtaining one or more additional images using the camera in response to additional authentication attempts initiated on the device;
- storing the first feature vector as the dynamic template in the memory in response to the matching score being above the second threshold and the first feature vector meeting at least one criteria for the additional images in comparison to the at least one static template.
28. The method of claim 27, further comprising:
- encoding the additional images to generate second feature vectors representing one or more features of the user in the additional image;
- generating a first set of matching scores between the second feature vectors and the first feature vector; and
- generating a second set of matching scores between the second features vectors and the at least one static template;
- wherein the at least one criteria includes a number of matching scores above the first threshold in the first set of matching scores being greater than a number of matching scores above the first threshold in the second set of matching scores.
29. A device, comprising:
- a camera;
- a processor coupled to the camera;
- a memory coupled to the processor; and
- circuitry coupled to the camera, wherein the circuitry is configured to: obtain an image of a face of a user using the camera in response to an authentication attempt initiated by the user; encode the image to generate a first feature vector representing one or more features of the user in the image; authorize the user in the image as an authenticated user of the device based on a matching score between the first feature vector and one or more reference templates stored in the memory being above a first threshold, wherein the one or more reference templates include at least one static template; and store the first feature vector as a dynamic template in the memory in response to the matching score being above a second threshold, wherein: when a number of dynamic templates stored in the memory is below a predetermined number of dynamic templates allowed in the memory, the first feature vector is stored as a new dynamic template in the memory; and when the number of dynamic templates stored in the memory is at the predetermined number of dynamic templates allowed in the memory, the first feature vector replaces an existing dynamic template in the memory when the first feature vector is a closer match to the one or more reference templates and existing dynamic templates in the memory as compared to the existing dynamic template being replaced.
30. The device of claim 29, wherein the device further comprises at least one illuminator configured to provide infrared illumination directed towards the user when obtaining the image of the face of the user using the camera.
31. The device of claim 29, wherein the camera includes an infrared sensor.
32. The device of claim 29, wherein the second threshold is higher than the first threshold.
33. The device of claim 29, wherein the circuitry is configured to enroll the authenticated user on the device in response to the authenticated user providing at least one additional authentication protocol on the device, and wherein the circuitry is configured to enroll the authenticated user by:
- obtaining one or more reference images of the face of the user using the camera;
- encoding facial features of the user from the one or more reference images to generate one or more reference feature vectors; and
- storing the one or more reference feature vectors as the one or more reference templates in the memory of the device.
34. The device of claim 33, wherein the at least one additional authentication protocol comprises entering a passcode for the authenticated user.
35. The device of claim 29, wherein the circuitry is configured to update the first threshold when the first feature vector is stored as the dynamic template in the memory.
36. The device of claim 29, wherein the circuitry is configured to:
- obtain one or more additional images using the camera in response to additional authentication attempts initiated on the device;
- store the first feature vector as the dynamic template in the memory in response to the matching score being above the second threshold and the first feature vector meeting at least one criteria for the additional images in comparison to the at least one static template.
37. A non-transitory computer-readable medium having instructions stored thereon that are executable by a computing device to perform operations, comprising:
- obtaining an image of a face of a user using a camera located on the computing device in response to an authentication attempt initiated by the user;
- encoding the image to generate a first feature vector representing one or more features of the user in the image;
- authorizing the user in the image as an authenticated user of the device based on a matching score between the first feature vector and one or more reference templates stored in a memory of the computing device being above a first threshold, wherein the one or more reference templates include at least one static template; and
- storing the first feature vector as a dynamic template in the memory in response to the matching score being above a second threshold, wherein: when a number of dynamic templates stored in the memory is below a predetermined number of dynamic templates allowed in the memory, the first feature vector is stored as a new dynamic template in the memory; and when the number of dynamic templates stored in the memory is at the predetermined number of dynamic templates allowed in the memory, the first feature vector replaces an existing dynamic template in the memory when the first feature vector is a closer match to the one or more reference templates and existing dynamic templates in the memory as compared to the existing dynamic template being replaced.
38. The non-transitory computer-readable medium of claim 37, wherein the image obtained includes an image of the user captured while illuminating the user with flood infrared illumination.
39. The non-transitory computer-readable medium of claim 37, wherein the image obtained includes an image of the user captured while illuminating the user with patterned infrared illumination.
40. The non-transitory computer-readable medium of claim 37, wherein authorizing the user in the image as the authenticated user of the device allows the authenticated user to have access to a selected functionality of the device.
Type: Application
Filed: Dec 10, 2019
Publication Date: Sep 10, 2020
Inventors: Eslam A. Mostafa (Sunnyvale, CA), Haitao Guo (Cupertino, CA), Feng Tang (Cupertino, CA)
Application Number: 16/708,770