Skip to main content

"A python based toolkit to download and anlyse data from the Ethoscope hardware system."

Project description

ethoscopy

CI/CD Pipeline codecov PyPI version Python versions License: GPL v3

A data-analysis toolbox utilising Pandas, Seaborn, and Plotly to curate, clean, analyse, and visualise behavioural time series data. Whilst the toolbix was created around the data produced from an Ethoscope (a Drosophila monitoring system), if the users data follows the same structure for time series data all methods can be utilised.

Head to the tutorial for an in-depth walk through. The Jupyter notebooks in tutorial_notebook/ are the authoritative, runnable examples.

For more information on the Ethoscope system, click here - If using in conjenction with Ethoscope data this software contains functions for loading the Ethoscope data into ethocopy from .db files both locally and in remote ftp servers.

At its core ethoscopy is a subclass of the data manipulation tool Pandas. The dataframe object has been altered to contain a linked metadata dataframe which contains experimental information. This secondary dataframe can be used to filter the data containing dataframe, as well as a store of information per specimen during analysis.

Ethoscopy contains methods to perform common analytical techniques per specimen in the data table, such as removing dead specimens, interpolating missing values, or calculating sleep from movement. Addtionally, specialist anlysing tools have been implemented for analysing circadian rhythm, such as periodograms, and for generating hidden Markov models (HMM) to understand latent behavioural states. HMMs are trained utilising hmmlearn in the background and come accompanied with a range of visualisation tools to understand the generated model.

-- Update to 2.0 --

This new update sees a whole refactoring of the code base to make everything more streamline and keep the package up to date with the new versions of pandas and numpy. Gone are seperate classes for periodograms and HMM based analysis, all are under one class behavpy(). Addtioanlly, now the user can choose between plotter packages, Seaborn and Plotly, and choose a desired colour pallete. The previous used package Plotly can balloon the size of jupyter notebooks, putting a strain on storage, despite being great for data exploration. If you just want static plots, use Seaborn. But be wary of comparison, the backend for Plotly plots is all calculated in ethoscopy applying z-score and bootstrapping to quantification plots, whereas Seaborn based plots will use the Seaborn internal tools for errors and averaging.

The latest update is backwards compatible with all previously saved behavpy dataframes. However, post loading they should be re-initiated as the new behavpy class. See in the getting started a demonstration of what to do.

Addtionally, the concat method ( behavpy_object.concat() ) for combining dataframes has been shifted to a function that is imported automatically. Call etho.concat(df1, df2) or etho.concat(*[df1, df2]) instead. There are other minor changes to method and argument names, which are reflected in their docstrings and in the tutorial.

Getting Started

Ethoscopy can be installed via pip from PyPi

We recommned installing ethoscopy into a virtual environment due to specific package versions.

python pip install ethoscopy

Example of use

Ethoscopy is primarily made to work in a Jupyter notebook environment and should be imported in as so:

import ethoscopy as etho

Generate a behavpy dataframe object as so:

data = pandas_dataframe
metadata = pandas_dataframe

df = etho.behavpy(data, metadata, check = True, canvas = 'plotly', palette = 'Set2')

# select only the data from specimens in experimental group 2
filtered_df = df.xmv('experimental_column', 'group_2')

Loading and re-initialising old data (saved pre 2.0)

import ethoscopy as etho
import pandas as pd

df = pd.read_pickle('path/to/your/file.pkl')
df = etho.behavpy(df, df.meta, check = True, canvas = 'plotly', palette = 'Set2')

Tutorial data

The six pickle files used by the tutorial notebooks (~36 MB total, dominated by overview_data.pkl at ~31 MB) are intentionally not shipped with the PyPI wheel to keep pip install ethoscopy lean. Fetch them once with:

import ethoscopy as etho
etho.download_tutorial_data()   # idempotent — skips files already on disk

By default this populates ~/.cache/ethoscopy/tutorial_data/ (user-writable on every platform, no root required). After that, get_tutorial('overview'), get_tutorial('circadian') and get_HMM('M'|'F') Just Work.

Lookup order. At load time, ethoscopy checks three locations in this order:

  1. <site-packages>/ethoscopy/misc/tutorial_data/ — used by dev/editable installs and by the project's Docker image (which pre-populates it during build; see Docker/Dockerfile).
  2. $ETHOSCOPY_TUTORIAL_DATA_DIR if set — useful for shared clusters where one admin-maintained copy serves many users.
  3. ~/.cache/ethoscopy/tutorial_data/ — the default for download_tutorial_data().

Manual download. The canonical URLs live at https://github.com/gilestrolab/ethoscopy/tree/main/src/ethoscopy/misc/tutorial_data. Place the six *.pkl files in any of the three locations above.

Development and Testing

Ethoscopy includes a comprehensive test suite to ensure code reliability and prevent regressions.

Running Tests

Install development dependencies:

pip install -e ".[dev]"

Run all tests:

pytest

Run tests with coverage:

pytest --cov=ethoscopy --cov-report=term-missing

Or use the convenience script:

python run_tests.py

Test Categories

  • Unit tests: Fast tests for individual functions (pytest -m unit)
  • Integration tests: Workflow testing (pytest -m integration)
  • Performance tests: Long-running tests (pytest -m slow)

For detailed testing information, see TESTING.md.

License

This project is licensed under the GNU-3 license

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

ethoscopy-2.2.0.tar.gz (13.8 MB view details)

Uploaded Source

Built Distribution

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

ethoscopy-2.2.0-py3-none-any.whl (147.6 kB view details)

Uploaded Python 3

File details

Details for the file ethoscopy-2.2.0.tar.gz.

File metadata

  • Download URL: ethoscopy-2.2.0.tar.gz
  • Upload date:
  • Size: 13.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for ethoscopy-2.2.0.tar.gz
Algorithm Hash digest
SHA256 25c63103680abcdfa772fe33089111b5bc82263aadea51c3588d5d2176fb3f85
MD5 735ef5a4cd23ee42b929310e24b72677
BLAKE2b-256 e01685a0395686e52889cf467232b6597f903dc4ea32a36029e305bf45878948

See more details on using hashes here.

File details

Details for the file ethoscopy-2.2.0-py3-none-any.whl.

File metadata

  • Download URL: ethoscopy-2.2.0-py3-none-any.whl
  • Upload date:
  • Size: 147.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for ethoscopy-2.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 094bb6848ef82517890f9ce6d535bf930efcba6b89dfa83294dab4a3e35b874f
MD5 f85be3fb58d56cc2bf3a720f24d821d1
BLAKE2b-256 ebca7b54c5588b1f785c19ddbe1488a0c4b916aa4e086bf9317a7c063ae252fb

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