Skip to main content

ADI SpO2 Watch Python SDK

Project description

SpO2 Watch Python SDK

The adi-spo2-watch provides an object-oriented interface for interacting with ADI's VSM Study Watch 4.5 platform (SpO2 Watch).

Installation

pip install adi-spo2-watch

Description

A user application can use the SDK to receive complete packets of bytes over a physical interface (USB or BLE) and decode it. The functionality is organized into applications, some of which own sensors, some own system-level functionality (i.e. file system), and while others own algorithms. The hierarchy of objects within the SDK mirrors the applications present on the device. Each application has its own object within the SDK hierarchy, which is used to interact with that application. A brief guide on using the SDK and few examples have been added below.

Firmware Setup

https://github.com/analogdevicesinc/spo2-watch-sdk/blob/main/firmware/Firmware_update_guide.pdf

Getting started with SDK

Import the adi-spo2-watch module into your application code

from adi_spo2_watch import SDK

Instantiate the SDK object by passing the com port number

sdk = SDK('COM28')

The application objects can be instantiated from the sdk object. In order to instantiate an application object, we'll have to pass a call-back function as an input argument which can be used to retrieve the data from the application object. Define a callback function as displayed below.

def callback_data(data):
    print(data)

Once the call-back function is defined, you can instantiate the application object as shown below.

application = sdk.get_sensorhub_application()
application.set_callback(callback_data, stream=application.SH_ADXL_STREAM)

Each application object has various methods that can be called by referring to the application. Almost all method in an application returns result in a dict.

Basic Example:

import time
from datetime import datetime
from adi_spo2_watch import SDK

# Callback function to receive adxl data
def callback_data(data):
    sequence_number = data["payload"]["sequence_number"]
    for stream_data in data["payload"]["stream_data"]:
        dt_object = datetime.fromtimestamp(stream_data['timestamp'] / 1000)  # convert timestamp from ms to sec.
        print(f"seq :{sequence_number} timestamp: {dt_object} x,y,z :: ({stream_data['x']}, "
                f"{stream_data['y']}, {stream_data['z']})")


if __name__ == "__main__":
    sdk = SDK("COM4")
    application = sdk.get_sensorhub_application()

    # Quickstart adxl stream
    application.set_callback(callback_data, stream=application.SH_ADXL_STREAM)
    application.enable_csv_logging("adxl.csv", stream=application.SH_ADXL_STREAM) # Logging adxl data to csv file
    application.subscribe_stream(stream=application.SH_ADXL_STREAM)
    application.set_operation_mode(application.SH_CONFIG_ADXL_MODE)
    application.start_sensor()
    time.sleep(10)
    application.stop_sensor()
    application.unsubscribe_stream(stream=application.SH_ADXL_STREAM)
    application.disable_csv_logging(stream=application.SH_ADXL_STREAM)

Permission Issue in Ubuntu

1 - You can run your script with admin (sudo).

2 - If you don't want to run scripts as admin follows the steps below:

  • add user to tty and dialout group
sudo usermod -aG tty <user>
sudo usermod -aG dialout <user>
  • create a file at /etc/udev/rules.d/ with name 10-adi-usb.rules:
ACTION=="add", SUBSYSTEMS=="usb", ATTRS{idVendor}=="0456", ATTRS{idProduct}=="2cfe", MODE="0666", GROUP="dialout"
  • reboot

All streams packet structure : https://analogdevicesinc.github.io/spo2-watch-sdk/python/_rst/adi_spo2_watch.core.packets.html#module-adi_spo2_watch.core.packets.stream_data_packets

Documentation : https://analogdevicesinc.github.io/spo2-watch-sdk/python

Examples : https://github.com/analogdevicesinc/spo2-watch-sdk/tree/main/python/samples

License : https://github.com/analogdevicesinc/spo2-watch-sdk/blob/main/LICENSE

Changelog https://github.com/analogdevicesinc/spo2-watch-sdk/blob/main/python/CHANGELOG.md

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

adi_spo2_watch-6.10.0.tar.gz (115.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

adi_spo2_watch-6.10.0-py3-none-any.whl (191.9 kB view details)

Uploaded Python 3

File details

Details for the file adi_spo2_watch-6.10.0.tar.gz.

File metadata

  • Download URL: adi_spo2_watch-6.10.0.tar.gz
  • Upload date:
  • Size: 115.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for adi_spo2_watch-6.10.0.tar.gz
Algorithm Hash digest
SHA256 11767ac4f872d45f7d5f31889576b3799acf6c5f88e379819ddede1a0d1df0bb
MD5 48a4f107704f7df3ba8a1a5c4d1ca92f
BLAKE2b-256 1750bc5fc590d0cd8514376bab7f7038c4e24e37a7b4c1458c6d7688cce9f85d

See more details on using hashes here.

File details

Details for the file adi_spo2_watch-6.10.0-py3-none-any.whl.

File metadata

File hashes

Hashes for adi_spo2_watch-6.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 31f281f112a124c4889e416726334acc2bc01db7cabe932c31c0772064f2c0b0
MD5 15d12b3d2b7e8d0c49d4389342838153
BLAKE2b-256 88b7c58c077be1a4a6c077a677e39dd32ca8d49a540d3f8b237ae123e1743406

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page