vf2_sub_graph_iso_example.cpp 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. //=======================================================================
  2. // Copyright (C) 2012 Flavio De Lorenzi (fdlorenzi@gmail.com)
  3. //
  4. // Distributed under the Boost Software License, Version 1.0. (See
  5. // accompanying file LICENSE_1_0.txt or copy at
  6. // http://www.boost.org/LICENSE_1_0.txt)
  7. //=======================================================================
  8. #include <boost/graph/adjacency_list.hpp>
  9. #include <boost/graph/vf2_sub_graph_iso.hpp>
  10. using namespace boost;
  11. int main() {
  12. typedef adjacency_list<setS, vecS, bidirectionalS> graph_type;
  13. // Build graph1
  14. int num_vertices1 = 8; graph_type graph1(num_vertices1);
  15. add_edge(0, 6, graph1); add_edge(0, 7, graph1);
  16. add_edge(1, 5, graph1); add_edge(1, 7, graph1);
  17. add_edge(2, 4, graph1); add_edge(2, 5, graph1); add_edge(2, 6, graph1);
  18. add_edge(3, 4, graph1);
  19. // Build graph2
  20. int num_vertices2 = 9; graph_type graph2(num_vertices2);
  21. add_edge(0, 6, graph2); add_edge(0, 8, graph2);
  22. add_edge(1, 5, graph2); add_edge(1, 7, graph2);
  23. add_edge(2, 4, graph2); add_edge(2, 7, graph2); add_edge(2, 8, graph2);
  24. add_edge(3, 4, graph2); add_edge(3, 5, graph2); add_edge(3, 6, graph2);
  25. // Create callback to print mappings
  26. vf2_print_callback<graph_type, graph_type> callback(graph1, graph2);
  27. // Print out all subgraph isomorphism mappings between graph1 and graph2.
  28. // Vertices and edges are assumed to be always equivalent.
  29. vf2_subgraph_iso(graph1, graph2, callback);
  30. return 0;
  31. }