#ifndef _DCutActions_ #define _DCutActions_ #include #include #include #include "TRandom3.h" #include "TMath.h" #include "JANA/JEventLoop.h" #include "particleType.h" #include "TRACKING/DMCThrown.h" #include "PID/DChargedTrackHypothesis.h" #include "PID/DNeutralParticleHypothesis.h" #include "ANALYSIS/DAnalysisAction.h" #include "ANALYSIS/DParticleCombo.h" #include "ANALYSIS/DAnalysisUtilities.h" #include "ANALYSIS/DMCThrownMatching.h" #include "ANALYSIS/DParticleComboBlueprint_factory.h" using namespace jana; using namespace std; /* //CLASSES DEFINED BELOW: DCutAction_PIDFOM DCutAction_AllPIDFOM DCutAction_TruePID DCutAction_AllVertexZ DCutAction_MaxTrackDOCA DCutAction_KinFitFOM DCutAction_MissingMass DCutAction_MissingMassSquared DCutAction_InvariantMass */ class DCutAction_PIDFOM : public DAnalysisAction { public: DCutAction_PIDFOM(const DReaction* locReaction, Particle_t locStepPID, Particle_t locParticleID, double locMinimumConfidenceLevel, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_PIDFOM", false, locActionUniqueString), dStepPID(locStepPID), dParticleID(locParticleID), dMinimumConfidenceLevel(locMinimumConfidenceLevel){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} Particle_t dStepPID; Particle_t dParticleID; double dMinimumConfidenceLevel; }; class DCutAction_AllPIDFOM : public DAnalysisAction { public: DCutAction_AllPIDFOM(const DReaction* locReaction, double locMinimumConfidenceLevel, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_AllPIDFOM", false, locActionUniqueString), dMinimumConfidenceLevel(locMinimumConfidenceLevel){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} double dMinimumConfidenceLevel; }; class DCutAction_MissingMass : public DAnalysisAction { public: DCutAction_MissingMass(const DReaction* locReaction, bool locUseKinFitResultsFlag, double locMinimumMissingMass, double locMaximumMissingMass, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_MissingMass", locUseKinFitResultsFlag, locActionUniqueString), dMinimumMissingMass(locMinimumMissingMass), dMaximumMissingMass(locMaximumMissingMass){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} double dMinimumMissingMass; double dMaximumMissingMass; }; class DCutAction_MissingMassSquared : public DAnalysisAction { public: DCutAction_MissingMassSquared(const DReaction* locReaction, bool locUseKinFitResultsFlag, double locMinimumMissingMassSq, double locMaximumMissingMassSq, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_MissingMassSq", locUseKinFitResultsFlag, locActionUniqueString), dMinimumMissingMassSq(locMinimumMissingMassSq), dMaximumMissingMassSq(locMaximumMissingMassSq){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} double dMinimumMissingMassSq; double dMaximumMissingMassSq; }; class DCutAction_InvariantMass : public DAnalysisAction { public: DCutAction_InvariantMass(const DReaction* locReaction, Particle_t locInitialPID, bool locUseKinFitResultsFlag, double locMinimumInvariantMass, double locMaximumInvariantMass, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_InvariantMass", locUseKinFitResultsFlag, locActionUniqueString), dInitialPID(locInitialPID), dMinimumInvariantMass(locMinimumInvariantMass), dMaximumInvariantMass(locMaximumInvariantMass){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} Particle_t dInitialPID; double dMinimumInvariantMass; double dMaximumInvariantMass; }; class DCutAction_AllVertexZ : public DAnalysisAction { public: DCutAction_AllVertexZ(const DReaction* locReaction, double locMinVertexZ, double locMaxVertexZ, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_AllVertexZ", false, locActionUniqueString), dMinVertexZ(locMinVertexZ), dMaxVertexZ(locMaxVertexZ){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} double dMinVertexZ; double dMaxVertexZ; }; class DCutAction_MaxTrackDOCA : public DAnalysisAction { public: DCutAction_MaxTrackDOCA(const DReaction* locReaction, Particle_t locInitialPID, double locMaxTrackDOCA, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_MaxTrackDOCA", false, locActionUniqueString), dInitialPID(locInitialPID), dMaxTrackDOCA(locMaxTrackDOCA){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} Particle_t dInitialPID; double dMaxTrackDOCA; }; class DCutAction_KinFitFOM : public DAnalysisAction { public: DCutAction_KinFitFOM(const DReaction* locReaction, double locMinimumConfidenceLevel, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_KinFitFOM", true, locActionUniqueString), dMinimumConfidenceLevel(locMinimumConfidenceLevel){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} const string dKinFitName; double dMinimumConfidenceLevel; }; class DCutAction_TruePID : public DAnalysisAction { public: DCutAction_TruePID(const DReaction* locReaction, Particle_t locTruePID, Particle_t locInitialPID, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_TruePID", false, locActionUniqueString), dTruePID(locTruePID), dInitialPID(locInitialPID){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} Particle_t dTruePID; Particle_t dInitialPID; }; class DCutAction_AllTruePID : public DAnalysisAction { public: DCutAction_AllTruePID(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Cut_AllTruePID", false, locActionUniqueString){} private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo, const deque >& locPreviousParticleCombos); inline void Initialize(JEventLoop* locEventLoop){} }; #endif // _DCutActions_