27#include "tbb/parallel_for.h"
32using namespace boost::posix_time;
33using Mantid::Types::Core::DateAndTime;
38Kernel::Logger
g_log(
"EventWorkspace");
43using Kernel::Exception::NotImplementedError;
51 for (
const auto &el : other.data) {
53 auto newel = std::make_unique<EventList>(*el);
55 newel->setMRU(this->
mru.get());
56 this->
data.emplace_back(std::move(newel));
80void EventWorkspace::init(
const std::size_t &NVectors,
const std::size_t &XLength,
const std::size_t &YLength) {
81 static_cast<void>(XLength);
82 static_cast<void>(YLength);
86 throw std::out_of_range(
"Zero pixels specified to EventWorkspace::init");
92 HistogramData::BinEdges edges{0.0, std::numeric_limits<double>::min()};
95 data.resize(NVectors);
99 for (
size_t i = 0; i < NVectors; i++) {
100 data[i] = std::make_unique<EventList>(el);
107 m_axes[0] = std::make_unique<API::RefAxis>(
this);
108 m_axes[1] = std::make_unique<API::SpectraAxis>(
this);
112 if (
histogram.xMode() != HistogramData::Histogram::XMode::BinEdges)
113 throw std::runtime_error(
"EventWorkspace can only be initialized with XMode::BinEdges");
116 throw std::runtime_error(
"EventWorkspace cannot be initialized non-NULL Y or E data");
121 for (
size_t i = 0; i <
data.size(); i++) {
122 data[i] = std::make_unique<EventList>(el);
128 m_axes[0] = std::make_unique<API::RefAxis>(
this);
129 m_axes[1] = std::make_unique<API::SpectraAxis>(
this);
136 throw std::runtime_error(
"There are no pixels in the event workspace, "
137 "therefore cannot determine if it is ragged.");
139 const auto numberOfBins =
data[0]->histogram_size();
140 return std::any_of(
data.cbegin(),
data.cend(),
141 [&numberOfBins](
const auto &eventList) { return numberOfBins != eventList->histogram_size(); });
148 return std::accumulate(
149 data.begin(),
data.end(),
static_cast<size_t>(0),
150 [](
size_t value,
const std::unique_ptr<EventList> &histo) { return value + histo->histogram_size(); });
157 throw std::range_error(
"EventWorkspace::blocksize, no pixels in workspace, "
158 "therefore cannot determine blocksize (# of bins).");
160 size_t numBins =
data[0]->histogram_size();
161 const auto iterPos = std::find_if_not(
data.cbegin(),
data.cend(),
162 [numBins](
const auto &iter) { return numBins == iter->histogram_size(); });
163 if (iterPos !=
data.cend())
164 throw std::length_error(
"blocksize undefined because size of histograms is not equal");
177 throw std::invalid_argument(
"Could not find number of bins in a histogram at index " +
std::to_string(
index) +
178 ": index is too large.");
188 auto maxNumberOfBins =
data[0]->histogram_size();
189 for (
const auto &iter :
data) {
190 const auto numberOfBins = iter->histogram_size();
191 if (numberOfBins > maxNumberOfBins)
192 maxNumberOfBins = numberOfBins;
194 return maxNumberOfBins;
214 throw std::range_error(
"EventWorkspace::getSpectrum, workspace index out of range");
241 Mantid::Types::Core::DateAndTime tMin = DateAndTime::maximum();
242 size_t numWorkspace = this->
data.size();
244 for (
size_t workspaceIndex = 0; workspaceIndex < numWorkspace; workspaceIndex++) {
259 Mantid::Types::Core::DateAndTime tMax = DateAndTime::minimum();
260 size_t numWorkspace = this->
data.size();
262 for (
size_t workspaceIndex = 0; workspaceIndex < numWorkspace; workspaceIndex++) {
276 Mantid::Types::Core::DateAndTime &Tmax)
const {
278 Tmax = DateAndTime::minimum();
279 Tmin = DateAndTime::maximum();
281 auto numWorkspace =
static_cast<int64_t
>(this->
data.size());
284 DateAndTime tTmax = DateAndTime::minimum();
285 DateAndTime tTmin = DateAndTime::maximum();
286#pragma omp for nowait
287 for (int64_t workspaceIndex = 0; workspaceIndex < numWorkspace; workspaceIndex++) {
289 DateAndTime tempMin, tempMax;
291 tTmin = std::min(tTmin, tempMin);
292 tTmax = std::max(tTmax, tempMax);
296 Tmin = std::min(Tmin, tTmin);
297 Tmax = std::max(Tmax, tTmax);
309 const auto L1 = specInfo.l1();
312 Mantid::Types::Core::DateAndTime tMin = DateAndTime::maximum();
313 size_t numWorkspace = this->
data.size();
316 for (
size_t workspaceIndex = 0; workspaceIndex < numWorkspace; workspaceIndex++) {
317 const auto L2 = specInfo.l2(workspaceIndex);
318 const double tofFactor = L1 / (L1 + L2);
335 const auto L1 = specInfo.l1();
338 Mantid::Types::Core::DateAndTime tMax = DateAndTime::minimum();
339 size_t numWorkspace = this->
data.size();
341 for (
size_t workspaceIndex = 0; workspaceIndex < numWorkspace; workspaceIndex++) {
342 const auto L2 = specInfo.l2(workspaceIndex);
343 const double tofFactor = L1 / (L1 + L2);
365 double xmin = std::numeric_limits<double>::max();
368 size_t numWorkspace = this->
data.size();
369 for (
size_t workspaceIndex = 0; workspaceIndex < numWorkspace; workspaceIndex++) {
390 double xmax = std::numeric_limits<double>::lowest();
393 size_t numWorkspace = this->
data.size();
394 for (
size_t workspaceIndex = 0; workspaceIndex < numWorkspace; workspaceIndex++) {
411 xmin = std::numeric_limits<double>::max();
416 auto numWorkspace =
static_cast<int64_t
>(this->
data.size());
421#pragma omp for nowait
422 for (int64_t workspaceIndex = 0; workspaceIndex < numWorkspace; workspaceIndex++) {
424 tXmin = std::min(evList.
getTofMin(), tXmin);
425 tXmax = std::max(evList.
getTofMax(), tXmax);
429 xmin = std::min(xmin, tXmin);
430 xmax = std::max(xmax, tXmax);
438 return std::accumulate(
data.cbegin(),
data.cend(),
size_t{0},
439 [](
const auto total,
const auto &list) { return total + list->getNumberEvents(); });
448 for (
const auto &list : this->
data) {
450 if (
static_cast<int>(out) <
static_cast<int>(thisType)) {
465 for (
auto &eventList : this->
data)
466 eventList->switchTo(type);
488 size_t total = std::accumulate(
data.begin(),
data.end(),
size_t{0},
489 [](
size_t total,
auto &list) { return total + list->getMemorySize(); });
516 "array: you can't modify the histogrammed data in "
517 "an EventWorkspace!");
525 "array: you can't modify the histogrammed data in "
526 "an EventWorkspace!");
567 bool skipError)
const {
569 throw std::range_error(
"EventWorkspace::generateHistogram, histogram number out of range");
570 this->
data[
index]->generateHistogram(X,
Y, E, skipError);
584 bool skipError)
const {
586 throw std::range_error(
"EventWorkspace::generateHistogramPulseTime, "
587 "histogram number out of range");
588 this->
data[
index]->generateHistogramPulseTime(X,
Y, E, skipError);
599 for (
auto &eventList : this->
data)
600 eventList->setHistogram(
x);
611 double tofmin, tofmax;
616 if (tofmin > tofmax) {
618 tofmax = std::numeric_limits<double>::min();
619 }
else if (tofmin == tofmax) {
620 tofmax += std::numeric_limits<double>::min();
633 void operator()(
const tbb::blocked_range<size_t> &range)
const {
634 for (
size_t wi = range.begin(); wi < range.end(); ++wi) {
638 if (spectrum.empty())
662 size_t dataSize = this->
data.size();
664 for (
size_t i = 1; i < dataSize; i++) {
678 if (prog !=
nullptr) {
686 constexpr size_t GRAINSIZE_DEFAULT{100};
687 const size_t grainsize = std::min<size_t>(GRAINSIZE_DEFAULT, (this->
getNumberHistograms() / GRAINSIZE_DEFAULT) + 1);
688 tbb::parallel_for(tbb::blocked_range<size_t>(0,
data.size(), grainsize), task);
704 const bool entireRange)
const {
715 out[wksp_index] = el->
integrate(minX, maxX, entireRange);
724IPropertyManager::getValue<Mantid::DataObjects::EventWorkspace_sptr>(
const std::string &
name)
const {
729 std::string message =
730 "Attempt to assign property " +
name +
" to incorrect type. Expected shared_ptr<EventWorkspace>.";
731 throw std::runtime_error(message);
737IPropertyManager::getValue<Mantid::DataObjects::EventWorkspace_const_sptr>(
const std::string &
name)
const {
741 return prop->operator()();
743 std::string message =
744 "Attempt to assign property " +
name +
" to incorrect type. Expected const shared_ptr<EventWorkspace>.";
745 throw std::runtime_error(message);
double value
The value of the point.
std::map< DeltaEMode::Type, std::string > index
#define PARALLEL_FOR_NO_WSP_CHECK()
#define DLLExport
Definitions of the DLLImport compiler directives for MSVC.
#define DECLARE_WORKSPACE(classname)
const SpectrumInfo & spectrumInfo() const
Return a reference to the SpectrumInfo object.
size_t numberOfDetectorGroups() const
Returns the number of detector groups.
const Run & run() const
Run details object access.
This class provides an interface to an EventWorkspace.
void setHistogram(T &&...data)
Sets the Histogram associated with this spectrum.
void setMatrixWorkspace(MatrixWorkspace *matrixWorkspace, const size_t index)
Sets the MatrixWorkspace pointer (pointer to the owning workspace).
virtual const MantidVec & readE() const
Deprecated, use e() instead. Returns the y error data const.
virtual const MantidVec & readY() const
Deprecated, use y() instead. Returns the y data const.
std::vector< std::unique_ptr< Axis > > m_axes
A vector of pointers to the axes for this workspace.
virtual size_t getMemorySizeForXAxes() const
Returns the memory used (in bytes) by the X axes, handling ragged bins.
void invalidateCommonBinsFlag()
Invalidates the commons bins flag.
HistogramData::Histogram histogram(const size_t index) const
Returns the Histogram at the given workspace index.
Helper class for reporting progress from algorithms.
size_t getMemorySize() const override
Return an approximate memory size for the object in bytes.
Mantid::Types::Core::DateAndTime getTimeAtSampleMax(const double &tofFactor, const double &tofOffset) const override
Get the maximum time at sample.
double getTofMax() const override
void setSortOrder(const EventSortType order) const
Manually set the event list sort order value.
double getTofMin() const override
const MantidVec & readDx() const override
Deprecated, use dx() instead.
void getPulseTimeMinMax(Mantid::Types::Core::DateAndTime &tMin, Mantid::Types::Core::DateAndTime &tM) const
Mantid::Types::Core::DateAndTime getPulseTimeMax() const override
Kernel::cow_ptr< HistogramData::HistogramX > ptrX() const override
Deprecated, use sharedX() instead. Returns a pointer to the x data.
MantidVec & dataX() override
Deprecated, use mutableX() instead.
MantidVec & dataDx() override
Deprecated, use mutableDx() instead.
Mantid::Types::Core::DateAndTime getTimeAtSampleMin(const double &tofFactor, const double &tofOffset) const override
Get the minimum time at sample.
const MantidVec & readX() const override
Deprecated, use x() instead. Returns the x data const.
void integrate(const double minX, const double maxX, const bool entireRange, double &sum, double &error) const
Integrate the events between a range of X values, or all events.
Mantid::Types::Core::DateAndTime getPulseTimeMin() const override
Task for sorting an event list.
void operator()(const tbb::blocked_range< size_t > &range) const
const EventWorkspace * m_WS
EventWorkspace on which to sort.
EventSortType m_sortType
How to sort.
EventSortingTask(const EventWorkspace *WS, EventSortType sortType, Mantid::API::Progress *prog)
ctor
Mantid::API::Progress * prog
Optional Progress dialog.
This is a container for the MRU (most-recently-used) list of generated histograms.
This class is intended to fulfill the design specified in <https://github.com/mantidproject/documents...
void init(const std::size_t &, const std::size_t &, const std::size_t &) override
Initialize the pixels.
std::vector< std::unique_ptr< EventList > > data
A vector that holds the event list for each spectrum; the key is the workspace index,...
void setAllX(const HistogramData::BinEdges &x) override
Set all histogram X vectors.
double getEventXMax() const
Get them maximum x-value for the events themselves, ignoring the histogram representation.
EventList * getSpectrumUnsafe(const size_t index)
Returns a pointer to the EventList for a given spectrum in a timely manner.
MantidVec & dataY(const std::size_t) override
Deprecated, use mutableY() instead.
std::size_t getNumberBins(const std::size_t &index) const override
Returns the number of bins for a given histogram index.
Kernel::cow_ptr< HistogramData::HistogramX > refX(const std::size_t) const override
Deprecated, use sharedX() instead.
bool isHistogramData() const override
Returns true always - an EventWorkspace always represents histogramm-able data.
Mantid::Types::Core::DateAndTime getPulseTimeMin() const override
Get the minimum pulse time for events accross the entire workspace.
std::size_t getMaxNumberBins() const override
Returns the maximum number of bins in a workspace (works on ragged data).
EventList & getSpectrum(const size_t index) override
Return the underlying ISpectrum ptr at the given workspace index.
std::size_t MRUSize() const
Return how many entries in the Y MRU list are used.
void getEventXMinMax(double &xmin, double &xmax) const
Get them minimum and maximum x-values for the events themselves, ignoring the histogram representatio...
std::size_t getNumberHistograms() const override
Get the number of histograms, usually the same as the number of pixels or detectors.
double getTofMax() const override
void getPulseTimeMinMax(Mantid::Types::Core::DateAndTime &xmin, Mantid::Types::Core::DateAndTime &xmax) const
Get the maximum and mimumum pulse time for events accross the entire workspace.
Mantid::Types::Core::DateAndTime getTimeAtSampleMin(double tofOffset=0) const override
Get the minimum time at sample for events across the entire workspace.
~EventWorkspace() override
EventSortType getSortType() const
double getEventXMin() const
Get them minimum x-value for the events themselves, ignoring the histogram representation.
void switchEventType(const Mantid::API::EventType type)
Switch all event lists to the given event type.
Mantid::Types::Core::DateAndTime getPulseTimeMax() const override
Get the maximum pulse time for events accross the entire workspace.
MantidVec & dataDx(const std::size_t) override
Deprecated, use mutableDx() instead.
void getIntegratedSpectra(std::vector< double > &out, const double minX, const double maxX, const bool entireRange) const override
Integrate all the spectra in the matrix workspace within the range given.
bool threadSafe() const override
Returns true if the EventWorkspace is safe for multithreaded operations.
std::size_t size() const override
The total size of the workspace.
void sortAll(EventSortType sortType, Mantid::API::Progress *prog) const
EventList & getSpectrumWithoutInvalidation(const size_t index) override
Return const reference to EventList at the given workspace index.
void clearMRU() const override
Clears the MRU lists.
Mantid::API::EventType getEventType() const override
Get the EventType of the most-specialized EventList in the workspace.
double getTofMin() const override
bool isRaggedWorkspace() const override
Returns true if the workspace is ragged (has differently sized spectra).
MantidVec & dataX(const std::size_t) override
Deprecated, use mutableX() instead.
Mantid::Types::Core::DateAndTime getTimeAtSampleMax(double tofOffset=0) const override
Get the maximum time at sample for events across the entire workspace.
std::size_t getNumberEvents() const override
The total number of events across all of the spectra.
std::size_t blocksize() const override
Get the blocksize, aka the number of bins in the histogram.
size_t getMemorySize() const override
Returns the amount of memory used in bytes.
void generateHistogram(const std::size_t index, const MantidVec &X, MantidVec &Y, MantidVec &E, bool skipError=false) const override
Generate a new histogram from specified event list at the given index.
void generateHistogramPulseTime(const std::size_t index, const MantidVec &X, MantidVec &Y, MantidVec &E, bool skipError=false) const
Generate a new histogram from specified event list at the given index.
MantidVec & dataE(const std::size_t) override
Deprecated, use mutableE() instead.
std::unique_ptr< EventWorkspaceMRU > mru
Container for the MRU lists of the event lists contained.
void resetAllXToSingleBin() override
Set all Histogram X vectors to a single bin with boundaries that fit the TOF of all events across all...
Marks code as not implemented yet.
void reportIncrement(int inc, const std::string &msg="")
Sends the progress notification and increment the loop counter by more than one.
void report()
Increments the loop counter by 1, then sends the progress notification on behalf of its algorithm.
The concrete, templated class for properties.
Implements a copy on write data template.
Kernel::Logger g_log("ExperimentInfo")
static logger object
EventType
What kind of event list is being stored.
std::shared_ptr< const EventWorkspace > EventWorkspace_const_sptr
shared pointer to a const Workspace2D
EventSortType
How the event list is sorted.
std::shared_ptr< EventWorkspace > EventWorkspace_sptr
shared pointer to the EventWorkspace class
std::vector< double > MantidVec
typedef for the data storage used in Mantid matrix workspaces
int32_t specnum_t
Typedef for a spectrum Number.
std::string to_string(const wide_integer< Bits, Signed > &n)