Documentation for Face Intellect 8.0-8.1. Documentation for other versions of Intellect is available too.
General information about scripts
Custom scripts are used for partial automation of processes when configuring Face Intellect. In the Programming Guide document there is the description of programming objects and methods which are used for scripts creation in Intellect.
Script for faces verification
The verification mode compares the face captured in the frame with the user photo stored on the disk at <Intellect installation folder>\Bmp\<Person>. It also determines the face parameters: emotions, temperature, face concealment (mask), gender, facial hair.
To perform face verification, do the following:
Create the script:
if(Event.SourceType == "MACRO" && Event.Action == "RUN" && Event.SourceID == "1") { DoReactStr("FIRSERVER","1","VERIFY_START","cam_id<1>,p_id<15>,wait<10>"); }
Parameters:
- 1—the identifier of the Face Recognition Server object;
- VERIFY_START—user verification command;
- cam_id<1>—camera identifier. If you use the VisionLabs face recognition module, instead of the camera identifier, specify the identifier of the Face detection object;
- p_id<15>—the name of the file with a photo in the <Intellect installation folder>\Bmp\<Person> folder without resolution (for example, 15 for the 15.bmp file);
- wait<10>—the waiting time in seconds for the face to appear.
Run the first macro. If the user from the photo does not appear in front of the camera in 10 seconds, the Verification declined event will be displayed. In case the user appears, the Successful verification event will be displayed immediately showing the similarity percentage of the captured face with the user photo stored on the disk.
Example of an event when a photo doesn't match the face being verified:Event : FIRSERVER|1|IDENTIFY_DECLINE|temperature_alarm<>,fraction<371>,int_obj_id<1>,owner<PC>,noImage<0>,date<10-02-22>,from_script<1>, guid_pk<{51A469CC-438A-EC11-94E5-D8BBC1166DF4}>,timeout<1>,core_global<1>,p_id<1>,quality<83.864>,wait<10>,cam_id<2>,time<10:34:01>,param0<Timeout>
Example of an event when a user doesn't have a photo:
Event : FIRSERVER|1|IDENTIFY_DECLINE|temperature_alarm<>,fraction<367>,int_obj_id<1>,owner<PC>,noImage<1>,date<10-02-22>,from_script<1>, guid_pk<{B314D117-458A-EC11-94E5-D8BBC1166DF4}>,timeout<1>,core_global<1>,p_id<4>,quality<0>,wait<10>,cam_id<2>,time<10:43:14>,param0<Timeout>
The face verification is completed.
Attention!
File with photo must have the .bmp extension. But the file format can be one from the list: JPG, BMP, or PNG.
Script for adding a reference face to the database from a file
A reference face can be added to the database from a file with photo using the ADD_PERSON_FROM_FILE reaction of the FIRSERVER object.
Note
When you add a reference face to the Face Intellect database, a new user is automatically created and assigned a photo from the specified file.
Parameters:
- filename—full name of the file with the photo. Files with the JPG, BMP, GIF, PNG extension are acceptable;
- name—the name of the added user;
- surname—the surname of the added user;
- department—the department to which the user will be added;
- comment—any text commentary.
Example of the script usage:
if(Event.SourceType == "MACRO" && Event.Action == "RUN" && Event.SourceID == "1") { DoReactStr("FIRSERVER","1","ADD_PERSON_FROM_FILE","filename<c:\\iso_small.jpg>,name<Jane>,surname<Kramer>,department<Department 1>,comment<>"); }
If the face was successfully added to the reference face database, the ADD_PERSON_FROM_FILE_OK event will be displayed in the Debug window. If there are any errors when adding the reference face, the ADD_PERSON_FROM_FILE_ERROR event will be displayed (see FIRSERVER events).
Script for checking the quality of a saved user photo
You can check the quality of a saved user photo using the CHECK_QUALITY_START command:
Create the script:
if(Event.SourceType == "MACRO" && Event.Action == "RUN" && Event.SourceID == "1") { DoReactStr("FIRSERVER","1","CHECK_QUALITY_START","p_id<1>"); }
Parameters:
- 1—the identifier of the Face Recognition Server object;
- CHECK_QUALITY_START—the command for checking the quality of a saved user photo;
- p_id<1>—the identifier of the user whose photo should be checked.
- Run the first macro.
If the quality of the photo is higher than the minimum quality of the face on the face recognition server, the following event is generated:
Event : FIRSERVER|1|QUALITY_OK|fraction<413>,int_obj_id<1>,owner<PC>,date<08-02-22>,guid_pk<{11DB55C9-F188-EC11-94E4-D8BBC1166DF4}>, core_global<1>,p_id<3>,time<18:14:24>,param0<92.4644>
If the quality of the photo is lower than the minimum quality of the face on the face recognition server, the following event is generated:
Event : FIRSERVER|1|QUALITY_BAD|fraction<281>,int_obj_id<1>,owner<PC>,date<08-02-22>,guid_pk<{0742EBE0-F288-EC11-94E4-D8BBC1166DF4}>, core_global<1>,p_id<3>,time<18:22:12>,param0<92.4644>
If there is no photo, the following event is generated:
Event : FIRSERVER|1|QUALITY_BAD|fraction<517>,int_obj_id<1>,owner<PC>,date<24-02-22>,guid_pk<{1C9609E4-7795-EC11-A50D-74D435D0E19B}>, core_global<1>,p_id<3>,time<17:44:34>,param0<0>
If the photo quality is successfully checked, the user can also be verified (see the script for user verification above). If a photo of a low quality is detected, the user will be marked to find them in the Access Manager and replace the photo.
Note
If the photo quality is higher than the quality of the face, set on the Face Recognition Server object, it doesn’t guarantee that the verification will be performed correctly 100% of the time. The verification result depends on the position and settings of the camera, on the lighting of the face, the camera angle and other derivatives. It is recommended to set the Similarity level on the Face Recognition Server settings panel to no higher than 50% and adjust it on a trial basis to get the required result.