Re: [Boost-users] Identify cycles in a undirected graph
data:image/s3,"s3://crabby-images/17783/17783e751c3b948f4dd4c2a24b207e874c51fc9b" alt=""
Sorry for the Doble posting,
wast'nt yet register to the mailing list.
Cheers!
hi Folks, I've played around with the following example:
struct detect_loops : public boost::dfs_visitor<>
{
template
data:image/s3,"s3://crabby-images/e5702/e570265f900a3b9564b22189d72b1c797ca0217f" alt=""
On Thu, 8 Mar 2012, ddboy40 wrote:
Sorry for the Doble posting, wast'nt yet register to the mailing list. Cheers!
hi Folks, I've played around with the following example:
struct detect_loops : public boost::dfs_visitor<> { template
void back_edge(Edge e, const Graph& g) { std::cout << source(e, g) << " -- " << target(e, g) << "\n"; } }; int main(int,char*[]) {
typedef std::pair
Edge; std::vector<Edge> edges; edges.push_back(Edge(0,1)); edges.push_back(Edge(1,2)); edges.push_back(Edge(2,3)); edges.push_back(Edge(3,1)); edges.push_back(Edge(4,5)); edges.push_back(Edge(5,0)); edges.push_back(Edge(4,0)); edges.push_back(Edge(5,6)); edges.push_back(Edge(2,6)); typedef adjacency_list< vecS, vecS, undirectedS, no_property, property
> graph_t; typedef graph_traits ::vertex_descriptor vertex_t; graph_t g(edges.begin(), edges.end(), 7);
std::cout << "back edges:\n"; detect_loops vis; undirected_dfs(g, root_vertex(vertex_t(0)).visitor(vis).edge_color_map(get(edge_color, g))); std::cout << std::endl;
return 0; }
However, I donot know how and where to place the predeccesor recorder. Secondly, I actually need but all the cycles, i.e. these may not have only distinct verterces. i.e some vertices may occur repeated in certain circles. My example above has 3 distinct cycles I guess and thats wha t the the back_edge() gives. But, I'll like to have all the hamiltonian cycles (hope they call it like that ;)). Thanks in advance for the tipps.
Finding all Hamiltonian cycles will be difficult (see http://en.wikipedia.org/wiki/Hamiltonian_cycle_problem). Are you sure that's what you want -- all cycles that go through each vertex exactly once? Or do you want all cycles of any length? Or something else? -- Jeremiah Willcock
data:image/s3,"s3://crabby-images/17783/17783e751c3b948f4dd4c2a24b207e874c51fc9b" alt=""
Hey, thanks for the rasch reply. I need just all cycles of any length. At the moment I donot care if the code is inefficient. I just need something really working. My graph is undirected and unweighted. Thanks. Daniel -- View this message in context: http://boost.2283326.n4.nabble.com/Identify-cycles-in-a-undirected-graph-tp4... Sent from the Boost - Users mailing list archive at Nabble.com.
data:image/s3,"s3://crabby-images/17783/17783e751c3b948f4dd4c2a24b207e874c51fc9b" alt=""
Hola Folks! I finally gave up the try using BGL, well, for the moment anyway. I'll latter look into the matter a gain. For now, this is my approach (I know this is really an over kill, but I just want things to work first) 1.) find all combinations of at least 3 vertices (my graphs are not big, max 45 vertices so far) 2.) remove all repeating permutations e.g. for A-B-C-A = B-C-A-B = C-A-B-C, use regex to match and select only one such cycle since they are all thesame in an undirected graph. 3.) For each set from 2.) above, check its connectivity and accept if it has a single cycle i.e number of vertices = number of edges Done! -- View this message in context: http://boost.2283326.n4.nabble.com/Identify-cycles-in-a-undirected-graph-tp4... Sent from the Boost - Users mailing list archive at Nabble.com.
participants (2)
-
ddboy40
-
Jeremiah Willcock