|
| 1 | +/** |
| 2 | + * @example chain.cpp |
| 3 | + * |
| 4 | + * @brief Data is send through a chain of compute |
| 5 | + * nodes and every node increments the value. |
| 6 | + * |
| 7 | + */ |
| 8 | + |
| 9 | +// STL |
| 10 | +#include <iostream> /* std::cout */ |
| 11 | +#include <vector> /* std::vector */ |
| 12 | + |
| 13 | +// GRAYBAT |
| 14 | +#include <graybat/Cage.hpp> |
| 15 | +#include <graybat/communicationPolicy/BMPI.hpp> |
| 16 | +#include <graybat/graphPolicy/BGL.hpp> |
| 17 | + |
| 18 | +// GRAYBAT mappings |
| 19 | +#include <graybat/mapping/Consecutive.hpp> |
| 20 | + |
| 21 | +// GRAYBAT pattern |
| 22 | +#include <graybat/pattern/Random.hpp> |
| 23 | + |
| 24 | +struct PageRank { |
| 25 | + PageRank() : pageRank({1}){ } |
| 26 | + std::vector<float> pageRank; |
| 27 | +}; |
| 28 | + |
| 29 | +int exp() { |
| 30 | + /*************************************************************************** |
| 31 | + * Configuration |
| 32 | + ****************************************************************************/ |
| 33 | + |
| 34 | + // CommunicationPolicy |
| 35 | + typedef graybat::communicationPolicy::BMPI CP; |
| 36 | + typedef CP::Config Config; |
| 37 | + |
| 38 | + // GraphPolicy |
| 39 | + typedef graybat::graphPolicy::BGL<PageRank> GP; |
| 40 | + |
| 41 | + // Cage |
| 42 | + typedef graybat::Cage<CP, GP> Cage; |
| 43 | + typedef typename Cage::Event Event; |
| 44 | + typedef typename Cage::Vertex Vertex; |
| 45 | + typedef typename Cage::Edge Edge; |
| 46 | + |
| 47 | + /*************************************************************************** |
| 48 | + * Initialize Communication |
| 49 | + ****************************************************************************/ |
| 50 | + size_t const n = 1000; |
| 51 | + size_t const min = 1; |
| 52 | + size_t const max = 10; |
| 53 | + size_t const seed = 1234; |
| 54 | + Config config; |
| 55 | + Cage cage(config); |
| 56 | + |
| 57 | + cage.setGraph(graybat::pattern::Random<GP>(n, min, max, seed)); |
| 58 | + |
| 59 | + // Distribute vertices |
| 60 | + cage.distribute(graybat::mapping::Consecutive()); |
| 61 | + |
| 62 | + /*************************************************************************** |
| 63 | + * Run Simulation |
| 64 | + ****************************************************************************/ |
| 65 | + std::vector<Event> events; |
| 66 | + size_t const nIterations = 20; |
| 67 | + float const dampingFactor = 0.5; |
| 68 | + |
| 69 | + for(size_t iteration = 0; iteration < nIterations; iteration++){ |
| 70 | + |
| 71 | + // Calculate relative pagerank and spread it to |
| 72 | + // adjacent vertices |
| 73 | + for(Vertex &v : cage.hostedVertices){ |
| 74 | + assert(cage.getAdjacentVertices(v).size() > 0); |
| 75 | + std::vector<float> relativePageRank{1}; |
| 76 | + relativePageRank[0] = v().pageRank[0] / static_cast<float>(cage.getAdjacentVertices(v).size()); |
| 77 | + v.spread(relativePageRank, events); |
| 78 | + } |
| 79 | + |
| 80 | + // Calculate vertex page rank based on |
| 81 | + // relative page rank of adjacent vertices |
| 82 | + for(Vertex &v : cage.hostedVertices){ |
| 83 | + std::vector<float> relativePageRank{1}; |
| 84 | + float relativePageRankSum = 0; |
| 85 | + |
| 86 | + for(Edge e : cage.getInEdges(v)){ |
| 87 | + cage.recv(e, relativePageRank); |
| 88 | + relativePageRankSum += relativePageRank[0]; |
| 89 | + } |
| 90 | + v().pageRank[0] = (1 - dampingFactor) + dampingFactor * relativePageRankSum; |
| 91 | + } |
| 92 | + |
| 93 | + for(unsigned i = 0; i < events.size(); ++i){ |
| 94 | + events.back().wait(); |
| 95 | + events.pop_back(); |
| 96 | + } |
| 97 | + } |
| 98 | + |
| 99 | + // Print page final page rank |
| 100 | + for(Vertex &v : cage.hostedVertices){ |
| 101 | + std::cout << "Pagerank[" <<v.id << "] : " << v().pageRank[0] << std::endl; |
| 102 | + } |
| 103 | + |
| 104 | + return 0; |
| 105 | + |
| 106 | +} |
| 107 | + |
| 108 | +int main(){ |
| 109 | + exp(); |
| 110 | + return 0; |
| 111 | +} |
0 commit comments