ESPResSo
Extensible Simulation Package for Research on Soft Matter Systems
Loading...
Searching...
No Matches
core/magnetostatics/scafacos.hpp
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
#pragma once
23
24
#include "
config/config.hpp
"
25
26
#ifdef SCAFACOS_DIPOLES
27
28
#include "
magnetostatics/actor.hpp
"
29
30
#include "
scafacos/ScafacosContextBase.hpp
"
31
32
#include <memory>
33
#include <string>
34
35
struct
DipolarScafacos
:
virtual
public
ScafacosContextBase
,
36
public
Dipoles::Actor
<DipolarScafacos> {
37
~DipolarScafacos
()
override
=
default
;
38
39
void
on_activation
() {
update_system_params
(); }
40
/** @brief Recalculate all box-length-dependent parameters. */
41
void
on_boxl_change
() {
update_system_params
(); }
42
void
on_node_grid_change
()
const
{}
43
void
on_periodicity_change
() {
update_system_params
(); }
44
void
on_cell_structure_change
()
const
{}
45
void
init
()
const
{}
46
47
void
sanity_checks
()
const override
{}
48
};
49
50
std::shared_ptr<DipolarScafacos>
51
make_dipolar_scafacos
(std::string
const
&method, std::string
const
¶meters);
52
53
#endif
// SCAFACOS_DIPOLES
ScafacosContextBase.hpp
ScafacosContextBase provides the public interface of the ScaFaCoS bridge.
Dipoles::Actor
Definition
magnetostatics/actor.hpp:32
config.hpp
This file contains the defaults for ESPResSo.
make_dipolar_scafacos
std::shared_ptr< DipolarScafacos > make_dipolar_scafacos(std::string const &method, std::string const ¶meters)
Definition
magnetostatics/scafacos_impl.cpp:44
actor.hpp
DipolarScafacos
Definition
core/magnetostatics/scafacos.hpp:36
DipolarScafacos::init
void init() const
Definition
core/magnetostatics/scafacos.hpp:45
DipolarScafacos::on_boxl_change
void on_boxl_change()
Recalculate all box-length-dependent parameters.
Definition
core/magnetostatics/scafacos.hpp:41
DipolarScafacos::~DipolarScafacos
~DipolarScafacos() override=default
DipolarScafacos::sanity_checks
void sanity_checks() const override
Definition
core/magnetostatics/scafacos.hpp:47
DipolarScafacos::on_periodicity_change
void on_periodicity_change()
Definition
core/magnetostatics/scafacos.hpp:43
DipolarScafacos::on_cell_structure_change
void on_cell_structure_change() const
Definition
core/magnetostatics/scafacos.hpp:44
DipolarScafacos::on_node_grid_change
void on_node_grid_change() const
Definition
core/magnetostatics/scafacos.hpp:42
DipolarScafacos::on_activation
void on_activation()
Definition
core/magnetostatics/scafacos.hpp:39
ScafacosContextBase
Public interface to the ScaFaCoS context.
Definition
ScafacosContextBase.hpp:47
ScafacosContextBase::update_system_params
virtual void update_system_params()=0
Reinitialize number of particles, box shape and periodicity.
src
core
magnetostatics
scafacos.hpp
Generated on Fri Nov 8 2024 02:12:53 for ESPResSo by
1.9.8