Defines interface IParticle.
Abstract base class for Particle, ParticleComposition, ParticleCoreShell, MesoCrystal.
kvector_t position() const
Returns particle position.
A composition of particles at fixed positions.
IFormFactor * createFormFactor() const final
Creates a form factor for this particle.
void addParticle(const IParticle &particle)
std::vector< std::unique_ptr< IParticle > > m_particles
size_t check_index(size_t index) const
size_t nbrParticles() const
Returns number of different particles.
void addParticlePointer(IParticle *p_particle)
For internal use.
ParticleLimits bottomTopZ() const final
Top and bottom z-coordinate.
ParticleComposition * clone() const final
Returns a clone of this ISampleNode object.
std::vector< const INode * > getChildren() const final
Returns a vector of children.
void accept(INodeVisitor *visitor) const final
Calls the INodeVisitor's visit method.
void addParticles(const IParticle &particle, std::vector< kvector_t > positions)
SafePointerVector< IParticle > decompose() const final
Decompose in constituent IParticle objects.
Vertical extension of a particle, specified by bottom and top z coordinate.