Skip to main content

Analysis of electrophysiology data

Project description

[![Python package](https://github.com/rhayman/ephysiopy/actions/workflows/python-package.yml/badge.svg)](https://github.com/rhayman/ephysiopy/actions/workflows/python-package.yml)

Synopsis

Tools for the analysis of electrophysiological data collected with the Axona or openephys recording systems.

Installation

ephysiopy requires python3.7 or greater. The easiest way to install is using pip:

python3 -m pip install ephysiopy

or,

pip3 install ephysiopy

Or similar.

Code Example

Neuropixels / openephys tetrode recordings

For openephys-type analysis there are two main entry classes depending on whether you are doing OpenEphys- or Axona-based analysis. Both classes inherit from the same abstract base class (TrialInterface) and so share a high degree of overlap in what they can do. Because of the inheritance structure, the methods you call on each concrete class are the same

`python from ephysiopy.io.recording import OpenEphysBase trial = OpenEphysBase("/path/to/top_level") `

The “/path/to/top_level” bit here means that if your directory hierarchy looks like this:

├── 2020-03-20_12-40-15
├── Record Node 101
|    └── settings.xml
         experiment1
|        └── recording1
|            ├── structure.oebin
|            ├── sync_messages.txt
|            ├── continuous
|            |   └── Neuropix-PXI-107.0
|            |       └── continuous.dat
|            └── events
├── Record Node 102

Then the “/path/to/top_level” is the folder “2020-03-20_12-40-15”

On insantiation of an OpenEphysBase object the directory structure containing the recording is traversed and various file locations are noted for later processing of the data in them.

The pos data is loaded by calling the load_pos_data() method:

`python npx.load_pos_data(ppm=300, jumpmax=100, cm=True) `

Note ppm = pixels per metre, used to convert pixel coords to cms. jumpmax = maximum “jump” in cms for point to be considered “bad” and smoothed over

The same principles apply to the other classes that inherit from TrialInterface (AxonaTrial and OpenEphysNWB)

Plotting data

A mixin class called FigureMaker allows consistent plots, regardless of recording technique. All plotting functions there begin with “plot” e.g “_rate_map” and return an instance of a matplotlib axis. The plotting functions in turn call a corresponding “get” function e.g. “get_rate_map” that will return an instance of the BinnedData class containing the binned data, the histogram edges, the variable being binned (XY, SPEED etc) and the map type (RATE, SPK, POS).

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

ephysiopy-2.0.57.tar.gz (151.7 kB view details)

Uploaded Source

Built Distribution

ephysiopy-2.0.57-py3-none-any.whl (163.7 kB view details)

Uploaded Python 3

File details

Details for the file ephysiopy-2.0.57.tar.gz.

File metadata

  • Download URL: ephysiopy-2.0.57.tar.gz
  • Upload date:
  • Size: 151.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for ephysiopy-2.0.57.tar.gz
Algorithm Hash digest
SHA256 a09baac5e81de41ec6500f8eff5dc1e24b748ba05ede3165c33e1a11c82619d8
MD5 6c840a0cbc8fb893f5db85b123059487
BLAKE2b-256 586e9070eaca3df5117ac16ae18e76cf141219cc628101ddb788fce39b20f10a

See more details on using hashes here.

Provenance

The following attestation bundles were made for ephysiopy-2.0.57.tar.gz:

Publisher: python-publish.yml on rhayman/ephysiopy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ephysiopy-2.0.57-py3-none-any.whl.

File metadata

  • Download URL: ephysiopy-2.0.57-py3-none-any.whl
  • Upload date:
  • Size: 163.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for ephysiopy-2.0.57-py3-none-any.whl
Algorithm Hash digest
SHA256 3c860b6bd10db9610325c27738bf9a6c48b095c0e1e963cb9c7576ce8f3ddacb
MD5 6b31a68491f3f2fd722829eb7e10e294
BLAKE2b-256 fdd62c8085a173fb5b68b5f98cb2cbc1a19ec7912ac990d750798b3a88e71623

See more details on using hashes here.

Provenance

The following attestation bundles were made for ephysiopy-2.0.57-py3-none-any.whl:

Publisher: python-publish.yml on rhayman/ephysiopy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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