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 68 69 70
|
/////////////////////////////////////////////////////////////
// //
// Copyright (c) 2003-2017 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 //
// //
/////////////////////////////////////////////////////////////
#ifndef ESYS_LSMBONDEDTRIMESHPRMSPY_H
#define ESYS_LSMBONDEDTRIMESHPRMSPY_H
//--- Project includes ---
#include "Python/esys/lsm/MeshBuildParamsPy.h"
#include "Model/BTriMeshIP.h"
//--- STL includes ---
#include <string>
//--- Boost includes ---
#include <boost/shared_ptr.hpp>
using std::string;
namespace esys
{
namespace lsm
{
/*!
\class NRotBondedTriMeshPrmsPy
\brief class for bonded TriMesh interactions in python interface
*/
class NRotBondedTriMeshPrmsPy : public BTriMeshIP
{
private:
typedef boost::shared_ptr<MeshTagBuildPrmsPy> TagBuildPrmsPtr;
typedef boost::shared_ptr<MeshGapBuildPrmsPy> GapBuildPrmsPtr;
const TagBuildPrmsPtr m_tagPrmsPtr;
const GapBuildPrmsPtr m_gapPrmsPtr;
public:
NRotBondedTriMeshPrmsPy(
const string &name,
const string &meshName,
double normalK,
double breakDistance,
const MeshTagBuildPrmsPy &buildPrms
);
NRotBondedTriMeshPrmsPy(
const string &name,
const string &meshName,
double normalK,
double breakDistance,
const MeshGapBuildPrmsPy &buildPrms
);
bool haveTagBuildPrms() const {return (m_tagPrmsPtr.get() != NULL);};
bool haveGapBuildPrms() const {return (m_gapPrmsPtr.get() != NULL);};
const MeshTagBuildPrmsPy &getTagBuildPrms() const {return *(m_tagPrmsPtr.get());};
const MeshGapBuildPrmsPy &getGapBuildPrms() const {return *(m_gapPrmsPtr.get());};
};
void exportBondedTriMeshPrms();
} // namespace lsm
} // namespace esys
#endif //ESYS_LSMBONDEDTRIMESHPRMSPY_H
|