TrackingRecHitInfo

Macros

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 42 43
#ifndef TrackInfo_TrackingRecHitInfo_h
#define TrackInfo_TrackingRecHitInfo_h
/** \class reco::TrackingRecHitInfo TrackingRecHitInfo.h DataFormats/TrackAnalysisInfo/interface/TrackingRecHitInfo.h
 *
 * It contains additional info
 * for tracker studies
 * 
 *
 * \author Chiara Genta
 *
 *
 */

#include "AnalysisDataFormats/TrackInfo/interface/TrackingStateInfo.h"
#include "AnalysisDataFormats/TrackInfo/interface/TrackInfoEnum.h"
#include "DataFormats/TrackReco/interface/TrackFwd.h"
#include "DataFormats/TrajectoryState/interface/PTrajectoryStateOnDet.h"
#include "DataFormats/TrackingRecHit/interface/TrackingRecHitFwd.h"
#include "DataFormats/TrajectorySeed/interface/TrajectorySeed.h"

namespace reco {
  class TrackingRecHitInfo {
  public:
    typedef reco::StateType StateType;
    typedef std::map<StateType, TrackingStateInfo> TrackingStates;

    TrackingRecHitInfo() {}
    TrackingRecHitInfo(RecHitType type, TrackingStates &states) : type_(type), states_(states) {}
    const RecHitType type() const { return type_; }
    const LocalVector localTrackMomentumOnMono(StateType statetype) const;
    const LocalVector localTrackMomentumOnStereo(StateType statetype) const;
    const LocalPoint localTrackPositionOnMono(StateType statetype) const;
    const LocalPoint localTrackPositionOnStereo(StateType statetype) const;
    const TrackingStates &statesOnDet() const { return states_; }
    const PTrajectoryStateOnDet *stateOnDet(StateType statetype) const;

  private:
    RecHitType type_;
    TrackingStates states_;
  };

}  // namespace reco
#endif