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 "
187 if (
sptr_instrument != (instr->isParametrized() ? instr->baseInstrument() : instr))
189 if (instr->isParametrized()) {
194 m_parmap = std::make_shared<ParameterMap>(*instr->getParameterMap());
197 m_parmap = std::make_shared<ParameterMap>();
244 RTP() : radius(0.0), haveRadius(false), theta(0.0), phi(0.0) {}
251struct ParameterValue {
253 : info(paramInfo), runData(run) {}
256 if (info.m_logfileID.empty())
257 return boost::lexical_cast<double>(info.m_value);
259 const TimeROI *roi = &runData.getTimeROI();
260 return info.createParamValue(runData.getTimeSeriesProperty<
double>(info.m_logfileID), roi);
263 operator int() {
return boost::lexical_cast<int>(info.m_value); }
265 if (boost::iequals(info.m_value,
"true"))
267 else if (boost::iequals(info.m_value,
"yes"))
283bool isScaleParameter(
const std::string &
name) {
return (
name ==
"scalex" ||
name ==
"scaley"); }
285bool isRedundantPosOrRot(
const std::string &
name) {
287 return (
name.size() == 4) &&
291template <
class T> T getParam(
const std::string ¶mType,
const std::string ¶mValue) {
292 const std::string
name =
"dummy";
294 param->fromString(paramValue);
295 return param->value<T>();
301 if (componentInfo.
hasParent(compIndex)) {
302 const auto parentIndex = componentInfo.
parent(compIndex);
313 if (componentInfo.
hasParent(compIndex)) {
314 const auto parentIndex = componentInfo.
parent(compIndex);
321 const std::string ¶mName,
double factor) {
324 if (paramName ==
"scalex")
342 const auto &runData =
run();
353 const auto instrument = parInstrument->baseInstrument();
354 const auto ¶mInfoFromIDF = instrument->getLogfileCache();
356 std::map<const IComponent *, RTP> rtpParams;
366 for (
const auto &item : paramInfoFromIDF) {
367 const auto &nameComp = item.first;
368 const auto ¶mInfo = item.second;
369 const std::string ¶mN = nameComp.first;
375 if (paramN.compare(1, 9,
"-position") == 0) {
376 auto &rtpValues = rtpParams[paramInfo->m_component];
379 double value = ParameterValue(*paramInfo, runData);
380 if (paramN.compare(0, 1,
"r") == 0) {
381 rtpValues.radius =
value;
382 rtpValues.haveRadius =
true;
383 }
else if (paramN.compare(0, 1,
"t") == 0)
384 rtpValues.theta =
value;
385 else if (paramN.compare(0, 1,
"p") == 0)
386 rtpValues.phi =
value;
387 if (rtpValues.haveRadius) {
389 pos.
spherical(rtpValues.radius, rtpValues.theta, rtpValues.phi);
395 }
catch (std::exception &exc) {
396 g_log.
information() <<
"Unable to add component parameter '" << nameComp.first <<
"'. Error: " << exc.what();
400 for (
const auto &item : paramMapForPosAndRot) {
401 if (isPositionParameter(item.second->name())) {
402 const auto newRelPos = item.second->value<
V3D>();
403 updatePosition(compInfo, item.first, newRelPos);
404 }
else if (isRotationParameter(item.second->name())) {
405 const auto newRelRot = item.second->value<
Quat>();
406 updateRotation(compInfo, item.first, newRelRot);
413 for (
const auto &item : paramMap) {
414 if (isScaleParameter(item.second->name()))
415 adjustPositionsFromScaleFactor(compInfo, item.first, item.second->name(), item.second->value<
double>());
447 SpectrumDefinition specDef;
448 for (
const auto detID : detIDs) {
451 specDef.add(detIndex);
452 }
catch (std::out_of_range &) {
468 throw std::runtime_error(
"ExperimentInfo::updateCachedDetectorGrouping: "
469 "Cannot update -- grouping information not "
506 return m_run.access();
537 if (logName.empty()) {
538 throw std::invalid_argument(
"ExperimentInfo::getLog - No instrument parameter named \"" + log +
539 "\". Cannot access full log name");
562 if (logName.empty()) {
563 throw std::invalid_argument(
"ExperimentInfo::getLog - No instrument parameter named \"" + log +
564 "\". Cannot access full log name");
575 const Run &thisRun =
run();
604 static const char *emodeTag =
"deltaE-mode";
605 std::string emodeStr;
606 if (
run().hasProperty(emodeTag)) {
610 emodeStr = param->asString();
645 const std::vector<std::string> ¶meterNames)
const {
647 for (
auto ¶meterName : parameterNames) {
650 efixed = par->value<
double>();
652 std::vector<double> efixedVec = detector->getNumberParameter(parameterName);
653 if (efixedVec.empty()) {
654 int detid = detector->getID();
656 efixedVec = detectorSingle->getNumberParameter(parameterName);
658 if (!efixedVec.empty()) {
664 std::ostringstream os;
665 os <<
"ExperimentInfo::getEFixed - Indirect mode efixed requested but "
666 "detector has no Efixed parameter attached. ID="
667 << detector->getID();
668 throw std::runtime_error(os.str());
684 for (
auto ¶meterName : {
"Ei",
"EnergyRequested",
"EnergyEstimate"}) {
691 throw std::runtime_error(
"Experiment logs do not contain an Ei "
692 "value. Have you run GetEi?");
697 throw std::runtime_error(
"ExperimentInfo::getEFixed - Indirect mode "
698 "efixed requested without a valid detector.");
701 throw std::runtime_error(
"ExperimentInfo::getEFixed - EFixed requested for "
702 "elastic mode, don't know what to do!");
710 pmap.addDouble(det.get(),
"Efixed",
value);
726 }
catch (std::runtime_error &) {
729 date = Types::Core::DateAndTime::getCurrentTime().toISO8601String();
745 }
catch (std::runtime_error &) {
762 }
catch (std::runtime_error &) {
783 return m_parmap->mutableDetectorInfo();
820 [](
char i) { return i == 1; })) {
823 [](
char i) { return i == 1; })) {
825#pragma omp parallel for
826 for (int64_t i = 0; i < size; ++i) {
846 if (spectrumDefinitions) {
847 m_spectrumInfo = std::make_unique<Beamline::SpectrumInfo>(std::move(spectrumDefinitions));
884 size_t specIndex = 0;
885 for (
const auto detID : detIDs) {
888 SpectrumDefinition specDef;
889 specDef.add(detIndex);
890 m_spectrumInfo->setSpectrumDefinition(specIndex, std::move(specDef));
908 if (saveLegacyInstrument) {
909 instrument->saveNexus(file,
"instrument");
922 bool saveLogs)
const {
926 instrument->saveNexus(file,
"instrument");
940 if (sampleVersion == 0) {
943 file->openGroup(
"sample",
"NXsample");
958 if (sampleVersion == 0) {
961 file->openGroup(
"sample",
"NXsample");
971 std::string ¶meterStr,
const std::string &prefix) {
988 std::string ¶meterStr) {
1006 std::string ¶meterStr) {
1009 file->openGroup(
"instrument",
"NXinstrument");
1012 std::string instrumentName;
1013 std::string instrumentXml;
1038 file->openGroup(
"instrument",
"NXinstrument");
1041 std::string instrumentName;
1042 std::string instrumentXml;
1059 std::string &instrumentXml) {
1061 file->readData(
"name", instrumentName);
1064 file->openGroup(
"instrument_xml",
"NXnote");
1065 file->readData(
"data", instrumentXml);
1068 g_log.
debug(std::string(
"Unable to load instrument_xml: ") + ex.what());
1082 std::string &instrumentXml) {
1086 std::string instrumentFilename;
1087 if (!instrumentXml.empty()) {
1091 instrumentFilename = nxFilename;
1092 g_log.
debug() <<
"Using instrument IDF XML text contained in nexus file.\n";
1102 if (!instrumentXml.empty() && !instrumentName.empty()) {
1108 if (InstrumentDataService::Instance().doesExist(instrumentNameMangled)) {
1110 instr = InstrumentDataService::Instance().retrieve(instrumentNameMangled);
1120 instr->parseTreeAndCacheBeamline();
1123 InstrumentDataService::Instance().add(instrumentNameMangled, instr);
1139 }
catch (std::exception &e) {
1140 g_log.
error() <<
"Error loading instrument IDF file: " << filename <<
".\n";
1154 file->openGroup(
"instrument_parameter_map",
"NXnote");
1155 file->readData(
"data", parameterStr);
1158 g_log.
debug(std::string(
"Unable to load instrument_parameter_map: ") + ex.what());
1159 g_log.
information(
"Parameter map entry missing from NeXus file. Continuing without it.");
1180 auto iend = splitter.
end();
1183 const std::string visibilityKey =
"visible:";
1185 for (
auto itr = splitter.
begin(); itr != iend; ++itr) {
1187 if (tokens.
count() < 4)
1189 std::string comp_name = tokens[0];
1194 if (comp_name.find(
"detID:") != std::string::npos) {
1195 int detID = std::stoi(comp_name.substr(6));
1198 g_log.
warning() <<
"Cannot find detector " << detID <<
'\n';
1204 g_log.
warning() <<
"Cannot find component " << comp_name <<
'\n';
1211 std::string paramValue = tokens[3];
1212 auto size =
static_cast<int>(tokens.
count());
1213 for (
int i = 4; i < size; i++)
1214 paramValue +=
";" + tokens[i];
1215 const auto ¶mType = tokens[1];
1216 const auto ¶mName = tokens[2];
1217 auto ¶mVisibility = tokens[size - 1];
1218 if (paramVisibility.find(visibilityKey) > paramVisibility.size())
1219 paramVisibility =
"true";
1222 paramVisibility.substr(paramVisibility.find(visibilityKey) + visibilityKey.size(), paramVisibility.size());
1223 paramValue.erase(paramValue.find(visibilityKey) - 1, paramValue.size());
1225 const auto paramDescr = std::string(
"");
1226 if (paramName ==
"masked") {
1227 auto value = getParam<bool>(paramType, paramValue);
1230 const auto componentIndex = compInfo.indexOf(comp->
getComponentID());
1231 if (!compInfo.isDetector(componentIndex)) {
1232 throw std::runtime_error(
"Found masking for a non-detector "
1233 "component. This is not possible");
1239 }
else if (isPositionParameter(paramName)) {
1244 const auto newRelPos = getParam<V3D>(paramType, paramValue);
1245 updatePosition(compInfo, comp, newRelPos);
1246 }
else if (isRotationParameter(paramName)) {
1251 const auto newRelRot = getParam<Quat>(paramType, paramValue);
1252 updateRotation(compInfo, comp, newRelRot);
1253 }
else if (!isRedundantPosOrRot(paramName)) {
1256 if (isScaleParameter(paramName))
1257 adjustPositionsFromScaleFactor(compInfo, comp, paramName, getParam<double>(paramType, paramValue));
1258 pmap.add(paramType, comp, paramName, paramValue, ¶mDescr, paramVisibility);
1276 const std::string &category = paramInfo.
m_type;
1277 ParameterValue paramValue(paramInfo,
1280 const std::string *pDescription =
nullptr;
1283 std::string pVisible =
"true";
1288 if (
name ==
"masked") {
1289 bool value(paramValue);
1295 throw std::runtime_error(
"Found masking for a non-detector component. This is not possible");
1301 }
else if (
name ==
"x" ||
name ==
"y" ||
name ==
"z") {
1303 }
else if (
name ==
"rot" ||
name ==
"rotx" ||
name ==
"roty" ||
name ==
"rotz") {
1306 }
else if (category ==
"fitting") {
1307 std::ostringstream str;
1312 paramMap.
add(
"fitting", paramInfo.
m_component,
name, str.str(), pDescription, pVisible);
1313 }
else if (category ==
"string") {
1315 }
else if (category ==
"bool") {
1317 }
else if (category ==
"int") {
1335IPropertyManager::getValue<Mantid::API::ExperimentInfo_sptr>(
const std::string &
name)
const {
1340 std::string message =
1341 "Attempt to assign property " +
name +
" to incorrect type. Expected shared_ptr<ExperimentInfo>.";
1342 throw std::runtime_error(message);
1348IPropertyManager::getValue<Mantid::API::ExperimentInfo_const_sptr>(
const std::string &
name)
const {
1351 return prop->operator()();
1353 std::string message =
1354 "Attempt to assign property " +
name +
" to incorrect type. Expected const shared_ptr<ExperimentInfo>.";
1355 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.
std::string to_string(const wide_integer< Bits, Signed > &n)
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,...