algograph

Crates.ioalgograph
lib.rsalgograph
version0.3.0
sourcesrc
created_at2023-03-20 15:14:36.982466
updated_at2023-07-09 03:01:00.482755
descriptionA (both directed and undirected) graph and their algorithms implemented in Rust
homepage
repositoryhttps://github.com/TimeExceed/algograph
max_upload_size
id815356
size110,283
Taoda (TimeExceed)

documentation

README

algograph

Directed or undirected graphs and their algorithms implemented in Rust.

Low-level graphs and tagged graphs

Some graph libraries allow customized types of vertices and edges. But for algorithm authors, these customized types are hard to deal with. Can we copy a vertex? What is the cost of doing that copying?

In this crate, there are traits and implementations of low level graphs. Vertices and edges in low level graphs are lightweight ID's. They are essentially usize. Algorithm authors may feel free to copy and store these ID's.

Based on low-level graphs, for convenience, there are also traits and a naive implementation to support graphs with customized vertex types and edge types. They are under tagged module.

ShadowedSubgraph and SelectedSubgraph

They can form subgraphs with shadowed/selected vertices and edges. Futhermore, these subgraphs are shrinkable. While they are shrinking, their underlying graphs are kept unchanged.

Commit count: 17

cargo fmt