A Python package for interacting with Bluetooth Low Energy (BLE) compatible bike trainers and power meters
Project description
pycycling
A Python package for interacting with Bluetooth Low Energy (BLE) compatible bike trainers and power meters.
The package uses Bleak (Bluetooth Low Energy platform Agnostic Klient) behind the scenes to connect and communicate with bike trainers. Bleak is cross-platform with support for Windows, MacOS, and Linux. Please refer to the Bleak repository for more information about supported platforms.
Disclaimer
I take no responsibility if the use of this package breaks your turbo trainer or stationary bike. Use at your own risk!
I have tested it with (tested protocols in brackets):
- a Tacx NEO trainer (ANT+ FE-C over BLE, CPS, CSCS)
- a Tacx NEO 2T trainer (ANT+ FE-C over BLE, CPS, CSCS)
- an Elite Sterzo Smart steering plate (STERZO)
- a pair of Garmin Vector 3 power meter pedals (CPS)
- a Garmin RVR315 rear view radar (RDR)
- a Magene S3+ Speed/Cadence sensor (CSCS)
- a Elite Suito-T smart trainer (CPS, CSCS, FTMS)
Please let me know if you have used it with another device, and I will add it to the list.
Supported protocols
- Battery Service (BAS)
- Cycling Power Service (CPS)
- Cycling Speed and Cadence Service (CSCS)
- Elite Sterzo Steering Service (STERZO)
- FiTness Machine Service (FTMS)
- Heart Rate Service (HRS)
- Rear View Radar (RDR)
- Tacx Trainer Control (ANT+ FE-C over BLE)
Installation
Clone this repo and then run the following command from the root directory
python setup.py develop
Documentation
Please refer to the documentation and the examples folder for basic usage of the package.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/zacharyedwardbull/pycycling. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.
In terms of contributing code, pull requests increasing the features supported in each protocol are especially welcome. If you would like to add support for another cycling related protocol, that would also be appreciated!
Useful documentation
- ANT+ specifications (need to sign up as ANT+ adopter to access these): https://www.thisisant.com/developer/resources/downloads/#documents_tab
- Bluetooth Low Energy specifications: https://www.bluetooth.com/specifications/gatt/
- Bluetooth XML specification files: https://github.com/sur5r/gatt-xml
- Tacx Trainer Control documentation: https://github.com/jedla22/BleTrainerControl/blob/master/How-to%20FE-C%20over%20BLE%20v1_0_0.pdf
- Reverse engineering Sterzo Smart: https://www.youtube.com/watch?v=BPVFjz5zD4g
- Reverse engineering Garmin RVR315 ( radar): https://forums.garmin.com/developer/connect-iq/f/discussion/240452/bluetooth-profile-for-garmin-varia-rtl515#pifragment-1298=3
- Bluetooth FTMS Specifications: https://www.bluetooth.org/DocMan/handlers/DownloadDoc.ashx?doc_id=423422
- Huawei HMSCore Bluetooth LE documentation ( FTMS): https://developer.huawei.com/consumer/en/doc/development/HMSCore-Guides/ibd-0000001051005923
Projects using pycycling
- cycling-cadence-display: https://github.com/cboddy/cycling-cadence-display
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
Hashes for pycycling-0.3.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c29bfaf80ac14bc3dea9963dcb8135e403a00d8815b61712a5251b678162defd |
|
MD5 | 75479aaf2eb3ec1fbb941c824cc60457 |
|
BLAKE2b-256 | 2f421095f579089d3445c7063ae9159043ceab481413f7acc71995586e74a3bf |