From c6725454f3e30c32a8055d464b7c5522d0df430c Mon Sep 17 00:00:00 2001 From: Verena Reimund <reimund@ill.eu> Date: Mon, 4 Jun 2018 11:55:07 +0200 Subject: [PATCH] Distinguish between points & histo inputs, validation & docs - No validation of dx for histograms Refs #22197 --- Framework/Algorithms/src/Stitch1D.cpp | 17 ++++++++++------- Framework/Algorithms/src/Stitch1DMany.cpp | 21 ++++++++++++++------- docs/source/algorithms/Stitch1D-v3.rst | 8 ++++---- 3 files changed, 28 insertions(+), 18 deletions(-) diff --git a/Framework/Algorithms/src/Stitch1D.cpp b/Framework/Algorithms/src/Stitch1D.cpp index 9f096583c4d..0c929cb94f1 100644 --- a/Framework/Algorithms/src/Stitch1D.cpp +++ b/Framework/Algorithms/src/Stitch1D.cpp @@ -53,7 +53,7 @@ void sortXAxis(MatrixWorkspace_sptr &ws) { x_value = ws->x(i)[k]; sorter.insert(std::pair<double, double>(x_value, ws->y(i)[k])); sorter.insert(std::pair<double, double>(x_value, ws->e(i)[k])); - if (ws->hasDx(i)) + if (ws->hasDx(i) && !ws->isHistogramData()) sorter.insert(std::pair<double, double>(x_value, ws->dx(i)[k])); } size_t ws_size = ws->size(); @@ -67,7 +67,7 @@ void sortXAxis(MatrixWorkspace_sptr &ws) { vecx[l] = it->first; vecy[l] = it->second; vece[l] = (++it)->second; - if (ws->hasDx(i)) + if (ws->hasDx(i) && !ws->isHistogramData()) vecdx[l] = (++it)->second; ++l; ++it; @@ -78,7 +78,7 @@ void sortXAxis(MatrixWorkspace_sptr &ws) { ws->setSharedX(i, x); ws->setSharedY(i, y); ws->setSharedE(i, e); - if (ws->hasDx(i)) { + if (ws->hasDx(i) && !ws->isHistogramData()) { auto dx = make_cow<HistogramDx>(std::move(vecdx)); ws->setSharedDx(i, dx); } @@ -221,9 +221,12 @@ std::map<std::string, std::string> Stitch1D::validateInputs(void) { RunCombinationHelper combHelper; combHelper.setReferenceProperties(lhs); std::string compatible = combHelper.checkCompatibility(rhs, true); - if (!compatible.empty()) - issues["RHSWorkspace"] = "Workspace " + rhs->getName() + - " is not compatible: " + compatible + "\n"; + if (!compatible.empty()) { + if (!(compatible == "spectra must have either Dx values or not; ") || + (rhs->isHistogramData())) // Issue only for point data + issues["RHSWorkspace"] = "Workspace " + rhs->getName() + + " is not compatible: " + compatible + "\n"; + } return issues; } @@ -535,7 +538,7 @@ void Stitch1D::scaleWorkspace(MatrixWorkspace_sptr &ws, // We lost Dx values (Multiply) and need to get them back for point data if (ws->size() == dxWS->size()) { for (size_t i = 0; i < ws->getNumberHistograms(); ++i) { - if (dxWS->hasDx(i) && !ws->hasDx(i)) { + if (dxWS->hasDx(i) && !ws->hasDx(i) && !ws->isHistogramData()) { ws->setSharedDx(i, dxWS->sharedDx(i)); } } diff --git a/Framework/Algorithms/src/Stitch1DMany.cpp b/Framework/Algorithms/src/Stitch1DMany.cpp index d2a330570be..8dfb17fee78 100644 --- a/Framework/Algorithms/src/Stitch1DMany.cpp +++ b/Framework/Algorithms/src/Stitch1DMany.cpp @@ -141,10 +141,14 @@ std::map<std::string, std::string> Stitch1DMany::validateInputs() { for (const auto &ws : column) { // check if all the others are compatible with the reference std::string compatible = combHelper.checkCompatibility(ws, true); - if (!compatible.empty()) - issues["InputWorkspaces"] = "Workspace " + ws->getName() + - " is not compatible: " + compatible + - "\n"; + if (!compatible.empty()) { + if (!(compatible == + "spectra must have either Dx values or not; ") || + (ws->isHistogramData())) // Issue only for point data + issues["RHSWorkspace"] = "Workspace " + ws->getName() + + " is not compatible: " + compatible + + "\n"; + } } m_inputWSMatrix.emplace_back(column); } else if (m_inputWSMatrix.size() != @@ -173,7 +177,8 @@ std::map<std::string, std::string> Stitch1DMany::validateInputs() { int scaleFactorFromPeriod = this->getProperty("ScaleFactorFromPeriod"); m_scaleFactorFromPeriod = static_cast<size_t>(scaleFactorFromPeriod); - m_scaleFactorFromPeriod--; // To account for period being indexed from 1 + m_scaleFactorFromPeriod--; // To account for period being indexed from + // 1 if (m_scaleFactorFromPeriod >= m_inputWSMatrix.size()) { std::stringstream expectedRange; expectedRange << m_inputWSMatrix.size(); @@ -231,7 +236,8 @@ void Stitch1DMany::exec() { std::string groupName = this->getProperty("OutputWorkspace"); std::string outName; - // Determine whether or not we are scaling workspaces using scale factors + // Determine whether or not we are scaling workspaces using scale + // factors // from a specific period Property *manualSF = this->getProperty("ManualScaleFactors"); bool usingScaleFromPeriod = m_useManualScaleFactors && @@ -347,7 +353,8 @@ void Stitch1DMany::doStitch1D(std::vector<MatrixWorkspace_sptr> &toStitch, /** Performs the Stitch1DMany algorithm at a specific period * @param period :: The period index we are stitching at - * @param useManualScaleFactors :: True to use provided values for scale factors + * @param useManualScaleFactors :: True to use provided values for scale + * factors * @param outName :: Output stitched workspace name * @param outScaleFactors :: Actual values used for scale factors */ diff --git a/docs/source/algorithms/Stitch1D-v3.rst b/docs/source/algorithms/Stitch1D-v3.rst index fb8e2ba4531..f7a2ef375ba 100644 --- a/docs/source/algorithms/Stitch1D-v3.rst +++ b/docs/source/algorithms/Stitch1D-v3.rst @@ -10,16 +10,16 @@ Description ----------- Stitches single histogram :ref:`Matrix Workspaces <MatrixWorkspace>` -together outputting a stitched Matrix Workspace. Note that workspaces must be histogrammed, you may -want to use :ref:`algm-ConvertToHistogram` on workspaces prior to passing them to this algorithm. +together outputting a stitched Matrix Workspace. +The type of the input workspaces (histogram or point data) determines the stitch procedure. +The x-error values Dx will always be ignored in case of histogram workspaces. +Point data workspaces must be consistent, i.e. must have Dx defined or not. Either the right-hand-side or left-hand-side workspace can be chosen to be scaled. Users can optionally provide :ref:`algm-Rebin` :literal:`Params`, otherwise they are calculated from the input workspaces. Likewise, :literal:`StartOverlap` and :literal:`EndOverlap` are optional. If not provided, then these are taken to be the region of X-axis intersection. -The type of the input workspaces (histogram or point data) determines the x values in the overlap range of the output workspace. - The algorithm workflow for histograms is as follows: #. The workspaces are initially rebinned, as prescribed by the rebin :literal:`Params`. Note that -- GitLab