[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

CN117377988A - Identification using facial-related physical features - Google Patents

Identification using facial-related physical features Download PDF

Info

Publication number
CN117377988A
CN117377988A CN202280034667.6A CN202280034667A CN117377988A CN 117377988 A CN117377988 A CN 117377988A CN 202280034667 A CN202280034667 A CN 202280034667A CN 117377988 A CN117377988 A CN 117377988A
Authority
CN
China
Prior art keywords
person
video frames
camera
physical
face
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202280034667.6A
Other languages
Chinese (zh)
Inventor
N·古普塔
朱静雯
陈钟勋
A·C·爱德华兹
F·沙伯特
V·莎尔玛
H·达尔坎普
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Apple Inc
Original Assignee
Apple Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Apple Inc filed Critical Apple Inc
Priority claimed from PCT/US2022/029314 external-priority patent/WO2022241294A2/en
Publication of CN117377988A publication Critical patent/CN117377988A/en
Pending legal-status Critical Current

Links

Landscapes

  • Collating Specific Patterns (AREA)
  • Alarm Systems (AREA)

Abstract

Techniques are disclosed for determining whether to include body imprints in a cluster of body imprints associated with an identified person. For example, the device performs facial recognition to identify the identity of the first person. The device also identifies and stores physical characteristic information of the first person, the stored information being associated with the identity of the first person based on the recognized face. Subsequently, the device receives a second video feed showing an image of a second person whose face is also determined to be recognized by the device. The device then generates a quality score for the physical feature in the image of the user. The device may then add the image with the physical feature to the image cluster associated with the person if the quality score is above a threshold, or discard the image if the quality score is not above the threshold.

Description

Identification using facial-related physical features
Cross Reference to Related Applications
The present application claims priority from U.S. provisional application Ser. No. 63/188,949 filed on day 5, month 14 of 2021 and U.S. provisional application Ser. No. 63/341,379 filed on day 5, month 12 of 2022, which are incorporated herein by reference in their entireties for all purposes.
Background
Techniques exist for performing identity recognition of a person using an image of the person's face. For example, a mobile phone camera may capture an image showing a portion of a person's face. The application may analyze the image to determine features of the person's face and then attempt to match the person's face with other known faces. However, identity recognition is a growing field and various challenges exist in connection with performing recognition. For example, given a particular video feed (e.g., if a person is facing away from the camera), the video camera may sometimes not be able to perform facial recognition of the person. In these cases, it may be difficult to accurately perform identification of a person.
Drawings
FIG. 1 is a simplified block diagram of an exemplary system according to some embodiments;
FIG. 2 is another simplified block diagram illustrating at least some example techniques for providing notifications based on the determination of the presence of a particular person at a location, according to some embodiments;
FIG. 3 is another simplified block diagram illustrating at least some example techniques for providing notifications based on the determination of the presence of a particular person at a location, according to some embodiments;
FIG. 4 is another simplified block diagram illustrating at least some example techniques involving a User Interface (UI) for providing notifications based on determining the presence of a particular person at a location, in accordance with some embodiments;
FIG. 5 is another simplified block diagram illustrating an exemplary architecture of a system for providing notifications based on the determination of the presence of a particular person at a location, in accordance with some embodiments;
FIG. 6 is a simplified flowchart illustrating a process for providing notifications based on the determination of the presence of a particular person at a location, in accordance with some embodiments; and is also provided with
Fig. 7 is a simplified flowchart illustrating a process for providing notification based on determining the presence of a particular person at a location, according to some embodiments.
Fig. 8 is a simplified flowchart illustrating a process for determining whether to add a newly identified body print (e.g., torso image) to a cluster of body prints (e.g., gallery) of known people, according to some embodiments.
Detailed Description
In the following description, various examples will be described. For purposes of explanation, numerous specific configurations and details are set forth in order to provide a thorough understanding of the examples. It will be apparent, however, to one skilled in the art that some examples may be practiced without these specific details. Furthermore, well-known features may be omitted or simplified in order not to obscure the examples described herein.
The techniques described in this disclosure enable identification of a particular person based on physical characteristics of the particular person to be performed. The physical characteristics of a particular person may be associated with their identity based on previously performed facial recognition of the particular person. In one example, the device may receive a first video feed, for example, showing a particular person (e.g., including his face and his torso portion of his body) going to the camera. The device may perform facial recognition to identify the identity of the particular person. The device may also identify physical features of the particular person from the first video feed, for example, based on analysis of other physical features of the particular person (e.g., including their torso, clothing worn, etc.). The device may then store physical characteristic information of the particular person in association with the identity of the particular person based on having recognized the face of the particular person from the first video feed. A library of images may be stored, wherein each image in the library contains a torso, and the image of the torso may be associated with the particular person whose face is identified. In some cases, the identified face may correspond to a person in the contact list so that the owner/user of the face/personal device is aware. The device may then receive a second video feed showing a second person whose face is determined to be unrecognized by the device (e.g., an occluded view or poor image quality) or not visible to the device (e.g., away from the camera). The device may compare the stored physical characteristic information (e.g., image library) of the first person with additional physical characteristic information of the second person shown in the second video feed (note: the second person may be the first person; however, this is to be determined). Based on the comparison, the device may provide a notification indicating whether the identity of the second person corresponds to the identity of the first person. The notification may be a message (e.g., text, email, pop-up, etc.), or it may be an on-screen name or visual identifier that displays the frame or video. In this way, the techniques may enable the device to identify a person without having a view or quality image of the face. In addition, the device may provide notification of the presence of a particular person in a wider range of scenes and/or with greater accuracy/recall, including, for example, when the person's face may not be shown in the video feed and/or recognizable by the device. In some examples, the image library corresponding to the physical features (e.g., torso, etc.) may only store a particular amount of time (e.g., a day, a week, etc.). In this way, the image library may be refilled for each detected person every day (or longer).
In an illustrative example, consider a scenario in which a first device (e.g., a resident device) within a home environment provides notification of the presence of a person located at a particular location associated with the home environment. In this example, the resident device (e.g., a smart speaker, a smart digital media player, and/or any device that may be configured or otherwise intended to be relatively stationary in a location (e.g., a residence) is communicatively connected to a first camera (e.g., positioned to view a residence entry location proximate to a front door) and a second camera (e.g., positioned within the residence to view an area within the residence, such as a hallway, living room area, etc.). The resident device may receive a first video feed (e.g., comprising a first plurality of video frames) during a first period of time (e.g., a first phase, during a particular weekday morning). The first plurality of video frames may show a first person approaching a front door of the home, whereby at least one frame of the first plurality of video frames includes a face of the first person. The resident device may identify the identity of the first person based at least in part on recognizing the face of the first person (e.g., using a suitable face recognition algorithm). For example, the resident device may have previously stored a facial stamp of the first person (e.g., personal contacts associated with a household, such as residents, friends, caregivers, caretakers, etc.), whereby the facial stamp corresponds to a unique multi-dimensional (e.g., vector-based) representation of the face. In one example, the dimension of the vector may be associated with at least one feature of the face of the contact. The facial recognition algorithm may compare a facial stamp determined from one of the first plurality of video frames with a previously stored facial stamp associated with the first person. Upon determining that the facial stamps match, the resident device may thus identify the identity of the first person (e.g., match the personal contact) shown in the first plurality of video frames.
The resident device may then identify one or more physical characteristics of the first person, and may then store physical characteristic information corresponding to the identified one or more physical characteristics. For example, the resident device may determine that at least one frame of the first plurality of video frames includes both the recognized face and other physical features of the first person, including but not limited to a torso, one or more arms, and/or one or more legs. The resident device may then identify one or more physical characteristics of the first person based on the other physical characteristics. These physical characteristics may also be associated with, for example, the shape of the first person, the texture and/or color of the body, the texture and/or color of the article of clothing worn by the first person, etc. In some embodiments, physical characteristic information corresponding to the identified one or more physical characteristics may be stored by the resident device. As previously described, these physical features may be stored as an image library (e.g., torso library) (e.g., by a resident device) and may be stored for only one day (or longer if desired). For example, the resident device may generate a body print of the first person, similar to that described above with respect to a facial print (e.g., a multi-dimensional vector). The body print may include a multi-dimensional vector associated with (e.g., representing) one or more physical features of the first person, whereby a dimension of the vector may be associated with at least one feature of the body of the contact. In some embodiments, the body imprints (and/or facial imprints) may utilize any suitable format and/or structure that may be suitable for effective comparison between body imprints, as further described herein.
Continuing with the description above, the body print may be stored in association with the identity of the first person. For example, the resident device may associate the identity of the first person with the body print using a frame showing the recognized facial and body features of the first person. In this example, a body print cluster (e.g., an image library) may also be generated and stored in association with the identity of the first person, respectively. For example, a different body print may be generated for each frame of the first plurality of video frames showing at least a portion of the first person's body. Using the above description, as the first person approaches the entrance of the home, the video frames may capture different aspects (e.g., shape, color, texture) of the person's torso, arms, legs, and/or other physical features, respectively. Upon determining that the identified body (e.g., and/or body part, as the case may be) in each frame is the same person (e.g., first person) associated with the identified face, the resident device may generate a body print based on the respective frame and then associate the body print with the identity of the first person. In some embodiments, the resident device may select body imprints to be included in the body imprint cluster based on determining that the body imprints provide acceptable information gain (e.g., above a threshold quality level), which may then be used to compare with another body imprint when performing identification. It should be appreciated that the body imprints generated from a particular frame may be candidates for inclusion within the body imprints cluster, even though the face of the first person may be unrecognizable in the particular frame. This may be the case, for example, if the resident device determines (e.g., based on executing a motion tracking algorithm) that the body shown in a particular frame is the same body shown in the relevant frame in the first plurality of frames. In this example, the body (and/or body part) shown in the relevant frame may include a face recognized by the resident device as corresponding to the identity of the first person.
Continuing with the description above, during a subsequent second period of time (e.g., during a second phase), the resident device receives a second plurality of video frames including a second person. For the second plurality of video frames, the resident device may determine that the face of the second person is not recognized by or in the field of view of the first device. For example, the second plurality of video frames may show the body of the second person being away from the camera with a portion of their face facing away from the camera (and/or otherwise obscured). In addition, the second plurality of video frames may be of poor image quality such that the face of the person is not recognizable at all. Thus, while the body of the second person may be captured within a frame of the second plurality of video frames, the resident device may determine that the face (e.g., and/or identity) of the second person is not recognized based on facial recognition. The resident device may thus attempt to determine the identity of the second person based on comparing previously stored body characteristic information (e.g., the body print of the first person) with additional body characteristic information (e.g., the body print) of the second person. In this example, the resident device determines that the body print of the first person matches the body print of the second person (e.g., based on calculating euclidean distances between the body print vectors). In some embodiments, a machine learning model of the resident device may be trained to generate vectors based on learning and/or perform comparisons to associate a first body print of a particular person with a second (e.g., different) body print of the same person, thereby performing training on multiple training samples. Thus, the resident device may determine that the second body print matches the first body print (or at least some number or percentage of body prints in a gallery (e.g., cluster)) of body prints. When a match is detected, the resident device may provide a notification (e.g., an audio announcement and/or text-based message) indicating that the identity of the second person corresponds to the identity of the first person or that the identity of the second person is unknown.
In some embodiments, the resident device may store a plurality of body print clusters for contacts associated with the home environment, respectively. Thus, when attempting to determine whether a most recently determined body print (e.g., of a second person in upper Wen Lishi) matches a previously stored body print, the resident device may compare different body prints of the same cluster to the most recently determined body print and/or compare body prints of multiple clusters to the most recently determined body print.
In some examples, the model (or a different model) used to generate the body print vector may determine that the image quality of the second body print is poor (e.g., below a threshold quality/confidence score). Various examples of this determination will be described below. When it is determined that the quality of the second body print is poor (e.g., below the quality/confidence score), the second body print is available for comparison with the image library; however, the second body print may not be added to the gallery. In this way, a poor quality body print will not affect future comparisons between future detected body prints and the gallery. Alternatively, in some examples, if the quality of the second body print is determined to be good enough (e.g., above the confidence score), the second body print may be added to the gallery for future comparison. In either case, the second body print may be used to compare with the gallery, regardless of the confidence score. In this way, once a good quality body print gallery is established for a contact (e.g., a person identified in a user's contact), the quality of the gallery will not be affected by future images (e.g., including images that are not body prints at all (e.g., not torso) in practice).
In some embodiments, the machine learning model executing on the resident device (and/or alternatively) may also be trained to compare other physical characteristics of the first person with other physical characteristics of the second person to determine whether there is a match. In one example, the physical characteristics may be associated with a person's movement over time (e.g., a person's gait while walking). In this example, and similar to that described above, a "motion stamp" that captures the unique motion of a person over time may be stored in a suitable database structure (e.g., a multidimensional vector). The previously stored motion signature of the first person may be compared to the recently generated motion signature of the second person to determine if there is a match. If there is a match, the resident device may utilize this information to determine if the second person's identity matches the first person's identity.
The techniques described herein provide several technical advantages over existing systems. In one example, the techniques described herein may enable a system to determine the identity of a person from a video feed even when the person's face may be determined to not be recognized by the system. This can improve the existing system by extending the range of scenarios in which the identity of a user can be recognized. This may improve the customer experience of a system operating in a home environment, for example, by optionally informing the user of the presence of a particular person at a location in the home. This function may be enabled even when a camera observing the location may not often capture detailed (e.g., good quality) images of the face of the person at the location, thereby making face recognition difficult to perform accurately (e.g., with acceptable accuracy and/or recall). Thus, the techniques described herein provide another mechanism (e.g., a fallback mechanism or a parallel mechanism) for performing identity recognition. In another example, the techniques described herein may be used to determine when it is detected that one or more physical characteristics of a particular person have changed. For example, the system may detect a likelihood that clothing worn by a particular person may have changed from a first time period (e.g., in the morning) to a second time period (e.g., in the afternoon). In some embodiments, this may be used to update the body print of a particular person at the appropriate cadence to ensure that the accuracy of the detection remains acceptable. In yet another example of technical advantages, the described techniques may implement a mechanism whereby a home environment including multiple cameras (e.g., each camera receiving a video feed) may utilize the respective feeds of the cameras to generate high quality body print clusters of people based on frames extracted from the multiple cameras. The person's body print clusters can also be synchronized between multiple devices (e.g., user devices, resident devices) in the home environment such that each device has a high quality set of body prints (and/or facial prints) that can be used for identity detection in the home environment setting. In some embodiments, this synchronization mechanism between multiple devices (e.g., resident devices) of a home environment may enable more privacy control. For example, instead of the device first uploading frames and/or body prints to a remote cloud server (e.g., then being retrieved from the cloud by another device of the home environment), body print clusters may be synchronized locally between devices of the home environment.
For clarity, it should be understood that while embodiments of the present disclosure are primarily directed to performing identification of a person in a home environment setting, embodiments should not be construed as being limited thereto. For example, the system of the present disclosure may be used in any suitable environment, such as an office building, warehouse, parking lot, park, etc. Further, while the embodiments described herein may primarily relate to providing notification (e.g., announcement) when the identity of a person is detected (or an unknown person is detected) at a particular location, the system may take any suitable action (e.g., grant access to a resource such as a door lock, deny access, perform automated actions, etc.) when performing identification.
FIG. 1 is a simplified block diagram 100 illustrating a system notification service operating in an exemplary environment, according to some embodiments. In fig. 1, the exemplary environment depicted is a home environment 101. The home environment 101 may have some commonalities with itOne or more persons (e.g., contacts) of an affiliation (e.g., family member, roommate, caretaker, etc.). In this example, user 112 may represent an affiliated user (e.g., "person A," which may be a housekeeper). In addition, devices 102 (e.g., tablet computers, smart home controllers, smart digital media players, home automation devices (e.g., that are part of a home automation system), etc.) may exist within the home environment 101. The device 102 (e.g., a resident device of a home) may be communicatively connected to one or more viewing cameras associated with the home environment 101. For example, the resident device may receive video feeds from the viewing camera 108 and the viewing camera 110, both cameras associated with the home environment 101. Each video feed may include a plurality of video frames. In this example, the two cameras may correspond to installed viewing cameras positioned to view different locations associated with the home environment 101. For example, the viewing camera 108 may observe that the user 112 (e.g., including the face and other physical features of the user 112) is at time T 1 Access to the residence (e.g., access to the front door of the residence) (during a first period of time). Meanwhile, the viewing camera 110 may be positioned to view an interior area (e.g., hallway, room, etc.) of the home environment 101. In this example, the viewing camera 110 may be positioned such that during a subsequent time period from when the user 112 enters home (at time T N ) Viewing camera 110 may capture a user 114 (which may be the same (or a different) person than user 112) facing away from camera 110. The device 102 may include a notification service 104 that executes a detection model 106 to detect the identity of a person (e.g., a trained machine learning model). As further described herein, the notification service 104 may be enabled to provide notification of the identity of a person shown in the video feed even when the person's face may not be recognized by the notification service 104. For example, notification service 104 may notify the home that detected user 114 matches the identity of user 112 (e.g., "person A").
Turning in more detail to the elements of fig. 1, the home environment 101 may be associated with a physical location and/or structure (e.g., a house and/or surrounding yard or aisle, etc.), whereby one or more cameras may be positioned within the home environment 101. It should be appreciated that the techniques described herein may be performed within any suitable physical environment (e.g., physical location) from which one or more cameras may be located. Some non-limiting examples include houses, entertainment centers, office buildings, outdoor parks, parking lots, and the like.
Using the home environment 101 as a representative physical setting, the cameras of the home environment 101 may be positioned in any suitable location associated with the home environment 101. In illustration 100, an observation camera 108 is positioned near a front door to investigate the outdoor entrance of a house, and an observation camera 110 is positioned to investigate the interior corridor of the house. In other embodiments, the camera may survey additional and/or alternative locations of the home environment 101, including, for example, a backyard of a home, a particular room (e.g., living room), a garage, and the like. In some non-limiting examples, the viewing camera may be a webcam, pan-tilt-zoom (PTZ) camera, or the like, which may be communicatively connected to a separate device (e.g., device 102). In some examples, the viewing camera may be a component of a user device (e.g., tablet, mobile phone), which in turn may be connected to a separate device (e.g., device 102). In some implementations, the device 102 itself may include an observation camera. It should be appreciated that any suitable arrangement may be used to communicatively connect the camera and the device, as described herein. Using the example of illustration 100, the viewing camera is communicatively connected (e.g., via a WiFi signal) to the device 102, whereby the viewing camera transmits video feeds of any suitable image (e.g., frame) quality, respectively, to the device 102. In some implementations, the techniques described herein may be performed with any suitable number of viewing cameras (e.g., one camera, two cameras, ten cameras, etc.). For example, in one embodiment, the techniques herein may be performed with a separate viewing camera (e.g., viewing camera 108). In this example, the observation camera 108 may be used to perform identification not only when the user 112 is approaching a residential entrance, but also at a later time when the user 112 is leaving a residence and the user's face may be facing away from the camera 108.
In some embodiments, device 102 may be any suitable computing device associated with (e.g., residing in) a particular environment and configured to receive video feeds (e.g., multiple video frames) from an observation camera, analyze the frames to determine if a person detected in the video frames matches a particular identity, and then perform one or more operations upon completion of the analysis (e.g., provide notification to a user or tag the user with their identity for recording, viewing the feeds later, and/or viewing a live stream of video at the same time). As depicted in diagram 100, device 102 may correspond to a resident device. In some non-limiting examples, the resident device may be a smart speaker, a smart television device, a tablet device, a smart digital media player (e.g., configured to provide streaming media to a television), and so forth. While the techniques described herein may be described primarily in the context of being performed by a resident device (e.g., resident device 102), it should be understood that embodiments are not so limited. For example, in some embodiments, device 102 may correspond to a user device (e.g., a tablet device, a mobile phone, a Personal Computer (PC), or a server device).
Continuing with the example of fig. 1, resident device 102 may correspond to a smart speaker device. When resident device 102 determines an identification of the face of user 112 (e.g., approaching a residential entrance and/or moving within a house), resident device 102 may provide a notification by declaring, for example, that a particular contact of home environment 101 (e.g., user 112) has arrived. In another example, the resident device 102 may transmit a message to one or more user devices that a particular contact has arrived. For example, the alert message may pop up on the display of the user device. It should be appreciated that the notification may be provided by the resident device using any suitable channel and/or method, depending on, for example, the type of resident device, the type of user device, the surrounding environment, etc. For example, consider another embodiment in which the resident device may correspond to a smart television device (e.g., a digital media player connected to a television). The smart television device may be equipped to present a Graphical User Interface (GUI) on the television, which may include a picture-in-picture (PIP) presentation. In this example, the resident device may provide the notification in the form of an Audio Visual (AV) feed. For example, the resident device may display a video feed (e.g., received from the viewing camera 108 or 110) in an insertion window of the television. In addition, where the viewing camera and/or the smart television device may be equipped with bi-directional audio (e.g., with a speaker and microphone), the resident device may enable bi-directional communication between the user in the home environment and an external person (e.g., user 112).
In some implementations, the resident device 102 may contain a local memory bank adapted to store and process information associated with images received from one or more cameras. This may include, for example, physical characteristic information of the person detected in the image. In some embodiments, the physical characteristic information may include facial characteristics of the person (e.g., stored within a facial stamp). In some embodiments, the physical characteristic information may also and/or alternatively include non-facial characteristics associated with the body of the person and/or movement of the body. The information may be associated with, for example, a person's head, a person's torso, a person's gait, one or more arms or legs, body shape, etc. In some embodiments, information associated with a person's body may be included within a body print (e.g., a multi-dimensional vector), as further described herein. In some embodiments, the physical characteristic information may include information associated with a texture or color of the person's body and/or a piece of clothing worn by the person. In some embodiments, the physical characteristic information may include any suitable combination of facial and/or non-facial features associated with the person's body. In some embodiments, resident device 102 may store physical characteristic information of a person in association within the identity of the person. For example, using illustration 100, resident device 102 may store a facial stamp of user 112 (which may be a contact of a home environment), or the like.
In some embodiments, the physical characteristic information (e.g., a facial stamp, a body stamp, an image, etc.) of the first person may be captured and/or stored in association with the identity of the first person (e.g., user 112) at any suitable time and subsequently processed according to any suitable method. For example, consider an illustrative scenario in which resident device 102 operates notification service 104 (which may execute detection model 106). Notification service 104 may be on timeM T 1 The previous time received an image of the first person (e.g., user 112, "person a" in fig. 1) from an appropriate source (e.g., a photo library of user devices, a viewing camera, etc.), generated a facial stamp from the image (e.g., via detection model 106), and the facial stamp was stored within a set of reference facial stamps for user 112. Subsequently, at time T 1 The notification service 104 of the resident device 102 may receive a first plurality of frames (e.g., in a video feed) from the viewing camera 108. The detection model 106 of the resident device 102 may then perform facial recognition using the set of reference facial stamps for the first person (e.g., the user 112). Upon recognizing the face of user 112, resident device 102 may identify the identity of user 112 (e.g., via a previously stored association between the identity of user 112 and facial feature information (e.g., a facial stamp) of user 112). After identifying the identity of the user 112, in this example, the resident device 102 (e.g., via the detection model 106) may identify one or more physical features of the body of the user 112 from one or more frames of a first plurality of frames used to identify the face of the user 112. The resident device 102 may thus store physical characteristic information (e.g., body print and/or body print clusters) of the user 112 in association with the identity of the first person (e.g., the user 112) based on the identified face shown in at least one of the first plurality of frames.
Continuing the above scenario, at a subsequent time T N The notification service 104 of the resident device 102 may receive a second plurality of video frames from the viewing camera 110 within the home environment 101 this time. As noted above, it should be understood that the second plurality of video frames may also be received from the same viewing camera 108 from which the resident device 102 receives the first plurality of video frames. In this example, resident device 102 may determine that the face of the second person (e.g., user 114, which may (or may not) be the same person as user 112) may not be recognizable by face recognition (e.g., because the person may be facing away from viewing camera 110). The resident device 102 (e.g., via the detection model 106) may determine additional physical characteristic information (e.g., corresponding to one or more physical imprints) of the second person shown in the second plurality of frames, and then compare the additional physical characteristic information with the previously stored physical characteristic informationStored physical characteristic information of the first person (e.g., from a person at time T 1 A received first plurality of video frames). It should be appreciated that the detection model 106 of the resident device 102 may compare the additional physical characteristic information to physical imprints (and/or clusters of physical imprints) of a plurality of people (e.g., contacts corresponding to the home environment 101) to determine whether a match exists. Depending on whether a match is determined via the comparison, notification service 104 of resident device 102 may then provide a notification (e.g., via an audio message and/or via a message to another device) indicating whether the identity of the second person shown within the second plurality of frames corresponds to the identity of the first person shown in the first plurality of frames. In this example, as depicted within diagram 100, resident device 102 determines that the identity of the second person (e.g., user 114) corresponds to (e.g., matches) the identity of the first person (e.g., the second person may be "person a", whereby user 114 is the same person as user 112). At time T N Resident device 102 (e.g., a smart speaker) may then output an audio message "i have detected someone who may be person a".
In some embodiments, multiple devices may be synchronized within a home environment. For example, consider a scenario in which a resident device 102 may be a first device of a plurality of resident devices of the home environment 101 (e.g., located in different locations of the home environment 101) (e.g., including a first device and a second device). Each device may execute a notification service similar to notification service 104. In this scenario, the first device and the second device may synchronize physical characteristic information (e.g., body print) of a particular person (e.g., a contact of the home environment 101). For example, using the illustration of diagram 100, a first device and a second device may be maintained separately (e.g., at time T 0 ) A synchronized body print cluster (e.g., a reference body print cluster) of the user 112 stored on each device. At time T 1 The first device may receive the first plurality of video frames, generate one or more body imprints (and/or facial imprints), and determine that at least one generated body imprints is associated with a higher information gain level than at least one body imprints in the existing body imprints cluster of the user 112. The first device may be available to a user 112 to update the existing clusters. The first device may further transmit the new body print associated with the higher information gain to the second device, which in turn may update its reference body print cluster for the user 112. In at least this way, the devices of the home environment 101 can be synchronized to ensure that they have the latest physical imprint of a person. In some embodiments, devices of the home environment 101 may not synchronize body imprints with each other. In some embodiments, the devices may exchange information (e.g., synchronization data, including images, facial stamps, body stamps, etc.) according to any suitable cadence and/or data set (or subset).
In some examples, certain body imprints may be discarded from the analysis, as reference body imprints (e.g., gallery) for comparison with the clusters, or as candidates for addition to the clusters. The determination of whether to discard the body imprint may be made based on one or more rules (or heuristics). An exemplary rule includes discarding images having body imprints (also referred to as torso) rotated beyond a threshold degree. For example, a person's body may bend (e.g., pick up something), or the camera angle may be such that the body appears at an angle. Other rules include discarding images that "scroll" more than a threshold (e.g., from a degree of vertical rotation) and/or discarding images that are in landscape mode (e.g., any images that are wider than high). Additionally, the image may have a defined region of interest (e.g., a particular portion of the image that is considered to include a facial stamp or body stamp). In some examples, the image may be discarded when the detected body print is too close to the edge of the region of interest. In some examples, any torso that applies to these rules may be discarded or otherwise ignored as if they were not a torso at all.
Other rules may also be considered as appropriate for body imprints that may be discarded with respect to adding to the cluster, but that are still available for analysis for the body imprints cluster. For example, some body imprints may have a high enough quality level that they may still be used for comparison with a cluster of body imprints to potentially identify a person, but the quality level is too low to be included in the cluster. Thus, a confidence score may be generated for all torso that pass the first set of discard rules (see rules above regarding rotation, scrolling, and/or orientation), and this confidence score may be used to determine whether to add the torso to the cluster after the comparison is complete. Thus, those torso's not included in the gallery are not associated with any identified faces. This prevents low confidence score torso from affecting future recognition attempts, but still allows the system to attempt to match and identify people based on the torso.
Various techniques may be employed to determine the confidence score for a given body print (e.g., torso). For example, image characteristics including some combination of saturation, brightness, sharpness, and/or contrast may be used to generate a confidence score (also referred to herein as a quality score). In some cases, the saturation level, sharpness level, brightness level, and/or contrast level of the image containing the body print may be analyzed. Using some combination of these techniques, the machine learning model output may include a confidence score. In some examples, if the confidence score is below a threshold, the image is considered low quality, and if the confidence score is above the threshold, the image is determined to be high quality. High quality images may be added to the clusters, while low quality images may be excluded from the clusters.
In some examples, an image may be received (e.g., by the resident device 102) and a confidence score may be generated by the detection model 106. The confidence score may be an output of a model separate from the multidimensional vector, or it may be part of the vector. In any case, the detection model 106 (or a different algorithm used prior to analysis by the detection model 106) may be configured to evaluate any combination of saturation, brightness, sharpness, and/or contrast to generate a confidence score.
In some examples, the evaluation of the image characteristic may be a first type of confidence score, and a second type of confidence score may be received as an output from a deep learning model trained with body imprints. In some embodiments, the model may be trained to output confidence scores, and some training data may need to be annotated. The training data may include good quality and poor quality body print images, and these images may need to be annotated prior to training. These training images may be annotated based on two separate confidence scores (e.g., saturation, brightness, sharpness, and/or contrast) determined by the above analysis. In addition, training data may be annotated based on false body print detection generated by the body print detector. For example, if the body imprint detector detects a false body imprint (e.g., an image in which there is actually no body imprint (e.g., torso)), the image may be marked as false. Some images may be manually marked as false. However, in other examples, algorithms may be used to automatically generate the false body print (e.g., by automatically cropping the body print image to remove the body print from the image). For example, a bounding box may be generated in the image and moved up/down/left/right as needed to trim out the body imprint, thereby creating a false body imprint. These automatically generated false body print images may also be automatically labeled as false. Thus, in some cases, the deep learning model may be trained with a) body print images labeled based on the above-described image characteristics and/or b) body print images labeled based on false body print detection scores (e.g., true or false). Given this training, the model may output a vector for input and/or a confidence score identifying whether the image includes a body print and the quality of the body print.
As described, in some examples, the final output (e.g., confidence/quality score) of the model may then be used to determine whether the image is to be added to the body print cluster or simply for comparison with existing body print clusters. If the confidence/quality score is above a threshold, the image may be used to compare to the current cluster and then added to the cluster for future comparison. On the other hand, if the confidence/quality score is below the threshold, the image may be used only for comparison with the current cluster (e.g., in the contact recognition phase) and then discarded. However, in some examples, if the person's face is also recognized, the image may still only be added to the cluster.
In some embodiments, the intermediate entity may perform one or more computing operations of notification service 104. For example, consider the case where an intermediate entity may correspond to a server device of a cloud computing platform. In this case, resident device 102 may offload one or more operations to a remote platform. For example, instead of the resident device 102 being responsible for training the detection model 106, the cloud server may train the detection model 106 and then assign the model to the user device and/or the resident device. In another example, the cloud server may receive data (e.g., physical characteristic information associated with one or more persons) from the resident device 102 and then compare the information to determine whether an identity match exists. It should be appreciated that any suitable combination of operations may be performed by resident device 102, an associated device of home environment 101, and/or an intermediate entity that may be external to home environment 101.
Fig. 2 and 3 are simplified block diagrams illustrating at least some example techniques for providing notification that a particular person may be detected at a location, according to some embodiments. The operation of process 200 spans both fig. 2 and 3, and collectively corresponds to an exemplary high-level process of a system (e.g., resident device 102 of fig. 1) that provides notification that the particular person was detected at the location (e.g., within a home environment context, which may be similar to home environment 101 of fig. 1). The operations of fig. 2 may correspond to a first stage of the process in which the system stores first body characteristic information (e.g., including one or more body imprints) of a first person identified in a first plurality of video frames. The operation of fig. 3 may correspond to a second phase of the process after the first phase, wherein the system receives and analyzes a second plurality of video frames (e.g., received during a subsequent time period), wherein the system determines that the face of the second person shown in the second plurality of frames may not be recognized by the system (e.g., by facial recognition). The system accordingly determines second physical characteristic information of the second person and then compares the second physical characteristic information with the previously stored first physical characteristic information to determine the identity of the second person.
Diagram 201 of fig. 2 depicts an exemplary state corresponding to a first stage of process 200, and diagram 301 of fig. 3 depicts an exemplary state corresponding to a second stage of process 200. Illustration 201 may include elements similar to those depicted with reference to fig. 1. For example, a first person (e.g., user 205) may be similar to user 112 of fig. 1, and viewing camera 203 may be similar to viewing camera 108. The data store 221 may correspond to a local repository of a system (e.g., resident device 102) within a home environment. Meanwhile, with respect to fig. 301, second person 225 may be similar to user 114 of fig. 1, viewing camera 223 may be similar to viewing camera 110, and system 235 may be similar to resident device 102 of fig. 1.
Turning in more detail to process 200, at block 202, the system may receive a first plurality of video frames during a first time period, whereby at least one of the frames shows a face of a first person. Further illustrated using illustration 201, a first person (e.g., user 205) may be proximate to viewing camera 203. In this example, the observation camera 203 may be positioned to observe activity near the entrance of the front door of the home. In this way, the viewing camera 203 may view the face and body of the user 205, for example, as they approach the front door of the home during a first period of time (e.g., during the morning). It should be appreciated that the viewing camera 203 may be positioned at any suitable location such that the camera 203 may capture facial and non-facial body parts of the user 205. Continuing with this example, a video feed may be transmitted by the viewing camera 203 to the system (e.g., system 235, which may be similar to the resident device 102 of fig. 1), whereby the video feed includes a first plurality of video frames 207.
In some embodiments, the system may perform one or more operations to analyze frames in the first plurality of video frames 207. For example, the system may perform object detection of one or more objects within a frame relative to a representative particular frame 214 of the first plurality of frames. This may include, for example, detecting a facial object, a non-facial body part object (which may sometimes be referred to as a "body" object), and so forth. It should be appreciated that multiple people may be shown in a particular frame 214, whereby more than one facial object and/or body object may be detected. In some embodiments, any suitable object recognition algorithm may be utilized, for example, a type of neural network (e.g., convolutional Neural Network (CNN)). Upon detecting the one or more objects, the system may generate a bounding box for the particular object. For example, with respect to frame 214, the system may generate bounding box 211 that includes the body of user 205 (e.g., including torso, arms, hands, legs, etc.). In some implementations, any suitable region (e.g., torso only, arms only, both torso and head, entire person, etc.) may be captured within the bounding box. Further, the system may generate a bounding box 209 that includes the face of the user 205 (e.g., the front of the head). In some embodiments, the system may determine which frames of the video feed to select for analysis as the first plurality of video frames 207 (e.g., each frame or samples of those frames).
As described herein, in some embodiments, multiple people and/or other objects may be detected within a particular frame. Further, in some implementations, the video feed (e.g., the first plurality of video frames 207) may correspond to activities (e.g., movements) of one or more people and/or objects. Thus, in some embodiments, the system may associate (e.g., track) bounding boxes of the same object across multiple frames. For example, assume that a first plurality of video frames 207 shows that user 205 is walking near the front door. Thus, each frame may show the body of the user 205 in a different position, depending on the gait of the user 205. The system may determine a bounding box of the body (e.g., including the torso) of the user 205 for each frame analyzed. As the torso appears in each image, the system may then analyze the features of the torso to determine if it is the same torso (or a different torso of another person). For example, a torso of similar size and location (e.g., from frame to frame) may be associated with the same person (e.g., user 205), while a torso in a different location (e.g., greater than a predefined threshold distance difference) and/or having a different size between frames may be determined to be a different person. In this way, the system can track and associate bounding boxes of the same person across the first plurality of video frames 207. Thus, the system may similarly track multiple persons within the first plurality of video frames 207. In some embodiments, a set of bounding boxes of a body (e.g., including a torso) of a given person (e.g., user 205) may be associated with one or more bounding boxes of the face of the given person. For example, the bounding box 211 may be included within a set of bounding boxes of the same person (e.g., user 205), which may be further associated with the bounding box 209 (and/or a set of facial bounding boxes) of the face of the same person. In this way, and as further described herein, the system may then associate one or more body imprints (e.g., determined from portions of frames corresponding to bounding boxes of a person's body, respectively) with the face (and/or identity) of the same person.
At block 204, the system identifies the identity of the first person based on recognizing the face shown in one or more frames of the first plurality of video frames. For example, continuing within the description of diagram 201, upon generating bounding box 209 of the face of user 205, the system may perform a face recognition process to recognize the face of user 205. For example, as described herein, prior to the first period of time, the system may maintain and store information associated with the face of the user 205. In some embodiments, this information may be stored, for example, within a facial stamp using a suitable data structure and/or format. In some implementations, the facial stamp may correspond to a multi-dimensional vector (e.g., a vector of 128 dimensions or any suitable number of dimensions). In this example, the size of the facial stamp may be associated with at least one feature of the face of the user 205 (e.g., features of lips, nose, eyes, relative distance between facial markers, texture, color, etc.). In some embodiments, a machine learning model (e.g., a neural network) may be trained to output a facial stamp vector. Although the embodiments described herein may primarily describe performing facial recognition using facial imprinting, the embodiments should not be construed as limited thereto. The pixel regions of the image may be analyzed using any suitable face recognition algorithm, such as using a machine learning algorithm (e.g., CNN). In some embodiments, a cluster of facial stamps may be selected and/or stored in association with an identity of the user 205 (e.g., a contact of a home environment), whereby a facial stamp may be selected to be at least partially included within the cluster because it provides a higher level of information gain/quality (e.g., as compared to other candidate facial stamps) suitable for performing facial recognition. For example, the facial stamps corresponding to capturing images of (e.g., and/or generated from) the face of the user 205 from different (e.g., unique) angles, illuminations, locations, etc., respectively, may be selected to be included within the clusters.
Continuing with the illustration 201, the system may perform facial recognition on a face associated with a bounding box 209 of the user 205. For example, the system may determine a set of face (image) cuts 213 from a set of bounding boxes including the face of bounding box 209. The system may then generate one or more facial stamps from the set of one or more facial cuts 213. For example, a given image crop may be used to generate a facial stamp of the face of the user 205. The machine learning model of the system (e.g., detection model 106 of fig. 1) may then compare one or more facial stamps (which were generated from facial cuts 213 of the first plurality of video frames 207) to previously stored reference facial stamp clusters of the user 205 (e.g., retrieved from a data store 221 of the system). In some embodiments, the system may compare the one or more facial stamps to a plurality of reference facial stamp clusters (e.g., stored in the data store 221) that are each associated with a different contact of the home environment. In this example, the detection model may detect a match between at least one facial stamp (e.g., from at least one frame, such as frame 214) and one of the facial stamps in the reference facial stamp clusters stored on the system. Thus, the system may thereby determine the identity 215 of the user 205 as "person a" (e.g., a known contact of the home environment).
At block 206, the system may store first body characteristic information of the first person in association with the identity of the first person. Continuing with the illustration of diagram 201, the system can generate one or more body clips 219 from the first plurality of video frames 207 (e.g., from one or more bounding boxes). In some embodiments, the body image crop may include any suitable portion of the body. For example, the body image crop may include only the torso, include both the torso and the head, include the entire body, and so on. The illustration 201 depicts the entire body as having been included within a set of body cuts 219. Similar to that described with respect to the generation of the facial print, a trained machine learning model (e.g., a sub-model of the detection model 106) may determine first body characteristic information 217 of the first person based on the set of body cuts. For example, a machine learning model may be trained to determine body feature information corresponding to one or more body features associated with a given body for a given body cut. These features may be associated with any suitable aspect of the body (e.g., body shape, color, texture, characteristics of clothing worn by the body, and/or movement of the body). In some embodiments, the physical characteristic information may include non-facial characteristic information that may be used to identify a person in addition to performing facial recognition. In some embodiments, these features may be associated with a particular portion of the body (e.g., the torso, the back of the brain, or arms, etc.) and/or any suitable combination of portions thereof. In some embodiments, these features may be used to uniquely identify a person (e.g., user 205 with identity 215). In some embodiments, first body characteristic information 217 may be collectively represented by any suitable data structure (e.g., body print). As described herein, and similar to a facial stamp, a body stamp may include a multi-dimensional vector (e.g., 128 dimensions or any suitable number of dimensions). In some embodiments, the dimension of the body print may be associated with at least one feature of the body. In some implementations, the association between the dimension and the at least one feature can be dynamically determined by the machine learning model when generating the vector. In some embodiments, the system may effectively store data representing aspects of a person's face or body using, in part, vector structures (e.g., for body imprinting and/or facial imprinting). In some embodiments, the vector structure may also enable more efficient vector comparisons (e.g., determining euclidean distance and/or cosine similarity of vectors), e.g., to enable more efficient identity detection. In some embodiments, the system may perform any suitable transformation on the crop (and/or bounding box of the image) to prepare the crop for input into the machine learning model so that vectors (e.g., facial and/or body imprints) may be generated. In one example, the torso may be resized (e.g., from a portrait image to a square image) by cropping.
In some embodiments, the system may associate first body characteristic information 217 (e.g., a body print of user 205) with the identity 215 of the first person ("person a") based in part on previously performed facial recognition. The association may also be performed based on the system associating the body clip 219 with the same face, as described herein (e.g., with respect to block 202). In some embodiments, the system may store any suitable association with respect to images, facial features (e.g., facial imprints), physical features (e.g., body imprints), and identities of persons. In some embodiments, the system may store the body print clusters in association with the identities 215. For example, the body imprints may be generated per body (image) cut, whereby a selected number of body imprints may be included within a body imprint cluster (e.g., a reference cluster) based on being determined to have a higher information gain (e.g., unique body features for performing identity detection) than other body imprints not included. In some embodiments, the one or more body imprints and/or associations may be stored in data store 221 for subsequent use, as described with reference to fig. 3. Accordingly, block 206 may end the first stage of process 200 (e.g., indicated by triangle mark "a").
As described herein, fig. 3 shows a second phase of process 200, whereby diagram 301 of fig. 3 depicts an exemplary state corresponding to the second phase of process 200.
Turning in more detail to the second stage of process 200 (e.g., as indicated by triangle mark "a"), at block 208, the system receives a second plurality of video frames 227 showing a second person during a second period of time, whereby the face of the second person is determined to be unrecognized by the system. For example, further illustrated using illustration 301, the second time period may follow the first time period of the first phase (e.g., the afternoon time period on the same day or on a different day). For example, the user 205 may have entered the home environment 101 of fig. 1 in the morning, and the viewing camera 223 (e.g., which may be similar to the viewing camera 110 of fig. 1) may capture a video feed (including a second plurality of video frames) showing the second person 225 at a later time in the afternoon. In this example, the second person 225 may be leaving the camera 223 (e.g., the face of the second person 225 faces away from the camera such that the face is not captured by the video frames of the video feed). In some embodiments, the face is captured by the video feed, but may still not be recognizable by the system, e.g., due to poor lighting conditions, image artifacts, occlusions, etc.
In some embodiments, the system may first attempt to perform facial recognition of the second person 225 based on the second plurality of video frames 227, similar to that described with reference to fig. 2 (e.g., block 202 and/or block 204). For example, the system may determine one or more bounding boxes for particular objects in each frame. In one example, for a representative frame in the second plurality of video frames 227, the bounding box 229 may correspond to a head of the second person 225 and the bounding box 231 may correspond to a body (e.g., excluding a head) portion of the second person 225. The system may determine a facial crop from the bounding box of the head of the second person 225 (e.g., potentially including a portion of the face, or not showing the face), determine a facial stamp from the facial crop, and then compare the facial stamp to one or more reference facial stamp clusters (e.g., contacts of the home environment). In this case, the machine learning model (e.g., detection model 106) of the system may determine that the face may not be recognized (e.g., because the face may not be sufficiently captured to be face-recognized with an acceptable level of confidence). In some embodiments, if the system is capable of performing accurate facial recognition to determine the identity of the second person 225, the operations of block 210 may not be performed (which may involve performing identification based on non-facial physical characteristics). For example, in the event that facial recognition does not successfully determine the identity of the second person 225 with high confidence, these operations may be performed as a fallback mechanism. In some embodiments, the system may perform the operations of block 210 and/or block 212 independent of whether facial recognition may successfully recognize the identity of the second person. In some embodiments, the system may perform facial recognition in parallel with performing identification based on non-facial physical features.
However, in some examples, using the operations of block 210 as a fallback is entirely optional. The system may decide whether to fall back to use body imprinting based on the quality of the face. In some cases, if the face is identifiable, a fallback to use body imprint may not be utilized. However, if the face is unrecognizable, the system may or may not fall back to use the body imprint. In some examples, it may be advantageous to fall back to using body print detection to attempt to identify a person regardless of whether the face is identifiable (e.g., where body print comparison techniques produce high accuracy identification). However, in some examples, the system may first determine whether the second person's facial stamp is identifiable (e.g., good quality) and recognizable, and then compare only the second person's body stamp to the body stamp gallery if the face is of low quality and not recognizable as a known person (e.g., a contact). Alternatively, in some examples, the system may use only the physical features of the second person when a) the facial stamp has low quality (e.g., not high enough quality to detect the person) or b) the face is not present in the lens. Additionally, in some cases, physical characteristics of a person that are not known to the user of the device/home environment may not be stored at all. This also helps to reduce false positives by avoiding storing the body print of an unknown person in a body print image library.
Continuing with the operation of block 208, and similar to that described with respect to block 202 of fig. 2, the system may determine second physical characteristic information associated with the second person. For example, the system may determine the body crop based on a bounding box of the object detected in the second plurality of video frames 227. As described herein, body trim may include any suitable one or more portions of the body and/or associated articles of clothing. For example, body clipping may include the head and torso of a person shown in the image. In another example, the body crop may include the entire body of the person shown in the image. In another example, the body trim may include only a torso portion of the body (and/or associated clothing). In some embodiments, the body crop may correspond to a new image cropped from the original image. In some embodiments, the body crop may correspond to a portion of the original image, whereby parameters of the portion are determined and/or stored by the system. In any event, the system provides one or more body cuts from respective frames in the second plurality of video frames 227 to a machine learning model (e.g., detection model 106), whereby the model can determine second body characteristic information from the body cuts. For example, the system may determine a body print for a particular body cut, as described with respect to fig. 2. In some embodiments, the system may determine the plurality of body imprints from samples of frames in the second plurality of video frames 227.
At block 210, the system may compare the first physical characteristic information of the first person with the second physical characteristic information of the second person, whereby the first physical characteristic information may be pre-stored in association with the identity of the first person. For example, recall that at block 206 of fig. 2, the system stores first body characteristic information 217 (e.g., a body print) in association with the identity of the first person. In some embodiments, the system may have stored a body print cluster in association with the identity 215 of the first person (e.g., "person a"). In this example, note that a body print corresponding to the first body characteristic information is generated based on the body image cropping, whereby the first person faces the camera. At the same time, a body print corresponding to the second body characteristic information is generated based on the body image cropping, whereby the second person (which may or may not be the same identity as the first person) faces away from the camera. While these aspects of clipping may be different, it is also noted that the first person and the second person are shown wearing the same garment (e.g., a lattice shirt). One or more dimensions of the corresponding body print may also capture this information, which may be used to compare the body print to determine if there is a match. In another example, the body print may be associated with a color of the shirt, a shape of the body and/or shirt, a shape of the head, a texture of the shirt, and the like. In some implementations, one or more of these features may remain substantially similar (e.g., the same) for a period of time regardless of whether the user is likely facing the camera or facing away from the camera. Thus, the machine learning model of the system may be trained to generate similar body imprints of the same person with similar body features (e.g., the same shirt color and/or pattern, the same body shape, etc.), regardless of whether the person may face or face away from the camera in the respective photograph. The machine learning model may also be trained to generate similar body imprints of the body of the same person, despite some characteristic differences between the bodies of the persons captured in different frames. For example, the model may generate a body-like impression of the body, although the body is shown as having slightly different dimensions between images and/or slightly different illumination between images. Further, as described herein, it should be appreciated that the reference body print clusters (e.g., including body print for the first body characteristic information 217) may be respectively associated with different vantage points of the body (e.g., different perspectives, etc.), and similarly, for body print clusters generated from the second plurality of video frames (e.g., including the second body characteristic information 233). Thus, the system may be enabled to perform a wider and/or more accurate range of body print comparisons, and as part of the comparison, may have the flexibility to analyze body features from different vantage points. In one example, the system may generate a score based on the comparison, whereby the score may correspond to a level of similarity (e.g., euclidean distance) between different body imprints.
At block 211, the system may determine a confidence score for the second body feature information (e.g., body print/torso) and use the score to determine whether to include the new second body feature information in the body print clusters. For example, if the confidence score is above a threshold (and the face is recognized), the newly identified body print (e.g., second body feature information) will be included in the body print cluster. However, if the face is not recognized or the confidence score is below the threshold, the newly identified body print will be discarded after performing the operations of block 210.
At block 212, the system may provide a notification that the identity of the second person matches the identity of the first person. For example, assume at block 210 that the system determines that first body characteristic information 217 matches second body characteristic information 233. In this example, the system may determine a score that matches a predefined threshold metric (e.g., greater than or equal to a predefined threshold, such as 90%). The system may then determine that the identity of the second person matches the identity of the first person based on the comparison. If the score does not match the threshold metric, the system may determine that the identity of the second person does not match the identity of the first person. In the example of process 200, the system determines that there is a match, and thus, second person 225 may be "person a" (e.g., having identity 215). Thus, in this example, where system 235 may correspond to a smart speaker device, the system provides notification in the form of an audio announcement "i have detected someone who may be person a". In some embodiments, the system may provide notification for presentation according to any suitable method (e.g., audio, video, text, etc.), as further described with reference to fig. 4.
FIG. 4 is another simplified block diagram illustrating at least some example techniques for providing notifications based on the determination of the presence of a particular person at a location, according to some embodiments. In the illustration 400 of fig. 4, several elements are depicted, including a viewing camera 402, a video feed 404, a body crop 408, a user device 406, a pop-up notification 410, and a video presentation 412. The diagram 400 depicts a scenario in which the viewing camera 402 captures a video feed 404 and transmits it to a device (e.g., the resident device 102 of fig. 1), whereby the resident device analyzes the video feed 404 and transmits a notification to the user device 406 to alert the user that a particular person (e.g., "person a") is present at a particular location that the viewing camera 402 is viewing.
Turning in more detail to fig. 4, the viewing camera may be positioned at any suitable location. For example, the viewing camera 402, which may be similar to the viewing camera 110 of fig. 1, may be positioned in an interior (e.g., living room hallway) environment. The camera 402 may be positioned at about waist height. In some embodiments, the camera may be positioned closer to the ground, mounted with a bird's eye view, or any suitable height such that the camera may capture at least a portion of a person's body and/or face. In some implementations, the location of the cameras may depend on one or more factors including, for example, the number of cameras, the location of each camera, the expected traffic pattern around the camera location, and so forth. For example, assume that the observation camera 402 is the only camera connected to the resident device of the home environment performing identity detection. In this example, the viewing camera 402 may be positioned to capture the face of a person approaching the camera 402 during a first period of time (e.g., into a living hallway) that may correspond to the first phase of the process 200 and to capture the body of a person facing/moving away from the camera 402 during a second period of time (e.g., out of a living hallway) that may correspond to the second phase of the process 200. The video feed 404 illustrates an example in which a person may be leaving the camera, whereby the video feed 404 may not capture the person's face so that it may be recognized by the resident device. In another example, where there may be two or more connected cameras (e.g., similar to fig. 1), a first camera may be positioned to capture primarily the face of a person (e.g., into a house), while a second camera may be positioned such that it captures primarily the back of the person (e.g., primarily showing non-facial features of the person). In this example, and as described herein, techniques may enable the system to identify the identity of a person captured by a video feed of a second camera (and/or a first camera, e.g., when the person is leaving a home), even though the face may not be recognized by the system.
As described herein, the body crop 408 may be generated based on a plurality of video frames of the video feed 404. For example, when a person leaves the viewing camera 402, the video feed 404 may capture different positions of the person's torso, arms, and/or head. It should be appreciated that other objects (e.g., people, plants, doors, etc.) may also be captured within the video frames, whereby the system detects and isolates (e.g., via bounding boxes and/or crop) the body of a particular person within one or more video frames. In some embodiments, the plurality of body crops 408 may be similar to those described with reference to body crops generated at block 208 of the second stage of process 200. The resident devices may thus generate a set of body imprints for the body cuts, respectively. Note that each body print may capture a different (or similar) vantage point of the person, whereby the body print may be compared to one or more reference body print clusters (e.g., determined during the first stage of process 200 and/or any suitable prior time).
In the example of diagram 400, upon comparing the previously stored reference body print with the body print of the person shown in body cut 408, the resident device determines that the person is likely to match the identity of "person a". The resident device (e.g., digital media player) generates a notification message and transmits the message to at least the user device 406. The message indicates that the resident device has detected that person a may be near a vicinity of the area where camera 402 (e.g., "camera 2" as shown in pop-up notification 410) is being viewed (or ever). In one example, user device 406 then displays pop-up notification 410 indicating that "camera 2 has detected someone who may be person a". In some embodiments, an application executing on the user device 406 may also (and/or alternatively) show a video presentation 412 of the area observed by the camera 402, thus enabling the user to visualize the person being identified and/or surrounding areas (e.g., for providing context). In some embodiments, the application may enable any suitable feature, for example, enabling a user of the user device to transmit an audio message (press a "Talk" button) for output (e.g., via a smart speaker) in the vicinity of the area where the detected person is observed. In another example, an application may enable a user to scan frames of a video feed, capture one or more frames, share images with others, and so forth.
As described herein, it should be appreciated that any suitable operation may be performed based on detecting the identity of a person in accordance with the techniques herein. In some non-limiting examples, the resident device may provide instructions for automatically adjusting a smart thermostat in a particular room, adjusting lighting in a room, playing music via a smart speaker, and so forth.
Fig. 5 is another simplified block diagram illustrating an exemplary architecture of a system for providing notifications based on the determination of the presence of a particular person at a location (e.g., within a home environment context), in accordance with some embodiments. The illustration 500 includes a user device 502 (e.g., which may have integrated camera components), an observation camera 504, a resident device 506, a network 508, and a remote server 522. The user device 502, the viewing camera 504, and the resident device 506 may be similar to any of the user devices, the viewing cameras, and/or the resident devices, respectively, described herein. Remote server 522 may correspond to one or more server computers (e.g., a server cluster) of a cloud computing platform, as described herein. In some implementations, the user device 502 and/or the resident device 506 may include the camera 504 as an integrated component. In some implementations, the camera 504 may be included within a device separate from the user device 502 and/or the resident device 506. For example, as described herein, camera 504 may be communicatively connected to user device 502 and/or resident device 506.
Network 508 may include any suitable communication path or channel such as, for example, wires or cables, optical fibers, telephone lines, cellular links, radio Frequency (RF) links, WAN or LAN networks, the internet, or any other suitable medium. Network 508 may include any one of many different types of networks (such as, for example, a wired network, the internet, a wireless network, a cellular network, other private networks, and/or a public network), or a combination of the above.
Turning in more detail to each element, the user device 502 may be any suitable computing device (e.g., a mobile phone, tablet, personal Computer (PC), smart glasses, smart watch, etc.). In some implementations, the user device 502 will have a camera (e.g., a mobile phone camera) embedded as part of the device. In some embodiments, the user device 502 will connect to another device (e.g., a stand-alone digital camera) from which the user device receives images (e.g., over the network 508). The user device 502 has at least one memory 510, one or more processing units (or processors) 514, a storage unit 516, a communication interface 518, and an input/output (I/O) device 520.
The processor 514 may be suitably implemented in hardware, computer-executable instructions, firmware, or a combination thereof. Computer-executable instructions or firmware implementations of the processor 514 may include computer-executable instructions or machine-executable instructions written in any suitable programming language to perform the various functions described.
Memory 510 may store program instructions that may be loaded and executed on processor 514, as well as data generated during execution of such programs. Depending on the configuration and type of user device 502, memory 510 may be volatile (such as Random Access Memory (RAM)) and/or nonvolatile (such as Read Only Memory (ROM), flash memory, etc.). In some implementations, the memory 510 may include a variety of different types of memory, such as Static Random Access Memory (SRAM), dynamic Random Access Memory (DRAM), or ROM. The user device 502 may also include additional storage 516, such as removable storage or non-removable storage, including, but not limited to, magnetic storage, optical disks, and/or tape storage. The disk drives and their associated computer-readable media may provide nonvolatile storage of computer-readable instructions, data structures, program modules and other data for the computing device. In some embodiments, the storage 516 may be used to store a photo library containing one or more images on the user device 502.
The user device 502 may also contain a communication interface 518 that allows the user device 502 to communicate with a storage database, another computing device or server, a user terminal, and/or other devices via the network 508. User device 502 may also include I/O devices 520, such as to enable connection with a keyboard, mouse, pen, voice input device, touch input device, display, speakers, printer, etc.
Turning in more detail to the contents of memory 510, memory 510 may include an operating system and one or more applications or services for implementing the features disclosed herein, including notification management module 512. Notification management module 512 may be responsible for performing one or more tasks, including configuring notification services of resident device 506 and/or sending (and/or receiving) data (e.g., image cropping) to resident device 506. For example, notification management module 512 may receive input to configure a resident device with settings for providing notifications. As described herein, one example may be a setting indicating the following operations: if the detected person is (or is not) a contact associated with the user device (e.g., the person is not found in any of the images in the photo library in storage 516), resident device 506 should only provide notification to user device 502. In another example, the settings may indicate how the notification should be provided. For example, one setting may indicate that resident device 506 should transmit a notification message to user device 502. Another setting may indicate that the resident device should broadcast a notification on a speaker connected to the resident device 506. Notification management module 512 (e.g., via a service or a background application running on user device 502) can transmit an image (e.g., image cropping generated from a photo library) to resident device 506 for processing by resident device 506. For example, the resident device 506 may generate a facial stamp (and/or reference facial stamp cluster) for the contact corresponding to the image in the photo library stored on the user device 502. The images may be transmitted in any suitable cadence and/or selection algorithm. In some embodiments, user device 502 may first encrypt the image transmitted to resident device 506. For example, user device 502 and resident device 506 may share an encryption key (e.g., a symmetric key), whereby resident device 506 receives an encrypted image and then decrypts the image using the encryption key. In some embodiments, the encryption key may not (or may) be shared with remote server 522, as further described herein. In some embodiments, the image may be transmitted first to remote server 522 (e.g., for temporary storage) and then later transmitted by remote server 522 to resident device 506. In some embodiments, the image may be transmitted directly to resident device 506 without involving remote server 522. It should be appreciated that one or more functions of notification management module 512 may be performed by (e.g., configure) resident device 506.
In some implementations, the viewing camera 504 may correspond to any suitable camera for capturing and transmitting images to the resident device 506. In some implementations, the viewing camera 504 can be positioned (e.g., mounted) at a particular location to have a particular viewable area, e.g., near a residential front door. The viewing camera 504 may be connected to the resident device 506 via a network 508.
In some embodiments, as described above, remote server 522 may correspond to a cloud computing platform. Remote server 522 may perform one or more functions including, for example: training one or more machine learning models (e.g., similar to that described with reference to detection model 106 of fig. 1), managing updates to the detection model, receiving images from a user device (e.g., user device 502), transmitting images to resident device 506, and so forth. As described above, in some embodiments, remote server 522 may not (or may not) have access to the encryption key used by user device 502 to encrypt the image. In some implementations, remote server 522 may receive images from user device 502 (and/or viewing camera 504), for example, when user device 502 does not have direct access to resident device 506. In this example, user device 502 may first transmit the encrypted image (e.g., image cropping) to remote server 522 in the cloud. The cloud may store the encrypted image crop for later transmission to the resident device 506. In some embodiments, the machine learning model (and/or sub-model) may be trained for any suitable purpose, including, for example, generating a facial stamp, generating a body stamp, comparing a facial stamp, comparing a body stamp, and the like.
Turning in more detail to resident device 506, resident device 506 may be a computer system including at least one memory 530, one or more processing units (or processors) 548, a storage unit 550, a communication device 552, and an I/O device 554. In some embodiments, these elements may be implemented in a similar manner (or in a different manner) as described with reference to similar elements of user device 502. In some implementations, the storage unit 550 may store images (e.g., image cropping) received by the user device 502 and/or the remote server 522. The resident device 506 may be housed in any suitable unit (e.g., a smart television, a smart speaker, etc.). As described herein, it should be understood that one or more of the elements described in illustration 500 (e.g., user device 502, camera 504, and/or remote server 522) may be enabled to perform one or more of the operations of resident device 506.
Turning in more detail to the contents of memory 530, memory 530 may include an operating system 532 and one or more applications or services for implementing features disclosed herein, including a communication module 534, an encryption module 536, a profile management module 538, a synchronization module 540, a model training module 542, a scoring module 544, and a notification management module 546. In some embodiments, one or more applications or services of memory 530 may be included as part of notification service 104 of fig. 1.
The communication module 534 may include code that causes the processor 548 to generate a message, forward the message, reformat the message, and/or otherwise communicate with other entities. For example, the communication module 534 may receive (and/or transmit) images from the user device 502 and/or the remote server 522. The communication module 534 may also be responsible for providing notifications. For example, the communication module 534 may transmit a notification message to the user device 502 upon detecting the presence and/or identity of a person based on a plurality of video frames received from the viewing camera 504. In some embodiments, communication module 534 may use any suitable channel and/or provide notifications to any suitable device. For example, the communication module 534 may provide audible notification via the speaker I/O device 554 at a location within the home environment. In another example, the communication module 534 may provide audiovisual notifications to a smart television within a home environment. For example, a PIP display of the smart television may display a video feed from camera 504 (e.g., showing a corridor through home, away from home, etc.). The smart television may also announce who is at the doorway and/or allow two-way communication via the speaker and/or microphone I/O devices of the resident device 506.
Encryption module 536 may include code that causes processor 548 to encrypt and/or decrypt messages. For example, the encryption module 536 may receive encrypted data (e.g., encrypted image cropping) from the remote server 522. In embodiments of the invention, encryption module 536 may include any suitable encryption algorithm for encrypting data. Suitable data encryption algorithms may include Data Encryption Standard (DES), triple DES, advanced Encryption Standard (AES), and the like. The encryption module may also store (e.g., in the storage unit 550) encryption keys (e.g., encryption keys and/or decryption keys) that may be used with such encryption algorithms. The encryption module 536 may encrypt and/or verify data using symmetric or asymmetric encryption techniques. For example, as described above, user device 502 may contain a code and/or key similar to encryption module 536 that is adapted to encrypt/decrypt data communications with the resident device (and/or remote server 522).
The profile management module 538 may include code that causes the processor 548 to maintain and store profiles for contacts. For example, the profile management module 538 may receive images (e.g., image clips) from one or more user devices and/or cameras, each image clip showing a portion of a face of a contact associated with a respective user device. The profile management module 540 may determine (e.g., via a trained model) facial feature information for a particular contact, which may include clusters of one or more reference facial stamps. The profile management module 540 may also determine non-facial physical characteristic information for a particular contact, which may include a cluster of one or more reference body imprints. In some embodiments, the module 540 may associate the identity of a particular contact with facial feature information and/or non-facial feature information. In some embodiments, elements of the profile may be updated separately according to any suitable cadence and/or heuristics. For example, facial feature information for a particular contact may be updated when a new image is received that provides more information gain than an existing facial image reference set. In another example, non-facial body characteristic information associated with the body may be updated according to a predefined schedule. For example, the system may update the body print clusters daily based in part on heuristics indicating that a person may change their clothing daily. In another example, the system may be enabled to determine when to change a person's clothing, and then update the body print clusters (e.g., reference body print) to up-to-date based on the up-to-date clothing. In some implementations, the profile management module 538 may store any suitable information that may be used to compare with recently received sensor data (e.g., frames of a video feed from the camera 504) to determine the identity of a person. For example, in another scenario, the system may store gait feature information corresponding to a unique profile of a person's walking pattern. This gait feature information may be compared to the reference gait information stored by the profile management module 538 to detect whether the detected gait of the person matches the reference gait profile. In some embodiments, any suitable number of body imprints (e.g., 10, 20, etc.) may be stored in the body imprint clusters. In some embodiments, any suitable algorithm may be used to determine the amount of information gain provided by a particular body imprint (e.g., a K-means clustering algorithm).
The synchronization module 540 may include code that causes the processor 548 to transmit and/or receive information associated with a synchronization profile across multiple devices (e.g., associated with the same home environment). For example, as described herein, resident device 506 may determine one or more images (and/or associated facial or body imprints) that provide a higher level of information gain when compared to an existing reference image (and/or reference facial or body imprints) for a particular person. The synchronization module 540 may then cause the one or more images to be transmitted as synchronization data to other resident devices of the home environment, whereby the receiving device updates reference data (e.g., images, facial imprints, body imprints, etc.) based on the received synchronization data. In this way, devices of the home environment can be synchronized with each other. It should be appreciated that any suitable device of the home environment (e.g., user device 502, remote server 522, etc.) may be synchronized according to the synchronization data. In some embodiments, one or more devices may be configured not to synchronize with other devices of the home environment.
Model training module 542 may include code that causes processor 548 to train a machine learning model. Machine Learning (ML) models may be trained to perform one or more subtasks including, for example, generating body feature information (e.g., captured via a body print vector or a motion print vector), facial feature information (e.g., captured via a facial print vector), and/or performing vector comparisons (e.g., determining cosine similarity) to identify whether a facial (e.g., and/or body, gait, etc.) match is detected. In some embodiments, model training module 542 may utilize any suitable machine learning technique. Some non-limiting examples may include utilizing a neural network, support vector machine, nearest neighbor method, or decision tree. As a representative example, involves training a neural network to generate a body print, a training process may begin whereby an untrained ML model receives multiple images (e.g., image cropping) of a particular person. The plurality of images may each include a different portion of the person's body (e.g., including the torso). For example, one portion may be a side view, another portion may be a direct view, another portion may be an opposite side view, etc. Some portions may have different conditions and/or backgrounds and/or may be captured by different devices (e.g., a camera of user device 502, viewing camera 504, etc.). In some embodiments, each image of the plurality of images may be labeled to depict the same person's body. These labels may correspond to "benchmark truth" data. The neural network may be trained to receive one of the plurality of images as an input and to output a first body print of the body (e.g., torso portion) shown in the image. As described herein, a body print may correspond to a multi-dimensional vector, whereby each dimension of the vector corresponds to a feature of a person's body in an image (e.g., a distance between two known points on the body, a particular color or texture represented by pixels of the image, etc.). The neural network may also receive another image of the plurality of images as input and output a second body print of the body (e.g., of the same person) shown in the other image. In some cases, module 544 may associate the first body print with the second body print as corresponding to the same person. For example, as described above, each of the images may be labeled as the same person. Additionally, in some cases, the images may be annotated to describe the type of body part depicted (e.g., side portion, direct view, etc.). In some embodiments, the training algorithm may calculate the similarity (e.g., cosine similarity or euclidean distance) between the vectors of each body print. The training algorithm may then adjust the dimensions of one or more of the body imprints based at least in part on the known similarity between the output and the image (e.g., based on the annotated reference truth data). For example, as described above, the training algorithm may utilize a back-propagation algorithm to minimize a cost function associated with the distance between the body imprints (e.g., the distance between the body imprints vectors). In some embodiments, the back propagation algorithm may be used to adjust (e.g., update) the weights of the nodes of the neural network. In this way, the neural network may be trained to generate similar body imprints from images of the same body, whereby the images may have varying levels of quality (e.g., received from different cameras and/or under different lighting conditions) and/or show different parts of the body. The body print may later be used by the trained model for active comparison during body recognition (e.g., at block 210 of fig. 2). It should be appreciated that the ML model may be trained to generate body imprints (and/or facial imprints, etc.) based on training samples associated with any suitable number of persons (e.g., hundreds, thousands, etc.), and to generate body imprints (and/or facial imprints) for each person that are suitable for subsequent comparison between imprints. It should be appreciated that in some embodiments, the operations of model training module 542 may also be performed by remote server 522.
The scoring module 544 may include code that causes the processor 548 to determine a score corresponding to a level of similarity between the first body characteristic information (e.g., a body print associated with the body of the first person) and the second body characteristic information (e.g., a body print associated with the body of the second person). In some implementations, the scoring module 544 can utilize a trained ML model (e.g., via the model training module 542) to generate and compare body imprints to determine whether the identity of the first person matches the identity of the second person. In some embodiments, the scoring module 544 may first generate a score by comparing facial stamps between the first person and the second person, as described herein. In the case of a score match threshold metric, the scoring module 544 may thus determine a successful match based on the facial stamp. In the event that the scores do not match (e.g., are less than) the threshold metric, the scoring module 544 may generate and compare body imprints of the first person and the second person (e.g., as a fallback mechanism). In another example, both facial imprinting and body imprinting recognition may be performed in parallel. In at least this manner, the techniques described herein enable identification to be performed with a higher level of recall and/or accuracy in a wider range of use cases.
Notification management module 546 may include code that causes processor 548 to store and manage settings for providing notifications, as described herein. The notification management module 546 may also be responsible for generating notifications provided by the communication module 534. It should be appreciated that the notification may be presented in any suitable form (e.g., text, audio, video, and/or suitable combinations). In some embodiments, notification management module 546 may be configured in certain settings to perform no operation (e.g., no operation). For example, the resident device 506 may be configured to: if the detected person is not a known contact, only AV-based notifications are provided to the user device 502. Thus, if resident device 506 detects a contact, notification management module 546 may determine not to perform an operation (e.g., keep silent, record observations only internally, etc.). In some implementations, the notification management module 546 can also determine whether to provide a notification based on whether the face is recognizable. In some embodiments, the notification management module 547 may output a notification that a person (e.g., an unknown person) was detected even though the identity of the person was not detected.
Fig. 6 and 7 are simplified flow diagrams illustrating a process for providing notifications based on determining the presence of a particular person at a location, according to some embodiments. The process 600 of fig. 6 may correspond to a first stage of the process (e.g., the process 200 of fig. 2), while the process 700 of fig. 7 may correspond to a second stage of the process (e.g., the process 200 (e.g., as described with reference to fig. 3)). While the operations of processes 600 and/or 700 are described as being performed by a resident device of a home environment, it should be understood that any suitable device (e.g., user device, server device) may be used to perform one or more operations of these processes. Process 600 and process 700 (described below) are each illustrated as a logic flow diagram, each of which represents a series of operations that can be implemented in hardware, computer instructions, or a combination thereof. In the context of computer instructions, operations represent computer-executable instructions stored on one or more computer-readable storage media that, when executed by one or more processors, perform the recited operations. Generally, computer-executable instructions include routines, programs, objects, components, data structures, etc. that perform particular functions or implement particular data types. The order in which the operations are described is not intended to be construed as a limitation, and any number of the operations may be combined in any order and/or in parallel to implement the process.
Additionally, some, any, or all of these processes may be performed under control of one or more computer systems configured with executable instructions, and may be implemented as code (e.g., executable instructions, one or more computer programs, or one or more application programs) that is executed jointly on one or more processors, by hardware, or a combination thereof. As described above, the code may be stored on a computer readable storage medium, for example, in the form of a computer program comprising a plurality of instructions executable by one or more processors. The computer readable storage medium is non-transitory.
At block 602, during a first phase of the process, a first device (e.g., a resident device) may receive (e.g., from a first camera) a first plurality of video frames during a first period of time, whereby at least one frame of the first plurality of video frames includes a face of a first person. In some embodiments, one or more operations of block 602 may be similar to one or more operations of block 202 of fig. 2. In some embodiments, the first device may be one of a plurality of devices communicatively connected to each other (e.g., of a home environment). In some embodiments, this may facilitate synchronous operation (e.g., local operation within a home environment), as described herein.
At block 604, the first device may identify the identity of the first person based on recognizing the face in at least one frame of the first plurality of frames. In some embodiments, one or more operations of block 602 may be similar to one or more operations of block 204 of fig. 2.
At block 606, the first device may identify one or more physical features of the first person from at least one frame of the first plurality of video frames that includes a face. In some embodiments, the one or more features are non-facial features associated with, for example, a torso and/or a rear portion of the brain of the first person. In some embodiments, the one or more features are associated with at least one of gait, one or more arms, one or more legs, or body shape. In some embodiments, the one or more physical characteristics of the first person are associated with at least one of a texture or a color of at least one of a body of the first person or an article of clothing worn by the first person. In some embodiments, one or more operations of block 606 may be similar to one or more operations of the first stage of fig. 2.
At block 608, the first device may store body feature information corresponding to the identified one or more body features, whereby the body feature information may be stored in association with the identity of the first person based at least in part on the identified face shown at least one frame of the first plurality of video frames. In some embodiments, one or more operations of block 608 may be similar to one or more operations of block 206. In some embodiments, the physical characteristic information corresponds to a physical imprint of the first person. The body print may comprise a multi-dimensional vector, whereby the dimensions of the vector may be associated with one or more physical features of the first person. In some embodiments, the body print may be one body print in a cluster of body prints (e.g., reference body print) stored by the first device. The body imprints may be selected for inclusion in the body imprints cluster based on information gains associated with the body imprints. In some embodiments, the first device may synchronize one or more body imprints with one or more other devices of the home environment, e.g., to ensure that the devices include a reference set of similar body imprints (and/or facial imprints). In some embodiments, the first device may update the reference body print clusters of the person based on any suitable criteria. For example, the first device may then receive a third plurality of video frames during a subsequent time period. The first device may determine that at least one of the one or more identified physical features of the first person may have changed (e.g., wearing a different color shirt) based at least in part on the analysis of the third plurality of video frames. The first device may update the body print clusters accordingly with updated body print determined from the third plurality of video frames. In another example, the first device may update the reference body print according to a particular cadence (e.g., daily, weekly, start of a new time period, etc.). In some embodiments, the first device may store a plurality of one body print clusters for a particular person. For example, assume that during a period of time, the device stores physical characteristic information (e.g., a cluster of physical imprints) associated with a particular person wearing a particular garment (e.g., a green pattern shirt). Further, assume that during another period of time, the device stores other physical characteristics (e.g., another cluster of physical imprints) associated with a particular person wearing a different garment (e.g., a red-patterned shirt). In this example, the device may store two body print clusters for the same person. Thus, during a subsequent (e.g., current) time period (e.g., as described below with reference to the second stage), the device may compare the one or more body imprints generated during the current time period to one or more clusters of a plurality of previously stored body imprints clusters (e.g., reference clusters), respectively. In some implementations, block 608 may end the first phase (e.g., indicated by triangle mark "B" in fig. 6), whereby the second phase of the process may continue during the second period of time, as shown by process 700 of fig. 7.
Turning in more detail to the second phase of the process, at block 610, the device may receive a second plurality of video frames during a second period of time. The second plurality of video frames may include a second person, wherein the face of the second person may be determined to be unrecognized by the first device. In some embodiments, one or more operations of block 610 may be similar to one or more operations of block 208 of fig. 3. In some embodiments, the second plurality of video frames may be received by the same camera (e.g., first camera) that received the first plurality of video frames. In some implementations, the second plurality of video frames can be received by a different camera (e.g., a second camera).
At block 612, the first device compares the additional physical characteristic information of the second person identified in the second plurality of video frames with stored physical characteristic information associated with the identity of the first person (e.g., one or more previously stored clusters of physical imprints). In some embodiments, one or more operations of block 612 may be similar to one or more operations of block 210 of fig. 3. In some embodiments, the additional physical characteristic information corresponds to one or more physical characteristics of the second person that are of the same type as the one or more physical characteristics of the first person. In some embodiments, the comparison is performed using a machine learning model that is trained to associate a first physical imprint of a first person with a second physical imprint of the first person.
At block 614, the first device may provide a notification indicating whether the identity of the second person corresponds to the identity of the first person based on the comparison. In some embodiments, one or more operations of block 614 may be similar to one or more operations of block 212 of fig. 3. In some implementations, the notification may be provided based on a confidence score determined from the comparison of block 612. For example, the first device may determine that the confidence score matches a threshold metric (e.g., 90%) and then provide a notification accordingly.
Fig. 8 is a simplified flowchart illustrating a process for determining whether to add a body print image to a cluster of body print images corresponding to a recognized person, according to some embodiments. While the operations of process 800 are described as being performed by a resident device of the home environment, it should be understood that any suitable device (e.g., user device, server device) may be used to perform one or more operations of these processes. Process 800 (described below) is illustrated as a logic flow diagram, each operation of which represents a series of operations that can be implemented in hardware, computer instructions, or a combination thereof. In the context of computer instructions, operations represent computer-executable instructions stored on one or more computer-readable storage media that, when executed by one or more processors, perform the recited operations. Generally, computer-executable instructions include routines, programs, objects, components, data structures, etc. that perform particular functions or implement particular data types. The order in which the operations are described is not intended to be construed as a limitation, and any number of the operations may be combined in any order and/or in parallel to implement the process.
Additionally, some, any, or all of these processes may be performed under control of one or more computer systems configured with executable instructions, and may be implemented as code (e.g., executable instructions, one or more computer programs, or one or more application programs) that is executed jointly on one or more processors, by hardware, or a combination thereof. As described above, the code may be stored on a computer readable storage medium, for example, in the form of a computer program comprising a plurality of instructions executable by one or more processors. The computer readable storage medium is non-transitory.
At block 802, a computing device (e.g., a residence device) may maintain (or generate and then maintain) a plurality of images associated with a person. The plurality of images may be a collection of physical features including, but not limited to, facial features and/or physical features of a person (e.g., a torso). As described above, the plurality of image (e.g., cluster and/or gallery) images may correspond to a particular person (e.g., a contact of a user of a computing device).
At block 804, the computing device may receive a new image (e.g., from a camera or other video recorder). The new image may be collected from the same or a different camera from that collecting the other images of the person. The new image may include both face and torso information.
At block 806, the computing device may determine whether the new image includes an identifiable face (e.g., good quality) and/or a face of a person. That is, the process 800 will determine whether the face is clear enough to determine that it is a face, and also recognize (e.g., identify) the person as being in the user's contact list. In some cases, if a face is not identifiable, then the face will also not be identifiable. Since process 800 may not fall back to using torso imprints where a face may be identified and/or recognized, and there will be cases where a face is identifiable but unrecognizable, process 800 will not fall back to using torso imprints (block 816) and will also be uncertain whether to add a new torso imprints to the clusters (blocks 808, 810). In these cases, process 800 may end without successfully identifying any person. In this case, process 800 may provide notification of the detection of an unidentified person.
Based on a determination that the new image includes a face of a person (e.g., a recognizable person in a user contact), the computing device may generate a score associated with the new image (and/or torso in the image) at block 808. The score may be generated based on one or more of the rules described above (e.g., some combination). For example, the score may be generated based on image characteristics such as saturation, contrast, brightness, and/or sharpness, whether the image is a false torso, and so on. At block 808, the computing device may determine whether the score is above a threshold (e.g., a quality threshold). If the score is above the threshold, then a new image may be added to the cluster at block 812. However, if the score is not above the threshold, then the new image may be discarded at block 814.
Alternatively, based on a determination that the new image does not include a face of the person (e.g., the face is unidentifiable (low quality) or unrecognizable), the computing device may identify the person based on a comparison of the new image and a cluster of body imprints associated with the person at block 816. If identified, the computing device may notify the user of the presence of a known/recognized person or the presence of an unrecognized person. In some examples, process 800 may proceed to block 816 only if the image does not have a face or the quality of a face in the image is so low that it is not identifiable (e.g., it will not be possible to recognize the user).
Exemplary techniques for providing notifications based on determining the presence of a particular person at a location and determining whether to add body imprints to a cluster of body imprints of recognized persons are described above. Some or all of these techniques may be implemented, at least in part, by an architecture such as those illustrated at least in fig. 1-7 above, but need not be implemented by such an architecture. While many embodiments are described above with reference to a resident device and a user device, it should be understood that other types of computing devices may be suitable for performing the techniques disclosed herein. Further, various non-limiting examples are described in the foregoing description. For purposes of explanation, numerous specific configurations and details are set forth in order to provide a thorough understanding of the examples. It will be apparent, however, to one skilled in the art that some examples may be practiced without these specific details. Furthermore, well-known features are sometimes omitted or simplified in order not to obscure the examples described herein.
The various embodiments may also be implemented in a variety of operating environments that may include, in some cases, one or more user computers, computing devices, or processing devices that may be used to operate any of a number of applications. The user device or client device may include any of a number of general purpose personal computers, such as desktop or laptop computers running a standard operating system, as well as cellular, wireless, and handheld devices running mobile software and capable of supporting multiple networking protocols and instant messaging protocols. This system may also include a plurality of workstations running any of a variety of commercially available operating systems and other known applications for purposes such as development and database management. These devices may also include other electronic devices such as virtual terminals, thin clients, gaming systems, and other devices capable of communicating via a network.
Most embodiments utilize at least one network familiar to those skilled in the art to support communications using any of a variety of commercially available protocols such as TCP/IP, OSI, FTP, UPnP, NFS, CIFS and AppleTalk. The network may be, for example, a local area network, a wide area network, a virtual private network, the internet, an intranet, an extranet, a public switched telephone network, an infrared network, a wireless network, and any combination thereof.
In embodiments utilizing web servers, the web server may run any of a variety of servers or middle tier applications, including HTTP servers, FTP servers, CGI servers, data servers, java servers, and business application servers. The one or more servers may also be capable of executing programs or scripts in response to requests from the user device, such as by executing one or more applications,the one or more application programs may be implemented in any programming language, such asC. C# or c++, or any scripting language such as Perl, python, or TCL, or combinations thereof. The one or more servers may also include database servers including, but not limited to, may be selected from +.>And->Those commercially available.
The environment may include various data stores and other memory and storage media, as described above. These may reside at various locations, such as on storage media local to one or more computers or on storage media remote from any or all of the computers on the network (and/or resident in one or more computers). In a particular set of embodiments, the information may reside in a Storage Area Network (SAN) familiar to those skilled in the art. Similarly, any necessary files for performing the functions attributed to a computer, server, or other network device may be stored locally and/or remotely as desired. When the system includes computerized devices, each such device may include hardware elements that may be electrically coupled via a bus, including, for example, at least one Central Processing Unit (CPU), at least one input device (e.g., a mouse, keyboard, controller, touch screen, or keypad), and at least one output device (e.g., a display device, printer, or speaker). Such systems may also include one or more storage devices, such as disk drives, optical storage devices, and solid-state storage devices such as RAM or ROM, as well as removable media devices, memory cards, flash memory cards, and the like.
Such devices may also include a computer-readable storage medium reader, a communication device (e.g., modem, network card (wireless or wired), infrared communication device, etc.), and working memory as described above. The computer-readable storage medium reader may be connected to or configured to receive non-transitory computer-readable storage media representing remote, local, fixed, and/or removable storage devices, as well as storage media for temporarily and/or more permanently containing, storing, transmitting, and retrieving computer-readable information. The system and various devices will typically also include a plurality of software applications, modules, services, or other elements, including an operating system and applications such as a client application or browser, located within at least one working memory device. It should be understood that alternative embodiments may have many variations according to the above description. For example, custom hardware may also be used, and/or certain elements may be implemented in hardware, software (including portable software, such as applets), or both. In addition, connections to other computing devices, such as network input/output devices, may be used.
Non-transitory storage media and computer-readable storage media for containing code or portions of code may include any suitable medium known or used in the art, such as, but not limited to, volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules or other data, including RAM, ROM, electrically erasable programmable read-only memory (EEPROM), flash memory or other memory technology, CD-ROM, DVD or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the system device. Based at least in part on the disclosure and teachings provided herein, one of ordinary skill in the art will recognize other ways and/or methods of implementing various embodiments. However, computer-readable storage media do not include transitory media such as carrier waves and the like.
The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the disclosure as set forth in the claims.
Other variations are within the spirit of the disclosure. Thus, while the disclosed technology is susceptible to various modifications and alternative constructions, certain illustrated embodiments thereof are shown in the drawings and have been described above in detail. It should be understood, however, that there is no intention to limit the disclosure to the specific forms disclosed, but on the contrary, the intention is to cover all modifications, alternative constructions, and equivalents falling within the spirit and scope of the disclosure as defined by the appended claims.
The use of the terms "a" and "an" and "the" and similar referents in the context of describing the disclosed embodiments (especially in the context of the following claims) are to be construed to cover both the singular and the plural, unless otherwise indicated herein or clearly contradicted by context. Unless otherwise indicated, the terms "comprising," "having," "including," and "containing" are to be construed as open-ended terms (i.e., meaning "including, but not limited to"). The term "connected" is to be interpreted as including partially or wholly contained within, attached to, or joined together even if there is intervening matter. The phrase "based, at least in part, on" should be understood to be open ended, and not limited in any way, and is intended to be interpreted, or otherwise interpreted, as "based, at least in part, on" where appropriate. Recitation of ranges of values herein are merely intended to serve as a shorthand method of referring individually to each separate value falling within the range, unless otherwise indicated herein, and each separate value is incorporated into the specification as if it were individually recited herein. All methods described herein can be performed in any suitable order unless otherwise indicated herein or otherwise clearly contradicted by context. The use of any and all examples, or exemplary language (e.g., "such as") provided herein, is intended merely to better illuminate embodiments of the disclosure and does not pose a limitation on the scope of the disclosure unless otherwise claimed. No language in the specification should be construed as indicating any non-claimed element as essential to the practice of the disclosure.
Unless specifically stated otherwise, a disjunctive language such as at least one of the phrases "X, Y or Z" is understood in the context of generally being used to present items, terms, etc., which may be X, Y or Z, or any combination thereof (e.g., X, Y and/or Z). Thus, such disjunctive language is generally not intended and should not imply that certain embodiments require at least one of X, at least one of Y, or at least one of Z to each be present. In addition, unless specifically stated otherwise, a conjunctive language such as the phrase "at least one of X, Y, and Z" is also understood to mean X, Y, Z or any combination thereof, including "X, Y and/or Z".
Preferred embodiments of this disclosure are described herein, including the best mode known to the inventors for carrying out the disclosure. Variations of those preferred embodiments may become apparent to those of ordinary skill in the art upon reading the foregoing description. The inventors expect skilled artisans to employ such variations as appropriate, and the inventors intend for the disclosure to be practiced otherwise than as specifically described herein. Accordingly, this disclosure includes all modifications and equivalents of the subject matter recited in the claims appended hereto as permitted by applicable law. Moreover, unless indicated otherwise or clearly contradicted by context, this disclosure encompasses any combination of all possible variations of the above elements.
All references, including publications, patent applications, and patents, cited herein are hereby incorporated by reference to the same extent as if each reference were individually and specifically indicated to be incorporated by reference and were set forth in its entirety herein.
As described above, one aspect of the present technology is to collect and use data (images of people) to perform face recognition. The present disclosure contemplates that in some examples, such collected data may include Personally Identifiable Information (PII) data that uniquely identifies or may be used to contact or locate a particular person. Such personal information data may include facial and/or non-facial features of a person's body, demographic data, location-based data (GPS coordinates), telephone numbers, email addresses, twitter IDs, home addresses, or any other identification or personal information.
The present disclosure recognizes that the use of such personal information data in the present technology may be used to benefit users. For example, personal information data may be used to identify a person that is a contact (or an unknown contact) of a user device.
The present disclosure contemplates that entities responsible for collecting, analyzing, disclosing, transmitting, storing, or otherwise using such personal information data will adhere to established privacy policies and/or privacy practices. In particular, such entities should exercise and adhere to privacy policies and practices that are recognized as meeting or exceeding industry or government requirements for maintaining the privacy and security of personal information data. Such policies should be readily accessible to the user and should be updated as the collection and/or use of the data changes. Personal information from users should be collected for legal and reasonable use by entities and not shared or sold outside of these legal uses. In addition, such collection/sharing should be performed after informed consent is received from the user. In addition, such entities should consider taking any necessary steps to defend and secure access to such personal information data and to ensure that others who have access to personal information data adhere to their privacy policies and procedures. In addition, such entities may subject themselves to third party evaluations to prove compliance with widely accepted privacy policies and practices. In addition, policies and practices should be adjusted to collect and/or access specific types of personal information data and to suit applicable laws and standards including specific considerations of jurisdiction. For example, in the united states, the collection or acquisition of certain health data may be governed by federal and/or state law, such as the health insurance flow and liability act (HIPAA); while health data in other countries may be subject to other regulations and policies and should be processed accordingly. Thus, different privacy practices should be maintained for different personal data types in each country.
In spite of the foregoing, the present disclosure also contemplates embodiments in which a user selectively prevents use or access to personal information data. That is, the present disclosure contemplates that hardware elements and/or software elements may be provided to prevent or block access to such personal information data. For example, with respect to services related to performing facial recognition, the present technology may be configured to allow a user to choose to "opt-in" or "opt-out" to participate in the collection of personal information data at any time during or after registration with a service. In addition to providing the "opt-in" and "opt-out" options, the present disclosure also contemplates providing notifications related to accessing or using personal information. For example, the user may be notified that his personal information data will be accessed when the application is downloaded, and then be reminded again just before the personal information data is accessed by the application.
Further, it is an object of the present disclosure that personal information data should be managed and processed to minimize the risk of inadvertent or unauthorized access or use. Once the data is no longer needed, risk can be minimized by limiting the data collection and deleting the data. In addition, and when applicable, included in certain health-related applications, the data de-identification may be used to protect the privacy of the user. De-identification may be facilitated by removing specific identifiers (e.g., date of birth, etc.), controlling the amount or specificity of stored data (e.g., collecting location data at a city level instead of at an address level), controlling how data is stored (e.g., aggregating data among users), and/or other methods, as appropriate.
Thus, while the present disclosure broadly covers the use of personal information data to implement one or more of the various disclosed embodiments, the present disclosure also contemplates that the various embodiments may be implemented without accessing such personal information data. That is, various embodiments of the present technology do not fail to function properly due to the lack of all or a portion of such personal information data.

Claims (33)

1. A method, comprising:
receiving, by at least one device of a plurality of devices, a first plurality of video frames from a camera during a first period of time, the at least one frame of the first plurality of video frames comprising a face of a first person;
identifying, by the at least one of the plurality of devices, an identity of the first person based at least in part on recognizing the face in the at least one of the first plurality of video frames;
identifying, by the at least one of the plurality of devices, one or more physical features of the first person from at least one of the first plurality of video frames that includes the face;
storing, by the at least one of the plurality of devices, body feature information corresponding to the identified one or more body features, the body feature information stored in association with the identity of the first person based at least in part on the recognized face shown in the at least one of the first plurality of video frames;
Receiving, by the at least one of the plurality of devices, a second plurality of video frames during a second period of time, the second plurality of video frames including a second person, wherein the face of the second person is determined to be unrecognized by the at least one device;
comparing, by the at least one of the plurality of devices, additional body characteristic information of the second person identified in the second plurality of video frames with stored body characteristic information associated with the identity of the first person; and
providing, by the at least one of the plurality of devices, a notification indicating whether the identity of the second person corresponds to the identity of the first person based at least in part on the comparison.
2. The method of claim 1, wherein the one or more physical features of the first person are associated with a torso of the first person.
3. The method of any one of claims 1-2, wherein the one or more physical features of the first person are associated with at least one of gait, one or more arms, one or more legs, or body shape.
4. A method according to any one of claims 1 to 3, wherein the one or more physical features of the first person are associated with at least one of a texture or a color of at least one of a body of the first person or an article of clothing worn by the first person.
5. The method of any of claims 1-4, wherein the additional physical characteristic information corresponds to one or more physical characteristics of the second person, the one or more physical characteristics being of the same type as the one or more physical characteristics of the first person.
6. The method of any of claims 1-5, wherein the physical characteristic information corresponds to a physical imprint of the first person, the physical imprint comprising a multi-dimensional vector, dimensions of the vector being associated with one or more of the physical characteristics of the first person.
7. The method of any of claims 1-6, wherein the comparing is performed using a machine learning model trained to associate a first body print of the first person with a second body print of the first person.
8. The method of any of claims 1-7, wherein providing the notification further comprises:
determining, by the at least one of the plurality of devices, a confidence score based at least in part on the comparison;
determining, by the at least one device of the plurality of devices, that the confidence score matches a threshold metric; and
The notification is provided by the at least one of the plurality of devices, the notification indicating that the identity of the second person matches the identity of the first person.
9. The method of any of claims 1-8, wherein a plurality of persons including the second person are shown within the second plurality of video frames.
10. The method of any one of claims 1 to 9, further comprising:
storing, by the at least one of the plurality of devices, information corresponding to the face of the first person in association with the identified identity.
11. The method of any one of claims 1 to 10, further comprising:
storing, by the at least one of the plurality of devices, a cluster of body imprints of the first person based at least in part on the first plurality of video frames, body imprints in the cluster being associated with a particular frame of the first plurality of video frames and being selected for inclusion in the cluster of body imprints based at least in part on an information gain associated with the body imprints, the information gain being used to perform the comparison between the additional body characteristic information of the second person and the body characteristic information of the first person.
12. The method of any of claims 1-11, wherein the plurality of devices includes a first device and a second device associated with a home environment setting, the method further comprising:
generating, by the first device, a body print of the first person from a frame of the first plurality of video frames;
determining, by the first device, that the body print is to be added to a cluster of body prints associated with the first person based at least in part on an information gain associated with the body print; and
transmitting, by the first device, the body print to the second device, the body print being stored by the second device in a second body print cluster maintained by the second device, wherein each body print cluster is synchronized between the first device and the second device.
13. The method of any of claims 1-12, wherein the camera is a first camera in a home environment setting, the home environment setting comprising the first camera and a second camera, the at least one device receiving the second plurality of video frames from the second camera.
14. The method of any of claims 1-13, wherein the at least one device receives the second plurality of video frames from a second camera, and wherein the camera is positioned in association with an entrance to a home environment and the second camera is positioned in association with an interior hallway of the home environment.
15. The method of any one of claims 1 to 14, further comprising:
a cluster of body imprints associated with the first person is determined to be updated by the at least one of the plurality of devices, the body imprints in the cluster being associated with stored body characteristic information associated with the first person.
16. The method of claim 15, wherein the body print cluster is updated based at least in part on determining a start of a new time period.
17. The method of claim 15, further comprising:
receiving, by the at least one of the plurality of devices, a third plurality of video frames during a third time period;
determining, by the at least one of the plurality of devices, that at least one of the one or more identified physical features of the first person has changed based at least in part on the analysis of the third plurality of video frames; and
determining, by the at least one of the plurality of devices, to update the body print cluster associated with the first person based at least in part on determining that at least one of the one or more identified body features of the first person has changed.
18. The method of any of claims 1-17, wherein the physical characteristic information corresponds to a physical impression of the first person, wherein a physical impression cluster of the first person is generated based at least in part on the first plurality of video frames, and wherein the physical impression clusters are respectively associated with an identity of the first person based at least in part on the recognition of the face in the at least one of the first plurality of video frames.
19. The method of any one of claims 1 to 18, wherein the at least one device comprises the camera.
20. The method of any of claims 1-18, wherein the camera is a separate device communicatively connected to the at least one of the plurality of devices, and wherein the camera is configured to transmit the first plurality of video frames to the at least one device.
21. An apparatus, comprising:
a memory including computer-executable instructions; and one or more processors in communication with the memory and configured to access the memory and execute the computer-executable instructions to perform the method of any one of claims 1 to 20.
22. One or more computer-readable storage media comprising computer-executable instructions that, when executed by one or more processors, cause the one or more processors to perform the method of any of claims 1-20.
23. A method, comprising:
maintaining, by the computing device, a plurality of images associated with the person;
receiving, by the computing device, a new image;
determining, by the computing device, whether the new image includes a face of the person; and
including the face of the person from the new image:
generating, by the computing device, a score associated with the new image;
determining, by the computing device, whether the score is above a threshold;
in accordance with a determination that the score is above the threshold, adding the new image to the plurality of images; and
in accordance with a determination that the score is not above the threshold, the new image is discarded.
24. The method of claim 23, wherein the plurality of images includes a first body feature associated with the person, and the method further comprises:
based on the new image not including the face of the person and based at least in part on having a quality score below a threshold, not being identifiable:
Comparing, by the computing device, a second physical feature identified in the image with the first physical feature associated with the person;
determining, by the computing device, whether the second physical feature identified in the image corresponds to the first physical feature associated with the person; and
the person is identified from the second physical feature identified in the image corresponding to the first physical feature associated with the person.
25. The method of any of claims 23-24, further comprising providing, by the computing device, a notification that the person was identified.
26. The method of any of claims 23-25, wherein the computing device comprises a resident device in a home environment, wherein the resident device is configured to be relatively stationary within the home environment.
27. The method of any one of claims 23 to 26, wherein the score comprises a mass score.
28. The method of claim 27, wherein the quality score identifies a relative quality of the image relative to other images.
29. The method of any one of claims 27 or 28, wherein the quality score is determined based at least in part on at least one of a saturation metric, a contrast metric, a brightness metric, or a sharpness metric.
30. The method of claim 23, wherein the plurality of images comprises a set of body imprints associated with the person.
31. The method of claim 30, wherein a body print of the set of body prints is generated based at least in part on a torso of a user.
32. An apparatus, comprising:
a memory including computer-executable instructions; and one or more processors in communication with the memory and configured to access the memory and execute the computer-executable instructions to perform the method of any of claims 23 to 31.
33. One or more computer-readable storage media comprising computer-executable instructions that, when executed by one or more processors, cause the one or more processors to perform the method of any of claims 23-31.
CN202280034667.6A 2021-05-14 2022-05-13 Identification using facial-related physical features Pending CN117377988A (en)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US63/188,949 2021-05-14
US202263341379P 2022-05-12 2022-05-12
US63/341,379 2022-05-12
PCT/US2022/029314 WO2022241294A2 (en) 2021-05-14 2022-05-13 Identity recognition utilizing face-associated body characteristics

Publications (1)

Publication Number Publication Date
CN117377988A true CN117377988A (en) 2024-01-09

Family

ID=89402689

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202280034667.6A Pending CN117377988A (en) 2021-05-14 2022-05-13 Identification using facial-related physical features

Country Status (1)

Country Link
CN (1) CN117377988A (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117745036A (en) * 2024-02-18 2024-03-22 四川金投科技股份有限公司 Livestock information management method and system based on feature recognition and near field communication

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117745036A (en) * 2024-02-18 2024-03-22 四川金投科技股份有限公司 Livestock information management method and system based on feature recognition and near field communication
CN117745036B (en) * 2024-02-18 2024-04-30 四川金投科技股份有限公司 Livestock information management method and system based on feature recognition and near field communication

Similar Documents

Publication Publication Date Title
US11735018B2 (en) Security system with face recognition
US10257558B2 (en) Systems and methods for constructing and indexing a database of joint profiles for persons viewed by multiple wearable apparatuses
US20220245396A1 (en) Systems and Methods of Person Recognition in Video Streams
US20190220933A1 (en) Presence Granularity with Augmented Reality
US20230316444A1 (en) High definition camera and image recognition system for criminal identification
US10032233B2 (en) Social context in augmented reality
US11710348B2 (en) Identifying objects within images from different sources
CN109686049B (en) Method, device, medium and electronic equipment for reminding falling order of children in public place
US20120207349A1 (en) Targeted content acquisition using image analysis
US20230013117A1 (en) Identity recognition utilizing face-associated body characteristics
US20140108530A1 (en) Person of Interest in Augmented Reality
EP3975132A1 (en) Identifying partially covered objects utilizing simulated coverings
WO2017049612A1 (en) Smart tracking video recorder
US10769909B1 (en) Using sensor data to detect events
US11659144B1 (en) Security video data processing systems and methods
US20140108529A1 (en) Person Filtering in Augmented Reality
CN117377988A (en) Identification using facial-related physical features
US20220366727A1 (en) Identity recognition utilizing face-associated body characteristics
WO2022241294A2 (en) Identity recognition utilizing face-associated body characteristics
WO2024063969A1 (en) Identity recognition utilizing face-associated body characteristics
RU2712417C1 (en) Method and system for recognizing faces and constructing a route using augmented reality tool
Constantino Best Effort Identification

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination