ESyS-Particle
4.0.1
|
Abstract base class for random assemblies, to be used for initialization of random lattices. More...
#include <RandomAssembly2D.h>
Public Member Functions | |
virtual void | generate (int, unsigned int)=0 |
virtual void | insertParticle (const SimpleParticle)=0 |
virtual void | tagParticleClosestTo (const Vec3 &, int)=0 |
virtual void | tagEdgeY (int, int, double)=0 |
Protected Member Functions | |
virtual Vec3 | getAPoint ()=0 |
bool | isInSpace (const Vec3 &) |
bool | findAFit (SimpleParticle &, const vector< SimpleParticle > &, const Line &) |
bool | findAFit (SimpleParticle &, const vector< SimpleParticle > &) |
virtual bool | checkAFit (const SimpleParticle &) |
virtual Line * | getClosestPlane (const SimpleParticle &) |
void | fillSpace (int) |
virtual int | getNParts () const =0 |
Protected Attributes | |
vector< Line > | Borders |
double | m_rmin |
double | m_rmax |
min/max particle radius | |
double | m_xmin |
double | m_xmax |
double | m_ymin |
double | m_ymax |
x,y borders of the lattice | |
bool | m_circ_x |
Abstract base class for random assemblies, to be used for initialization of random lattices.
bool ARandomAssembly2D::checkAFit | ( | const SimpleParticle & | Po | ) | [protected, virtual] |
check if Po is within the Space and is not crossing any boundary or overlapping with other particles.
Po | the particle |
Reimplemented in FaultedBlock2D.
References getClosestPlane(), ARandomAssembly::getNeighborList(), m_rmax, and m_ymax.
Referenced by fillSpace(), and CRandomBlock2D::generate().
void ARandomAssembly2D::fillSpace | ( | int | tries | ) | [protected] |
Fill the space in the skeleton after it has been seeded
tries | the number of tries |
References checkAFit(), findAFit(), ARandomAssembly::getClosestNeighbors(), getClosestPlane(), BasicCon::Info(), ARandomAssembly::m_random(), and m_rmax.
Referenced by FaultedBlock2D::generate(), and CRandomBlock2D::generate().
bool ARandomAssembly2D::findAFit | ( | SimpleParticle & | Po, |
const vector< SimpleParticle > & | NL, | ||
const Line & | L | ||
) | [protected] |
Find a fit for a sphere using the list of neigbor list and a plane
Po | the particle to fit |
NL | the list of neighbors |
PL | the Plane |
References Sphere2D::FillInWP().
Referenced by fillSpace().
bool ARandomAssembly2D::findAFit | ( | SimpleParticle & | Po, |
const vector< SimpleParticle > & | NL | ||
) | [protected] |
Find a fit for a sphere using the list of neigbors
Po | the particle to fit |
NL | the list of neighbors |
References Sphere2D::FillIn().
Line * ARandomAssembly2D::getClosestPlane | ( | const SimpleParticle & | Po | ) | [protected, virtual] |
get closest plane to a particle
Po | the particle |
Reimplemented in FaultedBlock2D.
Referenced by checkAFit(), and fillSpace().