Coder Social home page Coder Social logo

ruslanagishev / crazyflie-lib-python Goto Github PK

View Code? Open in Web Editor NEW

This project forked from bitcraze/crazyflie-lib-python

0.0 1.0 0.0 154.53 MB

Python library to communicate with Crazyflie

License: Other

Makefile 3.28% Python 79.64% Shell 0.85% PowerShell 0.06% CMake 2.56% C 0.72% C++ 1.05% Jupyter Notebook 11.85%

crazyflie-lib-python's Introduction

cflib: Crazyflie python library Build Status

cflib is an API written in Python that is used to communicate with the Crazyflie and Crazyflie 2.0 quadcopters. It is intended to be used by client software to communicate with and control a Crazyflie quadcopter. For instance the cfclient Crazyflie PC client uses the cflib.

See below for platform specific instruction. For more info see our wiki.

Development

Developing for the cfclient

Note: If you are developing for the cfclient you must use python3. On Ubuntu (16.04, 18.08) use pip3 instead of pip.

Linux, OSX, Windows

The following should be executed in the root of the crazyflie-lib-python file tree.

Virtualenv

This section contains a very short description of how to use virtualenv (local python environment) with package dependencies. If you don't want to use virualenv and don't mind installing cflib dependencies system-wide you can skip this section.

  • Install virtualenv: pip install virtualenv

  • create an environment: virtualenv venv

  • Activate the environment: source venv/bin/activate

  • To deactivate the virtualenv when you are done using it deactivate

Note: For systems that support make, you can use make venv to create an environment, activate it and install dependencies.

Install cflib dependencies

Install dependencies required by the lib: pip install -r requirements.txt

To verify the installation, connect the crazyflie and run an example: python examples/basiclog

Testing

With docker and the toolbelt

For information and installation of the toolbelt.

  • Check to see if you pass tests: tb test
  • Check to see if you pass style guidelines: tb verify

Note: Docker and the toolbelt is an optional way of running tests and reduces the work needed to maintain your python environmet.

Native python on Linux, OSX, Windows

Tox is used for native testing: pip install tox

  • If test fails after installing tox with pip install tox, installing with sudo apt-get install toxresult a successful test run

  • Test package in python2.7 TOXENV=py27 tox

  • Test package in python3.4 TOXENV=py34 tox

  • Test package in python3.6 TOXENV=py36 tox

Note: You must have the specific python versions on your machine or tests will fail. (ie. without specifying the TOXENV, tox runs tests for python2.7, 3.3, 3.4 and would require all python versions to be installed on the machine.)

Platform notes

Linux

Setting udev permissions

The following steps make it possible to use the USB Radio without being root.

sudo groupadd plugdev
sudo usermod -a -G plugdev $USER

You will need to log out and log in again in order to be a member of the plugdev group.

Create a file named /etc/udev/rules.d/99-crazyradio.rules and add the following:

# Crazyradio (normal operation)
SUBSYSTEM=="usb", ATTRS{idVendor}=="1915", ATTRS{idProduct}=="7777", MODE="0664", GROUP="plugdev"
# Bootloader
SUBSYSTEM=="usb", ATTRS{idVendor}=="1915", ATTRS{idProduct}=="0101", MODE="0664", GROUP="plugdev"

To connect Crazyflie 2.0 via usb, create a file name /etc/udev/rules.d/99-crazyflie.rules and add the following:

SUBSYSTEM=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="5740", MODE="0664", GROUP="plugdev"

You can reload the udev-rules using the following:

sudo udevadm control --reload-rules
sudo udevadm trigger

Contribute

Everyone is encouraged to contribute to the CrazyFlie library by forking the Github repository and making a pull request or opening an issue.

crazyflie-lib-python's People

Contributors

ataffanel avatar evoggy avatar fredg02 avatar kentwills avatar knmcguire avatar krichardsson avatar simonjwright avatar tobbeanton avatar whoenig avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.