23 InterferenceFunctionFinite3DLattice::InterferenceFunctionFinite3DLattice(
const Lattice& lattice,
 
   24                                                                          unsigned N_1, 
unsigned N_2,
 
   28     setName(
"InterferenceFinite3DLattice");
 
   32 InterferenceFunctionFinite3DLattice::~InterferenceFunctionFinite3DLattice() = 
default;
 
   37     ret->setPositionVariance(m_position_var);
 
   41 const Lattice& InterferenceFunctionFinite3DLattice::lattice()
 const 
   44         throw std::runtime_error(
"InterferenceFunctionFinite3DLattice::lattice() -> Error. " 
   45                                  "No lattice defined.");
 
   51     return std::vector<const INode*>() << mP_lattice;
 
   54 double InterferenceFunctionFinite3DLattice::iff_without_dw(
const kvector_t q)
 const 
   57     const double qadiv2 = q.
dot(mP_lattice->getBasisVectorA()) / 2.0;
 
   58     const double qbdiv2 = q.
dot(mP_lattice->getBasisVectorB()) / 2.0;
 
   59     const double qcdiv2 = q.
dot(mP_lattice->getBasisVectorC()) / 2.0;
 
   60     const double ampl = 
Laue(qadiv2, m_N_1) * 
Laue(qbdiv2, m_N_2) * 
Laue(qcdiv2, m_N_3);
 
   61     return ampl * ampl / (m_N_1 * m_N_2 * m_N_3);
 
   64 void InterferenceFunctionFinite3DLattice::setLattice(
const Lattice& lattice)
 
   66     mP_lattice = std::make_unique<Lattice>(lattice);
 
   67     registerChild(mP_lattice.get());
 
Defines many exception classes in namespace Exceptionss.
 
Defines class InterferenceFunctionFinite3DLattice.
 
Defines M_PI and some more mathematical constants.
 
Defines namespace MathFunctions.
 
Defines class RealParameter.
 
auto dot(const BasicVector3D< U > &v) const
Returns dot product of vectors (antilinear in the first [=self] argument).
 
Pure virtual base class of interference functions.
 
Interference function of a finite 3D lattice.
 
std::vector< const INode * > getChildren() const override final
Returns a vector of children (const).
 
InterferenceFunctionFinite3DLattice * clone() const override final
Returns a clone of this ISample object.
 
A lattice with three basis vectors.
 
double Laue(const double x, size_t N)
Real Laue function: .