Line Code
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
/** \file BeamSpotAlignmentDerivatives.cc
 *
 *  $Date: 2007/05/02 21:01:53 $
 *  $Revision: 1.7 $
 *  (last update by $Author: cklae $)
 */

#include "DataFormats/GeometrySurface/interface/Surface.h"

#include "TrackingTools/PatternTools/interface/TwoTrackMinimumDistance.h"

#include "TrackingTools/TrajectoryState/interface/PerigeeConversions.h"
#include "TrackingTools/TrajectoryState/interface/TrajectoryStateOnSurface.h"

#include "Alignment/CommonAlignmentParametrization/interface/BeamSpotAlignmentDerivatives.h"

AlgebraicMatrix BeamSpotAlignmentDerivatives::operator()(const TrajectoryStateOnSurface &tsos) const {
  AlgebraicMatrix aliderivs(4, 2);

  if (!tsos.isValid())
    return aliderivs;

  // lp.x = transverse impact parameter
  // lp.y = longitudinal impact parameter
  LocalPoint lp = tsos.localPosition();
  double phi = tsos.globalMomentum().phi();
  double dz = lp.y();
  double sinphi = sin(phi);
  double cosphi = cos(phi);

  aliderivs[0][0] = sinphi;
  aliderivs[0][1] = 0.0;
  aliderivs[1][0] = -cosphi;
  aliderivs[1][1] = 0.0;
  aliderivs[2][0] = sinphi * dz;
  aliderivs[2][1] = 0.0;
  aliderivs[3][0] = -cosphi * dz;
  aliderivs[3][1] = 0.0;

  return (aliderivs);
}