connected component on a directed graph
data:image/s3,"s3://crabby-images/ec72c/ec72c4ecc12a50c6a3c0e68dcba8e3e913ec9950" alt=""
Dear all, I see that it is already posted a lot of times, but i couldn't find an answer. Baiscally we want the connected component given a vertex given a directed graph. So a -> b -> c -> d e -> f would give {a, b, c, d} given b - for directed graphs there is only the strong component algorithm - for undirected graph there is an algorithm - there seems no adapter to fool the Bgl for interpreting a directed graph as undirected. Can anyone help? I am not a graph (or Bgl) expert, so maybe I am overlooking something. Wkr, me
data:image/s3,"s3://crabby-images/b513d/b513d05490f5928cb9ac5c2131f8f4fd6922a32b" alt=""
On Sep 12, 2007, at 8:06 AM, gast128 wrote:
Dear all,
I see that it is already posted a lot of times, but i couldn't find an answer. Baiscally we want the connected component given a vertex given a directed graph.
So a -> b -> c -> d
e -> f
would give {a, b, c, d} given b
- for directed graphs there is only the strong component algorithm - for undirected graph there is an algorithm - there seems no adapter to fool the Bgl for interpreting a directed graph as undirected.
You can use the "incremental" connected components approach to compute connected components for a directed graph: http://www.boost.org/libs/graph/doc/incremental_components.html - Doug
data:image/s3,"s3://crabby-images/ec72c/ec72c4ecc12a50c6a3c0e68dcba8e3e913ec9950" alt=""
Doug Gregor
You can use the "incremental" connected components approach to compute connected components for a directed graph:
http://www.boost.org/libs/graph/doc/incremental_components.html
- Doug
Thx. But the documentation states that it only works on undirected graphs: 'This section describes a family of functions and classes that work together to calculate the connected components of an undirected graph'
data:image/s3,"s3://crabby-images/e968b/e968bf8ad1f171ddc860bc91fa7ea64a96a071cb" alt=""
gast128 wrote:
Dear all,
I see that it is already posted a lot of times, but i couldn't find an answer. Baiscally we want the connected component given a vertex given a directed graph.
So a -> b -> c -> d
e -> f
would give {a, b, c, d} given b
- for directed graphs there is only the strong component algorithm - for undirected graph there is an algorithm - there seems no adapter to fool the Bgl for interpreting a directed graph as undirected.
Can anyone help? I am not a graph (or Bgl) expert, so maybe I am overlooking something.
I have written an adapter for bidirectional -> undirected, but I don't think it is really fit for production use. You might wanna search the boost-devel list archives. The code is at http://i11www.iti.uni-karlsruhe.de/~jmueller/undirected_graph_adapter.hpp Jens
participants (3)
-
Doug Gregor
-
gast128
-
Jens Müller