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;
}
|