File: BWallInteractionGroup.cpp

package info (click to toggle)
esys-particle 2.3.4%2Bdfsg1-4
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 13,036 kB
  • ctags: 10,805
  • sloc: cpp: 80,009; python: 5,872; makefile: 1,243; sh: 313; perl: 225
file content (67 lines) | stat: -rw-r--r-- 2,319 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/////////////////////////////////////////////////////////////
//                                                         //
// Copyright (c) 2003-2014 by The University of Queensland //
// Centre for Geoscience Computing                         //
// http://earth.uq.edu.au/centre-geoscience-computing      //
//                                                         //
// Primary Business: Brisbane, Queensland, Australia       //
// Licensed under the Open Software License version 3.0    //
// http://www.apache.org/licenses/LICENSE-2.0          //
//                                                         //
/////////////////////////////////////////////////////////////

#include "Model/BWallInteractionGroup.h"
#include "Foundation/console.h"

//----------------------------------------
//    CBWallIGP member functions 
//----------------------------------------

/*!
  Bonded wall interaction group constructor

  \param name the name of the interaction
  \param wallname the name of the wall
  \param k the spring constant for the elastic interactions
  \param tag the tag of the particles to which the wall is bonded (if build via bond and not via distance)
  \param mask the particle tag mask
*/
CBWallIGP::CBWallIGP(const std::string& name,const std::string& wallname,double k,int tag, int mask)
  : CEWallIGP(name,wallname,k)
{
  m_tag=tag;
  m_mask=mask;
}

void  CBWallIGP::packInto(CVarMPIBuffer* B) const
{
  console.XDebug() << "CBWallIGP::packInto( " << B << " )\n"; 
  CEWallIGP::packInto(B);
  B->append(m_tag);
  B->append(m_mask);
  console.XDebug() << "end CBWallIGP::packInto()\n ";
}

ostream& operator<<(ostream& ost,const CBWallIGP& I)
{
  ost << "CEWallIGP\n";
  ost << "Name            : " << I.getName() << endl;
  ost << "Wall Name       : " << I.m_wallname << endl;
  ost << "Spring constant : " << I.m_k << endl;
  ost << "Tag             : " << I.m_tag << endl;
  ost << "Mask            : " << I.m_mask << endl;
  return ost;
}

CBWallIGP* extractBWallIGP(AMPIBuffer* B)
{
  console.XDebug() << "extractBWallIGP\n";
  string name=B->pop_string();
  double k=B->pop_double();
  string wallname=B->pop_string();
  int tag=B->pop_int();
  int mask=B->pop_int();
  CBWallIGP* res=new CBWallIGP(name,wallname,k,tag,mask);
  console.XDebug() << "end extractBWallIGP\n";
  return res;
}