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
|