ESPResSo
Extensible Simulation Package for Research on Soft Matter Systems
Loading...
Searching...
No Matches
HomogeneousMagneticField.cpp
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
#include "
HomogeneousMagneticField.hpp
"
20
21
#include "
Observable_stat.hpp
"
22
#include "
Particle.hpp
"
23
#include "
config/config.hpp
"
24
25
#include <
utils/Vector.hpp
>
26
27
namespace
Constraints
{
28
29
ParticleForce
HomogeneousMagneticField::force
(
const
Particle
&p,
30
const
Utils::Vector3d
&,
double
) {
31
#ifdef DIPOLES
32
return
{{},
vector_product
(p.
calc_dip
(), m_field)};
33
#else
34
return
{};
35
#endif
36
}
37
38
void
HomogeneousMagneticField::add_energy
(
const
Particle
&p,
39
const
Utils::Vector3d
&,
double
,
40
Observable_stat
&obs_energy)
const
{
41
#ifdef DIPOLES
42
obs_energy.
dipolar
[0] += -1.0 * m_field * p.
calc_dip
();
43
#endif
44
}
45
46
}
// namespace Constraints
Observable_stat.hpp
Particle.hpp
Vector.hpp
Vector implementation and trait types for boost qvm interoperability.
Constraints::HomogeneousMagneticField::add_energy
void add_energy(const Particle &p, const Utils::Vector3d &, double, Observable_stat &energy) const override
Definition
HomogeneousMagneticField.cpp:38
Constraints::HomogeneousMagneticField::force
ParticleForce force(const Particle &p, const Utils::Vector3d &, double) override
Definition
HomogeneousMagneticField.cpp:29
Observable_stat
Observable for the pressure and energy.
Definition
Observable_stat.hpp:31
Observable_stat::dipolar
std::span< double > dipolar
Contribution(s) from dipolar interactions.
Definition
Observable_stat.hpp:80
Utils::Vector
Definition
Vector.hpp:48
config.hpp
This file contains the defaults for ESPResSo.
vector_product
__device__ void vector_product(float const *a, float const *b, float *out)
Definition
dipolar_direct_sum_gpu_cuda.cu:42
Constraints
Definition
core/constraints/Constraint.hpp:29
HomogeneousMagneticField.hpp
ParticleForce
Force information on a particle.
Definition
Particle.hpp:290
Particle
Struct holding all information for one particle.
Definition
Particle.hpp:395
Particle::calc_dip
auto calc_dip() const
Definition
Particle.hpp:495
src
core
constraints
HomogeneousMagneticField.cpp
Generated on Thu Dec 19 2024 02:13:16 for ESPResSo by
1.9.8