Skip to main content

Asynchronous Bluesky hardware abstraction code, compatible with control systems like EPICS and Tango

Project description

CI Coverage PyPI License

ophyd-async

Ophyd-async is a Python library for asynchronously interfacing with hardware, intended to be used as an abstraction layer that enables experiment orchestration and data acquisition code to operate above the specifics of particular devices and control systems.

What Where
Source https://github.com/bluesky/ophyd-async
PyPI pip install ophyd-async
Documentation https://bluesky.github.io/ophyd-async
Releases https://github.com/bluesky/ophyd-async/releases

Both ophyd sync and ophyd-async are typically used with the Bluesky Run Engine for experiment orchestration and data acquisition.

The main differences from ophyd sync are:

  • Asynchronous Signal access, simplifying the parallel control of multiple Signals
  • Support for EPICS PVA and Tango as well as the traditional EPICS CA
  • Better library support for splitting the logic from the hardware interface to avoid complex class heirarchies

It was written with the aim of implementing fly scanning in a generic and extensible way with highly customizable devices like PandABox and the Delta Tau PMAC products. Using async code makes it possible to do the "put 3 PVs in parallel, then get from another PV" logic that is common in fly scanning without the performance and complexity overhead of multiple threads.

Devices from both ophyd sync and ophyd-async can be used in the same RunEngine and even in the same scan. This allows a per-device migration where devices are reimplemented in ophyd-async one by one.

See https://bluesky.github.io/ophyd-async for more detailed documentation.

Project details


Release history Release notifications | RSS feed

This version

0.18

Download files

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

Source Distribution

ophyd_async-0.18.tar.gz (565.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ophyd_async-0.18-py3-none-any.whl (211.7 kB view details)

Uploaded Python 3

File details

Details for the file ophyd_async-0.18.tar.gz.

File metadata

  • Download URL: ophyd_async-0.18.tar.gz
  • Upload date:
  • Size: 565.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ophyd_async-0.18.tar.gz
Algorithm Hash digest
SHA256 5a6cda1e34f9d137b235ee730266713351f0619ffe66d141e57d6b0618f66260
MD5 c4c89ff8ae94e48b62c7625c0ce55f0d
BLAKE2b-256 51d82e739ac3243dc4cbdbe2835c82a4f78419016d6bf6d503fdb68b8ae0e55c

See more details on using hashes here.

File details

Details for the file ophyd_async-0.18-py3-none-any.whl.

File metadata

  • Download URL: ophyd_async-0.18-py3-none-any.whl
  • Upload date:
  • Size: 211.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ophyd_async-0.18-py3-none-any.whl
Algorithm Hash digest
SHA256 3c5d0924286b18e7ec579d9849147d7fe7e3dcc4621e3caf19bb853cf7c24d0f
MD5 6df0162352bf038ba10a2856874b6cfa
BLAKE2b-256 cd75cf84ce11f860acade0b6f5b54182c70d61fea7d5e8bc0013b4ece9af6787

See more details on using hashes here.

Supported by

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