[BGL] creating a single vertex for the loop in a graph
data:image/s3,"s3://crabby-images/de83b/de83b1e0a80eb32bb765228e60cd9d967a3290d0" alt=""
Hello All, I am looking for the following in boost graph. I have a graph in which I am able to find out the loops. Now, I wanted to replace the whole loop with a single vertex in the same Graph. Is that possible ? if it is, can you suggest me how do it. Alternate way could be, I copy the loop and make another graph and add this whole graph as a "vertex" in initial graph. Can I add a "graph" as a vertex to existing graph? Thanks and regards, Srinivas Boppu
data:image/s3,"s3://crabby-images/419b9/419b98040b1aafdd99afce5cf25276432634c9ef" alt=""
Am 12.01.2012 16:09, schrieb srinivas boppu:
Hello All,
I am looking for the following in boost graph.
I have a graph in which I am able to find out the loops.
Cycles. "loop" is easily misunderstood as self-loop, i.e., an edge (v,v).
Now, I wanted to replace the whole loop with a single vertex in the same Graph.
Is that possible ? if it is, can you suggest me how do it.
What happens with your edges? They get collapsed? So {v1,...,vn} becomes v, each (u,vi) becomes (u,v) and each (vi,u) becomes (v,u)? Easy enough, I'd say. Add v, iterate over all vi and their edges, add the respective (u,v) or (v,u) edges. Note that deleting vertices is difficult with an adjacency list storing vertices in a vector (vecS), because deleting a vertex invalidates _all_ vertex and edge descriptors/iterators of the graph. With listS or setS, however, it's easy: Just iterate over your list of vertices in the cycle and delete them.
Alternate way could be, I copy the loop
To what?
and make another graph
Looking how?
and add this whole graph as a "vertex" in initial graph.
"Initial" graph?
Can I add a "graph" as a vertex to existing graph?
That's known as hierarchical graphs. I don't think there is a dedicated type in the BGL. But I wonder whether this (one graph per vertex) is really the proper way to represent a hierarchical graph. -- Jens
data:image/s3,"s3://crabby-images/e5702/e570265f900a3b9564b22189d72b1c797ca0217f" alt=""
On Thu, 12 Jan 2012, srinivas boppu wrote:
Hello All,
I am looking for the following in boost graph.
I have a graph in which I am able to find out the loops. Now, I wanted to replace the whole loop with a single vertex in the same Graph.
Is that possible ? if it is, can you suggest me how do it.
Is this a directed graph? Are you trying to replace each strongly connected component with a single vertex? In that case, look at boost/graph/create_condensation_graph.hpp (undocumented AFAIK) and see if it does what you want. If you just need a topological sort of the components, use the normal strong_components() function.
Alternate way could be, I copy the loop and make another graph and add this whole graph as a "vertex" in initial graph.
Can I add a "graph" as a vertex to existing graph?
No; you could have a graph with a vertex property that is another graph, but that will not allow the graphs stored in properties to link to each other. -- Jeremiah Willcock
participants (3)
-
Jens Müller
-
Jeremiah Willcock
-
srinivas boppu