BornAgain  1.19.79
Simulate and fit neutron and x-ray scattering at grazing incidence
DistributionGateItem Class Reference

Description

Definition at line 95 of file DistributionItems.h.

Inheritance diagram for DistributionGateItem:
[legend]
Collaboration diagram for DistributionGateItem:
[legend]

Public Member Functions

 DistributionGateItem ()
 
std::unique_ptr< IDistribution1D > createDistribution (double scale=1.0) const override
 
DoubleDescriptors distributionValues (bool withMean=true) const override
 
 DOUBLE_PROPERTY (maximum, Maximum)
 
 DOUBLE_PROPERTY (minimum, Minimum)
 
 DOUBLE_PROPERTY (sigmaFactor, SigmaFactor)
 
bool hasSigmaFactor () const
 
void initDistribution (double value) override
 
template<typename T >
bool is () const
 
RealLimits limits () const
 
void serialize (Streamer &s)
 Serialization of contents. More...
 
virtual void setLimits (const RealLimits &limits)
 
void setRange (double min, double max)
 
void setUnit (const variant< QString, Unit > &unit) override
 Set the unit of the distributed value. More...
 
 UINT_PROPERTY (numberOfSamples, NumberOfSamples)
 

Protected Member Functions

void addToSerialization (DoubleProperty *d)
 
void initSigmaFactor ()
 

Protected Attributes

RealLimits m_limits
 

Private Attributes

QVector< DoubleProperty * > m_serializationProperties
 

Constructor & Destructor Documentation

◆ DistributionGateItem()

DistributionGateItem::DistributionGateItem ( )

Definition at line 126 of file DistributionItems.cpp.

127 {
128  m_minimum.init("Min", "", 0.0, Unit::unitless, 3, RealLimits::limitless(), "min");
129  m_maximum.init("Max", "", 1.0, Unit::unitless, 3, RealLimits::limitless(), "max");
130 
131  addToSerialization(&m_minimum);
132  addToSerialization(&m_maximum);
133 }
@ unitless
void addToSerialization(DoubleProperty *d)

References DistributionItem::addToSerialization(), and unitless.

Here is the call graph for this function:

Member Function Documentation

◆ addToSerialization()

◆ createDistribution()

std::unique_ptr< IDistribution1D > DistributionGateItem::createDistribution ( double  scale = 1.0) const
overridevirtual

Implements DistributionItem.

Definition at line 141 of file DistributionItems.cpp.

142 {
143  return std::make_unique<DistributionGate>(scale * m_minimum, scale * m_maximum);
144 }

◆ distributionValues()

DoubleDescriptors DistributionGateItem::distributionValues ( bool  withMean = true) const
overridevirtual

Implements DistributionItem.

Definition at line 161 of file DistributionItems.cpp.

162 {
163  return {minimum(), maximum()};
164 }

◆ DOUBLE_PROPERTY() [1/3]

DistributionGateItem::DOUBLE_PROPERTY ( maximum  ,
Maximum   
)

◆ DOUBLE_PROPERTY() [2/3]

DistributionGateItem::DOUBLE_PROPERTY ( minimum  ,
Minimum   
)

◆ DOUBLE_PROPERTY() [3/3]

DistributionItem::DOUBLE_PROPERTY ( sigmaFactor  ,
SigmaFactor   
)
inherited

◆ hasSigmaFactor()

bool DistributionItem::hasSigmaFactor ( ) const
inherited

Definition at line 45 of file DistributionItems.cpp.

46 {
47  return m_sigmaFactor.isInitialized();
48 }

Referenced by DistributionPlot::plot_multiple_values().

◆ initDistribution()

void DistributionGateItem::initDistribution ( double  value)
overridevirtual

Reimplemented from DistributionItem.

Definition at line 146 of file DistributionItems.cpp.

147 {
148  double sigma(0.1 * std::abs(value));
149  if (sigma == 0.0)
150  sigma = 0.1;
151  m_minimum.set(value - sigma);
152  m_maximum.set(value + sigma);
153 }

◆ initSigmaFactor()

void DistributionItem::initSigmaFactor ( )
protectedinherited

Definition at line 34 of file DistributionItems.cpp.

35 {
36  m_sigmaFactor.init("Sigma factor", "", 2.0, Unit::unitless, "sigmaFactor");
37  addToSerialization(&m_sigmaFactor);
38 }

References DistributionItem::addToSerialization(), and unitless.

Referenced by DistributionCosineItem::DistributionCosineItem(), DistributionGaussianItem::DistributionGaussianItem(), DistributionLogNormalItem::DistributionLogNormalItem(), and DistributionLorentzItem::DistributionLorentzItem().

Here is the call graph for this function:

◆ is()

template<typename T >
bool DistributionItem::is ( ) const
inlineinherited

Definition at line 33 of file DistributionItems.h.

34  {
35  return dynamic_cast<const T*>(this) != nullptr;
36  }

Referenced by DistributionPlot::plot_distributions(), DistributionPlot::plot_multiple_values(), and DistributionPlot::plot_single_value().

◆ limits()

RealLimits DistributionItem::limits ( ) const
inherited

◆ serialize()

void DistributionItem::serialize ( Streamer s)
inherited

Serialization of contents.

Important: limits and a changed unit (with setUnit) will not be serialized here. They have to be set again by the owner of DistributionItem after reading it

Definition at line 50 of file DistributionItems.cpp.

51 {
52  s.assertVersion(0);
53  Serialize::rwProperty(s, m_numberOfSamples);
54 
55  for (auto* p : m_serializationProperties)
56  Serialize::rwProperty(s, *p);
57 
58  // m_limits and a changed unit (with setUnit) will not be serialized here. They have to be set
59  // again by the owner of DistributionItem after reading it
60 }
void assertVersion(unsigned expectedVersion) const
As reader, throws DeserializationException unless the expected version is read. As writer,...
Definition: Streamer.cpp:26
void rwProperty(Streamer &s, DoubleProperty &d)

References Streamer::assertVersion(), DistributionItem::m_serializationProperties, and Serialize::rwProperty().

Here is the call graph for this function:

◆ setLimits()

void DistributionItem::setLimits ( const RealLimits &  limits)
virtualinherited

Reimplemented in SymmetricResolutionItem.

Definition at line 29 of file DistributionItems.cpp.

30 {
31  m_limits = limits;
32 }
RealLimits limits() const

References DistributionItem::limits(), and DistributionItem::m_limits.

Referenced by BeamAzimuthalAngleItem::initDistribution(), BeamInclinationAngleItem::initDistribution(), BeamAzimuthalAngleItem::serialize(), BeamInclinationAngleItem::serialize(), BeamWavelengthItem::serialize(), SpecularBeamInclinationItem::serialize(), and SymmetricResolutionItem::setLimits().

Here is the call graph for this function:

◆ setRange()

void DistributionGateItem::setRange ( double  min,
double  max 
)

Definition at line 155 of file DistributionItems.cpp.

156 {
157  m_minimum.set(min);
158  m_maximum.set(max);
159 }

◆ setUnit()

void DistributionGateItem::setUnit ( const variant< QString, Unit > &  unit)
overridevirtual

Set the unit of the distributed value.

Implements DistributionItem.

Definition at line 135 of file DistributionItems.cpp.

136 {
137  m_minimum.setUnit(unit);
138  m_maximum.setUnit(unit);
139 }

◆ UINT_PROPERTY()

DistributionItem::UINT_PROPERTY ( numberOfSamples  ,
NumberOfSamples   
)
inherited

Member Data Documentation

◆ m_limits

◆ m_serializationProperties

QVector<DoubleProperty*> DistributionItem::m_serializationProperties
privateinherited

The documentation for this class was generated from the following files: