Provides hardware device integrations for bussdcc.
Project description
BussDCC Hardware
bussdcc-hardware provides hardware device integrations for bussdcc.
It includes drivers for common buses and devices and exposes them through the BussDCC device system so they can be managed, monitored, and orchestrated by the runtime.
Architecture
Hardware in BussDCC is modeled as devices in a dependency graph. Bus devices are one common kind of dependency node.
Runtime
├── Bus Devices
│ ├── I2C Bus
│ ├── 1-Wire Bus
│ └── GPIO Bus
│
└── Hardware Devices
├── Sensors
├── ADCs
├── Cameras
└── Actuators
Each hardware component is represented as a BussDCC Device with a managed lifecycle:
connect → operate → disconnect
The runtime handles:
- device initialization
- dependency ordering
- failure detection
- online/offline status
Features
Bus Drivers
Hardware buses are modeled as devices themselves.
Currently supported:
I²C
bussdcc_hardware.bus.i2c
Features:
- bus discovery
- device address scanning
- register bus interface
1-Wire
bussdcc_hardware.bus.w1
Features:
- device discovery
- filesystem-based device access
Hardware Devices
NAU7802 Load Cell ADC
High precision load cell amplifier.
bussdcc_hardware.device.nau7802
Features:
- dual channel support
- calibration parameters
- automatic channel switching
- failure detection
DS18B20 Temperature Sensor
1-Wire temperature sensor.
bussdcc_hardware.device.ds18b20
Features:
- filesystem-based reading
- automatic offline detection
USB Camera
OpenCV-based camera integration.
bussdcc_hardware.device.usb_camera
Features:
- configurable resolution and FPS
- exposure control
- focus control
- white balance control
- automatic failure recovery
Digital Output
Simple GPIO-based actuator for controlling devices such as pumps, relays, LEDs, or lights.
bussdcc_hardware.device.digital_output
Features:
- on/off control
- safe shutdown
Device Configuration
All devices use typed dataclass configurations.
Example:
from bussdcc_hardware.device.nau7802 import NAU7802Config
config = NAU7802Config(
bus_id="i2c0",
addr=0x2A,
)
Configuration metadata includes UI hints:
- labels
- groups
- help text
- numeric constraints
- dependency references
This allows configuration systems or web interfaces to automatically generate forms.
Example metadata:
{
"label": "Frame Width",
"group": "Video",
"min": 160,
"max": 3840
}
Device Discovery
Hardware integrations are registered using Python entry points.
bussdcc.device
The registry loads available devices automatically:
from bussdcc_hardware.registry import registry
registry.devices
Unavailable drivers (missing optional dependencies) are detected and reported.
Optional Dependencies
Some hardware drivers require additional libraries.
Install them using extras:
pip install bussdcc-hardware[nau7802]
pip install bussdcc-hardware[digital_output]
pip install bussdcc-hardware[usb_camera]
Example
Example hardware configuration:
runtime.add_device(
"i2c0",
"i2c",
{
"bus": 1
}
)
runtime.add_device(
"scale_adc",
"nau7802",
{
"bus_id": "i2c0",
"addr": 0x2A
}
)
The runtime attaches devices in dependency order.
Design Goals
Hardware as first-class devices
Buses and sensors are modeled the same way as any other BussDCC device.
Runtime-managed lifecycle
Devices automatically:
- connect
- report failures
- recover when possible
Strong typing
All configurations are statically typed dataclasses.
Composable integrations
Hardware modules can be distributed as independent packages and discovered through entry points.
Installation
pip install bussdcc-hardware
Optional drivers:
pip install bussdcc-hardware[nau7802]
pip install bussdcc-hardware[digital_output]
pip install bussdcc-hardware[usb_camera]
Related Projects
- bussdcc — cybernetic runtime kernel
- bussdcc-framework — runtime utilities and web interface
License
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 bussdcc_hardware-0.31.0.tar.gz.
File metadata
- Download URL: bussdcc_hardware-0.31.0.tar.gz
- Upload date:
- Size: 23.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
287caa735223e50486a76f2de2c347aa435c2ff08f165cdbd52fcb2abe172961
|
|
| MD5 |
0d9c03b4e1aca09c3651f939daf3a99f
|
|
| BLAKE2b-256 |
b94db64362ec35b9e9a753490926c80ed60ae83a07866dfc6f864703b312d612
|
File details
Details for the file bussdcc_hardware-0.31.0-py3-none-any.whl.
File metadata
- Download URL: bussdcc_hardware-0.31.0-py3-none-any.whl
- Upload date:
- Size: 29.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b43723a4a2bd2a148911aa09a5b4cebfa76f4fca35b1d2ceaa4beb00fd65c7fa
|
|
| MD5 |
9f27f8fe66c7276a6a91264c329b334b
|
|
| BLAKE2b-256 |
5c02ed3f02c7a57c5e61928dd0395bbe455af6aea8322fa04cb888d899777f90
|