PhasicFlow
v0.1
www.cemf.ir
dynamicPointStructure.hpp
Go to the documentation of this file.
1
/*------------------------------- phasicFlow ---------------------------------
2
O C enter of
3
O O E ngineering and
4
O O M ultiscale modeling of
5
OOOOOOO F luid flow
6
------------------------------------------------------------------------------
7
Copyright (C): www.cemf.ir
8
email: hamid.r.norouzi AT gmail.com
9
------------------------------------------------------------------------------
10
Licence:
11
This file is part of phasicFlow code. It is a free software for simulating
12
granular and multiphase flows. You can redistribute it and/or modify it under
13
the terms of GNU General Public License v3 or any other later versions.
14
15
phasicFlow is distributed to help others in their research in the field of
16
granular and multiphase flows, but WITHOUT ANY WARRANTY; without even the
17
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
18
19
-----------------------------------------------------------------------------*/
20
21
22
#ifndef __dynamicPointStructure_hpp__
23
#define __dynamicPointStructure_hpp__
24
25
#include "
Time.hpp
"
26
#include "
pointFields.hpp
"
27
#include "
integrations.hpp
"
28
#include "
uniquePtr.hpp
"
29
30
namespace
pFlow
31
{
32
33
class
dynamicPointStructure
34
:
35
//public pointStructure
36
public
eventObserver
37
{
38
protected
:
39
40
Time
&
time_
;
41
42
word
integrationMethod_
;
43
44
pointStructure
&
pStruct_
;
45
46
realx3PointField_D
&
velocity_
;
47
48
uniquePtr<integration>
integrationPos_
;
49
50
uniquePtr<integration>
integrationVel_
;
51
52
public
:
53
54
TypeInfo
(
"dynamicPointStructure"
);
55
56
dynamicPointStructure
(
Time
& time,
const
word
& integrationMethod);
57
58
dynamicPointStructure
(
const
dynamicPointStructure
& ps) =
default
;
59
60
/*dynamicPointStructure(const dynamicPointStructure& ps):
61
pointStructure(ps),
62
time_(ps.time_),
63
integrationMethod_(ps.integrationMethod_),
64
velocity_(ps.velocity_),
65
integrationPos_(ps.integrationPos_->clone()),
66
integrationVel_(ps.integrationVel_->clone())
67
{
68
69
}*/
70
71
72
// - no move construct
73
dynamicPointStructure
(
dynamicPointStructure
&&) =
delete
;
74
75
// - copy assignment
76
//
77
// should be changed, may causs undefined behavior
79
dynamicPointStructure
&
operator=
(
const
dynamicPointStructure
&) =
default
;
80
81
// - no move assignment
82
dynamicPointStructure
&
operator=
(
dynamicPointStructure
&&) =
delete
;
83
84
// - destructor
85
virtual
~dynamicPointStructure
() =
default
;
86
87
88
inline
pointStructure
&
pStruct
()
89
{
90
return
pStruct_
;
91
}
92
93
inline
const
pointStructure
&
pStruct
()
const
94
{
95
return
pStruct_
;
96
}
97
98
inline
const
realx3PointField_D
&
velocity
()
const
99
{
100
return
velocity_
;
101
}
102
103
inline
auto
velocityHostAll
()
104
{
105
return
velocity_
.hostVectorAll();
106
}
107
108
inline
auto
pointPositionHostAll
()
109
{
110
return
pStruct_
.
pointPositionHostAll
();
111
}
112
113
auto
markDeleteOutOfBox
(
const
box
& domain)
114
{
115
return
pStruct_
.
markDeleteOutOfBox
(domain);
116
}
117
118
bool
predict
(
real
dt,
realx3PointField_D
&
acceleration
);
119
120
bool
correct
(
real
dt,
realx3PointField_D
&
acceleration
);
121
122
123
// - update data structure by inserting/setting new points
124
// Notifies all the fields in the registered list of data structure
125
// and exclude the fields that re in the exclusionList
126
// retrun nullptr if it fails
127
/*FUNCTION_H
128
virtual uniquePtr<int32IndexContainer> insertPoints(
129
const realx3Vector& pos,
130
const List<eventObserver*>& exclusionList={nullptr}
131
)override;*/
132
133
bool
update
(
const
eventMessage
& msg)
override
;
134
135
136
};
137
138
}
139
140
141
#endif
pFlow::dynamicPointStructure::velocity_
realx3PointField_D & velocity_
Definition:
dynamicPointStructure.hpp:46
pFlow::dynamicPointStructure::velocity
const realx3PointField_D & velocity() const
Definition:
dynamicPointStructure.hpp:98
pFlow::real
float real
Definition:
builtinTypes.hpp:46
pFlow::eventMessage
Definition:
eventMessage.hpp:29
pFlow::dynamicPointStructure::dynamicPointStructure
dynamicPointStructure(Time &time, const word &integrationMethod)
Definition:
dynamicPointStructure.cpp:25
pFlow::dynamicPointStructure::integrationMethod_
word integrationMethod_
Definition:
dynamicPointStructure.hpp:42
pFlow::pointStructure::markDeleteOutOfBox
FUNCTION_H size_t markDeleteOutOfBox(const box &domain)
Definition:
pointStructure.cpp:235
pFlow::dynamicPointStructure::markDeleteOutOfBox
auto markDeleteOutOfBox(const box &domain)
Definition:
dynamicPointStructure.hpp:113
pFlow::word
std::string word
Definition:
builtinTypes.hpp:63
pFlow::pointStructure::pointPositionHostAll
INLINE_FUNCTION_H auto pointPositionHostAll()
Definition:
pointStructure.hpp:259
pointFields.hpp
pFlow::dynamicPointStructure::pointPositionHostAll
auto pointPositionHostAll()
Definition:
dynamicPointStructure.hpp:108
pFlow::sphereParticlesKernels::acceleration
void acceleration(realx3 g, deviceViewType1D< real > mass, deviceViewType1D< realx3 > force, deviceViewType1D< real > I, deviceViewType1D< realx3 > torque, IncludeFunctionType incld, deviceViewType1D< realx3 > lAcc, deviceViewType1D< realx3 > rAcc)
Definition:
sphereParticlesKernels.hpp:34
pFlow::eventObserver
Definition:
eventObserver.hpp:33
pFlow::dynamicPointStructure::predict
bool predict(real dt, realx3PointField_D &acceleration)
Definition:
dynamicPointStructure.cpp:121
pFlow::dynamicPointStructure
Definition:
dynamicPointStructure.hpp:33
integrations.hpp
pFlow
Definition:
demComponent.hpp:28
pFlow::dynamicPointStructure::update
bool update(const eventMessage &msg) override
Definition:
dynamicPointStructure.cpp:181
pFlow::dynamicPointStructure::~dynamicPointStructure
virtual ~dynamicPointStructure()=default
uniquePtr.hpp
pFlow::pointField
Definition:
pointField.hpp:35
pFlow::pointStructure
Definition:
pointStructure.hpp:44
pFlow::dynamicPointStructure::correct
bool correct(real dt, realx3PointField_D &acceleration)
Definition:
dynamicPointStructure.cpp:135
pFlow::dynamicPointStructure::pStruct
pointStructure & pStruct()
Definition:
dynamicPointStructure.hpp:88
Time.hpp
pFlow::dynamicPointStructure::integrationVel_
uniquePtr< integration > integrationVel_
Definition:
dynamicPointStructure.hpp:50
pFlow::dynamicPointStructure::pStruct
const pointStructure & pStruct() const
Definition:
dynamicPointStructure.hpp:93
pFlow::dynamicPointStructure::time_
Time & time_
Definition:
dynamicPointStructure.hpp:40
pFlow::dynamicPointStructure::pStruct_
pointStructure & pStruct_
Definition:
dynamicPointStructure.hpp:44
pFlow::box
Definition:
box.hpp:32
pFlow::dynamicPointStructure::operator=
dynamicPointStructure & operator=(const dynamicPointStructure &)=default
pFlow::uniquePtr
Definition:
uniquePtr.hpp:44
pFlow::dynamicPointStructure::integrationPos_
uniquePtr< integration > integrationPos_
Definition:
dynamicPointStructure.hpp:48
pFlow::dynamicPointStructure::TypeInfo
TypeInfo("dynamicPointStructure")
pFlow::dynamicPointStructure::velocityHostAll
auto velocityHostAll()
Definition:
dynamicPointStructure.hpp:103
pFlow::Time
Definition:
Time.hpp:39
src
Particles
dynamicPointStructure
dynamicPointStructure.hpp
Generated by
1.8.17