Unified generation and analysis of networks in Python, with neuroscientific additions https://nngt.readthedocs.io/en/latest
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Tanguy Fardet 3f511d3c5c Version 2.5.3: bugfix for randomize_neural_states 3 weeks ago
doc Doc+Plot: updated doc and gallery plots 2 months ago
extra Format and check headers 9 months ago
nngt Version 2.5.3: bugfix for randomize_neural_states 3 weeks ago
testing IO: graphml support for missing attributes 3 weeks ago
.build.yml Doc+Plot: updated doc and gallery plots 2 months ago
.coveragerc Various - Support Networkx 2.6, improved config, coverage 4 months ago
.gitignore Plot: node annotations and improved plots 2 months ago
.gitmodules Move to SourceHut (#156) 10 months ago
.readthedocs.yml Geospatial - draw networks on maps 7 months ago
LICENSE.txt Fix+test examples and NeuralGroup/Pop + Pypi test(#19) 4 years ago
MANIFEST.in 2.0.1 Patch: fix windows install, correct max integer for RNG (#92) 1 year ago
README.md Version 2.5.3: bugfix for randomize_neural_states 3 weeks ago
requirements.txt Updates for pypi upload (#90) 1 year ago
setup.cfg Fix+test examples and NeuralGroup/Pop + Pypi test(#19) 4 years ago
setup.py Doc+Plot: updated doc and gallery plots 2 months ago

README.md

NNGT: a unified interface for networks in python

Logo of NNGT: a conceptual sketch of a pyramidal neuron linked to three
simple circular nodes to form a graph.

builds.sr.ht status Coverage Status Documentation Status License
DOI PyPI

The Neural Networks and Graphs' Topology (NNGT) module provides tools to generate and study graphs and detailed biological networks. It also lets user interface efficient graph libraries with highly distributed activity simulators to make the study of neuronal activity as easy and efficient as possible.

Source code is available and contributions are accepted on SourceHut and GitHub.

Principle

NNGT provides a unified interface that acts as a wrapper for 3 major graph libraries in Python: networkx, igraph, and graph-tool.

Use the same code, run it at home on the latest linux with graph-tool, then on your collaborator's laptop with networkx on Windows, no changes required!

In addition to this common interface, NNGT provides additional tools and methods to generate complex neuronal networks. Once the networks are created, they can be seamlessly sent to the nest-simulator, which will generate activity. This activity can then be analyzed together with the structure using NNGT.

Eventually, NNGT is also able to import neuronal networks generated using the DeNSE simulator for neuronal growth.

Install and use the library

NNGT requires Python 3.5+ since version 2.0, and is directly available on Pypi. To install it, make sure you have a valid Python installation, then do:

pip install nngt

If you want to use it with advanced geometry, geospatial or other tools, you can use the various extra to automatically download the relevant dependencies keep only one of the listed possibilities)

pip install nngt[matplotlib|nx|ig|geometry|geospatial]

To install all dependencies, use pip install nngt[full].

To use it, once installed, open a Python terminal or script file and type

import nngt

If you want to have the latest updates before they are released into a stable version, you can install directly from main via:

pip install --user git+https://git.sr.ht/~tfardet/NNGT@main

Support and bug reports

For general questions or support, you can write the mailing list.

If you stumble on bugs you can report them on the issue tracker.

Cloning/updating the repository

This repository includes the PyNCultures package from the SENeC initiative as its geometry module, using the git submodule feature. It also uses mpl_chord_diagram whithin the plot module. Thus, when cloning the repository, you must do:

git clone https://git.sr.ht/~tfardet/NNGT
cd NNGT && git submodule init && git submodule update

To update your local repository, do:

git pull
git submodule update --remote --merge

Features

Compatibility

  • Currently supports graph-tool (> 2.22), igraph, and networkx (>= 2.4).
  • Interactions with NEST and DeNSE.

Status

  • Standard functions and graph generation algorithms.
  • Special methods for graph analysis on weighted directed networks.
  • Full support for node and edge attributes.
  • Extended I/O features as well as graphical representations.
  • Advanced methods to design neuronal networks.
  • Supports complex 2D structures with shapely.

See documentation on ReadTheDocs.