Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/simonsobs/socs
Simons Observatory specific OCS agents.
https://github.com/simonsobs/socs
docker emulator library python
Last synced: 2 months ago
JSON representation
Simons Observatory specific OCS agents.
- Host: GitHub
- URL: https://github.com/simonsobs/socs
- Owner: simonsobs
- License: bsd-2-clause
- Created: 2019-05-13T23:52:37.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-05-21T17:45:39.000Z (8 months ago)
- Last Synced: 2024-05-22T15:35:39.761Z (8 months ago)
- Topics: docker, emulator, library, python
- Language: Python
- Homepage:
- Size: 10.1 MB
- Stars: 12
- Watchers: 25
- Forks: 11
- Open Issues: 100
-
Metadata Files:
- Readme: README.rst
- Contributing: CONTRIBUTING.rst
- License: LICENSE.txt
Awesome Lists containing this project
README
========================================
SOCS - Simons Observatory Control System
========================================| |pypi| |versions| |docker| |license|
| |tests| |pre-commit| |coverage| |docs|Overview
--------This repository, `SOCS`_, contains hardware control code for the
Simons Observatory. This code operates within the framework provided
by `OCS`_... _`OCS`: https://github.com/simonsobs/ocs/
.. _SOCS: https://github.com/simonsobs/socs/Installation
------------Install and update with pip::
$ pip3 install -U socs
You may install optional dependencies by including one or more agent group
names on installation, for example::$ pip3 install -U socs[labjack,synacc]
For a complete list of agent groups see the `Installation Documentation`_.
If you would like to install all optional dependencies use the special varient
"all"::$ pip3 install -U socs[all]
**Note:** Not all optional dependencies can be installed this way. See the
`Installation Documentation`_ for more info on specific agent dependencies... _`Installation Documentation`: https://socs.readthedocs.io/en/main/user/installation.html
Installing from Source
``````````````````````If you are considering contributing to SOCS, or would like to use an unreleased
feature, you will want to install from source. To do so, clone this repository
and install using pip:.. code-block:: bash
git clone https://github.com/simonsobs/socs.git
cd socs/
pip3 install -r requirements.txt
pip3 install .In order for OCS tools to find these agents, you must add the full
path to the agents directory, e.g. ``/home/simons/code/socs/agents/``,
to your OCS site config file. Do so by adding the following under your
configured host if it does not already exist:.. code-block:: yaml
# List of additional paths to Agent plugin modules.
'agent-paths': [
'/path/to/socs/agents/',
],See the `ocs docs`_ for more details.
.. _`ocs docs`: https://ocs.readthedocs.io/en/main/developer/site_config.html
Docker Images
-------------
Docker images for SOCS and each Agent are available on `Docker Hub`_. Official
releases will be tagged with their release version, i.e. ``v0.1.0``. These are
only built on release, and the ``latest`` tag will point to the latest of these
released tags. These should be considered stable.Test images will be tagged with the latest released version tag, the number of
commits ahead of that release, the latest commit hash, i.e.
``v0.0.2-81-g9c10ba6-dev``. These get built on each commit to the ``main``
branch, and are useful for testing and development, but should be considered
unstable... _Docker Hub: https://hub.docker.com/u/simonsobs
Documentation
-------------
The SOCS documentation can be built using Sphinx. There is a separate
``requirements.txt`` file in the ``docs/`` directory to install Sphinx and any
additional documentation dependencies::cd docs/
pip3 install -r requirements.txt
make htmlYou can then open ``docs/_build/html/index.html`` in your preferred web
browser. You can also find a copy hosted on `Read the Docs`_... _Read the Docs: https://socs.readthedocs.io/en/latest/
Tests
-----
The tests for SOCS are run using pytest, and should be run from the
``tests/`` directory::$ cd tests/
$ python3 -m pytest --covFor more details see `tests/README.rst `_.
.. _tests: https://github.com/simonsobs/socs/blob/main/tests/README.rst
Contributing
------------
For guidelines on how to contribute to OCS see `CONTRIBUTING.rst`_... _CONTRIBUTING.rst: https://github.com/simonsobs/socs/blob/main/CONTRIBUTING.rst
License
--------
This project is licensed under the BSD 2-Clause License - see the
`LICENSE.txt`_ file for details... _LICENSE.txt: https://github.com/simonsobs/socs/blob/main/LICENSE.txt
.. |coverage| image:: https://coveralls.io/repos/github/simonsobs/socs/badge.svg
:target: https://coveralls.io/github/simonsobs/socs.. |docker| image:: https://img.shields.io/badge/dockerhub-latest-blue
:target: https://hub.docker.com/r/simonsobs/socs.. |docs| image:: https://readthedocs.org/projects/socs/badge/?version=main
:target: https://socs.readthedocs.io/en/main/?badge=main
:alt: Documentation Status.. |license| image:: https://img.shields.io/pypi/l/socs
:target: LICENSE.txt
:alt: PyPI - License.. |pre-commit| image:: https://results.pre-commit.ci/badge/github/simonsobs/socs/main.svg
:target: https://results.pre-commit.ci/latest/github/simonsobs/socs/main
:alt: pre-commit.ci status.. |pypi| image:: https://img.shields.io/pypi/v/socs
:target: https://pypi.org/project/socs/
:alt: PyPI Package.. |tests| image:: https://github.com/simonsobs/socs/actions/workflows/develop.yml/badge.svg?branch=main
:target: https://github.com/simonsobs/socs/actions/workflows/develop.yml
:alt: GitHub Workflow Status.. |versions| image:: https://img.shields.io/pypi/pyversions/socs
:alt: PyPI - Python Version