Skip to main content

Python package to reconstruct axonal branches from high-density micro-electrode array data

Project description

PyPI version DOI

Axon velocity

Graph-based algorithm to reconstruct axonal branches and compute velocities from extracellular multi-electrode array (MEA) recordings in Python.

Installation

To install the axon_velocity package, you can clone the repo and install using pip:

pip install axon_velocity

To install from sources:

git clone https://github.com/alejoe91/axon_velocity.git
cd axon_velocity
python setup.py install (or develop)

Requirements

axon_velocity depends on the following packages, which are automatically installed

  • numpy
  • matplotlib
  • scipy
  • networkx
  • sklearn
  • MEAutility
  • probeinterface

For the simulation notebooks in the simulation_notebooks folder, additional requirements are needed:

All additional requirements can be installed with: pip install -r requirements_fill.txt

Usage

The inputs to the tracking algorithm are:

  • templates: mean extracellular waveforms (n_channels x n_samples)
  • locations: x-y position of electrodes (n_channels x 2)
  • fs: sampling frequency (float)

The graph-based method can be run as follows:

import axon_velocity as av

gtr = av.compute_graph_propagation_velocity(template=your_template, locations=your_locations, fs=fs)

To inspect available arguments, you can use av.compute_graph_propagation_velocity?.

The output gtr is an object of a class called GraphAxonTracking. It contains the following fields:

  • branches: List of dictionaries containing the following fields:
    • 'selected_channels': selected channels in the path
    • 'velocity': velocity estimate in mm/s (if locations in um and fs in Hz)
    • 'offset': offset of velocity estimate (same units as locations)
    • 'r2': r-squared of the velocoty fit
    • 'error': standard error of the linear fit
    • 'pval': p_value of the fit
    • 'distances': array with distances computed along the branch
    • 'peak_times': array with peak differences with initial channel
    • 'init_channel': channel used as initial channel
  • selected_channels: List of selected channels
  • graph: NetworkX directed graph

The GraphAxonTracking also implements useful methods for plotting the selected channels (gtr.plot_channel_selection()), plot the underlying graph (gtr.plot_graph()), plot the selected axonal branches (gtr.plot_branches()), and plot the estimated velocities for each branch (gtr.plot_velocities()).

Cite

If you use this package, please cite this paper: An automated method for precise axon reconstruction from recordings of high-density micro-electrode arrays:

@article{buccino2022automated,
  title={An automated method for precise axon reconstruction from recordings of high-density micro-electrode arrays},
  author={Buccino, Alessio Paolo and Yuan, Xinyue and Emmenegger, Vishalini and Xue, Xiaohan and G{\"a}nswein, Tobias and Hierlemann, Andreas},
  journal={Journal of neural engineering},
  volume={19},
  number={2},
  pages={026026},
  year={2022},
  publisher={IOP Publishing}
}

Contribute

Contributions are welcome! Before pushing, make sure to clean up all notebooks with nbconvert:

pip install nbconvert (just once)

jupyter nbconvert --to notebook --ClearOutputPreprocessor.enabled=True --ClearMetadataPreprocessor.enabled=True --inplace **/*.ipynb (before committing)

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

axon_velocity-0.2.0.tar.gz (29.9 kB view details)

Uploaded Source

Built Distribution

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

axon_velocity-0.2.0-py3-none-any.whl (29.8 kB view details)

Uploaded Python 3

File details

Details for the file axon_velocity-0.2.0.tar.gz.

File metadata

  • Download URL: axon_velocity-0.2.0.tar.gz
  • Upload date:
  • Size: 29.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for axon_velocity-0.2.0.tar.gz
Algorithm Hash digest
SHA256 15af3e905c6d1cb3a865eeae03b7371a1ff491892febbe794fe80a81daa51331
MD5 31bcc1addb377b778793cf00de6f5886
BLAKE2b-256 95d77effd9997d138bccecf393713e273697a9ccca076bd8ed6cf51155d8ea43

See more details on using hashes here.

File details

Details for the file axon_velocity-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: axon_velocity-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 29.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for axon_velocity-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1c191602f9824abebb244af57042fec7b0192703c6d8c396374b574ff303fbfe
MD5 71e12b5f40af89efb2059f1934bf4fed
BLAKE2b-256 f4b00bf9fa79901a78fb57d8f1bbc337703a99feebda786e9f5db0c3df38f999

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