15 #ifndef BORNAGAIN_SAMPLE_AGGREGATE_INTERFERENCEFINITE3DLATTICE_H
16 #define BORNAGAIN_SAMPLE_AGGREGATE_INTERFERENCEFINITE3DLATTICE_H
30 std::string
className() const final {
return "InterferenceFinite3DLattice"; }
Defines and implements the interface class IInterference.
Abstract base class of interference functions.
Interference function of a finite 3D lattice.
const Lattice3D & lattice() const
~InterferenceFinite3DLattice() override
InterferenceFinite3DLattice * clone() const override
InterferenceFinite3DLattice(const Lattice3D &lattice, unsigned N_1, unsigned N_2, unsigned N_3)
unsigned numberUnitCells3() const
void setLattice(const Lattice3D &lattice)
double iff_without_dw(R3 q) const override
Calculates the structure factor without Debye-Waller factor.
bool supportsMultilayer() const override
Indicates if this interference function can be used with a sample (DWBA mode)
std::vector< const INode * > nodeChildren() const override
Returns all children.
std::string className() const final
Returns the class name, to be hard-coded in each leaf class that inherits from INode.
std::unique_ptr< Lattice3D > m_lattice
unsigned m_N_3
Size of the finite lattice in lattice units.
unsigned numberUnitCells1() const
unsigned numberUnitCells2() const
A Bravais lattice, characterized by three basis vectors, and optionally an ISelectionRule.