ESyS-Particle  2.3.4
RotThermElasticInteractionGroup.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 __ROTTHERMELASTICINTERACTIONGROUP_H
14 #define __ROTTHERMELASTICINTERACTIONGROUP_H
15 
16 #include "Foundation/console.h"
17 #include "InteractionGroup.h"
19 #include "IGParam.h"
20 
21 //--- IO includes ---
22 #include <iostream>
23 using std::ostream;
24 using std::endl;
25 
26 
30 template <class T>
32 {
33  protected:
34  vector<CRotThermElasticInteraction> m_interactions;
35  AParallelInteractionStorage* m_exIG; //<! if an interaction is in m_exIG, it can't be in m_interactions
36  double m_k; //<! spring constant
37  double m_diffusivity ;
38 
39  public:
43 
44  virtual void setExIG(AParallelInteractionStorage* eg){m_exIG=eg;};
45  void setParam(const CRotThermElasticIGP*);
46 
47  virtual void calcForces();
48  virtual void Update(ParallelParticleArray<T>*);
49  friend ostream& operator<< <>(ostream&,const CRotThermElasticInteractionGroup<T>&);
50 };
51 
53 
54 #endif //__ELASTICINTERACTIONGROUP_H
AMPIBuffer::pop_int
virtual int pop_int()=0
CRotThermElasticInteractionGroup::m_diffusivity
double m_diffusivity
Definition: RotThermElasticInteractionGroup.h:37
CRotThermElasticIGP
Definition: RotThermElasticInteraction.h:24
CVarMPIBuffer
MPI send/recv buffer with automagically adjusted size.
Definition: mpivbuf.h:35
CRotThermElasticInteractionGroup::m_k
double m_k
Definition: RotThermElasticInteractionGroup.h:36
AMPIBuffer::pop_double
virtual double pop_double()=0
CRotThermElasticIGP::diffusivity
double diffusivity
Definition: RotThermElasticInteraction.h:36
CRotThermElasticIGP::packInto
virtual void packInto(CVarMPIBuffer *) const
Definition: RotThermElasticInteractionGroup.cpp:20
CRotThermElasticInteractionGroup::setExIG
virtual void setExIG(AParallelInteractionStorage *eg)
Definition: RotThermElasticInteractionGroup.h:44
console.h
AIGParam::packInto
virtual void packInto(CVarMPIBuffer *) const
Definition: IGParam.cpp:23
CRotThermElasticIGP::setSpringConst
void setSpringConst(double k)
Definition: RotThermElasticInteraction.h:39
RotThermElasticInteraction.h
extractRotThermElasticIGP_p
CRotThermElasticIGP * extractRotThermElasticIGP_p(AMPIBuffer *B)
Definition: RotThermElasticInteractionGroup.cpp:40
CVarMPIBuffer::append
virtual void append(int)
Definition: mpivbuf.cpp:152
CRotThermElasticInteractionGroup::~CRotThermElasticInteractionGroup
virtual ~CRotThermElasticInteractionGroup()
Definition: RotThermElasticInteractionGroup.h:42
CRotThermElasticInteractionGroup::m_exIG
AParallelInteractionStorage * m_exIG
Definition: RotThermElasticInteractionGroup.h:35
AMPIBuffer
Abstract base class for MPI send/recv buffer.
Definition: mpibuf.h:34
CRotThermElasticInteractionGroup::m_interactions
vector< CRotThermElasticInteraction > m_interactions
Definition: RotThermElasticInteractionGroup.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
CRotThermElasticInteractionGroup::CRotThermElasticInteractionGroup
CRotThermElasticInteractionGroup()
Definition: RotThermElasticInteractionGroup.hpp:18
ParallelParticleArray
parrallel particle storage array with neighborsearch and variable exchange
Definition: pp_array.h:75
CRotThermElasticIGP::setDiffusivity
void setDiffusivity(double d)
Definition: RotThermElasticInteraction.h:43
CRotThermElasticInteractionGroup::Update
virtual void Update(ParallelParticleArray< T > *)
Definition: RotThermElasticInteractionGroup.hpp:55
CRotThermElasticIGP::m_kr
double m_kr
Definition: RotThermElasticInteraction.h:35
APairInteractionGroup
Abstract base class for a group of pair interactions.
Definition: InteractionGroup.h:55
CRotThermElasticInteractionGroup::setParam
void setParam(const CRotThermElasticIGP *)
Definition: RotThermElasticInteractionGroup.hpp:34
RotThermElasticInteractionGroup.hpp
CRotThermElasticInteractionGroup::calcForces
virtual void calcForces()
Definition: RotThermElasticInteractionGroup.hpp:41
InteractionGroup.h
RotThermElasticInteractionGroup.h
CRotThermElasticInteractionGroup
Definition: RotThermElasticInteractionGroup.h:32
extractRotThermElasticIGP
CRotThermElasticIGP * extractRotThermElasticIGP(AMPIBuffer *B)
Definition: RotThermElasticInteractionGroup.cpp:27
AMPIBuffer::pop_string
virtual std::string pop_string()=0
IGParam.h
operator<<
ostream & operator<<(ostream &ost, const CRotThermElasticIGP &B)
Definition: RotThermElasticInteractionGroup.cpp:49