Model of a Bluesky Data Acquisition Instrument in console, notebook, & queueserver.
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]"
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 *
Start JupyterLab, a Jupyter notebook server, or a notebook, VSCode.
Start the data acquisition:
from instrument.startup import *
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.
The files that can be configured to adhere to your preferences are:
configs/iconfig.yml
- configuration for data collectionconfigs/logging.yml
- configuration for session logging to console and/or filesqserver/qs-config.yml
- contains all configuration of the QS host process. See the documentation for more details of the configuration.
The queueserver has a host process that manages a RunEngine. Client sessions will interact with that 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
To run the gui client for the queueserver you can use the next command inside the terminal:
queue-monitor &
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
Use this command to run the test suite locally:
pytest -vvv --lf ./src
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 &
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.
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.
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.
- Click on use as template button
- 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 fromtemp
to your catalog's namebeamline_id:
one word beamline name (such as known by APS scheduling system)instrument_name:
descriptive name of your beamlineDM_SETUP_FILE:
Path to DM bash setup file, comment out if you do not haveBEC:
adjust for your preferences
qserver/qs-config.yml
startup_module: instrument.startup
example:my_instrument.startup
docs/source/conf.py
import instrument
exampleimport my_instrument
project = "instrument"
example:"my_instrument"
version = instrument.__version__
example:my_instrument.__version__