Skip to main content

Python API for Mentalab biosignal aquisition devices

Project description

logo.png

Explorepy overview

Explorepy is Mentalab’s open-source Python-based biosignal acquisition API for working with Mentalab Explore device. Amongst many things, it provides the following features:

  • Real-time streaming of ExG, orientation and environmental data

  • Real-time visualization

  • Data recording in CSV and BDF+ formats

  • LSL integration

  • Impedance measurement

  • Explore device configuration

Quick installation

On a Windows machine, Explorepy can be installed using the installable file uploaded in the release page or using pip. Please note using the installable files, the dependencies will be installed automatically.

The following instructions are for other operating systems or in case you want to build the package yourself on Windows.

Requirements

  • Python 3.6 or newer versions

  • Visual Studio 2015 community edition (only Windows, in case of building the package)

  • Bluetooth header files (only Linux -> use this command: sudo apt-get install libbluetooth-dev)

Please check out the installation page for more detailed instructions.

To install explorepy from PyPI run:

pip install explorepy

To install the latest development version (git must be installed before running this command):

pip install git+https://github.com/Mentalab-hub/explorepy

Get started

CLI command

For a simple, quick start of Explorepy, run:

explorepy acquire -n Explore_XXXX

Enter explorepy -h for help.

Python code

When working in Python, the following connects to the Explore device and prints the data.

import explorepy
explorer = explorepy.Explore()
explorer.connect(device_name="Explore_XXXX")  # Put your device Bluetooth name
explorer.acquire()

You can also visualize the data in real-time.

import explorepy
explorer = explorepy.Explore()
explorer.connect(device_name="Explore_XXXX")  # Put your device Bluetooth name
explorer.visualize(bp_freq=(.5, 30), notch_freq=50)

EEG:

EEG Dashboard

ECG with heart beat detection:

ECG Dashboard

Documentation

For the full documentation of the API, visit: https://explorepy.readthedocs.io/

Troubleshooting

Please check the troubleshooting section of the documentation.

If you do not find the solution in the above link, please send us the error log via Sentry (Explorepy will send the log automatically after your permission) or send us the log file via email to contact@mentalab.com. The log file can be found in the following path.

  • Windows: <Windows Drive>:\Users\<USER_NAME>\AppData\Local\mentalab\explorepy\Logs\explorepy.log

  • Ubuntu: /home/<USER_NAME>/.cache/explorepy/log/explorepy.log

  • Mac OS: /Users/<USER_NAME>/Library/Logs/explorepy/explorepy.log

You can also create a new issue in the GitHub repository.

Authors

License

This project is licensed under the MIT license. You can reach us at contact@mentalab.com.

Changelog

1.5.1 (21.7.2021)

  • Hotfix for installation bug

1.5.0 (20.7.2021)

  • Push to LSL button in the GUI

  • Search free port for initialization of the dashboard

  • Update installation procedure for Windows

  • Fixing some minor bugs

1.4.0 (31.03.2021)

  • Baseline correction feature in the visualization

  • Error logging system (Logging and Sentry)

  • Fix a bug of SDK in MacOS

  • Change the default Bluetooth interface to SDK

  • Improved FFT visualization

  • More precise local time in all OSes

1.3.0 (30-12-2020)

  • GUI resizing for different screen resolutions

  • Added event button to dashboard

  • Improvement of impedance measurement

  • Fixed minor bugs

1.2.0 (25-11-2020)

  • Standalone installer for Windows OS

  • Fix bugs in ExploreSDK

  • Create new file on device settings change

1.1.0 (27-08-2020)

  • MacOS support

  • Fix bugs

  • Add module disable/enable feature

  • Enhanced user interface

  • Add unique lsl stream names

1.0.0 (22-05-2020)

  • Add ExploreSDK as the Bluetooth interface

  • New dark theme

  • Record module in dashboard

  • Improvement in visualization perfrmance

  • CLI migration to Click

0.6.0 (17-02-2020)

  • EDF (BDF+) file writer

  • Channel disable/enable feature

  • Calibration of movement sensors

  • Extraction of physical orientation (angle and rotation)

  • Soft marker event

  • Visualization performance enhancement

  • Automatic number of channel and sampling rate detection

  • Exception handling improvement

  • Command for soft reset of Explore

  • Marker visualization

0.5.0 (25-11-2019)

  • Impedance measurement

  • Send commands to device

  • Configuring device settings

  • Update push to lsl feature

0.4.0 (09-09-2019)

  • Added marker feature

  • Timer based recording

  • Fixed a bug in csv file writer

  • Fixed a bug in device reconnect

  • Improved performance of dashboard visualization

0.3.1 (28-05-2019)

  • Fixed a bug in 8-channel ExG packet conversion

  • Fixed a minor bug in the record function

  • Updated the documentation

0.3.0 (10-05-2019)

  • Explore dashboard

  • Real-time visualization of ExG and orientation signal

  • Device information in Dashboard

  • Environmental data (battery, temperature and light)

  • Real-time bandpass filter

  • New packet structures (ADS1294R & ADS1298R)

  • Heart rate estimation and R-peaks detector in dashboard

0.2.0 (2019-03-08)

  • Added real-time recording feature

  • Added Command Line Interface

  • Added lsl integration

  • Added new packet classes

  • Fixed reconnect issues

  • Removed input requests inside functions

0.1.0 (2019-01-18)

  • First release on PyPI.

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

explorepy-1.5.2.tar.gz (1.1 MB view details)

Uploaded Source

Built Distributions

explorepy-1.5.2-cp39-cp39-win_amd64.whl (191.8 kB view details)

Uploaded CPython 3.9 Windows x86-64

explorepy-1.5.2-cp38-cp38-win_amd64.whl (192.0 kB view details)

Uploaded CPython 3.8 Windows x86-64

explorepy-1.5.2-cp37-cp37m-win_amd64.whl (271.5 kB view details)

Uploaded CPython 3.7m Windows x86-64

explorepy-1.5.2-cp36-cp36m-win_amd64.whl (271.4 kB view details)

Uploaded CPython 3.6m Windows x86-64

File details

Details for the file explorepy-1.5.2.tar.gz.

File metadata

  • Download URL: explorepy-1.5.2.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.24.0 setuptools/46.1.3.post20200330 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.6.10

File hashes

Hashes for explorepy-1.5.2.tar.gz
Algorithm Hash digest
SHA256 7655ce93c9a737c11651b6d6e0bead6199261a8dc5d15815853de9e22711891c
MD5 b24e9e0302e440a23ca140142b5f9be8
BLAKE2b-256 7c5cbe2808d6f5f304ed88d189674e09075566d25bea9fd38c5548351faab83f

See more details on using hashes here.

File details

Details for the file explorepy-1.5.2-cp39-cp39-win_amd64.whl.

File metadata

  • Download URL: explorepy-1.5.2-cp39-cp39-win_amd64.whl
  • Upload date:
  • Size: 191.8 kB
  • Tags: CPython 3.9, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.24.0 setuptools/46.1.3.post20200330 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.6.10

File hashes

Hashes for explorepy-1.5.2-cp39-cp39-win_amd64.whl
Algorithm Hash digest
SHA256 66cdad601f68a5253b5052ff50a7a00aefceba49360ef4cff7e5a61e1c2b917b
MD5 b3a713a290c87a3199f888363df0f8d5
BLAKE2b-256 2b5f9e58cbf51a511c8f9e4f6380ca26adead0dc5e94870d7f0b2a6d7f9b427e

See more details on using hashes here.

File details

Details for the file explorepy-1.5.2-cp38-cp38-win_amd64.whl.

File metadata

  • Download URL: explorepy-1.5.2-cp38-cp38-win_amd64.whl
  • Upload date:
  • Size: 192.0 kB
  • Tags: CPython 3.8, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.24.0 setuptools/46.1.3.post20200330 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.6.10

File hashes

Hashes for explorepy-1.5.2-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 e03177ad8739e7c54723ce8b7628ffb1bef662e7f82c810ff7188789ad0077eb
MD5 edafcfc28df8e7539fa614e35d3e3f71
BLAKE2b-256 a71691c35515bbda586c5edadc908e89be072a5a6f9e3992cfd4a99ee62b9604

See more details on using hashes here.

File details

Details for the file explorepy-1.5.2-cp37-cp37m-win_amd64.whl.

File metadata

  • Download URL: explorepy-1.5.2-cp37-cp37m-win_amd64.whl
  • Upload date:
  • Size: 271.5 kB
  • Tags: CPython 3.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.24.0 setuptools/46.1.3.post20200330 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.6.10

File hashes

Hashes for explorepy-1.5.2-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 0872f8bc7933299f66ac18e2a2e689ae9ced3a9a30e0c2cae7629a446b851d28
MD5 4def2972f540f148a8270b11745586ab
BLAKE2b-256 1c7c4f9208618e3a33f286c7ce93ec5af7af5ea0988fed522f38e36592a9d841

See more details on using hashes here.

File details

Details for the file explorepy-1.5.2-cp36-cp36m-win_amd64.whl.

File metadata

  • Download URL: explorepy-1.5.2-cp36-cp36m-win_amd64.whl
  • Upload date:
  • Size: 271.4 kB
  • Tags: CPython 3.6m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.24.0 setuptools/46.1.3.post20200330 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.6.10

File hashes

Hashes for explorepy-1.5.2-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 1606f3e25688c23892fff202a064e1672dcb81d21327a5924224831a57e5e4d6
MD5 3baca7cfd45ef94401ac18664b8a182c
BLAKE2b-256 bdf356c8beb6110bf6936a85f966a2de30a5944f8e978410078f082abc9eef7b

See more details on using hashes here.

Supported by

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