Skip to main content

Graph and drawing algorithms framework

Project description

Grandalf is a python package made for experimentations with graphs and drawing algorithms. It is written in pure python, and implements two layouts: the Sugiyama hierarchical layout and the force-driven or energy minimization approach. While not as fast or featured as graphviz or other libraries like OGDF (C++), GDToolkit (C), tulip (Java), it provides a way to draw and navigate graphs no larger than thousands of nodes, while keeping the source code simple enough to make it possible to easily tweak and hack any part of it for experimental purpose. With a total of about 1500 lines of python, the code involved in drawing the Sugiyama (dot) layout fits in less than 600 lines. The energy minimization approach is comprised of only 250 lines!

Grandalf does only two not-so-simple things:

  • computing the nodes (x,y) coordinates (based on provided nodes dimensions, and a chosen layout)
  • routing the edges with lines or nurbs

It doesn’t depend on any GTK/Qt/whatever graphics toolkit. This means that it will help you find where to draw things like nodes and edges, but it’s up to you to actually draw things with your favorite graphics toolkit.

Project details


Release history Release notifications

This version

0.6

Download files

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

Files for grandalf, version 0.6
Filename, size File type Python version Upload date Hashes
Filename, size grandalf-0.6-py2.7.egg (72.6 kB) File type Egg Python version 2.7 Upload date Hashes View hashes
Filename, size grandalf-0.6-py2-none-any.whl (31.2 kB) File type Wheel Python version py2 Upload date Hashes View hashes
Filename, size grandalf-0.6-py3.5.egg (75.6 kB) File type Egg Python version 3.5 Upload date Hashes View hashes
Filename, size grandalf-0.6-py3-none-any.whl (31.2 kB) File type Wheel Python version py3 Upload date Hashes View hashes
Filename, size grandalf-0.6.tar.gz (36.7 kB) File type Source Python version None Upload date Hashes View hashes

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page