MorphoPy
MorphoPy: A python package for feature extraction of neural morphologies. - Published in JOSS (2020)
Science Score: 95.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
○CITATION.cff file
-
✓codemeta.json file
Found codemeta.json file -
✓.zenodo.json file
Found .zenodo.json file -
✓DOI references
Found 6 DOI reference(s) in README and JOSS metadata -
✓Academic publication links
Links to: ncbi.nlm.nih.gov, sciencedirect.com, springer.com, plos.org -
✓Committers with academic emails
3 of 11 committers (27.3%) from academic institutions -
○Institutional organization owner
-
✓JOSS paper metadata
Published in Journal of Open Source Software
Keywords from Contributors
Scientific Fields
Repository
Basic Info
- Host: GitHub
- Owner: berenslab
- License: gpl-3.0
- Language: Jupyter Notebook
- Default Branch: master
- Size: 17.3 MB
Statistics
- Stars: 42
- Watchers: 2
- Forks: 11
- Open Issues: 6
- Releases: 8
Metadata Files
README.md

A Python package for feature extraction of neural morphologies
(c) 2020 by Sophie Laturnus, Adam von Daranyi, Ziwei Huang and Philipp Berens.
Content
Overview
MorphoPy is a Python3 package that uses networkX to compute and show information about neurites. The input can be passed with single swc-files or it can handle whole directories with multiple files at once. You can use MorphoPy imported in Python, as well as from the command line as a batch-tool.
The current working build:
version 0.7.2
All builds are tested on Linux (Debian and CentOS) and Windows 10.
You can find all working builds at pypi.
And a full documentation of the source code is available at readthedocs.
Software Requirements
In the following, all commands written in boxes need to be entered into your terminal.
Mac:
- homebrew (to install latest version of python3)
- python >3.4: without homebrew you can find python here
- pip
1) If you want the latest python3 version you need to install homebrew, for that just run this command in your terminal:
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
2) Then you can easily install the newest version of python3:
brew install python
3) Now you should have python3 and pip3 installed. You can check the version like this:
bash
python3 --version
pip3 -V
If both are enough you can continue with installing MorphoPy, see below.
Linux:
- python >3.4
- pip 3
Install Python3 on Debian/Ubuntu systems:
apt-get install python3 python3-pip
Install Python3 on RedHat/CentOS/Fedora systems (perhaps python version differs):
yum install python36 python3-pip
That's it. All requirements are met and you can continue with the MorphoPy installation. See below.
Windows:
- python >3.5 (x64): download from here
- pip : be sure you selected it during installation with the base python package
- Microsoft Build Tools >14.0 you can download them here
1) Install python with pip by executing the downloaded installation file and be sure to check the option to add python paths to enviroment variable at the first step!
2) Install Microsoft Build Tools with the automatic installation tool from the website above. Select C/C++ Compiler Tools at the selection page
All requirements are met now, see below for continue with MorphoPy installation.
Installation:
Install the MorphoPy package (all platforms) from PyPI:
bash
pip3 install morphopy
Install the MorphoPy package from GitHub:
bash
git clone https://github.com/berenslab/MorphoPy
pip install -e MorphoPy
Upgrade:
Upgrade the MorphoPy package (all platforms):
bash
pip3 install --upgrade morphopy
Uninstallation:
bash
pip3 uninstall morphopy
Usage
After the installation you can simply call:
morphopy <options>
Help:
Usage: morphopy -c <compute_feature> -i <swc_file>|<directory> [-o <output directory>]
[--long | --func <persistence_function> | --conf <config_file>] [--help]
Options:
-h, --help show this help.
-c, --compute parameter for selecting the computing feature:
persistence: compute persistence data
stats : compute morphometric statistics
density : create density maps
statistics options:
--long you can change your output format, in long
format you get all values in a separate row.
(default: all values in one row)
persistence options:
--func if persistence is selected as feature, you can
specify with this option a method function you
want to use at computing the persistence.
(default: radial distance function)
density map options:
--conf if density map is selected, you can pass a
config file with more parameters for creating
the density maps. (optional)
-i, --input specifies a swc-file or a directory as input
for morphopy (mandatory)
-o, --output specifies the output directory for saving the
results in. (default: same as source)
Available functions for persistence at the moment are: - radialdistance (default function) - height - pathlength - branch_order
A sample config file for density maps looks like this (stored in a text file):
[global]
# specific distance for resampling nodes:
distance: 1
# width of each bin in microns across all dimensions
#bin_size: 20
# number of bins for each dimension (only if you don't use bin_size)
n_bins_x: 20
n_bins_y: 20
n_bins_z: 20
# if true: probabilty density is returned, count histogram otherwise
density: True
# smoothing the density data
smooth: True
# sigma used at smoothing
sigma: 2
# normalization bounds for density map:
[norm_bound]
r_max_x: 238.85
r_max_y: 140.95
r_max_z: 285.97
r_min_x: -236.17
r_min_y: -24.2
r_min_z: -173.72
Contributing to MorphoPy
We tested MorphoPy to the best of our knowledge and abilities in the scope of several projects. If you still find a bug or you are missing a feature, please do not hesitate to contact us via GitHub issues. Please try to provide a minimal example that reproduces the bug you want to be fixed. If you want to develop the code base further, you can work with git pull requests. Please make sure that you document the code and add tests and examples of how to use your code.
Citing MorphoPy
If you are using MorphoPy for your research or your work project please make sure to cite us and this repository:
@article{Laturnus2020,
doi = {10.21105/joss.02339},
url = {https://doi.org/10.21105/joss.02339},
year = {2020},
publisher = {The Open Journal},
volume = {5},
number = {52},
pages = {2339},
author = {Sophie Laturnus and Adam von Daranyi and Ziwei Huang and Philipp Berens},
title = {MorphoPy: A python package for feature extraction of neural morphologies.},
journal = {Journal of Open Source Software}
}
or
@misc{morphopy,
author = {Laturnus, Sophie and von Daranyi, Adam and Huang, Ziwei and Berens, Philipp},
title = {MorphoPy},
publisher = {GitHub},
journal = {GitHub repository},
url = {https://github.com/berenslab/MorphoPy}
}
Module description
Important: MorphoPy requires the soma to be one single point. If more than 3 somatic points are present in the reconstruction file they will be automatically collapsed to the centroid of their convex hull on file loading. If the soma is described by 2 to 3 points they will be automatically collapsed to their mean (also see utils.getstandardizedswc).
MorphoPy currently only supports neurites that connect back to the soma. This means, axons that emerge from dendritic structures can not be handled.
A neuron is represented as a directed acyclic graph with node attributes id, x-, y-, z- position, radius and typeid_ (soma: 1, axon: 2, dendrite: 3, apical dendrite: 4), and with edge attributes pathlength_ and euclideandist_. Positions, radius and length mesaures are assumed to be given in microns.

Fig. 1: Node and edge attributes associated with each neuron graph.
All data is stored in the tidy data format.
Please also refer to our tutorial and the documentation.
Density maps
Density maps are marginal histograms over the neural mass. MorphoPy allows you to create density maps of different projections through the function computedensitymaps(). Per default it computes x, y, z, xy, xz and yz density maps from the point cloud of the original reconstruction. The point cloud is constructed through resampling along all neurites with a default distance of 1 micron. The resulting point cloud is then binned into bins of 20 microns and smoothed using Gaussian smoothing with std of 1.
However, you can customize all these parameters by passing a config file to the function (see above).
Morphometric statistics
MorphoPy offers a default selection of 28 single-valued morphometric statistics, namely:
- number of branch points
- width (x-extent), depth (y-extent), height (z-extent)
- number of tips
- number of neurites extending from the soma directly (stems)
- the total path length (in microns)
- average and maximal radius thickness (with the soma excluded)
- total surface and volume
- maximal path distance to the soma
- maximal branch order
- maximal, min and median path angle
- average soma exit angle
- maximal path length of a segment
- median intermediate and median terminal segment length
- log of max, min and median tortuosity across all edges (= path length/euclidean length)
- max, min and average branch angle
- maximal branching degree (with soma excluded)
- weighted proportional sum of absolute deviations as a measure of tree asymmetry (for more details see https://www.sciencedirect.com/science/article/pii/0165027086901196)

Fig. 2: Explanatory schematic of the morphometric statistics that can be computed on all nodes. Left: distance measures, Right: angles.
Morphometric distributions
Morphometric distributions are not (yet) available via the command line tool.
Frequency histograms or Gaussian kernel density estimates can be queried for all listed key statistics using the
methods get_histogram(key) or get_kde_distribution(key). If you provide a distance measure (e.g. branch order,
path distance from soma or radial distance) the returned distribution will be two-dimensional and allows to investigate
a features' development across space.
Additionally, it is possible to compute Sholl intersection profiles using the function get_sholl_intersection_profile().
Key statistics are - branch orders - Strahler order - branch angles - path angles - root angles - thickness - segment lengths - path length to soma - radial distance
Persistence
Persistence diagrams are a concept from topology. They have been introduced as descriptors of neural morphologies by Kanari et al. and Li et al.

Fig. 3: Schematic of how a persistence diagram is generated. The longest branch with the longest 'lifetime' is marked in red. Taken from Kanari et al. 2018.
The recorded birth and death times in the figure above are based on a certain distance (or lifetime) function. MorphoPy implements four different distance functions to choose from: radial distance (default), height, path length and branch order.
They all compute the distance of a point with respect to the soma. In the command line tool you can switch between them using the --func keyword (see above).
To provide your own distance function, add its code and its keyword to the persistence_functions.py file, but make sure
that the distance functions interface fits the specification custom_distance(networkx.DiGraph,node_id_end, node_id_start)
(see Fig. 4 and the tutorial for an example).

Fig. 4: How to add a custom persistence distance function. To be able to call it from the command line you need to add it to the functions list.
If you are using the API you can simply pass a function to the get_persistence()-method (see the tutorial for an example).
Not enough?
You want to compute your own features? Go for it! We recommend you to check out networkx and shapely for more options.
Owner
- Name: Berens Lab @ University of Tübingen
- Login: berenslab
- Kind: organization
- Email: philipp.berens@uni-tuebingen.de
- Location: Tübingen, Germany
- Website: https://hertie.ai/data-science
- Repositories: 60
- Profile: https://github.com/berenslab
Department of Data Science at the Hertie Institute for AI in Brain Health, University of Tübingen
JOSS Publication
MorphoPy: A python package for feature extraction of neural morphologies.
Authors
Institute for Ophthalmic Research, University of Tübingen, Germany, Bernstein Center for Computational Neuroscience, University of Tübingen, Germany, Center for Integrative Neuroscience, University of Tübingen, Germany
Center for Integrative Neuroscience, University of Tübingen, Germany
Institute for Ophthalmic Research, University of Tübingen, Germany, Bernstein Center for Computational Neuroscience, University of Tübingen, Germany, Center for Integrative Neuroscience, University of Tübingen, Germany
Institute for Ophthalmic Research, University of Tübingen, Germany, Institute for Bioinformatics and Medical Informatics, University of Tübingen, Germany, Bernstein Center for Computational Neuroscience, University of Tübingen, Germany, Center for Integrative Neuroscience, University of Tübingen, Germany
Tags
neurons morphologies anatomyGitHub Events
Total
- Issues event: 5
- Watch event: 5
- Delete event: 2
- Issue comment event: 5
- Push event: 5
- Pull request event: 4
- Create event: 2
Last Year
- Issues event: 5
- Watch event: 5
- Delete event: 2
- Issue comment event: 5
- Push event: 5
- Pull request event: 4
- Create event: 2
Committers
Last synced: 7 months ago
Top Committers
| Name | Commits | |
|---|---|---|
| Sophie | S****s@g****m | 293 |
| ziweih | h****i@o****m | 94 |
| avdaranyi | 3****i | 74 |
| Thassilo Vogt | t****o@T****l | 11 |
| jnsbck-uni | j****k@u****e | 4 |
| Philipp Berens | p****s@u****e | 2 |
| Daniel S. Katz | d****z@i****g | 2 |
| Olivia Guest | o****t | 1 |
| ColoMAX | 5****X | 1 |
| Benjamin A. Beasley | c****e@m****t | 1 |
| Arfon Smith | a****n | 1 |
Committer Domains (Top 20 + Academic)
Issues and Pull Requests
Last synced: 6 months ago
All Time
- Total issues: 86
- Total pull requests: 28
- Average time to close issues: about 1 year
- Average time to close pull requests: 26 days
- Total issue authors: 12
- Total pull request authors: 8
- Average comments per issue: 0.66
- Average comments per pull request: 0.32
- Merged pull requests: 25
- Bot issues: 0
- Bot pull requests: 0
Past Year
- Issues: 4
- Pull requests: 4
- Average time to close issues: about 10 hours
- Average time to close pull requests: about 10 hours
- Issue authors: 2
- Pull request authors: 1
- Average comments per issue: 1.0
- Average comments per pull request: 0.0
- Merged pull requests: 4
- Bot issues: 0
- Bot pull requests: 0
Top Authors
Issue Authors
- Visdoom (64)
- jnsbck (5)
- mstimberg (4)
- huangziwei (3)
- deangeckt (2)
- emptymalei (2)
- sayali7 (1)
- amchagas (1)
- Thinknoon (1)
- philippberens (1)
- musicinmybrain (1)
- melancholy12 (1)
Pull Request Authors
- Visdoom (8)
- huangziwei (7)
- musicinmybrain (5)
- jnsbck (4)
- oliviaguest (1)
- ColoMAX (1)
- arfon (1)
- danielskatz (1)
Top Labels
Issue Labels
Pull Request Labels
Packages
- Total packages: 1
-
Total downloads:
- pypi 202 last-month
- Total dependent packages: 1
- Total dependent repositories: 1
- Total versions: 6
- Total maintainers: 1
pypi.org: morphopy
Python package to display morphologies of neurons and compute statistical measures and representations
- Homepage: https://github.com/berenslab/MorphoPy
- Documentation: https://morphopy.readthedocs.io/
- License: MIT License
-
Latest release: 0.7.2
published about 3 years ago
Rankings
Maintainers (1)
Dependencies
- matplotlib *
- matplotlib_scalebar *
- networkx *
- numpy *
- pandas *
- plotly *
- scipy *
- seaborn *
- shapely *
- sklearn *
- actions/checkout master composite
- actions/setup-python v3 composite
- pypa/gh-action-pypi-publish release/v1 composite
- actions/checkout v2 composite