Loading [MathJax]/extensions/TeX/AMSmath.js
ESPResSo
Extensible Simulation Package for Research on Soft Matter Systems
Toggle main menu visibility
Main Page
Related Pages
Namespaces
Namespace List
Namespace Members
All
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
Variables
_
a
b
c
f
g
i
k
m
n
o
p
r
s
w
Typedefs
a
b
c
d
e
f
g
h
i
l
m
o
p
q
t
v
Enumerations
Enumerator
d
h
m
n
r
s
t
Concepts
Classes
Class List
Class Index
Class Hierarchy
Class Members
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
Functions
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
z
~
Variables
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
Typedefs
_
a
b
c
d
e
f
i
j
k
l
m
o
p
q
r
s
t
u
v
Enumerations
Enumerator
a
i
l
n
o
p
s
u
v
Related Symbols
Files
File List
File Members
All
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
r
s
t
v
w
Variables
a
b
c
g
h
i
m
p
s
t
u
v
w
Typedefs
Enumerations
Enumerator
Macros
c
d
f
g
h
i
k
m
n
o
p
q
r
s
t
u
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Pages
Concepts
Loading...
Searching...
No Matches
ScafacosContext.cpp
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2010-2022 The ESPResSo project
3
* Copyright (C) 2002,2003,2004,2005,2006,2007,2008,2009,2010
4
* Max-Planck-Institute for Polymer Research, Theory Group
5
*
6
* This file is part of ESPResSo.
7
*
8
* ESPResSo is free software: you can redistribute it and/or modify
9
* it under the terms of the GNU General Public License as published by
10
* the Free Software Foundation, either version 3 of the License, or
11
* (at your option) any later version.
12
*
13
* ESPResSo is distributed in the hope that it will be useful,
14
* but WITHOUT ANY WARRANTY; without even the implied warranty of
15
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
* GNU General Public License for more details.
17
*
18
* You should have received a copy of the GNU General Public License
19
* along with this program. If not, see <http://www.gnu.org/licenses/>.
20
*/
21
22
#include "
config/config.hpp
"
23
24
#if defined(SCAFACOS) or defined(SCAFACOS_DIPOLES)
25
26
#include "
scafacos/ScafacosContext.hpp
"
27
28
#include "
BoxGeometry.hpp
"
29
#include "
cell_system/CellStructure.hpp
"
30
#include "communication.hpp"
31
#include "system/System.hpp"
32
33
#include <
utils/Vector.hpp
>
34
35
#include <boost/mpi/collectives.hpp>
36
37
#include <cstddef>
38
#include <functional>
39
40
namespace
detail {
41
std::tuple<Utils::Vector3d const &, Utils::Vector3i, std::size_t>
42
get_system_params() {
43
auto
const
&system =
System::get_system
();
44
auto
const
&box_geo = *system.box_geo;
45
auto
const
&cell_structure = *system.cell_structure;
46
auto
periodicity =
Utils::Vector3i
{
static_cast<
int
>
(box_geo.periodic(0u)),
47
static_cast<
int
>
(box_geo.periodic(1u)),
48
static_cast<
int
>
(box_geo.periodic(2u))};
49
auto
const
n_part = boost::mpi::all_reduce(
50
comm_cart
, cell_structure.local_particles().size(), std::plus<>());
51
return
{box_geo.length(), periodicity, n_part};
52
}
53
}
// namespace detail
54
55
#endif
// SCAFACOS or SCAFACOS_DIPOLES
BoxGeometry.hpp
CellStructure.hpp
ScafacosContext.hpp
ScafacosContext implements the interface of the ScaFaCoS bridge.
Vector.hpp
Vector implementation and trait types for boost qvm interoperability.
Utils::Vector
Definition
Vector.hpp:49
comm_cart
boost::mpi::communicator comm_cart
The communicator.
Definition
communication.cpp:52
config.hpp
This file contains the defaults for ESPResSo.
System::get_system
System & get_system()
Definition
core/system/System.cpp:126
src
core
scafacos
ScafacosContext.cpp
Generated on Wed Apr 23 2025 01:14:56 for ESPResSo by
1.9.8