dag v1.0.0
DAG - Directed Acyclic Graph API
A directed acyclic graph (DAG) API written in the crystal programming languge. This DAG implementation can be used for creating schedulers. E.g.: running multiple tasks which has predefined dependencies.
Installation
-
Add the dependency to your
shard.yml
:dependencies: dag: github: dseres/dag
-
Run
shards install
Usage
Create a new Graph object. You can add and delete vertices and edges easily. If you enumarate the vertices with the #each method, the enumeration will be topologically sorted. The graph structure uses adjacency lists in the backend (implemented with Hash(K,V)), and you can store any hashable objects in it.
require "dag"
dag = Dag::Graph(Int32).new
(1...10).each { |i| dag.add i}
dag.add_edge({1, 3} , {5, 9} , {8, 7} , {8, 6} , {6, 4} , {4, 3} , {4, 7})
dag.successors 4 # => [3,7]
dag.each { |v| p! v}
dag.to_a # => [1, 2, 5, 9, 8, 6, 4, 3, 7]
Contributing
- Fork it (https://github.com/your-github-user/dag_cr/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
Contributors
- dseres - creator and maintainer
Repository
dag
Owner
Statistic
- 1
- 0
- 0
- 0
- 1
- 12 months ago
- October 10, 2021
License
MIT License
Links
Synced at
Tue, 01 Jul 2025 10:20:41 GMT
Languages