ESyS-Particle  2.3.4
DampingIGP.h
Go to the documentation of this file.
1 // //
3 // Copyright (c) 2003-2017 by The University of Queensland //
4 // Centre for Geoscience Computing //
5 // http://earth.uq.edu.au/centre-geoscience-computing //
6 // //
7 // Primary Business: Brisbane, Queensland, Australia //
8 // Licensed under the Open Software License version 3.0 //
9 // http://www.apache.org/licenses/LICENSE-2.0 //
10 // //
12 
13 #ifndef __DAMPING_IGP_H
14 #define __DAMPING_IGP_H
15 
16 // -- project includes --
17 #include "Model/IGParam.h"
18 #include "Foundation/vec3.h"
19 // -- STL includes --
20 #include <string>
21 
22 using std::string;
23 
27 class CDampingIGP : public AIGParam
28 {
29 protected:
30  string m_type; // type of damping (rot/lin)
32  double m_visc;
33  double m_dt;
34  int m_max_iter;
35 
36 public:
37  CDampingIGP();
38  CDampingIGP(const string& type,
39  const string &name,
40  double viscosity,
41  double dt,
42  int maxIteractions,
43  const Vec3 &refVelocity = Vec3::ZERO
44  );
45 
46  virtual void packInto(CVarMPIBuffer*) const;
47  void setType(const string& type){m_type=type;}
48  void setVRef(const Vec3 V){m_vref=V;}
49  Vec3 getVRef()const{return m_vref;}
50  void setVisc(double v){m_visc=v;}
51  double getVisc()const{return m_visc;}
52  void setTimeStep(double t){m_dt=t;}
53  void setTimeStepSize(double t){setTimeStep(t);}
54  double getTimeStep()const{return m_dt;}
55  void setMaxIter(int mi){m_max_iter=mi;}
56  int getMaxIter()const {return m_max_iter;}
57 
58  virtual std::string getTypeString() const {return m_type;}
59 };
60 
62 
63 #endif //__DAMPING_IGP_H
AMPIBuffer::pop_int
virtual int pop_int()=0
CVarMPIBuffer
MPI send/recv buffer with automagically adjusted size.
Definition: mpivbuf.h:35
AMPIBuffer::pop_double
virtual double pop_double()=0
CDampingIGP::packInto
virtual void packInto(CVarMPIBuffer *) const
Definition: DampingIGP.cpp:49
extractDampingIGP
CDampingIGP * extractDampingIGP(AMPIBuffer *)
Definition: DampingIGP.cpp:64
AIGParam::packInto
virtual void packInto(CVarMPIBuffer *) const
Definition: IGParam.cpp:23
CDampingIGP::getTypeString
virtual std::string getTypeString() const
Definition: DampingIGP.h:58
CVarMPIBuffer::append
virtual void append(int)
Definition: mpivbuf.cpp:152
CDampingIGP::m_type
string m_type
Definition: DampingIGP.h:30
CDampingIGP::setMaxIter
void setMaxIter(int mi)
Definition: DampingIGP.h:55
CDampingIGP::getVRef
Vec3 getVRef() const
Definition: DampingIGP.h:49
CDampingIGP::setTimeStep
void setTimeStep(double t)
Definition: DampingIGP.h:52
AMPIBuffer
Abstract base class for MPI send/recv buffer.
Definition: mpibuf.h:34
AIGParam::setName
void setName(const std::string &name)
Definition: IGParam.cpp:28
CDampingIGP::getMaxIter
int getMaxIter() const
Definition: DampingIGP.h:56
CDampingIGP::m_dt
double m_dt
time step
Definition: DampingIGP.h:33
CDampingIGP::m_max_iter
int m_max_iter
max nr. of iterations
Definition: DampingIGP.h:34
CDampingIGP::setTimeStepSize
void setTimeStepSize(double t)
Definition: DampingIGP.h:53
CDampingIGP::setVisc
void setVisc(double v)
Definition: DampingIGP.h:50
CDampingIGP::m_vref
Vec3 m_vref
reference velocity
Definition: DampingIGP.h:31
Vec3
Definition: vec3.h:47
AMPIBuffer::pop_vector
virtual Vec3 pop_vector()
Definition: mpibuf.cpp:26
DampingIGP.h
AIGParam
Abstract base class for InteractionGroup parameters.
Definition: IGParam.h:29
CDampingIGP::setVRef
void setVRef(const Vec3 V)
Definition: DampingIGP.h:48
vec3.h
CDampingIGP::m_visc
double m_visc
artificial viscosity
Definition: DampingIGP.h:32
Vec3::ZERO
static const Vec3 ZERO
Definition: vec3.h:52
extractDampingIGP
CDampingIGP * extractDampingIGP(AMPIBuffer *B)
Definition: DampingIGP.cpp:64
CDampingIGP::setType
void setType(const string &type)
Definition: DampingIGP.h:47
CDampingIGP::CDampingIGP
CDampingIGP()
Definition: DampingIGP.cpp:20
CDampingIGP
Interaction group parameters for CDampingGroup.
Definition: DampingIGP.h:28
AMPIBuffer::pop_string
virtual std::string pop_string()=0
IGParam.h
CDampingIGP::getTimeStep
double getTimeStep() const
Definition: DampingIGP.h:54
CDampingIGP::getVisc
double getVisc() const
Definition: DampingIGP.h:51