CN117292418A - Face recognition method and device - Google Patents
Face recognition method and device Download PDFInfo
- Publication number
- CN117292418A CN117292418A CN202310936377.7A CN202310936377A CN117292418A CN 117292418 A CN117292418 A CN 117292418A CN 202310936377 A CN202310936377 A CN 202310936377A CN 117292418 A CN117292418 A CN 117292418A
- Authority
- CN
- China
- Prior art keywords
- camera
- module
- exposure time
- face recognition
- tof
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 85
- 238000004422 calculation algorithm Methods 0.000 claims description 143
- 230000015654 memory Effects 0.000 claims description 72
- 230000006870 function Effects 0.000 claims description 68
- 238000001514 detection method Methods 0.000 claims description 48
- 230000008569 process Effects 0.000 claims description 29
- 238000003860 storage Methods 0.000 claims description 24
- 238000004891 communication Methods 0.000 claims description 22
- 238000003384 imaging method Methods 0.000 claims description 16
- 238000004590 computer program Methods 0.000 claims description 7
- 238000007726 management method Methods 0.000 description 72
- 239000010410 layer Substances 0.000 description 44
- 230000003287 optical effect Effects 0.000 description 25
- 230000005540 biological transmission Effects 0.000 description 19
- 238000010586 diagram Methods 0.000 description 14
- 238000012545 processing Methods 0.000 description 14
- 230000004044 response Effects 0.000 description 13
- 238000013461 design Methods 0.000 description 11
- 230000003993 interaction Effects 0.000 description 11
- 238000010295 mobile communication Methods 0.000 description 9
- 230000002159 abnormal effect Effects 0.000 description 7
- 230000005236 sound signal Effects 0.000 description 7
- 238000012546 transfer Methods 0.000 description 6
- 238000004364 calculation method Methods 0.000 description 5
- 238000013528 artificial neural network Methods 0.000 description 4
- 238000004519 manufacturing process Methods 0.000 description 4
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 238000011161 development Methods 0.000 description 3
- 230000000694 effects Effects 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 238000003825 pressing Methods 0.000 description 3
- 238000012795 verification Methods 0.000 description 3
- 229920001621 AMOLED Polymers 0.000 description 2
- 230000003416 augmentation Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 230000000295 complement effect Effects 0.000 description 2
- 238000002955 isolation Methods 0.000 description 2
- 239000004973 liquid crystal related substance Substances 0.000 description 2
- 230000007774 longterm Effects 0.000 description 2
- 230000007246 mechanism Effects 0.000 description 2
- 229910044991 metal oxide Inorganic materials 0.000 description 2
- 150000004706 metal oxides Chemical class 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 238000007781 pre-processing Methods 0.000 description 2
- 238000002360 preparation method Methods 0.000 description 2
- 239000002096 quantum dot Substances 0.000 description 2
- 238000009877 rendering Methods 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 230000001133 acceleration Effects 0.000 description 1
- 230000002411 adverse Effects 0.000 description 1
- 238000013475 authorization Methods 0.000 description 1
- 238000013529 biological neural network Methods 0.000 description 1
- 210000000988 bone and bone Anatomy 0.000 description 1
- 210000004556 brain Anatomy 0.000 description 1
- 239000012792 core layer Substances 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000005538 encapsulation Methods 0.000 description 1
- 238000001914 filtration Methods 0.000 description 1
- 230000004927 fusion Effects 0.000 description 1
- 238000001559 infrared map Methods 0.000 description 1
- 230000001537 neural effect Effects 0.000 description 1
- 210000002569 neuron Anatomy 0.000 description 1
- 230000005855 radiation Effects 0.000 description 1
- 238000000926 separation method Methods 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 238000002366 time-of-flight method Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06V—IMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
- G06V40/00—Recognition of biometric, human-related or animal-related patterns in image or video data
- G06V40/10—Human or animal bodies, e.g. vehicle occupants or pedestrians; Body parts, e.g. hands
- G06V40/16—Human faces, e.g. facial parts, sketches or expressions
- G06V40/161—Detection; Localisation; Normalisation
- G06V40/166—Detection; Localisation; Normalisation using acquisition arrangements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06V—IMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
- G06V10/00—Arrangements for image or video recognition or understanding
- G06V10/70—Arrangements for image or video recognition or understanding using pattern recognition or machine learning
- G06V10/74—Image or video pattern matching; Proximity measures in feature spaces
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N23/00—Cameras or camera modules comprising electronic image sensors; Control thereof
- H04N23/60—Control of cameras or camera modules
- H04N23/61—Control of cameras or camera modules based on recognised objects
- H04N23/611—Control of cameras or camera modules based on recognised objects where the recognised objects include parts of the human body
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Multimedia (AREA)
- General Health & Medical Sciences (AREA)
- Computer Vision & Pattern Recognition (AREA)
- Health & Medical Sciences (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Oral & Maxillofacial Surgery (AREA)
- Artificial Intelligence (AREA)
- Computing Systems (AREA)
- Databases & Information Systems (AREA)
- Evolutionary Computation (AREA)
- Medical Informatics (AREA)
- Software Systems (AREA)
- Signal Processing (AREA)
- Studio Devices (AREA)
Abstract
The embodiment of the application provides a face recognition method and device, relates to the field of terminals, and can solve the problem that the time consumption for unlocking the face of electronic equipment is too long due to the fact that the image shot by a TOF camera is overexposed and underexposed, so that the face unlocking efficiency can be improved. The method is applied to electronic equipment, wherein the electronic equipment comprises a time-of-flight TOF camera module, and the method comprises the following steps: receiving a first operation of a user, wherein the first operation is used for triggering face recognition; controlling the TOF camera module to acquire a first image frame based on the first exposure time; determining a second exposure time from the first image frame, the second exposure time being different from the first exposure time; controlling the TOF camera module to acquire a second image frame based on the second exposure time; face recognition is performed based on the second image frame.
Description
This application is a divisional application, the filing number of the original application is 202210307908.1, the filing date of the original application is 2022, 03, 25, and the entire contents of the original application are incorporated herein by reference.
Technical Field
The application relates to the field of terminals, in particular to a face recognition method and device.
Background
A time of flight (TOF) camera may include a Transmitter (TX) for transmitting infrared light or laser pulses and a Receiver (RX) for receiving reflected light and imaging (TOF images). Since TX can autonomously emit optical signals for imaging, TOF images are not affected by most of the light in the environment. Thus, the TOF image can be applied to unlocking service, and the safety of face recognition can be improved.
However, in a scene that is too bright (sunlight scene) or too dark (full black scene), the TOF image may be overexposed or underexposed, which results in that the electronic device cannot perform face unlocking in time.
Disclosure of Invention
The embodiment of the application provides a face recognition method and device, which can solve the problem of excessively long time consumption for unlocking the face of electronic equipment due to the condition that an image shot by a TOF camera is overexposed and underexposed, thereby improving the face unlocking efficiency.
In a first aspect, an embodiment of the present application provides a face recognition method, applied to an electronic device, where the electronic device includes a time-of-flight TOF camera module method including: receiving a first operation of a user, wherein the first operation is used for triggering face recognition; controlling the TOF camera module to acquire a first image frame based on the first exposure time; determining a second exposure time from the first image frame, the second exposure time being different from the first exposure time; controlling the TOF camera module to acquire a second image frame based on the second exposure time; face recognition is performed based on the second image frame.
Based on the method provided by the embodiment of the application, the TOF camera module collects a first image frame based on the first exposure time, and when the second exposure time is determined according to the first image frame and is different from the first exposure time, the TOF camera module is controlled to collect a second image frame based on the second exposure time; face recognition is performed based on the second image frame. It can be understood that when the second exposure time determined according to the first image frame is different from the first exposure time, the first image frame can be considered to be overexposed and underexposed, so that the TOF camera module can be timely controlled to acquire the second image frame based on the second exposure time; face recognition is performed based on the second image frame, so that face recognition can be performed according to the second image frame in time, and the face unlocking efficiency can be improved.
In one possible implementation, the electronic device includes a face recognition control module, a camera service, a camera hardware abstraction layer HAL, a camera driving module, and a face recognition trusted application TA, the face recognition TA including a frame management module, a TOF algorithm module, and a face identification ID algorithm module, the camera HAL including a sensor node, the controlling the TOF camera module to collect a second image frame based on a second exposure time includes: the TOF algorithm module calculates a second exposure time according to the first image frame; the TOF algorithm module sends a second exposure time to the frame management module; the frame management module sends a second exposure time to the face recognition control module; the face recognition control module calls a first function through a hardware abstraction layer interface definition language HIDL interface to write the second exposure time into the camera HAL; the sensor node in the camera HAL calls a second function to read a second exposure time; the sensor node calls a third function to process the second exposure time to obtain an exposure value corresponding to an exposure register of the TOF camera module; the sensor node sends an exposure value corresponding to an exposure register of the TOF camera module to the camera driving module; the camera driving module writes the exposure value into an exposure register of the TOF camera module; the TOF camera module collects a second image frame according to the exposure value in the exposure register; performing face recognition based on the second image frame includes: the frame management module acquires a second image frame; the frame management module determines that the exposure time corresponding to the second image frame is the same as the second exposure time; the frame management module sends a second image frame to the TOF algorithm module; the TOF algorithm module calculates a gray level map and a depth map according to the second image frame; the TOF algorithm module sends a gray level image and a depth image to the face ID algorithm module; the face ID algorithm module performs face comparison based on the gray level map and performs anti-fake detection based on the depth map to obtain a face recognition result.
After the TOF algorithm module calculates the second exposure time, the TOF algorithm module directly sends the second exposure time to the frame management module; the frame management module sends the second exposure time to the face recognition control module. Therefore, the condition that the exposure time of the next frame calculated by the TOF algorithm module is transmitted back to the face recognition control module after passing through the face ID algorithm module to cause exposure time transmission lag can be avoided, and the exposure time transmission efficiency can be improved. And the face recognition control module directly calls the first function through the HIDL interface to write the second exposure time into the camera HAL; the sensor node in the camera HAL invokes a second function to read the second exposure time. In this way, the transmission time of the second exposure time can be saved without the face recognition control module transmitting the second exposure time to the camera HAL through the camera service of the application framework layer. Thus, the TOF camera module can shoot according to the updated exposure time (the exposure time of the next frame) as soon as possible, so that the electronic equipment can unlock the face as soon as possible. In addition, judging whether the exposure time corresponding to the second image frame is the same as the second exposure time, if so, sending the second image frame into the TOF algorithm module and the face ID algorithm module for calculation. In this way, the problem that invalid frames (i.e. image frames with exposure time different from the second exposure time) are repeatedly sent to the TOF algorithm module and the face ID algorithm module to be calculated, and face recognition time is consumed (unlocking efficiency is reduced) can be avoided.
In one possible implementation, the method further includes: if the frame management module determines that the exposure time corresponding to the second image frame is different from the second exposure time, the frame management module discards the second image frame. In this way, the problem that invalid frames (if the exposure time corresponding to the second image frame is different from the second exposure time, the second image frame belongs to the invalid frame) are repeatedly sent to the TOF algorithm module and the face ID algorithm module to be calculated, and face recognition time is consumed (unlocking efficiency is reduced) is avoided.
In one possible implementation, the electronic device includes a face recognition control module, a camera service, a camera hardware abstraction layer HAL, a camera driving module, and a face recognition trusted application TA, the face recognition TA including a frame management module, a TOF algorithm module, and a face identification ID algorithm module, the camera HAL including a sensor node, the controlling the TOF camera module to collect a second image frame based on a second exposure time includes: the TOF algorithm module calculates a second exposure time according to the first image frame; the TOF algorithm module sends a second exposure time to the frame management module; the frame management module sends a second exposure time to the face recognition control module; the face recognition control module sends a second exposure time to the camera service; the camera service sending a second exposure time to the camera HAL; the sensor node in the camera HAL obtains an exposure value corresponding to an exposure register of the TOF camera module according to the second exposure time; the sensor node sends an exposure value corresponding to an exposure register of the TOF camera module to the camera driving module; the camera driving module writes the exposure value into an exposure register of the TOF camera module; the TOF camera module collects a second image frame according to the exposure value in the exposure register. After the TOF algorithm module calculates the second exposure time, the TOF algorithm module directly sends the second exposure time to the frame management module; the frame management module sends the second exposure time to the face recognition control module. Therefore, the condition that the exposure time of the next frame calculated by the TOF algorithm module is transmitted back to the face recognition control module after passing through the face ID algorithm module to cause exposure time transmission lag can be avoided, and the exposure time transmission efficiency can be improved. Thus, the TOF camera module can shoot according to the updated exposure time (the exposure time of the next frame) as soon as possible, so that the electronic equipment can unlock the face as soon as possible.
In one possible implementation manner, the electronic device includes a face recognition control module, a camera hardware abstraction layer HAL, a camera driving module, and a face recognition trusted application TA, the face recognition TA includes a frame management module, a TOF algorithm module, and a face identification ID algorithm module, the camera HAL includes a sensor node, and controlling the TOF camera module to collect a second image frame based on a second exposure time includes: the TOF algorithm module calculates a second exposure time according to the first image frame; the TOF algorithm module sends a second exposure time to the face ID algorithm module; the face ID algorithm module sends a second exposure time to the frame management module; the frame management module sends a second exposure time to the face recognition control module; the face recognition control module calls a first function through a hardware abstraction layer interface definition language HIDL interface to write the second exposure time into the camera HAL; the sensor node in the camera HAL calls a second function to read a second exposure time; the sensor node calls a third function to process the second exposure time to obtain an exposure value corresponding to an exposure register of the TOF camera module; the sensor node sends an exposure value corresponding to an exposure register of the TOF camera module to the camera driving module; the camera driving module writes the exposure value into an exposure register of the TOF camera module; the TOF camera module collects a second image frame according to the exposure value in the exposure register.
The face recognition control module directly calls a first function through an HIDL interface to write the second exposure time into the camera HAL; the sensor node in the camera HAL invokes a second function to read the second exposure time. In this way, the transmission time of the second exposure time can be saved without the face recognition control module transmitting the second exposure time to the camera HAL through the camera service of the application framework layer. Thus, the TOF camera module can shoot according to the updated exposure time (the exposure time of the next frame) as soon as possible, so that the electronic equipment can unlock the face as soon as possible.
In one possible implementation, the electronic device includes a face recognition control module, a camera service, a camera hardware abstraction layer HAL, a camera driving module, and a face recognition trusted application TA, the face recognition TA including a frame management module, a TOF algorithm module, and a face identification ID algorithm module, the camera HAL including a sensor node, the controlling the TOF camera module to collect a second image frame based on a second exposure time includes: the TOF algorithm module calculates a second exposure time according to the first image frame; the TOF algorithm module sends a second exposure time to the frame management module; the frame management module sends a second exposure time to the face recognition control module; the face recognition control module calls a first function through an HIDL interface to write the second exposure time into the camera HAL; the sensor node in the camera HAL calls a second function to read a second exposure time; the sensor node calls a third function to process the second exposure time to obtain an exposure value corresponding to an exposure register of the TOF camera module; the sensor node sends an exposure value corresponding to an exposure register of the TOF camera module to the camera driving module; the camera driving module writes the exposure value into an exposure register of the TOF camera module; the TOF camera module collects a second image frame according to the exposure value in the exposure register.
After the TOF algorithm module calculates the second exposure time, the TOF algorithm module directly sends the second exposure time to the frame management module; the frame management module sends the second exposure time to the face recognition control module. Therefore, the condition that the exposure time of the next frame calculated by the TOF algorithm module is transmitted back to the face recognition control module after passing through the face ID algorithm module to cause exposure time transmission lag can be avoided, and the exposure time transmission efficiency can be improved. And the face recognition control module directly calls the first function through the HIDL interface to write the second exposure time into the camera HAL; the sensor node in the camera HAL invokes a second function to read the second exposure time. In this way, the transmission time of the second exposure time can be saved without the face recognition control module transmitting the second exposure time to the camera HAL through the camera service of the application framework layer. Thus, the TOF camera module can shoot according to the updated exposure time (the exposure time of the next frame) as soon as possible, so that the electronic equipment can unlock the face as soon as possible.
In one possible implementation, the first exposure time includes a first gray map exposure time and a first depth map exposure time; the second exposure time includes a second gray-scale image exposure time and a second depth-image exposure time; the second gray scale map exposure time is different from the first gray scale map exposure time and/or the second depth map exposure time is different from the first depth map exposure time. In the case of overexposure of the first image frame, the second exposure time may be less than the first exposure time. I.e. the second gray-scale image exposure time is smaller than the first gray-scale image exposure time and/or the second depth-image exposure time is smaller than the first depth-image exposure time. In this way, by reducing the exposure time, the TOF camera can be prevented from capturing overexposed image frames again. In the case of under-exposure of the first image frame, the second exposure time may be greater than the first exposure time. I.e. the second gray-scale image exposure time is greater than the first gray-scale image exposure time and/or the second depth-image exposure time is greater than the first depth-image exposure time. Thus, by increasing the exposure time, the TOF camera can be prevented from capturing an underexposed image frame again.
In one possible implementation, the TOF camera module includes an emitter for emitting an optical signal and an image sensor for receiving reflected light and imaging, and before controlling the TOF camera module to acquire the first image frame based on the first exposure time, the method further includes: controlling the transmitter to operate at a first light intensity; determining whether the transmitter is in a normal working state; and under the condition that the transmitter is in a normal working state, controlling the transmitter to work at a second light intensity, wherein the second light intensity is larger than the first light intensity.
In one possible implementation, the optical signal emitted by the emitter when operating at a first current value is a first light intensity, and the optical signal emitted by the emitter when operating at a second current value is a second light intensity, the second current value being greater than the first current value.
In one possible implementation, performing face recognition based on the second image frame includes: acquiring a second gray level map and a second depth map based on the second image frame; and performing face comparison based on the second gray level image, and performing anti-counterfeiting detection based on the second depth image to obtain a face recognition result. If the face comparison result meets the first preset condition, the anti-counterfeiting detection result meets the second preset condition, and the face recognition result can be considered to be successful, so that operations such as face unlocking and the like can be performed in time.
In one possible implementation, the method further includes: the face recognition failure is performed based on the first image frame. After the face recognition is failed to be carried out based on the first image frame, the face recognition can be carried out according to the second image frame in time, so that the face unlocking efficiency can be improved.
In one possible implementation, the first operation includes an operation for unlocking the electronic device, an operation for online payment, an operation for entering a face, or an operation for securely registering or logging in an application. The first operation may be, for example, an operation of pressing a power key, clicking, sliding, or the like, which is not limited in this application.
In a second aspect, the present application provides a chip system comprising one or more interface circuits and one or more processors. The interface circuit and the processor are interconnected by a wire. The chip system described above may be applied to an electronic device including a communication module and a memory. The interface circuit is for receiving signals from a memory of the electronic device and transmitting the received signals to the processor, the signals including computer instructions stored in the memory. When executed by a processor, the electronic device may perform the method as described in the first aspect and any one of its possible designs.
In a third aspect, the present application provides a computer-readable storage medium comprising computer instructions. When executed on an electronic device (such as a mobile phone) the computer instructions cause the electronic device to perform the method as described in the first aspect and any one of its possible designs.
In a fourth aspect, the present application provides a computer program product which, when run on a computer, causes the computer to perform the method according to the first aspect and any one of its possible designs.
In a fifth aspect, embodiments of the present application provide an apparatus, including a processor, the processor being coupled to a memory, the memory storing program instructions that, when executed by the processor, cause the apparatus to implement the method of the first aspect and any one of the possible designs thereof. The apparatus may be an electronic device or a server device; or may be an integral part of an electronic device or server device, such as a chip.
In a sixth aspect, embodiments of the present application provide an apparatus, where the apparatus may be functionally divided into different logic units or modules, each unit or module performing a different function, so that the apparatus performs the method described in the first aspect and any possible design manner thereof.
It will be appreciated that the advantages achieved by the chip system according to the second aspect, the computer readable storage medium according to the third aspect, the computer program product according to the fourth aspect, and the apparatus according to the fifth aspect and the sixth aspect provided above may refer to the advantages as in the first aspect and any of the possible designs thereof, and will not be repeated here.
Drawings
Fig. 1 is a schematic structural diagram of an electronic device according to an embodiment of the present application;
fig. 2 is a schematic diagram of a TOF imaging technique according to an embodiment of the present disclosure;
FIG. 3 is a schematic diagram of a software module architecture according to an embodiment of the present application;
FIG. 4 is a schematic diagram illustrating interactions between software modules according to an embodiment of the present application;
FIG. 5 is a schematic diagram illustrating interactions between software modules according to an embodiment of the present application;
FIG. 5A is a schematic diagram illustrating interactions between software modules according to an embodiment of the present application;
FIG. 5B is a schematic diagram illustrating interactions between software modules according to an embodiment of the present application;
FIG. 5C is a schematic diagram illustrating interactions between software modules according to an embodiment of the present application;
FIG. 5D is a schematic diagram illustrating interactions between software modules according to an embodiment of the present application;
Fig. 6A is a schematic signal interaction diagram provided in an embodiment of the present application;
FIG. 6B is a schematic diagram of another signal interaction provided in an embodiment of the present application;
FIG. 7 is a schematic view of a display provided in an embodiment of the present application;
FIG. 8 is a schematic view of another display provided in an embodiment of the present application;
FIG. 9 is a schematic view of another display provided in an embodiment of the present application;
FIG. 10 is a schematic diagram of still another signal interaction provided in an embodiment of the present application;
fig. 11 is a schematic diagram of a chip structure according to an embodiment of the present application.
Detailed Description
The technical solutions in the embodiments of the present application will be described below with reference to the drawings in the embodiments of the present application. Wherein, in the description of the present application, unless otherwise indicated, "at least one" means one or more, and "a plurality" means two or more. In addition, in order to clearly describe the technical solutions of the embodiments of the present application, in the embodiments of the present application, the words "first", "second", and the like are used to distinguish the same item or similar items having substantially the same function and effect. It will be appreciated by those of skill in the art that the words "first," "second," and the like do not limit the amount and order of execution, and that the words "first," "second," and the like do not necessarily differ.
For clarity and conciseness in the description of the embodiments below, a brief introduction to related concepts or technologies is first given:
the general running environment (rich execution environment, REE), which may also be referred to as a rich execution environment or a normal execution environment or an untrusted execution environment, refers to a system running environment of the mobile terminal, where operating systems such as Android, IOS, linux, and the like may be run. The REE has good opening and expansibility but low security.
The trusted execution environment (trusted execution environment, TEE), also known as a secure side or secure area, is an area that requires authorization to be accessed. The TEE and the REE coexist in the running environment of the electronic equipment, the isolation from the REE is realized through the support of hardware, the security capability is realized, and the software attack easily suffered by the conventional REE side can be resisted. The TEE has its own running space, and defines strict protection measures, so that the TEE has a higher security level than the REEs, and can protect assets (assets) in the TEE, such as data, software and the like, from software attacks and resist specific types of security threats.
The REE+TEE architecture refers to an architecture that provides services for applications in combination with REE through the TEE. That is, the TEE is co-present with the REE in the electronic device. By way of example, the TEE, through hardware support, may implement an operating mechanism that is isolated from the REEs. The TEE has its own running space, which is higher than the security level of the REEs, and can protect assets (e.g., data, software, etc.) in the TEE from software attacks. Only authorized security software can execute in the TEE, while it also protects the confidentiality of the security software's resources and data. Compared with REE, TEE can better protect the security of data and resources due to protection mechanisms such as isolation, authority control and the like.
The TA, i.e. the trusted application, is an application running in the TEE that is able to provide security services for CAs running outside the TEE, such as entering passwords, generating transaction signatures, face recognition, etc.
CA, i.e. client application. CA generally refers to an application running in the REE. The CA may make a call to the TA through a Client (Client) application programming interface (application programming interface, API) and instruct the TA to perform the corresponding security operation.
Software development kit (software development kit, SDK): broadly refers to a collection of related documents, examples, and tools that facilitate the development of a certain class of software.
RAW Data, i.e., RAW Data, can be understood as "RAW and uncompressed Data". In the embodiment of the present application, RAW Data may refer to RAW image Data that a TOF camera converts captured light source signals into digital signals. Some Metadata (Metadata) generated by camera shooting is also recorded in RAW Data.
Metadata, which may be called intermediate data or relay data, is data (data about data) for describing data, and mainly is information describing data attributes (properties). In the embodiment of the application, metadata can indicate the working mode of the camera, the magnitude of the lighting current value, the working state of the TOF camera device, the exposure value and other information.
Time of flight (TOF) imaging refers to imaging techniques in which a set of infrared light (or laser pulses) that is not visible to the human eye is emitted outward, reflected off an object, reflected off a camera, calculated as the time or phase difference from the emission to the reflection back to the camera, and collected to form a set of range depth data, thereby obtaining a three-dimensional 3D model. That is, the TOF imaging technique adds depth information from the Z-axis direction based on conventional 2D XY-axis imaging, and finally generates 3D image information. In the embodiments of the present application, the TOF technique may refer to an indirect TOF (iToF) technique.
A TOF camera (TOF camera module) may include a Transmitter (TX) for transmitting infrared light or laser pulses and a Receiver (RX) for receiving reflected light and imaging. Because TX can autonomously emit optical signals for imaging, TOF images are not affected by most light rays in the environment, and therefore, the TOF images are applied to unlocking service, and the safety of face recognition can be improved.
However, under an excessively bright scene (sunlight scene) or an excessively dark scene (full black scene), the image shot by the TOF camera is also subjected to overexposure and underexposure, so that the electronic device cannot perform face unlocking in time.
The embodiment of the application provides a face recognition method, which can timely adjust the exposure time of a TOF camera, avoid the problem that the electronic equipment cannot timely unlock the face due to overexposure or underexposure, and improve the user experience.
Fig. 1 is a schematic structural diagram of an electronic device 100 according to an embodiment of the present application.
As shown in fig. 1, the electronic device 100 may include a processor 110, an external memory interface 120, an internal memory 121, a universal serial bus (universal serial bus, USB) interface 130, a charge management module 140, a power management module 141, a battery 142, an antenna 1, an antenna 2, a mobile communication module 150, a wireless communication module 160, an audio module 170, a speaker 170A, a receiver 170B, a microphone 170C, an earphone interface 170D, a sensor module 180, keys 190, a motor 191, an indicator 192, a camera 193, a display 194, a user identification module (subscriber identification module, SIM) card interface 195, and the like.
The sensor module 180 may include a pressure sensor 180A, a gyroscope sensor 180B, an air pressure sensor 180C, a magnetic sensor 180D, an acceleration sensor 180E, a distance sensor 180F, a proximity sensor 180G, a fingerprint sensor 180H, a temperature sensor 180J, a touch sensor 180K, an ambient light sensor 180L, a bone conduction sensor 180M, and the like.
It is to be understood that the structure illustrated in the present embodiment does not constitute a specific limitation on the electronic apparatus 100. In other embodiments, electronic device 100 may include more or fewer components than shown, or certain components may be combined, or certain components may be split, or different arrangements of components. The illustrated components may be implemented in hardware, software, or a combination of software and hardware.
The processor 110 may include one or more processing units, such as: the processor 110 may include an application processor (application processor, AP), a modem processor, a graphics processor (graphics processing unit, GPU), an image signal processor (image signal processor, ISP), a controller, a memory, a video codec, a digital signal processor (digital signal processor, DSP), a baseband processor, and/or a neural network processor (neural-network processing unit, NPU), etc. Wherein the different processing units may be separate devices or may be integrated in one or more processors.
The controller may be a neural hub and command center of the electronic device 100. The controller can generate operation control signals according to the instruction operation codes and the time sequence signals to finish the control of instruction fetching and instruction execution.
A memory may also be provided in the processor 110 for storing instructions and data. In some embodiments, the memory in the processor 110 is a cache memory. The memory may hold instructions or data that the processor 110 has just used or recycled. If the processor 110 needs to reuse the instruction or data, it can be called directly from the memory. Repeated accesses are avoided and the latency of the processor 110 is reduced, thereby improving the efficiency of the system.
In some embodiments, the processor 110 may include one or more interfaces. The interfaces may include an integrated circuit (inter-integrated circuit, I2C) interface, an integrated circuit built-in audio (inter-integrated circuit sound, I2S) interface, a pulse code modulation (pulse code modulation, PCM) interface, a universal asynchronous receiver transmitter (universal asynchronous receiver/transmitter, UART) interface, a mobile industry processor interface (mobile industry processor interface, MIPI), a general-purpose input/output (GPIO) interface, a subscriber identity module (subscriber identity module, SIM) interface, and/or a universal serial bus (universal serial bus, USB) interface, among others.
It should be understood that the connection relationship between the modules illustrated in this embodiment is only illustrative, and does not limit the structure of the electronic device 100. In other embodiments, the electronic device 100 may also employ different interfaces in the above embodiments, or a combination of interfaces.
The charge management module 140 is configured to receive a charge input from a charger. The charging management module 140 may also supply power to the electronic device through the power management module 141 while charging the battery 142.
The power management module 141 is used for connecting the battery 142, and the charge management module 140 and the processor 110. The power management module 141 receives input from the battery 142 and/or the charge management module 140 and provides power to the processor 110, the internal memory 121, the external memory, the display 194, the camera 193, the wireless communication module 160, and the like. In other embodiments, the power management module 141 may also be provided in the processor 110. In other embodiments, the power management module 141 and the charge management module 140 may be disposed in the same device.
The wireless communication function of the electronic device 100 may be implemented by the antenna 1, the antenna 2, the mobile communication module 150, the wireless communication module 160, a modem processor, a baseband processor, and the like.
The antennas 1 and 2 are used for transmitting and receiving electromagnetic wave signals. Each antenna in the electronic device 100 may be used to cover a single or multiple communication bands. Different antennas may also be multiplexed to improve the utilization of the antennas. For example: the antenna 1 may be multiplexed into a diversity antenna of a wireless local area network.
The mobile communication module 150 may provide a solution for wireless communication including 2G/3G/4G/5G, etc., applied to the electronic device 100. The mobile communication module 150 may include at least one filter, switch, power amplifier, low noise amplifier (low noise amplifier, LNA), etc. The mobile communication module 150 may receive electromagnetic waves from the antenna 1, perform processes such as filtering, amplifying, and the like on the received electromagnetic waves, and transmit the processed electromagnetic waves to the modem processor for demodulation. The mobile communication module 150 can amplify the signal modulated by the modem processor, and convert the signal into electromagnetic waves through the antenna 1 to radiate.
The modem processor may include a modulator and a demodulator. The modulator is used for modulating the low-frequency baseband signal to be transmitted into a medium-high frequency signal. The demodulator is used for demodulating the received electromagnetic wave signal into a low-frequency baseband signal. The demodulator then transmits the demodulated low frequency baseband signal to the baseband processor for processing. The low frequency baseband signal is processed by the baseband processor and then transferred to the application processor. The application processor outputs sound signals through an audio device (not limited to the speaker 170A, the receiver 170B, etc.), or displays images or video through the display screen 194.
The wireless communication module 160 may provide solutions for wireless communication including wireless local area network (wireless local area networks, WLAN) (e.g., wireless fidelity (wireless fidelity, wi-Fi) network), bluetooth (BT), global navigation satellite system (global navigation satellite system, GNSS), frequency modulation (frequency modulation, FM), near field wireless communication technology (near field communication, NFC), infrared technology (IR), etc., as applied to the electronic device 100. The wireless communication module 160 may be one or more devices that integrate at least one communication processing module. The wireless communication module 160 receives electromagnetic waves via the antenna 2, modulates the electromagnetic wave signals, filters the electromagnetic wave signals, and transmits the processed signals to the processor 110. The wireless communication module 160 may also receive a signal to be transmitted from the processor 110, frequency modulate it, amplify it, and convert it to electromagnetic waves for radiation via the antenna 2.
In some embodiments, antenna 1 and mobile communication module 150 of electronic device 100 are coupled, and antenna 2 and wireless communication module 160 are coupled, such that electronic device 100 may communicate with a network and other devices through wireless communication techniques. The wireless communication techniques may include the Global System for Mobile communications (global system for mobile communications, GSM), general packet radio service (general packet radio service, GPRS), code division multiple access (code division multiple access, CDMA), wideband code division multiple access (wideband code division multiple access, WCDMA), time division code division multiple access (time-division code division multiple access, TD-SCDMA), long term evolution (long term evolution, LTE), BT, GNSS, WLAN, NFC, FM, and/or IR techniques, among others. The GNSS may include a global satellite positioning system (global positioning system, GPS), a global navigation satellite system (global navigation satellite system, GLONASS), a beidou satellite navigation system (beidou navigation satellite system, BDS), a quasi zenith satellite system (quasi-zenith satellite system, QZSS) and/or a satellite based augmentation system (satellite based augmentation systems, SBAS).
The electronic device 100 implements display functions through a GPU, a display screen 194, an application processor, and the like. The GPU is a microprocessor for image processing, and is connected to the display 194 and the application processor. The GPU is used to perform mathematical and geometric calculations for graphics rendering. Processor 110 may include one or more GPUs that execute program instructions to generate or change display information.
The display screen 194 is used to display images, videos, and the like. The display 194 includes a display panel. The display panel may employ a liquid crystal display (liquid crystal display, LCD), a light-emitting diode (LED), an organic light-emitting diode (OLED), an active-matrix organic light-emitting diode (AMOLED), a flexible light-emitting diode (flex light-emitting diode, FLED), a mini, micro-OLED, a quantum dot light-emitting diode (quantum dot light emitting diodes, QLED), or the like.
The electronic device 100 may implement photographing functions through an ISP, a camera 193, a video codec, a GPU, a display screen 194, an application processor, and the like. The ISP is used to process data fed back by the camera 193. The camera 193 is used to capture still images or video. The digital signal processor is used for processing digital signals, and can process other digital signals besides digital image signals. Video codecs are used to compress or decompress digital video. The electronic device 100 may support one or more video codecs. In this way, the electronic device 100 may play or record video in a variety of encoding formats, such as: dynamic picture experts group (moving picture experts group, MPEG) 1, MPEG2, MPEG3, MPEG4, etc.
The camera 193 may include 1 to N. For example, the electronic device may include 2 front cameras and 4 rear cameras. Wherein, front-facing camera can include TOF camera in the front-facing camera. The TOF camera includes TX, which may be used to transmit optical signals (infrared light or laser pulses), and RX, which may be used to receive imaging. The TX may be, for example, an infrared light transmitter. RX can be, for example, a complementary metal oxide semiconductor (complementary metal oxide semiconductor, CMOS) or charge coupled device (charge coupled device, CCD) image sensor.
Illustratively, as shown in (a) of fig. 2, an optical signal (infrared light or laser pulse) may be continuously transmitted to a measured object (e.g., a user) through an optical transmitter (Tx) of the TOF camera, and an optical signal returned from the measured object may be received at a sensor end (Rx) of the TOF camera, and depth information of the measured object may be obtained from a phase difference (delay) of the transmitted and received optical signals, as shown in (b) of fig. 2.
Wherein Tx and Rx can exchange information via a bus. For example, rx may send a configuration parameter over a bus (e.g., a serial peripheral interface (Serial Peripheral Interface, SPI) bus) to Tx indicating the address of the Tx corresponding register and the value for that register. For example, the address of the register corresponding to Tx may be 0x11, and the current value may be stored in the memory space corresponding to 0x 11. Tx may operate at a corresponding current value based on a corresponding configuration parameter to emit an optical signal of a corresponding light intensity. Rx may acquire corresponding image data based on reflected light of the corresponding intensity of the optical signal emitted by the emitter. It should be noted that, when Tx is operated at different current values, optical signals with different light intensities can be emitted. For example, operating Tx at a first current value may emit an optical signal of a first light intensity. The Tx operates at a second current value and may emit an optical signal of a second light intensity. The second current value is greater than the first current value. The second light intensity is greater than the first light intensity. The image data acquired by Rx based on reflected light of optical signals of different intensities is also different. For example, when Tx is operated at a first current value and emits a light signal of a first light intensity, rx acquires first image data within a corresponding exposure time; when the Tx works under a second current value and emits a light signal with second light intensity, the Rx acquires second image data in corresponding exposure time; the second image data is different from the first image data.
When the Tx works under the corresponding current value, the working state of the Tx can be judged, and the working state can be normal or abnormal. The Rx may request the operation state of the Tx to the Tx through the bus, and the Tx may feedback the operation state of itself (e.g., normal or abnormal) to the Rx through the bus, so that the Rx may acquire the operation state of the Tx. The Rx may pack the operation state of the Tx and the operation state of itself and the operation mode of both in a first data packet (e.g., metadata). Rx may also package Metadata and image Data acquired based on reflected light in a second Data packet (e.g., RAW Data).
The NPU is a neural-network (NN) computing processor, and can rapidly process input information by referencing a biological neural network structure, for example, referencing a transmission mode between human brain neurons, and can also continuously perform self-learning. Applications such as intelligent awareness of the electronic device 100 may be implemented through the NPU, for example: image recognition, face recognition, speech recognition, text understanding, etc.
The external memory interface 120 may be used to connect an external memory card, such as a Micro SD card, to enable expansion of the memory capabilities of the electronic device 100. The external memory card communicates with the processor 110 through an external memory interface 120 to implement data storage functions. For example, files such as music, video, etc. are stored in an external memory card. The internal memory 121 may be used to store computer executable program code including instructions. The processor 110 executes various functional applications of the electronic device 100 and data processing by executing instructions stored in the internal memory 121. For example, in an embodiment of the present application, the processor 110 may include a storage program area and a storage data area by executing instructions stored in the internal memory 121, and the internal memory 121 may include a storage program area and a storage data area. The storage program area may store an application program (such as a sound playing function, an image playing function, etc.) required for at least one function of the operating system, etc. The storage data area may store data created during use of the electronic device 100 (e.g., audio data, phonebook, etc.), and so on. In addition, the internal memory 121 may include a high-speed random access memory, and may further include a nonvolatile memory such as at least one magnetic disk storage device, a flash memory device, a universal flash memory (universal flash storage, UFS), and the like.
The electronic device 100 may implement audio functions through an audio module 170, a speaker 170A, a receiver 170B, a microphone 170C, an earphone interface 170D, an application processor, and the like. Such as music playing, recording, etc.
The audio module 170 is used to convert digital audio information into an analog audio signal output and also to convert an analog audio input into a digital audio signal. The audio module 170 may also be used to encode and decode audio signals. The speaker 170A, also referred to as a "horn," is used to convert audio electrical signals into sound signals. A receiver 170B, also referred to as a "earpiece", is used to convert the audio electrical signal into a sound signal. Microphone 170C, also referred to as a "microphone" or "microphone", is used to convert sound signals into electrical signals. The earphone interface 170D is used to connect a wired earphone.
The keys 190 include a power-on key, a volume key, etc. The keys 190 may be mechanical keys. Or may be a touch key. The electronic device 100 may receive key inputs, generating key signal inputs related to user settings and function controls of the electronic device 100. The motor 191 may generate a vibration cue. The motor 191 may be used for incoming call vibration alerting as well as for touch vibration feedback. The indicator 192 may be an indicator light, may be used to indicate a state of charge, a change in charge, a message indicating a missed call, a notification, etc. The SIM card interface 195 is used to connect a SIM card. The SIM card may be inserted into the SIM card interface 195, or removed from the SIM card interface 195 to enable contact and separation with the electronic device 100. The electronic device 100 may support 1 or N SIM card interfaces, N being a positive integer greater than 1. The SIM card interface 195 may support Nano SIM cards, micro SIM cards, and the like.
The methods in the following embodiments may be implemented in the electronic device 100 having the above-described hardware structure.
The software system of the electronic device 100 may employ a layered architecture, an event driven architecture, a micro-core architecture, a micro-service architecture, or a cloud architecture. In the embodiment of the invention, taking an Android system with a layered architecture as an example, a software structure of the electronic device 100 is illustrated.
The layered architecture divides the software into several layers, each with distinct roles and branches. The layers communicate via interfaces. In some embodiments, an Android system may include an application layer, an application framework layer, an Zhuoyun rows (Android run) and libraries, a hardware abstraction layer (hardware abstraction layer, HAL), and a kernel layer. It should be noted that, in the embodiment of the present application, the Android system is illustrated, and in other operating systems (such as a hong mo system, an IOS system, etc.), the scheme of the present application can be implemented as long as the functions implemented by the respective functional modules are similar to those implemented by the embodiment of the present application.
The application layer may include a series of application packages, among other things.
As shown in fig. 3, the application package may include applications for cameras, gallery, calendar, phone calls, maps, navigation, WLAN, bluetooth, music, video, short messages, lock screen applications, setup applications, etc. Of course, the application layer may also include other application packages, such as a payment application, a shopping application, a banking application, a chat application, or a financial application, which are not limited in this application.
The setting application has a function of inputting a face, and the input face is used for face unlocking. The lock screen application has a function of unlocking in response to an unlocking operation (e.g., pressing a power key) by a user. The screen locking application can perform unlocking processing such as face unlocking, fingerprint unlocking, password unlocking and the like, and the embodiment of the application mainly uses face unlocking as an example for explanation.
The application framework layer provides an application programming interface (application programming interface, API) and programming framework for application programs of the application layer. The application framework layer includes a number of predefined functions. For example, an activity manager, a window manager, a content provider, a view system, a resource manager, a notification manager, a Camera Service (Camera Service), a face recognition Service, and the like may be included, which is not limited in any way by the embodiments of the present application.
The system library may include a plurality of functional modules. For example: surface manager (surface manager), media library (Media Libraries), openGL ES, SGL, etc.
The surface manager is used to manage the display subsystem and provides a fusion of 2D and 3D layers for multiple applications.
Media libraries support a variety of commonly used audio, video format playback and recording, still image files, and the like. The media library may support a variety of audio video encoding formats, such as: MPEG4, h.264, MP3, AAC, AMR, JPG, PNG, etc.
OpenGL ES is used to implement three-dimensional graphics drawing, image rendering, compositing, and layer processing, among others.
SGL is the drawing engine for 2D drawing.
Android Runtime (Android run) includes a core library and virtual machines. Android run time is responsible for scheduling and management of the Android system. The core library consists of two parts: one part is a function which needs to be called by java language, and the other part is a core library of android. The application layer and the application framework layer run in a virtual machine. The virtual machine executes java files of the application program layer and the application program framework layer as binary files. The virtual machine is used for executing the functions of object life cycle management, stack management, thread management, security and exception management, garbage collection and the like.
The HAL layer is encapsulation of a Linux kernel driver, provides an interface upwards, and shields implementation details of low-level hardware.
The HAL layer may include Wi-Fi HAL, audio (audio) HAL, camera HAL (Camera HAL), face recognition control module (Face CA), face trusted application, and the like.
The Camera HAL is a core software framework of the Camera, and may include a sensor node (sensor node) and an Image Front End (IFE) node (IFE node). The sensor nodes and IFE nodes are components (nodes) in the image data and control instruction transmission path (which may also be referred to as a transmission pipeline) created by the camera HAL.
The face recognition control module is a core software framework/application of face recognition.
Face trusted application (Face Trusted Application, face TA): an application for face recognition running in a TEE environment. In the embodiment of the present application, face TA is referred to as Face recognition TA.
Among them, the Face TA (may also be referred to as Face recognition TA) may include a Frame management module (Frame Manager), a TOF algorithm (algo) module, and a Face (Face) ID algorithm module. The frame management module may send RAW Data corresponding to each frame of image to the TOF algorithm module. The TOF algorithm module can convert RAW Data into a grayscale map (IR map) and a depth map (depth map). The TOF algorithm module may send the gray map and the depth map to the face ID algorithm module. The face ID algorithm module can perform face recognition (namely judging whether the current user is a machine owner) based on the gray level map, and perform living body detection (anti-fake detection) based on the depth map, so that a face recognition result is obtained.
The kernel layer is a layer between hardware and software. The inner core layer at least comprises a display driver, a camera driver, an audio driver and a sensor driver.
The Camera driving is a driving layer of the Camera device and is mainly responsible for interaction with hardware.
The hardware layer comprises a display, a TOF camera, an IFE module, a Secure Buffer (Secure Buffer) and the like.
The safe memory is a memory with a safety protection function, and can be used for storing raw data acquired by the TOF camera.
A TOF camera, which may also be referred to as a TOF sensor, may include a Transmitter (TX) for transmitting infrared light or laser pulses and a Receiver (RX) for receiving reflected light and imaging.
IFE module (IFE-Lite): the image preprocessing module can be used for forwarding the image data, and the image data is not processed in the forwarding process.
The following describes software modules and interactions between modules involved in the face recognition method provided in the embodiment of the present application. As shown in fig. 4, the screen locking application in the application layer may interact with the face recognition SDK, which may interact with the face recognition service in the framework layer by calling a preset application program interface (application programming interface, API), the face recognition service may interact with the face recognition control module in the HAL layer, the face recognition control module may interact with the camera HAL in the HAL layer through the camera service in the framework layer, or the face recognition control module may interact directly with the camera HAL in the HAL layer. Sensor nodes and IFE nodes may be included in the camera HAL. The sensor node may interact with a camera driving module in the kernel layer, which may be used to drive a TOF camera in the hardware layer to acquire image data in a default operating mode (e.g. eye-safe mode, see in particular the description in S112 below). The IFE module may store image data acquired by the TOF camera into a secure memory. The storage location of the image data acquired by the TOF camera in the secure memory may be represented using a File Descriptor (FD). The IFE module may send the FD of the image data to the camera driving module. The camera drive module may pass the FD to the IFE node of the camera HAL. The IFE node may communicate the FD to the camera service. The camera service may pass the FD to the face recognition control module. The face recognition control module may pass FD to face recognition TA. The frame management module in the face recognition TA may read the image Data (RAW Data 1) from the secure memory according to the FD, and send the RAW Data to the TOF algorithm module. The TOF algorithm module may convert RAW Data 1 into a gray scale map and a depth map, and then send the gray scale map and the depth map to the face ID algorithm module. The face ID algorithm module can be used for matching gray level images and judging anti-counterfeiting of depth images so as to obtain face recognition results. The face ID algorithm module can send the face recognition result to the face recognition control module through the frame management module. The face recognition control module may continue to send the face recognition result to the camera HAL through the camera service, or the face recognition control module may directly send the face recognition result to the camera HAL, so that the camera HAL switches the operation mode of the TOF camera according to the face recognition result. The camera HAL may continue to interact with the camera driving module, so that the camera driving module may drive the TOF camera to acquire image data with the switched working module (for example, a face ID mode, specifically may refer to the description in S112 below), the FD corresponding to the image data may continue to be transferred to the face recognition TA through the IFE module, the camera driving module, the IFE node, the camera service and the face control module, and the face recognition TA may read and process the image data again, and feedback the processing result (that the face recognition is successful or fails) to the face recognition control module. The face recognition control module can feed back the processing result to the screen locking application through the face recognition service and the face recognition SDK so that the screen locking application can determine whether to unlock or not (if the face recognition is successful, unlock, if the face recognition is failed, unlock is not performed, namely unlock is failed). Wherein solid arrows in fig. 4 may be used to represent control flow and dashed arrows may be used to represent data flow.
Specifically, as shown in fig. 5, the sensor node in the camera HAL may be used to select the operation modes of the TOF camera, including an eye-safe mode (first operation mode), a face ID mode (second operation mode), and a TX off mode (third operation mode), and the details of the various operation modes may be referred to as the description in S112 below. The default initial mode of operation of the TOF camera may be a human eye safety mode. When the TOF camera works in the eye safety mode, the eye safety current value (first current value) marked by the production line can be read from the memory, the eye safety mode configuration is updated according to the current value, and the configuration parameters of the eye safety mode can be sent to the camera driving module. After the eye safety detection result is obtained, a mode switching process may be performed. Specifically, if the eye safety detection result is successful, the TOF camera may switch to the face ID mode. If the eye safety detection result fails, the TOF camera can be switched to a TX off mode. Thus, the safety of human eyes can be ensured.
It should be noted that, the above process of switching the operation mode of the TOF camera may be replaced by the following two switching processes:
In the first switching process, the IFE module may send FD (for example, FD 1) of the image data to the camera driving module, the camera driving module may transmit FD1 to the IFE node of the camera HAL, after receiving FD1, the IFE node may transmit FD1 to the sensor node of the camera HAL, and after receiving FD1, the sensor node triggers a flow of reading the working state of the TOF camera. Namely, the sensor node can read a working state register (namely a register for storing the working state of the TOF camera) of the TOF camera through the camera driving module, determine a human eye safety detection result according to the value of the working state register, and switch the working mode of the TOF camera according to the human eye safety detection result.
In the second switching process, the image data collected by the TOF camera may include metadata. The IFE module can delete other data in the image data acquired by the TOF camera, reserve metadata and send the metadata to the camera driving module, the camera driving module can transfer the metadata to an IFE node of the camera HAL, the IFE node can transfer the metadata to a sensor node, the sensor node can analyze the metadata, a human eye safety detection result is calculated, and the working mode of the TOF camera is switched according to the human eye safety detection result.
When the sensor node in the camera HAL selects to switch the working mode of the TOF camera to the face ID mode, the sensor node may send configuration parameters of the face ID mode to the camera driving module. The configuration parameters of the face ID mode may be default, for example, may include: the current value (second current value) was 2800ma, the ir gray scale exposure time was 500 μs, and the depth map exposure time was 800 μs. The camera driving module writes (updates) the configuration parameters of the face ID mode into the register of the TOF camera. The TOF camera collects RAW Data based on the face ID pattern.
However, in a scene that is too bright (sunlight scene) or too dark (full black scene), the configuration parameters of the default eye safety mode may not be suitable for the current environment, so that the situation of overexposure and underexposure occurs in the image shot by the TOF camera, and the electronic device cannot perform face unlocking timely.
In order to solve the problems, the method can adopt the following three improved modes to solve the problem that the time consumption of unlocking the face of the electronic equipment is too long or the face cannot be unlocked due to the fact that the image shot by the TOF camera is overexposed and underexposed, so that the face unlocking efficiency is improved.
In one mode, as shown in fig. 5A, after the frame management module of the face recognition TA acquires the first frame image DATA (RAW DATA 2, i.e., the first image frame) of the TOF camera module operating in the face ID mode, the frame management module sends the RAW DATA 2 to the TOF algorithm module. The RAW DATA 2 is acquired by the TOF camera module based on a default exposure time (first exposure time) of the face ID mode. The TOF algorithm module acquires a gray scale image and a depth image according to the RAW DATA 2, and calculates the exposure time of the next frame (for adjusting the exposure of the next frame image, the second exposure time). The next frame exposure time may include an IR gray map exposure time (e.g., 750 us) and a depth map exposure time (e.g., 1200 us). On the one hand, the gray level map and the depth map can be sent to a face ID algorithm module to carry out face recognition and living body verification; on the other hand, the TOF algorithm module can directly transmit the exposure time of the next frame back to the face recognition control module through the frame management module. The face recognition control module may send the exposure time of the next frame to the camera HAL through the camera service. The sensor node in the camera HAL can process the exposure time of the next frame to obtain the exposure value corresponding to the exposure register of the TOF camera. Therefore, the condition that the exposure time of the next frame calculated by the TOF algorithm module is transmitted back to the face recognition control module after passing through the face ID algorithm module to cause exposure time transmission lag can be avoided, and the exposure time transmission efficiency can be improved. Furthermore, the TOF camera module can shoot according to the updated exposure time (the exposure time of the next frame) as soon as possible, so that the electronic equipment can unlock the face as soon as possible.
In the second mode, as shown in fig. 5B, after the TOF algorithm module calculates the exposure time of the next frame, the next frame may be sent to the face ID algorithm module. The next frame exposure time may include an IR gray map exposure time (e.g., 750 us) and a depth map exposure time (e.g., 1200 us). The face ID algorithm module sends the face recognition result and the exposure time of the next frame to the frame management module, and the frame management module sends the face recognition result and the exposure time of the next frame to the face recognition control module. After receiving the next frame exposure time, the face recognition control module may directly transfer the next frame exposure time to the camera HAL through the HIDL interface. For example, the face recognition control module may call a first function (e.g., setitofecdata function in camera configuration service (camcfgserver)) to write the next frame exposure time to the camera HAL. In this way, the time consumption caused by the fact that the face recognition control module transmits the exposure time of the next frame to the camera HAL through the camera service can be avoided, and the transmission efficiency of the exposure time can be improved. Upon receiving a next frame request (for requesting photographing of a next frame image) of the frame layer (frame work), the sensor node in the camera HAL may call a second function (e.g., a getitofecdata function in an execution process request) to read the next frame exposure time written by the face recognition control module into the camera HAL. The sensor node may also process the next frame exposure time by a third function (e.g., calcitoffregisteraecdata function) to obtain an exposure value corresponding to the TOF sensor exposure register. The TOF sensor exposure registers may include, among other things, an IR gray map exposure register and a depth map exposure register. The address of the IR gray scale exposure register and the corresponding value thereof may be respectively: 0x2129,0x01;0x212a,0x5f;0x212b 0x90; the address of the depth map exposure register and the corresponding value thereof can be 0x2125,0x02;0x2126,0x32;0x2127,0x80. Wherein the calcitoff registeraecdata function can convert the IR gray map exposure time (e.g., 750 us) to 0x01,0x5f,0x90; the depth map exposure time (e.g., 1200 us) is converted to 0x02,0x32,0x80. And then the sensor node transmits an exposure value corresponding to an exposure register of the TOF camera to the camera driving module. The camera driving module writes the exposure value into the TOF camera module through the I2C bus. The TOF camera module starts to expose according to the exposure value and outputs corresponding image DATA (RAW DATA 3). In this way, the transmission time of the second exposure time can be saved without the face recognition control module transmitting the second exposure time to the camera HAL through the camera service of the application framework layer. The TOF camera module can shoot according to the updated exposure time (the exposure time of the next frame) as soon as possible, so that the electronic equipment can unlock the face as soon as possible.
In addition, if the sensor node does not acquire the next frame exposure time (i.e., the sensor node calls the gettofAECdatas function and does not read the next frame exposure time when the face recognition control module writes the camera HAL), the sensor node does not need to issue the exposure value corresponding to the exposure register of the TOF camera to the camera driving module (i.e., the exposure value corresponding to the TOF sensor exposure register is not reconfigured), and the TOF camera still adopts the default exposure value. If the exposure time of the next frame acquired by the sensor node continuously twice is the same, the exposure value corresponding to the exposure register of the TOF camera does not need to be repeatedly issued to the camera driving module (namely, the exposure value corresponding to the exposure register of the TOF camera does not need to be repeatedly configured).
In a third mode, as shown in fig. 5C, after the frame management module of the face recognition TA obtains the nth frame (N is greater than or equal to 2) image DATA (e.g., RAW DATA 3) of the TOF camera module operating in the face ID mode, it may be determined whether the exposure time in RAW DATA 3 is the same as the exposure time of the expected configuration (the next frame exposure time calculated by the TOF algorithm module according to RAW DATA 2 may include the IR gray-scale exposure time (e.g., 750 us) and the depth-map exposure time (e.g., 1200 us)). If the same, the RAW DATA 3 may be sent to the TOF algorithm module to calculate the gray level map and the depth map and calculate the exposure time of the next frame. If the frames are different, the frames are lost (namely the RAW DATA 3 is discarded), so that the problem that the face recognition time is consumed (the unlocking efficiency is reduced) because invalid frames are repeatedly sent into the TOF algorithm module and the face ID algorithm module to be calculated is avoided. In addition, after the continuous frame loss reaches a preset threshold (for example, 3 frames), the frame loss can be avoided, and the problem that the face unlocking algorithm cannot continue to run due to the continuous frame loss is avoided.
Of course, the above three modes can be used alternatively or in combination (any two of the first mode, the second mode or the third mode are used in combination, or the three modes are used in combination at the same time, which is not limited in the application), so that the electronic device can adjust the exposure time of the TOF camera module in time, and thus the face unlocking can be successfully performed.
For example, when the above three modes are combined together for use, as shown in fig. 5D, after the frame management module of the face recognition TA obtains the first frame image DATA (RAW DATA 2) of the TOF camera module working in the face ID mode, the RAW DATA 2 is sent to the TOF algorithm module. The TOF algorithm module acquires the gray level map and the depth map according to the RAW DATA 2, and performs calculation of the exposure time of the next frame (for adjusting the exposure of the next frame image). On the other hand, the TOF algorithm module can send the gray level image and the depth image to the face ID algorithm module to carry out face recognition and living body verification; on the other hand, the TOF algorithm module can directly transmit the exposure time of the next frame to the face recognition control module through the frame management module. After receiving the next frame exposure time, the face recognition control module may communicate the next frame exposure time directly to the camera HAL via the HAL interface definition language (HAL interface definition language, HIDL) interface. For example, the face recognition control module may call the setcaecdatas function in the camcfgserver to write the next frame exposure time to the camera HAL. When the next frame request of the frame work is received, the sensor node in the camera HAL may call the gettofaecdata function in the execteprocess request to read the next frame exposure time of the face recognition control module to write into the camera HAL. The sensor node can also process the exposure time of the next frame through a CalcetofRegisterAECdatas function to obtain an exposure value corresponding to the TOF sensor exposure register. And then, the sensor node transmits an exposure value corresponding to an exposure register of the TOF camera to the camera driving module. The camera driving module writes the exposure value into the TOF camera module through the I2C bus. The TOF camera module starts to expose according to the exposure value and outputs corresponding image DATA (e.g. RAW DATA 3). After the frame management module of the face recognition TA obtains the nth frame (N is greater than or equal to 2) image DATA (e.g., RAW DATA 3) of the TOF camera module working in the face ID mode, it may be determined whether the exposure time in the RAW DATA 3 is the same as the exposure time of the expected configuration (e.g., the exposure time of the next frame calculated by the TOF algorithm module according to RAW DATA 2). If the same, the frame management module sends the RAW DATA 3 to the TOF algorithm module for gray level map and depth map calculation and next frame exposure time calculation. If the frames are different, the frame management module can discard the frames (namely discard the RAW DATA 3), so that the problem that the invalid frames are repeatedly sent into the TOF algorithm module and the face ID algorithm module to be calculated, and the face recognition time is consumed (the unlocking efficiency is reduced) is avoided. In addition, after the continuous frame loss reaches the preset threshold (for example, 3 frames), the frame loss can be avoided, and the problem that the face recognition algorithm cannot continue to run due to the continuous frame loss is avoided.
For ease of understanding, the methods provided in the embodiments of the present application are specifically described below with reference to the accompanying drawings.
As shown in fig. 6A, an embodiment of the present application provides a method for human eye security detection and face recognition based on TOF images, and the flow is as follows:
s101, the screen locking application calls the face recognition SDK to carry out face recognition.
When the unlocking operation (first operation) of the user is detected, the screen locking application calls the face recognition SDK to conduct face recognition. The unlocking operation of the user includes operations such as the user picking up the mobile phone, pressing a power key, operating on a screen (clicking, sliding, etc.), or pulling out a charging wire.
Meanwhile, the screen locking application can register a callback with the face recognition SDK, and the callback is registered to return the face recognition result to the screen locking application after the face recognition SDK obtains the face recognition result.
S102, the face recognition SDK sends a face recognition request to a face recognition service.
The face recognition request carries the identification of the face recognition type, the resolution of the image and the data stream format. The face recognition types include a 2D face recognition type (e.g., may correspond to the identification 0) and a 3D face recognition type (e.g., may correspond to the identification 1), among others.
For example, the type of face recognition carried in the face recognition request may be 1 (i.e., 3D face recognition type), the resolution of the image may be 1280x2898 pixels (pixels), and the data stream format may be RAW image format (RAW) 16.
Meanwhile, the face recognition SDK can register a callback to the face recognition service, and the callback is registered to return the face recognition result to the face recognition SDK when the face recognition service obtains the face comparison result.
S103, the face recognition service sends a face recognition request to the face recognition control module.
The request for face recognition may refer to the description of S102, which is not described herein.
That is, the face recognition SDK may inform the face recognition control module of performing face recognition through the face recognition service. The face recognition service may send a request for face recognition received from the face recognition SDK to the face recognition control module.
Meanwhile, the face recognition service can register a callback to the face recognition control module, and the function of registering the callback is that when the face recognition control module obtains the face comparison result, the face comparison result can be returned to the face recognition service.
S104, responding to the received face recognition request, and matching the camera by the face recognition control module according to the face recognition request.
Specifically, the face recognition control module may obtain the identification of the face recognition type, the resolution size of the image, and the data stream format from the request for face recognition, and determine the matched camera by querying the camera capability from the camera service.
It should be appreciated that during the power-on process of the electronic device, the camera service may send a camera capability query request to the camera HAL for requesting a query of the camera capability supported by the electronic device. After receiving the camera capability query request, the camera HAL may send the capabilities of the camera supported by the electronic device to the camera service, and the camera service may store the received capabilities of the camera supported by the electronic device. The camera capability supported by the electronic device includes a camera Identifier (ID) of each camera, a supported maximum resolution, a format of a data stream, whether the camera supports acquisition of depth information, and the like.
For example, assuming that three cameras are installed on the mobile phone, the capability information of the three cameras may be as shown in table 1:
TABLE 1
Camera ID | Mounting position | Maximum resolution supported | Data stream format | Depth information |
1 | Rear-mounted | 4096x3072pixel | YUY | No |
2 | Front-mounted | 3264x2448 pixel | YUY | No |
3 | Front-mounted | 1280x2898 pixel | RAW16 | Yes |
The camera with the camera ID of 3 can be a TOF camera, and the acquisition of depth information is supported. Cameras with camera IDs 1 and 2 may be ordinary cameras, and do not support acquisition of depth information. Of course, more front or rear cameras may be mounted on the mobile phone, for example, 2 front cameras and 4 rear cameras may be mounted on the mobile phone.
The face recognition control module may send a camera capability query request to the camera service, and the camera service may send the capabilities of the cameras supported by the electronic device to the face recognition control module, and the face recognition control module may determine a matched camera according to the capabilities of the cameras supported by the electronic device, for example, may determine that the matched camera is a camera with ID 3 (i.e., a TOF camera).
It should be noted that table 1 is only an example, and the data stream format corresponding to each camera may include multiple types. For example, the camera with the camera identifier 1 may not only correspond to the data stream format of YUY, but also correspond to the data stream format of RAW16, which is not limited in this application.
S105, the face recognition control module sends a Camera opening request to a Camera service.
Illustratively, the face recognition control module may send a request to the Camera service to turn on the Camera through a vendor native development suite (vendor native development kit, VNDK) interface. The request for opening the Camera carries information such as a security identifier, a Camera ID, the size of resolution, a data stream format and the like. The security identifier is used for indicating that the data is stored in the security Buffer. That is, the security tag may be used to apply for a secure memory, and subsequently used to store data collected by the camera. For example, the security identifier may be 1 or 0,1 indicating that data is stored in a secure Buffer and 0 indicating that data is stored in an unsecure Buffer.
For example, the security identifier carried in the request for opening the Camera may be 1 (i.e. the data is stored in the security Buffer), the resolution of the image may be 1280x2898 pixel, the data stream format may be RAW16, and the Camera ID may be 3.
Meanwhile, the face recognition control module can register a callback to the Camera service, and the callback is registered to inform the face recognition control module that the Camera is opened after the Camera service is opened.
S106, in response to receiving a request for opening the Camera, the Camera service sends the request for opening the Camera to the Camera HAL, wherein the request for opening the Camera carries information such as a security identifier, a Camera ID, the size of resolution, a data stream format and the like.
In the process that the camera service calls the camera HAL, the camera service can send information such as security identification, camera ID, resolution of image, data stream format, etc. to the camera HAL. The camera HAL may cache information such as security identification, camera ID, resolution of the image, data stream format, etc. for a preset time.
At the same time, the camera service may register a callback with the camera HAL for the camera HAL to notify the camera service of the result of creating the path.
S107, the camera HAL creates a corresponding path according to the camera ID, the resolution of the image and the data stream format.
The camera HAL may select available nodes based on camera ID, resolution and data stream format, and then create corresponding paths based on the available nodes. Illustratively, if the resolution is 1280x2898 pixel and the data stream format is RAW16 and the camera ID is 3, it may be determined to select the sensor node and IFE node. This is because the sensor node and IFE node can support transmitting data with a resolution of 1280x2898 pixel acquired by a camera with a camera ID of 3, and the data stream format is RAW 16.
The paths corresponding to the sensor nodes may be: and a sensor node, a camera driver, a TOF camera, an IFE module and a safe memory. The paths corresponding to the IFE nodes may be: IFE module (carrying FD) -camera drive-IFE node. The camera HAL may connect the output port of the sensor node and the input port of the IFE node at the HAL layer. Thus, the path corresponding to the sensor node and the path corresponding to the IFE node can form a closed loop path. After the path is created, the hardware in the path is powered up (i.e., the hardware circuitry is powered on) to await a data request.
S108, the camera HAL returns the result of creating the path to the camera service.
Wherein the result of creating a path may be success or failure. If the result of creating the path is a failure, the camera HAL notifies the camera of the failure of creating the service path. If the creation of the path is successful, the camera HAL informs the camera that the service path creation is successful, and may proceed to S109 and subsequent steps.
S109, in response to receiving the notification of successful path creation, the camera service returns a camera opening completion message to the face recognition control module.
It will be understood that camera on completion refers to preparation before the camera takes a picture or images (e.g., preparation for camera parameter configuration, power up, etc.) having been completed.
And S110, in response to receiving the camera opening completion message, the face recognition control module sends a data request to the camera service.
Wherein the data request is for requesting acquisition of a data stream of the camera.
S111, in response to receiving a data request sent by the face recognition control module, the camera service calls the camera HAL to acquire a data stream.
S112, the camera HAL selects a camera working mode through the sensor node.
Specifically, the sensor node may select a camera working mode corresponding to the sensor node through the camera resolution and the data stream format cached in S106. Illustratively, the sensor node may select a camera mode of operation for the sensor node by looking up a table (e.g., table 2).
TABLE 2
The eye safety Mode (eye safe Mode) refers to a Mode in which the Tx of the TOF camera operates at a small current (a current smaller than a preset threshold value, a first current value), and is used for checking whether the TOF camera is damaged. Face ID Mode (Face ID Mode), which is a Mode in which the Tx of the TOF camera operates at a normal current (second current value, within a preset threshold range), is used for performing scenes such as security Face unlocking and security payment. Wherein the second current value is greater than the first current value. TX OFF Mode (TX OFF Mode) refers to a Mode in which the TX of the TOF camera is not energized (and thus does not emit light), and is used to detect if the TX device of the TOF camera is damaged or not operating properly. This is because the use of the Tx device still energized may have an adverse effect on the human eye in the event of a Tx device failure, and thus when the Tx device of the TOF camera is detected to be damaged, the Tx device is turned off in a Tx off mode, thereby avoiding damage to the human eye.
Of course, the working modes of the camera can also include more, and the application is not limited.
As can be seen from table 2, when the maximum value of the resolution of the image is 1280×2898 pixel and the data stream format is Raw, the camera operation mode may include an eye-safe mode, a face ID mode, a TX off mode, and the like. The sensor node may default to the eye-safe mode for the initial mode of operation of the camera. When the working mode of the camera is the eye safety mode, the sensor node can read the eye safety current value (i.e. the current value without hurting the eyes) marked by the production line from the memory (for example, oemiinfo), and update the eye safety mode setting (setting) of the TOF camera according to the eye safety current value. For example, the address of the current register of the TOF camera may be obtained by table look-up, and the eye-safe current value is written into the current register of the TOF camera. It should be appreciated that the sensor node may store addresses of various registers of the TOF camera, which may be as shown in table 3.
TABLE 3 Table 3
Register identification | Storing data types | Address of |
1 | Electric current | 0x1 |
2 | Resolution ratio | 0x2 |
3 | Data stream format | 0x3 |
4 | TOF camera device operating state | 0x4 |
5 | Working mode of TOF camera | 0x5 |
By way of example, by referring to table 3, it can be determined that the address of the register corresponding to the current value is 0x1, so that the eye-safe current value can be written into the memory space corresponding to 0x 1.
S113, the sensor node sends configuration parameters of the eye safety mode to a Camera Driver (Camera Driver) module of the Kernel layer.
Illustratively, the configuration parameters of the eye-safe mode may be: the current value was 700mA, the IR gray scale exposure time was 10. Mu.s, and the depth map exposure time was 10. Mu.s.
And S114a, the camera driving module writes (updates) configuration parameters of the eye safety mode into a register of the TOF camera.
That is, the camera drive module may send configuration parameters of the human eye safety mode to the TOF camera.
Illustratively, the camera driver module may write configuration parameters of the eye-safe mode into a register of the RX of the TOF camera via an integrated circuit bus (inter-integrated circuit, I2C). The address corresponding to the register of RX may be 0x01. The number of the registers corresponding to RX may be plural, which is not limited in this application. I.e. the configuration parameters of the eye-safe mode can be sent over I2C to the RX of the TOF camera. Wherein the configuration parameters for the eye-safe mode include configuration parameters for RX and TX. For example, the configuration parameter for TX may be a first current value. The configuration parameter for RX may be exposure time. RX can write the configuration parameters corresponding to TX into the register corresponding to TX through SPI bus. The address of the register to which TX corresponds may be 0x11. The TX corresponding register may include a plurality of registers, which is not limited in this application.
S114b, the camera driving module sends a start (stream on) command/instruction (second start command) to the TOF camera.
The stream on command is used for driving the TOF camera to acquire data.
It should be noted that, before S114b, after S114a, the camera driving module may further send a configuration parameter writing completion message to the sensor node; in response to receiving the configuration parameter write complete message, the sensor node sends a start command (first start command) to the camera driver module.
S115, responding to the received stream on command, and acquiring RAW Data 1 by the TOF camera based on the human eye safety mode.
Specifically, in response to receiving a stream on command, RX may send a request for a light emitting signal to TX, where the TX operates at a corresponding current value (first current value) to send a light signal of a first light intensity; RX receives the optical signal at a corresponding exposure time (exposure value, e.g., 10 us), and includes the reflected light of the optical signal of the first light intensity in the optical signal received by RX. Based on the received optical signal, RX acquires the first image data.
That is, RAW Data 1 (RAW Data 1) refers to image Data (first image Data) obtained by receiving reflected light and imaging by the Rx of the TOF camera when the Tx of the TOF camera is operated to transmit light signals to the face at the eye-safe current value calibrated by the production line. The Tx is operated at a line-calibrated eye-safe current value to emit an optical signal at a first optical intensity.
RX can also obtain the working condition to TX through SPI bus, then TX can return the working condition of oneself to RX, RX can obtain TOF camera device working condition in the RX after receiving the working condition that TX sent, include: the operation state of TX and the operation state of RX.
Wherein, the RAW Data contains Metadata. Illustratively, metadata stores information such as the current working mode (e.g., eye-safe mode) of the TOF camera, the magnitude of the lighting current value (e.g., eye-safe current value calibrated by the production line), the working state (e.g., normal or abnormal) of the TOF camera device, and the graph exposure value (e.g., 10 μs).
S116, the TOF camera sends RAW Data 1 acquired based on the human eye safety mode to the IFE module.
Illustratively, the TOF camera may transmit RAW Data 1 acquired by the TOF camera to the IFE module via a Mobile Industry Processor Interface (MIPI) stry processor interface. The IFE module may also be referred to as an image preprocessing module (IFE-Lite), and the IFE module may not process RAW Data 1.
S117, the IFE module sends the RAW Data 1 to a Secure memory (Secure Buffer) for storage.
The storage location of RAW Data 1 acquired by the TOF camera based on the eye-safe mode in the safe memory can be represented by FD 1.
Illustratively, when FD1 is 69, it may represent that the storage location is XX secure memory; when FD1 is 96, it may indicate that the storage location is YY non-secure memory (normal memory).
And S118, the IFE module sends the FD1 to the camera driving module.
And S119, the camera driving module sends the FD1 to the IFE node.
S120, the IFE node sends FD1 to the camera service through the interface of the camera HAL.
S121, the camera service sends FD1 to the face recognition control module.
S122, the FACE recognition control module sends the FD1 to a FACE recognition TA (FACE TA).
The face recognition TA comprises a TOF algorithm and a face ID algorithm. The TOF algorithm is used for converting RAW Data into a gray level map and a depth map, and calculating whether the face is safe or not (i.e. whether the current user is a machine owner or not) according to the gray level map and the depth map. The face ID algorithm is used for matching the gray level image and judging the anti-counterfeiting of the depth image.
S123, the frame management module of the face recognition TA reads RAW Data 1 from the secure memory according to the FD 1.
The face recognition TA may request RAW Data 1 from the secure memory according to FD1, and the secure memory sends RAW Data 1 to the face recognition TA.
S124a, the frame management module sends RAW Data 1 to the TOF algorithm module.
S124b, the TOF algorithm module obtains the human eye safety detection result according to RAW Data 1.
And the TOF algorithm module processes the Metadata in the RAW Data 1 to obtain a human eye safety detection result.
Specifically, the TOF algorithm module may determine whether the TOF camera is in a human eye safety operation mode according to Metadata, if so (i.e. the TOF camera is operated in the human eye safety operation mode), determine whether the device operation state is normal, and if the device operation state is normal, the human eye safety detection result is safe/normal (or the human eye safety detection is successful). If the working state of the device is abnormal, the human eye safety detection result is unsafe/abnormal (or the human eye safety detection fails).
And S124c, the TOF algorithm module sends the human eye safety detection result to the frame management module.
And S125, the frame management module sends the human eye safety detection result to the face recognition control module.
And S126, the human face recognition control module sends the human eye safety detection result to the camera HAL.
In one possible design, if the eye safety detection result is safe/normal (or the eye safety detection is successful), the face recognition control module sends the eye safety detection result to the camera HAL, and the camera HAL determines a corresponding operation mode according to the eye safety detection result (see S127). If the eye safety detection result is unsafe (abnormal), the face recognition control module may consider that the face recognition fails, and the face recognition control module may transmit the face recognition result (failure) to the face recognition service based on the callback registered by the face recognition service (in S103). The face recognition service passes the face recognition result (failure) to the face recognition SDK based on the callback of the previous (in S102) face recognition SDK registration. The face recognition SDK passes the face recognition result (failure) to the lock screen application based on the callback registered by the previous lock screen application (in S101). The screen locking application can decide not to unlock according to the face recognition result (failure).
In one possible design, the face recognition control module may send the eye safety detection result to the camera HAL through the camera service (whether the eye safety detection result is successful or failed). That is, the face recognition control module may transmit the eye safety detection result to the camera service, which in turn transmits the eye safety detection result to the camera HAL. The camera HAL determines a corresponding operation mode based on the eye-safety detection result (see S127).
In another possible design, the face recognition control module may send the eye safety detection result directly to the camera HAL (whether the eye safety detection result is successful or failed), and the camera HAL determines the corresponding operation mode according to the eye safety detection result (see S127).
Illustratively, the face recognition control module may communicate the eye security detection results directly to the camera HAL via the HIDL interface. Or, the face recognition control module may send the eye safety detection result to the camera service through the VNDK interface, so that the camera service sends the eye safety detection result to the camera HAL.
S127, the sensor node of the camera HAL determines the working mode of the TOF camera based on the human eye safety detection result.
If the human eye safety detection result is safe (normal), determining that the working mode of the TOF camera is a human face ID mode; if the eye safety detection result is unsafe (abnormal), the working mode of the TOF camera is determined to be a Tx closing mode.
It should be noted that, the sensor node may store configuration parameters corresponding to the face ID mode and the Tx off mode.
For example, the configuration parameters corresponding to the face ID mode may be: the current value (second current value) was 2800ma, the ir gray scale exposure time was 500 μs, depth was yes, and the depth map exposure time was 800 μs. The configuration parameters corresponding to the TxOFF mode may be: the current value (third current value) was 0ma, the ir gray scale exposure time was 10 μs, depth was no, and the depth map exposure time was 10 μs.
Note that, the embodiment of the present application does not limit the execution order of S101 to S127. In some embodiments, S101-S107 may be performed directly after S112-S126 is performed, S108-S111 may be performed after S126, and S127 may be performed after S111. Of course, other combination sequences may be provided in S101-S127 to ensure that the sensor node of the camera HAL may obtain the eye safety detection result, so as to determine the working mode of the TOF camera, which is not described herein in detail.
The following describes an example in which the operation mode of the TOF camera determined by the sensor node is a face ID mode, and after S127, S128-S144 are further included:
s128, the sensor node sends the configuration parameters of the face ID mode to the camera driving module.
S129, the camera driving module writes configuration parameters of the face ID mode into a register of the TOF camera to drive the TOF camera to collect data based on the face ID mode.
That is, the camera driver module may send configuration parameters of the face ID mode to the TOF camera.
Illustratively, the camera driver module may write configuration parameters of the face ID mode into the TOF camera register via I2C. That is, the camera driving module may send configuration parameters of the face ID mode to the TOF camera through the I2C.
S130, the TOF camera acquires RAW Data 2 based on the face ID mode.
The RAW Data 2 may be image Data (second image Data) obtained by receiving reflected light and imaging by the Rx of the TOF camera when the Tx of the TOF camera is operated at a second current value (for example, 2800 mA) to transmit an optical signal to the face. The optical signal emitted when the Tx of the TOF camera operates at the second current value is the second light intensity. The second light intensity is greater than the first light intensity.
Wherein, RAW Data2 contains Metadata. Illustratively, metadata stores information such as the current TOF camera operating mode (e.g., face ID mode), the magnitude of the lighting current value (e.g., 2800 mA), the TOF camera device operating state (e.g., normal), and the depth map exposure time (e.g., 800 μs).
S131, the TOF camera sends RAW Data2 to the IFE module.
Illustratively, the TOF camera may transmit RAW Data2 acquired by the TOF camera based on the face ID mode to the IFE module via MIPI.
S132, the IFE module sends the RAW Data2 to the secure memory for storage.
The storage position of RAW Data2 acquired by the TOF camera based on the face ID mode in the secure memory may be represented by FD 2.
FD2 in this step may be the same as or different from FD1 in S117. When FD2 in this step is the same as FD1 in S117, that is, RAW Data2 collected by the TOF camera based on the face ID mode and RAW Data 1 collected by the TOF camera based on the eye security mode in S117 are stored in the same secure memory. The RAW Data 1 collected by the TOF camera based on the human eye security mode in S117 may be deleted, so that the RAW Data2 collected by the TOF camera based on the human face ID mode may be restored to the security memory. In the case where FD2 is different from FD1, RAW Data2 collected by the TOF camera based on the face ID mode and RAW Data 1 collected by the TOF camera based on the eye safety mode in S117 may be stored in different safety memories.
And S133, the IFE module sends the FD2 to the camera driving module.
S134, the camera driving module sends FD2 to the IFE node.
S135, the IFE node sends FD2 to the camera service through the interface of the camera HAL.
S136, the camera service sends the FD2 to the face recognition control module.
S137, the face recognition control module sends the FD2 to the face recognition TA.
S138, the frame management module of the face recognition TA reads RAW Data 2 from the secure memory according to the FD 2.
S139a, the frame management module sends RAW Data 2 to the TOF algorithm module.
And S139b, the TOF algorithm module obtains a gray scale image (a first gray scale image), a depth image (a first depth image) and the exposure time (T1) of the next frame according to the RAW Data 2.
The TOF algorithm module may calculate RAW Data 2 according to ITOF algorithm to obtain the next frame exposure time (T1). The next frame exposure time may include an IR gray map exposure time (e.g., 750 us) and a depth map exposure time (e.g., 1200 us).
The TOF algorithm module may obtain the operation mode of the TOF camera from Metadata in RAW Data 2, for example, may be a face ID mode. Then, the face recognition TA may process the second image Data in RAW Data 2 through the TOF algorithm to obtain a first gray scale map and a first depth map.
On the one hand, after the TOF algorithm module obtains the gray scale map and the depth map according to RAW Data2, steps S139c-S139f may be performed.
On the other hand, after the TOF algorithm module obtains the next frame exposure time (T1) according to RAW Data2, steps S140a-S141k may be performed.
And S139c, the TOF algorithm module sends the gray level map and the depth map to the face ID algorithm module.
S139d, the face ID algorithm module obtains a face recognition result according to the gray level map and the depth map.
The face ID algorithm module can perform face recognition based on the gray level map (first depth map) and based on the depth map (second depth map) and anti-fake detection, so that a face recognition result is obtained.
It should be noted that, the gray level map and the depth map converted from the face information input by the user before can be stored in the face ID algorithm module. If the currently acquired face information (RAW Data acquired by the TOF camera based on the face ID mode, namely RAW Data 2) is matched with the gray map corresponding to the previously input face information (namely RAW Data acquired by the electronic device when the user performs the face input operation), the currently acquired face information can be considered as the same user (namely, the same user performs the face input operation and the unlocking operation), and if the currently acquired face information comprises depth information, the currently acquired face information can be considered as authentic (disguised such as non-photograph and video), and at the moment, the face safety of the currently user can be considered, namely, the face recognition result is successful. If the gray level map corresponding to the currently acquired face information (RAW Data acquired by the TOF camera based on the face ID mode, namely RAW Data 2) and the previously input face information (namely RAW Data acquired by the electronic equipment when the user performs face input operation) is not matched, or if the currently acquired face information does not comprise depth information, the face of the current user is considered unsafe, namely the face recognition result is failed.
If the face recognition fails, the face recognition TA can acquire the RAW DATA of the TOF camera module after the exposure time is adjusted, and continue to perform face recognition according to the RAW DATA until the unlocking is successful or the unlocking is overtime and exits from unlocking.
S139e, the face ID algorithm module sends the face recognition result to the frame management module.
And S139f, the frame management module sends the face recognition result to the face recognition control module.
The face recognition control module receives the face recognition result, and if the face recognition result is safe/normal (or the face recognition is successful), steps 143-147 may be performed. I.e. the electronic device may be successfully unlocked.
If the face recognition result is failure, the face recognition control module may continue to obtain a new face recognition result (e.g., step 143 below) from the face recognition TA until the face recognition is successful before the unlocking time is out (e.g., the unlocking time is 3 s). After the unlocking timeout, if the face recognition is still unsuccessful, the face recognition control module may transfer the face recognition result (failure) to the face recognition service based on the callback of the previous face recognition service registration (in S103). The face recognition service passes the face recognition result (failure) to the face recognition SDK based on the callback of the previous (in S102) face recognition SDK registration. The face recognition SDK passes the face recognition result (failure) to the lock screen application based on the callback registered by the previous lock screen application (in S101). The screen locking application can decide not to unlock according to the face recognition result (failure).
As shown in fig. 6B, the method further includes:
s140a, the TOF algorithm module sends the next frame exposure time (T1) to the frame management module.
And S140b, the frame management module sends the exposure time of the next frame to the face recognition control module (T1).
The TOF algorithm module can directly transmit the exposure time of the next frame back to the face recognition control module through the frame management module. Therefore, the condition that the exposure time of the next frame calculated by the TOF algorithm module is transmitted back to the face recognition control module after passing through the face ID algorithm module to cause exposure time transmission lag can be avoided, and the exposure time transmission efficiency can be improved. Furthermore, the TOF camera module can shoot as soon as possible according to the updated exposure time, so that the situation of overexposure and underexposure of an image shot by the TOF camera is avoided, and the electronic equipment can unlock the face as soon as possible.
And S140c, the face recognition control module sends the exposure time of the next frame to the camera HAL.
In one possible design, the face recognition control module may send the next frame exposure time to the camera HAL through the camera service. That is, the face recognition control module may send the next frame exposure time to the camera service, which in turn sends the next frame exposure time to the camera HAL.
In another possible design, the face recognition control module may pass the next frame exposure time directly to the camera HAL through a HAL interface definition language (HAL interface definition language, HIDL) interface. For example, the face recognition control module may call a first function (e.g., setcaecdatas function in camcfgserver) to write the next frame exposure time to the camera HAL. The camera HAL can redetermine the exposure value corresponding to the TOF camera module according to the exposure time of the next frame. Wherein the redetermined exposure value is different from the default exposure value of the face ID mode.
And S140d, the sensor node of the camera HAL receives a next frame request from the camera service, calls a second function to read the exposure time of the next frame, and obtains an exposure value according to the exposure time of the next frame.
It will be appreciated that when the camera service determines that image Data (e.g., RAW Data 2) in secure memory is read (consumed), a next frame request may be sent to the camera HAL to request acquisition of the next frame of image Data.
When the sensor node of the camera HAL receives a next frame request from the camera service, the sensor node may call a first function (e.g., the getitofecdata function in the exechamp-processrequest) to read the next frame exposure time for the face recognition control module to write to the camera HAL. The sensor node may also process the exposure time of the next frame through a third function (e.g., calcitoff register aecdata function) to obtain an exposure value (t 1) corresponding to the TOF sensor exposure register. The exposure value (t 1) includes a value corresponding to the IR grayscale image exposure register and a value corresponding to the depth image exposure register. For example, the address of the IR grayscale exposure register and its corresponding value may be: 0x2129,0x01;0x212a,0x5f;0x212b 0x90; the address of the depth map exposure register and the corresponding value thereof can be 0x2125,0x02;0x2126,0x32;0x2127,0x80.
In addition, if the sensor node does not acquire the exposure time of the next frame (i.e., the sensor node calls the getitofecdata function to not read the exposure time of the next frame written into the camera HAL by the face recognition control module), the sensor node does not need to issue the exposure value corresponding to the exposure register of the TOF camera to the camera driving module (i.e., the exposure value corresponding to the exposure register of the TOF camera is not reconfigured), and the TOF camera still adopts the default exposure value. If the exposure time of the next frame acquired by the sensor node continuously twice is the same, the exposure value corresponding to the exposure register of the TOF camera does not need to be repeatedly issued to the camera driving module (namely, the exposure value corresponding to the exposure register of the TOF camera does not need to be repeatedly configured).
And S140e, the sensor node sends the exposure value to the camera driving module.
And S140f, the camera driving module writes the exposure value into a register of the TOF camera to drive the TOF camera to collect data based on the exposure value.
That is, the camera drive module may send exposure values to the TOF camera.
Illustratively, the camera drive module may write the exposure value into the TOF camera register via I2C. That is, the camera driving module may send exposure values to the TOF camera through the I2C.
S140g, the TOF camera acquires RAW Data3 based on the exposure value.
The RAW Data3 may be image Data obtained when the TOF camera works with the next frame exposure time (corresponding exposure value). When the TOF camera operates with the next frame exposure time (corresponding exposure value), rx may be exposed according to the next frame exposure time, and the lighting time of TX is also determined according to the next frame exposure time. Rx may configure the lighting time to Tx through a synchronization signal (sync signal).
The TOF camera still operates in face ID mode, and Tx may operate at a second current value, and the light signal emitted by the TOF camera is a second light intensity. The second light intensity is greater than the first light intensity.
Wherein, RAW Data3 contains Metadata. Illustratively, metadata stores information such as the current TOF camera operating mode (e.g., face ID mode), the lighting current value (e.g., 2800 mA), the TOF camera device operating state (e.g., normal), the IR grayscale exposure time (e.g., 750 us), and the depth map exposure time (e.g., 1200 us).
And S140h, the TOF camera sends RAW Data3 to the IFE module.
Illustratively, the TOF camera may transmit RAW Data3 acquired by the TOF camera based on the face ID mode to the IFE module via MIPI.
S140i, the IFE module sends the RAW Data 3 to the secure memory for storage.
The storage position of RAW Data 3 acquired by the TOF camera based on the face ID mode in the secure memory may be represented by FD 3.
FD3 in this step may be the same as or different from FD1 in S117. When FD3 in this step is the same as FD1 in S117, that is, RAW Data 3 collected by the TOF camera based on the face ID mode and RAW Data 1 collected by the TOF camera based on the eye security mode in S117 are stored in the same secure memory. The RAW Data 1 collected by the TOF camera based on the human eye security mode in S117 may be deleted, so that the RAW Data 3 collected by the TOF camera based on the human face ID mode may be restored to the security memory. In the case where FD3 is different from FD1, RAW Data 3 collected by the TOF camera based on the face ID mode and RAW Data 1 collected by the TOF camera based on the eye safety mode in S117 may be stored in different safety memories.
And S141a, the IFE module sends the FD3 to the camera driving module.
And S141b, the camera driving module sends the FD3 to the IFE node.
S141c, IFE node sends FD3 to camera service through interface of camera HAL.
S141d, the camera service transmits FD3 to the face recognition control module.
S141e, the face recognition control module sends FD3 to the face recognition TA.
S141f, the frame management module of the face recognition TA reads RAW Data3 from the secure memory according to the FD 3.
S141g, the frame management module determines that the exposure time in RAW DATA3 is the same as the exposure time of the expected configuration.
After the frame management module obtains the nth frame (N is greater than or equal to 2) image DATA (e.g., RAW DATA 3) of the TOF camera module operating in the face ID mode, it may determine whether the exposure time in RAW DATA3 is the same as the exposure time of the expected configuration (e.g., the exposure time of the next frame calculated by the TOF algorithm module according to RAW DATA 2).
If the two frames are the same, the RAW DATA3 is sent to the TOF algorithm module to calculate a gray level map and a depth map and calculate the exposure time of the next frame. If the frames are different, the frames are lost (namely the RAW DATA3 is discarded), so that the problem that the face recognition time is consumed (the unlocking efficiency is reduced) because invalid frames are repeatedly sent into the TOF algorithm module and the face ID algorithm module to be calculated is avoided. In addition, after the continuous frame loss reaches the preset threshold, the frame loss can be avoided, and the problem that the algorithm cannot continue to run due to the continuous frame loss is avoided.
S141h, the frame management module sends RAW Data3 to the TOF algorithm module.
And S141i, the TOF algorithm module obtains a gray level map (a second gray level map) and a depth map (a second depth map) according to the RAW Data 3.
Specifically, the face recognition TA may acquire the working mode of the TOF camera from Metadata in RAW Data 3, for example, may be a face ID mode. Then, the face recognition TA can process the image Data in RAW Data 3 through the TOF algorithm to obtain a gray scale map and a depth map.
The TOF algorithm module may also derive the next frame exposure time (T2, the same or different from T1) from RAW Data 3. The transmission process of T2 may refer to the related descriptions of steps S140a-S140d, which are not described herein.
S141j, the TOF algorithm module sends the gray level map and the depth map to the face ID algorithm module.
S141k, a face ID algorithm module obtains a face recognition result according to the gray level map and the depth map.
The face ID algorithm module can perform face recognition based on the gray level map (second gray level map) and based on the depth map (second depth map) and anti-fake detection, so that a face recognition result is obtained. Reference may be made specifically to step 139d, which is not described herein.
S142, the face ID algorithm module sends the face recognition result to the frame management module.
S143, the frame management module sends the face recognition result to the face recognition control module.
S144, the face recognition control module sends the face recognition result to the face recognition service.
The face recognition control module may pass the face recognition result (success or failure) to the face recognition service based on the callback of the previous (in S103) face recognition service registration.
S145, the face recognition service transmits the face recognition result to the face recognition SDK.
The face recognition service passes the face recognition result (success or failure) to the face recognition SDK based on the callback of the previous (in S102) face recognition SDK registration.
S146, the face recognition SDK transmits the face recognition result to the screen locking application.
The face recognition SDK passes the face recognition result (success or failure) to the lock screen application based on the callback registered by the previous lock screen application (in S101).
And S147, the screen locking application decides whether to unlock according to the face recognition result.
If the face recognition result is successful, the screen locking application can be successfully unlocked, so that the electronic equipment can display a desktop or an interface of an application (a system application or a third party application). If the face recognition result is failure, the screen locking application is not unlocked, namely the face unlocking fails. After the face unlocking fails, the screen locking application may disable the face recognition function for a period of time (e.g., 5 minutes) when the face recognition fails.
For example, if the user sets face unlocking, as shown in (a) of fig. 7, when the user picks up the mobile phone to perform face recognition, in response to the operation of picking up the mobile phone, as shown in (b) of fig. 7, the mobile phone may display a lock screen interface 701, and in the process of performing face recognition, the mobile phone may display an unlocking icon 702 and a prompt word "face being recognized" 703 on the lock screen interface 701.
If the face recognition is successful, as shown in (a) of fig. 8, an interface 704 may be displayed, and the interface 704 may include an unlock icon 705 (in an open state, which may visually prompt the user that the face is successfully unlocked) and a prompt word "slide up" 706, and in response to the user's slide up operation, the mobile phone may display an interface of a desktop or an application (a system application or a third party application). Alternatively, as shown in fig. 8 (b), if the face recognition is successful, the mobile phone can be directly unlocked without additional operation of the user, and the desktop 707 (or the interface of the application) can be immediately displayed.
If the face recognition fails, as shown in (a) of fig. 9, an interface 708 may be displayed, and the interface 708 may include an unlock icon 709 (in a closed state, which may visually indicate that the face of the user is not successfully unlocked) and a prompt text "not successfully identified," a double-click screen retry "710, and in response to the double-click operation of the user, the mobile phone may perform the face recognition again (i.e. acquire the face information of the user again for comparison and anti-counterfeiting judgment). Alternatively, in response to a user sliding up in the interface 708, as shown in fig. 9 (b), the mobile phone may display an interface 711, enter the interface 711, and then the mobile phone may perform face recognition again, and the interface 711 may include a face recognition icon 712 and a prompt word "face recognition in progress" 713. If the recognition is still unsuccessful, as shown in (c) in fig. 9, the mobile phone may display an interface 714, where the interface 714 may include a prompt text "not recognized successfully", click on the retry here "715, and the user may click on the corresponding position to trigger the face recognition again, or may input a password through the soft keyboard 716 to unlock, so as to avoid the problem that the user experience is low because the user cannot recognize successfully all the time.
It should be noted that, in the above embodiment, the operation mode selection of the TOF camera is described by taking the method flow of face unlocking performed by the screen locking application as an example, the operation mode selection of the TOF camera may also be applied to payment or transfer (for example, the user performs a payment application/financial application/chat application/shopping application (for example,) In which payment or transfer operations are performed), face recognition of the user at a secure registration or face security verification of the login application (e.g., the user at +.>In a registration or login operation), and the like, the present application is not limited. The screen locking application can be replaced by a shopping application, a chat application, a payment application, a banking application or a financial application, and the like, and the application is not limited.
The following description will take an example that the operation mode of the TOF camera determined by the sensor node is Tx off mode, as shown in fig. 10, after S127, S150-S167 are further included:
and S150, determining that the working mode of the TOF camera is a Tx closing mode by the sensor node of the camera HAL based on the eye safety detection result.
And S151, the sensor node sends the configuration parameters of the Tx closing mode to the camera driving module.
And S152, the camera driving module writes (updates) configuration parameters of the Tx closing mode into a register of the TOF camera so as to drive the TOF camera to acquire data.
That is, the camera driving module may send configuration parameters of the Tx off mode to the TOF camera.
Illustratively, the camera drive module may write configuration parameters of the Tx off mode into the TOF camera register via I2C. I.e. send configuration parameters of Tx off mode to the TOF camera over I2C.
S153, the TOF camera acquires RAW DATA4 based on a Tx closing mode.
The RAW DATA4 may be image DATA obtained by receiving reflected light (no emitted light or ambient emitted light) and imaging when Tx of the TOF camera is not energized and does not emit light, and is generally a "black image" of a clear face image.
Wherein, metadata is contained in RAW DATA 4. Illustratively, metadata stores information of the current TOF camera operation mode (e.g., tx off mode), the magnitude of the lighting current value (e.g., 0 mA), the TOF camera device operation state (e.g., anomaly), and the map exposure time (e.g., 10 μs).
S154, the TOF camera transmits the RAW DATA4 to the IFE module.
Illustratively, the TOF camera may transmit RAW DATA4 acquired by the TOF camera to the IFE module via MIPI.
S155, the IFE module sends the RAW DATA4 to the secure memory for storage.
The storage location of RAW DATA4 acquired by the TOF camera based on Tx off mode in the secure memory may be represented using FD 4.
FD4 in this step may be the same as or different from FD1 in S117. When FD4 in this step is the same as FD1 in S117, that is, RAW DATA 4 collected by the TOF camera based on Tx off mode and RAW DATA 1 collected by the TOF camera based on eye safety mode in S117 are stored in the same secure memory. The RAW Data 1 collected by the TOF camera based on the human eye security mode in S117 may be deleted, so that the RAW Data 4 collected by the TOF camera based on the Tx shutdown mode may be restored to the security memory. In the case where FD4 is different from FD1, RAW DATA 4 acquired by the TOF camera based on Tx off mode and RAW DATA 1 acquired by the TOF camera based on eye safety mode in S117 may be stored in different safety memories.
And S156, the IFE module sends the FD4 to the camera driving module.
And S157, the camera driving module sends the FD4 to the IFE node.
S158, the IFE node sends FD4 to the camera service through the interface of the camera HAL.
S159, the camera service transmits FD4 to the face recognition control module.
S160, the face recognition control module sends the FD4 to the face recognition TA.
S161, reading RAW DATA 4 from the secure memory according to FD4 by the face recognition TA.
S162, the face recognition TA obtains a face recognition result according to the RAW DATA 4.
Specifically, the face recognition TA may acquire Metadata DATA in RAW DATA 4 acquired by the TOF camera based on the Tx shutdown mode, then obtain a third gray scale image and a third depth image based on image DATA in RAW DATA 4 through the TOF algorithm, perform face recognition based on the third gray scale image through the face ID algorithm, and perform anti-counterfeiting detection based on the third depth image to obtain a face recognition result.
It should be noted that, when the TOF camera operates in the Tx off mode, the face recognition result is failure. The TOF camera cannot emit light in the Tx off mode, so the TOF camera cannot acquire a clear face image, and even if the currently unlocked user is an authenticated user (i.e., a machine owner), the face recognition result still fails.
S163, the face recognition TA transmits the face recognition result (failure) to the face recognition control module.
I.e. the face recognition TA may inform the face recognition control module that the face recognition result is failure.
S164, the face recognition control module transmits the face recognition result (failure) to the face recognition service.
The face recognition control module transmits the face recognition result (failure) to the face recognition service based on the callback of the previous face recognition service registration. Namely, the face recognition control module informs the face recognition service that the face recognition result is failure.
S165, the face recognition service transmits the face recognition result (failure) to the face recognition SDK.
The face recognition service passes the face recognition result (failure) to the face recognition SDK based on the callback of the previous face recognition SDK registration. That is, the face recognition service may notify the face recognition SDK that the face recognition result is failure.
S166, the face recognition SDK transmits the face recognition result (failure) to the screen locking application.
The face recognition SDK passes the face recognition result (failure) to the lock screen application based on the callback registered by the previous lock screen application. That is, the face recognition SDK may notify the lock screen that the face recognition result of the application of face recognition is failure.
And S167, the screen locking application decides not to unlock according to the face recognition result (failure).
Because the face recognition result is failure, the screen locking application is not unlocked.
For example, if the face recognition fails, as shown in (a) of fig. 9, an interface 708 may be displayed, and the interface 708 may include an unlock icon 709 (in a closed state, which may visually indicate that the face of the user is not successfully unlocked) and a prompt text "not successfully identified," a double-click screen retry "710, and in response to the double-click operation of the user, the mobile phone may perform the face recognition again (i.e. acquire the face information of the user again for comparison and anti-counterfeit judgment). Or, in response to the user sliding up in the interface 708, the mobile phone may display the interface 711, after entering the interface 711, the mobile phone may perform face recognition again, the interface 711 may include a face recognition icon 712 and a prompt text "face recognition in progress" 713, if the user still fails to recognize the user, the mobile phone may display the interface 714, the interface 714 may include a prompt text "fail to recognize the user, click the retry here" 715, the user may click the corresponding location to re-trigger the face recognition, or may also input a password through the soft keyboard 716 to perform unlocking, so as to avoid the problem that the user experience is low because the user cannot recognize the user successfully.
Some embodiments of the present application provide an electronic device that may include: a touch screen, a memory, and one or more processors. The touch screen, memory, and processor are coupled. The memory is for storing computer program code, the computer program code comprising computer instructions. When the processor executes the computer instructions, the electronic device may perform the various functions or steps performed by the electronic device in the method embodiments described above. The structure of the electronic device may refer to the structure of the electronic device 100 shown in fig. 1.
Embodiments of the present application also provide a system-on-a-chip (SoC) including at least one processor 1101 and at least one interface circuit 1102, as shown in fig. 11. The processor 1101 and interface circuit 1102 may be interconnected by wires. For example, interface circuit 1102 may be used to receive signals from other devices (e.g., a memory of an electronic apparatus). For another example, the interface circuit 1102 may be used to send signals to other devices (e.g., the processor 1101 or a touch screen of an electronic device). The interface circuit 1102 may, for example, read instructions stored in a memory and send the instructions to the processor 1101. The instructions, when executed by the processor 1101, may cause the electronic device to perform the various steps of the embodiments described above. Of course, the chip system may also include other discrete devices, which are not specifically limited in this embodiment of the present application.
The embodiment of the application also provides a TOF camera, which can be used for realizing the eye safety mode, the face ID mode, the TX closing mode and the like in the embodiment, and the electronic equipment provided with the TOF camera can execute the functions or steps executed by the electronic equipment in the embodiment of the method.
Embodiments of the present application also provide a computer readable storage medium, where the computer readable storage medium includes computer instructions, which when executed on an electronic device, cause the electronic device to perform the functions or steps performed by the electronic device in the method embodiments described above.
Embodiments of the present application also provide a computer program product that, when run on an electronic device, causes the electronic device to perform the functions or steps performed by the electronic device in the method embodiments described above.
It will be apparent to those skilled in the art from this description that, for convenience and brevity of description, only the above-described division of the functional modules is illustrated, and in practical application, the above-described functional allocation may be performed by different functional modules according to needs, i.e. the internal structure of the apparatus is divided into different functional modules to perform all or part of the functions described above.
In the several embodiments provided in this application, it should be understood that the disclosed apparatus and method may be implemented in other ways. For example, the apparatus embodiments described above are merely illustrative, e.g., the division of the modules or units is merely a logical functional division, and there may be additional divisions when actually implemented, e.g., multiple units or components may be combined or integrated into another apparatus, or some features may be omitted, or not performed. Alternatively, the coupling or direct coupling or communication connection shown or discussed with each other may be an indirect coupling or communication connection via some interfaces, devices or units, which may be in electrical, mechanical or other form.
The units described as separate parts may or may not be physically separate, and the parts displayed as units may be one physical unit or a plurality of physical units, may be located in one place, or may be distributed in a plurality of different places. Some or all of the units may be selected according to actual needs to achieve the purpose of the solution of this embodiment.
In addition, each functional unit in each embodiment of the present application may be integrated in one processing unit, or each unit may exist alone physically, or two or more units may be integrated in one unit. The integrated units may be implemented in hardware or in software functional units.
The integrated units, if implemented in the form of software functional units and sold or used as stand-alone products, may be stored in a readable storage medium. Based on such understanding, the technical solution of the embodiments of the present application may be essentially or a part contributing to the prior art or all or part of the technical solution may be embodied in the form of a software product stored in a storage medium, including several instructions for causing a device (may be a single-chip microcomputer, a chip or the like) or a processor (processor) to perform all or part of the steps of the methods described in the embodiments of the present application. And the aforementioned storage medium includes: a U-disk, a removable hard disk, a Read Only Memory (ROM), a random access memory (random access memory, RAM), a magnetic disk, or an optical disk, or other various media capable of storing program codes.
The foregoing is merely a specific embodiment of the present application, but the scope of the present application is not limited thereto, and any changes or substitutions within the technical scope of the present disclosure should be covered in the scope of the present application. Therefore, the protection scope of the present application shall be subject to the protection scope of the claims.
Claims (16)
1. The face recognition method is applied to electronic equipment, wherein the electronic equipment comprises a time-of-flight TOF camera module, and is characterized by comprising the following steps:
controlling the TOF camera module to acquire a first image frame based on a first exposure time;
determining a second exposure time from the first image frame, the second exposure time being different from the first exposure time;
and controlling the TOF camera module to acquire a second image frame based on the second exposure time.
2. The method of claim 1, wherein the electronic device comprises a face recognition control module, a camera service, a camera hardware abstraction layer HAL, a camera driver module, and a face recognition trusted application TA, the face recognition TA comprising a frame management module, a TOF algorithm module, and a face identification ID algorithm module, the camera HAL comprising a sensor node, the controlling the TOF camera module to acquire a second image frame based on the second exposure time comprising:
the TOF algorithm module calculates the second exposure time according to the first image frame;
the TOF algorithm module sends the second exposure time to the frame management module;
the frame management module sends the second exposure time to the face recognition control module;
The face recognition control module calls a first function through a hardware abstraction layer interface definition language (HIDL) interface to write the second exposure time into the camera HAL;
the sensor node in the camera HAL calls a second function to read the second exposure time;
the sensor node calls a third function to process the second exposure time to obtain an exposure value corresponding to an exposure register of the TOF camera module;
the sensor node sends an exposure value corresponding to an exposure register of the TOF camera module to the camera driving module;
the camera driving module writes the exposure value into an exposure register of the TOF camera module;
and the TOF camera module acquires the second image frame according to the exposure value in the exposure register.
3. The method of claim 2, wherein the controlling the TOF camera module is prior to acquiring a first image frame based on a first exposure time, the method further comprising:
receiving a first operation of a user, wherein the first operation is used for triggering face recognition;
after the controlling the TOF camera module to acquire a second image frame based on the second exposure time, the method further includes:
And performing face recognition based on the second image frame.
4. A method according to claim 3, wherein said performing face recognition based on said second image frame comprises:
the frame management module acquires the second image frame;
the frame management module determines that the exposure time corresponding to the second image frame is the same as the second exposure time;
the frame management module sends the second image frame to the TOF algorithm module;
the TOF algorithm module calculates a gray level map and a depth map according to the second image frame;
the TOF algorithm module sends the gray level map and the depth map to the face ID algorithm module;
and the face ID algorithm module performs face comparison based on the gray level map, and performs anti-counterfeiting detection based on the depth map to obtain a face recognition result.
5. The method according to claim 3 or 4, characterized in that the method further comprises:
and if the frame management module determines that the exposure time corresponding to the second image frame is different from the second exposure time, discarding the second image frame by the frame management module.
6. The method of claim 1, wherein the electronic device comprises a face recognition control module, a camera service, a camera hardware abstraction layer HAL, a camera driver module, and a face recognition trusted application TA, the face recognition TA comprising a frame management module, a TOF algorithm module, and a face identification ID algorithm module, the camera HAL comprising a sensor node, the controlling the TOF camera module to acquire a second image frame based on the second exposure time comprising:
The TOF algorithm module calculates the second exposure time according to the first image frame;
the TOF algorithm module sends the second exposure time to the frame management module;
the frame management module sends the second exposure time to the face recognition control module;
the face recognition control module sends the second exposure time to the camera service;
the camera service sending the second exposure time to the camera HAL;
the sensor node in the camera HAL obtains an exposure value corresponding to an exposure register of the TOF camera module according to the second exposure time;
the sensor node sends an exposure value corresponding to an exposure register of the TOF camera module to the camera driving module;
the camera driving module writes the exposure value into an exposure register of the TOF camera module;
and the TOF camera module acquires the second image frame according to the exposure value in the exposure register.
7. The method of claim 1, wherein the electronic device comprises a face recognition control module, a camera hardware abstraction layer HAL, a camera driver module, and a face recognition trusted application TA, the face recognition TA comprising a frame management module, a TOF algorithm module, and a face identification ID algorithm module, the camera HAL comprising a sensor node, the controlling the TOF camera module to acquire a second image frame based on the second exposure time comprising:
The TOF algorithm module calculates the second exposure time according to the first image frame;
the TOF algorithm module sends the second exposure time to the face ID algorithm module;
the face ID algorithm module sends the second exposure time to the frame management module;
the frame management module sends the second exposure time to the face recognition control module;
the face recognition control module calls a first function through a hardware abstraction layer interface definition language (HIDL) interface to write the second exposure time into the camera HAL;
the sensor node in the camera HAL calls a second function to read the second exposure time;
the sensor node calls a third function to process the second exposure time to obtain an exposure value corresponding to an exposure register of the TOF camera module;
the sensor node sends an exposure value corresponding to an exposure register of the TOF camera module to the camera driving module;
the camera driving module writes the exposure value into an exposure register of the TOF camera module;
and the TOF camera module acquires the second image frame according to the exposure value in the exposure register.
8. The method of claim 1, wherein the electronic device comprises a face recognition control module, a camera service, a camera hardware abstraction layer HAL, a camera driver module, and a face recognition trusted application TA, the face recognition TA comprising a frame management module, a TOF algorithm module, and a face identification ID algorithm module, the camera HAL comprising a sensor node, the controlling the TOF camera module to acquire a second image frame based on the second exposure time comprising:
the TOF algorithm module calculates the second exposure time according to the first image frame;
the TOF algorithm module sends the second exposure time to the frame management module;
the frame management module sends the second exposure time to the face recognition control module;
the face recognition control module calls a first function through an HIDL interface to write the second exposure time into the camera HAL;
the sensor node in the camera HAL calls a second function to read the second exposure time;
the sensor node calls a third function to process the second exposure time to obtain an exposure value corresponding to an exposure register of the TOF camera module;
The sensor node sends an exposure value corresponding to an exposure register of the TOF camera module to the camera driving module;
the camera driving module writes the exposure value into an exposure register of the TOF camera module;
and the TOF camera module acquires the second image frame according to the exposure value in the exposure register.
9. The method according to any one of claims 1 to 8, wherein,
the first exposure time comprises a first gray scale image exposure time and a first depth image exposure time;
the second exposure time comprises a second gray scale image exposure time and a second depth image exposure time;
the second gray scale map exposure time is different from the first gray scale map exposure time and/or the second depth map exposure time is different from the first depth map exposure time.
10. The method of any of claims 1-9, wherein the TOF camera module includes an emitter for emitting light signals and an image sensor for receiving reflected light and imaging, the method further comprising, prior to controlling the TOF camera module to acquire a first image frame based on a first exposure time:
Controlling the transmitter to operate at a first light intensity;
determining whether the transmitter is in a normal working state;
and under the condition that the transmitter is in a normal working state, controlling the transmitter to work at a second light intensity, wherein the second light intensity is larger than the first light intensity.
11. The method of claim 10, wherein the step of determining the position of the first electrode is performed,
the light signal emitted by the emitter when working at a first current value is the first light intensity, the light signal emitted by the emitter when working at a second current value is the second light intensity, and the second current value is larger than the first current value.
12. The method of any of claims 1-11, wherein the performing the face recognition based on the second image frame comprises:
acquiring a second gray level map and a second depth map based on the second image frame;
and comparing the faces based on the second gray level image, and performing anti-counterfeiting detection based on the second depth image to obtain a face recognition result.
13. The method according to any one of claims 1-12, further comprising:
and performing face recognition failure based on the first image frame.
14. The method according to any one of claims 1 to 13, wherein,
the first operation includes an operation for unlocking the electronic device, an operation for online payment, an operation for entering a face, or an operation for securely registering or logging in an application.
15. An electronic device, the electronic device comprising: a wireless communication module, a memory, and one or more processors; the wireless communication module, the memory, and the processor are coupled;
wherein the memory is for storing computer program code, the computer program code comprising computer instructions; the computer instructions, when executed by the processor, cause the electronic device to perform the method of any of claims 1-14.
16. A computer-readable storage medium comprising computer instructions;
the computer instructions, when run on an electronic device, cause the electronic device to perform the method of any one of claims 1-14.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310936377.7A CN117292418A (en) | 2022-03-25 | 2022-03-25 | Face recognition method and device |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310936377.7A CN117292418A (en) | 2022-03-25 | 2022-03-25 | Face recognition method and device |
CN202210307908.1A CN114863510B (en) | 2022-03-25 | 2022-03-25 | Face recognition method and device |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210307908.1A Division CN114863510B (en) | 2022-03-25 | 2022-03-25 | Face recognition method and device |
Publications (1)
Publication Number | Publication Date |
---|---|
CN117292418A true CN117292418A (en) | 2023-12-26 |
Family
ID=82628922
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210307908.1A Active CN114863510B (en) | 2022-03-25 | 2022-03-25 | Face recognition method and device |
CN202310936377.7A Pending CN117292418A (en) | 2022-03-25 | 2022-03-25 | Face recognition method and device |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210307908.1A Active CN114863510B (en) | 2022-03-25 | 2022-03-25 | Face recognition method and device |
Country Status (1)
Country | Link |
---|---|
CN (2) | CN114863510B (en) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116704571B (en) * | 2022-09-30 | 2024-09-24 | 荣耀终端有限公司 | Face recognition method, electronic device and readable storage medium |
CN116257139B (en) * | 2023-02-27 | 2023-12-22 | 荣耀终端有限公司 | Eye movement tracking method and electronic equipment |
CN116996762B (en) * | 2023-03-29 | 2024-04-16 | 荣耀终端有限公司 | Automatic exposure method, electronic equipment and computer readable storage medium |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109819174B (en) * | 2017-11-22 | 2021-07-13 | 浙江舜宇智能光学技术有限公司 | Automatic exposure method based on TOF imaging system, automatic exposure time calculation method and TOF camera |
CN108288044B (en) * | 2018-01-31 | 2020-11-20 | Oppo广东移动通信有限公司 | Electronic device, face recognition method and related product |
CN110248111B (en) * | 2018-04-28 | 2020-08-28 | Oppo广东移动通信有限公司 | Method and device for controlling shooting, electronic equipment and computer-readable storage medium |
CN112639801A (en) * | 2018-08-28 | 2021-04-09 | 华为技术有限公司 | Face recognition method and device |
WO2020243967A1 (en) * | 2019-06-06 | 2020-12-10 | 深圳市汇顶科技股份有限公司 | Face recognition method and apparatus, and electronic device |
CN112446252A (en) * | 2019-08-30 | 2021-03-05 | 华为技术有限公司 | Image recognition method and electronic equipment |
CN110784592A (en) * | 2019-09-29 | 2020-02-11 | 华为技术有限公司 | Biological identification method and electronic equipment |
KR20210101049A (en) * | 2020-02-07 | 2021-08-18 | 삼성전자주식회사 | The electronic device and the method for recognizing the object |
CN113497880A (en) * | 2020-03-20 | 2021-10-12 | 华为技术有限公司 | Method for shooting image and electronic equipment |
CN113807172B (en) * | 2021-08-11 | 2022-10-18 | 荣耀终端有限公司 | Face recognition method and device |
CN113779588B (en) * | 2021-08-12 | 2023-03-24 | 荣耀终端有限公司 | Face recognition method and device |
CN114120431B (en) * | 2022-01-27 | 2022-06-28 | 荣耀终端有限公司 | Face recognition method, medium and electronic equipment |
-
2022
- 2022-03-25 CN CN202210307908.1A patent/CN114863510B/en active Active
- 2022-03-25 CN CN202310936377.7A patent/CN117292418A/en active Pending
Also Published As
Publication number | Publication date |
---|---|
CN114863510B (en) | 2023-08-01 |
CN114863510A (en) | 2022-08-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN115937922B (en) | Face recognition method and device | |
CN114863510B (en) | Face recognition method and device | |
CN114531541B (en) | Control method and device for camera module | |
WO2020088290A1 (en) | Method for obtaining depth information and electronic device | |
CN114095666B (en) | Photographing method, electronic device, and computer-readable storage medium | |
US20230262065A1 (en) | Atomic Ability Invoking Method and Terminal Device | |
EP4361954A1 (en) | Object reconstruction method and related device | |
CN114726950A (en) | Opening method and device of camera module | |
CN116074634B (en) | Exposure parameter determination method and device | |
CN115309547B (en) | Method and device for processing asynchronous binder call | |
CN112087649B (en) | Equipment searching method and electronic equipment | |
WO2021057626A1 (en) | Image processing method, apparatus, device, and computer storage medium | |
CN114283195B (en) | Method for generating dynamic image, electronic device and readable storage medium | |
CN116704571B (en) | Face recognition method, electronic device and readable storage medium | |
CN116074623B (en) | Resolution selecting method and device for camera | |
CN115686182B (en) | Processing method of augmented reality video and electronic equipment | |
CN115705726A (en) | Face recognition method and device | |
CN116486500B (en) | Mail sending method and electronic equipment | |
CN115705749A (en) | Face recognition method and device | |
CN116703692B (en) | Shooting performance optimization method and device | |
CN116033341B (en) | Method and device for triggering fence event | |
CN116704572B (en) | Eye movement tracking method and device based on depth camera | |
CN116684517B (en) | Method and device for sending response message | |
CN115002939B (en) | Method and device for joining WiFi group | |
CN116781718A (en) | Data transmission method, electronic equipment and device |
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 |