This invention relates generally to user authentication, and more particularly, to methods and systems for determining user liveness and verifying user identities.
Users conduct transactions with service providers in person and remotely over the Internet. Network-based transactions conducted over the Internet may involve purchasing items from a merchant website or accessing confidential information from a website. Service providers that own and operate such websites typically require successfully authenticating a user before allowing that user to conduct a desired transaction.
Typically, during network-based biometric authentication transactions conducted with a user at a remote location, the user provides a claim of identity and biometric data. However, imposters have been known to impersonate users by providing a false claim of identity supported by fraudulent biometric data in an effort to deceive a service provider into concluding the imposter is the person he or she claims to be. Such impersonations are known as spoofing.
Impostors have been known to use many methods to obtain or create fraudulent biometric data of others that can be submitted during authentication transactions. For example, imposters have been known to obtain two-dimensional pictures from social networking sites which can be presented to a camera during authentication to support a false claim of identity. Imposters have also been known to make physical models of a biometric modality, such as a fingerprint using gelatin or a three-dimensional face using a custom mannequin. Moreover, imposters have been known to eavesdrop on networks during legitimate network-based biometric authentication transactions to surreptitiously obtain genuine biometric data. The imposters use the obtained biometric data for playback during fraudulent network-based authentication transactions. Such fraudulent biometric data are difficult to detect using known liveness detection methods. Consequently, accurately conducting network-based biometric authentication transactions with biometric data captured from a user at a remote location depends on verifying the physical presence of the user during the authentication transaction as well as accurately verifying the identity of the user with the captured biometric data. Verifying that the biometric data presented during a network-based biometric authentication transaction conducted at a remote location is from a live person at the remote location, is known as liveness detection or anti-spoofing.
Liveness detection methods have been known to use structure derived from motion of a biometric modality, such as a face, to distinguish a live user from a photographic image. Other methods have been known to detect sequential images of eyes or eye blink techniques, to determine if face biometric data is from a live user. Yet other methods have been known to illuminate a biometric modality with a pattern to distinguish a live user from a photographic image. However, these methods may not be convenient for the user and may not detect spoofing attempts that use high definition video playback, and therefore may not provide high confidence liveness detection support for entities dependent upon accurate biometric authentication transaction results.
In one aspect, a method for determining user liveness is provided that includes calculating, by a computing device, parameters for each frame in a video of face biometric data captured from a user. Each parameter results from movement of at least one of the computing device and the biometric data during capture of the biometric data. Moreover, the method includes creating a signal for each parameter, calculating a similarity score, and determining the user is live when the similarity score is at least equal to a threshold score. The similarity score indicates the similarity between the signals.
In another aspect, a computing device for determining user liveness is provided that includes a processor and a memory. The memory is configured to store data and the computing device is associated with a network. The memory is in communication with the processor and has instructions stored thereon which, when read and executed by the processor, cause the computing device to calculate parameters for each frame in a video of face biometric data captured from a user, wherein each parameter results from movement of at least one of the computing device and the biometric data during capture of the biometric data. The instructions which when read and executed by the processor further cause the computing device to create a signal for each parameter, calculate a similarity score, and determine the user is live when the similarity score is at least equal to a threshold score. The similarity score indicates the similarity between the signals.
In yet another aspect, a method for determining user liveness is provided that includes calculating, by a computing device, an illumination-based parameter for each frame in a video of face biometric data captured from a user. The parameter results from movement of at least one of the computing device and the biometric data during capture of the biometric data. Moreover, the method includes creating a signal for the parameter, and calculating a total change in the signal and incremental changes between sequential frames. Furthermore, the method includes determining the user is live when the signal is monotonous, the total change is less than ten percent, and the incremental change between all sequential frames is less than twenty percent of the total change.
In another aspect, a method for verifying the identity of a user is provided that includes generating, by a computing device, a parameter for each processed frame in a video of biometric data captured from a user. The parameter results from movement of the computing device during capture of the biometric data. Moreover, the method includes generating a signal for the parameter and calculating a confidence score based on the generated signal and a classification model specific to the user. The classification model is generated from other signals generated for the parameter. Furthermore, the method includes verifying the identity of the user as true when the confidence score is at least equal to a threshold score.
In yet another aspect, a computing device for verifying the identity of a user is provided that includes a processor and a memory configured to store data. The computing device is associated with a network and the memory is in communication with the processor and has instructions stored thereon which, when read and executed by the processor, cause the computing device to generate a parameter for each processed frame in a video of biometric data captured from a user. The parameter results from movement of the computing device during capture of the biometric data. Moreover, the instructions when read and executed by the processor cause the computing device to generate a signal for the parameter, and calculate a confidence score based on the generated signal and a classification model specific to the user. The classification model is generated from other signals generated for the parameter. The identity of the user is validated as true when the confidence score is at least equal to a threshold score.
In yet another aspect, a method for verifying the identity of a user is provided that includes generating, by a computing device, a parameter for each processed frame in a video of biometric data captured from a user. The parameter results from movement of the computing device during capture of the biometric data. Moreover, the method includes identifying processed frames captured at different values of the parameter, wherein the different values are based on incremental changes in the parameter. Furthermore, the method includes comparing biometric templates generated from the data included in the identified frames against corresponding user record biometric templates and calculating a matching score for each comparison. The user record biometric templates are based on biometric data captured at the different values of the parameter. The method also includes validating the identity of the user as true based on the matching scores.
The computing device 10 may be any device capable of at least capturing and processing biometric data from users, and performing the functions described herein. One example of the computing device 10 is a smart phone. Other examples of the computing device 10 include, but are not limited to, a cellular phone, a tablet computer, a phablet computer, a laptop computer, a personal computer (PC), and any type of device having wired or wireless networking capabilities such as a personal digital assistant (PDA).
The processor 12 executes instructions, or computer programs, stored in the memory 14. As used herein, the term processor is not limited to just those integrated circuits referred to in the art as a processor, but broadly refers to a computer, a microcontroller, a microcomputer, a programmable logic controller, an application specific integrated circuit, and any other programmable circuit capable of executing at least a portion of the functions and/or methods described herein. The above examples are not intended to limit in any way the definition and/or meaning of the term “processor.”
As used herein, the term “computer program” is intended to encompass an executable program that exists permanently or temporarily on any non-transitory computer-readable recordable medium that causes the computing device 10 to perform at least a portion of the functions and/or methods described herein. Application programs 30, also known as applications, are computer programs stored in the memory 14. Application programs 30 include, but are not limited to, an operating system, an Internet browser application, enrolment applications, authentication applications, user liveness detection applications, face tracking applications, applications that use pre-trained models based on machine learning algorithms, motion prediction applications, feature vector generator applications, active appearance applications, key point detection applications, face pose detection applications, and any special computer program that manages the relationship between application software and any suitable variety of hardware that helps to make-up a computer system or computing environment.
Authentication applications enable the computing device 10 to conduct user verification and identification transactions with any type of authentication data. Key point detection applications enable the computing device 10 to detect points of interest in a frame in a video, and to track the detected points of interest between frames in the video. Machine learning algorithm applications include at least classifiers and regressors. Machine learning algorithms may process data to generate a classification model. For example, a machine learning algorithm may process data that includes signals generated for a user to generate user specific classification models which may be used to facilitate verifying the identity of the user. Examples of such machine learning algorithms include, but are not limited to, support vector machine learning algorithms, linear discriminant analysis learning algorithms, and artificial neural network learning algorithms.
The memory 14 may be any non-transitory computer-readable recording medium used to store data including, but not limited to, computer programs and user data records. The data record for each user may include record biometric data, record biometric templates and personal data of the user. The record biometric data is raw biometric data processed to generate at least one record biometric template. The record biometric template may be used to verify the identity of a user. The process of verifying the identity of a user is referred to as a verification transaction. Typically, during a verification transaction, a biometric template is generated from biometric data captured from the user during the transaction. The generated biometric template is compared against the corresponding user record biometric template, and if the generated and record templates match, the identity of the user is verified as true. Alternatively, the captured user biometric data may be compared against the corresponding user record biometric data to verify the identity of the user. Authentication transactions may include identity verification transactions and identification (1:N) transactions, where “N” is a number of candidates.
Personal data includes any demographic information regarding a user such as, but not limited to, a user's name, gender, age, date-of-birth, address, citizenship and marital status. Each data record may also include any kind of data that may be used to enhance the trustworthiness of user liveness detection results and authentication transaction results. The data records are typically for users associated with the computing device 10.
Configurable policies for determining record data requirements and authentication data requirements, respectively, may also be stored in the memory 14. A record data requirement is the data desired to be captured from a user and stored in the corresponding user data record prior to conducting authentication transactions for the user. An authentication data requirement is the data desired to be captured from a user during either a verification or identification transaction. The record and authentication data requirements may be for any type of authentication data, for example, biometric data. The biometric data may be for any biometric modality including, but not limited to, voice, face, finger, iris, palm, and electrocardiogram, and any combination of biometric modalities. Moreover, biometric data for these modalities may take any form such as, but not limited to, audio recordings, photographs, and video. For the example methods described herein, the authentication data requirement is for face biometric data captured as a video. A video includes a sequence of frames.
The authentication data requirement may also be for any combination of different types of authentication data, for example, Global Positioning Coordinates and biometric data. The record and authentication data requirements may be determined by an individual, by any system 32 or device 34 configured to communicate with the computing device 10 over a network 36, or in any other manner.
While capturing face biometric data as a video, the computing device 10 may extract frames from the video and assign a time stamp to each frame in the video. An application, for example a face tracker application, may process the extracted frames. However, the rate at which the computing device 10 extracts frames from the video may be greater than the rate at which the extracted frames are processed. Consequently, some of the extracted frames may not be processed. Because some frames may take more or less time to process the frame processing rate may be regular or irregular, and may be the same or different for each authentication transaction. The number of frames processed for each authentication transaction may vary with the frame processing rate.
The data for a processed frame may be stored in the memory 14 with other data generated by the computing device 10 for that processed frame. Thus, for each processed frame, all the frame data as stored in the memory 14 may be associated with other data generated for the frame. The captured face biometric data includes at least facial image data, while the other data may include parameters generated by the computing device 10 that are associated with movement of at least the computing device 10 during biometric data capture. Parameters include, but are not limited to, measurements made or calculated by the computing device 10, changes in the measurements, and measurements calculated from other measurements or calculations made by the computing device 10.
Non-transitory computer-readable recording media may be any tangible computer-based device implemented in any method or technology for short-term and long-term storage of information or data. Moreover, the non-transitory computer-readable recording media may be implemented using any appropriate combination of alterable, volatile or non-volatile memory or non-alterable, or fixed, memory. The alterable memory, whether volatile or non-volatile, can be implemented using any one or more of static or dynamic RAM (Random Access Memory), a floppy disc and disc drive, a writeable or re-writeable optical disc and disc drive, a hard drive, flash memory or the like. Similarly, the non-alterable or fixed memory can be implemented using any one or more of ROM (Read-Only Memory), PROM (Programmable Read-Only Memory), EPROM (Erasable Programmable Read-Only Memory), EEPROM (Electrically Erasable Programmable Read-Only Memory), an optical ROM disc, such as a CD-ROM or DVD-ROM disc, and disc drive or the like. Furthermore, the non-transitory computer-readable recording media may be implemented as smart cards, SIMs, any type of physical and/or virtual storage, or any other digital source such as a network or the Internet from which a computing device can read computer programs, applications or executable instructions.
The gyroscope 16 and the accelerometer 18 generate data regarding rotation and translation of the computing device 10 that may be communicated to the processor 12 and the memory 14 via the bus 20. The processor 12 may use the generated data to at least calculate the acceleration of the computing device 10, calculate the orientation and position of the computing device 10, calculate parameters, calculate signals, and calculate the similarity between signals.
The user interface 22 and the display 24 allow interaction between a user and the computing device 10. The display 24 may include a visual display or monitor that displays information to a user. For example, the display 24 may be a Liquid Crystal Display (LCD), active matrix display, plasma display, or cathode ray tube (CRT). The user interface 22 may include a keypad, a keyboard, a mouse, an infrared light source, a microphone, cameras, and/or speakers. Moreover, the user interface 22 and the display 24 may be integrated into a touch screen display. Accordingly, the display may also be used to show a graphical user interface, which can display various data and provide “forms” that include fields that allow for the entry of information by the user. Touching the screen at locations corresponding to the display of a graphical user interface allows the person to interact with the device 10 to enter data, change settings, control functions, etc. Consequently, when the touch screen is touched, the user interface 22 communicates this change to the processor 12, and settings can be changed or user entered information can be captured and stored in the memory 14.
The sensing device 26 may include Radio Frequency Identification (RFID) components or systems for receiving information from other devices. The sensing device 26 may also include components with Bluetooth, Near Field Communication (NFC), infrared, or other similar capabilities. The computing device 10 may alternatively not include the sensing device 26.
The communications interface 28 provides the computing device 10 with two-way data communications. Moreover, the communications interface 28 enables the computing device 10 to conduct wireless communications such as cellular telephone calls and to wirelessly access the Internet over the network 36. By way of example, the communications interface 28 may be a digital subscriber line (DSL) card or modem, an integrated services digital network (ISDN) card, a cable modem, or a telephone modem to provide a data communication connection to a corresponding type of telephone line. As another example, the communications interface 28 may be a local area network (LAN) card (e.g., for Ethernet™ or an Asynchronous Transfer Model (ATM) network) to provide a data communication connection to a compatible LAN. As yet another example, the communications interface 28 may be a wire or a cable connecting the computing device 10 with a LAN, or with accessories such as, but not limited to, biometric capture devices. Further, the communications interface 28 may include peripheral interface devices, such as a Universal Serial Bus (USB) interface, a PCMCIA (Personal Computer Memory Card International Association) interface, and the like. Thus, it should be understood the communications interface 28 may enable the computing device 10 to conduct any type of wireless or wired communications such as, but not limited to, accessing the Internet. Although the computing device 10 includes a single communications interface 28, the computing device 10 may alternatively include multiple communications interfaces 28.
The communications interface 28 also allows the exchange of information across the network 36. The exchange of information may involve the transmission of radio frequency (RF) signals through an antenna (not shown). Moreover, the exchange of information may be between the computing device 10 and any other computer systems 32 and any other computing devices 34 capable of communicating over the network 36. The computer systems 32 and the computing devices 34 typically include components similar to the components included in the computing device 10. The network 36 may be a 5G communications network. Alternatively, the network 36 may be any wireless network including, but not limited to, 4G, 3G, Wi-Fi, Global System for Mobile (GSM), Enhanced Data for GSM Evolution (EDGE), and any combination of a LAN, a wide area network (WAN) and the Internet. The network 36 may also be any type of wired network or a combination of wired and wireless networks.
Examples of other computer systems 32 include computer systems of service providers such as, but not limited to, financial institutions, medical facilities, national security agencies, merchants, and authenticators. Examples of other computing devices 34 include, but are not limited to, smart phones, tablet computers, phablet computers, laptop computers, personal computers and cellular phones. The other computing devices 34 may be associated with any individual or with any type of entity including, but not limited to, commercial and non-commercial entities. The computing devices 10, 34 may alternatively be referred to as computer systems or information systems, while the computer systems 32 may alternatively be referred to as computing devices or information systems.
A three-dimensional Cartesian coordinate system having X, Y, and Z-axes may be virtually positioned in any location on the computing device 10 that enables generating at least one parameter usable for creating a signal that represents changes in the parameter over time. The coordinate system represents the three-dimensional space through which the computing device 10 may freely move.
The computing device 10 may be rotated about any combination of the X, Y, and Z-axes, and may be translated along any combination of the X, Y, and Z-axes. Rotation of the computing device 10 about the X-axis is called pitch (i.e., pitch angle), rotation of the computing device 10 about the Y-axis is called yaw (i.e., yaw angle), and rotation of the computing device 10 about the Z-axis is called roll (i.e., roll angle). The computing device 10 may also be simultaneously rotated about and translated along any combination of the X, Y and Z-axes in any manner. Angles measured clockwise CW from the Y-axis, or any axis parallel to the Y-axis, are positive while angles measured counter clockwise CCW from the Y-axis, or any axis parallel to the Y-axis, are negative.
A front face of the computing device 10 defines a plane 40 and the face of the user 38 facilitates defining another plane 42. The plane 40 forms an angle theta (θ) with respect to the Y-axis. The plane 42 forms an angle alpha (α) with respect to a vertical axis, which is parallel to the Y-axis, and is included in the X, Y, and Z coordinate system. The planes 40 and 42 form an angle beta (β) therebetween. In the first position, the angles θ and β typically are different and the planes 40 and 42 typically are not parallel. The angles θ, β, and a as well as the planes 40 and 42 are examples of parameters that may be generated by the computing device 10.
While in the second position the computing device 10 is best positioned to capture biometric data usable for generating trustworthy verification transaction results. However, trustworthy verification transaction results may also be generated from biometric data captured while the computing device 10 is in the first position, in any position between the first and second position, or in any combination of positions.
The displayed image of the user 38 is to be positioned within the visual aid 44 while capturing biometric data from the user with the computing device 10 and moving the computing device 10 from the first to the second position. The displayed image may be close to the visual aid 44 border but not outside the border. Staying within the visual aid 44 facilitates capturing biometric data usable for enhancing the accuracy of user liveness determinations and generating trustworthy verification transaction results. Alternatively, a small percentage of the facial image may be allowed to extend beyond the border of the visual aid 44 so long as trustworthy user liveness detection results may be calculated as described herein.
The user 38 starts capturing biometric data from his or her self with the computing device 10 when the device 10 is in the first position. Because adequate quality biometric data usable for generating trustworthy verification results is typically not obtained in the first position, a prompt is displayed by the computing device 10 for the user to see. The prompt may be any information that causes the user to move the computing device 10 into the second position. For example, the prompt may be an arrow pointing in the direction that the user is to move the computing device 10, or a message instructing the user to move the computing device 10 to be about level with the head of the user.
Users typically move the computing device 10 from the first to the second position in a manner that is natural to them. Moreover, the user 38 may translate and rotate the computing device 10 into the second position in any manner. For example, the user may change the distance between the computing device 10 and the face of the user while moving the computing device 10 into the second position. While moving the computing device 10 into the second position, the user also positions his or her head to be more vertical.
The user may cause the computing device 10 to start capturing biometric data, or the computing device 10 may start capturing biometric data automatically. For example, the computing device 10 may start capturing biometric data automatically when the prompt is displayed.
In response to the prompt, the user 38 moves the computing device 10 into the second position. While moving the device 10, the user aims the computing device 10 at his or her self, such that the image of his or her face displayed by the computing device 10 is within the visual aid 44. While being moved into the second position, the computing device continuously captures biometric data from the user. Biometric data capture stops when the computing device 10 is in the second position. The user may cause the computing device 10 to stop capturing biometric data, or the computing device 10 may stop capturing biometric data automatically when the angles θ and β are each between about minus five degrees and plus five degrees.
The computing device 10 calculates the angle θ for each processed frame from data generated by the accelerometer 18 and the gyroscope 16 for that processed frame. Alternatively, the angle θ may be calculated from data generated by only the accelerometer 18. A face pose detection application may be used to calculate the angle β for a processed frame from the image data for that processed frame. Alternatively, any application that may cause the computing device 10 to calculate the angle β for a frame from the image data for that frame, or from any other data for that frame, may be used. The computing device 10 may calculate the angle α for a frame by any means, for example, from the image data for that frame.
The computing device 10 calculates an X component (i.e., θx and βx), a Y-component (i.e., θY and βY), and a Z-component (i.e., θZ and βZ) for the angles θ and β in each frame. Due to the nature of the movement from the first to the second position, the most significant angular change occurs about the X-axis. Typically, there is less significant angular change about the Y and Z-axes. A significant angular change about the Y or Z-axis may be evidence the user has not moved the computing device 10 in accordance with the prompt, so the calculated angles θ and β are deemed faulty and thus not usable for detecting user liveness. A significant angular change may be any angular change that enables detecting movement that does not comply with the prompt. For example, a significant angular change may be between five and ten degrees. The angular change about the Y or Z-axis may be measured with respect to the initial values of the angles θ (i.e., θY, θZ) and β (i.e., βY, βZ) in the first position. Faulty data may also be detected using a face tracker application that analyzes face image data included in the captured biometric data to detect any anomalies. For example, an anomaly may be a bend detected in a photograph used by an imposter during a spoofing attempt. If any anomalies are detected, the calculated angular data (i.e., θx and βx) are deemed faulty and not usable for detecting user liveness.
The X, Y, and Z-components of the angles θ and β may be plotted over time to generate a signal for each component. Thus, at least six signals may be generated. Signals generated from faulty angles θ and β are also deemed faulty and cannot be used to determine user liveness.
The information shown in
The light source 52 may be a single light source or multiple light sources. Multiple light sources include any combination of the same or different types of light sources. The light source 52, or sources, are typically stationary while the user 38 operates the computing device 10. The user 38 may be illuminated by light directly from the light source 52 or may be illuminated by indirect light. Indirect light is light produced by the light source 52 that interacts with a feature before illuminating the user. Example features include, but are not limited to, walls, mirrors, curtains and glass. For example, indirect light may reflect off a wall or mirror before illuminating the user. Alternatively, or additionally, indirect light may be refracted by glass before illuminating the user.
The computing device 10 calculates an illumination line 54 between the light source 52 and the face of the user 38. The illumination line 54 represents the ambient light direction between the light source 52 and the user 38. When multiple light sources 52 are used, the illumination line 54 is calculated as the combined effect of the multiple sources.
For each processed frame from a video of captured biometric data, the computing device 10 also calculates a line 56 normal to the plane 42 and an angle phi (ϕ) between the normal line 56 and the illumination line 54. When the angles θ and a are each about zero, the computing device 10 is in the second position and is best positioned to capture biometric data usable for generating trustworthy authentication transaction results. Angles measured clockwise CW from the illumination line 54 are positive while angles measured counter clockwise CCW are negative.
The computing device 10 may project the facial image data from each processed frame in the captured biometric data video onto a geometrically normalized reference frame which preserves only the pixel intensity variations of the image. By doing so, the computing device 10 transforms the captured biometric image data for each processed frame into a normalized frame version that has only pixel intensity variations. Alternatively, the image data may be normalized in any manner that yields only pixel intensity variations. Normalizing the image data removes most of the geometric variations between processed frames. Moreover, the pixel variations in the normalized frame image data may be used to detect illumination variations between processed frames. The computing device 10 may process a gray scale version of the normalized frame data to determine user liveness or may process color information from the normalized frame data to determine user liveness.
While moving the computing device 10 into the second position, the user also positions his or her head to be more vertical and better align with the Y-axis. Such movement causes the angles α and ϕ to change. As a result, the facial illumination varies between frames of normalized image data. This facial illumination variation between normalized frame image data may be used to determine user liveness. The facial illumination variation is the change in lighting of the biometric data between sequential frames of normalized image data. The facial illumination variations may be caused by changes in the angle ϕ. The angle phi ϕ, the illumination line 54, the normalized frame data, and illumination variation are additional examples of parameters that may be generated by the computing device 10.
The angle ϕ is calculated by an active appearance model application or the like. The active appearance model application is trained to learn correspondences between the normalized face image data and the angle ϕ of the light illuminating the face during capture. After being properly trained, the application is able to calculate the angle ϕ for every processed frame using parameters generated by the computing device 10 while moving the computing device 10 from the first to the second position. The application is able to calculate X, Y, and Z components for the angle phi ϕ which angles may be plotted over time to create a signal. Thus, at least three signals may be created.
Because the most significant angular changes occur about the X-axis, when the angle ϕ experiences a significant angular change about the Y or Z-axis, the calculated angle ϕ is deemed faulty and thus not usable for determining user liveness. The change in the angle ϕ may be measured with respect to the initial values of the angle ϕ (i.e., ϕY, ϕZ) in the first position. Signals generated from faulty angles ϕ and θ are also deemed faulty and cannot be used to detect user liveness.
The angles θx, βx, and ϕx at time t=0.0 seconds may vary depending on how the user holds the computing device 10 in the first position when initiating movement of the computing device 10. Although the angles θx, βx, and ϕx are forty-five, thirty, and fifteen degrees, respectively, in the first position, the angles θx, βx, and ϕx may alternatively be any angle in the first position that may be used for determining user liveness as described herein. For example, the angle θx may be any angle between twenty and fifty-five degrees.
Twenty-one different values of each angle (i.e., θx, βx, ϕx) are plotted to create the signals 48, 50, and 58 which corresponds to a frame processing rate of twenty-one frames per second. At a frame processing rate of twenty-one processed frames per second, the time between plotted values is 0.05 seconds. Each 0.05 seconds is a temporal segment so the signals 48, 50, and 58 each include twenty (20) temporal segments. However, the frame processing rate, and consequently the number of values used to create the signals, may alternatively vary from a minimum often processed frames per second to a maximum of thirty processed frames per second. Frame processing rates between ten and thirty frames per second typically yield trustworthy user liveness detection results. Higher frame processing rates typically yield more accurate and trustworthy liveness detection results. Thus, liveness detection results determined using a thirty frame per second processing rate are typically more trustworthy than results determined using a ten frame per second processing rate. The frame processing rates for each of the signals 48, 50, and 58 may be the same or different. Moreover, the signals 48, 50, and 58 may be stored in the data record of the respective user. The duration of the temporal segment typically varies with the frame processing rate.
The total change Δϕt between time t=0 and t=n is about fifteen degrees, and the total change Δθt between time t=0 and t=n is about forty-five degrees. Large incremental changes Δθi, Δβi, and Δϕi in the signals 48, 50, and 58, respectively, between sequential frames may be evidence of a spoof attack. Incremental changes Δθi, Δβi, and Δϕi no greater than twenty percent of the total change Δθt, Δβt, and Δϕt, respectively, typically are not evidence of a spoof attack. Consequently, the incremental changes Δθi, Δβi, and Δϕi are limited to a maximum of twenty percent of the total changes Δθt, Δβt, and Δϕt, respectively.
When the incremental change Δθi between all sequential frames in the signal 48 is less than twenty percent of the total change Δθt, the signal 48 may be used to detect user liveness. Otherwise, the signal 48 is considered faulty and is not usable for detecting user liveness. Likewise, when the incremental change Δβi, between all sequential frames in the signal 50 is less than twenty percent of the total change Δβt, the signal 50 may be used to detect user liveness. Otherwise, the signal 50 is considered faulty and is not usable for detecting user liveness. Similarly, when the incremental change Δϕi between all sequential frames in the signal 58 are less than twenty percent of the total change Δϕt, the signal 58 may be used to detect user liveness. Otherwise, the signal 58 is considered faulty and is not usable for detecting user liveness. Although the example incremental changes Δθi, Δβi, and Δϕi are limited to a maximum of twenty percent of the total changes Δθt, Δβt, and Δϕt, respectively, the incremental changes Δθi, Δi, and Δϕi may alternatively be any percentage of the total changes Δθt, Δβt, and Δϕt, respectively, judged not to be evidence of a spoof attack.
When a signal representing illumination variations is monotonous, has a total change of at least five degrees, and the incremental change between sequential frames is less than twenty percent of the total change, the user may be determined to be a live person. Thus, user liveness may be determined based on illumination change only. The total change in the signal 58 may alternatively be any change deemed to facilitate accurate user liveness detection based solely on illumination. For example, the total change may be at least ten degrees. Because the signal 58 is monotonous, changes more than five degrees, and includes incremental changes between all frames less than twenty percent of the total change, the signal 58 may be used to determine a user is live. A monotonous signal varies in one direction only.
Different computing devices 10 associated with different users may allow for different maximum biometric data capture rates as well as different frame processing rates. To account for such different rates, the percentage of the total changes Δθt, Δβt, and Δϕt, respectively, may be normalized with respect to the frame capture rate of the computing device 10, or with respect to the frame processing rate of the computing device 10.
The computing device 10 may calculate a similarity score which indicates the similarity between signals. The similarity score may be calculated as the correlation coefficient between signals. For example, a similarity score may be calculated between the signals 48 and 50 as shown in
The signal 48 may be generated each time a user captures biometric data from his or her self while moving the computing device 10 from the first to the second positions. Thus, a signal 48 may be generated at least during an authentication transaction and while complying with a record data requirement. The signals 48 generated for different users are typically different because different people naturally move the computing device 10 from the first to the second position differently. Each signal 48 may further be mapped into a fixed-dimension vector, called a feature vector, which characterizes the underlying pattern of the signal.
To generate the feature vector different measures can be used such as, but not limited to, maximum, minimum and mean signal values, the maximum absolute increase between consecutive signal data points divided by their time difference, the maximum absolute decrease between consecutive signal data points divided by their time difference, the number of consecutive signal data points which are non-decreasing divided by the total number of data points, and the sum of consecutive signal data point differences divided by the sum of absolute signal data point differences. The feature vectors corresponding to the stored signals 48 may be used to represent the variability of the signals 48. More specifically, feature vectors corresponding to all of the signals 48 may be used or features vectors corresponding to a subset of the signals 48 may be used to represent the signal variability.
The variability of the signals 48 may be modeled using a probability density model such as a Gaussian Mixture Model (GMM). A GMM is represented as a weighted sum of Gaussian component densities. Model variables are estimated from signals 48 using characteristic optimization methods. For a GMM, the model variables are the mean signal vectors, covariance matrices, and mixture weights from all Gaussian component densities.
User-specific classification models can be generated from data that includes signals 48 from a specific user. Probability density models generated for a specific user are user specific classification models. Moreover, during a verification transaction, the user specific probability density model enables calculating a score between zero and one for a signal 48 generated during the transaction. The score represents the confidence that the user is genuine. When the confidence score is equal to or greater than a threshold score, the identity of the user is verified as true. Alternatively, when the confidence score is less than the threshold score the identity of the user may be verified as true.
As additional signals 48 for a user are generated during additional authentication transactions, the additional signals 48 may be added to those signals 48 for the user stored in the memory 14. The stored signals 48 may be included in data processed by a machine learning algorithm to generate a user specific probability density model, or may be included in data processed to update a previously generated user specific probability density model. Although the confidence score is calculated using a user specific probability density model as described above, the confidence score may alternatively be calculated using any type of user specific classification model that facilitates generating accurate and trustworthy verification transaction results
User identity verification may be based on any signal generated from any parameter obtained while moving the computing device 10 from the first to the second position. Such parameters include, but are not limited to, acceleration of the computing device 10, changes in the location of the image between processed frames, changes in the angle of the image between processed frames, and changes in the size of the image between processed frames. Such signals may be processed and the identity of the user verified in the same manner as described herein regarding the signal 48. Thus, the stored signals 50 and 58 may also be used in conjunction with a respective user specific classification model to verify user identities during verification transactions.
The identity of a user may also be verified based on any combination of such signals. Doing so, increases the accuracy and trustworthiness of verification results. Thus, for example, any combination of the signals 48, 50, and 58 may be used to verify the identity of users. Accordingly, it should be appreciated that the confidence score may alternatively be calculated based on any number of different signals and one or more classification models specific to the user. For example, when signals 48 and 50 are both generated from the captured biometric data, a confidence score may be calculated for each of the generated signals 48 and 50. The confidence score for signal 50 is generated using the signal 50 and a user specific classification model for the signal 50. Alternatively, the different confidence scores may be calculated using the same classification model wherein the same classification model is generated from the signals 48 and 50 for the user stored in the memory 14 as well as other data. The other data may include signals, the same as signals 48 and 50, generated for different users.
For such identity verifications, the confidence score calculated for each signal may be compared against a respective threshold score, and the identity of the user may be verified as true when each confidence score is equal to or greater than the respective threshold score. Alternatively, the confidence scores may be fused into a single confidence score which is compared against a threshold score. The identity of the user may be successfully verified when the fused confidence score is equal to or greater than the threshold score. Alternatively, the identity of the user may be verified as true when the confidence scores or the fused single confidence score is less that the respective threshold score.
After verifying the identity of a user based on a single signal or a combination of signals, the identity of the user may be verified based on any other type of authentication data, for example, biometric data. The biometric data may be from any processed frame in the video or may be from processed frames captured at incremental changes in the angle θ. Such verification transactions are multi-modal and thus increase the accuracy and trustworthiness of identity verification transaction results.
The data for any processed frame or combination of processed frames from the captured biometric data video may be used to generate trustworthy verification transaction results. For example, the data for processed frames captured at incremental changes in the angle θ may be used during verification transactions. Such incremental changes may be, for example, ten-degrees which equates to using data from processed frames captured at θ=45°, 35°, 25°, 15°, and 5°. The incremental change may alternatively be any increment that facilitates generating accurate and trustworthy verification transaction results.
Biometric templates may be generated for processed frames captured at these angles during a verification transaction. Each of the templates may be compared against a corresponding user record biometric template generated from record biometric data captured at the same angle θ. Thus, for example, a biometric template generated from biometric data captured at θ=45° may be compared against a corresponding user record biometric template generated from record biometric data captured at θ=45°. Likewise, a biometric template generated from biometric data captured at θ=35° may be compared against a corresponding user record biometric template generated from record biometric data captured at θ=35°. A matching score may be calculated for each comparison. Biometric data captured when the angle θ is 25°, 15°, and 5° may likewise be used to calculate additional matching scores.
The calculated matching scores may be combined, or fused, together to calculate a final matching score. When the final matching score equals or exceeds a threshold score, the claim of identity made by the user may be verified as true. Alternatively, when the final matching score is less than the threshold score the identity of the user may be verified as true. The matching scores may be combined, or fused, in any manner. The number of comparisons and resulting matching scores depends on the incremental change in the angle θ. Thus, the number of calculated matching scores may vary for each verification transaction. The record data initially stored for a user in the memory 14 should include biometric data and biometric templates for processed frames captured at each one-degree increment of the angle θ.
The incremental changes in the angle θ may be within a tolerance of plus or minus two degrees. Thus, for example, when the incremental change is ten-degrees the incremental changes in the angle θ may range between eight and twelve degrees. The tolerance is not limited to plus or minus two degrees and may alternatively be any range that facilitates generating accurate and trustworthy authentication results.
The data for each processed frame captured during verification transactions may be stored in the memory 14. The stored data may be analyzed for movement patterns unique to a user. Such movement patterns may include how a user moves his or her head through the angle α while moving the computing device 10 from the first to the second position. Different people typically exhibit different head movement patterns while moving the computing device between the first and second positions. Consequently, user head movement patterns may be used as a basis for verifying the identity of a user. Should a detected movement pattern not match the movement pattern expected for a user, verification fails.
Although user head movement patterns are described herein, the pattern may alternatively be for any user movement that can be accurately analyzed such as, but not limited to, the angular speed at which the user moves the computing device 10 from the first to the second position.
The information shown in
For each processed frame, the perpendicular distance relative to the line 66 is calculated for each point of interest. For points below the line 66 the perpendicular distances are negative and for points above the line 66 the perpendicular distances are positive. The distance D and the perpendicular distances may be calculated as a number of pixels. The distance D varies with the distance between the computing device 10 and the user during biometric data capture. More specifically, when the computing device is positioned closer to the user the number of pixels between the eyes increases, so the distance D increases. When the computing device 10 is positioned further from the user the number of pixels between the eyes decreases, so the distance D decreases.
The information shown in
Points of interest may be occluded by another object and thus not be included in the field of view 60 for one frame, but may be included in the field of view 60 for a subsequent frame. For example, in one frame, the corner of a picture hanging on a wall behind the user 38 may be occluded by a coat hanging on a coat rack behind the user 38. In a subsequent frame, the corner of the picture may be included in the field of view. New point pt4 is a point of interest that may have been occluded in the frame illustrated in
The information shown in
The point of interest pt3 does not appear in this frame which indicates that the computing device 10 is positioned such that pt3 is not included in the field of view 60. Alternatively, if point pt3 represents a corner of an object, for example the corner of a painting, at least the corner represented by point pt3 is not included in the field of view 60. A perpendicular distance is not calculated for point pt3 because point pt3 is not included in the field of view 60. Although four points of interest are described herein, there may be more or fewer points of interest.
The perpendicular distances calculated for each point of interest are divided by the distance D to calculate, for each processed frame, a ratio for each point of interest therein. The ratios may be converted into percentages which are plotted over time to form a signal for each point of interest. The point of interest signals may be used to determine user liveness.
The similarity score between the signal 48 and the signals 68, 70, 72, and 74 is the average of the correlated coefficients calculated for the processed frames, multiplied by negative one (−1). The average is calculated by summing the correlation coefficients calculated for the processed frames, and dividing the sum by the number of temporal segments in the signal 48. Multiplying by negative one should yield more accurate user liveness detection results. Using the example correlation coefficients calculated for the processed frames, an example similarity score of 0.755 (i.e., (((−0.7)(2)+(−0.75)(1)+(−0.8)(4)+(−0.75)(13))/20)(−1)=0.755) may be calculated. The similarity score is compared against the threshold score and if the similarity score is at least equal to the threshold score the user is considered to be a live person. For this example, 0.755 is greater than the threshold of 0.70 so the user is determined to be a live person. Alternatively, when the similarity score is less than the threshold score the user may be considered to be a live person. Thus, user liveness may be determined using signals created from points of interest included within the field of view 60 during biometric data capture.
Although the similarity score between signal 48 and the signals 68, 70, 72, and 74 is calculated from the average of the correlation coefficients for each processed frame, the similarity score may alternatively be calculated from the median value of the correlation coefficients for each processed frame. The similarity score as described with regard to the signals described herein may alternatively be calculated using any appropriate correlation method, or may be calculated in any manner, that facilitates accurate comparison against a threshold score. For example, when the frame processing rate is not regular, a weighted average may be calculated and multiplied by negative one. In other methods of calculating the similarity score, it may not be necessary to multiply by negative one.
Locations of the points of interest in the field of view 60, the distance D, the perpendicular distances, percentages, and correlation coefficients are additional examples of parameters that may be generated by the computing device 10.
While the computing device 10 is moved, the computing device 10 also generates parameters for each processed frame of the video. For each processed frame, the computing device 10 associates 88 all the frame data as stored in the memory 14 with the generated parameters in the memory 14. Next, the computing device 10 continues by creating signals from the generated parameters and calculating a similarity score for the created signals. When the similarity score is at least equal to the threshold score, the computing device 10 determines 90 the user is live. Otherwise, the user is not considered live. A message indicating the user is live, or not, may be transmitted to a service provider computer system operating a website on which the user desires to conduct the network-based transaction. Next, processing ends 92.
The information shown in
More specifically, the computing device 10 continues by obtaining biometric data from any one of the processed video frames captured by the computing device 10 while in the second position, generating a biometric template from the obtained data, and verifying the identity of the user based on the generated biometric template. When the identity of the user is not verified 98 as true, processing ends 92. However, before processing ends 92, the computing device 10 may continue by transmitting a message indicating that the user's claim of identity was not verified as true. The message may be transmitted to a service provider computer system operating a website on which the user desires to conduct the transaction. When the identity of the user is verified 98 as true, the computing device 10 continues by transmitting 100 a message indicating the user's identity was verified as true to a service provider computer system operating the web site on which the user desires to conduct the transaction. Next, processing ends 92.
At operation 98, the identity of the user may alternatively be verified based on the biometric data from processed frames captured at ten degree incremental changes in the angle θ. As another alternative, at operation 98, the identity of the user may be verified based on any signal or combination of signals that may be generated from parameters or background points. Moreover, the identity of the user may be verified based on signals and biometric data.
The information shown in
While the computing device 10 is moved, the computing device 10 also generates parameters for each processed frame of the video. For each processed frame, the computing device 10 associates all the frame data as stored in the memory 14 with the generated parameters in the memory 14. Next, the computing device 10 continues by determining which parameter to use as a basis of verification and identifying processed frames 114 captured at certain values of the parameter. The parameter may be the angle θ and the certain values may be calculated based on ten degree incremental changes in the angle θ yielding values of θ=45°, 35°, 25°, 15°, and 5°. Thus, the identified frames are frames captured at θ=45°, 35°, 25°, 15°, and 5°. Next, processing continues by generating a biometric template for the biometric data included in each identified frame, comparing 116 each generated biometric template against a corresponding user record biometric template, and calculating 116 a matching score for each comparison. The corresponding user record biometric templates were generated from data included in frames captured at the same certain values of the parameter, that is, at θ=45°, 35°, 25°, 15°, and 5°.
Next, processing continues by verifying 118 the identity of the user. More specifically, each matching score is compared against a threshold score, and when each matching score exceeds the threshold score, the claimed identity of the user may be verified 118 as true. After verifying 118 the claimed identity of the user as true, processing continues by transmitting 120 a message to a service provider computer system operating a web site on which the user desires to conduct the network-based transaction. The message indicates that the claimed identity of the user was verified as true. Next, processing ends 122.
Although each matching score is required to exceed the threshold score for a true verification transaction result in the example verification method, any number of matching scores may alternatively be required to exceed the threshold score to yield a true verification result. Moreover, the identity of the user may alternatively be verified by combining, or fusing, the matching scores into a final matching score and comparing the final matching score against a final threshold score. When the final matching score is equal to or greater than the final threshold score, the claimed identity of the user may be verified as true. Alternatively, the identity of the user may be verified when the matching scores or the final matching score are less than the respective threshold score.
The information shown in
The example methods described herein may be conducted entirely by the computing device 10, or partly on the computing device 10 and partly on other computing devices 34 and computer systems 32 operable to communicate with the computing device 10 over the network 36. Moreover, the example methods described herein may be conducted entirely on the other computer systems 32 and other computing devices 34. Thus, the example methods may be conducted on any combination of computers, computer systems 32, and computing devices 34. Furthermore, data described herein as being stored in the memory 14 may alternatively be stored in any computer system 32 or computing device 34 operable to communicate with the computing device 10 over the network 36. Additionally, the example methods described herein may be implemented with any number and organization of computer program components. Thus, the methods described herein are not limited to specific computer-executable instructions. Alternative example methods may include different computer-executable instructions or components having more or less functionality than described herein.
In example embodiments, the above-described methods and systems enhance the trustworthiness of user liveness detection results. More specifically, a user starts capturing biometric data as a video from his or her self with a computing device when the computing device is in a first position. The computing device captures biometric data of the user as a video while the user moves the computing device from the first position to a second position. Moreover, the computing device generates parameters for processed frames in the video and associates the generated parameters with at least biometric image data from the respective frame. The computing device generates signals from the parameters and calculates a similarity score that represents the similarity of the signals. When the similarity score is at least equal to a threshold score, the computing device concludes the user is a live person.
After concluding the user is a live person, the computing device may continue by verifying the identity of the user, and after verifying the identity of the user as true may transmit a message to a service provider computer system that operates a website on which the user desires to conduct a network-based transaction. As a result, detection of high definition video playback spoofing attempts is facilitated to be increased, trustworthiness of user liveness detection results is facilitated to be enhanced, accuracy and trustworthiness of identity verification transactions are facilitated to be enhanced, and costs incurred due to successful spoofing and faulty verification transaction results are facilitated to be reduced.
In other embodiments, the above-described methods and systems enhance the accuracy and trustworthiness of verification transaction results. More specifically, a user starts capturing biometric data as a video from his or her self with a computing device when the computing device is in a first position. The computing device captures biometric data of the user as a video while the user moves the computing device from the first position to a second position. Moreover, the computing device generates parameters for processed frames in the video and associates the generated parameters with at least biometric image data from the respective frame.
The computing device generates signals from the parameters and calculates a confidence score based on one of the signals and a classification model specific to the user. The classification model is generated from stored signals generated for the same parameter. The confidence score is compared against a threshold score. When the confidence score is equal to or greater than the threshold score the identity of the user is verified as true and processing continues by transmitting a message to a service provider computer system operating a website on which the user desires to conduct a network-based transaction. The message indicates that the claimed identity of the user was verified as true. As a result, the accuracy and trustworthiness of identity verification transactions are facilitated to be enhanced, and costs incurred due to successful spoofing and faulty verification transaction results are facilitated to be reduced.
The example methods for determining user liveness and for verifying user identities described above should not be considered to imply a fixed order for performing the method steps. Rather, the method steps may be performed in any order that is practicable, including simultaneous performance of at least some steps. Moreover, the method steps may be performed in real time or in near real time. Furthermore, the invention is not limited to the embodiments of the methods described above in detail. Rather, other variations of the methods may be utilized within the spirit and scope of the claims.
This is a continuation application of U.S. patent application Ser. No. 15/355,540, filed Nov. 18, 2016, which is a continuation-in-part application of U.S. patent application Ser. No. 15/265,012, filed Sep. 14, 2016, which is a continuation-in-part application of U.S. patent application Ser. No. 15/231,863, filed Aug. 9, 2016, the disclosures of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
7027617 | Frishholz | Apr 2006 | B1 |
7630522 | Popp et al. | Dec 2009 | B2 |
8457367 | Sipe et al. | Jun 2013 | B1 |
8542879 | Nechyba et al. | Sep 2013 | B1 |
8676123 | Hinkle | Mar 2014 | B1 |
9025830 | Ma et al. | May 2015 | B2 |
9105132 | Thorn | Aug 2015 | B2 |
9137246 | Parry et al. | Sep 2015 | B2 |
9202105 | Wang et al. | Dec 2015 | B1 |
9392460 | Blake et al. | Jul 2016 | B1 |
9395562 | Nguyen et al. | Jul 2016 | B1 |
9600649 | Parry et al. | Mar 2017 | B2 |
9953149 | Tussy | Apr 2018 | B2 |
10084776 | Ionita | Sep 2018 | B2 |
20040234120 | Honda et al. | Nov 2004 | A1 |
20060206724 | Schaufele | Sep 2006 | A1 |
20070226509 | Senga et al. | Sep 2007 | A1 |
20080192980 | Park et al. | Aug 2008 | A1 |
20090137286 | Luke et al. | May 2009 | A1 |
20090309698 | Headley | Dec 2009 | A1 |
20100017618 | Golic | Jan 2010 | A1 |
20100149365 | Ishihara | Jun 2010 | A1 |
20110254942 | Suzuki | Oct 2011 | A1 |
20120027292 | Kozakaya et al. | Feb 2012 | A1 |
20120036433 | Zimmer et al. | Feb 2012 | A1 |
20120069308 | Satake et al. | Mar 2012 | A1 |
20130016882 | Cavallini | Jan 2013 | A1 |
20130069988 | Kamei et al. | Mar 2013 | A1 |
20130188840 | Ma et al. | Jul 2013 | A1 |
20130222236 | Gardenfors et al. | Aug 2013 | A1 |
20130254909 | Marengo et al. | Sep 2013 | A1 |
20130329014 | Obata | Dec 2013 | A1 |
20140009387 | Hwang | Jan 2014 | A1 |
20140016837 | Nechyba et al. | Jan 2014 | A1 |
20140270412 | Ma et al. | Sep 2014 | A1 |
20140330900 | Libin et al. | Nov 2014 | A1 |
20140347397 | Wu | Nov 2014 | A1 |
20150033305 | Shear | Jan 2015 | A1 |
20150104081 | Ionita | Apr 2015 | A1 |
20150128075 | Kempinski | May 2015 | A1 |
20150169943 | Khitrov et al. | Jun 2015 | A1 |
20150264567 | Sensharma et al. | Sep 2015 | A1 |
20150347734 | Beigi | Dec 2015 | A1 |
20160026782 | Smowton | Jan 2016 | A1 |
20160035096 | Rudow et al. | Feb 2016 | A1 |
20160063235 | Tussy | Mar 2016 | A1 |
20160182503 | Cheng et al. | Jun 2016 | A1 |
20160188958 | Martin | Jun 2016 | A1 |
20160196475 | Martin | Jul 2016 | A1 |
20160294824 | Sezille | Oct 2016 | A1 |
20160300099 | Xiaolu et al. | Oct 2016 | A1 |
20160353018 | Anderson et al. | Dec 2016 | A1 |
20160373647 | Garcia Morate et al. | Dec 2016 | A1 |
20170048244 | Loughlin-McHugh et al. | Feb 2017 | A1 |
20170063852 | Azar | Mar 2017 | A1 |
20170193215 | Parry et al. | Jul 2017 | A1 |
20170262961 | Ekambaram et al. | Sep 2017 | A1 |
20170308738 | Zhang et al. | Oct 2017 | A1 |
20170310898 | Misawa et al. | Oct 2017 | A1 |
20170364732 | Komogortsev | Dec 2017 | A1 |
20180041503 | Lindemann | Feb 2018 | A1 |
20180173979 | Fan | Jun 2018 | A1 |
20180218139 | Tussy | Aug 2018 | A1 |
20180239955 | Rodriguez et al. | Aug 2018 | A1 |
Number | Date | Country |
---|---|---|
201410483249.2 | Sep 2014 | CN |
2 725 521 | Apr 2014 | EP |
Entry |
---|
European Search Report from EPO Application No. 17183890.7, dated Dec. 12, 2017, pp. 1-6. |
Notice of Allowance for counterpart U.S. Appl. No. 15/363,232 dated Dec. 12, 2018, pp. 1-12. |
Office Action for counterpart U.S. Appl. No. 15/231,863, dated Sep. 4, 2019, pp. 1-18. |
Final Office Action for counterpart U.S. Appl. No. 15/355,540, dated Aug. 2, 2019, pp. 1-20. |
Number | Date | Country | |
---|---|---|---|
20180046853 A1 | Feb 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15355540 | Nov 2016 | US |
Child | 15363320 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15265012 | Sep 2016 | US |
Child | 15355540 | US | |
Parent | 15231863 | Aug 2016 | US |
Child | 15265012 | US |