#undirected-graph #construct #line #graph-algorithms

line-graph

Construct the line graph of an undirected graph

1 unstable release

0.1.0 Feb 10, 2022

#1737 in Math

MIT/Apache

6KB
85 lines

line-graph

Construct the line graph of an undirected graph

This crate provides a single function that takes an undirected petgraph graph and constructs the corresponding line graph. Node weights are turned into edge weights and vice versa.

Example

The triangle graph is the same as its line graph.

use line_graph::line_graph;
use petgraph::{
   algo::is_isomorphic,
   graph::UnGraph
};

let g = UnGraph::<(), ()>::from_edges([(0, 1), (1, 2), (2, 0)]);
let g_line = line_graph(&g);
assert!(is_isomorphic(&g, &g_line));

Caveats

If edges are connected by two vertices, the corresponding vertices in the line graph will also be connected by two edges.

License: MIT OR Apache-2.0


lib.rs:

Construct the line graph of an undirected graph

This crate provides a single function that takes an undirected petgraph graph and constructs the corresponding line graph. Node weights are turned into edge weights and vice versa.

Example

The triangle graph is the same as its line graph.

use line_graph::line_graph;
use petgraph::{
   algo::is_isomorphic,
   graph::UnGraph
};

let g = UnGraph::<(), ()>::from_edges([(0, 1), (1, 2), (2, 0)]);
let g_line = line_graph(&g);
assert!(is_isomorphic(&g, &g_line));

Caveats

If edges are connected by two vertices, the corresponding vertices in the line graph will also be connected by two edges.

Dependencies

~2MB
~30K SLoC