ESPResSo
Extensible Simulation Package for Research on Soft Matter Systems
Loading...
Searching...
No Matches
Dipoles.hpp
Go to the documentation of this file.
1/*
2 * Copyright (C) 2010-2022 The ESPResSo project
3 *
4 * This file is part of ESPResSo.
5 *
6 * ESPResSo is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * ESPResSo is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19
20#ifndef ESPRESSO_SRC_SCAFACOS_DIPOLES_HPP
21#define ESPRESSO_SRC_SCAFACOS_DIPOLES_HPP
22
23#include "scafacos/Scafacos.hpp"
24
25#include <fcs.h>
26
27#include <mpi.h>
28
29#include <string>
30#include <vector>
31
32#ifdef FCS_ENABLE_DIPOLES
33
34namespace Scafacos {
35
36/** @brief Abstraction of a dipolar method from the ScaFaCoS library. */
37struct Dipoles : public Scafacos {
38 Dipoles(MPI_Comm comm, std::string method, std::string parameters);
39
40 /** @brief Set box geometry and number of particles. */
41 void set_runtime_parameters(double const *box_l, int const *periodicity,
42 int total_particles);
43
44 /** @brief Calculate the fields and potentials for dipoles. */
45 void run(std::vector<double> &dipoles, std::vector<double> &positions,
46 std::vector<double> &fields, std::vector<double> &potentials);
47};
48
49} // namespace Scafacos
50
51#endif // FCS_ENABLE_DIPOLES
52
53#endif