ug4
parallelization_util.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2010-2015: G-CSC, Goethe University Frankfurt
3  * Authors: Andreas Vogel, Sebastian Reiter
4  *
5  * This file is part of UG4.
6  *
7  * UG4 is free software: you can redistribute it and/or modify it under the
8  * terms of the GNU Lesser General Public License version 3 (as published by the
9  * Free Software Foundation) with the following additional attribution
10  * requirements (according to LGPL/GPL v3 §7):
11  *
12  * (1) The following notice must be displayed in the Appropriate Legal Notices
13  * of covered and combined works: "Based on UG4 (www.ug4.org/license)".
14  *
15  * (2) The following notice must be displayed at a prominent place in the
16  * terminal output of covered works: "Based on UG4 (www.ug4.org/license)".
17  *
18  * (3) The following bibliography is recommended for citation and must be
19  * preserved in all covered files:
20  * "Reiter, S., Vogel, A., Heppner, I., Rupp, M., and Wittum, G. A massively
21  * parallel geometric multigrid solver on hierarchically distributed grids.
22  * Computing and visualization in science 16, 4 (2013), 151-164"
23  * "Vogel, A., Reiter, S., Rupp, M., Nägel, A., and Wittum, G. UG4 -- a novel
24  * flexible software system for simulating pde based models on high performance
25  * computers. Computing and visualization in science 16, 4 (2013), 165-179"
26  *
27  * This program is distributed in the hope that it will be useful,
28  * but WITHOUT ANY WARRANTY; without even the implied warranty of
29  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
30  * GNU Lesser General Public License for more details.
31  */
32 
33 #ifndef __H__UG__LIB_DISC__PARALLELIZATION__PARALLELIZATION_UTIL__
34 #define __H__UG__LIB_DISC__PARALLELIZATION__PARALLELIZATION_UTIL__
35 
36 #include "pcl/pcl_util.h"
43 
44 namespace ug
45 {
46 
48 
62 bool CreateLevelIndexLayout( IndexLayout& layoutOut,
63  DoFDistribution& dofDistr,
64  GridLayoutMap& layoutMap,
65  int keyType, int level);
66 
68 
82 bool CreateSurfaceIndexLayout( IndexLayout& layoutOut,
83  DoFDistribution& dofDistr,
84  GridLayoutMap& layoutMap,
85  int keyType,
86  MultiGrid& mg, DistributedGridManager& dGrMgr);
87 
88 
90  IndexLayout& processLayoutOut,
91  IndexLayout& subdomainLayoutOut,
92  DoFDistribution& dofDistr,
93  GridLayoutMap& layoutMap,
94  int keyType, int level,
96 
97 
98 // returns in a vector all appearencies of an index in a layout
99 void FindPositionInInterfaces(std::vector<std::pair<int, size_t> >& vIndexInterface,
100  const IndexLayout& layout, size_t index);
101 
103  size_t numIDs,
104  IndexLayout& processMasterLayoutIn,
105  IndexLayout& processSlaveLayoutIn,
106  IndexLayout& subdomainMasterLayoutInOut,
107  IndexLayout& subdomainSlaveLayoutInOut);
108 
110 
121  const std::vector<size_t>& vIndNew);
122 
123 }// end of namespace
124 
125 #endif
Definition: pcl_domain_decomposition.h:43
pcl::SingleLevelLayout< pcl::OrderedInterface< size_t, std::vector > > IndexLayout
Definition: parallel_index_layout.h:53
the ug namespace
bool CreateLevelIndexLayout(IndexLayout &layoutOut, DoFDistribution &dofDistr, GridLayoutMap &layoutMap, int keyType, int level)
creates the index layout for a level given a GridLayoutMap
Definition: parallelization_util.cpp:138
void PermuteIndicesInIndexLayout(IndexLayout &layout, const std::vector< size_t > &vIndNew)
permutes an IndexLayout for the permutation of indices
Definition: parallelization_util.cpp:431
bool AddExtraProcessEntriesToSubdomainLayout(size_t numIDs, IndexLayout &processMasterLayoutIn, IndexLayout &processSlaveLayoutIn, IndexLayout &subdomainMasterLayoutInOut, IndexLayout &subdomainSlaveLayoutInOut)
Definition: parallelization_util.cpp:340
void FindPositionInInterfaces(std::vector< std::pair< int, size_t > > &vIndexInterface, const IndexLayout &layout, size_t index)
returns in a vector all appearencies of an index in a layout
Definition: parallelization_util.cpp:316
bool CreateSurfaceIndexLayout(IndexLayout &layoutOut, DoFDistribution &dofDistr, GridLayoutMap &layoutMap, int keyType, MultiGrid &mg, DistributedGridManager &dGrMgr)
creates the index layout for a level given a GridLayoutMap
Definition: parallelization_util.cpp:260
bool CreateIndexLayouts_DomainDecomposition(IndexLayout &processLayoutOut, IndexLayout &subdomainLayoutOut, DoFDistribution &dofDistr, GridLayoutMap &layoutMap, int keyType, int level, pcl::IDomainDecompositionInfo *ddInfoIn)
Definition: parallelization_util.cpp:533