source: ThirdParty/vmg/src/grid/global_grid_partitioning.cpp@ 4e0e08

Action_Thermostats Add_AtomRandomPerturbation Add_RotateAroundBondAction Add_SelectAtomByNameAction Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests AutomationFragmentation_failures Candidate_v1.6.0 Candidate_v1.6.1 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_ChronosMutex Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion GeometryObjects Gui_displays_atomic_force_velocity IndependentFragmentGrids_IntegrationTest JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix PartialCharges_OrthogonalSummation PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo StoppableMakroAction TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps Ubuntu_1604_changes stable
Last change on this file since 4e0e08 was 7faa5c, checked in by Frederik Heber <heber@…>, 8 years ago

Merge commit 'de061d9d851257a04e924d4472df4523d33bb08b' as 'ThirdParty/vmg'

  • Property mode set to 100644
File size: 2.3 KB
Line 
1/*
2 * vmg - a versatile multigrid solver
3 * Copyright (C) 2012 Institute for Numerical Simulation, University of Bonn
4 *
5 * vmg is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
9 *
10 * vmg is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18
19/**
20 * @file global_grid_partitioning.hpp
21 * @author Julian Iseringhausen <isering@ins.uni-bonn.de>
22 * @date Thu May 19 14:02:46 2011
23 *
24 * @brief Class to store global grid partitioning.
25 *
26 */
27
28#ifdef HAVE_CONFIG_H
29#include <libvmg_config.h>
30#endif
31
32#include <cassert>
33
34#include "grid/global_grid_partitioning.hpp"
35
36using namespace VMG;
37
38GlobalGridPartitioning::GlobalGridPartitioning(Index pos, Index procs, Index size, int points_min)
39{
40 Index i;
41 Index index_beg, index_end;
42 Index local_size;
43
44 const Index active_procs = size / points_min;
45 const Index size_per_proc = size / active_procs;
46 const Index remainder = size % active_procs;
47
48 for (i.X() = 0; i.X() < active_procs.X(); ++i.X())
49 for (i.Y() = 0; i.Y() < active_procs.Y(); ++i.Y())
50 for (i.Z() = 0; i.Z() < active_procs.Z(); ++i.Z()) {
51
52 local_size = size_per_proc;
53
54 for (int j=0; j<3; ++j)
55 if (pos[j] < remainder[j])
56 ++(local_size[j]);
57
58 index_beg = i * local_size;
59
60 for (int j=0; j<3; ++j)
61 if (i[j] >= remainder[j])
62 index_beg[j] += remainder[j];
63
64 index_end = index_beg + local_size;
65
66 begin.insert(std::make_pair(i, index_beg));
67 end.insert(std::make_pair(i, index_end));
68
69 }
70
71}
72
73const Index& GlobalGridPartitioning::GlobalBegin(const Index& pos) const
74{
75 std::map<Index, Index>::const_iterator iter = begin.find(pos);
76
77 assert(iter != begin.end());
78
79 return iter->second;
80}
81
82const Index& GlobalGridPartitioning::GlobalEnd(const Index& pos) const
83{
84 std::map<Index, Index>::const_iterator iter = end.find(pos);
85
86 assert(iter != end.end());
87
88 return iter->second;
89}
Note: See TracBrowser for help on using the repository browser.