9#include "MantidAPI/DllConfig.h"
11#include "MantidHistogramData/Histogram.h"
18namespace DataObjects {
44 void copyInfoFrom(
const ISpectrum &other);
71 virtual std::pair<double, double> getXDataRange()
const;
73 void addDetectorID(
const detid_t detID);
74 void addDetectorIDs(
const std::set<detid_t> &detIDs);
75 void addDetectorIDs(
const std::vector<detid_t> &detIDs);
76 void setDetectorID(
const detid_t detID);
77 void setDetectorIDs(
const std::set<detid_t> &detIDs);
78 void setDetectorIDs(std::set<detid_t> &&detIDs);
80 bool hasDetectorID(
const detid_t detID)
const;
81 const std::set<detid_t> &getDetectorIDs()
const;
83 void clearDetectorIDs();
94 virtual HistogramData::Histogram
histogram()
const {
return histogramRef(); }
97 HistogramData::Histogram hist(std::forward<T>(data)...);
100 checkAndSanitizeHistogram(hist);
101 mutableHistogramRef() = std::move(hist);
104 HistogramData::Histogram::YMode
yMode()
const {
return histogramRef().yMode(); }
105 void setYMode(HistogramData::Histogram::YMode ymode) { mutableHistogramRef().setYMode(ymode); }
107 checkIsYAndEWritable();
108 mutableHistogramRef().convertToCounts();
111 checkIsYAndEWritable();
112 mutableHistogramRef().convertToFrequencies();
115 HistogramData::BinEdges
binEdges()
const {
return histogramRef().binEdges(); }
116 HistogramData::Points
points()
const {
return histogramRef().points(); }
118 return histogramRef().pointStandardDeviations();
121 mutableHistogramRef().setBinEdges(std::forward<T>(data)...);
123 template <
typename... T>
void setPoints(T &&...data) & {
125 checkWorksWithPoints();
126 mutableHistogramRef().setPoints(std::forward<T>(data)...);
131 mutableHistogramRef().setPointVariances(std::forward<T>(data)...);
134 mutableHistogramRef().setPointStandardDeviations(std::forward<T>(data)...);
136 virtual HistogramData::Counts
counts()
const {
return histogramRef().counts(); }
137 virtual HistogramData::CountVariances
countVariances()
const {
return histogramRef().countVariances(); }
139 return histogramRef().countStandardDeviations();
141 virtual HistogramData::Frequencies
frequencies()
const {
return histogramRef().frequencies(); }
142 virtual HistogramData::FrequencyVariances
frequencyVariances()
const {
return histogramRef().frequencyVariances(); }
144 return histogramRef().frequencyStandardDeviations();
146 template <
typename... T>
void setCounts(T &&...data) & {
148 checkIsYAndEWritable();
149 mutableHistogramRef().setCounts(std::forward<T>(data)...);
152 checkIsYAndEWritable();
153 mutableHistogramRef().setCountVariances(std::forward<T>(data)...);
156 checkIsYAndEWritable();
157 mutableHistogramRef().setCountStandardDeviations(std::forward<T>(data)...);
160 checkIsYAndEWritable();
161 mutableHistogramRef().setFrequencies(std::forward<T>(data)...);
164 checkIsYAndEWritable();
165 mutableHistogramRef().setFrequencyVariances(std::forward<T>(data)...);
168 checkIsYAndEWritable();
169 mutableHistogramRef().setFrequencyStandardDeviations(std::forward<T>(data)...);
171 const HistogramData::HistogramX &
x()
const {
return histogramRef().x(); }
172 virtual const HistogramData::HistogramY &
y()
const {
return histogramRef().y(); }
173 virtual const HistogramData::HistogramE &
e()
const {
return histogramRef().e(); }
174 const HistogramData::HistogramDx &
dx()
const {
return histogramRef().dx(); }
175 HistogramData::HistogramX &
mutableX() & {
return mutableHistogramRef().mutableX(); }
176 HistogramData::HistogramDx &
mutableDx() & {
return mutableHistogramRef().mutableDx(); }
178 checkIsYAndEWritable();
179 return mutableHistogramRef().mutableY();
182 checkIsYAndEWritable();
183 return mutableHistogramRef().mutableE();
192 checkIsYAndEWritable();
193 mutableHistogramRef().setSharedY(
y);
196 checkIsYAndEWritable();
197 mutableHistogramRef().setSharedE(e);
200 void resize(
size_t n) { mutableHistogramRef().resize(
n); }
201 size_t size()
const {
return histogramRef().size(); }
225 void invalidateCachedSpectrumNumbers()
const;
226 void invalidateSpectrumDefinition()
const;
std::map< DeltaEMode::Type, std::string > index
A "spectrum" is an object that holds the data for a particular spectrum, in particular:
void setHistogram(T &&...data)
Sets the Histogram associated with this spectrum.
virtual HistogramData::FrequencyVariances frequencyVariances() const
void setFrequencyVariances(T &&...data) &
HistogramData::Histogram::YMode yMode() const
virtual HistogramData::FrequencyStandardDeviations frequencyStandardDeviations() const
HistogramData::HistogramY & mutableY() &
HistogramData::Points points() const
virtual const MantidVec & dataX() const =0
const HistogramData::HistogramX & x() const
virtual const HistogramData::HistogramE & e() const
void setSharedDx(const Kernel::cow_ptr< HistogramData::HistogramDx > &dx) &
virtual MantidVec & dataY()=0
virtual const MantidVec & readX() const =0
void setPointStandardDeviations(T &&...data) &
void setCountVariances(T &&...data) &
virtual MantidVec & dataE()=0
std::set< detid_t > detectorIDs
Set of the detector IDs associated with this spectrum.
void setSharedY(const Kernel::cow_ptr< HistogramData::HistogramY > &y) &
void setCountStandardDeviations(T &&...data) &
virtual const MantidVec & dataDx() const =0
virtual HistogramData::Frequencies frequencies() const
void setPointVariances(T &&...data) &
virtual void setX(const Kernel::cow_ptr< HistogramData::HistogramX > &X)=0
void setBinEdges(T &&...data) &
virtual HistogramData::Histogram & mutableHistogramRef()=0
virtual size_t getMemorySize() const =0
const HistogramData::HistogramDx & dx() const
HistogramData::HistogramDx & mutableDx() &
void convertToFrequencies()
virtual void checkWorksWithPoints() const
virtual const MantidVec & readDx() const =0
virtual ~ISpectrum()=default
virtual HistogramData::Histogram histogram() const
Returns the Histogram associated with this spectrum.
virtual HistogramData::Counts counts() const
void setYMode(HistogramData::Histogram::YMode ymode)
Kernel::cow_ptr< HistogramData::HistogramX > sharedX() const
void setFrequencies(T &&...data) &
virtual const HistogramData::HistogramY & y() const
virtual HistogramData::CountStandardDeviations countStandardDeviations() const
void setSharedE(const Kernel::cow_ptr< HistogramData::HistogramE > &e) &
HistogramData::BinEdges binEdges() const
void setCounts(T &&...data) &
virtual MantidVec & dataDx()=0
virtual void clearData()=0
virtual const HistogramData::Histogram & histogramRef() const =0
virtual Kernel::cow_ptr< HistogramData::HistogramY > sharedY() const
virtual Kernel::cow_ptr< HistogramData::HistogramE > sharedE() const
virtual void checkAndSanitizeHistogram(HistogramData::Histogram &)
virtual HistogramData::CountVariances countVariances() const
void setPoints(T &&...data) &
virtual const MantidVec & dataE() const =0
virtual Kernel::cow_ptr< HistogramData::HistogramX > ptrX() const =0
Kernel::cow_ptr< HistogramData::HistogramDx > sharedDx() const
virtual void copyDataFrom(const ISpectrum &source)=0
Copy data from another ISpectrum with double-dynamic dispatch.
void setSharedX(const Kernel::cow_ptr< HistogramData::HistogramX > &x) &
HistogramData::HistogramX & mutableX() &
HistogramData::HistogramE & mutableE() &
void setFrequencyStandardDeviations(T &&...data) &
virtual MantidVec & dataX()=0
virtual void checkIsYAndEWritable() const
virtual const MantidVec & dataY() const =0
HistogramData::PointStandardDeviations pointStandardDeviations() const
Base MatrixWorkspace Abstract Class.
1D histogram implementation.
Implements a copy on write data template.
Helper class that implements ISpectrum.
Helper class which provides the Collimation Length for SANS instruments.
std::vector< double > MantidVec
typedef for the data storage used in Mantid matrix workspaces
int32_t specnum_t
Typedef for a spectrum Number.