Mantid
Loading...
Searching...
No Matches
DiffRotDiscreteCircle.cpp
Go to the documentation of this file.
1// Mantid Repository : https://github.com/mantidproject/mantid
2//
3// Copyright © 2018 ISIS Rutherford Appleton Laboratory UKRI,
4// NScD Oak Ridge National Laboratory, European Spallation Source,
5// Institut Laue - Langevin & CSNS, Institute of High Energy Physics, CAS
6// SPDX - License - Identifier: GPL - 3.0 +
7// Mantid Coding standards <http://www.mantidproject.org/Coding_Standards>
8// Main Module Header
10// Mantid Headers from the same project
13// Mantid headers from other projects
15#include "MantidAPI/IFunction.h"
17// 3rd party library headers (N/A)
18// standard library headers (N/A)
19
20namespace {
21Mantid::Kernel::Logger g_log("DiffRotDiscreteCircle");
22}
23
25
26DECLARE_FUNCTION(DiffRotDiscreteCircle)
27
28
33void DiffRotDiscreteCircle::trickleDownAttribute(const std::string &name) {
34 for (size_t iFun = 0; iFun < nFunctions(); iFun++) {
35 API::IFunction_sptr fun = this->getFunction(iFun);
36 if (fun->hasAttribute(name))
37 fun->setAttribute(name, this->getAttribute(name));
38 }
39}
40
44void DiffRotDiscreteCircle::declareAttribute(const std::string &name, const API::IFunction::Attribute &defaultValue) {
46 this->trickleDownAttribute(name);
47}
48
52void DiffRotDiscreteCircle::setAttribute(const std::string &name, const Attribute &att) {
54 this->trickleDownAttribute(name);
55}
56
61 m_elastic = std::dynamic_pointer_cast<ElasticDiffRotDiscreteCircle>(
62 API::FunctionFactory::Instance().createFunction("ElasticDiffRotDiscreteCircle"));
64 m_inelastic = std::dynamic_pointer_cast<InelasticDiffRotDiscreteCircle>(
65 API::FunctionFactory::Instance().createFunction("InelasticDiffRotDiscreteCircle"));
67
68 this->setAttributeValue("NumDeriv", true);
69
72
73 // Set the ties between Elastic and Inelastic parameters
74 this->addDefaultTies("f0.Height=f1.Intensity,f0.Radius=f1.Radius");
75 this->applyTies();
76}
77
78} // namespace Mantid::CurveFitting::Functions
#define DECLARE_FUNCTION(classname)
Macro for declaring a new type of function to be used with the FunctionFactory.
void declareAttribute(const std::string &name, const API::IFunction::Attribute &defaultValue)
Declare a single attribute.
void setAttribute(const std::string &name, const API::IFunction::Attribute &value) override
Set a value of a named attribute.
void applyTies() override
Apply the ties.
Attribute is a non-fitting parameter.
Definition: IFunction.h:282
void setAttributeValue(const std::string &attName, const T &value)
Set an attribute value.
Definition: IFunction.h:597
void addDefaultTies(const std::string &ties)
Add default ties.
void addFunction(IFunction *fun)
Overload addFunction to take a bare pointer.
void setAttribute(const std::string &name, const API::IFunction::Attribute &att) override
Override parent definition.
virtual void declareAttribute(const std::string &name, const API::IFunction::Attribute &defaultValue)
Override parent definition.
std::shared_ptr< ElasticDiffRotDiscreteCircle > m_elastic
std::shared_ptr< InelasticDiffRotDiscreteCircle > m_inelastic
std::string name() const override
Returns the function's name.
void init() override
Initialize elastic and inelastic parts, aliases, attributes, and ties.
virtual void trickleDownAttribute(const std::string &name)
Propagate an attribute to member functions.
The Logger class is in charge of the publishing messages from the framework through various channels.
Definition: Logger.h:52
static T & Instance()
Return a reference to the Singleton instance, creating it if it does not already exist Creation is do...
Kernel::Logger g_log("ExperimentInfo")
static logger object
std::shared_ptr< IFunction > IFunction_sptr
shared pointer to the function base class
Definition: IFunction.h:732
STL namespace.