BornAgain  1.19.79
Open-source research software to simulate and fit neutron and x-ray reflectometry and grazing-incidence small-angle scattering
IFootprintFactor.h
Go to the documentation of this file.
1 // ************************************************************************************************
2 //
3 // BornAgain: simulate and fit reflection and scattering
4 //
5 //! @file Device/Beam/IFootprintFactor.h
6 //! @brief Defines interface IFootprintFactor.
7 //!
8 //! @homepage http://www.bornagainproject.org
9 //! @license GNU General Public License v3 or higher (see COPYING)
10 //! @copyright Forschungszentrum Jülich GmbH 2018
11 //! @authors Scientific Computing Group at MLZ (see CITATION, AUTHORS)
12 //
13 // ************************************************************************************************
14 
15 #ifndef BORNAGAIN_DEVICE_BEAM_IFOOTPRINTFACTOR_H
16 #define BORNAGAIN_DEVICE_BEAM_IFOOTPRINTFACTOR_H
17 
18 #include "Base/Types/ICloneable.h"
19 #include "Param/Node/INode.h"
20 
21 class MultiLayer;
22 class Beam;
23 
24 //! Abstract base for classes that calculate the beam footprint factor
25 //! @ingroup beam
26 
27 class IFootprintFactor : public ICloneable, public INode {
28 public:
29  IFootprintFactor(const std::vector<double>& PValues);
30  ~IFootprintFactor() override;
31 
32  IFootprintFactor* clone() const override = 0;
33 
34  double widthRatio() const { return m_width_ratio; }
35 
36  //! Calculate footprint correction coefficient from the beam incident angle _alpha_.
37  virtual double calculate(double alpha) const = 0;
38 
39  virtual std::string name() const = 0;
40 
41 protected:
42  const double& m_width_ratio; //! Beam to sample width ratio
43 
44 private:
45  void initialize();
46 };
47 
48 #endif // BORNAGAIN_DEVICE_BEAM_IFOOTPRINTFACTOR_H
Defines and implements the standard mix-in ICloneable.
Defines interface INode.
An incident neutron or x-ray beam.
Definition: Beam.h:28
Interface for polymorphic classes that should not be copied, except by explicit cloning.
Definition: ICloneable.h:23
Abstract base for classes that calculate the beam footprint factor.
IFootprintFactor(const std::vector< double > &PValues)
~IFootprintFactor() override
double widthRatio() const
void initialize()
Beam to sample width ratio.
const double & m_width_ratio
IFootprintFactor * clone() const override=0
virtual std::string name() const =0
virtual double calculate(double alpha) const =0
Calculate footprint correction coefficient from the beam incident angle alpha.
Base class for tree-like structures containing parameterized objects.
Definition: INode.h:40
Our sample model: a stack of layers one below the other.
Definition: MultiLayer.h:43