Mantid
Loading...
Searching...
No Matches
PolarizationCorrectionWildes.h
Go to the documentation of this file.
1// Mantid Repository : https://github.com/mantidproject/mantid
2//
3// Copyright © 2018 ISIS Rutherford Appleton Laboratory UKRI,
4// NScD Oak Ridge National Laboratory, European Spallation Source,
5// Institut Laue - Langevin & CSNS, Institute of High Energy Physics, CAS
6// SPDX - License - Identifier: GPL - 3.0 +
7#pragma once
8
12#include "MantidAlgorithms/DllConfig.h"
13
14namespace Mantid {
15namespace API {
16class ISpectrum;
17}
18
19namespace Algorithms {
20
26class MANTID_ALGORITHMS_DLL PolarizationCorrectionWildes final : public API::Algorithm {
27public:
28 const std::string name() const override;
29 int version() const override;
30 const std::string category() const override;
31 const std::string summary() const override;
32 const std::vector<std::string> seeAlso() const override;
33
34private:
36 struct WorkspaceMap {
41 size_t size() const noexcept;
42 };
43
46 const API::ISpectrum *P1{nullptr};
47 const API::ISpectrum *P2{nullptr};
48 const API::ISpectrum *F1{nullptr};
49 const API::ISpectrum *F2{nullptr};
50 };
51
52 void init() override;
53 void exec() override;
54 std::map<std::string, std::string> validateInputs() override;
55 void checkConsistentNumberHistograms(const WorkspaceMap &inputs);
56 void checkConsistentX(const WorkspaceMap &inputs, const EfficiencyMap &efficiencies);
57 EfficiencyMap efficiencyFactors();
58 WorkspaceMap directBeamCorrections(const WorkspaceMap &inputs, const EfficiencyMap &efficiencies);
59 WorkspaceMap analyzerlessCorrections(const WorkspaceMap &inputs, const EfficiencyMap &efficiencies);
60 WorkspaceMap twoInputCorrections(const WorkspaceMap &inputs, const EfficiencyMap &efficiencies);
61 WorkspaceMap threeInputCorrections(const WorkspaceMap &inputs, const EfficiencyMap &efficiencies);
62 WorkspaceMap fullCorrections(const WorkspaceMap &inputs, const EfficiencyMap &efficiencies);
63 API::WorkspaceGroup_sptr groupOutput(const WorkspaceMap &outputs, const bool hasAnalyser);
64 WorkspaceMap mapInputsToDirections(const std::vector<std::string> &flippers);
65 void threeInputsSolve01(WorkspaceMap &inputs, const EfficiencyMap &efficiencies);
66 void threeInputsSolve10(WorkspaceMap &inputs, const EfficiencyMap &efficiencies);
67 void twoInputsSolve01And10(WorkspaceMap &fullInputs, const WorkspaceMap &inputs, const EfficiencyMap &efficiencies);
68 void addSpinStateOutput(std::vector<std::string> &names, const std::string &spinStateOrder,
69 const std::string &baseName, const API::MatrixWorkspace_sptr &ws,
70 const std::string &spinState, const bool addSpinStateLog, const bool hasAnalyser);
71 void addSpinStateLogToWs(const API::MatrixWorkspace_sptr &ws, const std::string &spinState, const bool hasAnalyser);
72};
73} // namespace Algorithms
74} // namespace Mantid
std::string name
Definition Run.cpp:60
Base class from which all concrete algorithm classes should be derived.
Definition Algorithm.h:76
A "spectrum" is an object that holds the data for a particular spectrum, in particular:
Definition ISpectrum.h:38
PolarizationCorrectionWildes : This algorithm corrects for non-ideal component efficiencies in polari...
std::shared_ptr< WorkspaceGroup > WorkspaceGroup_sptr
shared pointer to Mantid::API::WorkspaceGroup
std::shared_ptr< MatrixWorkspace > MatrixWorkspace_sptr
shared pointer to the matrix workspace base class
Helper class which provides the Collimation Length for SANS instruments.
A convenience set of workspaces corresponding flipper configurations.