ESPResSo
Extensible Simulation Package for Research on Soft Matter Systems
Loading...
Searching...
No Matches
magnetostatics/Actor.impl.hpp
Go to the documentation of this file.
1
/*
2
* Copyright (C) 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
#pragma once
21
22
#include "
config/config.hpp
"
23
24
#ifdef ESPRESSO_DIPOLES
25
26
#include "
Actor.hpp
"
27
28
#include "
core/actor/registration.hpp
"
29
#include "
core/magnetostatics/dipoles.hpp
"
30
31
#include "
script_interface/auto_parameters/AutoParameter.hpp
"
32
33
#include <cassert>
34
#include <string>
35
36
namespace
ScriptInterface
{
37
namespace
Dipoles
{
38
39
template
<
class
SIClass,
class
CoreClass>
40
Variant
Actor<SIClass, CoreClass>::do_call_method
(
41
std::string
const
&name, [[
maybe_unused
]]
VariantMap
const
&
params
) {
42
assert
(
params
.empty());
43
if
(name ==
"activate"
) {
44
context()->parallel_try_catch([
this
]() {
45
auto
&
system
= get_system();
46
add_actor
(context()->get_comm(), m_system.lock(),
47
system
.dipoles.impl->solver, m_actor,
48
[&
system
]() { system.on_dipoles_change(); });
49
});
50
return
{};
51
}
52
return
{};
53
}
54
55
}
// namespace Dipoles
56
}
// namespace ScriptInterface
57
58
#endif
// ESPRESSO_DIPOLES
AutoParameter.hpp
ScriptInterface::Dipoles::Actor::do_call_method
Variant do_call_method(std::string const &name, VariantMap const ¶ms) override
Definition
magnetostatics/Actor.impl.hpp:40
stream
cudaStream_t stream[1]
CUDA streams for parallel computing on CPU and GPU.
Definition
common_cuda.cu:34
config.hpp
dipoles.hpp
Actor.hpp
Dipoles
Definition
magnetostatics/actor.hpp:30
ScriptInterface
Definition
script_interface/accumulators/AccumulatorBase.hpp:33
ScriptInterface::VariantMap
std::unordered_map< std::string, Variant > VariantMap
Definition
Variant.hpp:133
registration.hpp
add_actor
void add_actor(boost::mpi::communicator const &comm, std::shared_ptr< System::System > const &system, std::optional< Variant > &active_actor, std::shared_ptr< T > const &actor, F &&on_actor_change)
Definition
registration.hpp:35
params
static SteepestDescentParameters params
Currently active steepest descent instance.
Definition
steepest_descent.cpp:44
ScriptInterface::impl::recursive_variant
Recursive variant implementation.
Definition
Variant.hpp:84
src
script_interface
magnetostatics
Actor.impl.hpp
Generated on Mon Dec 8 2025 02:32:29 for ESPResSo by
1.9.8