2020-12-10 04:13:05 +01:00
|
|
|
---
|
|
|
|
layout: default
|
|
|
|
title: MediaPipe in Python
|
|
|
|
parent: Getting Started
|
|
|
|
has_children: true
|
|
|
|
has_toc: false
|
|
|
|
nav_order: 3
|
|
|
|
---
|
|
|
|
|
|
|
|
# MediaPipe in Python
|
|
|
|
{: .no_toc }
|
|
|
|
|
|
|
|
1. TOC
|
|
|
|
{:toc}
|
|
|
|
---
|
|
|
|
|
|
|
|
## Ready-to-use Python Solutions
|
|
|
|
|
|
|
|
MediaPipe offers ready-to-use yet customizable Python solutions as a prebuilt
|
|
|
|
Python package. MediaPipe Python package is available on
|
|
|
|
[PyPI](https://pypi.org/project/mediapipe/) for Linux, macOS and Windows.
|
|
|
|
|
|
|
|
You can, for instance, activate a Python virtual environment:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ python3 -m venv mp_env && source mp_env/bin/activate
|
|
|
|
```
|
|
|
|
|
2021-05-05 03:30:15 +02:00
|
|
|
Install MediaPipe Python package and start Python interpreter:
|
2020-12-10 04:13:05 +01:00
|
|
|
|
|
|
|
```bash
|
|
|
|
(mp_env)$ pip install mediapipe
|
|
|
|
(mp_env)$ python3
|
|
|
|
```
|
|
|
|
|
|
|
|
In Python interpreter, import the package and start using one of the solutions:
|
|
|
|
|
|
|
|
```python
|
|
|
|
import mediapipe as mp
|
|
|
|
mp_face_mesh = mp.solutions.face_mesh
|
|
|
|
```
|
|
|
|
|
|
|
|
Tip: Use command `deactivate` to later exit the Python virtual environment.
|
|
|
|
|
|
|
|
To learn more about configuration options and usage examples, please find
|
|
|
|
details in each solution via the links below:
|
|
|
|
|
2021-02-27 09:21:16 +01:00
|
|
|
* [MediaPipe Face Detection](../solutions/face_detection#python-solution-api)
|
2020-12-10 04:13:05 +01:00
|
|
|
* [MediaPipe Face Mesh](../solutions/face_mesh#python-solution-api)
|
|
|
|
* [MediaPipe Hands](../solutions/hands#python-solution-api)
|
|
|
|
* [MediaPipe Holistic](../solutions/holistic#python-solution-api)
|
2021-02-27 09:21:16 +01:00
|
|
|
* [MediaPipe Objectron](../solutions/objectron#python-solution-api)
|
|
|
|
* [MediaPipe Pose](../solutions/pose#python-solution-api)
|
2021-06-03 22:13:30 +02:00
|
|
|
* [MediaPipe Selfie Segmentation](../solutions/selfie_segmentation#python-solution-api)
|
2020-12-10 04:13:05 +01:00
|
|
|
|
|
|
|
## MediaPipe on Google Colab
|
|
|
|
|
2021-02-27 09:21:16 +01:00
|
|
|
* [MediaPipe Face Detection Colab](https://mediapipe.page.link/face_detection_py_colab)
|
2020-12-10 04:13:05 +01:00
|
|
|
* [MediaPipe Face Mesh Colab](https://mediapipe.page.link/face_mesh_py_colab)
|
|
|
|
* [MediaPipe Hands Colab](https://mediapipe.page.link/hands_py_colab)
|
|
|
|
* [MediaPipe Holistic Colab](https://mediapipe.page.link/holistic_py_colab)
|
2021-02-27 09:21:16 +01:00
|
|
|
* [MediaPipe Objectron Colab](https://mediapipe.page.link/objectron_py_colab)
|
|
|
|
* [MediaPipe Pose Colab](https://mediapipe.page.link/pose_py_colab)
|
|
|
|
* [MediaPipe Pose Classification Colab (Basic)](https://mediapipe.page.link/pose_classification_basic)
|
|
|
|
* [MediaPipe Pose Classification Colab (Extended)](https://mediapipe.page.link/pose_classification_extended)
|
2021-06-03 22:13:30 +02:00
|
|
|
* [MediaPipe Selfie Segmentation Colab](https://mediapipe.page.link/selfie_segmentation_py_colab)
|
2020-12-10 04:13:05 +01:00
|
|
|
|
|
|
|
## MediaPipe Python Framework
|
|
|
|
|
|
|
|
The ready-to-use solutions are built upon the MediaPipe Python framework, which
|
|
|
|
can be used by advanced users to run their own MediaPipe graphs in Python.
|
|
|
|
Please see [here](./python_framework.md) for more info.
|
|
|
|
|
|
|
|
## Building MediaPipe Python Package
|
|
|
|
|
|
|
|
Follow the steps below only if you have local changes and need to build the
|
|
|
|
Python package from source. Otherwise, we strongly encourage our users to simply
|
|
|
|
run `pip install mediapipe` to use the ready-to-use solutions, more convenient
|
|
|
|
and much faster.
|
|
|
|
|
2020-12-16 05:29:11 +01:00
|
|
|
MediaPipe PyPI currently doesn't provide aarch64 Python wheel
|
|
|
|
files. For building and using MediaPipe Python on aarch64 Linux systems such as
|
|
|
|
Nvidia Jetson and Raspberry Pi, please read
|
|
|
|
[here](https://github.com/jiuqiant/mediapipe-python-aarch64).
|
|
|
|
|
2020-12-10 04:13:05 +01:00
|
|
|
1. Make sure that Bazel and OpenCV are correctly installed and configured for
|
|
|
|
MediaPipe. Please see [Installation](./install.md) for how to setup Bazel
|
|
|
|
and OpenCV for MediaPipe on Linux and macOS.
|
|
|
|
|
|
|
|
2. Install the following dependencies.
|
|
|
|
|
|
|
|
Debian or Ubuntu:
|
|
|
|
|
|
|
|
```bash
|
2021-10-26 11:07:24 +02:00
|
|
|
$ sudo apt install -y python3-dev python3-venv protobuf-compiler libprotobuf-dev
|
2020-12-16 05:29:11 +01:00
|
|
|
|
|
|
|
# If you need to build opencv from source.
|
|
|
|
$ sudo apt install cmake
|
2020-12-10 04:13:05 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
macOS:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ brew install protobuf
|
2020-12-16 05:29:11 +01:00
|
|
|
|
|
|
|
# If you need to build opencv from source.
|
|
|
|
$ brew install cmake
|
2020-12-10 04:13:05 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Windows:
|
|
|
|
|
|
|
|
Download the latest protoc win64 zip from
|
|
|
|
[the Protobuf GitHub repo](https://github.com/protocolbuffers/protobuf/releases),
|
|
|
|
unzip the file, and copy the protoc.exe executable to a preferred
|
|
|
|
location. Please ensure that location is added into the Path environment
|
|
|
|
variable.
|
|
|
|
|
|
|
|
3. Activate a Python virtual environment.
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ python3 -m venv mp_env && source mp_env/bin/activate
|
|
|
|
```
|
|
|
|
|
|
|
|
4. In the virtual environment, go to the MediaPipe repo directory.
|
|
|
|
|
|
|
|
5. Install the required Python packages.
|
|
|
|
|
|
|
|
```bash
|
|
|
|
(mp_env)mediapipe$ pip3 install -r requirements.txt
|
|
|
|
```
|
|
|
|
|
|
|
|
6. Generate and install MediaPipe package.
|
|
|
|
|
|
|
|
```bash
|
|
|
|
(mp_env)mediapipe$ python3 setup.py gen_protos
|
|
|
|
(mp_env)mediapipe$ python3 setup.py install --link-opencv
|
|
|
|
```
|
2020-12-16 05:29:11 +01:00
|
|
|
|
|
|
|
or
|
|
|
|
|
|
|
|
```bash
|
|
|
|
(mp_env)mediapipe$ python3 setup.py gen_protos
|
|
|
|
(mp_env)mediapipe$ python3 setup.py bdist_wheel
|
|
|
|
```
|