Skip to content

Latest commit

 

History

History
159 lines (110 loc) · 7.84 KB

README.md

File metadata and controls

159 lines (110 loc) · 7.84 KB

MafQud Data Science

One of the core parts of MafQud project is the tasks and work that are associated to the data science sub-team. So, their main big tasks are:

  • Populating the data to train, validate and test the face recognition model.
  • Build the core face recognition model.

And if there is another model (e.g., GANs, Speech-to-Text, …) as upcoming features.

Project Structure

├─MafQud-Data-Science
├───Data-Scraping
│   │   arabic_content.py
│   │   Atfal_Facebook_Scrapping.py
│   │   Atfal_Website_Scrapping.py
│   │
│   └───Scrapped-Data
│           missing_people.json
│           scrapped_data.csv
│           scrapped_data.xlsx
│
└────Prototype-Code
   │   arabic_content.py
   │   knn_model.clf
   │   Mafqud_Recognition.py
   │   main.py
   │
   ├───Saved-Data
   │   │   face_locations.npy
   │   │   feature.npy
   │   │   ids.npy
   │   │   knn_model.clf
   │   │   people.npy
   │   │
   │   └───Well_Trained
   │           face_location.npy
   │           feature.npy
   │           ids.npy
   │           knn_clf.clf
   │           people.npy
   │
   └───__pycache__
           arabic_content.cpython-38.pyc
           arabic_content.cpython-39.pyc
           Mafqud_Recognition.cpython-38.pyc
           Mafqud_Recognition.cpython-39.pyc

Data Scrapping:

We need to find a specific data for our model, our target data should contain at least: photos of the missing people, and their names associated to each photo.

We are able to find our target data and more by scrapping the Atfal Mafkoda | أطفال مفقودة Website and Facebook Page. With this data we can capture a data of each missing person that contain:

  • Name of the missing person.
  • Photo(s) of the missing person.
  • The government or the location of his residence.
  • Date of absence.
  • Expected current age.

You can see our scrapping codes for the Website and the Facebook Page and see how they save their final data in JSON or CSV file.

Scrapped Data CSV Scrapped Data Json

MafQud Recognition:

Our face recognition model is the second main part. The approach of recognizing a familiar face (i.e. trained or stored on the system database) has more than one step to be done:

1. Face detection model:

We need first to detect the location of the face (or many faces) on a photo (i.e. the coordinates of the face(s) in the photo). That can be done using one of the two algorithms:

  • Histogram of Oriented Gradients (HOG) [a method invented in 2005]: it is the older algorithm, so it is less accurate but yet faster than the other algorithm.

  • Convolutional Neural Network (CNN): it is a way more accurate than HOG, but it is slower than it. [based on ResNet-34 network architecture from “Deep Residual Learning for Image Recognition” paper by He et al].

We added to them "the mixed method" which makes use of the best of the two algorithms.

HOG

2. Face landmarks estimation:

We need second to mark the main points in the face which called in our case: landmarks, the more landmarks we target and capture, the more accurate to recognize someone in the photo. So, we capture 68 landmarks in the face (such that: chin, eyebrows, eyes, lips, …) [using face landmark estimation algorithm invented 2014]

Ideal Landmarks

3. Face alignment:

According to the landmarks that are captured from the face, we compare them with an ideal landmark model and their ideal locations, then the photo is aligned to match and cope with the ideal standard landmarks with group of shearing (resizing and rotating).

4. Face encoding:

Last step is to encode the 68 landmarks to be almost unique for the person. Unfortunately, they can’t be interpreted or said that they represent something in the photo as they are the output of a neural network. Now instead of storing the whole photo with its big size of pixels, we just store the 128 encoding numbers ranging from -1 to 1. That is more computational-saving approach and more efficient for space and time.

Face Encoding Example

5. Face comparing model:

After storing each face as 128 encoding values ranging from -1 to 1, we now are able to compare our stored faces with the new photos that are queried, all what we need is to go through the last 4 steps with the new photo to find the 128-encoding value of the face on it, then we compare them with the stored ones by determining the distance between them and it is more probable that the nearest face of it is the targeted face. That is exactly what our K-Nearest Neighbors (KNN) model does.

Final output:

Each face enters the system either for storing or for querying about it go through our 5 steps, finally it gives one of the outputs:

- Matching:

If there is matching between the new photo and one (or some) of the stored photos, then it is the person we are searching for (with accuracy = %82.0 in our prototype demo).

Matching Case Example 1

Matching Case Example 2

- Unknown:

If there is no matching happened, then it is a new unknown face to our system model, then we need to store and retrain our model on it in case of future cases.

Unknown Case Example/>
</p>
<p align= Asking for storing

- No Face Detected:

There is a possibility that the user by mistake queries for a photo that doesn’t contain a human face at all (photo of dog, photo of nature, …) or even he/she queries for a low-pixeled (i.e., low resolution) photo that is difficult to capture the face on it.

No Face Detcted Case Example

MafQud Recognition Overview Chart

Storing Images (creating encodings)

Storing Images Flowchart

Query New Images (searching for matching)

Query New Images Flowchart

References