Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/anvaka/ngraph
Beautiful Graphs
https://github.com/anvaka/ngraph
Last synced: about 1 month ago
JSON representation
Beautiful Graphs
- Host: GitHub
- URL: https://github.com/anvaka/ngraph
- Owner: anvaka
- License: mit
- Created: 2014-01-02T05:27:25.000Z (about 11 years ago)
- Default Branch: main
- Last Pushed: 2024-05-16T05:16:22.000Z (8 months ago)
- Last Synced: 2024-10-16T05:23:18.216Z (3 months ago)
- Size: 1.59 MB
- Stars: 1,428
- Watchers: 70
- Forks: 131
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-frontend-graph-library - ngraph
- awesome-starred - anvaka/ngraph - Beautiful Graphs (others)
- jimsghstars - anvaka/ngraph - Beautiful Graphs (Others)
README
# ngraph
Ngraph is a set of graph related algorithms. It can be used in a browser
or on the server side. This repository is a collection of examples, which show
how to use some of them or build your own.# What is available?
At the core of the library is [ngraph.graph](https://github.com/anvaka/ngraph.graph)
package, which simply represents a graph data structure.## Interactive renderer
This is set of libraries that use ngraph modules to provide rendering in the
browser:* [VivaGraph](https://github.com/anvaka/VivaGraphJS), one of the [fastest](https://www.youtube.com/watch?v=Ax7KSQZ0_hk)
graph drawing libraries is now [constructed](https://github.com/anvaka/VivaGraphJS/blob/master/package.json)
from ngraph modules. It is an opinionated set of modules packed together.
* [ngraph.pixel](https://github.com/anvaka/ngraph.pixel) - Fast 3D graph renderer
based on low level ShaderMaterial from three.js## Algorithms
* [ngraph.path](https://github.com/anvaka/ngraph.path) - extremely fast path finding on graphs
* [ngraph.kruskal](https://github.com/anvaka/ngraph.kruskal) - minimum spanning tree algorithm## Clusters/Community Detection
* [ngraph.cw](https://github.com/anvaka/ngraph.cw) - fast community detection algorithm, based on label propagation
* [ngraph.louvain](https://github.com/anvaka/ngraph.louvain) - another state of the art algorithm, uses modularity optimization.## Graph metrics
* [ngraph.pagerank](https://github.com/anvaka/ngraph.pagerank) - computes PageRank of a graph.
* [ngraph.hits](https://github.com/anvaka/ngraph.hits) - alternative to PageRank. Implements Hubs and authorities (HITS) algorithm
* [ngraph.centrality](https://github.com/anvaka/ngraph.centrality) - computation of centrality.## Serialization
* Dot files serializer [from](https://github.com/anvaka/ngraph.fromdot)/[to](https://github.com/anvaka/ngraph.todot)
* (Gephi) `gexf` file - [Source](https://github.com/anvaka/ngraph.gexf); [Demo](https://github.com/anvaka/ngraph/tree/master/examples/storage/gephi)
* [Binary format](https://github.com/anvaka/ngraph.tobinary) - space-efficient
format for large graphs. E.g. 5 million edges, 1 million nodes requires only 23 MB of space.## Graph layout
* [ngraph.forcelayout](https://github.com/anvaka/ngraph.forcelayout) performs force
based layout in arbitrary dimensions space (2D, 3D, 4D, and so on).When layout in the browser is not feasible (e.g. the graph is too large
to achieve decent performance) we can compute layout offline and
provide static positions to the browser:* [ngraph.offline.layout](https://github.com/anvaka/ngraph.offline.layout) is an
npm module to perform such layout. If this module is too slow, you can also
try:
* [ngraph.native](https://github.com/anvaka/ngraph.native) which is fully implemented
in C++ and is 9x faster thant javascript version.## Other
There are plenty modules within ngraph family: [this npm search](https://www.npmjs.com/search?q=ngraph)
shows most of them## Playground
You can quickly start a new project with core ngraph modules using this template project: https://github.com/anvaka/graph-start
# Building your own modules
This repository has multiple examples how to build your own module which suits
your needs best:* [Rendering graphs with PIXI.js](https://github.com/anvaka/ngraph/tree/master/examples/pixi.js)
* [Rendering graphs with fabric.js](https://github.com/anvaka/ngraph/tree/master/examples/fabric.js)
* [Rendering graph from terminal](https://github.com/anvaka/ngraph/tree/master/examples/terminal)
* [Rendering 3D graphs](https://github.com/anvaka/ngraph/tree/master/examples/three.js)# Video
Here is an introduction video to this library: [Browserify Monolith](https://www.youtube.com/watch?v=Kp377p-NSFc). This library has also appeared in TEDx talk at Stanford: [The Beauty I See in Algebra](https://www.youtube.com/watch?v=8CX-Q0gtSp8) by Margot Gerritsen. It has also appeared in this TEDx talk [How can visualizing our personal data empower our health?](https://www.youtube.com/watch?v=90y_iAHyO0w) by Amina Qutub# Why?
I built [vivagraph](https://github.com/anvaka/VivaGraphJS) to learn javascript two years ago.
I definitely learned a lot and vivagraph itself is a pretty decent graph drawing library.However vivagraph is built in monolithic way. For example, if I wanted to add new streaming
traversal API I could not justify it inside monolithic "graph drawing" library.Ngraph opens huge possibilities, with each module being available on [npm](https://npmjs.org/).
Now you can pick just what you need and swap out parts which are not relevant to
your project.I'm not abandoning vivagraph by any means. Quite the opposite, this repository is
a next step of evolution.# How to run examples locally?
`ngraph` is powered by `npm`. All examples require a `bundle.js` file, which is produced by executing `npm start` command inside folder with example. Make sure you have all modules installed inside a folder (`npm install` inside folder with example will download all dependencies).Looking for alternatives?
-------------------------I'm trying to put up a list of all known graph drawing libraries.
Please [find it here](http://anvaka.github.io/graph-drawing-libraries/#/all)# license
MIT