13 #ifndef __LATTICEMASTER_H
14 #define __LATTICEMASTER_H
71 #include <boost/filesystem/path.hpp>
169 void runRunnables(RunnableVector::iterator begin, RunnableVector::iterator end);
174 TriMeshDataPair
readTriMesh(
const std::string &fileName,
int);
175 TriMeshDataPair
readTriMesh(
const std::string &fileName);
189 return std::string(PACKAGE_VERSION);
239 const std::string &meshName,
240 const MeshNodeDataVector &mndVector,
241 const MeshTriDataVector &mtdVector
243 void addMesh2D(
const std::string&,
const std::string&,
int);
245 void addTriMesh(
const std::string &meshName,
const std::string &fileName);
259 void addExIG(
const std::string&,
const std::string&);
264 void addRotBondedIG(
int,
const std::string&,
double,
double,
double,
double,
double,
double,
double,
double,
bool,
bool,
double);
355 void addScalarInteractionSaveField(
const std::string&,
const std::string&,
const std::string&,
const std::string&,
const std::string&,
int,
int,
int,
bool checked=
false);
356 void addVectorInteractionSaveField(
const std::string&,
const std::string&,
const std::string&,
const std::string&,
const std::string&,
int,
int,
int,
bool checked=
false);
357 void addTaggedScalarInteractionSaveField(
const std::string&,
const std::string&,
const std::string&,
const std::string&,
const std::string&,
int,
int,
int,
int,
int,
bool);
358 void addTaggedScalarParticleDistributionSaver(
const std::string&,
const std::string&,
const std::string&,
int,
int,
int,
int,
int,
int,
double,
double,
int);
361 void addVectorWallField(
const string&,
const string&,vector<string>,
const string&,
int,
int,
int);
377 const std::string &fileNamePrefix,
397 const std::string &fileNamePrefix,
408 const char *particleType,
414 const char *particleType,
491 const Vec3 &minBBoxPt,
492 const Vec3 &maxBBoxPt,
515 template <
class TmplParticle>
542 template <
class TmplIterator,
class TmplParticle>
553 template <
class TmplIterator>
557 template <
typename TmplVisitor>
560 template <
typename TmplVisitor>
563 template <
typename TmplVisitor>
566 template <
typename TmplVisitor>
568 const string &meshName,
574 template <
typename TmplVisitor,
typename TmplParticle>
576 const IdVector &particleIdVector,
580 template <
typename TmplVisitor>
581 void visitParticles(
const IdVector &particleIdVector, TmplVisitor &visitor);
592 template<
typename TmplParticle>
void moveTaggedParticlesBy(int particleTag, const Vec3 &displacement)
Definition: LatticeMaster.cpp:757
bool m_geometry_is_initialized
Definition: LatticeMaster.h:142
CheckPointController * m_pSnapShotController
Definition: LatticeMaster.h:131
void setProcessDims(const esys::lsm::CLatticeParam::ProcessDims &dims)
Definition: LatticeMaster.cpp:295
void setParticleAngVel(int, const Vec3 &)
Definition: LatticeMaster.cpp:1082
void addVectorTriangleSaveField(const string &, const string &, const string &, const string &, int, int, int)
Definition: LatticeMaster.cpp:1709
void loadCheckPointData(const std::string &checkPointFileName)
Definition: LatticeMaster.cpp:490
Definition: RankAndComm.h:19
int m_max_ts
Definition: LatticeMaster.h:147
void visitMeshFaceReferences(const string &meshName)
Definition: LatticeMaster.hpp:81
void addBondedMesh2DIG(const BMesh2DIP &, const MeshTagBuildPrms &)
Definition: LatticeMaster.cpp:2817
TML_Comm m_tml_global_comm
Definition: LatticeMaster.h:159
Vec3 m_init_min_pt
Definition: LatticeMaster.h:165
RunnableVector & getPreTimeStepRunnableVector()
Definition: LatticeMaster.h:437
void setParticleDensity(int tag, int mask, double rho)
Definition: LatticeMaster.cpp:1061
void runRunnables(RunnableVector::iterator begin, RunnableVector::iterator end)
Definition: LatticeMaster.cpp:1883
vector< AFieldMaster * > m_save_fields
Definition: LatticeMaster.h:137
MPI_Group m_mpi_local_group
Definition: LatticeMaster.h:161
bool m_first_time
Definition: LatticeMaster.h:153
void setTaggedParticleVel(int tag, const Vec3 &)
Definition: LatticeMaster.cpp:1041
int findParticleNearestTo(const Vec3 &pos)
Definition: LatticeMaster.cpp:879
void setWallNormal(const std::string &, const Vec3 &)
Definition: LatticeMaster.cpp:1120
void addBondedIG(const CBondedIGP &)
Definition: LatticeMaster.cpp:2084
MpiRankAndComm getGlobalRankAndComm() const
Definition: LatticeMaster.h:178
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:344
RunnableVector m_postRunnableVector
Definition: LatticeMaster.h:157
RunnableVector m_preRunnableVector
Definition: LatticeMaster.h:156
std::string m_timingFileName
Definition: LatticeMaster.h:128
void visitParticles(const IdVector &particleIdVector, TmplVisitor &visitor)
Definition: LatticeMaster.hpp:228
void searchNeighbors(bool)
Definition: LatticeMaster.cpp:1205
MpiWTimers * m_pTimers
Definition: LatticeMaster.h:129
double m_total_time
Definition: LatticeMaster.h:149
void oneStep()
Definition: LatticeMaster.cpp:1175
void performCheckPoints(const std::string &fileNamePrefix, int beginTime, int endTime, int timeInterval, int precision)
Definition: LatticeMaster.cpp:1546
Vec3 getWallPosn(const std::string &)
Definition: LatticeMaster.cpp:674
Vec3 m_init_max_pt
Definition: LatticeMaster.h:166
void setNumSteps(int s)
Definition: LatticeMaster.cpp:179
Definition: BodyForceGroup.h:26
void moveTaggedNodesBy(const std::string &, int, const Vec3 &)
Definition: LatticeMaster.cpp:813
Definition: RotThermFricInteraction.h:34
void addScalarTriangleSaveField(const string &, const string &, const string &, const string &, int, int, int)
Definition: LatticeMaster.cpp:1742
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:1276
std::pair< MeshNodeDataVector, MeshTriDataVector > TriMeshDataPair
Definition: LatticeMaster.h:125
void moveSingleNodeBy(const std::string &, int, const Vec3 &)
Definition: LatticeMaster.cpp:792
void setParticleVel(int, const Vec3 &)
Definition: LatticeMaster.cpp:1021
void setVerbosity(bool)
Definition: LatticeMaster.cpp:3355
double getTimeStepSize() const
Definition: LatticeMaster.h:195
void addTaggedVectorParticleSaveFieldWT(const std::string &, const std::string &, const std::string &, int, int, int, int, int, const MaxTrigParams &)
Definition: LatticeMaster.cpp:1484
std::vector< ParticleIdPair > ParticleIdPairVector
Definition: LatticeMaster.h:122
Definition: GeometryInfo.h:33
std::vector< MeshTriData > MeshTriDataVector
Definition: LatticeMaster.h:124
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:833
void do2dCalculations(bool do2d)
Definition: LatticeMaster.cpp:214
Definition: CheckPointable.cpp:16
Definition: MaxTrigger.h:24
void addPostTimeStepRunnable(esys::lsm::Runnable &runnable)
Definition: LatticeMaster.cpp:1878
void addPairIG(const CElasticIGP &prms)
Definition: LatticeMaster.cpp:2302
~CLatticeMaster()
Definition: LatticeMaster.cpp:115
const std::string & getTimingFileName() const
Definition: LatticeMaster.cpp:209
TriMeshDataPair readTriMesh(const std::string &fileName, int)
Definition: LatticeMaster.cpp:2967
void setupWorkers(int numWorkers)
Definition: LatticeMaster.cpp:145
void readAndDistributeMesh2D(const std::string &, int)
Definition: LatticeMaster.cpp:3063
const std::string & getParticleType() const
Definition: LatticeMaster.h:343
void runPostRunnables()
Definition: LatticeMaster.cpp:1899
Interaction group parameters for Hertzian elastic interactions.
Definition: HertzianElasticInteraction.h:24
void readGeometryFile(const std::string &fileName)
Definition: LatticeMaster.cpp:459
int m_t
Definition: LatticeMaster.h:150
void getSlaveSpatialDomains()
Definition: LatticeMaster.cpp:407
Interaction group parameters for CBWallInteractionGroups.
Definition: BWallInteractionGroup.h:38
Definition: ABCDampingIGP.h:23
int m_global_rank
Definition: LatticeMaster.h:145
int m_global_size
Definition: LatticeMaster.h:146
std::vector< int > IntVector
Definition: LatticeMaster.h:113
void addPreTimeStepRunnable(esys::lsm::Runnable &runnable)
Definition: LatticeMaster.cpp:1873
double m_dbl_NaN
Definition: LatticeMaster.h:164
Interaction group parameters for CEWallInteractionGroups.
Definition: brokenEWallInteractionGroup.h:32
double m_dt
Definition: LatticeMaster.h:151
void addVectorParticleSaveFieldWT(const std::string &, const std::string &, const std::string &, int, int, int, const MaxTrigParams &)
Definition: LatticeMaster.cpp:1453
void particlesMinMax(const TmplParticle &particle)
Definition: LatticeMaster.hpp:402
void addExIG(const std::string &, const std::string &)
Definition: LatticeMaster.cpp:3273
std::vector< int > IdVector
Definition: LatticeMaster.h:572
Definition: Runnable.h:23
void tagParticleNearestTo(int, int, const Vec3 &)
Definition: LatticeMaster.cpp:856
Vec3 getWallForce(const std::string &)
Definition: LatticeMaster.cpp:703
void addWallIG(const CEWallIGP &)
Definition: LatticeMaster.cpp:561
bool m_isInitialized
Definition: LatticeMaster.h:152
void visitParticlesOfType(const IdVector &particleIdVector, TmplVisitor &visitor)
Definition: LatticeMaster.hpp:185
void runOneStep()
Definition: LatticeMaster.cpp:1910
void addMesh2D(const std::string &, const std::string &, int)
Definition: LatticeMaster.cpp:3040
void addTriMeshIG(const ETriMeshIP &prms)
Definition: LatticeMaster.cpp:2692
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:1101
std::string m_particle_type
Definition: LatticeMaster.h:154
void addTaggedWallIG(const CEWallIGP &, int, int)
Definition: LatticeMaster.cpp:653
void makeLattice(const char *particleType, double gridSize, double verletDist)
initialization functions
Definition: LatticeMaster.cpp:238
void addCappedBondedIG(int, const std::string &, double, double, double)
Definition: LatticeMaster.cpp:2116
void addShortBondedIG(int, const std::string &, double, double)
Definition: LatticeMaster.cpp:2150
Interaction group parameters for CElasticInteractionGroups.
Definition: ElasticInteraction.h:24
const RunnableVector & getPostTimeStepRunnableVector() const
Definition: LatticeMaster.h:451
esys::lsm::IntVector m_particle_dimensions
Definition: LatticeMaster.h:167
void addTaggedVectorParticleSaveField(const std::string &, const std::string &, const std::string &, int, int, int, int, int)
Definition: LatticeMaster.cpp:1425
void runPreRunnables()
Definition: LatticeMaster.cpp:1891
void addParticles(TmplIterator &it)
Definition: LatticeMaster.hpp:262
esys::lsm::IntVector getParticleDimensions()
Definition: LatticeMaster.h:469
Vec3 getParticlePosn(int particleId)
Definition: LatticeMaster.cpp:929
int getNumParticles()
Definition: LatticeMaster.cpp:2258
GeometryInfo m_geo_info
Definition: LatticeMaster.h:140
void performCheckPointsThroughMaster(const std::string &fileNamePrefix, int beginTime, int endTime, int timeInterval, int precision)
Definition: LatticeMaster.cpp:1576
map< int, ConnIdVector > m_temp_conn
Definition: LatticeMaster.h:136
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:1367
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:204
void readGeometry(const std::string &fileName)
Definition: LatticeMaster.hpp:29
void runEnd()
Definition: LatticeMaster.cpp:1847
void addRotThermBondedIG(const CRotThermBondedIGP &prms)
Definition: LatticeMaster.cpp:2224
void addBondedTriMeshIG(const BTriMeshIP &triMeshPrms, const MeshTagBuildPrms &buildPrms)
Definition: LatticeMaster.cpp:2765
void setVelocityOfWall(const std::string &, const Vec3 &)
Definition: LatticeMaster.cpp:1159
CheckPointController * m_pCheckPointController
Definition: LatticeMaster.h:130
void addTaggedScalarParticleSaveField(const std::string &, const std::string &, const std::string &, int, int, int, int, int)
Definition: LatticeMaster.cpp:1333
RunnableVector & getPostTimeStepRunnableVector()
Definition: LatticeMaster.h:459
std::string getLsmVersion() const
Definition: LatticeMaster.h:187
void getInitMinMaxPt(Vec3 &initMinPt, Vec3 &initMaxPt)
Definition: LatticeMaster.cpp:311
Definition: BTriMeshIP.h:18
void moveSingleParticleTo(int particleId, const Vec3 &posn)
Definition: LatticeMaster.cpp:772
void addVectorWallField(const string &, const string &, vector< string >, const string &, int, int, int)
Definition: LatticeMaster.cpp:1512
void createTriMesh(const std::string &meshName, const MeshNodeDataVector &mndVector, const MeshTriDataVector &mtdVector)
Definition: LatticeMaster.cpp:3006
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:1645
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:1810
const esys::lsm::CLatticeParam::ProcessDims & getProcessDims() const
Definition: LatticeMaster.cpp:300
void addVectorParticleSaveField(const std::string &, const std::string &, const std::string &, int, int, int)
Definition: LatticeMaster.cpp:1395
void addRotBondedIG(int, const std::string &, double, double, double, double, double, double, double, double, bool, bool, double)
Definition: LatticeMaster.cpp:2176
void updateInteractions()
Definition: LatticeMaster.cpp:1253
int getSteps() const
Definition: LatticeMaster.h:262
std::pair< int, int > ParticleIdPair
Definition: LatticeMaster.h:121
int getNumSteps() const
Definition: LatticeMaster.h:261
Interaction group parameters for CSoftBWallInteractionGroups.
Definition: SoftBWallInteractionGroup.h:31
void addTriMesh(const std::string &meshName, const std::string &fileName)
Definition: LatticeMaster.cpp:2891
void applyForceToWall(const std::string &, const Vec3 &)
Definition: LatticeMaster.cpp:1139
std::vector< int > ConnIdVector
Definition: LatticeMaster.h:135
void addDamping(const CDampingIGP &dampingIGP)
Definition: LatticeMaster.cpp:3206
int getTimeStep() const
Definition: LatticeMaster.h:194
void runInit()
Definition: LatticeMaster.cpp:1831
Definition: LatticeMaster.h:117
void addMesh2DIG(const ETriMeshIP &prms)
Definition: LatticeMaster.cpp:2719
Interaction group parameters for Hertzian viscoelastic interactions with friction.
Definition: HertzianViscoElasticFrictionInteraction.h:27
std::vector< MeshNodeData > MeshNodeDataVector
Definition: LatticeMaster.h:123
void setParticleNonRot(int)
Definition: LatticeMaster.cpp:986
std::vector< esys::lsm::Runnable * > RunnableVector
Definition: LatticeMaster.h:120
void readAndDistributeTriMesh(const std::string &, const std::string &, int)
Definition: LatticeMaster.cpp:2920
void visitMesh2dEdgeStress(const string &meshName, TmplVisitor &visitor)
Definition: LatticeMaster.hpp:112
Definition: RotThermBondedInteraction.h:34
void run()
Definition: LatticeMaster.cpp:2039
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:160
Interaction group parameters for Hertzian viscoelastic interactions.
Definition: HertzianViscoElasticInteraction.h:24
const RunnableVector & getPreTimeStepRunnableVector() const
Definition: LatticeMaster.h:429
bool m_bbx_has_been_set
Definition: LatticeMaster.h:141
void addWall(const std::string &, const Vec3 &, const Vec3 &)
Definition: LatticeMaster.cpp:539
void visitMesh2dNodeReferences(const string &meshName, TmplVisitor &visitor)
Definition: LatticeMaster.hpp:87
int getNumWorkerProcesses() const
Definition: LatticeMaster.cpp:174
esys::lsm::CLatticeParam::ProcessDims m_processDims
Definition: LatticeMaster.h:132
Definition: BodyForceGroup.h:50
void saveTimingDataToFile(const std::string &fileNamePrefix)
Definition: LatticeMaster.cpp:186
int m_center_id
Definition: LatticeMaster.h:148
void initSnapShotController(const std::string &, int, int, int)
Definition: LatticeMaster.cpp:1609
Definition: BTriMeshIP.h:75
MPI_Comm m_global_comm
Definition: LatticeMaster.h:160
void addTaggedPairIG(const CRotFrictionIGP &prms, int, int, int, int)
Definition: LatticeMaster.cpp:2482
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:737
void init()
Definition: LatticeMaster.cpp:136
void saveTimingData()
Definition: LatticeMaster.cpp:1858
void setTimeStepSize(double dt)
Definition: LatticeMaster.cpp:284
bool checkNeighbors()
Definition: LatticeMaster.cpp:1228
void addSingleIG(const esys::lsm::GravityIGP &gravityIGP)
Definition: LatticeMaster.cpp:3122
void removeIG(const std::string &)
Definition: LatticeMaster.cpp:2665
Definition: BTriMeshIP.h:62
void setParticleNonDynamic(int)
Definition: LatticeMaster.cpp:969
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:1776
Definition: ETriMeshIP.h:17
void setParticleNonTrans(int)
Definition: LatticeMaster.cpp:1003
void setSpatialDomain(const Vec3 &minBBoxPt, const Vec3 &maxBBoxPt)
Definition: LatticeMaster.cpp:323
Definition: RotThermElasticInteraction.h:23