Skip to main content

A small suit of function for analyzing freezing behavior based on a threshold.

Project description

FrozenPy

FrozenPy is a small collection of Python functions for detecting freezing behavior and averaging data based on a threshold and experimental parameters, with a particular focus on Pavlovian conditioning paradigms. Freezing is detected by thresholding motion data under a defined value (e.g., 10 a.u.) for a defined minimum length of time (1 sec). It also includes functions for converting .out files generated from MedPC to easier-to-handle .csv files.

FrozenPy is designed so that it is easy to add metadata (group, sex, etc.) and formats data for use with popular plotting (Seaborn) and statistical (Pingouin) packages within Python.

Usage

Installation

FrozenPy can easily be installed via pip. Type the following into your terminal to install FrozenPy.

pip install FrozenPy

Read .out files

Converting .out to .raw.csv, read .raw.csv:

# Base directory containing .out files
out_dir = '/path/to/your/.out/files'

# convert all .out files within dir to .raw.csv
fp.read_out(out_dir)

# read .raw.csv
data_raw = fp.read_rawcsv('your_data.raw.csv')

Detect freezing and average

Detect freezing:

# detect freezing
data_freezing = fp.detect_freezing(data_raw)

This is an example for if we wanted to slice and average data with a 3 min baseline, 10s CS, 2s US, 58s ISI, and 5 trials:

# slice data
frz_bl, frz_trials = fp.get_averagedslices(df=data_freezing,
                                         BL=180,
                                         CS=10,
                                         US=2,
                                         Trials=5,
                                         ISI=58,
                                         fs=5,
                                         Behav='Freezing')

This would output two variables: frz_bl which contained the averaged BL data for each subject, and frz_trials which contained CS, US, and ISI data for each subject. These are separated because BL is factorial data whereas Trials are repeated measures.

Notes

This code was developed specifically for the Maren Lab which uses MedPC boxes that measure motion via loadcells, but it should work with any motion data so long as it is in the correct format. If you notice any problems or wish to contribute please don't hesitate to contact me at mictott@gmail.com, open a pull request, or submit an issue.

Future directions

  • take advantage of xarrays (not in the near future)
  • provide visible feedback to allow for threshold adjustments (not in the near future unless needed)

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

FrozenPy-0.2.5.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

FrozenPy-0.2.5-py3-none-any.whl (12.4 kB view details)

Uploaded Python 3

File details

Details for the file FrozenPy-0.2.5.tar.gz.

File metadata

  • Download URL: FrozenPy-0.2.5.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/51.0.0.post20201207 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.7.7

File hashes

Hashes for FrozenPy-0.2.5.tar.gz
Algorithm Hash digest
SHA256 7936aefadc19249b4c0b724eaa5f1bb1811f0a6ee2fac0c4c4a966ac4ea333f1
MD5 dc6ac5d2c2b8d635a80029b09d8a03dc
BLAKE2b-256 93acc48e285b16bdfb66af4c51a7f9d6d91af9d85f063ed375b6895453e98b3d

See more details on using hashes here.

File details

Details for the file FrozenPy-0.2.5-py3-none-any.whl.

File metadata

  • Download URL: FrozenPy-0.2.5-py3-none-any.whl
  • Upload date:
  • Size: 12.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/51.0.0.post20201207 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.7.7

File hashes

Hashes for FrozenPy-0.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 a4e916f6de5e3092f3c3989f190e08957f793e64bd7a1977f7f6b70ae0d24b3f
MD5 a742a7c29d460421ae9dc1da2aa0aafe
BLAKE2b-256 b3f0ecbd3c806dbfbdc06f05dacb75f7be5906947c2a154b05f5b35c954c2ada

See more details on using hashes here.

Supported by

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