Skip to content

BCDA-APS/bs_model_instrument

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Model Package for Bluesky Instrument Minimal Installation

Model of a Bluesky Data Acquisition Instrument in console, notebook, & queueserver.

Installation

Clone the repository.

git clone [email protected]:BCDA-APS/bs_model_instrument.git
cd bs_model_instrument

Set up the development environment.

export ENV_NAME=bs_model_env
conda create -y -n $ENV_NAME python=3.11 pyepics
conda activate $ENV_NAME
pip install -e ."[all]"

IPython console

To start the bluesky instrument session in a ipython execute the next command in a terminal:

ipython

Inside the ipython console execute:

from instrument.startup import *

Jupyter notebook

Start JupyterLab, a Jupyter notebook server, or a notebook, VSCode.

Start the data acquisition:

from instrument.startup import *

Sim Plan Demo

To run some simulated plans that ensure the installation worked as expected please run the next commands inside an ipython session or a jupyter notebook after starting the data acquisition:

RE(sim_print_plan())
RE(sim_count_plan())
RE(sim_rel_scan_plan())

See this example.

Configuration files

The files that can be configured to adhere to your preferences are:

  • configs/iconfig.yml - configuration for data collection
  • configs/logging.yml - configuration for session logging to console and/or files
  • qserver/qs-config.yml - contains all configuration of the QS host process. See the documentation for more details of the configuration.

queueserver

The queueserver has a host process that manages a RunEngine. Client sessions will interact with that host process.

Run a queueserver host process

Use the queueserver host management script to start the QS host process. The restart option stops the server (if it is running) and then starts it. This is the usual way to (re)start the QS host process. Using restart, the process runs in the background.

./qserver/qs_host.sh restart

Run a queueserver client GUI

To run the gui client for the queueserver you can use the next command inside the terminal:

queue-monitor &

Shell script explained

A shell script is used to start the QS host process. Below are all the command options, and what they do.

(bstest) $ ./qserver/qs_host.sh help
Usage: qs_host.sh {start|stop|restart|status|checkup|console|run} [NAME]

    COMMANDS
        console   attach to process console if process is running in screen
        checkup   check that process is running, restart if not
        restart   restart process
        run       run process in console (not screen)
        start     start process
        status    report if process is running
        stop      stop process

    OPTIONAL TERMS
        NAME      name of process (default: bluesky_queueserver-)

Alternatively, run the QS host's startup command directly within the ./qserver/ subdirectory.

cd ./qserver
start-re-manager --config=./qs-config.yml

Testing

Use this command to run the test suite locally:

pytest -vvv --lf ./src

Documentation

prerequisite

To build the documentation locally, install pandoc in your conda environment:

conda install conda-forge::pandoc

Use this command to build the documentation locally:

make -C docs clean html

Once the documentation builds, view the HTML pages using your web browser:

BROWSER ./docs/build/html/index.html &

Adding to the documentation source

The documentation source is located in files and directories under ./docs/source. Various examples are provided.

Documentation can be added in these formats: .rst (reStructured text), .md (markdown), and .ipynb (Jupyter notebook). For more information, see the Sphinx documentation.

Warnings

Bluesky Queueserver

The QS host process writes files into the qserver/ directory. This directory can be relocated. However, it should not be moved into the instrument package since that might be installed into a read-only directory.

How-To Guides

How to use the template

Consider renaming this instrument package to be more clear that is specific to this instrument. This will be the name by which it is pip installed and also used with import. Let's use an example instrument package name my_instrument below to show which parts are edited.

  1. Click on use as template button
  2. Adjust the following parameters in the following files:
    • pyproject.toml
      • [project] name = example: my_instrument
      • [project.urls] change URLs for your repo
      • [tool.setuptools] package-dir = {"instrument" = "src/instrument"} example: {"my_instrument" = "src/instrument"}
    • src/instrument/init.py
      • __package__ = "instrument" example: "my_instrument"
    • src/instrument/configs/iconfig.yml
      • DATABROKER_CATALOG: change from temp to your catalog's name
      • beamline_id: one word beamline name (such as known by APS scheduling system)
      • instrument_name: descriptive name of your beamline
      • DM_SETUP_FILE: Path to DM bash setup file, comment out if you do not have
      • BEC: adjust for your preferences
    • qserver/qs-config.yml
      • startup_module: instrument.startup example: my_instrument.startup
    • docs/source/conf.py
      • import instrument example import my_instrument
      • project = "instrument" example: "my_instrument"
      • version = instrument.__version__ example: my_instrument.__version__

About

Model of a Bluesky Data Acquisition Instrument in console, notebook, & queueserver.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •