19 std::vector<SteppingHelixStateInfo>
22 float step,
float minR,
float minZ,
float maxR,
float maxZ) {
34 bool isPropagationSuccessful = neckLace.
propagateAll(state);
36 if (!isPropagationSuccessful)
37 return std::vector<SteppingHelixStateInfo> () ;
39 std::vector<SteppingHelixStateInfo> complicatePoints;
42 return complicatePoints;
63 float r22 = vector.
z()/
sqrt(1-
pow(vector.x(),2));
64 float r23 = -vector.y()/
sqrt(1-
pow(vector.x(),2));
65 float r31 = vector.x();
66 float r32 = vector.y();
67 float r33 = vector.z();
68 float r11 = r22*r33-r23*
r32;
84 state = shp->propagate(state, plane);
89 edm::LogWarning(
"TrackAssociator") <<
"An exception is caught during the track propagation\n"
108 state = shp->propagate(state, cylinder);
113 edm::LogWarning(
"TrackAssociator") <<
"An exception is caught during the track propagation\n"
130 edm::LogWarning(
"TrackAssociator") <<
"Reseting all trajectories. Please call reset_trajectory() explicitely to avoid this message";
142 LogTrace(
"TrackAssociator") <<
"[propagateAll] Propagate outward from (rho, r, z, phi) (" <<
146 if (! currentState.
isValid() ) {
147 LogTrace(
"TrackAssociator") <<
"Failed to propagate the track; moving on\n";
150 LogTrace(
"TrackAssociator") <<
"\treached (rho, r, z, phi) (" <<
160 previousState=currentState2;
162 if (! currentState2.
isValid() ) {
163 LogTrace(
"TrackAssociator") <<
"Failed to propagate the track; moving on\n";
167 LogTrace(
"TrackAssociator") <<
"Error: TrackAssociator has propogated the particle past the point of closest approach to IP" << std::endl;
170 LogTrace(
"TrackAssociator") <<
"[propagateAll] Propagated inward from (rho, r, z, phi) (" <<
191 LogTrace(
"TrackAssociator") <<
"Done with the track propagation in the detector. Number of steps: " <<
fullTrajectory_.size();
208 const float matchingDistance = 1;
212 int closestPointOnLeft = 0;
216 LogTrace(
"TrackAssociator") <<
"Track didn't cross the plane:\n\tleft distance: "<<
distance(plane, leftIndex)
217 <<
"\n\tright distance: " <<
distance(plane, rightIndex);
221 while (leftIndex + 1 < rightIndex) {
222 closestPointOnLeft = int((leftIndex+rightIndex)/2);
223 float dist =
distance(plane,closestPointOnLeft);
226 if (fabs(dist)<matchingDistance) {
228 if (closestPointOnLeft>0 &&
sign(
distance(plane, closestPointOnLeft-1) ) * dist == -1)
229 closestPointOnLeft--;
235 rightIndex = closestPointOnLeft;
237 leftIndex = closestPointOnLeft;
245 LogTrace(
"TrackAssociator") <<
"closestPointOnLeft: " << closestPointOnLeft
246 <<
"\n\ttrajectory point (z,R,eta,phi): "
251 <<
"\n\tplane center (z,R,eta,phi): "
268 edm::LogWarning(
"TrackAssociator") <<
"An exception is caught during the track propagation\n"
291 std::pair<float,float>
result(0,0);
293 edm::LogWarning(
"TrackAssociator") <<
"State at IP is not known set. Cannot estimate trajectory change. " <<
294 "Trajectory change is not taken into account in matching";
297 switch (trajectoryType) {
300 edm::LogWarning(
"TrackAssociator") <<
"ECAL trajector is empty. Cannot estimate trajectory change. " <<
301 "Trajectory change is not taken into account in matching";
307 edm::LogWarning(
"TrackAssociator") <<
"HCAL trajector is empty. Cannot estimate trajectory change. " <<
308 "Trajectory change is not taken into account in matching";
314 edm::LogWarning(
"TrackAssociator") <<
"HO trajector is empty. Cannot estimate trajectory change. " <<
315 "Trajectory change is not taken into account in matching";
321 edm::LogWarning(
"TrackAssociator") <<
"Full trajector is empty. Cannot estimate trajectory change. " <<
322 "Trajectory change is not taken into account in matching";
327 edm::LogWarning(
"TrackAssociator") <<
"Unkown or not supported trajector type. Cannot estimate trajectory change. " <<
328 "Trajectory change is not taken into account in matching";
334 const double& theta2,
338 std::pair<float,float>
result(theta2 - theta1, phi2 - phi1 );
340 if ( fabs(result.second) > 2*
M_PI-fabs(result.second) ) {
342 result.second -= 2*
M_PI;
344 result.second += 2*
M_PI;
355 LogTrace(
"TrackAssociator") <<
"Trajectory is empty. Move on";
359 LogTrace(
"TrackAssociator") <<
"no trajectory is expected to be found since the fiducial volume is not valid";
364 int closestPointOnLeft = -1;
371 LogTrace(
"TrackAssociator") <<
"Track didn't cross the region (R1,R2,L1,L2): " << volume.
minR() <<
", " << volume.
maxR() <<
372 ", " << volume.
minZ() <<
", " << volume.
maxZ();
386 int firstPointInside(-1);
393 if ( dR> 0 || dZ >0 )
396 firstPointInside =
i;
397 closestPointOnLeft =
i - 1;
399 firstPointInside = 0;
400 closestPointOnLeft = 0;
405 if (closestPointOnLeft == -1)
throw cms::Exception(
"FatalError") <<
"This shouls never happen - internal logic error";
415 if (firstPointInside != closestPointOnLeft) {
425 if ( currentState.
isValid() ) trajectory.push_back(currentState);
427 LogTrace(
"TrackAssociator") <<
"Weird message\n";
429 while (currentState.
isValid() &&
434 if (! currentState.
isValid() ) {
435 LogTrace(
"TrackAssociator") <<
"Failed to propagate the track; moving on\n";
441 trajectory.push_back(currentState);
458 LogTrace(
"TrackAssociator") <<
"getting trajectory in ECAL";
464 LogTrace(
"TrackAssociator") <<
"getting trajectory in Preshower";
478 LogTrace(
"TrackAssociator") <<
"getting trajectory in HCAL";
488 LogTrace(
"TrackAssociator") <<
"getting trajectory in HO";
497 std::vector<GlobalPoint>*
500 std::vector<GlobalPoint>* wideTrajectory = 0;
501 switch (wideTrajectoryType) {
503 LogTrace(
"TrackAssociator") <<
"Filling ellipses in Ecal trajectory";
507 LogTrace(
"TrackAssociator") <<
"Filling ellipses in Hcal trajectory";
511 LogTrace(
"TrackAssociator") <<
"Filling ellipses in HO trajectory";
515 if(!wideTrajectory)
return 0;
517 for(std::vector<SteppingHelixStateInfo>::const_iterator
state= states.begin();
523 float r22 = vector.
z()/
sqrt(1-
pow(vector.x(),2));
524 float r23 = -vector.y()/
sqrt(1-
pow(vector.x(),2));
525 float r31 = vector.x();
526 float r32 = vector.y();
527 float r33 = vector.z();
528 float r11 = r22*r33-r23*
r32;
530 float r13 = -r22*r31;
539 if (!tsos.isValid()) {
540 LogTrace(
"TrackAssociator") <<
"[getWideTrajectory] TSOS not valid";
543 if (!tsos.hasError()) {
544 LogTrace(
"TrackAssociator") <<
"[getWideTrajectory] TSOS does not have Errors";
547 LocalError localErr = tsos.localError().positionError();
549 float xx = localErr.
xx();
550 float xy = localErr.
xy();
551 float yy = localErr.
yy();
553 float denom = yy - xx;
555 if(xy == 0 && denom==0) phi = M_PI_4;
556 else phi = 0.5 * atan2(2.*xy,denom);
560 float semi1 =
sqrt(rotErr.
xx());
561 float semi2 =
sqrt(rotErr.
yy());
580 wideTrajectory->push_back(
state->position());
588 return wideTrajectory;
TkRotation< Scalar > RotationType
GlobalPoint toGlobal(const Point2DBase< Scalar, LocalTag > lp) const
bool fullTrajectoryFilled_
void setMaxDetectorLength(float l=2200.) dso_internal
std::pair< float, float > trajectoryDelta(TrajectorType) dso_internal
bool isValid() const
check whether the volume is properly defined
void findEcalTrajectory(const FiducialVolume &) dso_internal
SteppingHelixStateInfo stateAtIP_
void setMinDetectorRadius(float r=0.) dso_internal
void reset_trajectory() dso_internal
std::vector< SteppingHelixStateInfo > ecalTrajectory_
const std::vector< SteppingHelixStateInfo > & getHOTrajectory() const
SteppingHelixStateInfo getStateAtHO() dso_internal
const std::vector< SteppingHelixStateInfo > & getHcalTrajectory() const
const Propagator * propagator_
virtual std::string explainSelf() const
void getFreeState(FreeTrajectoryState &fts) const
convert internal structure into the fts
SteppingHelixStateInfo getOuterState() dso_internal
double maxZ(bool withTolerance=true) const
Sin< T >::type sin(const T &t)
Geom::Phi< T > phi() const
void findHcalTrajectory(const FiducialVolume &) dso_internal
std::string const & category() const
void setPropagationStep(float s=20.)
void propagateForward(SteppingHelixStateInfo &state, float distance) dso_internal
std::vector< GlobalPoint > wideHcalTrajectory_
const std::vector< SteppingHelixStateInfo > & getPreshowerTrajectory() const
double minZ(bool withTolerance=true) const
GlobalVector momentum() const
static int position[TOTALCHAMBERS][3]
std::vector< GlobalPoint > wideEcalTrajectory_
Geom::Theta< T > theta() const
Point3DBase< Scalar, GlobalTag > PositionType
std::vector< GlobalPoint > * getWideTrajectory(const std::vector< SteppingHelixStateInfo > &, WideTrajectoryType) dso_internal
std::vector< SteppingHelixStateInfo > hoTrajectory_
std::vector< GlobalPoint > wideHOTrajectory_
const std::vector< SteppingHelixStateInfo > & getEcalTrajectory() const
FreeTrajectoryState * freeState(bool withErrors=true) const
const T & max(const T &a, const T &b)
void setPropagator(const Propagator *ptr) dso_internal
GlobalPoint position() const
TrajectoryStateOnSurface getStateOnSurface(const Surface &surf, bool returnTangentPlane=false) const
static PlanePointer build(Args &&...args)
Cos< T >::type cos(const T &t)
std::vector< SteppingHelixStateInfo > preshowerTrajectory_
SteppingHelixStateInfo getStateAtPreshower() dso_internal
virtual TrajectoryStateOnSurface propagate(const FreeTrajectoryState &, const Surface &) const
double minR(bool withTolerance=true) const
void findPreshowerTrajectory(const FiducialVolume &) dso_internal
Vector3DBase unit() const
void getTrajectory(std::vector< SteppingHelixStateInfo > &, const FiducialVolume &, int steps=4) dso_internal
float distance(const Plane *plane, int index) dso_internal
std::deque< SteppingHelixStateInfo > fullTrajectory_
bool propagateAll(const SteppingHelixStateInfo &initialState) dso_internal
propagate through the whole detector, returns true if successful
void setStateAtIP(const SteppingHelixStateInfo &state) dso_internal
SteppingHelixStateInfo getStateAtHcal() dso_internal
void findHOTrajectory(const FiducialVolume &) dso_internal
std::pair< float, float > delta(const double &theta1, const double &theta2, const double &phi1, const double &phi2) dso_internal
Point2DBase< float, LocalTag > Local2DPoint
std::vector< SteppingHelixStateInfo > propagateThoughFromIP(const SteppingHelixStateInfo &state, const Propagator *prop, const FiducialVolume &volume, int nsteps, float step, float minR, float minZ, float maxR, float maxZ)
SteppingHelixStateInfo getInnerState() dso_internal
LocalError rotate(float x, float y) const
Return a new LocalError, rotated by an angle defined by the direction (x,y)
SteppingHelixStateInfo getStateAtEcal() dso_internal
void propagate(SteppingHelixStateInfo &state, const Plane &plane) dso_internal
void setMinDetectorLength(float l=0.) dso_internal
const PositionType & position() const
double maxR(bool withTolerance=true) const
Power< A, B >::type pow(const A &a, const B &b)
static int sign(float number) dso_internal
void setMaxDetectorRadius(float r=800.) dso_internal
std::vector< SteppingHelixStateInfo > hcalTrajectory_
LocalError scale(float s) const