Unified generation and analysis of networks in Python, with neuroscientific additions

223231a Bugfixes: to_undirected and SWP

~tfardet pushed to ~tfardet/NNGT git

8 days ago

builds.sr.ht via nngt-developers

9 days ago

#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 Documentation Status License DOI Release (latest by date) 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.


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 --user nngt

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



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


  • 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.