Skip to main content

A realtime Python interface for the Firmata procotol

Project description

==========
pyFirmata2
==========

PyFirmata2 is an API which allows you to sample
analogue and digital ports of your Arduino without
writing any C code. Just upload the default firmata sketch
into your Arduino and you are all set.

The Python API is fully compatible with Firmata 2.1, and has some
functionality of version 2.2. It runs on Python 2.7, 3.3, 3.4, 3.5
and 3.6

.. _Firmata: http://firmata.org

pyFirmata2 is an updated version of pyFirmata where you can
measure at a given sampling rate which then allows digital
filtering, for example with a realtime IIR filter.


Installation
============

1. Upload firmata
-----------------

Upload the standard firmata sketch into your Arduino with
File -> Examples -> Firmata -> Standard Firmata.


2. Install pyfirmata
--------------------

The preferred way to install is with pip_::

pip3 install pyfirmata2

You can also install from source with ``python setup.py install``. You will
need to have `setuptools`_ installed::

git clone https://github.com/berndporr/pyFirmata2
cd pyFirmata2
python3 setup.py install

.. _pip: http://www.pip-installer.org/en/latest/
.. _setuptools: https://pypi.python.org/pypi/setuptools


Usage
=====

Initialisation
--------------

Specify serial USB port in the constructor of `Arduino`::

>>> from pyfirmata import Arduino
>>> board = Arduino('/dev/ttyACM0')

Writing to a digital pin
------------------------

Digital ports can written to any time::

>>> board.digital[13].write(1)

Starting sampling at a given sampling interval
----------------------------------------------

In order to measure analoge data you need to specify a
sampling interval in ms. The smallest reliable interval is 10ms.

>>> board.samplingOn(samplinginterval in ms)

Calling `samplingOn()` without its argument sets
the sampling interval to 19ms.

Enabling and reading from individual analoge pins
-------------------------------------------------

In order to process the data at the given sampling interval register a callback
handler and then enable it::

>>> board.analog[0].register_callback(myCallback)
>>> board.analog[0].enable_reporting()

where `myCallback(data)` is then called every time after data has been received
and is timed by the arduino itself.


If you are not interested in the timing you can read
the analoge value of a port any time by issuing a read
command:

>>> board.analog[0].enable_reporting()
>>> board.analog[0].read()
0.661440304938

Still, the value will only be updated at the given sampling rate.


If you use a pin more often, it can be worth using the ``get_pin`` method
of the board. It let's you specify what pin you need by a string, composed of
'a' or 'd' (depending on wether you need an analog or digital pin), the pin
number, and the mode ('i' for input, 'o' for output, 'p' for pwm). All
seperated by ``:``. Eg. ``a:0:i`` for analog 0 as input or ``d:3:p`` for
digital pin 3 as pwm.::

>>> analog_0 = board.get_pin('a:0:i')
>>> analog_0.read()
0.661440304938
>>> pin3 = board.get_pin('d:3:p')
>>> pin3.write(0.6)


Example code
============

The subdirectory ``examples`` contains::

1. a realtime Oscillsocope using matplotlib,
2. a digital port reader and
3. a program which prints data using the callback handler.


Board layout
============

If you want to use a board with a different layout than the standard Arduino
or the Arduino Mega (for which there exist the shortcut classes
``pyfirmata.Arduino`` and ``pyfirmata.ArduinoMega``), instantiate the Board
class with a dictionary as the ``layout`` argument. This is the layout dict
for the Mega for example::

>>> mega = {
... 'digital' : tuple(x for x in range(54)),
... 'analog' : tuple(x for x in range(16)),
... 'pwm' : tuple(x for x in range(2,14)),
... 'use_ports' : True,
... 'disabled' : (0, 1, 14, 15) # Rx, Tx, Crystal
... }

Credits
=======

The original pyFirmata has been written by Tino de Bruijn.
The realtime sampling / callback has been added by Bernd Porr.

Project details


Download files

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

Source Distribution

pyFirmata2-0.9.2.tar.gz (15.0 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page