36 #include <TLorentzVector.h>
38 #include <GenFit/MeasuredStateOnPlane.h>
55 virtual void set_track_id(
const int a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
58 virtual void set_rec_track_id(
const int a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
61 virtual void set_charge(
const int a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
64 virtual void set_num_hits(
const int a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
67 virtual void set_pos_vtx(
const TVector3 a) { fVertexPos = a; }
70 virtual void set_pos_st1(
const TVector3 a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
73 virtual void set_pos_st3(
const TVector3 a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
76 virtual void set_mom_vtx(
const TLorentzVector a) { fVertexMom = a.Vect(); }
79 virtual void set_mom_st1(
const TLorentzVector a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
82 virtual void set_mom_st3(
const TLorentzVector a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
96 virtual int get_hit_id(
const int i)
const {
return fHitIndex[i]; }
98 inline TLorentzVector
getlvec(
const TVector3& vec)
const { TLorentzVector lvec; lvec.SetVectM(vec,
M_MU);
return lvec; }
101 Int_t
getCharge()
const {
return (fState[0])[0][0] > 0 ? 1 : -1; }
102 Int_t
getNHits()
const {
return fHitIndex.size(); }
111 Double_t
getZ(Int_t i) {
return fZ[i]; }
119 TMatrixDSym
getGFCov(Int_t i) {
return fGFCov[i]; }
124 Double_t
getExpMomentumFast(Double_t z, Double_t& px, Double_t& py, Double_t& pz, Int_t iNode = -1);
143 Double_t
getMomentum(
const TMatrixD& state, Double_t& px, Double_t& py, Double_t& pz)
const;
144 Double_t
getPosition(
const TMatrixD& state, Double_t& x, Double_t& y)
const;
159 void insertChisq(Double_t chisq) { fChisqAtNode.push_back(chisq); }
160 void insertGFState(
const genfit::MeasuredStateOnPlane& msop);
167 void setZVertex(Double_t z,
bool update =
true);
174 void swimToVertex(TVector3* pos =
nullptr, TVector3* mom =
nullptr,
bool hyptest =
true);
225 void setPTSlope(Double_t slopeX, Double_t slopeY) { fPropSlopeX = slopeX; fPropSlopeY = slopeY; }
226 void setNHitsInPT(Int_t nHitsX, Int_t nHitsY) { fNPropHitsX = nHitsX; fNPropHitsY = nHitsY; }
240 void print(std::ostream& os = std::cout)
const;
241 void printGF(std::ostream& os = std::cout)
const;
248 std::vector<Int_t> fHitIndex;
249 std::vector<TMatrixD> fState;
250 std::vector<TMatrixD> fCovar;
251 std::vector<Double_t> fZ;
252 std::vector<Double_t> fChisqAtNode;
255 TVector3 fDumpFacePos;
258 TVector3 fXVertexPos;
259 TVector3 fYVertexPos;
261 TVector3 fDumpFaceMom;
264 TVector3 fXVertexMom;
265 TVector3 fYVertexMom;
270 Double_t fChisqVertex;
271 TMatrixD fStateVertex;
272 TMatrixD fCovarVertex;
283 Double_t fPropSlopeX;
284 Double_t fPropSlopeY;
287 Double_t fChisqTarget;
289 Double_t fChisqUpstream;
292 std::vector<TVector3> fGFDetPlaneVec[3];
293 std::vector<TVectorD> fGFAuxInfo;
294 std::vector<TVectorD> fGFStateVec;
295 std::vector<TMatrixDSym> fGFCov;
305 void identify(std::ostream& os = std::cout)
const { os <<
"SRecDimuon: TODO: NOT IMPLEMENTED!" << std::endl; }
312 virtual void set_dimuon_id(
const int a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
318 virtual void set_pdg_id(
const int a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
330 virtual void set_mom(
const TLorentzVector a) {
throw std::logic_error(__PRETTY_FUNCTION__); }
418 void identify(std::ostream& os = std::cout)
const {
420 <<
" SRecEvent: { " << fRunID <<
", " << fSpillID <<
", " << fEventID <<
" } "
421 <<
" NTracks: " << fAllTracks.size()
430 void setEventInfo(
int runID,
int spillID,
int eventID) { fRunID = runID; fSpillID = spillID; fEventID = eventID; }
467 void reIndex() { sort(fAllTracks.begin(), fAllTracks.end()); }
493 std::vector<SRecTrack> fAllTracks;
496 std::vector<SRecDimuon> fDimuons;
499 std::map<Int_t, Int_t> fLocalID;
An SQ interface class to hold one true or reconstructed dimuon.
An SQ interface class to hold one true or reconstructed track.
virtual int get_rec_dimuon_id() const
Return the dimuon ID of associated reconstructed dimuon. Valid only if this object holds truth dimuon...
TVector3 vtx
3-vector vertex position
virtual int get_dimuon_id() const
SQDimuon virtual functions.
void calcVariables(int choice=0)
Calculate the kinematic vairables, 0 = vertex, 1 = target, 2 = dump.
virtual double get_xf() const
TLorentzVector p_neg_target
virtual void set_dimuon_id(const int a)
virtual void set_mom_neg(const TLorentzVector a)
bool isDump()
Dump dimuon.
int isValid() const
isValid returns non zero if object contains vailid data
virtual void set_track_id_pos(const int a)
virtual int get_pdg_id() const
Return the GPD ID of parent particle. It is valid only for true dimuon.
Int_t trackID_pos
Index of muon track used in host SRecEvent.
virtual TVector3 get_pos() const
Return the dimuon position at vertex.
Double_t chisq_target
Chisq of three test position.
TLorentzVector p_neg_single
virtual void set_pdg_id(const int a)
TLorentzVector p_pos_target
Track momentum projections at different location.
virtual double get_mass() const
TLorentzVector p_pos_single
4-momentum of the muon tracks before vertex fit
virtual void set_pos(const TVector3 a)
Double_t chisq_kf
Vertex fit chisqs.
TLorentzVector p_pos
4-momentum of the muon tracks after vertex fit
virtual double get_x2() const
virtual TLorentzVector get_mom() const
Return the dimuon momentum at vertex.
virtual double get_chisq() const
virtual void set_track_id_neg(const int a)
virtual int get_track_id_neg() const
Return the track ID of the negative track.
virtual int get_track_id_pos() const
Return the track ID of the positive track.
Double_t mass
Kinematic variables.
bool isTarget()
Target dimuon.
virtual void set_mom_pos(const TLorentzVector a)
virtual void set_rec_dimuon_id(const int a)
TVector3 proj_target_pos
Track projections at different location.
TLorentzVector p_pos_dump
virtual void set_mom(const TLorentzVector a)
virtual TLorentzVector get_mom_neg() const
Return the momentum of the negative track at vertex.
TLorentzVector p_neg_dump
virtual double get_x1() const
SRecDimuon * Clone() const
virtual TLorentzVector get_mom_pos() const
Return the momentum of the positive track at vertex.
TLorentzVector getVPhoton()
Get the total momentum of the virtual photon.
void identify(std::ostream &os=std::cout) const
PHObject virtual overloads.
void setRecStatus(int status)
SRecEvent * Clone() const
void setEventSource(Int_t id1, Int_t id2)
Event source set/get.
void setTargetPos(int targetPos)
void setEventInfo(int runID, int spillID, int eventID)
bool isTriggeredBy(Int_t trigger)
Trigger util.
std::vector< Int_t > getChargedTrackIDs(Int_t charge)
Get track IDs.
void insertTrack(SRecTrack trk)
Insert tracks.
void identify(std::ostream &os=std::cout) const
PHObject virtual overloads.
void setRawEvent(SRawEvent *rawEvent)
directly setup everything by raw event
Int_t getLocalID(Int_t hitID)
SRecDimuon & getDimuon(Int_t i)
int isValid() const
isValid returns non zero if object contains vailid data
void insertDimuon(SRecDimuon dimuon)
Insert dimuon.
void setEventInfo(SRawEvent *rawEvent)
Set/Get event info.
void clear()
Clear everything.
Int_t getNTracks()
Get tracks.
void clearDimuons()
Clear the dimuon list.
SRecTrack & getTrack(Int_t i)
Int_t getNDimuons()
Get dimuons.
virtual TVector3 get_pos_st3() const
Return the track position at Station 3.
void getExpPosErrorFast(Double_t z, Double_t &dx, Double_t &dy, Int_t iNode=-1)
TMatrixD getCovariance(Int_t i)
Double_t getChisq() const
void setNHitsInPT(Int_t nHitsX, Int_t nHitsY)
virtual void set_mom_st3(const TLorentzVector a)
Int_t getCharge() const
Gets.
SRecTrack * Clone() const
Double_t getVtxPar(Int_t i)
Double_t getChisqTarget()
TLorentzVector getlvec(const TVector3 &vec) const
TVector3 getMomentumVecSt3() const
virtual TLorentzVector get_mom_st3() const
Return the track momentum at Station 3.
Double_t getMomentum(const TMatrixD &state, Double_t &px, Double_t &py, Double_t &pz) const
Double_t getPosition(const TMatrixD &state, Double_t &x, Double_t &y) const
virtual int get_charge() const
Return the charge, i.e. +1 or -1.
Double_t getMomentumSt1(Double_t &px, Double_t &py, Double_t &pz) const
Double_t getChisqAtNode(Int_t i)
virtual TLorentzVector get_mom_target() const
Double_t getPositionSt3(Double_t &x, Double_t &y) const
bool isVertexValid() const
Vertex stuff.
void setVertexPos(TVector3 pos)
void setChisqDump(Double_t chisq)
TVectorD getGFAuxInfo(Int_t i)
TLorentzVector getMomentumVertex()
Get the vertex info.
void setDumpPos(TVector3 pos)
Set mom/pos at a given location.
void getExpPositionFast(Double_t z, Double_t &x, Double_t &y, Int_t iNode=-1)
virtual double get_chsiq_upstream() const
bool operator<(const SRecTrack &elem) const
Comparitor.
virtual double get_chisq_target() const
void setTargetPos(TVector3 pos)
Double_t getMomentumSt3() const
void insertChisq(Double_t chisq)
void setZVertex(Double_t z, bool update=true)
void setChisq(Double_t chisq)
Sets.
Double_t getPositionSt3() const
void insertCovariance(TMatrixD covar)
void print(std::ostream &os=std::cout) const
Debugging output.
void insertGFState(const genfit::MeasuredStateOnPlane &msop)
virtual int get_track_id() const
SQTrack virtual overloads.
TMatrixD getStateVector(Int_t i)
Double_t getPositionSt1(Double_t &x, Double_t &y) const
void setYVertexPos(TVector3 pos)
void adjustKMag(double kmagStr)
Fast-adjust of kmag.
virtual void set_mom_vtx(const TLorentzVector a)
TVector3 getMomentumVecSt1() const
void setChisqTarget(Double_t chisq)
virtual void set_pos_st1(const TVector3 a)
TVector3 getDumpFacePos()
Double_t getChisqUpstream()
void setXVertexPos(TVector3 pos)
TVector3 getPositionVecSt1() const
virtual TVector3 get_pos_st1() const
Return the track position at Station 1.
Double_t getQuality() const
Double_t getMomentumSt1() const
void setYVertexMom(TVector3 mom)
Int_t getHitIndex(Int_t i)
TVectorD getGFState(Int_t i)
TVector3 getPositionVecSt3() const
virtual int get_hit_id(const int i) const
virtual double get_chisq_upstream() const
virtual TLorentzVector get_mom_st1() const
Return the track momentum at Station 1.
void printGF(std::ostream &os=std::cout) const
TVector3 getGFPlaneU(Int_t i)
void setVertexMom(TVector3 mom)
Double_t getDeflectionY()
Int_t getNHitsInStation(Int_t stationID)
int isValid() const
isValid returns non zero if object contains vailid data
bool isTarget()
Overall track quality cut.
TVector3 getGFPlaneO(Int_t i)
void setDumpFaceMom(TVector3 mom)
Int_t getNearestNode(Double_t z)
void setPTSlope(Double_t slopeX, Double_t slopeY)
Prop. tube muon ID info.
void setTriggerRoad(Int_t roadID)
Trigger road info.
virtual void set_track_id(const int a)
Double_t getMomentumVertex(Double_t &px, Double_t &py, Double_t &pz)
virtual void set_num_hits(const int a)
virtual void set_mom_st1(const TLorentzVector a)
virtual TVector3 get_pos_dump() const
void setXVertexMom(TVector3 mom)
virtual void set_charge(const int a)
virtual void set_pos_vtx(const TVector3 a)
void setTargetMom(TVector3 mom)
void setChisqUpstream(Double_t chisq)
Double_t getDeflectionX()
virtual void set_pos_st3(const TVector3 a)
TVector3 getDumpFaceMom()
virtual void set_rec_track_id(const int a)
Double_t getExpMomentumFast(Double_t z, Double_t &px, Double_t &py, Double_t &pz, Int_t iNode=-1)
TMatrixDSym getGFCov(Int_t i)
Bool_t isKalmanFitted()
Fit status.
void setDumpMom(TVector3 mom)
void swimToVertex(TVector3 *pos=nullptr, TVector3 *mom=nullptr, bool hyptest=true)
Simple swim to vertex.
virtual TLorentzVector get_mom_dump() const
virtual int get_num_hits() const
Return the number of hits associated to this track.
void insertHitIndex(Int_t index)
virtual TVector3 get_pos_target() const
Double_t getMomentumSt3(Double_t &px, Double_t &py, Double_t &pz) const
void updateVtxHypothesis()
TVector3 getDumpPos()
Get mom/pos at a given location.
virtual double get_chisq_dump() const
void setDumpFacePos(TVector3 pos)
virtual int get_rec_track_id() const
Return the track ID of associated reconstructed track. Valid only if this object holds truth track in...
virtual TLorentzVector get_mom_vtx() const
Return the track momentum at vertex.
void identify(std::ostream &os=std::cout) const
PHObject virtual overloads.
virtual double get_chisq() const
Double_t getPositionSt1() const
void setKalmanStatus(Int_t status)
void setVertexFast(TVector3 mom, TVector3 pos)
Plain setting, no KF-related stuff.
TVector3 getGFPlaneV(Int_t i)
void insertStateVector(TMatrixD state)
Double_t getChisqVertex()
void setChisqVertex(Double_t chisq)
virtual TVector3 get_pos_vtx() const
Return the track position at vertex.