|
Boost Users : |
Subject: Re: [Boost-users] [graph] Example parallel BGL
From: Sensei (senseiwa_at_[hidden])
Date: 2015-08-03 11:01:35
On 8/3/15 12:18pm, Marcin Zalewski wrote:
> You can find some examples here:
>
> https://github.com/boostorg/graph_parallel/tree/master/example
>
> You can also look at tests:
>
> https://github.com/boostorg/graph_parallel/tree/master/test
Thanks, Marcin, I finally can compile my code!
I wrote a simple graph based on the named graph example (*), in order to
learn, but my code seems to avoid nodes distribution, while the example
does it perfectly.
(*)
https://github.com/boostorg/graph_parallel/blob/master/test/named_vertices_test.cpp
In my source I think I made the same steps, but I'm obviously
mistaken... my example every processor has every node, and every edge
if I comment the if statement.
I think I'm using the wrong boost::add_vertex/edge here, but honestly, I
am a very newbie on the distributed graph side.
Thanks for any pointers you can give me!
#include <iostream>
#include <string>
#include <vector>
#include <cmath>
#include <list>
#include <functional>
#include <boost/mpi.hpp>
#include <boost/graph/use_mpi.hpp>
#include <boost/graph/distributed/mpi_process_group.hpp>
#include <boost/graph/distributed/adjacency_list.hpp>
//using namespace boost;
//using boost::graph::distributed::mpi_process_group;
int main(int argc, const char * argv[])
{
boost::mpi::environment env;
boost::mpi::communicator comm;
std::cout << comm.rank() << std::endl;
typedef boost::adjacency_list<boost::vecS,
boost::distributedS<boost::graph::distributed::mpi_process_group,
boost::vecS>,
boost::directedS, std::string> graph;
graph g;
std::vector<std::string> names { "alpha", "beta", "gamma", "delta" };
std::vector<graph::vertex_descriptor> descs;
for(auto p : names) descs.push_back(boost::add_vertex(p, g));
if (comm.rank() == 0)
{
boost::add_edge(descs[0], descs[0], g);
boost::add_edge(descs[0], descs[1], g);
boost::add_edge(descs[1], descs[2], g);
boost::add_edge(descs[2], descs[3], g);
}
boost::synchronize(g);
BGL_FORALL_VERTICES(v, g, graph)
{
std::cout << "V @ " << comm.rank() << " " << g[v] << std::endl;
}
BGL_FORALL_EDGES(e, g, graph)
{
std::cout << "E @ " << comm.rank() << " " << boost::source(e,
g).local << " -> " << boost::target(e, g).local << " srccpu " <<
e.source_processor << " dstcpu " << e.target_processor << std::endl;
}
return 0;
}
***OUTPUT***
5
4
2
1
3
0
V @ 1 alpha
V @ 1 beta
V @ 1 gamma
V @ 1 delta
E @ 1 0 -> 0 srccpu 1 dstcpu 1
E @ 1 0 -> 1 srccpu 1 dstcpu 1
E @ 1 1 -> 2 srccpu 1 dstcpu 1
E @ 1 2 -> 3 srccpu 1 dstcpu 1
V @ 3 alpha
V @ 3 beta
V @ 3 gamma
V @ 3 delta
E @ 3 0 -> 0 srccpu 3 dstcpu 3
E @ 3 0 -> 1 srccpu 3 dstcpu 3
E @ 3 1 -> 2 srccpu 3 dstcpu 3
E @ 3 2 -> 3 srccpu 3 dstcpu 3
V @ 2 alpha
V @ 2 beta
V @ 2 gamma
V @ 2 delta
E @ 2 0 -> 0 srccpu 2 dstcpu 2
E @ 2 0 -> 1 srccpu 2 dstcpu 2
E @ 2 1 -> 2 srccpu 2 dstcpu 2
E @ 2 2 -> 3 srccpu 2 dstcpu 2
V @ 5 alpha
V @ 5 beta
V @ 5 gamma
V @ 5 delta
E @ 5 0 -> 0 srccpu 5 dstcpu 5
E @ 5 0 -> 1 srccpu 5 dstcpu 5
E @ 5 1 -> 2 srccpu 5 dstcpu 5
E @ 5 2 -> 3 srccpu 5 dstcpu 5
V @ 4 alpha
V @ 4 beta
V @ 4 gamma
V @ 4 delta
E @ 4 0 -> 0 srccpu 4 dstcpu 4
E @ 4 0 -> 1 srccpu 4 dstcpu 4
E @ 4 1 -> 2 srccpu 4 dstcpu 4
E @ 4 2 -> 3 srccpu 4 dstcpu 4
V @ 0 alpha
V @ 0 beta
V @ 0 gamma
V @ 0 delta
E @ 0 0 -> 0 srccpu 0 dstcpu 0
E @ 0 0 -> 1 srccpu 0 dstcpu 0
E @ 0 1 -> 2 srccpu 0 dstcpu 0
E @ 0 2 -> 3 srccpu 0 dstcpu 0
Boost-users list run by williamkempf at hotmail.com, kalb at libertysoft.com, bjorn.karlsson at readsoft.com, gregod at cs.rpi.edu, wekempf at cox.net