#ifndef _DReaction_ #define _DReaction_ #include #include #include #include "JANA/JObject.h" #include "particleType.h" #include "ANALYSIS/DReactionStep.h" #include "ANALYSIS/DKinFitResults.h" using namespace std; using namespace jana; class DAnalysisAction; class DReaction : public JObject { public: JOBJECT_PUBLIC(DReaction); // CONSTRUCTOR: DReaction(string locReactionName); //User must specify a unique reaction name upon construction // DESTRUCTOR: virtual ~DReaction(void); // SET OBJECT DATA: void Set_KinFitType(DKinFitType locKinFitType){dKinFitType = locKinFitType;} void Add_ReactionStep(const DReactionStep* locReactionStep){dReactionSteps.push_back(locReactionStep);} void Clear_ReactionSteps(void){dReactionSteps.clear();} void Add_AnalysisAction(DAnalysisAction* locAnalysisAction){dAnalysisActions.push_back(locAnalysisAction);} // SET PRE-DPARTICLECOMBO CUT VALUES //Command-line values will override these values void Set_MinChargedPIDFOM(double locMinChargedPIDFOM){dMinChargedPIDFOM = pair(true, locMinChargedPIDFOM);} void Set_MinPhotonPIDFOM(double locMinPhotonPIDFOM){dMinPhotonPIDFOM = pair(true, locMinPhotonPIDFOM);} void Set_MaxPhotonRFDeltaT(double locMaxPhotonRFDeltaT){dMaxPhotonRFDeltaT = pair(true, locMaxPhotonRFDeltaT);} void Set_MinProtonMomentum(double locMinProtonMomentum){dMinProtonMomentum = pair(true, locMinProtonMomentum);} void Set_MaxExtraGoodTracks(size_t locMaxExtraGoodTracks){dMaxExtraGoodTracks = pair(true, locMaxExtraGoodTracks);} void Set_MaxNumBeamPhotonsInBunch(size_t locMaxNumBeamPhotonsInBunch){dMaxNumBeamPhotonsInBunch = pair(true, locMaxNumBeamPhotonsInBunch);} // SET PRE-COMBO-BLUEPRINT INVARIANT MASS CUTS void Set_InvariantMassCut(Particle_t locStepInitialPID, double locMinInvariantMass, double locMaxInvariantMass); // SET EventStore QUERY void Set_EventStoreQuery(string locSkimName, string locAdditionalQuery = ""); // ADD COMBO PRE-SELECTION ACTION void Add_ComboPreSelectionAction(DAnalysisAction* locAction){dComboPreSelectionActions.push_back(locAction);} // GET CONTROL MEMBERS: string Get_ReactionName(void) const{return dReactionName;} DKinFitType Get_KinFitType(void) const{return dKinFitType;} // GET REACTION STEPS: size_t Get_NumReactionSteps(void) const{return dReactionSteps.size();} const DReactionStep* Get_ReactionStep(size_t locStepIndex) const; void Get_ReactionSteps(Particle_t locInitialPID, deque& locReactionSteps) const; // GET ANALYSIS ACTIONS: size_t Get_NumAnalysisActions(void) const{return dAnalysisActions.size();} DAnalysisAction* Get_AnalysisAction(size_t locActionIndex) const; DAnalysisAction* Get_LastAnalysisAction(void) const; // GET COMBO PRE-SELECTION CUTS: size_t Get_NumComboPreSelectionActions(void) const{return dComboPreSelectionActions.size();} DAnalysisAction* Get_ComboPreSelectionAction(size_t locActionIndex) const; // GET PIDs: //locChargeFlag: 0/1/2/3/4 for all, charged, neutral, q+, q- particles void Get_DetectedFinalPIDs(deque& locDetectedPIDs, int locChargeFlag = 0, bool locIncludeDuplicatesFlag = false) const; void Get_DetectedFinalPIDs(deque >& locDetectedPIDs, int locChargeFlag = 0, bool locIncludeDuplicatesFlag = false) const; void Get_FinalStatePIDs(deque& locFinalStatePIDs, bool locIncludeDuplicatesFlag = false) const; bool Get_MissingPID(Particle_t& locPID) const; //false if none missing // GET PARTICLE NAME STRINGS: string Get_DetectedParticlesROOTName(void) const; string Get_InitialParticlesROOTName(void) const; string Get_DecayChainFinalParticlesROOTNames(Particle_t locInitialPID, bool locKinFitResultsFlag) const; string Get_DecayChainFinalParticlesROOTNames(Particle_t locInitialPID, int locUpToStepIndex, deque locUpThroughPIDs, bool locKinFitResultsFlag) const; string Get_DecayChainFinalParticlesROOTNames(size_t locStepIndex, int locUpToStepIndex, deque locUpThroughPIDs, bool locKinFitResultsFlag, bool locExpandDecayingParticlesFlag) const; // GET PRE-DPARTICLECOMBO CUT VALUES //Command-line values will override these values pair Get_MinChargedPIDFOM(void) const{return dMinChargedPIDFOM;} pair Get_MinPhotonPIDFOM(void) const{return dMinPhotonPIDFOM;} pair Get_MaxPhotonRFDeltaT(void) const{return dMaxPhotonRFDeltaT;} pair Get_MinProtonMomentum(void) const{return dMinProtonMomentum;} pair Get_MaxExtraGoodTracks(void) const{return dMaxExtraGoodTracks;} pair Get_MaxNumBeamPhotonsInBunch(void) const{return dMaxNumBeamPhotonsInBunch;} // GET PRE-COMBO-BLUEPRINT MASS CUTS bool Get_InvariantMassCut(Particle_t locStepInitialPID, double& locMinInvariantMass, double& locMaxInvariantMass) const; // GET EventStore QUERY pair Get_EventStoreQuery(void) const{return dEventStoreQuery;} // ROOT OUTPUT: void Enable_TTreeOutput(string locTTreeOutputFileName); string Get_TTreeOutputFileName(void) const{return dTTreeOutputFileName;} bool Get_EnableTTreeOutputFlag(void) const{return dEnableTTreeOutputFlag;} void Set_MinThrownMatchFOMForROOT(double locMinThrownMatchFOMForROOT){dMinThrownMatchFOMForROOT = locMinThrownMatchFOMForROOT;} double Get_MinThrownMatchFOMForROOT(void) const{return dMinThrownMatchFOMForROOT;} // OTHER: bool Check_IsDecayingParticle(Particle_t locPID, size_t locSearchStartIndex = 1) const; bool Check_AreStepsIdentical(const DReaction* locReaction) const; private: // PRIVATE METHODS: DReaction(void); //make default constructor private. MUST set a name upon construction (and must be unique!) // CONTROL MEMBERS: string dReactionName; //must be unique DKinFitType dKinFitType; //defined in ANALYSIS/DKinFitResults.h // ROOT TTREE OUTPUT: bool dEnableTTreeOutputFlag; //default is false string dTTreeOutputFileName; double dMinThrownMatchFOMForROOT; //cut applied when setting matching when filling ROOT tree //default is -1 (always passes) // REACTION AND ANALYSIS MEMBERS: deque dReactionSteps; deque dAnalysisActions; // PRE-DPARTICLECOMBO CONTROL-CUT VALUES //bool = true/false for cut enabled/disabled, double = cut value //Command-line values (variable names are below in all-caps) will override these values //all cuts are disabled by default except dMinProtonMomentum: 300 MeV/c (value used during track reconstruction) //note: tracks with no PID information are not cut-by/included-in the PID cuts pair dMinChargedPIDFOM; //COMBO:MIN_CHARGED_PID_FOM - the minimum PID FOM for a particle used for this DReaction pair dMinPhotonPIDFOM; //COMBO:MIN_PHOTON_PID_FOM - the minimum PID FOM for a neutral particle used for this DReaction pair dMaxPhotonRFDeltaT; //COMBO:MAX_PHOTON_RF_DELTAT - the maximum photon-rf time difference: used for photon selection pair dMinProtonMomentum; //COMBO:MIN_PROTON_MOMENTUM - when testing whether a non-proton DChargedTrackHypothesis could be a proton, this is the minimum momentum it can have pair dMaxExtraGoodTracks; //COMBO:MAX_EXTRA_GOOD_TRACKS - "good" defined by PreSelect factory pair dMaxNumBeamPhotonsInBunch; //COMBO:MAX_NUM_BEAM_PHOTONS cut out combos with more than this # of beam photons surviving the RF delta-t cut // PRE-COMBO-BLUEPRINT MASS CUTS map > dInvariantMassCuts; // COMBO PRE-SELECTION CUTS deque dComboPreSelectionActions; // EVENT STORE QUERY pair dEventStoreQuery; // First is skim name (default = "all"), second is additional query (default = "") }; inline void DReaction::Set_InvariantMassCut(Particle_t locStepInitialPID, double locMinInvariantMass, double locMaxInvariantMass) { dInvariantMassCuts[locStepInitialPID] = pair(locMinInvariantMass, locMaxInvariantMass); } inline void DReaction::Set_EventStoreQuery(string locSkimName, string locAdditionalQuery) { dEventStoreQuery = pair(locSkimName, locAdditionalQuery); } inline const DReactionStep* DReaction::Get_ReactionStep(size_t locStepIndex) const { if(locStepIndex >= dReactionSteps.size()) return NULL; return dReactionSteps[locStepIndex]; } inline string DReaction::Get_InitialParticlesROOTName(void) const { if(dReactionSteps.empty()) return (string()); return dReactionSteps[0]->Get_InitialParticlesROOTName(); } inline string DReaction::Get_DecayChainFinalParticlesROOTNames(Particle_t locInitialPID, bool locKinFitResultsFlag) const { //if multiple decay steps have locInitialPID as the parent, only the first listed is used return Get_DecayChainFinalParticlesROOTNames(locInitialPID, -1, deque(), locKinFitResultsFlag); } inline string DReaction::Get_DecayChainFinalParticlesROOTNames(Particle_t locInitialPID, int locUpToStepIndex, deque locUpThroughPIDs, bool locKinFitResultsFlag) const { //if multiple decay steps have locInitialPID as the parent, only the first listed is used deque locPIDs; string locName = ""; for(size_t loc_i = 0; loc_i < dReactionSteps.size(); ++loc_i) { if(dReactionSteps[loc_i]->Get_InitialParticleID() != locInitialPID) continue; return Get_DecayChainFinalParticlesROOTNames(loc_i, locUpToStepIndex, locUpThroughPIDs, locKinFitResultsFlag, false); } return string(""); } inline bool DReaction::Check_IsDecayingParticle(Particle_t locPID, size_t locSearchStartIndex) const { //see if this pid is a parent in a future step for(size_t loc_k = locSearchStartIndex; loc_k < dReactionSteps.size(); ++loc_k) { if(dReactionSteps[loc_k]->Get_InitialParticleID() == locPID) return true; } return false; } inline void DReaction::Get_ReactionSteps(Particle_t locInitialPID, deque& locReactionSteps) const { locReactionSteps.clear(); for(size_t loc_i = 0; loc_i < dReactionSteps.size(); ++loc_i) { if(dReactionSteps[loc_i]->Get_InitialParticleID() == locInitialPID) locReactionSteps.push_back(dReactionSteps[loc_i]); } } inline DAnalysisAction* DReaction::Get_AnalysisAction(size_t locActionIndex) const { if(locActionIndex >= dAnalysisActions.size()) return NULL; return dAnalysisActions[locActionIndex]; } inline DAnalysisAction* DReaction::Get_LastAnalysisAction(void) const { if(dAnalysisActions.empty()) return NULL; return dAnalysisActions.back(); } inline DAnalysisAction* DReaction::Get_ComboPreSelectionAction(size_t locActionIndex) const { if(locActionIndex >= dComboPreSelectionActions.size()) return NULL; return dComboPreSelectionActions[locActionIndex]; } inline bool DReaction::Get_MissingPID(Particle_t& locPID) const { for(size_t loc_i = 0; loc_i < Get_NumReactionSteps(); ++loc_i) { if(Get_ReactionStep(loc_i)->Get_MissingPID(locPID)) return true; } return false; } inline bool DReaction::Check_AreStepsIdentical(const DReaction* locReaction) const { if(locReaction->Get_NumReactionSteps() != dReactionSteps.size()) return false; for(size_t loc_i = 0; loc_i < Get_NumReactionSteps(); ++loc_i) { if(locReaction->Get_ReactionStep(loc_i) != dReactionSteps[loc_i]) return false; } return true; } inline void DReaction::Enable_TTreeOutput(string locTTreeOutputFileName) { dEnableTTreeOutputFlag = true; dTTreeOutputFileName = locTTreeOutputFileName; } inline bool DReaction::Get_InvariantMassCut(Particle_t locStepInitialPID, double& locMinInvariantMass, double& locMaxInvariantMass) const { map >::const_iterator locIterator = dInvariantMassCuts.find(locStepInitialPID); if(locIterator == dInvariantMassCuts.end()) return false; locMinInvariantMass = locIterator->second.first; locMaxInvariantMass = locIterator->second.second; return true; } #endif // _DReaction_