Eye State Prototype Blink Matching in EAR time series
Project description
ESPBM - Eye State Prototype Blink Matching
[Project Page] [Publication] [PDF] [Nature Scientic Reports Work]
This work presents a novel method for detecting eye blinking by establishing eye state prototypes to match blink patterns within the eye aspect ratio (EAR) time series. In contrast to traditional methods, which mainly focus on the binary ON/OFF of blinks, our method takes care of critical diagnostic details such as blink speed, duration, and inter-eye synchronicity.
In an unsupervised manner, we learned prototypes from the existing blink patterns and established manually defined prototypes. Our research shows that both unsupervised learned and manually defined prototypes can reliably detect blink intervals and have comparable results, which offers potential diagnostic tools for identifying muscular or neural disorders.
Under the "minimal working prototype" principle, we aim to establish the eye blink prototype with minimal work, enabling medical professionals without computer expertise to quickly create prototypes to match specific patterns. This repository presents the source code of our approach and provides a demonstration of sample experiments.
Getting Started
Locally
- Clone the repository
git clone git@github.com:cvjena/ESPBM.git
cdto ESPBM- Create a new conda environment and install the dependencies:
conda create -n espbm python=3.10 -y
conda activate espbm
# conda install cudatoolkit -y
pip install jupyter
pip install -e .
Via Pip
pip install espbm
Usage
We provide some example time series and prototypes to demonstrate the usage of our method in the sample_experiments folder.
Our code is designed to be modular and flexible, so you can quickly adapt it to your data and prototypes.
We demonstrate the usage of our method in the following steps:
- Data loading
- Prototypes learning or manual definition
- Extraction
- Inter-eye synchronicity
Citation
@inproceedings{xie2024unsupervised,
title = {Unsupervised Learning of Eye State Prototypes for Semantically Rich Blinking Detection},
author = {Yuxuan Xie and Tim B{\"u}chner and Lukas Schuhmann and Orlando Guntinas-Lichius and Joachim Denzler},
booktitle = {Digital Health & Informatics Innovations for Sustainable Health Care Systems},
year = {2024},
month = august,
pages = {1607--1611},
publisher = {IOS Press},
series = {Studies in Health Technology and Informatics},
volume = {316},
code = {https://github.com/cvjena/ESPBM},
doi = {10.3233/SHTI240731},
groups = {facialpalsy},
langid = {english},
url = {https://ebooks.iospress.nl/doi/10.3233/SHTI240731},
note = {}
}
License
Licensed under MIT.
Acknowledgments
Our project is and was only possible with the help of many existing projects and their maintainers and contributors. We would like to thank the following projects and their maintainers for their work:
- Stumpy for the unsupervised learning of prototypes and fast pattern-matching
- JeFaPaTo the extraction of the EAR time series
- CurlyBrace for the nice visualizations of curly braces :)
Contact
For any queries, requests, or problems, please reach out to
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
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 espbm-1.2.1.tar.gz.
File metadata
- Download URL: espbm-1.2.1.tar.gz
- Upload date:
- Size: 9.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.8.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ed547247ddad4d4d4375fb98c0cd73d55442d2ad52c7b318c84dbc9aec97cddc
|
|
| MD5 |
09b14d279222d858e5abd11b0cc96f3f
|
|
| BLAKE2b-256 |
a5881e7053d7faad19fb19b223213ba107fa0684680e10d0baf7b5a1766ad162
|
File details
Details for the file espbm-1.2.1-py3-none-any.whl.
File metadata
- Download URL: espbm-1.2.1-py3-none-any.whl
- Upload date:
- Size: 16.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.8.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cb5b8ad2074f0665233b0572dea35f5e524c75b2865fed424977c67b3882b354
|
|
| MD5 |
1a442714da87964ef920bca15faf398d
|
|
| BLAKE2b-256 |
b0d81d7ee593485e87bdd08b579deb7e97cc6f8e689909f41aca99823f44a19f
|