A hypermodern, type-safe, zero-dependency python library for the Boltwood II & III cloud sensors.
Project description
Boltwood
Modern, type-safe, zero-dependency python library for controlling the Boltwood III observing conditions sensor.
Installation
uv add boltwood
or
using your preferred environment / package manager of choice, e.g., poetry, conda or pip:
pip install boltwood
poetry add boltwood
conda install boltwood
Usage
To use the conditions monitor, you need to create an instance of the BoltwoodIIIConditionsMonitorDeviceInterface class with the appropriate parameters.
Below is a simple example of how to set up and use the Boltwood III Conditions Monitor:
from boltwood import (
BoltwoodIIIConditionsMonitorDeviceInterface,
BoltwoodIIIConditionsMonitorDeviceParameters,
)
# Define the parameters for the BoltwoodIII monitor device:
params: BoltwoodIIIConditionsMonitorDeviceParameters = BoltwoodIIIConditionsMonitorDeviceParameters(
name="Boltwood III Conditions Monitor",
description="Boltwood III Conditions Monitor",
port="/dev/ttyUSB0", # Replace with your actual port
baudrate=9600,
latitude=33.87047,
longitude=-118.24708,
elevation=0.0,
did="0", # Device ID
vid="067b", # Vendor ID
pid="23a3", # Product ID
)
# Create a new Boltwood III Conditions Monitor device interface:
monitor = BoltwoodIIIConditionsMonitorDeviceInterface(
id=0,
params=params,
)
# Initialise the monitor:
monitor.initialise()
# Get the current status of the monitor:
status = monitor.get_status()
...
To use the safety monitor, you can create an instance of the BoltwoodIIISafetyMonitorDeviceInterface class in a similar way:
from boltwood import (
BoltwoodIIISafetyMonitorDeviceInterface,
BoltwoodIIISafetyMonitorDeviceParameters,
)
# Define the parameters for the BoltwoodIII safety monitor device:
params: BoltwoodIIISafetyMonitorDeviceParameters = BoltwoodIIISafetyMonitorDeviceParameters(
name="Boltwood III Safety Monitor",
description="Boltwood III Safety Monitor",
port="/dev/ttyUSB0", # Replace with your actual port
baudrate=9600,
did="0", # Device ID
vid="067b", # Vendor ID
pid="23a3", # Product ID
)
# Create a new Boltwood III Safety Monitor device interface:
safety_monitor = BoltwoodIIISafetyMonitorDeviceInterface(
id=0,
params=params,
)
# Initialise the safety monitor:
safety_monitor.initialise()
# Get the current status of the safety monitor:
status = safety_monitor.get_status()
...
As the boltwood instance is fully typed, you can use your IDE's autocompletion to see all the available methods and properties.
We have also provided further usage examples in the examples directory.
Milestones
- Type-safe modern 3.6+ Python
- Fully unit tested
- Simpler API (modelled around the ASCOM Alpaca API)
- Integration testing with HIL testing (hardware-in-the-loop)
- Zero-external dependencies (no numpy, astropy etc for portability)
- Example API usage
- Fully supported Observing Conditions Sensor operations
- Fully supported Safety Monitor operations
- Fully supported Alert Threshold operations
- ASCOM Alpaca APIs w/Fast API
Disclaimer
This project is not affiliated with Diffraction Limited in any way. It is a community-driven project. All trademarks and logos are the property of their respective owners.
License
This project is licensed under the terms of the MIT license.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file boltwood-0.3.0.tar.gz.
File metadata
- Download URL: boltwood-0.3.0.tar.gz
- Upload date:
- Size: 39.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8db3d932dd5e3f7ee6c78dc23822a8e360d1b7ab72d5cc4761d53bebeb50639e
|
|
| MD5 |
c784e3c9fffca874218ce2a0e24602df
|
|
| BLAKE2b-256 |
d4a8ebf4e1baafb7835590e5e95a62549e550a5e633901eec9fde34b914f1f9e
|
Provenance
The following attestation bundles were made for boltwood-0.3.0.tar.gz:
Publisher:
publish.yml on michealroberts/boltwood
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
boltwood-0.3.0.tar.gz -
Subject digest:
8db3d932dd5e3f7ee6c78dc23822a8e360d1b7ab72d5cc4761d53bebeb50639e - Sigstore transparency entry: 957439210
- Sigstore integration time:
-
Permalink:
michealroberts/boltwood@1b65a535788e8c48f1a89139167aff27e86234c3 -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/michealroberts
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1b65a535788e8c48f1a89139167aff27e86234c3 -
Trigger Event:
release
-
Statement type:
File details
Details for the file boltwood-0.3.0-py3-none-any.whl.
File metadata
- Download URL: boltwood-0.3.0-py3-none-any.whl
- Upload date:
- Size: 22.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e9c47bbdd665fc052295a86da78189cca3ec24aa717976e94e0a2ff31fdf79ab
|
|
| MD5 |
b739525c3489a87e6fcdd3098eecfcda
|
|
| BLAKE2b-256 |
cd6ce7303c6d4618a4a9e8a82b988a76bdf8b56735d8bf0993716efe9ced8232
|
Provenance
The following attestation bundles were made for boltwood-0.3.0-py3-none-any.whl:
Publisher:
publish.yml on michealroberts/boltwood
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
boltwood-0.3.0-py3-none-any.whl -
Subject digest:
e9c47bbdd665fc052295a86da78189cca3ec24aa717976e94e0a2ff31fdf79ab - Sigstore transparency entry: 957439211
- Sigstore integration time:
-
Permalink:
michealroberts/boltwood@1b65a535788e8c48f1a89139167aff27e86234c3 -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/michealroberts
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1b65a535788e8c48f1a89139167aff27e86234c3 -
Trigger Event:
release
-
Statement type: