ESyS-Particle  2.3.4
RotElasticInteractionGroup.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 __ROTELASTICINTERACTIONGROUP_H
14 #define __ROTELASTICINTERACTIONGROUP_H
15 
16 #include "Model/InteractionGroup.h"
18 #include "Model/IGParam.h"
19 
20 //--- IO includes ---
21 #include <iostream>
22 using std::ostream;
23 using std::endl;
24 
25 
29 template <class T>
31 {
32  protected:
33  vector<CRotElasticInteraction> m_interactions;
34  AParallelInteractionStorage* m_exIG; //<! if an interaction is in m_exIG, it can't be in m_interactions
35  double m_kr; //<! Normal spring constant
36 
37  public:
41 
42  virtual void setExIG(AParallelInteractionStorage* eg){m_exIG=eg;};
43  void setParam(const CRotElasticIGP*);
44 
48  virtual void setTimeStepSize(double dt)
49  {
50  }
51 
52  virtual void calcForces();
53  virtual void Update(ParallelParticleArray<T>*);
54  friend ostream& operator<< <>(ostream&,const CRotElasticInteractionGroup<T>&);
55 };
56 
58 
59 #endif //__ELASTICINTERACTIONGROUP_H
AMPIBuffer::pop_int
virtual int pop_int()=0
CRotElasticInteractionGroup::setExIG
virtual void setExIG(AParallelInteractionStorage *eg)
Definition: RotElasticInteractionGroup.h:42
CRotElasticInteractionGroup::setTimeStepSize
virtual void setTimeStepSize(double dt)
Definition: RotElasticInteractionGroup.h:48
extractRotElasticIGP_p
CRotElasticIGP * extractRotElasticIGP_p(AMPIBuffer *B)
Definition: RotElasticInteractionGroup.cpp:37
RotElasticInteractionGroup.h
CRotElasticInteractionGroup::Update
virtual void Update(ParallelParticleArray< T > *)
Definition: RotElasticInteractionGroup.hpp:57
CVarMPIBuffer
MPI send/recv buffer with automagically adjusted size.
Definition: mpivbuf.h:35
AMPIBuffer::pop_double
virtual double pop_double()=0
operator<<
ostream & operator<<(ostream &ost, const CRotElasticIGP &B)
Definition: RotElasticInteractionGroup.cpp:45
CRotElasticIGP::setNormalSpringConst
void setNormalSpringConst(double k)
Definition: RotElasticInteraction.h:35
console.h
AIGParam::packInto
virtual void packInto(CVarMPIBuffer *) const
Definition: IGParam.cpp:23
CRotElasticInteractionGroup::m_exIG
AParallelInteractionStorage * m_exIG
Definition: RotElasticInteractionGroup.h:34
CVarMPIBuffer::append
virtual void append(int)
Definition: mpivbuf.cpp:152
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
AParallelInteractionStorage
abstract base class for parallel interaction storage array
Definition: pi_storage.h:45
CRotElasticInteractionGroup::m_kr
double m_kr
Definition: RotElasticInteractionGroup.h:35
CRotElasticInteractionGroup::m_interactions
vector< CRotElasticInteraction > m_interactions
Definition: RotElasticInteractionGroup.h:33
ParallelParticleArray
parrallel particle storage array with neighborsearch and variable exchange
Definition: pp_array.h:75
CRotElasticIGP::m_kr
double m_kr
Definition: RotElasticInteraction.h:31
RotElasticInteractionGroup.hpp
CRotElasticInteractionGroup::setParam
void setParam(const CRotElasticIGP *)
Definition: RotElasticInteractionGroup.hpp:35
CRotElasticInteractionGroup::CRotElasticInteractionGroup
CRotElasticInteractionGroup()
Definition: RotElasticInteractionGroup.hpp:20
RotElasticInteraction.h
CRotElasticInteractionGroup::calcForces
virtual void calcForces()
Definition: RotElasticInteractionGroup.hpp:41
CRotElasticInteractionGroup::~CRotElasticInteractionGroup
virtual ~CRotElasticInteractionGroup()
Definition: RotElasticInteractionGroup.h:40
APairInteractionGroup
Abstract base class for a group of pair interactions.
Definition: InteractionGroup.h:55
CRotElasticInteractionGroup
Class for a group of unbonded,elastic interactions.
Definition: RotElasticInteractionGroup.h:31
CRotElasticIGP
Interaction group parameters for CRotElasticInteractionGroups.
Definition: RotElasticInteraction.h:25
extractRotElasticIGP
CRotElasticIGP * extractRotElasticIGP(AMPIBuffer *B)
Definition: RotElasticInteractionGroup.cpp:25
InteractionGroup.h
CRotElasticIGP::packInto
virtual void packInto(CVarMPIBuffer *) const
Definition: RotElasticInteractionGroup.cpp:19
AMPIBuffer::pop_string
virtual std::string pop_string()=0
IGParam.h