Communicate with your Empatica E4 in your Python scripts.
Project description
pyEmpatica
Parties Involved
Institution: Munroe Meyer Institute in the University of Nebraska Medical Center
Laboratory: Virtual Reality Laboratory
Advisor: Dr. James Gehringer
Developer: Walker Arce
Motivation
This Python library was written to facilitate biometric data collection from an Empatica E4. It also includes windowed sample collection, threaded error handling, and on-wrist detection.
Installation
This library is available for installation over pip using:
pip install pyEmpatica
For developers, clone this repository, cd into the directory using either your virtual environment or your local environment, and run:
python setup.py install
To actually utilize this library the Empatica Streaming Server is required, meaning this library is only compatible with Windows systems.
Usage
from pyempatica import EmpaticaClient, EmpaticaE4, EmpaticaDataStreams, EmpaticaServerConnectError
import time
try:
client = EmpaticaClient()
print("Connected to E4 Streaming Server...")
client.list_connected_devices()
print("Listing E4 devices...")
time.sleep(1)
if len(client.device_list) != 0:
e4 = EmpaticaE4(client.device_list[0])
if e4.connected:
print("Connected to", str(client.device_list[0]), "device...")
for stream in EmpaticaDataStreams.ALL_STREAMS:
e4.subscribe_to_stream(stream)
print("Subscribed to all streams, starting streaming...")
e4.start_streaming()
for i in range(0, 10):
time.sleep(1)
if not e4.on_wrist:
print("E4 is not on wrist, please put it on!")
if e4.client.last_error:
print("Error encountered:", e4.client.last_error)
break
e4.suspend_streaming()
e4.disconnect()
e4.close()
print("E4 Errors")
for key in e4.client.errors:
print("\t", key, ":", e4.client.errors[key])
print("E4 connection closed, saving readings...")
e4.save_readings("readings.txt")
print("Readings saved to readings.txt...")
else:
print("Could not connect to Empatica E4:", client.device_list[0])
client.close()
print("Cleaning up connections...")
except EmpaticaServerConnectError:
print("Failed to connect to server, check that the E4 Streaming Server is open and connected to the BLE dongle.")
Before running this script, ensure the Empatica Streaming Server is up and running. This library is currently only compatible with Windows due to the Streaming Server dependency.
Citation
@misc{Arce_pyEmpatica_2021,
author = {Arce, Walker and Gehringer, James},
month = {8},
title = {{pyEmpatica}},
url = {https://github.com/Munroe-Meyer-Institute-VR-Laboratory/pyEmpatica},
year = {2021}
}
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
Built Distribution
File details
Details for the file pyEmpatica-0.5.8.tar.gz
.
File metadata
- Download URL: pyEmpatica-0.5.8.tar.gz
- Upload date:
- Size: 3.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5bbd66fff7321eed11ebe98084b911687852f2dbf70897382e66162583cdf24f |
|
MD5 | f584d4bddf75f5013b4e4e7c31c86c2b |
|
BLAKE2b-256 | 19e1166ea3f309f4add3df150aaaea9c56676945ac99eea13365a021eb741ec7 |
File details
Details for the file pyEmpatica-0.5.8-py3-none-any.whl
.
File metadata
- Download URL: pyEmpatica-0.5.8-py3-none-any.whl
- Upload date:
- Size: 3.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8d2784b83e65c8798533eb3bd478d9b487a10db9567762b1e991d8adde3e69c0 |
|
MD5 | 3e60f572a618bab6f082907f9387db89 |
|
BLAKE2b-256 | cceae8c8d6fc495b19d5c8a781f5841111c5c6ddb599627a69cc74a21e8be930 |