arrow left
Back to Developer Education

Leveraging BodyPix Model for Body Segmentation using Python

Leveraging BodyPix Model for Body Segmentation using Python

BodyPix is a body segmentation model built on TensorFlow. The model uses a pre-trained neural network to segment a human body from a frame. <!--more--> There is a wide range of use cases for this model. For instance, it can be utilized to remove human objects from an image.

In this tutorial, we will use the BodyPix model to change the background from a frame using OpenCV.

Prerequisites

To follow along with this tutorial, you need to be familiar with:

  • Machine Learning modeling.
  • Google Colab.

Table of contents

Installing and importing dependencies

To get started, we will install the following libraries:

  • tensorflow==2.8.0: The Bodypix model relies on Tensorflow 2.0 and above.

  • tensorflow-gpu==2.8.0: It allows us to leverage the GPU. Though we do not require a GPU to run this code, we will use it to speed up the detection.

  • tf_bodypix: It gives us the pre-trained body segmentation model from Tensorflow.

  • tfjs_graph_converter: It allows us to convert the tensorflow.js BodyPix model to something we can use in Python. By default, the BodyPix model is native in the Tensorflow.js package.

The command below will install the required libraries:

!pip install tensorflow==2.8.0 tensorflow-gpu==2.8.0 tf_bodypix opencv-python tfjs_graph_converter matplotlib

We will go ahead and import the installed dependencies into our notebook:

import cv2
import tensorflow as tf
from tf_bodypix.api import load_model, download_model, BodyPixModelPaths
import numpy as np
from matplotlib import pyplot as plt

The load_model, download_model, BodyPixModelPaths are the classes that will allow us to interact with the BodyPix model.

Loading the BodyPix model

We define the bp_model variable to store the BodyPix model. The BodyPixModelPaths.MOBILENET_FLOAT_50_STRIDE_16 defines our BodyPix model path.

bp_model = load_model(download_model(BodyPixModelPaths.MOBILENET_FLOAT_50_STRIDE_16))

You can confirm the path by running it separately.

BodyPixModelPaths.MOBILENET_FLOAT_50_STRIDE_16

Output:

https://storage.googleapis.com/tfjs-models/savedmodel/bodypix/mobilenet/float/050/model-stride16.json

This path directs the program to where the model is stored.

We pass the above path to the download_model class to import it into our notebook. We then use the load_model class to access its contents. The result is stored in the bp_model variable.

Uploading static image using OpenCV

In this tutorial, will use the following image downloaded from Unsplash.

Boy

Image Source: Unsplash

Once downloaded, you can upload it into the notebook, as shown below:

from google.colab.patches import cv2_imshow

image = cv2.imread("https://sparkling-desk-070a6c243e.media.strapiapp.com/737_boy_1f565273ac.jpg")
cv2_imshow(image)
cv2.waitKey(0)

Let's make some detections with BodyPix. We also need to perform the body segmentation.

Performing body segmentation

We use the code below for the body segmentation:

from google.colab.patches import cv2_imshow

image = cv2.imread("https://sparkling-desk-070a6c243e.media.strapiapp.com/737_boy_1f565273ac.jpg") #Reading the image

prediction = bp_model.predict_single(image) # Passing the image to the model
mask = prediction.get_mask(threshold=0.5).numpy().astype(np.uint8)
new_mask = cv2.bitwise_and(image, image, mask=mask)

cv2_imshow(new_mask)
cv2.waitKey(0)
  • The threshold is set to 0.5, which is 50%. Changing this value up and down will impact the detection confidence. A higher value will produce a tighter mask, while a lower value will make it more flexible.
  • The bitwise_and function helps us to mask the image.

When you run the code above, it results in the following output:

Masked boy

Though it's not perfect, it still masks the boy from the background. The next step is to apply a virtual background.

Applying a virtual background

We need to apply an inverse mask to our virtual background. We can then combine the two images. We will still retrieve a background image from Unsplash.

Background

Image Source: Unsplash

Note that you can use any image as the background.

Let's load the image into the notebook:

from google.colab.patches import cv2_imshow

image = cv2.imread("https://sparkling-desk-070a6c243e.media.strapiapp.com/737_nature_3035b2e47a.jpg")
cv2_imshow(image)
cv2.waitKey(0)

Ensure that the input image and virtual background are of the same dimensions when we overlay them on top of each other. You can find out the dimensions of your image using the image.shape method.

Once you've established that the dimensions are the same, we can proceed to apply the virtual background. We will build upon the body segmentation code:

from google.colab.patches import cv2_imshow

img = cv2.imread("https://sparkling-desk-070a6c243e.media.strapiapp.com/737_nature_3035b2e47a.jpg")

#Performing body segmentation
prediction = bp_model.predict_single(image)
mask = prediction.get_mask(threshold=0.5).numpy().astype(np.uint8)
new_mask = cv2.bitwise_and(image, image, mask=mask)

#Applying virtual mask
negative = np.add(mask, -1)
inverse = np.where(negative==-1, 1, negative).astype(np.uint8)
masked_bg = cv2.bitwise_and(img, img, mask=inverse)
final_image = cv2.add(new_mask, masked_bg)

cv2_imshow(final_image)

Output:

Final image

We have now successfully leveraged the BodyPix model to segment a human object from a frame using OpenCV. We also added the segmented body to another background image.

The resulting image is not perfect because some background is still visible. You can adjust the threshold value to get a tighter mask.

The BodyPix model can also be used to generate fake webcam backgrounds for video calls.

Please find the complete code for this tutorial here.

Conclusion

In this tutorial, we discussed body segmentation using the BodyPix model. We installed the required dependencies, loaded the model, and uploaded a static image.

Finally, we performed a body segmentation on the image and overlayed a new virtual background on it using the BodyPix model.

Further reading


Peer Review Contributions by: Willies Ogola

Published on: Mar 30, 2022
Updated on: Jul 12, 2024
CTA

Cloudzilla is FREE for React and Node.js projects

Deploy GitHub projects across every major cloud in under 3 minutes. No credit card required.
Get Started for Free