45 throw std::invalid_argument(
"parameter is read only! (locked)");
55 bool isSet()
const {
return m_set;}
77 int to_intTiming(
const std::string& text)
const
79 if (text ==
"fastestpriority") {
return 0;}
80 else if (text ==
"fastest2d") {
return 1;}
81 else if (text ==
"etf") {
return 2;}
82 else if (text ==
"etf_or_fastestpriority") {
return 3;}
83 else if (text ==
"etf_or_fastest2d") {
return 4;}
84 else if (text ==
"etf_only") {
return 5;}
85 else if (text ==
"etfcc") {
return 6;}
86 else if (text ==
"etfhwin") {
return 7;}
87 else if (text ==
"etfcc_or_fastestpriority") {
return 8;}
88 else if (text ==
"min_etf_fastestpriority") {
return 9;}
89 else if (text ==
"min_etfcc_fastestpriority") {
return 10;}
92 const std::string to_strTiming(
const unsigned& i)
const
94 if (i == 0) {
return "fastestpriority";}
95 else if (i == 1) {
return "fastest2d";}
96 else if (i == 2) {
return "etf";}
97 else if (i == 3) {
return "etf_or_fastestpriority";}
98 else if (i == 4) {
return "etf_or_fastest2d";}
99 else if (i == 5) {
return "etf_only";}
100 else if (i == 6) {
return "etfcc";}
101 else if (i == 7) {
return "etfhwin";}
102 else if (i == 8) {
return "etfcc_or_fastestpriority";}
103 else if (i == 9) {
return "min_etf_fastestpriority";}
104 else if (i == 10) {
return "min_etfcc_fastestpriority";}
105 else {
return "invalid";}
128 std::vector<std::vector<X>> ret;
132 line.push_back((X) y);
142 std::vector<std::vector<X>> ret;
144 ret.push_back((X) x);
210 std::vector<std::vector<NNTParam<float>>>
nHidden;
231 std::vector<std::vector<NNTParam<float>>>
IDRanges;
241 std::vector<std::vector<NNTParam<X>>>
read2dArray(std::string keyx,
bool locked);
244 std::vector<NNTParam<X>>
read1dArray(std::string keyx,
bool locked);
Class to represent a complete set to describe a Neurotrigger.
NNTParam(const T &xvalue)
copy constructor
bool isLocked() const
check, if variable was already locked and is read only now
bool isSet() const
check, if variable was already initialized
bool m_locked
saves the "locked" state
void lock()
lock the variable, to make it read only
NNTParam operator()() const
return the value of the data type this wrapper class is holding
T operator=(const T t)
assignment operator, but checks first if the variable is already locked
NNTParam()
this is a typewrapper class for the parameters for the neurotrigger.
T m_value
holding the value
std::vector< NNTParam< unsigned short > > maxHitsPerSL
Maximum number of hits in a single super layer for all networks.
std::vector< std::vector< NNTParam< float > > > invptRangeUse
Charge / Pt region for which MLP is used in 1/GeV for all networks.
std::vector< std::vector< NNTParam< float > > > thetaRangeUse
Theta region for which MLP is used in degree for all networks.
std::vector< NNTParam< X > > read1dArray(std::string keyx, bool locked)
fill the array from a given string that looks like: [1,2,3]
NNTParam< unsigned > nMLP
Number of networks.
std::vector< NNTParam< unsigned long > > SLpatternMask
Super layer pattern mask for which MLP is trained for all networks.
std::vector< std::vector< NNTParam< float > > > nHidden
Number of nodes in each hidden layer for all networks or factor to multiply with number of inputs.
std::vector< std::vector< NNTParam< float > > > thetaRangeTrain
Theta region for which MLP is trained in degree for all networks.
std::vector< std::vector< X > > tcastvector(const std::vector< std::vector< NNTParam< X >>> vec) const
the parameters stored in the parameterset are not advanced enough to be vectors, they can only be sin...
std::string print1dArray(const std::string &name, std::vector< NNTParam< X >> vecvec)
this is a class for piping the output of a 1d array to a string with brackets
NNTParam< unsigned > tMax
Maximal drift time, identical for all networks.
bool checkarr(std::vector< std::vector< NNTParam< X >>> vec)
check, if a vector is already set.
std::vector< NNTParam< unsigned long > > SLpattern
Super layer pattern for which MLP is trained for all networks.
NNTParam< bool > rescaleTarget
flag to allow for target tracks lying out of the output range to be rescaled during training.
std::vector< std::vector< NNTParam< float > > > IDRanges
relative ID range of the relevant wire IDs of the track segments that are taken into consideration wh...
NNTParam< bool > multiplyHidden
If true, multiply nHidden with number of input nodes.
NNTParam< bool > targetTheta
train theta as output
NNTParam< unsigned > nOutput
number of output nodes
std::vector< std::vector< NNTParam< float > > > phiRangeUse
Phi region for which MLP is used in degree for all networks.
std::vector< std::vector< NNTParam< X > > > read2dArray(std::string keyx, bool locked)
fill the array from a given string that looks like: [[1,2],[3, 4]]
NNTParam< unsigned > ETOption
Determine, how the event time should be obtained.
NNTParam< bool > targetZ
train z as output
const std::string et_option() const
return the string variant ov the et option
NNTParam< bool > cutSum
only used in the idhist module.
std::vector< std::vector< NNTParam< float > > > invptRangeTrain
Charge / Pt region for which MLP is trained in 1/GeV for all networks.
std::vector< std::vector< NNTParam< float > > > phiRangeTrain
Phi region for which MLP is trained in degree for all networks.
void loadconfigtxt(const std::string &filename)
load the configuration from a file
void saveconfigtxt(const std::string &filename)
save the configuration to a file
std::string print2dArray(const std::string &name, std::vector< std::vector< NNTParam< X >>> vecvec)
this is a class for piping the output of a 2d array to a string with brackets
NNTParam< double > relevantCut
only used in the idhist module.
NNTParam< unsigned > nInput
Network parameters.
std::vector< NNTParam< unsigned > > precision
precision used for the hardware simulation
std::vector< std::vector< NNTParam< float > > > outputScale
Output scale for all networks.
Abstract base class for different kinds of events.