00001
00002
00003
00004
00005 #ifndef MyParticlePairH
00006 #define MyParticlePairH
00007
00008
00009
00010
00011
00020
00021
00022
00023
00024
00025
00026 #include <iostream>
00027 #include <string>
00028 #include <vector>
00029
00030
00031 #include "TLorentzVector.h"
00032
00033
00034 #include "MyParticle.h"
00035
00036 class MyParticlePair {
00037
00038 public:
00039
00040 MyParticlePair(void) {
00041 }
00043 MyParticlePair(MyParticle* particle1,
00044 MyParticle* particle2){
00045 init(particle1, particle2);
00046 }
00050
00051
00052
00053
00054 inline MyParticle* get_particle1(void) const;
00055
00056 inline MyParticle* get_particle2(void) const;
00057
00058 inline TLorentzVector tlv(void) const;
00060
00061 inline double EtaProd(void) const;
00062 inline double DeltaPhi(void) const;
00063 inline double AbsDeltaPhi(void) const;
00064 inline double DeltaR(void) const;
00065 inline double M(void) const;
00066 inline double DeltaEta(void) const;
00067 inline double AbsDeltaEta(void) const;
00068 inline double DeltaPt(void) const;
00069 inline double AbsDeltaPt(void) const;
00070
00071 inline TString get_lepton_flavors(void);
00073
00074 inline void Print(std::string option="");
00076
00077
00078
00079
00080 private:
00081
00082 MyParticle* m_particle1;
00083 MyParticle* m_particle2;
00084
00085
00086
00087 inline void init(MyParticle* particle1,
00088 MyParticle* particle2);
00089
00090
00091
00092
00093 inline TString pdgIdToString(int pdgId);
00095 };
00096
00097
00098
00099
00100
00101 #include "MyParticlePair.ixx"
00102
00103 #endif