-
Notifications
You must be signed in to change notification settings - Fork 122
/
GetEiMonDet2.h
99 lines (76 loc) · 3.76 KB
/
GetEiMonDet2.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#ifndef MANTID_ALGORITHMS_GETEIMONDET2_H_
#define MANTID_ALGORITHMS_GETEIMONDET2_H_
//----------------------------------------------------------------------
// Includes
//----------------------------------------------------------------------
#include "MantidAPI/Algorithm.h"
#include "MantidAPI/ITableWorkspace_fwd.h"
#include "MantidAPI/MatrixWorkspace_fwd.h"
namespace Mantid {
namespace Algorithms {
/** Estimates the incident neutron energy from the time of flight
between a monitor and a set of detectors.
Copyright © 2016 ISIS Rutherford Appleton Laboratory, NScD Oak
Ridge National Laboratory & European Spallation Source
This file is part of Mantid.
Mantid is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
Mantid is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
File change history is stored at: <https://github.com/mantidproject/mantid>.
Code Documentation is available at: <http://doxygen.mantidproject.org>
*/
class DLLExport GetEiMonDet2 : public Mantid::API::Algorithm {
public:
/// Initializes the algorithm
void init() override;
/// Executes the algorithm
void exec() override;
/// Returns algorithm's name for identification
const std::string name() const override { return "GetEiMonDet"; }
/// Returns a summary of algorithm's purpose
const std::string summary() const override {
return "Calculates the kinetic energy of neutrons leaving the source based "
"on the time it takes for them to travel between a monitor and a "
"set of detectors.";
}
/// Returns algorithm's version for identification
int version() const override { return 2; }
/// Algorithm's category for identification overriding a virtual method
const std::string category() const override { return "Inelastic\\Ei"; }
private:
/// Calculates the average sample-to-detector distance and TOF
void averageDetectorDistanceAndTOF(const std::vector<size_t> &detectorIndices,
double &sampleToDetectorDistance,
double &detectorEPP);
/// Calculates the total TOF from monitor to detectors
double computeTOF(const double distance, const double detectorEPP,
const double monitorEPP);
/// Sets the monitor-to-sample distance and TOF
void monitorDistanceAndTOF(const size_t monitorIndex,
double &monitorToSampleDistance,
double &monitorEPP) const;
/// Reads detector and monitor indices from properties
void parseIndices(std::vector<size_t> &detectorIndices,
size_t &monitorIndex) const;
/// Removes duplicates and checks consistency
void sanitizeIndices(std::vector<size_t> &detectorIndices,
size_t monitorIndex) const;
/// Shared pointer to the detector workspace
Mantid::API::MatrixWorkspace_const_sptr m_detectorWs;
/// Shared pointer to the detectors' EPP table
Mantid::API::ITableWorkspace_const_sptr m_detectorEPPTable;
/// Shared pointer to the monitor workspace
Mantid::API::MatrixWorkspace_const_sptr m_monitorWs;
/// Shared pointer to the monitor's EPP table
Mantid::API::ITableWorkspace_const_sptr m_monitorEPPTable;
};
} // namespace Algorithms
} // namespace Mantid
#endif /*MANTID_ALGORITHMS_GETEIMONDET2_H_*/