ESPResSo
Extensible Simulation Package for Research on Soft Matter Systems
Loading...
Searching...
No Matches
shapes/include/shapes/Wall.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
#ifndef SHAPES_WALL_HPP
23
#define SHAPES_WALL_HPP
24
25
#include "
Shape.hpp
"
26
#include <
utils/Vector.hpp
>
27
28
namespace
Shapes
{
29
class
Wall
:
public
Shape
{
30
public
:
31
Wall
() : m_n({1., 0., 0.}), m_d(0.0) {}
32
33
void
calculate_dist
(
const
Utils::Vector3d
&pos,
double
&dist,
34
Utils::Vector3d
&vec)
const override
;
35
36
void
set_normal
(
const
Utils::Vector3d
&normal) {
37
m_n = normal;
38
39
m_n.
normalize
();
40
}
41
42
Utils::Vector3d
const
&
n
()
const
{
return
m_n; }
43
44
double
const
&
d
()
const
{
return
m_d; }
45
46
double
&
d
() {
return
m_d; }
47
48
private
:
49
/** normal vector on the plane */
50
Utils::Vector3d
m_n;
51
/** distance of the wall from the origin. */
52
double
m_d;
53
};
54
55
}
/* namespace Shapes */
56
57
#endif
Vector.hpp
Vector implementation and trait types for boost qvm interoperability.
Shapes::Shape
Definition
shapes/include/shapes/Shape.hpp:29
Shapes::Wall
Definition
shapes/include/shapes/Wall.hpp:29
Shapes::Wall::Wall
Wall()
Definition
shapes/include/shapes/Wall.hpp:31
Shapes::Wall::n
Utils::Vector3d const & n() const
Definition
shapes/include/shapes/Wall.hpp:42
Shapes::Wall::d
double const & d() const
Definition
shapes/include/shapes/Wall.hpp:44
Shapes::Wall::set_normal
void set_normal(const Utils::Vector3d &normal)
Definition
shapes/include/shapes/Wall.hpp:36
Shapes::Wall::d
double & d()
Definition
shapes/include/shapes/Wall.hpp:46
Shapes::Wall::calculate_dist
void calculate_dist(const Utils::Vector3d &pos, double &dist, Utils::Vector3d &vec) const override
Definition
Wall.cpp:28
Utils::Vector
Definition
Vector.hpp:48
Utils::Vector::normalize
Vector & normalize()
Definition
Vector.hpp:147
Shapes
Definition
shapes/include/shapes/Cylinder.hpp:31
Shape.hpp
src
shapes
include
shapes
Wall.hpp
Generated on Thu Dec 19 2024 02:13:16 for ESPResSo by
1.9.8