13 #ifndef __LATTICEMASTER_H
14 #define __LATTICEMASTER_H
71 #include <boost/filesystem/path.hpp>
162 void runRunnables(RunnableVector::iterator begin, RunnableVector::iterator end);
182 return std::string(PACKAGE_VERSION);
232 const std::string &meshName,
236 void addMesh2D(
const std::string&,
const std::string&,
int);
238 void addTriMesh(
const std::string &meshName,
const std::string &fileName);
252 void addExIG(
const std::string&,
const std::string&);
257 void addRotBondedIG(
int,
const std::string&,
double,
double,
double,
double,
double,
double,
double,
double,
bool,
bool,
double);
347 void addScalarInteractionSaveField(
const std::string&,
const std::string&,
const std::string&,
const std::string&,
const std::string&,
int,
int,
int,
bool checked=
false);
348 void addVectorInteractionSaveField(
const std::string&,
const std::string&,
const std::string&,
const std::string&,
const std::string&,
int,
int,
int,
bool checked=
false);
349 void addTaggedScalarInteractionSaveField(
const std::string&,
const std::string&,
const std::string&,
const std::string&,
const std::string&,
int,
int,
int,
int,
int,
bool);
350 void addTaggedScalarParticleDistributionSaver(
const std::string&,
const std::string&,
const std::string&,
int,
int,
int,
int,
int,
int,
double,
double,
int);
353 void addVectorWallField(
const string&,
const string&,vector<string>,
const string&,
int,
int,
int);
369 const std::string &fileNamePrefix,
389 const std::string &fileNamePrefix,
400 const char *particleType,
406 const char *particleType,
465 const Vec3 &minBBoxPt,
466 const Vec3 &maxBBoxPt,
489 template <
class TmplParticle>
516 template <
class TmplIterator,
class TmplParticle>
527 template <
class TmplIterator>
531 template <
typename TmplVisitor>
534 template <
typename TmplVisitor>
537 template <
typename TmplVisitor>
540 template <
typename TmplVisitor>
542 const string &meshName,
548 template <
typename TmplVisitor,
typename TmplParticle>
554 template <
typename TmplVisitor>
void moveTaggedParticlesBy(int particleTag, const Vec3 &displacement)
Definition: LatticeMaster.cpp:718
bool m_geometry_is_initialized
Definition: LatticeMaster.h:141
CheckPointController * m_pSnapShotController
Definition: LatticeMaster.h:130
void setProcessDims(const esys::lsm::CLatticeParam::ProcessDims &dims)
Definition: LatticeMaster.cpp:291
void setParticleAngVel(int, const Vec3 &)
Definition: LatticeMaster.cpp:1043
void addVectorTriangleSaveField(const string &, const string &, const string &, const string &, int, int, int)
Definition: LatticeMaster.cpp:1670
void loadCheckPointData(const std::string &checkPointFileName)
Definition: LatticeMaster.cpp:474
Definition: RankAndComm.h:19
int m_max_ts
Definition: LatticeMaster.h:146
void visitMeshFaceReferences(const string &meshName)
Definition: LatticeMaster.hpp:81
void addBondedMesh2DIG(const BMesh2DIP &, const MeshTagBuildPrms &)
Definition: LatticeMaster.cpp:2778
TML_Comm m_tml_global_comm
Definition: LatticeMaster.h:158
RunnableVector & getPreTimeStepRunnableVector()
Definition: LatticeMaster.h:429
void setParticleDensity(int tag, int mask, double rho)
Definition: LatticeMaster.cpp:1022
void runRunnables(RunnableVector::iterator begin, RunnableVector::iterator end)
Definition: LatticeMaster.cpp:1844
vector< AFieldMaster * > m_save_fields
Definition: LatticeMaster.h:136
MPI_Group m_mpi_local_group
Definition: LatticeMaster.h:160
bool m_first_time
Definition: LatticeMaster.h:152
void setTaggedParticleVel(int tag, const Vec3 &)
Definition: LatticeMaster.cpp:1002
int findParticleNearestTo(const Vec3 &pos)
Definition: LatticeMaster.cpp:840
void setWallNormal(const std::string &, const Vec3 &)
Definition: LatticeMaster.cpp:1081
void addBondedIG(const CBondedIGP &)
Definition: LatticeMaster.cpp:2045
MpiRankAndComm getGlobalRankAndComm() const
Definition: LatticeMaster.h:171
Interaction parameters for frictional interaction.
Definition: FrictionInteraction.h:27
Interaction parameters for bonded interaction.
Definition: BondedInteraction.h:39
Interaction group parameters for CRotElasticInteractionGroups.
Definition: RotElasticInteraction.h:24
void addConnections(TmplIterator &it)
Definition: LatticeMaster.hpp:325
RunnableVector m_postRunnableVector
Definition: LatticeMaster.h:156
RunnableVector m_preRunnableVector
Definition: LatticeMaster.h:155
std::string m_timingFileName
Definition: LatticeMaster.h:127
void visitParticles(const IdVector &particleIdVector, TmplVisitor &visitor)
Definition: LatticeMaster.hpp:228
void searchNeighbors(bool)
Definition: LatticeMaster.cpp:1166
MpiWTimers * m_pTimers
Definition: LatticeMaster.h:128
double m_total_time
Definition: LatticeMaster.h:148
void oneStep()
Definition: LatticeMaster.cpp:1136
void performCheckPoints(const std::string &fileNamePrefix, int beginTime, int endTime, int timeInterval, int precision)
Definition: LatticeMaster.cpp:1507
Vec3 getWallPosn(const std::string &)
Definition: LatticeMaster.cpp:635
void setNumSteps(int s)
Definition: LatticeMaster.cpp:175
Definition: BodyForceGroup.h:26
void moveTaggedNodesBy(const std::string &, int, const Vec3 &)
Definition: LatticeMaster.cpp:774
Definition: RotThermFricInteraction.h:34
void addScalarTriangleSaveField(const string &, const string &, const string &, const string &, int, int, int)
Definition: LatticeMaster.cpp:1703
Interaction parameters for frictional interaction between rotational particles.
Definition: RotFricInteraction.h:37
void addScalarParticleSaveField(const std::string &, const std::string &, const std::string &, int, int, int)
field saving functions
Definition: LatticeMaster.cpp:1237
std::pair< MeshNodeDataVector, MeshTriDataVector > TriMeshDataPair
Definition: LatticeMaster.h:124
void moveSingleNodeBy(const std::string &, int, const Vec3 &)
Definition: LatticeMaster.cpp:753
void setParticleVel(int, const Vec3 &)
Definition: LatticeMaster.cpp:982
void setVerbosity(bool)
Definition: LatticeMaster.cpp:3316
double getTimeStepSize() const
Definition: LatticeMaster.h:188
void addTaggedVectorParticleSaveFieldWT(const std::string &, const std::string &, const std::string &, int, int, int, int, int, const MaxTrigParams &)
Definition: LatticeMaster.cpp:1445
std::vector< ParticleIdPair > ParticleIdPairVector
Definition: LatticeMaster.h:121
Definition: GeometryInfo.h:33
std::vector< MeshTriData > MeshTriDataVector
Definition: LatticeMaster.h:123
std::vector< unsigned int > ProcessDims
Definition: LatticeParam.h:32
Definition: BodyForceGroup.h:67
CLatticeMaster()
Definition: LatticeMaster.cpp:85
Interaction parameters for adhesive frictional interaction.
Definition: AdhesiveFriction.h:21
void translateMeshBy(const std::string &, const Vec3 &)
Definition: LatticeMaster.cpp:794
void do2dCalculations(bool do2d)
Definition: LatticeMaster.cpp:210
Definition: MaxTrigger.h:24
void addPostTimeStepRunnable(esys::lsm::Runnable &runnable)
Definition: LatticeMaster.cpp:1839
void addPairIG(const CElasticIGP &prms)
Definition: LatticeMaster.cpp:2263
~CLatticeMaster()
Definition: LatticeMaster.cpp:111
const std::string & getTimingFileName() const
Definition: LatticeMaster.cpp:205
TriMeshDataPair readTriMesh(const std::string &fileName, int)
Definition: LatticeMaster.cpp:2928
void setupWorkers(int numWorkers)
Definition: LatticeMaster.cpp:141
void readAndDistributeMesh2D(const std::string &, int)
Definition: LatticeMaster.cpp:3024
const std::string & getParticleType() const
Definition: LatticeMaster.h:335
void runPostRunnables()
Definition: LatticeMaster.cpp:1860
Interaction group parameters for Hertzian elastic interactions.
Definition: HertzianElasticInteraction.h:24
void readGeometryFile(const std::string &fileName)
Definition: LatticeMaster.cpp:443
int m_t
Definition: LatticeMaster.h:149
void getSlaveSpatialDomains()
Definition: LatticeMaster.cpp:391
Interaction group parameters for CBWallInteractionGroups.
Definition: BWallInteractionGroup.h:38
Definition: ABCDampingIGP.h:23
int m_global_rank
Definition: LatticeMaster.h:144
int m_global_size
Definition: LatticeMaster.h:145
std::vector< int > IntVector
Definition: LatticeMaster.h:112
void addPreTimeStepRunnable(esys::lsm::Runnable &runnable)
Definition: LatticeMaster.cpp:1834
Interaction group parameters for CEWallInteractionGroups.
Definition: brokenEWallInteractionGroup.h:32
double m_dt
Definition: LatticeMaster.h:150
void addVectorParticleSaveFieldWT(const std::string &, const std::string &, const std::string &, int, int, int, const MaxTrigParams &)
Definition: LatticeMaster.cpp:1414
void addExIG(const std::string &, const std::string &)
Definition: LatticeMaster.cpp:3234
std::vector< int > IdVector
Definition: LatticeMaster.h:546
Definition: Runnable.h:23
void tagParticleNearestTo(int, int, const Vec3 &)
Definition: LatticeMaster.cpp:817
Vec3 getWallForce(const std::string &)
Definition: LatticeMaster.cpp:664
void addWallIG(const CEWallIGP &)
Definition: LatticeMaster.cpp:545
bool m_isInitialized
Definition: LatticeMaster.h:151
void visitParticlesOfType(const IdVector &particleIdVector, TmplVisitor &visitor)
Definition: LatticeMaster.hpp:185
void runOneStep()
Definition: LatticeMaster.cpp:1871
void addMesh2D(const std::string &, const std::string &, int)
Definition: LatticeMaster.cpp:3001
void addTriMeshIG(const ETriMeshIP &prms)
Definition: LatticeMaster.cpp:2653
void visitTriMeshFaceForce(const string &meshName, TmplVisitor &visitor)
Definition: LatticeMaster.hpp:147
Definition: BMesh2DIP.h:16
void moveWallBy(const std::string &, const Vec3 &)
Definition: LatticeMaster.cpp:1062
std::string m_particle_type
Definition: LatticeMaster.h:153
void makeLattice(const char *particleType, double gridSize, double verletDist)
initialization functions
Definition: LatticeMaster.cpp:234
void addCappedBondedIG(int, const std::string &, double, double, double)
Definition: LatticeMaster.cpp:2077
void addShortBondedIG(int, const std::string &, double, double)
Definition: LatticeMaster.cpp:2111
Interaction group parameters for CElasticInteractionGroups.
Definition: ElasticInteraction.h:24
const RunnableVector & getPostTimeStepRunnableVector() const
Definition: LatticeMaster.h:443
void addTaggedVectorParticleSaveField(const std::string &, const std::string &, const std::string &, int, int, int, int, int)
Definition: LatticeMaster.cpp:1386
void runPreRunnables()
Definition: LatticeMaster.cpp:1852
void addParticles(TmplIterator &it)
Definition: LatticeMaster.hpp:262
Vec3 getParticlePosn(int particleId)
Definition: LatticeMaster.cpp:890
int getNumParticles()
Definition: LatticeMaster.cpp:2219
GeometryInfo m_geo_info
Definition: LatticeMaster.h:139
void performCheckPointsThroughMaster(const std::string &fileNamePrefix, int beginTime, int endTime, int timeInterval, int precision)
Definition: LatticeMaster.cpp:1537
map< int, ConnIdVector > m_temp_conn
Definition: LatticeMaster.h:135
Interaction group parameters for CLocalDampingGroup.
Definition: LocalDampingIGP.h:27
void addTaggedScalarParticleDistributionSaver(const std::string &, const std::string &, const std::string &, int, int, int, int, int, int, double, double, int)
Definition: LatticeMaster.cpp:1328
Definition: CheckPointController.h:31
Interaction group parameters for CDampingGroup.
Definition: DampingIGP.h:27
abstract base class for communicator
Definition: comm.h:46
void setTimingFileName(const std::string &fileName)
Definition: LatticeMaster.cpp:200
void readGeometry(const std::string &fileName)
Definition: LatticeMaster.hpp:29
void runEnd()
Definition: LatticeMaster.cpp:1808
void addRotThermBondedIG(const CRotThermBondedIGP &prms)
Definition: LatticeMaster.cpp:2185
void addBondedTriMeshIG(const BTriMeshIP &triMeshPrms, const MeshTagBuildPrms &buildPrms)
Definition: LatticeMaster.cpp:2726
void setVelocityOfWall(const std::string &, const Vec3 &)
Definition: LatticeMaster.cpp:1120
CheckPointController * m_pCheckPointController
Definition: LatticeMaster.h:129
void addTaggedScalarParticleSaveField(const std::string &, const std::string &, const std::string &, int, int, int, int, int)
Definition: LatticeMaster.cpp:1294
RunnableVector & getPostTimeStepRunnableVector()
Definition: LatticeMaster.h:451
std::string getLsmVersion() const
Definition: LatticeMaster.h:180
Definition: BTriMeshIP.h:18
void moveSingleParticleTo(int particleId, const Vec3 &posn)
Definition: LatticeMaster.cpp:733
void addVectorWallField(const string &, const string &, vector< string >, const string &, int, int, int)
Definition: LatticeMaster.cpp:1473
void createTriMesh(const std::string &meshName, const MeshNodeDataVector &mndVector, const MeshTriDataVector &mtdVector)
Definition: LatticeMaster.cpp:2967
void addScalarInteractionSaveField(const std::string &, const std::string &, const std::string &, const std::string &, const std::string &, int, int, int, bool checked=false)
Definition: LatticeMaster.cpp:1606
void addTaggedScalarInteractionSaveField(const std::string &, const std::string &, const std::string &, const std::string &, const std::string &, int, int, int, int, int, bool)
Definition: LatticeMaster.cpp:1771
const esys::lsm::CLatticeParam::ProcessDims & getProcessDims() const
Definition: LatticeMaster.cpp:296
void addVectorParticleSaveField(const std::string &, const std::string &, const std::string &, int, int, int)
Definition: LatticeMaster.cpp:1356
void addRotBondedIG(int, const std::string &, double, double, double, double, double, double, double, double, bool, bool, double)
Definition: LatticeMaster.cpp:2137
void updateInteractions()
Definition: LatticeMaster.cpp:1214
int getSteps() const
Definition: LatticeMaster.h:255
std::pair< int, int > ParticleIdPair
Definition: LatticeMaster.h:120
int getNumSteps() const
Definition: LatticeMaster.h:254
Interaction group parameters for CSoftBWallInteractionGroups.
Definition: SoftBWallInteractionGroup.h:31
void addTriMesh(const std::string &meshName, const std::string &fileName)
Definition: LatticeMaster.cpp:2852
void applyForceToWall(const std::string &, const Vec3 &)
Definition: LatticeMaster.cpp:1100
std::vector< int > ConnIdVector
Definition: LatticeMaster.h:134
void addDamping(const CDampingIGP &dampingIGP)
Definition: LatticeMaster.cpp:3167
int getTimeStep() const
Definition: LatticeMaster.h:187
void runInit()
Definition: LatticeMaster.cpp:1792
Definition: LatticeMaster.h:116
void addMesh2DIG(const ETriMeshIP &prms)
Definition: LatticeMaster.cpp:2680
Interaction group parameters for Hertzian viscoelastic interactions with friction.
Definition: HertzianViscoElasticFrictionInteraction.h:27
std::vector< MeshNodeData > MeshNodeDataVector
Definition: LatticeMaster.h:122
void setParticleNonRot(int)
Definition: LatticeMaster.cpp:947
std::vector< esys::lsm::Runnable * > RunnableVector
Definition: LatticeMaster.h:119
void readAndDistributeTriMesh(const std::string &, const std::string &, int)
Definition: LatticeMaster.cpp:2881
void visitMesh2dEdgeStress(const string &meshName, TmplVisitor &visitor)
Definition: LatticeMaster.hpp:112
Definition: RotThermBondedInteraction.h:34
void run()
Definition: LatticeMaster.cpp:2000
Interaction parameters for frictional interaction with a fractal distribution of the coefficient of f...
Definition: FractalFriction.h:25
MPI_Comm m_local_comm
Definition: LatticeMaster.h:159
Interaction group parameters for Hertzian viscoelastic interactions.
Definition: HertzianViscoElasticInteraction.h:24
const RunnableVector & getPreTimeStepRunnableVector() const
Definition: LatticeMaster.h:421
bool m_bbx_has_been_set
Definition: LatticeMaster.h:140
void addWall(const std::string &, const Vec3 &, const Vec3 &)
Definition: LatticeMaster.cpp:523
void visitMesh2dNodeReferences(const string &meshName, TmplVisitor &visitor)
Definition: LatticeMaster.hpp:87
int getNumWorkerProcesses() const
Definition: LatticeMaster.cpp:170
esys::lsm::CLatticeParam::ProcessDims m_processDims
Definition: LatticeMaster.h:131
Definition: BodyForceGroup.h:50
void saveTimingDataToFile(const std::string &fileNamePrefix)
Definition: LatticeMaster.cpp:182
int m_center_id
Definition: LatticeMaster.h:147
void initSnapShotController(const std::string &, int, int, int)
Definition: LatticeMaster.cpp:1570
Definition: BTriMeshIP.h:75
MPI_Comm m_global_comm
Definition: LatticeMaster.h:159
void addTaggedPairIG(const CRotFrictionIGP &prms, int, int, int, int)
Definition: LatticeMaster.cpp:2443
Interaction group parameters for CBWallInteractionGroups.
Definition: ViscWallIG.h:32
Interaction group parameters for Linear Dashpot interactions.
Definition: LinearDashpotInteraction.h:24
void moveParticleTo(int particleTag, const Vec3 &posn)
Definition: LatticeMaster.cpp:698
void init()
Definition: LatticeMaster.cpp:132
void saveTimingData()
Definition: LatticeMaster.cpp:1819
void setTimeStepSize(double dt)
Definition: LatticeMaster.cpp:280
bool checkNeighbors()
Definition: LatticeMaster.cpp:1189
void addSingleIG(const esys::lsm::GravityIGP &gravityIGP)
Definition: LatticeMaster.cpp:3083
void removeIG(const std::string &)
Definition: LatticeMaster.cpp:2626
Definition: BTriMeshIP.h:62
void setParticleNonDynamic(int)
Definition: LatticeMaster.cpp:930
void addVectorInteractionSaveField(const std::string &, const std::string &, const std::string &, const std::string &, const std::string &, int, int, int, bool checked=false)
Definition: LatticeMaster.cpp:1737
Definition: ETriMeshIP.h:17
void setParticleNonTrans(int)
Definition: LatticeMaster.cpp:964
void setSpatialDomain(const Vec3 &minBBoxPt, const Vec3 &maxBBoxPt)
Definition: LatticeMaster.cpp:307
Definition: RotThermElasticInteraction.h:23