Skip to main content

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

Project description

FrozenPy

FrozenPy is a small suit of Python functions for detecting freezing behavior and averaging data based on paradigm structure, 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 cannot currently be installed via pip, so for if you want to use it you can download or clone this repository to your local machine by clicking Clone or download in the upper right corner,

or it can be cloned using git with:

git clone https://github.com/MicTott/FrozenPy

Importing FrozenPy functions

Because FrozenPy cannot be installed by pip yet, you need to be in the directory containing containing 'FrozenPy.py' to import the functions. This is easily done with the 'os' package:

import os
path = '/your/path/to/FrozenPy'
os.chdir(path)
import FrozenPy as fp

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 seperated because BL is factorial data whereas Trials are repeated measures. Combining these into one dataframe gets weird in long format and it's easiest to keep these separated for plotting and statistics.

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

  • pip integration
  • plot CS data
  • take advantage of xarrays
  • 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.1.2.tar.gz (2.8 kB view details)

Uploaded Source

Built Distribution

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

FrozenPy-0.1.2-py3-none-any.whl (3.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: FrozenPy-0.1.2.tar.gz
  • Upload date:
  • Size: 2.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.1.2.tar.gz
Algorithm Hash digest
SHA256 2ad7d8d36d1356848b1615fcf2cb922781967bb2050d0f1c9821a6ddd90bdca2
MD5 95611af01f34d0d0b56aa2e3de9e8eda
BLAKE2b-256 402bb22fb0e89ec4c7bbcf7cf0af5bea376213bee3230ecc9fd83fcfad6f8e4e

See more details on using hashes here.

File details

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

File metadata

  • Download URL: FrozenPy-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 3.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.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 14dd0f0d8dd3551d568e275f78cb0bcaf0576c0738c4cc6208b15423d711c0b3
MD5 cae736eef4dd9934cd4fa82c616d1268
BLAKE2b-256 86197c385c4b64cf686c0a795bc3f2a969c2d1c4adbcb1c89f46bf690bcfd2de

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