Skip to content

Latest commit

 

History

History
74 lines (46 loc) · 1.83 KB

README.md

File metadata and controls

74 lines (46 loc) · 1.83 KB

MiniGraphdb

MiniGraphdb is a minimal in-memory graph library for Ruby.

Why? Where is it going?

I was going back through "Algorithms in a Nutshell" and I hit the Graph chapter. After looking for some toy graph libraries for Ruby, to no avail, I was like: "Shoot mang, I finna code this myself." So I did.

Currently, its meant to be an educational toy. I would like to expose an adapter to save snapshots to a data store (Redis). I am going to run benchmarks against this monkey, a mem profiler, perhaps it will grow-up one day.

Installation

Add this line to your application's Gemfile:

gem 'mini_graphdb'

And then execute:

$ bundle

Or install it yourself as:

$ gem install mini_graphdb

Usage

Create a "simple graph" using an array of vertices

v = [ [ 1, 3 ], [ 1, 2 ], [ 2, 11 ], ]
graph = MiniGraphdb.simple_graph(v)

(1) <-> (3) | (2) <-> (11)

Create a "complex graph" specifying in/out bound edges, weights, etc.

Create a node (subclassed from OpenStruct)

n = MiniGraphdb::Node.new(type: :person, city: "Chi")
n.name = "Fwank"

Create another node, connect with an edge, giving no weight

v = MiniGraphdb::Node.new(type: :category, name: "Favorite Vacation Spots")

n.outbound_edges << v
v.inbound_edges  << n

Create a few other nodes, add to the outbound edges with a weight

vs = MiniGraphdb::Node.new(type: :city, name: "Waikiki")
v.edges.add(vs, 45)

vs = MiniGraphdb::Node.new(type: :city, name: "Dubrovnik")
v.edges.add(vs, 90)

vs = MiniGraphdb::Node.new(type: :city, name: "Geneva")
v.edges.add(vs, 15)

v.edges.byweight

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Added some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request