28#include "MantidBeamline/ComponentInfo.h"
29#include "MantidBeamline/DetectorInfo.h"
30#include "MantidBeamline/SpectrumInfo.h"
42#include "MantidTypes/SpectrumDefinition.h"
44#include <boost/algorithm/string.hpp>
45#include <boost/lexical_cast.hpp>
46#include <boost/regex.hpp>
115 }
catch (std::exception &) {
120 std::ostringstream out;
123 const auto instName = inst->getName();
124 out <<
"Instrument: ";
125 if (!instName.empty()) {
126 out << instName <<
" (" << inst->getValidFromDate().toFormattedString(
"%Y-%b-%d") <<
" to "
127 << inst->getValidToDate().toFormattedString(
"%Y-%b-%d") <<
")";
128 const auto instFilename = inst->getFilename();
129 if (!instFilename.empty()) {
130 out <<
"Instrument from: " << instFilename;
140 for (
auto const &itFilename : paramFileVector) {
141 out <<
"Parameters from: " << itFilename;
147 std::string msgNA =
"not available";
148 if (runStart.empty())
152 out <<
"Run start: " << runStart <<
"\n";
153 out <<
"Run end: " << runEnd <<
"\n";
155 if (this->
sample().hasOrientedLattice()) {
157 out <<
"Sample: a " << std::fixed << std::setprecision(1) << latt.
a() <<
", b " << latt.
b() <<
", c " << latt.
c();
158 out <<
"; alpha " << std::fixed << std::setprecision(0) << latt.
alpha() <<
", beta " << latt.
beta() <<
", gamma "
169 if (numDets != detInfo.
size())
170 throw std::runtime_error(
"ExperimentInfo: size mismatch between "
171 "DetectorInfo and number of detectors in "
186 if (
sptr_instrument != (instr->isParametrized() ? instr->baseInstrument() : instr))
188 if (instr->isParametrized()) {
193 m_parmap = std::make_shared<ParameterMap>(*instr->getParameterMap());
196 m_parmap = std::make_shared<ParameterMap>();
243 RTP() : radius(0.0), haveRadius(false), theta(0.0), phi(0.0) {}
250struct ParameterValue {
252 : info(paramInfo), runData(run) {}
255 if (info.m_logfileID.empty())
256 return boost::lexical_cast<double>(info.m_value);
258 const TimeROI *roi = &runData.getTimeROI();
259 return info.createParamValue(runData.getTimeSeriesProperty<
double>(info.m_logfileID), roi);
262 operator int() {
return boost::lexical_cast<int>(info.m_value); }
264 if (boost::iequals(info.m_value,
"true"))
266 else if (boost::iequals(info.m_value,
"yes"))
282bool isScaleParameter(
const std::string &
name) {
return (
name ==
"scalex" ||
name ==
"scaley"); }
284bool isRedundantPosOrRot(
const std::string &
name) {
286 return (
name.size() == 4) &&
290template <
class T> T getParam(
const std::string ¶mType,
const std::string ¶mValue) {
291 const std::string
name =
"dummy";
293 param->fromString(paramValue);
294 return param->value<T>();
300 if (componentInfo.
hasParent(compIndex)) {
301 const auto parentIndex = componentInfo.
parent(compIndex);
312 if (componentInfo.
hasParent(compIndex)) {
313 const auto parentIndex = componentInfo.
parent(compIndex);
320 const std::string ¶mName,
double factor) {
323 if (paramName ==
"scalex")
341 const auto &runData =
run();
352 const auto instrument = parInstrument->baseInstrument();
353 const auto ¶mInfoFromIDF = instrument->getLogfileCache();
355 std::map<const IComponent *, RTP> rtpParams;
365 for (
const auto &item : paramInfoFromIDF) {
366 const auto &nameComp = item.first;
367 const auto ¶mInfo = item.second;
368 const std::string ¶mN = nameComp.first;
374 if (paramN.compare(1, 9,
"-position") == 0) {
375 auto &rtpValues = rtpParams[paramInfo->m_component];
378 double value = ParameterValue(*paramInfo, runData);
379 if (paramN.compare(0, 1,
"r") == 0) {
380 rtpValues.radius =
value;
381 rtpValues.haveRadius =
true;
382 }
else if (paramN.compare(0, 1,
"t") == 0)
383 rtpValues.theta =
value;
384 else if (paramN.compare(0, 1,
"p") == 0)
385 rtpValues.phi =
value;
386 if (rtpValues.haveRadius) {
388 pos.
spherical(rtpValues.radius, rtpValues.theta, rtpValues.phi);
394 }
catch (std::exception &exc) {
395 g_log.
information() <<
"Unable to add component parameter '" << nameComp.first <<
"'. Error: " << exc.what();
399 for (
const auto &item : paramMapForPosAndRot) {
400 if (isPositionParameter(item.second->name())) {
401 const auto newRelPos = item.second->value<
V3D>();
402 updatePosition(compInfo, item.first, newRelPos);
403 }
else if (isRotationParameter(item.second->name())) {
404 const auto newRelRot = item.second->value<
Quat>();
405 updateRotation(compInfo, item.first, newRelRot);
412 for (
const auto &item : paramMap) {
413 if (isScaleParameter(item.second->name()))
414 adjustPositionsFromScaleFactor(compInfo, item.first, item.second->name(), item.second->value<
double>());
446 SpectrumDefinition specDef;
447 for (
const auto detID : detIDs) {
450 specDef.add(detIndex);
451 }
catch (std::out_of_range &) {
467 throw std::runtime_error(
"ExperimentInfo::updateCachedDetectorGrouping: "
468 "Cannot update -- grouping information not "
505 return m_run.access();
536 if (logName.empty()) {
537 throw std::invalid_argument(
"ExperimentInfo::getLog - No instrument parameter named \"" + log +
538 "\". Cannot access full log name");
561 if (logName.empty()) {
562 throw std::invalid_argument(
"ExperimentInfo::getLog - No instrument parameter named \"" + log +
563 "\". Cannot access full log name");
574 const Run &thisRun =
run();
603 static const char *emodeTag =
"deltaE-mode";
604 std::string emodeStr;
605 if (
run().hasProperty(emodeTag)) {
609 emodeStr = param->asString();
644 const std::vector<std::string> ¶meterNames)
const {
646 for (
auto ¶meterName : parameterNames) {
649 efixed = par->value<
double>();
651 std::vector<double> efixedVec = detector->getNumberParameter(parameterName);
652 if (efixedVec.empty()) {
653 int detid = detector->getID();
655 efixedVec = detectorSingle->getNumberParameter(parameterName);
657 if (!efixedVec.empty()) {
663 std::ostringstream os;
664 os <<
"ExperimentInfo::getEFixed - Indirect mode efixed requested but "
665 "detector has no Efixed parameter attached. ID="
666 << detector->getID();
667 throw std::runtime_error(os.str());
683 for (
auto ¶meterName : {
"Ei",
"EnergyRequested",
"EnergyEstimate"}) {
690 throw std::runtime_error(
"Experiment logs do not contain an Ei "
691 "value. Have you run GetEi?");
696 throw std::runtime_error(
"ExperimentInfo::getEFixed - Indirect mode "
697 "efixed requested without a valid detector.");
700 throw std::runtime_error(
"ExperimentInfo::getEFixed - EFixed requested for "
701 "elastic mode, don't know what to do!");
709 pmap.addDouble(det.get(),
"Efixed",
value);
725 }
catch (std::runtime_error &) {
728 date = Types::Core::DateAndTime::getCurrentTime().toISO8601String();
744 }
catch (std::runtime_error &) {
761 }
catch (std::runtime_error &) {
782 return m_parmap->mutableDetectorInfo();
819 [](
char i) { return i == 1; })) {
822 [](
char i) { return i == 1; })) {
824#pragma omp parallel for
825 for (int64_t i = 0; i < size; ++i) {
845 if (spectrumDefinitions) {
846 m_spectrumInfo = std::make_unique<Beamline::SpectrumInfo>(std::move(spectrumDefinitions));
883 size_t specIndex = 0;
884 for (
const auto detID : detIDs) {
887 SpectrumDefinition specDef;
888 specDef.add(detIndex);
889 m_spectrumInfo->setSpectrumDefinition(specIndex, std::move(specDef));
907 if (saveLegacyInstrument) {
908 instrument->saveNexus(file,
"instrument");
921 bool saveLogs)
const {
925 instrument->saveNexus(file,
"instrument");
939 if (sampleVersion == 0) {
942 file->openGroup(
"sample",
"NXsample");
957 if (sampleVersion == 0) {
960 file->openGroup(
"sample",
"NXsample");
970 std::string ¶meterStr,
const std::string &prefix) {
987 std::string ¶meterStr) {
1005 std::string ¶meterStr) {
1008 file->openGroup(
"instrument",
"NXinstrument");
1011 std::string instrumentName;
1012 std::string instrumentXml;
1037 file->openGroup(
"instrument",
"NXinstrument");
1040 std::string instrumentName;
1041 std::string instrumentXml;
1058 std::string &instrumentXml) {
1060 file->readData(
"name", instrumentName);
1063 file->openGroup(
"instrument_xml",
"NXnote");
1064 file->readData(
"data", instrumentXml);
1067 g_log.
debug(std::string(
"Unable to load instrument_xml: ") + ex.what());
1081 std::string &instrumentXml) {
1085 std::string instrumentFilename;
1086 if (!instrumentXml.empty()) {
1090 instrumentFilename = nxFilename;
1091 g_log.
debug() <<
"Using instrument IDF XML text contained in nexus file.\n";
1101 if (!instrumentXml.empty() && !instrumentName.empty()) {
1107 if (InstrumentDataService::Instance().doesExist(instrumentNameMangled)) {
1109 instr = InstrumentDataService::Instance().retrieve(instrumentNameMangled);
1119 instr->parseTreeAndCacheBeamline();
1122 InstrumentDataService::Instance().add(instrumentNameMangled, instr);
1138 }
catch (std::exception &e) {
1139 g_log.
error() <<
"Error loading instrument IDF file: " << filename <<
".\n";
1153 file->openGroup(
"instrument_parameter_map",
"NXnote");
1154 file->readData(
"data", parameterStr);
1157 g_log.
debug(std::string(
"Unable to load instrument_parameter_map: ") + ex.what());
1158 g_log.
information(
"Parameter map entry missing from NeXus file. Continuing without it.");
1179 auto iend = splitter.
end();
1182 const std::string visibilityKey =
"visible:";
1184 for (
auto itr = splitter.
begin(); itr != iend; ++itr) {
1186 if (tokens.
count() < 4)
1188 std::string comp_name = tokens[0];
1193 if (comp_name.find(
"detID:") != std::string::npos) {
1194 int detID = std::stoi(comp_name.substr(6));
1197 g_log.
warning() <<
"Cannot find detector " << detID <<
'\n';
1203 g_log.
warning() <<
"Cannot find component " << comp_name <<
'\n';
1210 std::string paramValue = tokens[3];
1211 auto size =
static_cast<int>(tokens.
count());
1212 for (
int i = 4; i < size; i++)
1213 paramValue +=
";" + tokens[i];
1214 const auto ¶mType = tokens[1];
1215 const auto ¶mName = tokens[2];
1216 auto ¶mVisibility = tokens[size - 1];
1217 if (paramVisibility.find(visibilityKey) > paramVisibility.size())
1218 paramVisibility =
"true";
1221 paramVisibility.substr(paramVisibility.find(visibilityKey) + visibilityKey.size(), paramVisibility.size());
1222 paramValue.erase(paramValue.find(visibilityKey) - 1, paramValue.size());
1224 const auto paramDescr = std::string(
"");
1225 if (paramName ==
"masked") {
1226 auto value = getParam<bool>(paramType, paramValue);
1229 const auto componentIndex = compInfo.indexOf(comp->
getComponentID());
1230 if (!compInfo.isDetector(componentIndex)) {
1231 throw std::runtime_error(
"Found masking for a non-detector "
1232 "component. This is not possible");
1238 }
else if (isPositionParameter(paramName)) {
1243 const auto newRelPos = getParam<V3D>(paramType, paramValue);
1244 updatePosition(compInfo, comp, newRelPos);
1245 }
else if (isRotationParameter(paramName)) {
1250 const auto newRelRot = getParam<Quat>(paramType, paramValue);
1251 updateRotation(compInfo, comp, newRelRot);
1252 }
else if (!isRedundantPosOrRot(paramName)) {
1255 if (isScaleParameter(paramName))
1256 adjustPositionsFromScaleFactor(compInfo, comp, paramName, getParam<double>(paramType, paramValue));
1257 pmap.add(paramType, comp, paramName, paramValue, ¶mDescr, paramVisibility);
1275 const std::string &category = paramInfo.
m_type;
1276 ParameterValue paramValue(paramInfo,
1279 const std::string *pDescription =
nullptr;
1282 std::string pVisible =
"true";
1287 if (
name ==
"masked") {
1288 bool value(paramValue);
1294 throw std::runtime_error(
"Found masking for a non-detector component. This is not possible");
1300 }
else if (
name ==
"x" ||
name ==
"y" ||
name ==
"z") {
1302 }
else if (
name ==
"rot" ||
name ==
"rotx" ||
name ==
"roty" ||
name ==
"rotz") {
1305 }
else if (category ==
"fitting") {
1306 std::ostringstream str;
1311 paramMap.
add(
"fitting", paramInfo.
m_component,
name, str.str(), pDescription, pVisible);
1312 }
else if (category ==
"string") {
1314 }
else if (category ==
"bool") {
1316 }
else if (category ==
"int") {
1334IPropertyManager::getValue<Mantid::API::ExperimentInfo_sptr>(
const std::string &
name)
const {
1339 std::string message =
1340 "Attempt to assign property " +
name +
" to incorrect type. Expected shared_ptr<ExperimentInfo>.";
1341 throw std::runtime_error(message);
1347IPropertyManager::getValue<Mantid::API::ExperimentInfo_const_sptr>(
const std::string &
name)
const {
1350 return prop->operator()();
1352 std::string message =
1353 "Attempt to assign property " +
name +
" to incorrect type. Expected const shared_ptr<ExperimentInfo>.";
1354 throw std::runtime_error(message);
double value
The value of the point.
std::map< DeltaEMode::Type, std::string > index
Mantid::Kernel::Quat(ComponentInfo::* rotation)(const size_t) const
This class is shared by a few Workspace types and holds information related to a particular experimen...
void loadEmbeddedInstrumentInfoNexus(Nexus::File *file, std::string &instrumentName, std::string &instrumentXml)
Attempt to load instrument embedded in Nexus file. *file must have instrument group open.
Geometry::DetectorInfo & mutableDetectorInfo()
Return a non-const reference to the DetectorInfo object.
Run & mutableRun()
Writable version of the run object.
Kernel::cow_ptr< Sample > m_sample
The information on the sample environment.
const SpectrumInfo & spectrumInfo() const
Return a reference to the SpectrumInfo object.
std::shared_ptr< Geometry::ParameterMap > m_parmap
Parameters modifying the base instrument.
ExperimentInfo()
Default constructor.
void setInstumentFromXML(const std::string &nxFilename, std::string &instrumentName, std::string &instrumentXml)
Set the instrument given the name and XML leading from IDF file if XML string is empty.
Geometry::ComponentInfo & mutableComponentInfo()
const Geometry::DetectorInfo & detectorInfo() const
Return a const reference to the DetectorInfo object.
virtual ExperimentInfo * cloneExperimentInfo() const
Clone us.
std::unordered_map< detid_t, size_t > m_det2group
Detector grouping information.
double getEFixed(const detid_t detID) const
Easy access to the efixed value for this run & detector ID.
void readParameterMap(const std::string ¶meterStr)
Populate the parameter map given a string.
virtual void populateIfNotLoaded() const
Called as the first operation of most public methods.
void invalidateSpectrumDefinition(const size_t index)
Notifies the ExperimentInfo that a spectrum definition has changed.
void saveExperimentInfoNexus(Nexus::File *file, bool saveLegacyInstrument=true) const
Saves this experiment description to the open NeXus file.
size_t numberOfDetectorGroups() const
Returns the number of detector groups.
void updateSpectrumDefinitionIfNecessary(const size_t index) const
std::string getAvailableWorkspaceStartDate() const
Return workspace start date as a formatted string (strftime, as returned by Types::Core::DateAndTime)...
std::string loadInstrumentXML(const std::string &filename)
Loads the contents of a file and returns the string The file is assumed to be an IDF,...
virtual ~ExperimentInfo()
Virtual destructor.
virtual void updateCachedDetectorGrouping(const size_t index) const
Update detector grouping for spectrum with given index.
void cacheDefaultDetectorGrouping() const
Sets up a default detector grouping.
std::mutex m_spectrumInfoMutex
void copyExperimentInfoFrom(const ExperimentInfo *other)
Copy everything from the given experiment object.
const Run & run() const
Run details object access.
void loadSampleAndLogInfoNexus(Nexus::File *file, std::string const &prefix)
Load the sample and log info from an open NeXus file.
const Geometry::ParameterMap & constInstrumentParameters() const
Const version.
Geometry::Instrument_const_sptr getInstrument() const
Returns the parameterized instrument.
Kernel::DeltaEMode::Type getEMode() const
Returns the emode for this run.
std::unique_ptr< Beamline::SpectrumInfo > m_spectrumInfo
void loadExperimentInfoNexus(std::string const &nxFilename, Nexus::File *file, std::string ¶meterStr, std::string const &prefix)
const Sample & sample() const
Sample accessors.
void setEFixed(const detid_t detID, const double value)
Set the efixed value for a given detector ID.
double getEFixedGivenEMode(const std::shared_ptr< const Geometry::IDetector > &detector, const Kernel::DeltaEMode::Type emode) const
Easy access to the efixed value for this run & detector.
double getEFixedForIndirect(const std::shared_ptr< const Geometry::IDetector > &detector, const std::vector< std::string > ¶meterNames) const
const std::string toString() const
Returns a string description of the object.
const Geometry::ParameterMap & instrumentParameters() const
Returns the set of parameters modifying the base instrument (const-version)
int getRunNumber() const
Utility method to get the run number.
std::string getAvailableWorkspaceEndDate() const
Return workspace end date as a formatted string (strftime style, as returned by Kernel::DateAdnTime) ...
const Geometry::ComponentInfo & componentInfo() const
std::string getWorkspaceStartDate() const
Returns the start date for this experiment (or current time if no info available)
void setInstrument(const Geometry::Instrument_const_sptr &instr)
Instrument accessors.
std::unique_ptr< SpectrumInfo > m_spectrumInfoWrapper
void setSharedRun(Kernel::cow_ptr< Run > run)
Set the run object. Use in particular to clear run without copying old run.
void setDetectorGrouping(const size_t index, const std::set< detid_t > &detIDs) const
Sets the detector grouping for the spectrum with the given index.
Kernel::cow_ptr< Run > sharedRun()
Return the cow ptr of the run.
ExperimentInfo & operator=(const ExperimentInfo &)
Implements the copy assignment operator.
void setSpectrumDefinitions(Kernel::cow_ptr< std::vector< SpectrumDefinition > > spectrumDefinitions)
Sets the SpectrumDefinition for all spectra.
void populateWithParameter(Geometry::ParameterMap ¶mMap, Geometry::ParameterMap ¶mMapForPosAndRot, const std::string &name, const Geometry::XMLInstrumentParameter ¶mInfo, const Run &runData)
Fill with given instrument parameter.
std::vector< char > m_spectrumDefinitionNeedsUpdate
double getLogAsSingleValue(const std::string &log) const
Access a single value from a log for this experiment.
SpectrumInfo & mutableSpectrumInfo()
Return a non-const reference to the SpectrumInfo object.
void loadInstrumentParametersNexus(Nexus::File *file, std::string ¶meterStr)
Load instrument parameters from an open Nexus file in Instrument group if found there.
void setNumberOfDetectorGroups(const size_t count) const
Sets the number of detector groups.
Sample & mutableSample()
Writable version of the sample object.
Geometry::Instrument_const_sptr sptr_instrument
The base (unparametrized) instrument.
void loadInstrumentInfoNexus(const std::string &nxFilename, Nexus::File *file, std::string ¶meterStr)
Load the instrument from an open NeXus file.
void populateInstrumentParameters()
Add parameters to the instrument parameter map that are defined in instrument definition file or para...
Kernel::Property * getLog(const std::string &log) const
Access a log for this experiment.
void invalidateAllSpectrumDefinitions()
Sets flags for all spectrum definitions indicating that they need to be updated.
Kernel::cow_ptr< Run > m_run
The run information.
static std::string getInstrumentFilename(const std::string &instrumentName, const std::string &date="")
Get the IDF using the instrument name and date.
const Types::Core::DateAndTime endTime() const
Return the run end time.
bool hasProperty(const std::string &name) const
Does the property exist on the object.
const Types::Core::DateAndTime startTime() const
Return the run start time.
Kernel::Property * getProperty(const std::string &name) const
Returns the named property as a pointer.
double getPropertyAsSingleValue(const std::string &name, Kernel::Math::StatisticType statistic=Kernel::Math::Mean) const
Returns a property as a single double value from its name.
HeldType getPropertyValueAsType(const std::string &name) const
Get the value of a property as the given TYPE.
This class stores information regarding an experimental run as a series of log entries.
void saveNexus(Nexus::File *file, const std::string &group, bool keepOpen=false) const override
Save the run to a NeXus file with a given group name.
void loadNexus(Nexus::File *file, const std::string &group, const std::string &prefix, bool keepOpen=false) override
Load the run from a NeXus file with a given group name.
This class stores information about the sample used in particular run.
int loadNexus(Nexus::File *file, const std::string &group)
Load the object from an open NeXus file.
void saveNexus(Nexus::File *file, const std::string &group) const
Save the object to an open NeXus file.
const Geometry::OrientedLattice & getOrientedLattice() const
Get a reference to the sample's OrientedLattice.
API::SpectrumInfo is an intermediate step towards a SpectrumInfo that is part of Instrument-2....
const Kernel::cow_ptr< std::vector< SpectrumDefinition > > & sharedSpectrumDefinitions() const
std::shared_ptr< const IComponent > getComponentByName(const std::string &cname, int nlevels=0) const override
Returns a pointer to the first component of assembly encountered with the given name.
ComponentInfo : Provides a component centric view on to the instrument.
bool hasParent(const size_t componentIndex) const
void setRotation(size_t componentIndex, const Kernel::Quat &newRotation)
size_t parent(const size_t componentIndex) const
Kernel::Quat rotation(const size_t componentIndex) const
Kernel::V3D position(const size_t componentIndex) const
size_t indexOf(Geometry::IComponent const *id) const
void setPosition(size_t componentIndex, const Kernel::V3D &newPosition)
Geometry::DetectorInfo is an intermediate step towards a DetectorInfo that is part of Instrument-2....
void setMasked(const size_t index, bool masked)
Set the mask flag of the detector with given index. Not thread safe.
size_t indexOf(const detid_t id) const
Returns the index of the detector with the given detector ID.
size_t size() const
Returns the size of the DetectorInfo, i.e., the number of detectors in the instrument.
base class for Geometric IComponent
virtual ComponentID getComponentID() const =0
Returns the ComponentID - a unique identifier of the component.
Creates an instrument data from a XML instrument description file.
std::shared_ptr< Instrument > parseXML(Kernel::ProgressBase *progressReporter)
Parse XML contents.
std::string getMangledName()
Handle used in the singleton constructor for instrument file should append the value file sha-1 check...
std::size_t getNumberDetectors(bool skipMonitors=false) const
std::shared_ptr< const Instrument > baseInstrument() const
Pointer to the 'real' instrument, for parametrized instruments.
IDetector_const_sptr getDetector(const detid_t &detector_id) const
Gets a pointer to the detector from its ID Note that for getting the detector associated with a spect...
Class to implement UB matrix.
static std::shared_ptr< Instrument > createInstrument(const std::shared_ptr< const Instrument > &base, const std::shared_ptr< ParameterMap > &map)
Create a parameterized instrument from the given base and ParameterMap.
static std::shared_ptr< Parameter > create(const std::string &className, const std::string &name, const std::string &visible="true")
Creates an instance of a parameter.
const std::vector< std::string > & getParameterFilenames() const
Returns a list of all the parameter files loaded.
bool contains(const IComponent *comp, const std::string &name, const std::string &type="") const
Does the named parameter exist for the given component and type (std::string version)
void addInt(const IComponent *comp, const std::string &name, const std::string &value, const std::string *const pDescription=nullptr, const std::string &pVisible="true")
Adds an int value to the parameter map.
void addPositionCoordinate(const IComponent *comp, const std::string &name, const double value, const std::string *const pDescription=nullptr)
Create or adjust "pos" parameter for a component.
std::shared_ptr< Parameter > getRecursive(const IComponent *comp, const std::string &name, const std::string &type="") const
Use get() recursively to see if can find param in all parents of comp and given type (std::string ver...
static const std::string & rot()
std::string getString(const IComponent *comp, const std::string &name, bool recursive=false) const
Return the value of a parameter as a string.
void addString(const IComponent *comp, const std::string &name, const std::string &value, const std::string *const pDescription=nullptr, const std::string &pVisible="true")
Adds a std::string value to the parameter map.
void addDouble(const IComponent *comp, const std::string &name, const std::string &value, const std::string *const pDescription=nullptr, const std::string &pVisible="true")
Adds a double value to the parameter map.
static const std::string & pos()
Return string to be used in the map.
void addRotationParam(const IComponent *comp, const std::string &name, const double deg, const std::string *const pDescription=nullptr)
Create or adjust "rot" parameter for a component.
void add(const std::string &type, const IComponent *comp, const std::string &name, const std::string &value, const std::string *const pDescription=nullptr, const std::string &visible="true")
Method for adding a parameter providing its value as a string.
void addV3D(const IComponent *comp, const std::string &name, const std::string &value, const std::string *const pDescription=nullptr)
Adds a Kernel::V3D value to the parameter map.
void addBool(const IComponent *comp, const std::string &name, const std::string &value, const std::string *const pDescription=nullptr, const std::string &pVisible="true")
Adds a bool value to the parameter map.
std::shared_ptr< Parameter > get(const IComponent *comp, const std::string &name, const std::string &type="") const
Get a parameter with a given name and type (std::string version)
double alpha() const
Get lattice parameter.
double a(int nd) const
Get lattice parameter a1-a3 as function of index (0-2)
double c() const
Get lattice parameter.
double beta() const
Get lattice parameter.
double b() const
Get lattice parameter.
double gamma() const
Get lattice parameter.
This class is used to store information about parameters in XML instrument definition files and instr...
const Geometry::IComponent * m_component
value from the log value
const std::string m_value
rather then extracting value from logfile,
const std::string m_type
type of the data, e.g. int, double or string
const std::string m_description
if present, contains help string, describing the parameter
const std::string m_visible
if present, describes whether the parameter shall be visible in InstrumentViewer
std::shared_ptr< Kernel::Interpolation > m_interpolation
evaluating the formula
const std::string m_fittingFunction
specific to fitting parameter
std::string m_penaltyFactor
parameter specify lower and upper bound in that order
const std::string m_formula
specify fitting function
const std::string m_resultUnit
expected result (output) unit from
const std::vector< std::string > m_constraint
specific to fitting
const std::string m_tie
specific to fitting parameter specify any tie
const std::string m_formulaUnit
formula to use for setting this parameter
Exception for when an item is not found in a collection.
The Logger class is in charge of the publishing messages from the framework through various channels.
void debug(const std::string &msg)
Logs at debug level.
void error(const std::string &msg)
Logs at error level.
void warning(const std::string &msg)
Logs at warning level.
void information(const std::string &msg)
Logs at information level.
The concrete, templated class for properties.
Base class for properties.
virtual std::string value() const =0
Returns the value of the property as a string.
void rotate(V3D &) const
Rotate a vector.
Iterator begin()
Iterator referring to first element in the container.
@ TOK_IGNORE_EMPTY
ignore empty tokens
@ TOK_TRIM
remove leading and trailing whitespace from tokens
Iterator end()
Iterator referring to the past-the-end element in the container.
std::size_t count() const
Get the total number of tokens.
TimeROI : Object that holds information about when the time measurement was active.
void spherical(const double R, const double theta, const double phi) noexcept
Sets the vector position based on spherical coordinates.
Implements a copy on write data template.
Class that provides for a standard Nexus exception.
std::shared_ptr< const ExperimentInfo > ExperimentInfo_const_sptr
Shared pointer to const ExperimentInfo.
Kernel::Logger g_log("ExperimentInfo")
static logger object
std::shared_ptr< ExperimentInfo > ExperimentInfo_sptr
Shared pointer to ExperimentInfo.
MANTID_API_DLL void applyRectangularDetectorScaleToComponentInfo(Geometry::ComponentInfo &componentInfo, Geometry::IComponent *componentId, const double scaleX, const double scaleY)
Helpers for resizing RectangularDetectors.
std::shared_ptr< Parameter > Parameter_sptr
Typedef for the shared pointer.
std::shared_ptr< const Mantid::Geometry::IDetector > IDetector_const_sptr
Shared pointer to IDetector (const version)
std::shared_ptr< const Instrument > Instrument_const_sptr
Shared pointer to an const instrument object.
std::shared_ptr< Instrument > Instrument_sptr
Shared pointer to an instrument object.
MANTID_KERNEL_DLL std::string strip(const std::string &A)
strip pre/post spaces
MANTID_KERNEL_DLL std::string loadFile(const std::string &filename)
Loads the entire contents of a text file into a string.
int convert(const std::string &A, T &out)
Convert a string into a number.
int32_t detid_t
Typedef for a detector ID.
Generate a tableworkspace to store the calibration results.
static Type fromString(const std::string &modeStr)
Returns the emode from the given string.
Type
Define the available energy transfer modes It is important to assign enums proper numbers,...