Skip to main content

Python Library for Robot Control

Project description

[![PyPI](]( [![Build Status](]( [![DOI](](

# Pypot: A Python lib for Dynamixel motors control

Pypot is a library developed in the [inria FLOWERS]( team to make it easy and fast to control custom robots based on dynamixel motors. This framework provides different levels of abstraction corresponding to different types of use. More precisely, you can use pypot to:

  • directly control robotis motors (both protocol v1 and v2 are supported) through a USB2serial device,
  • define the structure of your particular robot and control it through high-level commands,
  • define primitives and easily combine them to create complex behavior.

Pypot has been entirely written in Python to allow for fast development, easy deployment and quick scripting by non-necessary expert developers. It can also benefits from the scientific and machine learning libraries existing in Python. The serial communication is handled through the standard library and thus allows for rather high performance (10ms sensorimotor loop). It is crossed-platform and has been tested on Linux, Windows and Mac OS.

Pypot is also compatible with the [V-REP simulator]( This allows you to seamlessly switch from a real robot to its simulated equivalent without having to modify your code.

Finally, it has been developed to permit an easy and fast extension to other types of motors and sensors.

## The Poppy-project: open source

Pypot is part of the [Poppy project]( aiming at developing robotic creations that are easy to build, customize, deploy, and share. It promotes open-source by sharing hardware, software, and web tools.

At the moment we already proposed a few Poppy Creatures:

![Poppy Humanoid](./doc/poppy-creatures.jpg)

All those creatures are based on a combination of standard dynamixel actuators, 3D printed parts and open-source electronics such as Arduino boards. Both the hardware (3D models, electronics…) and software can be freely used, modified and duplicated.

## Documentation

The full pypot documentation on a html format can be found [here]( It provides tutorials, examples and a complete API.

The documentation is slowly moving toward [Jupyter Notebooks]( are they are such a powerful tool for writing and sharing tutorials, experiments or pedagogical contents.

They can be found [here]( with a detailed explanation on how they can be used, installed, and modified.

## Installation

Pypot is a library entirely written in [Python]( It works with Python 2.7, 3.3+ and pypy-2.5. It is crossed platform and has been tested on Windows, Mac, Linux - yet specific usb to serial driver may be required depending on your system (see below).

Pypot also requires the following python package: * [pyserial]( 2.6 (or later) * [numpy]( * [scipy](

You can build and install pypot with the typically python way:

cd pypot python install

or directly via [pip](

pip install pypot

You will also have to install the driver for the USB2serial port. There are a few devices that have been tested with pypot that could be used:

  • USB2AX - this device is designed to manage TTL communication only
  • USB2Dynamixel - this device can manage both TTL and RS485 communication.
  • [Pixl board]( for RaspberryPi

For more details on the installation procedure, please refer to the [installation section]( of the documentation.

## Roadmap

The roadmap of the project can be found [here](

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for pypoticia, version 3.2.0
Filename, size File type Python version Upload date Hashes
Filename, size pypoticia-3.2.0.tar.gz (422.1 kB) File type Source Python version None Upload date Hashes View

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring DigiCert DigiCert EV certificate Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page