22 unsigned N_2,
unsigned N_3)
43 throw std::runtime_error(
"InterferenceFinite3DLattice::lattice() -> Error. "
44 "No lattice defined.");
50 return std::vector<const INode*>() <<
m_lattice;
56 const double qadiv2 = q.dot(
m_lattice->basisVectorA()) / 2.0;
57 const double qbdiv2 = q.dot(
m_lattice->basisVectorB()) / 2.0;
58 const double qcdiv2 = q.dot(
m_lattice->basisVectorC()) / 2.0;
Defines M_PI and some more mathematical constants.
Defines class InterferenceFinite3DLattice.
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)
void setLattice(const Lattice3D &lattice)
double iff_without_dw(R3 q) const override
Calculates the structure factor without Debye-Waller factor.
std::vector< const INode * > nodeChildren() const override
Returns all children.
std::unique_ptr< Lattice3D > m_lattice
unsigned m_N_3
Size of the finite lattice in lattice units.
A Bravais lattice, characterized by three basis vectors, and optionally an ISelectionRule.
double Laue(double x, size_t N)
Real Laue function: .