13 #ifndef ESYS_LSM_LSMMPIPY_H
14 #define ESYS_LSM_LSMMPIPY_H
17 #include <boost/python.hpp>
18 #include <boost/shared_ptr.hpp>
111 int numWorkerProcesses,
112 const boost::python::list &mpiDimList
120 const std::string &particleType,
185 const std::string &interactionName1,
186 const std::string &interactionName2
214 void readMeshWithTag(
const std::string &fileName,
const std::string &meshName,
int tag);
215 void readMesh(
const std::string &fileName,
const std::string &meshName);
217 const std::string &meshName,
218 const boost::python::object &nodeSequence,
219 const boost::python::object &triSequence
222 void readMesh2D(
const std::string &fileName,
const std::string &meshName,
int tag);
243 const boost::python::list &circDimList
298 void addTaggedScalarParticleDistributionSaver(
const string&,
const string&,
const string&,
int,
int,
int,
int,
int,
int,
double,
double,
int);
307 void visitNodeRefs2d(
const std::string &meshName, boost::python::object pyObject);
314 const boost::python::list &idList,
315 boost::python::object &pyObject
319 boost::python::object &pyObject
325 const boost::python::list &idList
329 const std::string &groupName,
330 const ParticleIdPairVector &idPairVector
336 const std::string &groupName
353 typedef boost::shared_ptr<Impl>
ImplPtr;
class for bonded Mesh2D interactions in python interface
Definition: BondedMesh2DPrmsPy.h:29
void setNumTimeSteps(int numTimeSteps)
Definition: LsmMpiPy.cpp:726
wrapper for CRotBondedIGP
Definition: InteractionParamsPy.h:267
void createInteractionVectorFieldSaver(const InteractionVectorFieldSaverPrmsPy &)
Definition: LsmMpiPy.cpp:1198
wrapper for CBondedIGP
Definition: InteractionParamsPy.h:146
void setVerbosityPy(bool verbose)
Definition: LsmMpiPy.cpp:1414
wrapper for CRotElasticIGP
Definition: InteractionParamsPy.h:456
void createRotFrictionInteractGrpTag(const RotFrictionPrmsPy &prms, int, int, int, int)
Definition: LsmMpiPy.cpp:612
Definition: InteractionFieldSaverPrmsPy.h:50
void setSpatialDomain(const Vec3Py &minPt, const Vec3Py &maxPt)
Definition: LsmMpiPy.cpp:929
Vec3Py getParticlePosn(int particleId)
Definition: LsmMpiPy.cpp:939
wrapper for CBWallIGP
Definition: WallPrmsPy.h:57
void createNRotElasticLinMeshInteractGrp(const NRotElasticLinMeshPrmsPy &prms)
Definition: LsmMpiPy.cpp:846
Definition: WallFieldSaverPrmsPy.h:77
void createNRotElasticInteractGrp(const NRotElasticPrmsPy &prms)
Definition: LsmMpiPy.cpp:377
Definition: ParticleFieldSaverPrmsPy.h:92
void visitNodeRefs2d(const std::string &meshName, boost::python::object pyObject)
Definition: LsmMpiPy.cpp:1458
void createNRotElasticWallTagged(const NRotElasticWallPrmsPy &prms, int tag, int mask)
Definition: LsmMpiPy.cpp:1003
void visitRefForcePairs(const std::string &meshName, boost::python::object pyObject)
void createFrictionInteractGrp(const FrictionPrmsPy &prms)
Definition: LsmMpiPy.cpp:516
void addPostTimeStepRunnable(RunnablePy &runnable)
Definition: LsmMpiPy.cpp:882
CLatticeMaster::MeshNodeDataVector MeshNodeDataVector
Definition: LsmMpiPy.h:104
void createCheckPointerThroughMaster(const RestartCheckPointPrmsPy &prms)
Definition: LsmMpiPy.cpp:694
void setSlaveTimingFileName(const std::string &fileNamePrefix)
Definition: LsmMpiPy.cpp:276
Definition: InteractionFieldSaverPrmsPy.h:101
Definition: InteractionFieldSaverPrmsPy.h:64
std::string getParticleType() const
Definition: LsmMpiPy.cpp:339
void tagParticleNearestTo(int, int, const Vec3Py &)
Definition: LsmMpiPy.cpp:1049
Definition: InteractionParamsPy.h:529
wrapper for CEWallIGP
Definition: WallPrmsPy.h:40
int findClosestParticle(const Vec3Py &pt)
Definition: LsmMpiPy.cpp:934
ImplPtr m_implPtr
Definition: LsmMpiPy.h:354
$Revision$ $Date$
Definition: CheckPointParamsPy.h:34
wrapper for CRotThermFrictionIGP
Definition: InteractionParamsPy.h:489
void force2dComputations(bool do2d)
Definition: LsmMpiPy.cpp:904
Definition: ParticleFieldSaverPrmsPy.h:70
class for elastic triangular mesh interactions in python interface
Definition: ElasticTriMeshPrmsPy.h:30
Definition: ParticleFieldSaverPrmsPy.h:57
void setParticleNonRot(int)
Definition: LsmMpiPy.cpp:1059
Definition: BondInteractionGroupPy.h:36
void createNRotShortBondInteractGrp(const NRotShortBondPrmsPy &bondPrms)
Definition: LsmMpiPy.cpp:442
void createDamping(const DampingPrmsPy &prms)
Definition: LsmMpiPy.cpp:565
std::pair< MeshNodeDataVector, MeshTriDataVector > TriMeshDataPair
Definition: LatticeMaster.h:125
void addVectorWallField(const WallVectorFieldSaverPrmsPy &prms)
Definition: LsmMpiPy.cpp:1332
void setParticleDensity(int, int, double)
Definition: LsmMpiPy.cpp:1034
std::vector< ParticleIdPair > ParticleIdPairVector
Definition: LatticeMaster.h:122
std::vector< MeshTriData > MeshTriDataVector
Definition: LatticeMaster.h:124
void createNRotFrictionInteractGrpTag(const NRotFrictionPrmsPy &prms, int, int, int, int)
Definition: LsmMpiPy.cpp:624
wrapper for CRotFrictionIGP
Definition: InteractionParamsPy.h:375
wrapper for CDampingIGP
Definition: InteractionParamsPy.h:66
void exportLsm()
Definition: LsmMpiPy.cpp:1680
wrapper for CLinearDashpotIGP
Definition: InteractionParamsPy.h:234
Definition: CheckPointable.cpp:16
Definition: InteractionParamsPy.h:542
void setParticleVel(int, const Vec3Py &)
Definition: LsmMpiPy.cpp:1024
void createTaggedInteractionScalarFieldSaver(const TaggedInteractionScalarFieldSaverPrmsPy &)
Definition: LsmMpiPy.cpp:1162
void createLinearDashpotIG(const LinearDashpotPrmsPy &prms)
Definition: LsmMpiPy.cpp:412
Class for elastic piece-wise linear mesh interactions in the python interface.
Definition: ElasticMesh2DPrmsPy.h:43
void moveSingleParticleTo(int particleId, const Vec3Py &pt)
Definition: LsmMpiPy.cpp:957
wrapper for CRotThermElasticIGP
Definition: InteractionParamsPy.h:475
wrapper for CRotThermBondedIGP
Definition: InteractionParamsPy.h:506
void addTaggedScalarParticleDistributionSaver(const string &, const string &, const string &, int, int, int, int, int, int, double, double, int)
Definition: LsmMpiPy.cpp:1288
void setWallNormal(const string &, const Vec3Py &wn)
Definition: LsmMpiPy.cpp:978
void readGeometry(const std::string &fileName)
Definition: LsmMpiPy.cpp:360
wrapper for CHertzianViscoElasticIGP
Definition: InteractionParamsPy.h:224
InteractionNameTypeMap & getNameTypeMap()
Definition: LsmMpiPy.cpp:209
void createHertzianViscoElasticFrictionIG(const HertzianViscoElasticFrictionPrmsPy &prms)
Definition: LsmMpiPy.cpp:393
LsmMpiPy(int numWorkerProcesses, const boost::python::list &mpiDimList)
Definition: LsmMpiPy.cpp:193
Definition: RunnablePy.h:22
void setTimeStepSize(double dt)
Definition: LsmMpiPy.cpp:261
void checkMpiDimensions(int numProcesses, const std::vector< int > &mpiDimVector)
Definition: LsmMpiPy.cpp:115
void exit()
Definition: LsmMpiPy.cpp:899
void createInteractionScalarFieldSaver(const InteractionScalarFieldSaverPrmsPy &prms)
Definition: LsmMpiPy.cpp:1099
void createNRotFrictionInteractGrp(const NRotFrictionPrmsPy &prms)
Definition: LsmMpiPy.cpp:455
void createRotElasticInteractGrpTag(const RotElasticPrmsPy &prms, int, int, int, int)
Definition: LsmMpiPy.cpp:656
void moveTaggedParticlesTo(int tag, const Vec3Py &pt)
Definition: LsmMpiPy.cpp:947
wrapper for CRotBondedIGP
Definition: InteractionParamsPy.h:307
Definition: BoundingBoxPy.h:29
void createNRotElasticMesh2DInteractGrp(const NRotElasticMesh2DPrmsPy &prms)
Definition: LsmMpiPy.cpp:839
void getInitMinMaxPt(Vec3Py &initMinPt, Vec3Py &initMaxPt)
Definition: LsmMpiPy.cpp:1648
void createNRotElasticTriMeshInteractGrp(const NRotElasticTriMeshPrmsPy &prms)
Definition: LsmMpiPy.cpp:817
void createTaggedParticleVectorFieldSaver(const TaggedParticleVectorFieldSaverPrmsPy &)
Definition: LsmMpiPy.cpp:1275
const CLatticeMaster & getLatticeMaster() const
Definition: LsmMpiPy.cpp:1401
CLatticeMaster::ParticleIdPairVector ParticleIdPairVector
Definition: LsmMpiPy.h:103
void createWall(const string &name, const Vec3Py &posn, const Vec3Py &normal)
Definition: LsmMpiPy.cpp:965
class for bonded TriMesh interactions in python interface
Definition: BondedTriMeshPrmsPy.h:36
void createParticles(boost::python::object &iterable)
Definition: LsmMpiPy.cpp:287
void visitParticles(boost::python::object &pyObject)
wrapper for CFrictionIGP
Definition: InteractionParamsPy.h:244
CLatticeMaster::MeshTriDataVector MeshTriDataVector
Definition: LsmMpiPy.h:105
void createRotBondInteractGrp(const RotBondPrmsPy &bondPrms)
Definition: LsmMpiPy.cpp:466
wrapper for CLocalDampingIGP
Definition: InteractionParamsPy.h:114
wrapper for VWFrictionIGP
Definition: InteractionParamsPy.h:557
wrapper for CBondedIGP (used in construction of short bonded IG)
Definition: InteractionParamsPy.h:167
void createNRotBondInteractGrp(const NRotBondPrmsPy &bondPrms)
Definition: LsmMpiPy.cpp:420
void checkParticleType(const std::string &particleType)
void createHertzianElasticIG(const HertzianElasticPrmsPy &prms)
Definition: LsmMpiPy.cpp:385
wrapper for CCappedBondedIGP
Definition: InteractionParamsPy.h:157
std::map< std::string, std::string > InteractionNameTypeMap
Definition: LsmMpiPy.h:342
void createCheckPointer(const RestartCheckPointPrmsPy &prms)
Definition: LsmMpiPy.cpp:683
virtual ~LsmMpiPy()
Definition: LsmMpiPy.cpp:205
wrapper for CElasticIGP
Definition: InteractionParamsPy.h:177
void loadCheckPoint(const std::string &)
Definition: LsmMpiPy.cpp:716
void createNRotBondedLinMeshInteractGrp(const NRotBondedLinMeshPrmsPy &prms)
Definition: LsmMpiPy.cpp:853
void translateMesh(const std::string &, const Vec3Py &)
Definition: LsmMpiPy.cpp:809
void setBBoxSpatialDomain(const BoundingBoxPy &domain)
Definition: LsmMpiPy.cpp:909
void createRotLocalDamping(const RotLocalDampingPrmsPy &prms)
Definition: LsmMpiPy.cpp:579
class for elastic 2D mesh interactions in python interface. Deprecated: use NRotElasticLinMeshPrmsPy...
Definition: ElasticMesh2DPrmsPy.h:29
void createCheckedInteractionVectorFieldSaver(const CheckedInteractionVectorFieldSaverPrmsPy &prms)
Definition: LsmMpiPy.cpp:1230
void createNRotBondedWall(const NRotBondedWallPrmsPy &prms)
Definition: LsmMpiPy.cpp:983
void createRotThermFrictionInteractGrp(const RotThermFrictionPrmsPy &prms)
Definition: LsmMpiPy.cpp:534
void createNRotSoftBondedWall(const NRotSoftBondedWallPrmsPy &prms)
Definition: LsmMpiPy.cpp:997
void setParticleNonTrans(int)
Definition: LsmMpiPy.cpp:1064
void readMesh(const std::string &fileName, const std::string &meshName)
Definition: LsmMpiPy.cpp:745
void setVerbosityPy(bool verbose)
Definition: LsmMpiPy.cpp:1394
boost::python::list getParticleList()
Definition: LsmMpiPy.cpp:1626
CLatticeMaster::ParticleIdPair ParticleIdPair
Definition: LsmMpiPy.h:102
boost::python::list getParticleWithIdList(const boost::python::list &idList)
Definition: LsmMpiPy.cpp:1636
Definition: TriggerPrmsPy.h:29
void createTriMesh(const std::string &meshName, const boost::python::object &nodeSequence, const boost::python::object &triSequence)
Definition: LsmMpiPy.cpp:753
void createGravity(const GravityPrmsPy &)
Definition: LsmMpiPy.cpp:593
Definition: ParticleFieldSaverPrmsPy.h:44
void createLinearDashpotInteractGrpTag(const LinearDashpotPrmsPy &prms, int, int, int, int)
Definition: LsmMpiPy.cpp:636
wrapper for CHertzianElasticIGP
Definition: InteractionParamsPy.h:196
void createBonds(const std::string &groupName, const ParticleIdPairVector &idPairVector)
Definition: LsmMpiPy.cpp:1661
Parameter class for restart checkpointers, differs from CheckPointPrmsPy by having an additional "bin...
Definition: CheckPointParamsPy.h:58
void addPreTimeStepRunnable(RunnablePy &runnable)
Definition: LsmMpiPy.cpp:877
Vec3Py getWallForce(const std::string &)
Definition: LsmMpiPy.cpp:1018
void updateInteractions()
Definition: LsmMpiPy.cpp:1473
Definition: InteractionFieldSaverPrmsPy.h:115
wrapper for CRotFrictionIGP
Definition: InteractionParamsPy.h:410
void createTaggedParticleVectorFieldSaverWithTrigger(const MaxTriggerPrmsPy &, const TaggedParticleVectorFieldSaverPrmsPy &)
Definition: LsmMpiPy.cpp:1372
void createABCDamping(const ABCDampingPrmsPy &prms)
Definition: LsmMpiPy.cpp:586
Wrapper to make LatticeMaster methods available in Python.
Definition: LsmMpiPy.h:99
wrapper for CSoftBWallIGP
Definition: WallPrmsPy.h:73
void createRotElasticInteractGrp(const RotElasticPrmsPy &prms)
Definition: LsmMpiPy.cpp:551
CLatticeMaster::TriMeshDataPair TriMeshDataPair
Definition: LsmMpiPy.h:106
void setTaggedParticleVel(int, const Vec3Py &)
Definition: LsmMpiPy.cpp:1039
void applyForceToWall(const string &, const Vec3Py &)
Definition: LsmMpiPy.cpp:1008
void createVWFrictionIG(const VWFrictionPrmsPy &)
Definition: LsmMpiPy.cpp:542
int getNumParticles()
Definition: LsmMpiPy.cpp:365
void addVectorTriangleSaveField(const TriangleVectorFieldSaverPrmsPy &)
Definition: LsmMpiPy.cpp:1303
void moveSingleMeshNodeBy(const std::string &meshname, int id, const Vec3Py &d)
Definition: LsmMpiPy.cpp:868
wrapper for ABCDampingIGP
Definition: InteractionParamsPy.h:127
std::pair< int, int > ParticleIdPair
Definition: LatticeMaster.h:121
void setBBoxSpatialDomainWithCirc(const BoundingBoxPy &domain, const boost::python::list &circDimList)
Definition: LsmMpiPy.cpp:917
void moveWallBy(const string &, const Vec3Py &disp)
Definition: LsmMpiPy.cpp:973
void visitParticlesWithId(const boost::python::list &idList, boost::python::object &pyObject)
Definition: LsmMpiPy.cpp:1614
Definition: TriangleFieldSaverPrmsPy.h:26
void createHertzianViscoElasticIG(const HertzianViscoElasticPrmsPy &prms)
Definition: LsmMpiPy.cpp:404
int getTimeStep() const
Definition: LsmMpiPy.cpp:370
void setTimingFileName(const std::string &fileNamePrefix)
Definition: LsmMpiPy.cpp:271
void createParticleScalarFieldSaver(const ParticleScalarFieldSaverPrmsPy &prms)
Definition: LsmMpiPy.cpp:1073
wrapper for CLocalDampingIGP
Definition: InteractionParamsPy.h:101
void readMesh2D(const std::string &fileName, const std::string &meshName, int tag)
Definition: LsmMpiPy.cpp:800
void createRotThermElasticInteractGrp(const RotThermElasticPrmsPy &prms)
Definition: LsmMpiPy.cpp:557
void createParticleVectorFieldSaver(const ParticleVectorFieldSaverPrmsPy &)
Definition: LsmMpiPy.cpp:1087
void createLocalDamping(const LocalDampingPrmsPy &prms)
Definition: LsmMpiPy.cpp:572
void createCheckedInteractionScalarFieldSaver(const CheckedInteractionScalarFieldSaverPrmsPy &prms)
Definition: LsmMpiPy.cpp:1130
void createExclusion(const std::string &interactionName1, const std::string &interactionName2)
Definition: LsmMpiPy.cpp:673
void createBuoyancy(const BuoyancyPrmsPy &)
Definition: LsmMpiPy.cpp:598
wrapper for CHertzianViscoElasticFrictionIGP
Definition: InteractionParamsPy.h:206
void createNRotBondedTriMeshInteractGrp(const NRotBondedTriMeshPrmsPy &prms)
Definition: LsmMpiPy.cpp:824
Definition: LatticeMaster.h:117
void readMeshWithTag(const std::string &fileName, const std::string &meshName, int tag)
Definition: LsmMpiPy.cpp:737
std::string getLsmVersion() const
Definition: LsmMpiPy.cpp:266
double getTimeStepSize() const
Definition: LsmMpiPy.cpp:256
void createCappedNRotBondInteractGrp(const CappedNRotBondPrmsPy &bondPrms)
Definition: LsmMpiPy.cpp:428
void getCurMinMaxPt(Vec3Py &curMinPt, Vec3Py &curMaxPt)
Definition: LsmMpiPy.cpp:1653
std::vector< MeshNodeData > MeshNodeDataVector
Definition: LatticeMaster.h:123
void createBrittleBeamInteractGrp(const BrittleBeamPrmsPy &bondPrms)
Definition: LsmMpiPy.cpp:496
void checkMpiDimensionsPy(int numWorkerProcesses, const boost::python::list &mpiDimList)
Definition: LsmMpiPy.cpp:185
void createSnapShots(const CheckPointPrmsPy &prms)
Definition: LsmMpiPy.cpp:706
void moveTaggedParticlesBy(int tag, const Vec3Py &displacement)
Definition: LsmMpiPy.cpp:952
void createParticleVectorFieldSaverWithTrigger(const MaxTriggerPrmsPy &, const ParticleVectorFieldSaverPrmsPy &)
Definition: LsmMpiPy.cpp:1352
void removeInteractionGrp(const std::string &)
Definition: LsmMpiPy.cpp:603
Definition: TriangleFieldSaverPrmsPy.h:37
Definition: InteractionFieldSaverPrmsPy.h:78
void setVelocityOfWall(const std::string &, const Vec3Py &)
Definition: LsmMpiPy.cpp:1044
void setParticleNonDynamic(int)
Definition: LsmMpiPy.cpp:1054
ParticleIdPairVector getBondGroupIdPairs(const std::string &groupName)
Definition: LsmMpiPy.cpp:1670
void runTimeStep()
Definition: LsmMpiPy.cpp:887
void addScalarTriangleSaveField(const TriangleScalarFieldSaverPrmsPy &)
Definition: LsmMpiPy.cpp:1316
void initVerletModel(const std::string &particleType, double gridSpacing, double verletDist)
Definition: LsmMpiPy.cpp:224
void createParticle(boost::python::object &particle)
Definition: LsmMpiPy.cpp:332
void createConnections(boost::python::object &iterable)
Definition: LsmMpiPy.cpp:281
void run()
Definition: LsmMpiPy.cpp:892
void SetVerbosityPy(bool)
int getNumWorkerProcesses() const
Definition: LsmMpiPy.cpp:219
void createNRotElasticWall(const NRotElasticWallPrmsPy &prms)
Definition: LsmMpiPy.cpp:990
boost::shared_ptr< Impl > ImplPtr
Definition: LsmMpiPy.h:352
void createTaggedParticleScalarFieldSaver(const TaggedParticleScalarFieldSaverPrmsPy &)
Definition: LsmMpiPy.cpp:1262
void setParticleAngVel(int, const Vec3Py &)
Definition: LsmMpiPy.cpp:1029
BondInteractionGroupPy createRotThermBondInteractGrp(const RotThermBondPrmsPy &bondPrms)
Definition: LsmMpiPy.cpp:486
void createRotFrictionInteractGrp(const RotFrictionPrmsPy &prms)
Definition: LsmMpiPy.cpp:525
Vec3Py getWallPosition(const std::string &)
Definition: LsmMpiPy.cpp:1013
void visitRefStressPairs2d(const std::string &meshName, boost::python::object pyObject)
Definition: LsmMpiPy.cpp:1464
Definition: LsmMpiPy.cpp:60
void createElasticInteractGrpTag(const NRotElasticPrmsPy &prms, int, int, int, int)
Definition: LsmMpiPy.cpp:646
int getNumTimeSteps() const
Definition: LsmMpiPy.cpp:721