Skip to main content

PupEyes: Your Buddy for Pupil Size and Eye Movement Data Analysis

Project description

PupEyes: Your Buddy for Pupil Size and Eye Movement Data Analysis

Python Version License Jupyter Book Badge GitHub issues Github All Releases ReadtheDocs

PupEyes

Overview

PupEyes is a Python package for preprocessing and visualizing eye movement data. It handles pupil size preprocessing and supports interactive visualization of pupil size and fixation data. It was designed to streamline data preparation so you can analyze your data with ease and confidence.

Tutorials and API Reference

Higlights

Best practices

The pupil data preprocessing pipeline is desgined based on the best practices available.

Pandas integration

Raw data is cleaned and prepared as a pandas dataframe, allowing you to enjoy the vast data analysis and manipulation methods offered by the pandas ecosystem.

Interactive interface

Multiple interactive visualizations using Plotly Dash allow you understand your data better.

Pupil Viewer: Examining Pupil Preprocessing Steps

Fixation Viewer: Visualize Fixation Patterns

AOI Drawing Tool: Flexibly Define AOIs

Installation

pip install pupeyes

or install the latest development version from Github

pip install git+https://github.com/HanZhang-psych/pupeyes.git

Documentation

Tutorials and API reference are available at Read the Docs.

Compatibility

While some PupEyes features are specific to Eyelink eye-trackers, many tools are compatible with any eye movement data.

Contributing

Please report bugs if you notice any. See the Contributing Guidelines for details on how to submit pull requests, report issues, and contribute to the project.

License

This project is licensed under the GNU General Public License v3.0 - see the LICENSE.md file for details.

Citation

If you use PupEyes in your research, please cite:

@software{pupeyes2025,
  author = {Zhang, Han},
  title = {PupEyes: Your Buddy for Pupil Size and Eye Movement Data Analysis},
  year = {2025},
  publisher = {GitHub},
  url = {https://github.com/HanZhang-psych/pupeyes}
}

Changelog

See CHANGELOG.md for a list of changes in each release.


The project began as an attempt to formalize the eye-tracking processing scripts used in my past research. It then evolved into a much bigger project (as is always the case).

I hope PupEyes will be useful to the eye-tracking community!

Supported by

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