Jpp 19.3.0-rc.1
the software that should make you happy
Loading...
Searching...
No Matches
JTRIGGER::JTrigger3D Class Reference

General purpose majority trigger. More...

#include <JTrigger3D.hh>

Inheritance diagram for JTRIGGER::JTrigger3D:
JTRIGGER::JTriggerInterface JTRIGGER::JTrigger3DShower

Classes

struct  JParameters
 Trigger parameters. More...
 

Public Types

typedef JTriggerInput::value_type value_type
 
typedef JMatch< value_typematch_type
 

Public Member Functions

 JTrigger3D (const JParameters &input)
 Constructor.
 
void operator() (const JTriggerInput &input, std::back_insert_iterator< JTriggerOutput > out) const
 Process trigger.
 
JTriggerbit_t getTriggerBit () const
 Get the trigger bit.
 

Static Public Member Functions

static const char * getTriggerName (JTriggerbit_t bit)
 Get trigger name.
 

Public Attributes

JParameters parameters
 

Protected Member Functions

template<JTriggerbit_t N>
bool checkTriggerBit () const
 Test whether specific trigger bit correponds to derived trigger class.
 
template<JTriggerbit_t N>
JTriggerbit_t find_trigger_bit (JBit< N > bit) const
 Recursive method to find the trigger bit of the given trigger data.
 
JTriggerbit_t find_trigger_bit (JBit< NUMBER_OF_TRIGGER_BITS > bit) const
 Termination method of recursive method to find the trigger bit of the given trigger data.
 

Static Protected Member Functions

template<JTriggerbit_t N>
static const char * getTriggerName ()
 Get trigger name.
 
template<JTriggerbit_t N>
static const char * get_trigger_name (JBit< N > bit, JTriggerbit_t value)
 Recursive method to get trigger name for given trigger bit.
 
static const char * get_trigger_name (JBit< NUMBER_OF_TRIGGER_BITS > bit, JTriggerbit_t value)
 Termination method of recursive method to get trigger name.
 

Private Attributes

std::vector< value_typebuffer
 

Detailed Description

General purpose majority trigger.

Definition at line 30 of file JTrigger3D.hh.

Member Typedef Documentation

◆ value_type

JTriggerInput::value_type JTRIGGER::JTriggerInterface::value_type
inherited

Definition at line 161 of file JTriggerInterface.hh.

◆ match_type

Constructor & Destructor Documentation

◆ JTrigger3D()

JTRIGGER::JTrigger3D::JTrigger3D ( const JParameters & input)
inline

Constructor.

Parameters
inputtrigger parameters

Definition at line 80 of file JTrigger3D.hh.

80 :
81 parameters(input)
82 {
83 if (parameters.numberOfHits == 0) {
85 }
86
87 if (parameters.numberOfHits == 1) {
89 }
90
92 }
std::vector< value_type > buffer
JParameters parameters

Member Function Documentation

◆ operator()()

void JTRIGGER::JTrigger3D::operator() ( const JTriggerInput & input,
std::back_insert_iterator< JTriggerOutput > out ) const
inline

Process trigger.

Parameters
inputinput data
outoutput data

Definition at line 101 of file JTrigger3D.hh.

102 {
103 using std::distance;
104
105 if (parameters.enabled && input.size() >= (size_t) parameters.numberOfHits) {
106
107 match_type& match3D = *parameters.match3D;
108
109 for (JTriggerInput::const_iterator p = input.begin(), q = p; p != input.end(); ) {
110
111 for (++q; q->getT() - p->getT() < parameters.TMaxEvent_ns; ++q) {}
112
113 if (distance (p,q) >= parameters.numberOfHits &&
115
116 if (distance(p,q) < parameters.factoryLimit) {
117
118 do {
119
120 if (distance (p,q) >= parameters.numberOfHits &&
122
123 // copy
124
125 JTriggerInput::iterator root = buffer.begin();
126 JTriggerInput::iterator __p = buffer.begin();
127 JTriggerInput::iterator __q = buffer.begin();
128
129 *root = *p;
130
131 ++__p;
132 ++__q;
133
134 for (JTriggerInput::const_iterator i = p; ++i != q; ) {
135 if (match3D(*p,*i)) {
136 *__q = *i;
137 ++__q;
138 }
139 }
140
141 if (distance (root,__q) >= parameters.numberOfHits &&
143
144 __q = clusterize(__p, __q, match3D, parameters.numberOfHits - 1);
145
146 if (distance (root,__q) >= parameters.numberOfHits &&
148 *out = JEvent(input.getDAQChronometer(), root, __q, this->getTriggerBit());
149 ++out;
150 }
151 }
152 }
153
154 ++p;
155
156 } while (q->getT() - p->getT() >= parameters.TMaxEvent_ns);
157
158 } else {
159
160 // Anomalous large event
161
162 JEvent event(input.getDAQChronometer(), p, q, this->getTriggerBit());
163
164 event.addTriggerBit(FACTORY_LIMIT);
165
166 *out = event;
167 ++out;
168
169 p = q;
170 }
171
172 } else {
173
174 for (++p; q->getT() - p->getT() >= parameters.TMaxEvent_ns; ++p) {}
175 }
176 }
177 }
178 }
std::vector< T >::difference_type distance(typename std::vector< T >::const_iterator first, typename PhysicsEvent::const_iterator< T > second)
Specialisation of STL distance.
JMatch< value_type > match_type
const JDAQChronometer & getDAQChronometer() const
Get DAQ chronometer.
JFIT::JEvent JEvent
Definition JHistory.hh:404
JHitIterator_t clusterize(JHitIterator_t __begin, JHitIterator_t __end, const JMatch_t &match, const int Nmin=1)
Partition data according given binary match operator.
Definition JAlgorithm.hh:38
static const JModuleCounter getNumberOfModules
Function object to count unique modules.
Definition root.py:1
static const int FACTORY_LIMIT
Bit indicating max nhits reached in trigger.
Definition trigger.hh:16

◆ checkTriggerBit()

template<JTriggerbit_t N>
bool JTRIGGER::JTriggerInterface::checkTriggerBit ( ) const
inlineprotectedinherited

Test whether specific trigger bit correponds to derived trigger class.

This method will be specialised using the marco setTriggerBit() so that it will return true if this triggered event corresponds to bit N.

This method will be repeatedly called by method find_trigger_bit() which in turn is called by the member method JTriggerInterface::getTriggerBit() so that it returns the correct trigger bit.

Returns
false

Definition at line 76 of file JTriggerInterface.hh.

77 {
78 return false;
79 }

◆ find_trigger_bit() [1/2]

template<JTriggerbit_t N>
JTriggerbit_t JTRIGGER::JTriggerInterface::find_trigger_bit ( JBit< N > bit) const
inlineprotectedinherited

Recursive method to find the trigger bit of the given trigger data.

Parameters
bittrigger bit
Returns
trigger bit

Definition at line 89 of file JTriggerInterface.hh.

90 {
92 return N;
93 else
95 }
JTriggerbit_t find_trigger_bit(JBit< N > bit) const
Recursive method to find the trigger bit of the given trigger data.
bool checkTriggerBit() const
Test whether specific trigger bit correponds to derived trigger class.
Auxiliary data structure for single bit.
Definition JDAQ.hh:36

◆ find_trigger_bit() [2/2]

JTriggerbit_t JTRIGGER::JTriggerInterface::find_trigger_bit ( JBit< NUMBER_OF_TRIGGER_BITS > bit) const
inlineprotectedinherited

Termination method of recursive method to find the trigger bit of the given trigger data.

This method throws an error.

Parameters
bittrigger bit
Returns
trigger bit

Definition at line 105 of file JTriggerInterface.hh.

106 {
107 throw JTriggerException("Method find_trigger_bit<>(): no corresponding trigger bit found.");
108 }

◆ getTriggerName() [1/2]

template<JTriggerbit_t N>
static const char * JTRIGGER::JTriggerInterface::getTriggerName ( )
inlinestaticprotectedinherited

Get trigger name.

This method will be specialised using the marco setTriggerBit() so that it will return name of trigger for bit N.

This method will be repeatedly called by method get_trigger_name() which in turn is called by the method JTriggerInterface::getTriggerName() so that it returns the correct trigger name.

Returns
NULL

Definition at line 124 of file JTriggerInterface.hh.

125 {
126 return NULL;
127 }

◆ getTriggerName() [2/2]

static const char * JTRIGGER::JTriggerInterface::getTriggerName ( JTriggerbit_t bit)
inlinestaticinherited

Get trigger name.

param bit trigger bit

Returns
trigger name

Definition at line 182 of file JTriggerInterface.hh.

183 {
184 return get_trigger_name(JBit<0>(), bit);
185 }
static const char * get_trigger_name(JBit< N > bit, JTriggerbit_t value)
Recursive method to get trigger name for given trigger bit.

◆ get_trigger_name() [1/2]

template<JTriggerbit_t N>
static const char * JTRIGGER::JTriggerInterface::get_trigger_name ( JBit< N > bit,
JTriggerbit_t value )
inlinestaticprotectedinherited

Recursive method to get trigger name for given trigger bit.

Parameters
bittrigger bit
valuetrigger bit
Returns
trigger name

Definition at line 138 of file JTriggerInterface.hh.

139 {
140 if (bit.value == value)
141 return getTriggerName<N>();
142 else
143 return get_trigger_name(JBit<N+1>(), value);
144 }
static const char * getTriggerName()
Get trigger name.

◆ get_trigger_name() [2/2]

static const char * JTRIGGER::JTriggerInterface::get_trigger_name ( JBit< NUMBER_OF_TRIGGER_BITS > bit,
JTriggerbit_t value )
inlinestaticprotectedinherited

Termination method of recursive method to get trigger name.

Parameters
bittrigger bit
valuetrigger bit
Returns
NULL

Definition at line 154 of file JTriggerInterface.hh.

155 {
156 return NULL;
157 }

◆ getTriggerBit()

JTriggerbit_t JTRIGGER::JTriggerInterface::getTriggerBit ( ) const
inlineinherited

Get the trigger bit.

Returns
trigger bit

Definition at line 170 of file JTriggerInterface.hh.

171 {
172 return find_trigger_bit(JBit<0>());
173 }

Member Data Documentation

◆ parameters

JParameters JTRIGGER::JTrigger3D::parameters

Definition at line 182 of file JTrigger3D.hh.

◆ buffer

std::vector<value_type> JTRIGGER::JTrigger3D::buffer
mutableprivate

Definition at line 185 of file JTrigger3D.hh.


The documentation for this class was generated from the following file: