graph_communicator.cpp
来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 74 行
CPP
74 行
// Copyright (C) 2007 Trustees of Indiana University// Authors: Douglas Gregor// Andrew Lumsdaine// Use, modification and distribution is subject to the Boost Software// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at// http://www.boost.org/LICENSE_1_0.txt)#include <boost/mpi/graph_communicator.hpp>namespace boost { namespace mpi {// Incidence Graph requirementsstd::pair<detail::comm_out_edge_iterator, detail::comm_out_edge_iterator>out_edges(int vertex, const graph_communicator& comm){ int nneighbors = out_degree(vertex, comm); shared_array<int> neighbors(new int[nneighbors]); BOOST_MPI_CHECK_RESULT(MPI_Graph_neighbors, ((MPI_Comm)comm, vertex, nneighbors, neighbors.get())); return std::make_pair(detail::comm_out_edge_iterator(vertex, neighbors, 0), detail::comm_out_edge_iterator(vertex, neighbors, nneighbors));}int out_degree(int vertex, const graph_communicator& comm){ int nneighbors; BOOST_MPI_CHECK_RESULT(MPI_Graph_neighbors_count, ((MPI_Comm)comm, vertex, &nneighbors)); return nneighbors;}// Adjacency Graph requirementsstd::pair<detail::comm_adj_iterator, detail::comm_adj_iterator>adjacent_vertices(int vertex, const graph_communicator& comm){ int nneighbors = out_degree(vertex, comm); shared_array<int> neighbors(new int[nneighbors]); BOOST_MPI_CHECK_RESULT(MPI_Graph_neighbors, ((MPI_Comm)comm, vertex, nneighbors, neighbors.get())); return std::make_pair(detail::comm_adj_iterator(neighbors, 0), detail::comm_adj_iterator(neighbors, nneighbors));}// Edge List Graph requirementsstd::pair<detail::comm_edge_iterator, detail::comm_edge_iterator>edges(const graph_communicator& comm);std::pair<detail::comm_edge_iterator, detail::comm_edge_iterator>edges(const graph_communicator& comm){ int nnodes, nedges; BOOST_MPI_CHECK_RESULT(MPI_Graphdims_get, ((MPI_Comm)comm, &nnodes, &nedges)); shared_array<int> indices(new int[nnodes]); shared_array<int> edges(new int[nedges]); BOOST_MPI_CHECK_RESULT(MPI_Graph_get, ((MPI_Comm)comm, nnodes, nedges, indices.get(), edges.get())); return std::make_pair(detail::comm_edge_iterator(indices, edges), detail::comm_edge_iterator(nedges));}int num_edges(const graph_communicator& comm){ int nnodes, nedges; BOOST_MPI_CHECK_RESULT(MPI_Graphdims_get, ((MPI_Comm)comm, &nnodes, &nedges)); return nedges;}} } // end namespace boost::mpi
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?