Skip to main content

Python Package to interface with Radio Shack's 2200087 Multimeter

Project description

This is a Python Package to interface with Radio Shack’s 2200087 Multimeter.

The 2200087 is an inexpensive DMM which supports logging and graphing data on a computer, but the supplied code only supports Windows. This is a python package to allow for connecting to the multimeter over USB on Linux or Mac OSX. Due to radioshack not supplying any serial specifications, the protocol was reverse engineered by David Dworken from simply observing the output of the DMM.

The serialDecoder module and the serial protocol documentation is essentially a slightly tweaked version of the script written and maintained by David Dworken, available at https://github.com/ddworken/2200087-Serial-Protocol.git

This package includes a version of the serialDecoder module, slightly refactored to allow it to be imported into other python scripts. It also includes a runner module which contains a Twisted protocol, wrapped by Crochet. This module should be relatively easier to include into other python scripts and applications.

Installation

This package has been tested only with python 2.7.

This package can be installed from pypi using pip:

$ pip install driver2200087

Or using easy_install (python 2.7 only):

$ easy_install driver2200087

Usage

Standalone usage is listed in the documentation, and should be fairly straightforward to follow.

The serialDecoder module can also be imported and used from within a python script, and the documentation can help you use it in that manner.

The recommended way for using the package, though, is through the runner module which it provides. The simpler form of use is to get the latest available value whenever necessary. A short example of how this can be done using this package in a typical python application would be

from driver2200087 import runner

dmm = runner.InstInterface2200087()
dmm.connect()

# Other Application code
# ...
#
# And when the measurement is required :

if dmm.data_available() > 0:
    print dmm.latest_point()
else:
    raise Exception # Or pass, or retry, as per application requirements

# other application code
# ...

If the application calls for continuous recording of the data, the following is likely a better approach

from driver2200087 import runner

dmm = runner.InstInterface2200087()
dmm.connect()
while True:
    if dmm.data_available() > 0:
        print dmm.next_point()

Note that in this code snippet, the python interpreter is blocked by the infinite while loop. This is not required by the module. As long as dmm.next_point() is called often enough (10 Hz), you can use whatever mechanism you like to actually make the call. Note that dmm.data_available() must be checked by your application before making the call, or you should trap the exception that results.

Making the call at less than this frequency will cause data points to be lost when the point buffer fills up - if your application only calls for the occasional measurement, you’re probably better off with dmm.latest_point() instead.

For an example of using the runner module from within a larger framework by subclassing the provided twisted protocol, see the corresponding Tendril module. The Tendril module, while WIP, also includes examples of parsing the obtained datapoint strings into usable values.

Downloads and Documentation

The simplest way to obtain the source for this package is to clone the git repository:

git clone https://github.com/chintal/driver2200087.git driver2200087

You can install it as usual, with:

python setup.py install

The latest version of the documentation can be found at ReadTheDocs.

License

driver2200087 is distributed under the GPLv2 license.

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

driver2200087-0.6.1.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

driver2200087-0.6.1-py2-none-any.whl (17.1 kB view details)

Uploaded Python 2

File details

Details for the file driver2200087-0.6.1.tar.gz.

File metadata

File hashes

Hashes for driver2200087-0.6.1.tar.gz
Algorithm Hash digest
SHA256 830ffd3ad21b49c666437a6e086fbb87312ee9407001b5cece0904ef2c9ad023
MD5 cb3baab9e62f4f7bd728ff7858292469
BLAKE2b-256 44b02e9b9e9fda4b19b350cafa92a2bec05d39a6d9e1ad60b22e0ec558806ae5

See more details on using hashes here.

File details

Details for the file driver2200087-0.6.1-py2-none-any.whl.

File metadata

File hashes

Hashes for driver2200087-0.6.1-py2-none-any.whl
Algorithm Hash digest
SHA256 e48de7ea08eef3b9f6b425a4bbfa2b807119d183747bb7ea74d85273b4706caa
MD5 5a712dab05d1becd024ec0422fece823
BLAKE2b-256 967d83226ec779693a3b6613f5619b00fb525ba42a5c1c6fe4b1a6715171fd45

See more details on using hashes here.

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