Skip to main content

View graph data structures in the IPython notebook.

Reason this release was yanked:

python-igraph was renamed to igraph; deleting old packages to avoid confusion

Project description

igraph
======

An embeddable webGL graph visualization library.
http://patrickfuller.github.io/igraph/

Examples
========

* [IPython notebook](http://patrickfuller.github.io/igraph/examples/ipython.html)
* [les misérables](http://patrickfuller.github.io/igraph/examples/miserables.html)
* [github connections](http://patrickfuller.github.io/igraph/examples/github.html)

IPython
=======

The IPython notebook is an open-source tool poised to replace MATLAB in many
applications. As a scientist of sorts, I'm all about it. Therefore, I made
handles to use igraph with the notebook. Install through pip:

```
pip install igraph
```

Open a new notebook and test the setup by typing:

```python
import igraph
igraph.draw([(1, 2), (2, 3), (3, 4), (4, 1), (4, 5), (5, 2)])
```

into a notebook cell. You should get a paddlewheel graph as an output. You can
use this in conjunction with other code for educational purposes (try generating
a red-black tree!). There are three commands and some optional parameters to
check out. Read the docstrings and check out the [associated
example](http://patrickfuller.github.io/igraph/examples/ipython.html) for more.

Javascript
==========

Start by downloading the minified javascript file:

```
wget https://raw.githubusercontent.com/patrickfuller/igraph/master/js/build/igraph.min.js
```

Include this file alongside [jQuery](http://jquery.com/) in your project, and then use with:

```javascript
igraph.create('my-selector');
igraph.draw(myGraph);
```

where `'my-selector'` is where you want to place igraph, and `myGraph` is a
plain ol' object. See below for more on the object structure, or just check out
the included example. The `igraph.create()` method takes a few optional
parameters, specifying the sizes and colors of nodes, as well as force-directed
optimization.

```javascript
options = {
directed: true, // Toggles edge arrows
nodeSize: 2.0, // Default node size
edgeSize: 0.25, // Edge connection diameter
arrowSize: 1.0, // If drawn, edge arrow size
defaultNodeColor: 0xaaaaaa, // Color for nodes without a "color" property
defaultEdgeColor: 0x777777, // Color for edges without a "color" property
shader: "toon", // three.js shader to use, can be "toon", "basic", "phong", or "lambert"
runOptimization: true // Runs a force-directed-layout algorithm on the graph
};
```

Graph Data Format
=================

igraph takes input graph data structures as plain objects. Here's the most
boring graph in the world:

```javascript
{
nodes: {
jane: { },
bob: { },
mike: { },
sally: { }
},
edges: [
{ source: "jane", target: "bob" },
{ source: "bob", target: "mike" },
{ source: "mike", target: "sally" }
]
}
```

Nodes require no information outside of their keys. However, there are useful
optional parameters that can be specified.

```javascript
{
color: 0xffffff, // Color for this node
size: 1.0, // Scaling factor for this node's size
location: [0.0, 0.0, 0.0] // Starting location of node. Useful for pre-rendering.
}
```

By default, the algorithm runs a force-directed layout on the graph. When
enabled, the "location" field is optional. However, for larger graphs, you will
want to disable this feature and pre-render the locations. Use the associated
Python library (`igraph.generate`) to do so.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

igraph-0.1.5.tar.gz (121.9 kB view details)

Uploaded Source

Built Distribution

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

igraph-0.1.5-py2.py3-none-any.whl (122.6 kB view details)

Uploaded Python 2Python 3

File details

Details for the file igraph-0.1.5.tar.gz.

File metadata

  • Download URL: igraph-0.1.5.tar.gz
  • Upload date:
  • Size: 121.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for igraph-0.1.5.tar.gz
Algorithm Hash digest
SHA256 b7632bfb9f2eccaaaa1b65bdf3d5034db08d4afc3f4194c0b80373615d48b618
MD5 d7734dd985ede2af8611edbb52d1b18c
BLAKE2b-256 0c65909a55a2d185b4b5bf5223d30eb7b1b83bb81545f9e9b7f52458cbf4608d

See more details on using hashes here.

File details

Details for the file igraph-0.1.5-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for igraph-0.1.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 addc81a795cb3dd87709c990548b37a2bca29e30037111ae4dfb81e18228a144
MD5 99d7dc96132f2f893dbf7a762c91e27a
BLAKE2b-256 83e972969a292413d4fc20a061466f5d8aa766d452f02ff4af75f443bf862170

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