Skip to main content

Module for communicating with TDT's System 3 hardware

Project description

https://zenodo.org/badge/doi/10.5281/zenodo.17651.svg

TDTPy is a Python wrapper around Tucker-Davis Technologies ActiveX library [PDF link] (known as RPcoX) for communicating with their System 3 hardware (e.g. the RP2.1, RX6, RZ6, etc.).

In addition to the standard operations (loading circuits, configuring tags and reading/writing to hardware buffers), TDTPy offers a number of high-level features that are not included in the ActiveX library:

  • Handling type conversion between analog and digital units (e.g. converting seconds to number of DSP cycles based on the CPU frequency of the hardware).

  • Remote procedure call (RPC) server for allowing multiple processes and/or programs to communicate with the hardware across the same connection. The drivers provided by TDT do not handle concurrency issues. To handle these issues, we have created a RPC server that handles concurrency issues, allowing multiple programs to talk to the hardware simultaneously. The programs can either run on the same computer or on a separate computer.

  • If you use the RPC server, your client code can run on any platform (e.g. Mac OSX, Unix, Solaris, etc); however, the server must run on a Windows-based computer.

  • Simple reads and writes. The hardware buffers are implemented as “ring buffers” with various features such as multichannel storage and data compression. TDTPy automatically detects the configuration of the hardware buffer and returns a buffer object (DSPBuffer) that you can read/write to without having to deal with the intricacies of the hardware buffer itself.

  • Robust error handling. Some methods in the ActiveX library will fail silently (e.g. if you try to access a nonexistent tag, attempt to write more data than the hardware buffer can hold, or wire up a tag to a static port). When the RPvds circuit is first loaded to the hardware, TDTPy will inspect the microcode (i.e. the RPvds circuit) and store some information about the tags and buffers available. All subsequent operations are validated against this metadata before being passed to the ActiveX library. If an invalid operation is attempted, a DSPError is raised with the appropriate message.

The minimum required dependencies to run the software are:

  • Python >= 3.7

  • NumPy >= 1.8

  • pywin32

License

TDTPy is distributed under the BSD license.

Contributors

  • Brad Buran (New York University, Oregon Health & Science University)

  • Eric Larson (University of Washington)

  • Decibel Therapeutics, Inc.

Source code: http://github.com/LABSN/tdtpy

Documentation: http://tdtpy.readthedocs.org

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

TDTPy-0.9.0.tar.gz (346.3 kB view details)

Uploaded Source

Built Distribution

TDTPy-0.9.0-py3-none-any.whl (358.3 kB view details)

Uploaded Python 3

File details

Details for the file TDTPy-0.9.0.tar.gz.

File metadata

  • Download URL: TDTPy-0.9.0.tar.gz
  • Upload date:
  • Size: 346.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.7.4

File hashes

Hashes for TDTPy-0.9.0.tar.gz
Algorithm Hash digest
SHA256 e78fc9c5c624e60542d675f924cec13bb762a5d78d18e2462e62824a78c82b60
MD5 14369d0326c25ae800a4c1fcccc64ca4
BLAKE2b-256 47ce59fd9d6fc6f8bb9d1052d51260592db889b1ae23b74fa9ec9f1eb0c9801a

See more details on using hashes here.

File details

Details for the file TDTPy-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: TDTPy-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 358.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.7.4

File hashes

Hashes for TDTPy-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 435d1160f7589614a0b6e3959bb027833d415a95b6dc9df4445da7457f6ca42a
MD5 dcc8067b32a65195b443d257bdbe82f6
BLAKE2b-256 3588127ded6b59dd0cc30ca83869d85ecc27a793957d4ab652f52712ea26a720

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