Skip to content

Commit

Permalink
Add files via upload
Browse files Browse the repository at this point in the history
  • Loading branch information
mohamed-gasser authored Jun 27, 2023
1 parent 2d5dee8 commit 21d4ca6
Show file tree
Hide file tree
Showing 31 changed files with 3,101 additions and 0 deletions.
145 changes: 145 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,145 @@
# Word-Level LipReading in Arabic

Our application works to support Visual Speech Recognition (VSR) is
the ability to recognize words from the mouth movements of a speaking
person Lip reading in arabic language,the system using a locally collected dataset that
was prepared and photographed through us, and the number of videos
(9000), You can find more details in our paper coming soon.
We are students from the Faculty of Computers and Artificial Intelligence, Helwan University, who made this system


Video Input | Processed Input | output in our application
:-------------------------:|:-------------------------:|:-------------------------:
![input video](https://github.com/Megamind22/lstArab100words/assets/102036714/7aac6787-e5bf-4e92-99c4-33aa98e0b239)|![image](https://github.com/Megamind22/lstArab100words/assets/102036714/74ae9d7f-c3fe-454f-ab3c-fd769df85dbd)|![output](https://github.com/Megamind22/lstArab100words/assets/102036714/f296bec6-db7e-48a6-8b5f-aa4c84fbae07)




# Requirements
<h4>fastapi<h4/>
<h4>uvicorn<h4/>
<h4>pickle5<h4/>
<h4>pydantic<h4/>
<h4>scikit-learn<h4/>
<h4>requests<h4/>
<h4>pypi-json<h4/>
<h4>pyngrok==4.1.1<h4/>


# How To Use and Running the demo of the project
1- download and extract the code.

2- run the file call demo.ipynb.

3- use the api address that appear for you from running demo.ipynb in test_api.py file .

4- change the video path you want to test in test_api.py file.



# We train the model using two types of dataset
### the sample of this words in words.txt file
#### YouTube dataset

In the beginning, we will talk about the first approach to building our owndatabase, which is by collecting videos from YouTube each video isbetween 3 and 7 seconds long and 25 fps. We take from multiple channel ex sada Elbalad and different platforms about 50 people (20males an 30 females), And we have collected 6,000 videos, and it isentered in several stages to be prepared for processing.

The multiple stages are:
1- We upload the video in 360 or 240 qualities.

2- Then we extract text from video

3- Then we make a time stamp in which every word in video said in certain amount of seconds (00:00 00:02 "اخبار")With using tool named “time thing”

#### Camera dataset

Now, we will talk about the second approach to building our database,where in this approach we photographed people with our mobilecamera. 9000 videos were captured for different participants from both genders (i.e. 24 females and 62 males). Age range is 13 to 75 years from the same country. . The videos of the dataset are captured with different background lighting settings, different distances, and using cameras of multismartphones.
Different cameras, distances, and background lighting settings guarantee dataset generalization. All used cameras record videos at a rate of 30 frames per second (fps). All 86 speakers uttered each one of the 100 words once (i.e. 9000 videos)
This ensures the inclusiveness of the dataset because there are many diversities between people that need to be accounted for, such as: Speediness of speaking, mouth shape and movements, lips geometric features, amount of tongue determined by the redness of the taken mouth frame, the alveolar ridge, teeth, braces, mustache, beard, and makeup.

### If you want to use dataset for future work, you can contact a member of our team to take it we provide preprocssing video only now .

# Preprocessing

One of the most important steps in our application tasks is to preprocess and split the dataset before feeding it to the learning algorithm. In our application, the following preprocessing steps are required:
1) The lengths of all videos in the dataset are fixed to exactly one or two second while making sure that each video contains the target word without any errors.
2) Each video is converted to 30 frames of images using the Video Capture class from the Python cv2 library
3) Each frame is processed using Face Tracker Which tracks the movement of the person's face in the video. You can find more details in https://github.com/mpc001/Visual_Speech_Recognition_for_Multiple_Languages/tree/master/tools
4) Each frame is processed to locate the lip area of the face. A cut is made for the frame at the mouth area. As a result, the final frame will only contain the mouth area in order to isolate any interference or noise from the background or other parts of the face.
5) Each frame is resized to 112X112 pixels in order to reduce the dataset size without affecting the accuracy.
6) Each pixel value in a frame is normalized to a range between 0 and 1 without distorting differences between the frame’s pixels. This is achieved by dividing each pixel value by 255.

# Project Structure
### Important Training Details
During the implementation phase of our application, deep learning models were investigated in order to test the one with the highest recognition accuracy for the Arabic words using the dataset described in subsection dataset .

We pretrain backend with You Tupe videos with fine tuning and train frontend model with camera videos and freeze another layer andmake end to end train model which means 2 model trainingwithout freeze in camera dataset with new face trackerprocessing not cutting with fixed size like paper[1] and made Merge model combine 2 model vf with backend to train vf with transfromer not 2 temp 2 layer CNN as backend that is occurred before in paper[1].
Finally, train this model with different lengths of char ... means backend when You Tube fixed 145 frames with padding and change it 15to 100 when camera dataset and in end-to-end train ... make it variable mean changes to change of frames of video.Output of model is probabilities of SoftMax layer for 40 num classes and loss depend on CTC with greedy search to backward and train model ..made front-end with beam search 100 beam width.Greedy we take the best path in alternative paths and beam walk as tree take the best 100 every alternative paths


## Pre-trained Weights
If you want to use pre-trained weights for future work, you can contact a member of our team to take it .



# Results
<table>
<thead>
<tr>
<th>Operation Mode</th>
<th colspan="1">VO Model</th>
<th colspan="1">(WER)</th>
<th colspan="1">(CER)</th>
</tr>
</thead>
<tbody>
<tr>
</tr>
<tr>
<td>VO</td>
<td>Greedy</td>
<td>39.8%</td>
<td>28.1%</td>
</tr>
<tr>
</tr>
<tr>
</tbody>
</table>






# License
All rights reserved to our teams who update the model and developed it and built the application


# Contact
You can communicate through one of team by following e-mails to obtain the pre-trained model and the processed dataset:

1- mohamedgasser230@gmail.com

2- mohameda.shaker16@gmail.com

3- Ma7157563@gmail.com

4- mostafakotb359@gmail.com

5- omarmo5tar12@gmail.com


# References
1- The pre-trained weights of the Visual Frontend and the Model have been obtained from
https://github.com/smeetrs/deep_avsr GitHub repository.

2- We also used this paper in our work https://www.sciencedirect.com/science/article/pii/S1110866522000433

3- We used the LRW, LRS2 and LRS3 lip reading datasets from the BBC https://www.robots.ox.ac.uk/~vgg/data/lip_reading/

4- We used https://github.com/feldberlin/timething.git to Calculate timestamp





Loading

0 comments on commit 21d4ca6

Please sign in to comment.