Skip to main content

Data Acquisition and Behavioral Experiment Platform

Project description

Thalamus

Thalamus is an open-source Python program designed for real-time, synchronized, closed-loop multimodal data capture, specifically tailored to meet the stringent demands of neurosurgical environments.

Overview

Thalamus facilitates the advancement of clinical applications of Brain-Computer Interface (BCI) technology by integrating behavioral and electrophysiological data streams. Thalamus prioritizes the following design requirements:

  1. Requires minimal setup within an operating room, clinical and research environment and could be easily controlled and quickly modified by the experimenter​
  2. Operated with high reliability with few crashes​
  3. Fail-safe architecture that guarantees minimal data loss in the setting of a crash​
  4. Allows for real-time computation to support visualizations of research and clinical data streams​
  5. Closed-loop control based on research and/or clinical data streams​
  6. Acquires synchronous data from the available research and clinical sensors including relevant behavioral, physiologic, and neural sensors that could easily be scaled over time​
  7. Supports a high-bandwidth, low latency, parallel distributed architecture for modular acquisition and computation that could easily be upgraded as technology continues to advance​
  8. Open-source with source code available to support research use​
  9. Embodies best practice in software engineering using unit tests and validation checks​
  10. Supports advances in translational applications and, hence, also operates in research domains​

System Requirements

Hardware Requirements

Thalamus requires only a standard computer with enough RAM to support the in-memory operations. External hardware devices for data aquisition are dependent on the goals of individual projects.

Software Requirements

Thalamus requires Python.

OS Requirements

We provide auto builds for Linux (glibc 2.35) and Windows (10).

Python Dependencies

requirements.txt includes required dependencies if installing from Github. However, all dependencies have been packaged into the auto builds.

Installation Guide

Install from Build

Download appropriate (Windows or Linux) build directly from actions tab or under Releases.

For Windows:

python -m pip install thalamus-0.3.0-py3-none-win_amd64.whl

For Linux:

python -m pip install thalamus-0.3.0-py3-none-manylunux_2_27.whl

You should now be able to run any of the Thalamus tools

python -m thalamus.pipeline # Data pipeline, no task controller

python -m thalamus.task_controller # Data pipeline and task controller

python -m thalamus.hydrate # Convert capture files to sharable formats

Approximately 1 hour set-up time

Documentaton

The code respository for Thalamus is hosted on GitHub at https://github.com/cajigaslab/thalamus. For detailed documentation of Thalamus visit https://cajigaslab.github.io/Thalamus/. For additional examples and generation of figures in our paper, refer to the SimpleUseCase folder in the repo.

License

If you use Thalamus in your work, please remember to cite the repository in any publications.

Issues

Like all open-source projects, Thalamus will benefit from your involvement, suggestions and contributions. This platform is intended as a repository for extensions to the program based on your code contributions as well as for flagging and tracking open issues. Please use the Issues tab as fit.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

thalamus_neuro-0.3.48-py3-none-win_amd64.whl (37.8 MB view details)

Uploaded Python 3Windows x86-64

thalamus_neuro-0.3.48-py3-none-manylinux_2_27_x86_64.whl (66.9 MB view details)

Uploaded Python 3manylinux: glibc 2.27+ x86-64

thalamus_neuro-0.3.48-py3-none-macosx_11_0_arm64.whl (25.9 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

File details

Details for the file thalamus_neuro-0.3.48-py3-none-win_amd64.whl.

File metadata

File hashes

Hashes for thalamus_neuro-0.3.48-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 5b0b20c39f804836130049be41eb6a225129e187ea0faf57e1011ab760818283
MD5 2ee71c1d66e6582935b75b17fbb9a1b7
BLAKE2b-256 171768e37dd2c507651d6eca1f855242e409e03d62cb8671c039e5411681864d

See more details on using hashes here.

File details

Details for the file thalamus_neuro-0.3.48-py3-none-manylinux_2_27_x86_64.whl.

File metadata

File hashes

Hashes for thalamus_neuro-0.3.48-py3-none-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 65bc52f79b0ddc3c87b9ad9cbe892eb5b99c60efb8f7966ab51fb6f848d7d8b9
MD5 1034addfbef629c24a0de83b5a87dbd6
BLAKE2b-256 e870133d5ae24b8a7ed533e39dbe7648f62df772d74eaea9f4c1237fbef3b721

See more details on using hashes here.

File details

Details for the file thalamus_neuro-0.3.48-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for thalamus_neuro-0.3.48-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 109339c8cb7a30cf3c7f9c096cee8a715d551740991fe378614aaa39671be70f
MD5 948f15dd4aff9a27cae4d7c9d6163af5
BLAKE2b-256 873fa002d5cdbd2df486fa1eebf220d0d8f7daab3f03e5b8a045d4fe2b0ba473

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