| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if __cplusplus
 | 
					
						
							|  |  |  | extern "C" | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "image_util.h"
 | 
					
						
							| 
									
										
										
										
											2019-05-12 18:52:23 +03:00
										 |  |  | #include "dl_lib_matrix3d.h"
 | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  | #include "frmn.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define FACE_WIDTH 56
 | 
					
						
							|  |  |  | #define FACE_HEIGHT 56
 | 
					
						
							|  |  |  | #define FACE_ID_SIZE 512
 | 
					
						
							| 
									
										
										
										
											2020-01-20 22:07:04 +02:00
										 |  |  | #define FACE_REC_THRESHOLD 0.55
 | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define LEFT_EYE_X 0
 | 
					
						
							|  |  |  | #define LEFT_EYE_Y 1
 | 
					
						
							|  |  |  | #define RIGHT_EYE_X 6
 | 
					
						
							|  |  |  | #define RIGHT_EYE_Y 7
 | 
					
						
							|  |  |  | #define NOSE_X 4
 | 
					
						
							|  |  |  | #define NOSE_Y 5
 | 
					
						
							| 
									
										
										
										
											2020-01-20 22:07:04 +02:00
										 |  |  | #define LEFT_MOUTH_X 2
 | 
					
						
							|  |  |  | #define LEFT_MOUTH_Y 3
 | 
					
						
							|  |  |  | #define RIGHT_MOUTH_X 8
 | 
					
						
							|  |  |  | #define RIGHT_MOUTH_Y 9
 | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define EYE_DIST_SET 16.5f
 | 
					
						
							|  |  |  | #define NOSE_EYE_RATIO_THRES_MIN 0.49f
 | 
					
						
							|  |  |  | #define NOSE_EYE_RATIO_THRES_MAX 2.04f
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief      HTTP Client events data | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-03 17:19:11 +01:00
										 |  |  | #define ENROLL_NAME_LEN 16
 | 
					
						
							|  |  |  |     typedef struct tag_face_id_node | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         struct tag_face_id_node *next; | 
					
						
							|  |  |  |         char id_name[ENROLL_NAME_LEN]; | 
					
						
							|  |  |  |         dl_matrix3d_t *id_vec; | 
					
						
							|  |  |  |     } face_id_node; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     typedef struct | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-05-12 18:52:23 +03:00
										 |  |  |         face_id_node *head;    /*!< head pointer of the id list */ | 
					
						
							|  |  |  |         face_id_node *tail;    /*!< tail pointer of the id list */ | 
					
						
							|  |  |  |         uint8_t count;         /*!< number of enrolled ids */ | 
					
						
							|  |  |  |         uint8_t confirm_times; /*!< images needed for one enrolling */ | 
					
						
							| 
									
										
										
										
											2019-03-03 17:19:11 +01:00
										 |  |  |     } face_id_name_list; | 
					
						
							| 
									
										
										
										
											2019-05-12 18:52:23 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  |     typedef struct | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-05-12 18:52:23 +03:00
										 |  |  |         uint8_t head;            /*!< head index of the id list */ | 
					
						
							|  |  |  |         uint8_t tail;            /*!< tail index of the id list */ | 
					
						
							|  |  |  |         uint8_t count;           /*!< number of enrolled ids */ | 
					
						
							|  |  |  |         uint8_t size;            /*!< max len of id list */ | 
					
						
							|  |  |  |         uint8_t confirm_times;   /*!< images needed for one enrolling */ | 
					
						
							|  |  |  |         dl_matrix3d_t **id_list; /*!< stores face id vectors */ | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  |     } face_id_list; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief Initialize face id list | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param l                 Face id list | 
					
						
							|  |  |  |      * @param size              Size of list, one list contains one vector | 
					
						
							|  |  |  |      * @param confirm_times     Enroll times for one id | 
					
						
							|  |  |  |      * @return dl_matrix3du_t*          Size: 1xFACE_WIDTHxFACE_HEIGHTx3 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void face_id_init(face_id_list *l, uint8_t size, uint8_t confirm_times); | 
					
						
							| 
									
										
										
										
											2019-03-03 17:19:11 +01:00
										 |  |  |     void face_id_name_init(face_id_name_list *l, uint8_t size, uint8_t confirm_times); | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief Alloc memory for aligned face. | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @return dl_matrix3du_t*          Size: 1xFACE_WIDTHxFACE_HEIGHTx3 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     dl_matrix3du_t *aligned_face_alloc(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief Align detected face to average face according to landmark | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param onet_boxes        Output of MTMN with box and landmark | 
					
						
							|  |  |  |      * @param src               Image matrix, rgb888 format | 
					
						
							|  |  |  |      * @param dest              Output image | 
					
						
							|  |  |  |      * @return ESP_OK           Input face is good for recognition | 
					
						
							|  |  |  |      * @return ESP_FAIL         Input face is not good for recognition | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-01-20 22:07:04 +02:00
										 |  |  |     int8_t align_face_rot(box_array_t *onet_boxes, | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  |                       dl_matrix3du_t *src, | 
					
						
							|  |  |  |                       dl_matrix3du_t *dest); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-12 18:52:23 +03:00
										 |  |  |     int8_t align_face2(fptp_t *landmark, | 
					
						
							|  |  |  |                        dl_matrix3du_t *src, | 
					
						
							|  |  |  |                        dl_matrix3du_t *dest); | 
					
						
							| 
									
										
										
										
											2020-01-20 22:07:04 +02:00
										 |  |  |      | 
					
						
							|  |  |  |     int8_t align_face_sim(box_array_t *onet_boxes, | 
					
						
							|  |  |  |                    dl_matrix3du_t *src, | 
					
						
							|  |  |  |                    dl_matrix3du_t *dest); | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     inline int8_t align_face(box_array_t *onet_boxes, | 
					
						
							|  |  |  |                        dl_matrix3du_t *src, | 
					
						
							|  |  |  |                        dl_matrix3du_t *dest) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return align_face_sim(onet_boxes, src, dest);               | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-05-12 18:52:23 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-17 16:48:51 +03:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief Run the face recognition model to get the face feature | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param aligned_face      A 56x56x3 image, the variable need to do align_face first | 
					
						
							|  |  |  |      * @return face_id          A 512 vector, size (1, 1, 1, 512) | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-04-12 15:43:53 +02:00
										 |  |  |     dl_matrix3d_t *get_face_id(dl_matrix3du_t *aligned_face); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief Add src_id to dest_id | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param dest_id  | 
					
						
							|  |  |  |      * @param src_id  | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void add_face_id(dl_matrix3d_t *dest_id, | 
					
						
							|  |  |  |                      dl_matrix3d_t *src_id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief Match face with the id_list, and return matched_id. | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param algined_face          An aligned face | 
					
						
							|  |  |  |      * @param id_list               An ID list | 
					
						
							|  |  |  |      * @return int8_t               Matched face id | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-05-12 18:52:23 +03:00
										 |  |  |     int8_t recognize_face(face_id_list *l, dl_matrix3du_t *algined_face); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     face_id_node *recognize_face_with_name(face_id_name_list *l, dl_matrix3d_t *face_id); | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief Produce face id according to the input aligned face, and save it to dest_id. | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param l                     face id list | 
					
						
							|  |  |  |      * @param aligned_face          An aligned face | 
					
						
							|  |  |  |      * @param enroll_confirm_times  Confirm times for each face id enrollment | 
					
						
							|  |  |  |      * @return -1                   Wrong input enroll_confirm_times | 
					
						
							|  |  |  |      * @return 0                    Enrollment finish | 
					
						
							|  |  |  |      * @return >=1                  The left piece of aligned faces should be input | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-05-12 18:52:23 +03:00
										 |  |  |     int8_t enroll_face(face_id_list *l, dl_matrix3du_t *aligned_face); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     int8_t enroll_face_with_name(face_id_name_list *l, | 
					
						
							|  |  |  |                                  dl_matrix3d_t *new_id, | 
					
						
							|  |  |  |                                  char *name); | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief Alloc memory for aligned face. | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param l                     face id list | 
					
						
							|  |  |  |      * @return uint8_t              left count | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint8_t delete_face(face_id_list *l); | 
					
						
							| 
									
										
										
										
											2019-05-12 18:52:23 +03:00
										 |  |  |     int8_t delete_face_with_name(face_id_name_list *l, char *name); | 
					
						
							| 
									
										
										
										
											2019-03-03 17:19:11 +01:00
										 |  |  |     void delete_face_all_with_name(face_id_name_list *l); | 
					
						
							| 
									
										
										
										
											2019-01-09 19:31:46 +01:00
										 |  |  | #if __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 |