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-2026 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 <
config/config.hpp
>
20
21
#include "
HomogeneousMagneticField.hpp
"
22
23
#include "
Observable_stat.hpp
"
24
#include "
Particle.hpp
"
25
26
#include <
utils/Vector.hpp
>
27
28
namespace
Constraints
{
29
30
ParticleForce
HomogeneousMagneticField::force
(
const
Particle
&p,
31
const
Utils::Vector3d
&,
double
) {
32
#ifdef ESPRESSO_DIPOLES
33
return
{{},
vector_product
(p.
calc_dip
(), m_field)};
34
#else
35
return
{};
36
#endif
37
}
38
39
void
HomogeneousMagneticField::add_energy
(
const
Particle
&p,
40
const
Utils::Vector3d
&,
double
,
41
Observable_stat
&
obs_energy
)
const
{
42
#ifdef ESPRESSO_DIPOLES
43
obs_energy
.dipolar[0] += -1.0 * m_field * p.
calc_dip
();
44
#endif
45
}
46
47
}
// 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:39
Constraints::HomogeneousMagneticField::force
ParticleForce force(const Particle &p, const Utils::Vector3d &, double) override
Definition
HomogeneousMagneticField.cpp:30
Observable_stat
Observable for the pressure and energy.
Definition
Observable_stat.hpp:31
Utils::Vector
Definition
Vector.hpp:50
stream
cudaStream_t stream[1]
CUDA streams for parallel computing on CPU and GPU.
Definition
common_cuda.cu:34
config.hpp
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:30
HomogeneousMagneticField.hpp
ParticleForce
Force information on a particle.
Definition
Particle.hpp:330
Particle
Struct holding all information for one particle.
Definition
Particle.hpp:435
Particle::calc_dip
auto calc_dip() const
Definition
Particle.hpp:535
src
core
constraints
HomogeneousMagneticField.cpp
Generated on Thu Mar 5 2026 02:40:45 for ESPResSo by
1.9.8