Skip to main content

A lightweight python package to simplify the communication with several scientific instruments.

Project description

Slave is a micro framework designed to simplify instrument communication and control and comes with a variety of ready to use device drivers.

Overview

Slave provides an intuitive way of creating instrument api’s, inspired by object relational mappers.

from slave.iec60488 import IEC60488, PowerOn
from slave.driver import Command
from slave.types import Integer, Enum

class Device(IEC60488, PowerOn):
    """An iec60488 conforming device api with additional commands."""
    def __init__(self, transport):
        super(Device, self).__init__(transport)
        # A custom command
        self.my_command = Command(
            'QRY?', # query message header
            'WRT',  # command message header
            # response and command data type
            [Integer, Enum('first', 'second')]
        )

Commands mimic instance attributes. Read access queries the device, parses and converts the response and finally returns it. Write access parses and converts the arguments and sends them to the device. This leads to very intuitive interfaces.

Several device drivers are already implemented, and many more are under development. A short usage example is given below:

import time
from slave.transport import Visa
from slave.srs import SR830

lockin = SR830(Visa('GPIB::08'))
# configure the lockin amplifier
lockin.reserve = 'high'
lockin.time_constant = 3
# take 60 measurements and print the result
for i in range(60):
    print lockin.x
    time.sleep(1)

Requirements

  • Python 2.6 or higher

  • Sphinx (optional, to build the documentation)

  • sphinx_bootstrap_theme(optional, default theme used for the documentation)

  • distribute (Python 3.x)

Installation

To install Slave, simply type

python setup.py install

Documentation

Slave is fully documented. Both the latest stable as well as the develop documentations are available online. To build the documentation manually, e.g. the html documentation, navigate into the /doc/ subfolder and execute make html. For a prettier theme, install sphinx_boostrap_theme first (pip install sphinx_bootstrap_theme).

Licensing

You should have received a copy of the GNU General Public License along with slave; see the file COPYING.

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

slave-0.4.0.tar.gz (136.5 kB view details)

Uploaded Source

File details

Details for the file slave-0.4.0.tar.gz.

File metadata

  • Download URL: slave-0.4.0.tar.gz
  • Upload date:
  • Size: 136.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for slave-0.4.0.tar.gz
Algorithm Hash digest
SHA256 11717d87d7ef2d289a792ed71b64aa8ba074a810e3d61b0ae657bfe49f136a92
MD5 ec052dd7c3f4dda8a4bc16983f769a41
BLAKE2b-256 b5776830a81bad766034f34fbad9ae9543e1a905df60180a298ba287054f5bf5

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