Jpp 19.3.0-rc.1
the software that should make you happy
Loading...
Searching...
No Matches
JACOUSTICS::event_type Struct Reference

Event. More...

Inheritance diagram for JACOUSTICS::event_type:
JACOUSTICS::JEvent JGEOMETRY3D::JVertex3D JIO::JSerialisable JACOUSTICS::JCounter std::vector< JTransmission > TObject JGEOMETRY3D::JPosition3D JGEOMETRY3D::JTime JMATH::JMath< JFirst_t, JSecond_t > JGEOMETRY3D::JVector3D JMATH::JMath< JFirst_t, JSecond_t >

Public Member Functions

 event_type ()
 Default constructor.
 
 event_type (const JEvent &event, const JVertex3D &vertex=JVertex3D())
 Constructor.
 
const JEventgetEvent () const
 Get event.
 
const JVertex3DgetVertex () const
 Get vertex.
 
const int getDetectorID () const
 Get detector identifier.
 
int getOverlays () const
 Get number of overlayed events.
 
int getID () const
 Get emitter identifier.
 
void merge (const JEvent &event)
 Merge event.
 
virtual JReaderread (JReader &in) override
 Read from input.
 
virtual JWriterwrite (JWriter &out) const override
 Write to output.
 
 ClassDefOverride (JEvent, 4)
 
int getCounter () const
 Get counter.
 
 ClassDefNV (JCounter, 1)
 
JVertex3Dnegate ()
 Prefix unary minus.
 
JVertex3Dadd (const JVertex3D &value)
 Addition operator.
 
JTimeadd (const JTime &value)
 Addition operator.
 
JVector3Dadd (const JVector3D &vector)
 Add vector.
 
JVertex3Dsub (const JVertex3D &value)
 Subtraction operator.
 
JTimesub (const JTime &value)
 Subtraction operator.
 
JVector3Dsub (const JVector3D &vector)
 Subtract vector.
 
JVertex3Dmul (const double value)
 Multiplication operator.
 
JFirst_t & mul (const JSecond_t &object)
 Multiply with object.
 
JFirst_t & mul (const JSecond_t &object)
 Multiply with object.
 
JVertex3Ddiv (const double value)
 Division operator.
 
double getT (const JVector3D &pos) const
 Get arrival time of Cherenkov light at given position.
 
double getT () const
 Get time.
 
JVersor3D getDirection (const JVector3D &pos) const
 Get photon direction of Cherenkov light on PMT.
 
double getDot (const JAxis3D &axis) const
 Get cosine angle of impact of Cherenkov light on PMT.
 
double getDot (const JAngle3D &angle) const
 Get dot product.
 
double getDot (const JVersor3D &dir) const
 Get dot product.
 
double getDot (const JVersor3Z &dir) const
 Get dot product.
 
double getDot (const JVector3D &vector) const
 Get dot product.
 
const JPosition3DgetPosition () const
 Get position.
 
JPosition3DgetPosition ()
 Get position.
 
void setPosition (const JVector3D &pos)
 Set position.
 
 operator JAngle3D () const
 Type conversion operator.
 
 operator JVersor3D () const
 Type conversion operator.
 
JPosition3Drotate (const JRotation3D &R)
 Rotate.
 
JPosition3Drotate (const JRotation3X &R)
 Rotate around X-axis.
 
JPosition3Drotate (const JRotation3Y &R)
 Rotate around Y-axis.
 
JPosition3Drotate (const JRotation3Z &R)
 Rotate around Z-axis.
 
JPosition3Drotate (const JQuaternion3D &Q)
 Rotate.
 
JPosition3Drotate_back (const JRotation3D &R)
 Rotate back.
 
JPosition3Drotate_back (const JRotation3X &R)
 Rotate back around X-axis.
 
JPosition3Drotate_back (const JRotation3Y &R)
 Rotate back around Y-axis.
 
JPosition3Drotate_back (const JRotation3Z &R)
 Rotate back around Z-axis.
 
JPosition3Drotate_back (const JQuaternion3D &Q)
 Rotate back.
 
void transform (const JRotation3D &R, const JVector3D &pos)
 Transform position.
 
JVector3Dtransform (const JMatrix3D &T)
 Transform.
 
void transform_back (const JRotation3D &R, const JVector3D &pos)
 Transform back position.
 
 operator JVector2D () const
 Type conversion operator.
 
double getX () const
 Get x position.
 
double getY () const
 Get y position.
 
double getZ () const
 Get z position.
 
bool equals (const JVector3D &vector, const double precision=std::numeric_limits< double >::min()) const
 Check equality.
 
double getLengthSquared () const
 Get length squared.
 
double getLength () const
 Get length.
 
double getDistanceSquared (const JVector3D &pos) const
 Get squared of distance to point.
 
double getDistance (const JVector3D &pos) const
 Get distance to point.
 
JVector3DgetCross (const JVector3D &first, const JVector3D &second)
 Get cross product.
 
void setT (const double time)
 Set time.
 

Static Public Member Functions

template<class T >
static void overlap (T p, T q, const double Tmax_s)
 Empty overlapping events.
 

Protected Attributes

int detid
 
int overlays
 
int id
 
int counter
 
double __x
 
double __y
 
double __z
 
double __t
 

Detailed Description

Event.

Definition at line 141 of file JAcousticsTriggerProcessor.cc.

Constructor & Destructor Documentation

◆ event_type() [1/2]

JACOUSTICS::event_type::event_type ( )
inline

Default constructor.

Definition at line 148 of file JAcousticsTriggerProcessor.cc.

148 :
149 JEvent(),
150 JVertex3D()
151 {}
JVertex3D()
Default constructor.
Definition JVertex3D.hh:49
JEvent()
Default constructor.

◆ event_type() [2/2]

JACOUSTICS::event_type::event_type ( const JEvent & event,
const JVertex3D & vertex = JVertex3D() )
inline

Constructor.

Parameters
eventevent
vertexvertex

Definition at line 160 of file JAcousticsTriggerProcessor.cc.

160 :
161 JEvent(event),
162 JVertex3D(vertex)
163 {}

Member Function Documentation

◆ getEvent()

const JEvent & JACOUSTICS::event_type::getEvent ( ) const
inline

Get event.

Returns
event

Definition at line 171 of file JAcousticsTriggerProcessor.cc.

172 {
173 return static_cast<const JEvent&>(*this);
174 }

◆ getVertex()

const JVertex3D & JACOUSTICS::event_type::getVertex ( ) const
inline

Get vertex.

Returns
vertex

Definition at line 182 of file JAcousticsTriggerProcessor.cc.

183 {
184 return static_cast<const JVertex3D&>(*this);
185 }

◆ getDetectorID()

const int JACOUSTICS::JEvent::getDetectorID ( ) const
inlineinherited

Get detector identifier.

Returns
detector identifier.

Definition at line 129 of file JAcoustics/JEvent.hh.

130 {
131 return detid;
132 }

◆ getOverlays()

int JACOUSTICS::JEvent::getOverlays ( ) const
inlineinherited

Get number of overlayed events.

Returns
overlays

Definition at line 140 of file JAcoustics/JEvent.hh.

141 {
142 return overlays;
143 }

◆ getID()

int JACOUSTICS::JEvent::getID ( ) const
inlineinherited

Get emitter identifier.

Returns
identifier

Definition at line 151 of file JAcoustics/JEvent.hh.

152 {
153 return id;
154 }

◆ merge()

void JACOUSTICS::JEvent::merge ( const JEvent & event)
inlineinherited

Merge event.

It is assumed that the transmissions in both events are ordered according the default less-than operator.

Parameters
eventevent

Definition at line 165 of file JAcoustics/JEvent.hh.

166 {
167 using namespace std;
168
170
171 const_iterator __hit1 = this ->begin();
172 const_iterator __end1 = this ->end();
173
174 const_iterator __hit2 = event.begin();
175 const_iterator __end2 = event.end();
176
177 buffer.resize(this->size() + event.size());
178
179 iterator out = buffer.begin();
180
181 while (__hit1 != __end1 && __hit2 != __end2) {
182
183 if (*__hit1 < *__hit2) {
184
185 *out = *__hit1;
186 ++__hit1;
187
188 } else if (*__hit2 < *__hit1) {
189
190 *out = *__hit2;
191 ++__hit2;
192
193 } else {
194
195 *out = *__hit1;
196
197 ++__hit1;
198 ++__hit2;
199 }
200
201 ++out;
202 }
203
204 // append remaining hits from either set
205
206 out = copy(__hit1, __end1, out);
207 out = copy(__hit2, __end2, out);
208
209 buffer.resize(distance(buffer.begin(), out));
210
211 this->swap(buffer);
212
213 ++overlays;
214 }
std::vector< T >::difference_type distance(typename std::vector< T >::const_iterator first, typename PhysicsEvent::const_iterator< T > second)
Specialisation of STL distance.
void copy(const Head &from, JHead &to)
Copy header from from to to.
Definition JHead.cc:163
friend void swap(JEvent &first, JEvent &second)
Swap events.

◆ overlap()

template<class T >
static void JACOUSTICS::JEvent::overlap ( T p,
T q,
const double Tmax_s )
inlinestaticinherited

Empty overlapping events.

The events should be time sorted on input.
The time window applies to the difference between the first transmission of an event and the last transmission of the previous event.

Parameters
pbegin of events
qend of events
Tmax_stime window [s]

Definition at line 247 of file JAcoustics/JEvent.hh.

248 {
249 for (T __q = p, __p = __q++; __p != q && __q != q; __p = __q++) {
250
251 if (!__p->empty() &&
252 !__q->empty() &&
253 __q->begin()->getToE() < __p->rbegin()->getToE() + Tmax_s) {
254
255 __p->clear(); // clear first
256
257 for (__p = __q++; __p != q && __q != q; __p = __q++) {
258
259 if (__q->begin()->getToE() < __p->rbegin()->getToE() + Tmax_s)
260 __p->clear(); // clear intermediate
261 else
262 break;
263 }
264
265 __p->clear(); // clear last
266 }
267 }
268 }

◆ read()

virtual JReader & JACOUSTICS::JEvent::read ( JReader & in)
inlineoverridevirtualinherited

Read from input.

Parameters
inreader
Returns
reader

Implements JIO::JSerialisable.

Definition at line 326 of file JAcoustics/JEvent.hh.

327 {
328 in >> static_cast<JCounter&>(*this);
329 in >> this->detid;
330 in >> this->overlays;
331 in >> this->id;
332 in >> static_cast<std::vector<JTransmission>&>(*this);
333
334 return in;
335 }
JCounter()
Default constructor.

◆ write()

virtual JWriter & JACOUSTICS::JEvent::write ( JWriter & out) const
inlineoverridevirtualinherited

Write to output.

Parameters
outwriter
Returns
writer

Implements JIO::JSerialisable.

Definition at line 344 of file JAcoustics/JEvent.hh.

345 {
346 out << static_cast<const JCounter&>(*this);
347 out << this->detid;
348 out << this->overlays;
349 out << this->id;
350 out << static_cast<const std::vector<JTransmission>&>(*this);
351
352 return out;
353 }

◆ ClassDefOverride()

JACOUSTICS::JEvent::ClassDefOverride ( JEvent ,
4  )
inherited

◆ getCounter()

int JACOUSTICS::JCounter::getCounter ( ) const
inlineinherited

Get counter.

Returns
counter

Definition at line 50 of file JAcoustics/JCounter.hh.

51 {
52 return counter;
53 }

◆ ClassDefNV()

JACOUSTICS::JCounter::ClassDefNV ( JCounter ,
1  )
inherited

◆ negate()

JVertex3D & JGEOMETRY3D::JVertex3D::negate ( )
inlineinherited

Prefix unary minus.

Returns
line

Definition at line 73 of file JVertex3D.hh.

74 {
76 JTime ::negate();
77
78 return *this;
79 }
JVector3D & negate()
Negate vector.
Definition JVector3D.hh:126

◆ add() [1/3]

JVertex3D & JGEOMETRY3D::JVertex3D::add ( const JVertex3D & value)
inlineinherited

Addition operator.

Parameters
valueline
Returns
line

Definition at line 87 of file JVertex3D.hh.

88 {
89 JPosition3D::add(value);
90 JTime ::add(value);
91
92 return *this;
93 }
JVector3D & add(const JVector3D &vector)
Add vector.
Definition JVector3D.hh:142

◆ add() [2/3]

JTime & JGEOMETRY3D::JTime::add ( const JTime & value)
inlineinherited

Addition operator.

Parameters
valuetime
Returns
time

Definition at line 67 of file JGeometry3D/JTime.hh.

68 {
69 __t += value.getT();
70
71 return *this;
72 }

◆ add() [3/3]

JVector3D & JGEOMETRY3D::JVector3D::add ( const JVector3D & vector)
inlineinherited

Add vector.

Parameters
vectorvector
Returns
this vector

Definition at line 142 of file JVector3D.hh.

143 {
144 __x += vector.getX();
145 __y += vector.getY();
146 __z += vector.getZ();
147
148 return *this;
149 }

◆ sub() [1/3]

JVertex3D & JGEOMETRY3D::JVertex3D::sub ( const JVertex3D & value)
inlineinherited

Subtraction operator.

Parameters
valueline
Returns
line

Definition at line 102 of file JVertex3D.hh.

103 {
104 JPosition3D::sub(value);
105 JTime ::sub(value);
106
107 return *this;
108 }
JVector3D & sub(const JVector3D &vector)
Subtract vector.
Definition JVector3D.hh:158

◆ sub() [2/3]

JTime & JGEOMETRY3D::JTime::sub ( const JTime & value)
inlineinherited

Subtraction operator.

Parameters
valuetime
Returns
time

Definition at line 81 of file JGeometry3D/JTime.hh.

82 {
83 __t -= value.getT();
84
85 return *this;
86 }

◆ sub() [3/3]

JVector3D & JGEOMETRY3D::JVector3D::sub ( const JVector3D & vector)
inlineinherited

Subtract vector.

Parameters
vectorvector
Returns
this vector

Definition at line 158 of file JVector3D.hh.

159 {
160 __x -= vector.getX();
161 __y -= vector.getY();
162 __z -= vector.getZ();
163
164 return *this;
165 }

◆ mul() [1/3]

JVertex3D & JGEOMETRY3D::JVertex3D::mul ( const double value)
inlineinherited

Multiplication operator.

Parameters
valuemultiplication factor
Returns
line

Definition at line 117 of file JVertex3D.hh.

118 {
119 JPosition3D::mul(value);
120 JTime ::mul(value);
121
122 return *this;
123 }
JVector3D & mul(const double factor)
Scale vector.
Definition JVector3D.hh:174

◆ mul() [2/3]

template<class JFirst_t , class JSecond_t >
JFirst_t & JMATH::JMath< JFirst_t, JSecond_t >::mul ( const JSecond_t & object)
inlineinherited

Multiply with object.

Parameters
objectobject
Returns
result object

Definition at line 354 of file JMath.hh.

355 {
356 return static_cast<JFirst_t&>(*this) = JFirst_t().mul(static_cast<const JFirst_t&>(*this), object);
357 }

◆ mul() [3/3]

template<class JFirst_t , class JSecond_t >
JFirst_t & JMATH::JMath< JFirst_t, JSecond_t >::mul ( const JSecond_t & object)
inlineinherited

Multiply with object.

Parameters
objectobject
Returns
result object

Definition at line 354 of file JMath.hh.

355 {
356 return static_cast<JFirst_t&>(*this) = JFirst_t().mul(static_cast<const JFirst_t&>(*this), object);
357 }

◆ div()

JVertex3D & JGEOMETRY3D::JVertex3D::div ( const double value)
inlineinherited

Division operator.

Parameters
valuemultiplication factor
Returns
line

Definition at line 132 of file JVertex3D.hh.

133 {
134 JPosition3D::div(value);
135 JTime ::div(value);
136
137 return *this;
138 }
JVector3D & div(const double factor)
Scale vector.
Definition JVector3D.hh:190

◆ getT() [1/2]

double JGEOMETRY3D::JVertex3D::getT ( const JVector3D & pos) const
inlineinherited

Get arrival time of Cherenkov light at given position.

Parameters
posposition [m]
Returns
time [ns]

Definition at line 147 of file JVertex3D.hh.

148 {
149 using namespace JPHYSICS;
150
151 return this->getT() + this->getDistance(pos) * getInverseSpeedOfLight() * getIndexOfRefraction();
152 }
double getDistance(const JVector3D &pos) const
Get distance to point.
Definition JVector3D.hh:270
double getT() const
Get time.
Auxiliary methods for light properties of deep-sea water.

◆ getT() [2/2]

double JGEOMETRY3D::JTime::getT ( ) const
inlineinherited

Get time.

Returns
time

Definition at line 133 of file JGeometry3D/JTime.hh.

134 {
135 return __t;
136 }

◆ getDirection()

JVersor3D JGEOMETRY3D::JVertex3D::getDirection ( const JVector3D & pos) const
inlineinherited

Get photon direction of Cherenkov light on PMT.

Parameters
posPMT position
Returns
direction

Definition at line 161 of file JVertex3D.hh.

162 {
163 JPosition3D D(pos);
164
165 D.sub(this->getPosition());
166
167 return JVersor3D(D);
168 }
JPosition3D()
Default constructor.
const JPosition3D & getPosition() const
Get position.

◆ getDot() [1/5]

double JGEOMETRY3D::JVertex3D::getDot ( const JAxis3D & axis) const
inlineinherited

Get cosine angle of impact of Cherenkov light on PMT.

Parameters
axisPMT axis
Returns
cosine angle of impact

Definition at line 177 of file JVertex3D.hh.

178 {
179 return getDirection(axis.getPosition()).getDot(axis.getDirection());
180 }
double getDot(const JVersor3D &versor) const
Get dot product.
Definition JVersor3D.hh:156
JVersor3D getDirection(const JVector3D &pos) const
Get photon direction of Cherenkov light on PMT.
Definition JVertex3D.hh:161

◆ getDot() [2/5]

double JGEOMETRY3D::JPosition3D::getDot ( const JAngle3D & angle) const
inlineinherited

Get dot product.

Parameters
angleangle
Returns
dot product

Definition at line 378 of file JPosition3D.hh.

379 {
380 return
381 getX() * angle.getDX() +
382 getY() * angle.getDY() +
383 getZ() * angle.getDZ();
384 }
double getY() const
Get y position.
Definition JVector3D.hh:104
double getZ() const
Get z position.
Definition JVector3D.hh:115
double getX() const
Get x position.
Definition JVector3D.hh:94

◆ getDot() [3/5]

double JGEOMETRY3D::JPosition3D::getDot ( const JVersor3D & dir) const
inlineinherited

Get dot product.

Parameters
dirdirection
Returns
dot product

Definition at line 393 of file JPosition3D.hh.

394 {
395 return
396 getX() * dir.getDX() +
397 getY() * dir.getDY() +
398 getZ() * dir.getDZ();
399 }

◆ getDot() [4/5]

double JGEOMETRY3D::JPosition3D::getDot ( const JVersor3Z & dir) const
inlineinherited

Get dot product.

Parameters
dirdirection
Returns
dot product

Definition at line 408 of file JPosition3D.hh.

409 {
410 return
411 getX() * dir.getDX() +
412 getY() * dir.getDY() +
413 getZ() * dir.getDZ();
414 }

◆ getDot() [5/5]

double JGEOMETRY3D::JVector3D::getDot ( const JVector3D & vector) const
inlineinherited

Get dot product.

Parameters
vectorvector
Returns
dot product

Definition at line 282 of file JVector3D.hh.

283 {
284 return
285 getX() * vector.getX() +
286 getY() * vector.getY() +
287 getZ() * vector.getZ();
288 }

◆ getPosition() [1/2]

const JPosition3D & JGEOMETRY3D::JPosition3D::getPosition ( ) const
inlineinherited

Get position.

Returns
position

Definition at line 130 of file JPosition3D.hh.

131 {
132 return static_cast<const JPosition3D&>(*this);
133 }

◆ getPosition() [2/2]

JPosition3D & JGEOMETRY3D::JPosition3D::getPosition ( )
inlineinherited

Get position.

Returns
position

Definition at line 141 of file JPosition3D.hh.

142 {
143 return static_cast<JPosition3D&>(*this);
144 }

◆ setPosition()

void JGEOMETRY3D::JPosition3D::setPosition ( const JVector3D & pos)
inlineinherited

Set position.

Parameters
posposition

Definition at line 152 of file JPosition3D.hh.

153 {
154 static_cast<JVector3D&>(*this) = pos;
155 }
JVector3D()
Default constructor.
Definition JVector3D.hh:41

◆ operator JAngle3D()

JGEOMETRY3D::JPosition3D::operator JAngle3D ( ) const
inlineinherited

Type conversion operator.

Returns
angle

Definition at line 163 of file JPosition3D.hh.

164 {
165 return JAngle3D(getX(), getY(), getZ());
166 }

◆ operator JVersor3D()

JGEOMETRY3D::JPosition3D::operator JVersor3D ( ) const
inlineinherited

Type conversion operator.

Returns
direction

Definition at line 174 of file JPosition3D.hh.

175 {
176 return JVersor3D(getX(), getY(), getZ());
177 }

◆ rotate() [1/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate ( const JRotation3D & R)
inlineinherited

Rotate.

Parameters
Rrotation matrix
Returns
this position

Definition at line 186 of file JPosition3D.hh.

187 {
188 R.rotate(__x, __y, __z);
189
190 return *this;
191 }

◆ rotate() [2/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate ( const JRotation3X & R)
inlineinherited

Rotate around X-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 214 of file JPosition3D.hh.

215 {
216 R.rotate(__y, __z);
217
218 return *this;
219 }

◆ rotate() [3/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate ( const JRotation3Y & R)
inlineinherited

Rotate around Y-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 242 of file JPosition3D.hh.

243 {
244 R.rotate(__x, __z);
245
246 return *this;
247 }

◆ rotate() [4/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate ( const JRotation3Z & R)
inlineinherited

Rotate around Z-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 270 of file JPosition3D.hh.

271 {
272 R.rotate(__x, __y);
273
274 return *this;
275 }

◆ rotate() [5/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate ( const JQuaternion3D & Q)
inlineinherited

Rotate.

Parameters
Qquaternion
Returns
this position

Definition at line 298 of file JPosition3D.hh.

299 {
300 Q.rotate(__x, __y, __z);
301
302 return *this;
303 }

◆ rotate_back() [1/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate_back ( const JRotation3D & R)
inlineinherited

Rotate back.

Parameters
Rrotation matrix
Returns
this position

Definition at line 200 of file JPosition3D.hh.

201 {
202 R.rotate_back(__x, __y, __z);
203
204 return *this;
205 }

◆ rotate_back() [2/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate_back ( const JRotation3X & R)
inlineinherited

Rotate back around X-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 228 of file JPosition3D.hh.

229 {
230 R.rotate_back(__y, __z);
231
232 return *this;
233 }

◆ rotate_back() [3/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate_back ( const JRotation3Y & R)
inlineinherited

Rotate back around Y-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 256 of file JPosition3D.hh.

257 {
258 R.rotate_back(__x, __z);
259
260 return *this;
261 }

◆ rotate_back() [4/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate_back ( const JRotation3Z & R)
inlineinherited

Rotate back around Z-axis.

Parameters
Rrotation matrix
Returns
this position

Definition at line 284 of file JPosition3D.hh.

285 {
286 R.rotate_back(__x, __y);
287
288 return *this;
289 }

◆ rotate_back() [5/5]

JPosition3D & JGEOMETRY3D::JPosition3D::rotate_back ( const JQuaternion3D & Q)
inlineinherited

Rotate back.

Parameters
Qquaternion
Returns
this position

Definition at line 312 of file JPosition3D.hh.

313 {
314 Q.rotate_back(__x, __y, __z);
315
316 return *this;
317 }

◆ transform() [1/2]

void JGEOMETRY3D::JPosition3D::transform ( const JRotation3D & R,
const JVector3D & pos )
inlineinherited

Transform position.

The final position is obtained as follows:

  1. rotation of the position according matrix R;
  2. offset position with pos;
  3. rotation of position around z-axis, such that final position lies in x-z plane;
Parameters
Rrotation matrix
posposition of origin (after rotation)

Definition at line 331 of file JPosition3D.hh.

333 {
334 // rotate geometry to system with particle direction along z-axis
335
336 rotate(R);
337
338 // offset with respect to origin
339
340 sub(pos);
341
342 // rotate geometry to x-z plane
343
344 __x = sqrt(__x*__x + __y*__y);
345 __y = 0.0;
346 }
JPosition3D & rotate(const JRotation3D &R)
Rotate.

◆ transform() [2/2]

JVector3D & JGEOMETRY3D::JVector3D::transform ( const JMatrix3D & T)
inlineinherited

Transform.

Parameters
Tmatrix
Returns
this vector

Definition at line 206 of file JVector3D.hh.

207 {
208 T.transform(__x, __y, __z);
209
210 return *this;
211 }

◆ transform_back()

void JGEOMETRY3D::JPosition3D::transform_back ( const JRotation3D & R,
const JVector3D & pos )
inlineinherited

Transform back position.

The final position is obtained as follows:

  1. offset position with position pos;
  2. rotation of postion according matrix R;
Parameters
Rrotation matrix
posposition of origin (before rotation)

Definition at line 359 of file JPosition3D.hh.

361 {
362 // offset with respect to origin
363
364 add(pos);
365
366 // rotate back geometry to system with particle direction along z-axis
367
368 rotate_back(R);
369 }
JPosition3D & rotate_back(const JRotation3D &R)
Rotate back.

◆ operator JVector2D()

JGEOMETRY3D::JVector3D::operator JVector2D ( ) const
inlineinherited

Type conversion operator.

Returns
JVector2D

Definition at line 83 of file JVector3D.hh.

84 {
85 return JVector2D(this->getX(), this->getY());
86 }

◆ getX()

double JGEOMETRY3D::JVector3D::getX ( ) const
inlineinherited

Get x position.

Returns
x position

Definition at line 94 of file JVector3D.hh.

95 {
96 return __x;
97 }

◆ getY()

double JGEOMETRY3D::JVector3D::getY ( ) const
inlineinherited

Get y position.

Returns
y position

Definition at line 104 of file JVector3D.hh.

105 {
106 return __y;
107 }

◆ getZ()

double JGEOMETRY3D::JVector3D::getZ ( ) const
inlineinherited

Get z position.

Returns
z position

Definition at line 115 of file JVector3D.hh.

116 {
117 return __z;
118 }

◆ equals()

bool JGEOMETRY3D::JVector3D::equals ( const JVector3D & vector,
const double precision = std::numeric_limits<double>::min() ) const
inlineinherited

Check equality.

Parameters
vectorvector
precisionprecision
Returns
true if vectors are equal; else false

Definition at line 221 of file JVector3D.hh.

223 {
224 return (fabs(getX() - vector.getX()) <= precision &&
225 fabs(getY() - vector.getY()) <= precision &&
226 fabs(getZ() - vector.getZ()) <= precision);
227 }

◆ getLengthSquared()

double JGEOMETRY3D::JVector3D::getLengthSquared ( ) const
inlineinherited

Get length squared.

Returns
square of length

Definition at line 235 of file JVector3D.hh.

236 {
237 return getX()*getX() + getY()*getY() + getZ()*getZ();
238 }

◆ getLength()

double JGEOMETRY3D::JVector3D::getLength ( ) const
inlineinherited

Get length.

Returns
length

Definition at line 246 of file JVector3D.hh.

247 {
248 return sqrt(getLengthSquared());
249 }
double getLengthSquared() const
Get length squared.
Definition JVector3D.hh:235

◆ getDistanceSquared()

double JGEOMETRY3D::JVector3D::getDistanceSquared ( const JVector3D & pos) const
inlineinherited

Get squared of distance to point.

Parameters
posposition
Returns
square of distance

Definition at line 258 of file JVector3D.hh.

259 {
260 return JVector3D(pos).sub(*this).getLengthSquared();
261 }

◆ getDistance()

double JGEOMETRY3D::JVector3D::getDistance ( const JVector3D & pos) const
inlineinherited

Get distance to point.

Parameters
posposition
Returns
distance

Definition at line 270 of file JVector3D.hh.

271 {
272 return sqrt(getDistanceSquared(pos));
273 }
double getDistanceSquared(const JVector3D &pos) const
Get squared of distance to point.
Definition JVector3D.hh:258

◆ getCross()

JVector3D & JGEOMETRY3D::JVector3D::getCross ( const JVector3D & first,
const JVector3D & second )
inlineinherited

Get cross product.

Note that this vector should not overlap with the first or second vector,

Parameters
firstfirst vector
secondsecond vector
Returns
this vector

Definition at line 299 of file JVector3D.hh.

301 {
302 __x = first .getY() * second.getZ() - second.getY() * first .getZ();
303 __y = second.getX() * first .getZ() - first .getX() * second.getZ();
304 __z = first .getX() * second.getY() - second.getX() * first .getY();
305
306 return *this;
307 }

◆ setT()

void JGEOMETRY3D::JTime::setT ( const double time)
inlineinherited

Set time.

Parameters
time

Definition at line 122 of file JGeometry3D/JTime.hh.

123 {
124 __t = time;
125 }

Member Data Documentation

◆ detid

int JACOUSTICS::JEvent::detid
protectedinherited

Definition at line 358 of file JAcoustics/JEvent.hh.

◆ overlays

int JACOUSTICS::JEvent::overlays
protectedinherited

Definition at line 359 of file JAcoustics/JEvent.hh.

◆ id

int JACOUSTICS::JEvent::id
protectedinherited

Definition at line 360 of file JAcoustics/JEvent.hh.

◆ counter

int JACOUSTICS::JCounter::counter
protectedinherited

Definition at line 88 of file JAcoustics/JCounter.hh.

◆ __x

double JGEOMETRY3D::JVector3D::__x
protectedinherited

Definition at line 310 of file JVector3D.hh.

◆ __y

double JGEOMETRY3D::JVector3D::__y
protectedinherited

Definition at line 311 of file JVector3D.hh.

◆ __z

double JGEOMETRY3D::JVector3D::__z
protectedinherited

Definition at line 312 of file JVector3D.hh.

◆ __t

double JGEOMETRY3D::JTime::__t
protectedinherited

Definition at line 202 of file JGeometry3D/JTime.hh.


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