Bod Language Reader With Ai

by ambufire in Circuits > Raspberry Pi

61 Views, 2 Favorites, 0 Comments

Bod Language Reader With Ai

IMG-20240615-WA0008.jpg
emotions_culture_1600.jpg
360_F_308753421_Hb7XWYj37dLiCqO2FqPK4U20toB3PoNW.jpg

Welcome to my Body Language/emotions Reader project, where we delve into the world of non-verbal communication. With this innovative tool, we aim to decode the subtle gestures of people!

Supplies

the supplies needed:

  • Raspberry Pi 5/4.
  • 2 basic webcams
  • raspberry pi projects kit
  • 3D printer
  • 4 m angle bracket
  • 0.5m² wood
  • paint
  • wing nuts
  • bolts
  • nuts
  • tools for sanding, cutting the wood , drilling and installing the bolts and nuts

Github link:

https://github.com/howest-mct/2023-2024-projectone-ctai-CrombezWout


If anything is not clear during the instructables, please refer to the github code shared!

Emotion Detection Model

face_mesh_2_by_jakeheili_d5164qu-fullview.jpg

Before we begin, ensure you have the following installed:

  • Python
  • OpenCV: pip install opencv-python-headless
  • cvzone: pip install cvzone
  • numpy: pip install numpy
  • pandas: pip install pandas
  • Pickle: Comes with the standard library, no installation needed.
  • facemesh: Part of cvzone, no additional installation required.

Step-by-Step Guide to Creating and Capturing FaceMesh Data

1. Set Up the FaceMesh Detector

  • Initialize the Detector:
  • Use cvzone.FaceMeshModule.FaceMeshDetector to create a FaceMesh detector.

2. Capture Data from Camera or Video

  • Open the Camera or Video:
  • Use OpenCV to capture data from your own camera or video files.
  • Capture FaceMesh Data:
  • For each frame, detect facial landmarks and save the coordinates into a CSV file.

3. Ensure Data Diversity

  • Different People:
  • Capture data from multiple individuals to ensure variety.
  • Different Angles and Distances:
  • Record faces from various angles and distances to make the data robust.
  • Balance the Data:
  • Ensure the dataset is balanced with respect to different classes or labels you are using.

Detailed Instructions

Step 1: Set Up the FaceMesh Detector

  1. Initialize the Detector:
  • Import necessary libraries and initialize the FaceMesh detector from cvzone.

Step 2: Capture Data from Camera or Video

  1. Open the Camera or Video:
  • Use OpenCV to open your camera or load a video file.
  1. Capture FaceMesh Data:
  • Read frames from the camera or video in a loop.
  • Use the FaceMesh detector to detect facial landmarks.
  • Save the coordinates of these landmarks into a CSV file.

Step 3: Ensure Data Diversity

  1. Capture Data from Different People:
  • Record data from multiple individuals. Each person should perform different facial expressions and movements to capture a wide range of data.
  1. Capture Data from Different Angles and Distances:
  • Move the camera to different angles and distances from the face to capture diverse perspectives.
  1. Ensure Data Balance:
  • Ensure your dataset is balanced by having an equal representation of all classes or labels (e.g., different emotions, angles, etc.).


Training the Model

1_kzmiuypmxgehhxx7slbp4w.jpeg

1. Preprocess the Data

  • Load the Data:
  • Read the CSV file into a DataFrame using pandas.
  • Split into Features and Target:
  • Separate the features (all columns except the last) and the target (the last column).
  • Split the Dataset:
  • Use train_test_split from scikit-learn to split the data into training and testing sets.

2. Train the Model

  • Choose the Model:
  • Use Logistic Regression or Ridge Classifier for training.
  • Train the Model:
  • Fit the model using the training data.
  • Save the Model:
  • Use pickle to save the trained model to a file.

3. Evaluate the Model

  • Predict on Test Data:
  • Use the trained model to make predictions on the test set.
  • Create Evaluation Metrics:
  • Calculate accuracy, precision, recall, and F1-score to evaluate the model's performance.
  • Decide if the Model is Good Enough:
  • Based on the evaluation metrics, determine if the model meets the required performance criteria.


Testing the Model

Schermafbeelding 2024-06-13 145440.png

1. Set Up the Environment

  • Ensure Necessary Libraries:
  • Make sure you have OpenCV (cv2) and Pickle installed in your Python environment.

2. Load the Trained Model

  • Open the Pickle File:
  • Load the trained model from the pickle file that was saved during the training process.

3. Capture Video Feed

  • Use cv2.VideoCapture:
  • Initialize the video capture using cv2.VideoCapture.
  • You can use a video file path for pre-recorded footage or 0 for a live camera feed.

4. Process Each Frame

  • Read Frames in a Loop:
  • Continuously read frames from the video capture in a loop.
  • Process each frame to detect faces and extract features.

5. Predict Emotions

  • Use the Loaded Model:
  • Use the loaded trained model to predict emotions based on the extracted features from each frame.

6. Display Results

  • Overlay Text on Frames:
  • Use OpenCV’s text functions to display the predicted emotion class on the screen.
  • Ensure the text is clear and positioned appropriately.


Bodylanguage Model Creating Data

Now that we have a working emotion detection we are going to make another model for the bodylanguage following the same steps. we will use mediapipe holistics for this model ,

Bodylanguage Model Training

follow steps in step2:

Bodylanguage Model Testing

follow steps in step 3

Flask Website

Schermafbeelding 2024-06-13 151350.png

Create the HTML Structure:

  • Create an index.html file with the basic structure and sect ions for each model.

Add CSS for Styling:

  • Create a styles.css file to style the website and make it visually appealing.

Add JavaScript for Interactivity:

  • Create a script.js file to add any interactive elements or functionality.

Raspberry Pi

rasp.jpg

Now that we have 2 working models , we will connect the raspberry pi model to the emotion detection model. the connection happens with wifi for fast and reliable connection.


Making a Nice Display

4105489153_2c712c1cac_b.jpg

1. Set Up the LED Matrix on Raspberry Pi

  • Connect the LED Matrix:
  • Connect the LED matrix to your Raspberry Pi using appropriate GPIO pins or an I2C connection.
  • Install Necessary Libraries:
  • Ensure you have the required libraries for controlling the LED matrix, such as rpi_ws281x or any library specific to your LED matrix model.

2. Prepare the Python Script on Raspberry Pi

  • Initialize the LED Matrix:
  • Set up the LED matrix using the chosen library.
  • Define Emotions:
  • Create bitwise representations for different emotions (e.g., happy, sad, neutral, angry). Each bitwise pattern will represent the pixels to light up on the LED matrix.
  • Display Function:
  • Write a function to update the LED matrix with the appropriate emotion based on received data.

3. Send Data from AI Model to Raspberry Pi

  • Establish Connection:
  • Use a network connection (e.g., sockets) to send emotion data from the machine running the AI model to the Raspberry Pi.
  • Sending Data:
  • Write a script on the AI model machine to send emotion data to the Raspberry Pi over the network.

4. Update Raspberry Pi Script to Handle Incoming Data

  • Receive Data:
  • Modify the Raspberry Pi script to listen for incoming connections and data.
  • Handle Emotions:
  • Update the LED matrix display based on the received emotion data.


Maker Part

IMG-20240615-WA0000.jpg
IMG-20240615-WA0010.jpg
IMG-20240615-WA0001.jpg



Frame Construction:

1 Build the Frame:

  • Assemble the main structure using angle brackets.
  • Use screws and bolts to secure the brackets together.

2 Attach the Wood Panels:

  • Measure and cut the wood panels to fit the frame.
  • Prime and paint the wood panels beforehand.
  • Attach the wood panels to the outside of the frame using screws or nails.

3 Install Inner Supports:

  • Inside the frame, add more angle brackets to create support for the project board.
  • Ensure these brackets are securely fastened to hold the weight of the Raspberry Pi and other components.

4 Mount the Project Board:

  • Screw the project board onto the inner angle brackets.
  • Position the board so that it hangs in the front of the robot.

5 Create the LED Matrix Cutout:

  • Measure and mark the location on the front panel where the LED matrix will be visible.
  • Use a saw to cut a hole in the chest area, ensuring it aligns with the LED matrix on the project board.

6 Add Ventilation:

  • Measure and mark the locations for vents in front of the Raspberry Pi.
  • Use a saw to cut out the vents to prevent overheating.

7 Cable Management:

  • Cut a hole in the back of the robot for the Raspberry Pi cables.
  • Ensure the hole is large enough to accommodate all necessary cables without causing strain.

Head Construction:


1 Build the Head Frame:

  • Use angle brackets to construct the head frame, similar to the main frame.

2 Drill Camera Cable Holes:

  • Drill holes on the side of the head frame for the camera cables.
  • Ensure the holes are positioned to allow the cables to move freely.

3 Mount the Cameras:

  • Attach the two cameras to a makeshift GoPro stick or similar mounting device.
  • Secure the stick inside the head frame, ensuring the cameras can move up, down, and to the sides without obstruction.

4 Assemble and Attach the Head:

  • Once the head is fully assembled, attach it to the main frame using angle brackets.
  • Ensure it is securely fastened and aligned with the rest of the robot.

Final Touches:

  • Paint Touch-Ups:
  • After assembly, do any necessary touch-up painting to cover any scratches or marks from construction.
  • Testing:
  • Test all components to ensure they are securely fastened and functioning correctly.
  • Verify that the Raspberry Pi, LED matrix, and cameras are working properly and that the ventilation is adequate.

Visual Guide:

  • Frame:
  • A rectangular structure with wood panels.
  • The front panel has a cutout for the LED matrix.
  • Vents are positioned near the Raspberry Pi.
  • A hole in the back for cable management.
  • all panels are removable for easy acces to components
  • Head:
  • A smaller rectangular structure.
  • Mounted cameras on a movable stick.
  • Holes for camera cables.
  • all panels are removable for easy acces to components