#ifndef _DHistogramActions_ #define _DHistogramActions_ #include #include #include #include #include #include #include #include "TROOT.h" #include "TDirectoryFile.h" #include "TH1D.h" #include "TH2D.h" #include "TTree.h" #include "JANA/JEventLoop.h" #include "particleType.h" #include "PID/DChargedTrack.h" #include "PID/DChargedTrackHypothesis.h" #include "PID/DNeutralParticle.h" #include "PID/DNeutralShower.h" #include "PID/DDetectorMatches.h" #include "PID/DNeutralParticleHypothesis.h" #include "PID/DEventRFBunch.h" #include "TRACKING/DMCThrown.h" #include "ANALYSIS/DReaction.h" #include "ANALYSIS/DKinFitParticle.h" #include "ANALYSIS/DMCThrownMatching.h" #include "ANALYSIS/DMCThrownMatching_factory.h" #include "ANALYSIS/DParticleCombo.h" #include "ANALYSIS/DAnalysisUtilities.h" #include "ANALYSIS/DAnalysisAction.h" #include "ANALYSIS/DCutActions.h" #include "START_COUNTER/DSCHit.h" #include "CDC/DCDCHit.h" #include "FDC/DFDCHit.h" #include "TOF/DTOFPoint.h" #include "TOF/DTOFHit.h" #include "TOF/DTOFTruth.h" #include "BCAL/DBCALShower.h" #include "BCAL/DBCALHit.h" #include "BCAL/DBCALTruthShower.h" #include "FCAL/DFCALShower.h" #include "FCAL/DFCALHit.h" #include "FCAL/DFCALTruthShower.h" #include "TRACKING/DTrackTimeBased.h" #include "TRACKING/DTrackWireBased.h" #include "TRACKING/DTrackCandidate.h" using namespace std; using namespace jana; /* REACTION-BASED ACTIONS: DHistogramAction_NumParticleCombos DHistogramAction_ParticleComboKinematics DHistogramAction_PID DHistogramAction_TruePID DHistogramAction_TrackVertexComparison DHistogramAction_KinFitResults DHistogramAction_InvariantMass DHistogramAction_MissingMass DHistogramAction_MissingMassSquared REACTION-INDEPENDENT ACTIONS: DHistogramAction_TrackMultiplicity DHistogramAction_ThrownParticleKinematics DHistogramAction_ReconnedThrownKinematics DHistogramAction_DetectedParticleKinematics DHistogramAction_GenReconTrackComparison DHistogramAction_TOFHitStudy DHistogramAction_NumReconstructedObjects */ class DHistogramAction_NumParticleCombos : public DAnalysisAction { public: DHistogramAction_NumParticleCombos(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_NumParticleCombos", false, locActionUniqueString), dNumComboBins(1000) {} void Initialize(JEventLoop* locEventLoop); unsigned int dNumComboBins; private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); TH1D* dHist_NumParticleCombos; }; class DHistogramAction_PID : public DAnalysisAction { public: DHistogramAction_PID(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_PID", false, locActionUniqueString), dNumFOMBins(200), dNumBetaBins(400), dNumDeltaBetaBins(400), dNum2DPBins(300), dNum2DThetaBins(140), dNumPullBins(1000), dNum2DPullBins(500), dMinBeta(-0.2), dMaxBeta(1.2), dMinDeltaBeta(-1.0), dMaxDeltaBeta(1.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(150.0), dMinThrownMatchFOM(5.73303E-7) { dThrownPIDs.clear(); dThrownPIDs.push_back(Gamma); dThrownPIDs.push_back(Neutron); dThrownPIDs.push_back(PiPlus); dThrownPIDs.push_back(KPlus); dThrownPIDs.push_back(Proton); dThrownPIDs.push_back(PiMinus); dThrownPIDs.push_back(KMinus); dThrownPIDs.push_back(Electron); dThrownPIDs.push_back(MuonMinus); } void Initialize(JEventLoop* locEventLoop); unsigned int dNumFOMBins, dNumBetaBins, dNumDeltaBetaBins, dNum2DPBins, dNum2DThetaBins, dNumPullBins, dNum2DPullBins; double dMinBeta, dMaxBeta, dMinDeltaBeta, dMaxDeltaBeta, dMinP, dMaxP, dMinTheta, dMaxTheta; double dMinThrownMatchFOM; deque dThrownPIDs; private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); void Fill_ChargedHists(const DChargedTrackHypothesis* locChargedTrackHypothesis, const DMCThrownMatching* locMCThrownMatching, const DEventRFBunch* locEventRFBunch); void Fill_NeutralHists(const DNeutralParticleHypothesis* locNeutralParticleHypothesis, const DMCThrownMatching* locMCThrownMatching, const DEventRFBunch* locEventRFBunch); const DParticleID* dParticleID; const DAnalysisUtilities* dAnalysisUtilities; map dHistMap_PIDFOM; map dHistMap_TOFFOM_BCAL; map dHistMap_TOFFOM_FCAL; map dHistMap_TOFFOM_TOF; map dHistMap_TOFFOM_CDC; map dHistMap_DCdEdxFOM; map dHistMap_BetaVsP; map dHistMap_DeltaBetaVsP; map dHistMap_TOFFOMVsDeltaBeta; map dHistMap_TimePull_CDC; map dHistMap_TimePull_BCAL; map dHistMap_TimePull_TOF; map dHistMap_TimePull_FCAL; map dHistMap_TimePullVsTheta_CDC; map dHistMap_TimePullVsP_CDC; map dHistMap_TimePullVsTheta_BCAL; map dHistMap_TimePullVsP_BCAL; map dHistMap_TimePullVsP_TOF; map dHistMap_TimePullVsP_FCAL; map dHistMap_PVsTheta_LowPIDFOM; map dHistMap_PVsTheta_NaNPIDFOM; map dHistMap_PVsTheta_LowTOFFOM; map dHistMap_PVsTheta_NaNTOFFOM; map dHistMap_PVsTheta_NegativeBeta; map dHistMap_PVsTheta_LowDCdEdxFOM; map dHistMap_PVsTheta_NaNDCdEdxFOM; map, TH1D*> dHistMap_PIDFOMForTruePID; set > > dPreviouslyHistogrammedParticles; //to prevent double-counting (JObject is source object) }; class DHistogramAction_TrackVertexComparison : public DAnalysisAction { public: DHistogramAction_TrackVertexComparison(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_TrackVertexComparison", false, locActionUniqueString), dNumDeltaVertexZBins(200), dNumDeltaVertexTBins(100), dNumDOCABins(100), dNum2DPBins(300), dNumThetaBins(300), dMinDeltaVertexZ(-10.0), dMaxDeltaVertexZ(10.0), dMinDeltaVertexT(-5.0), dMaxDeltaVertexT(5.0), dMinDOCA(0.0), dMaxDOCA(10.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(150.0){} unsigned int dNumDeltaVertexZBins, dNumDeltaVertexTBins, dNumDOCABins, dNum2DPBins, dNumThetaBins; double dMinDeltaVertexZ, dMaxDeltaVertexZ, dMinDeltaVertexT, dMaxDeltaVertexT, dMinDOCA, dMaxDOCA, dMinP, dMaxP, dMinTheta, dMaxTheta; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); const DAnalysisUtilities* dAnalysisUtilities; //should be improved...: the particles at a given vertex may span several steps deque > dHistDeque_TrackZToCommon; //dim is step deque > dHistDeque_TrackTToCommon; //dim is step deque > dHistDeque_TrackDOCAToCommon; //dim is step deque dHistDeque_MaxTrackDeltaZ; deque dHistDeque_MaxTrackDeltaT; deque dHistDeque_MaxTrackDOCA; deque, TH2D*> > dHistDeque_TrackDeltaTVsP; //one hist per track pair, more massive particle is listed first, p is that of the more massive particle (generally slower: worse projected resolution) map dHistMap_BeamTrackDeltaTVsP; }; class DHistogramAction_ParticleComboKinematics : public DAnalysisAction { public: DHistogramAction_ParticleComboKinematics(const DReaction* locReaction, bool locUseKinFitResultsFlag, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_ParticleComboKinematics", locUseKinFitResultsFlag, locActionUniqueString), dNumPBins(600), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(200), dNumVertexXYBins(200), dNumBetaBins(400), dNumDeltaBetaBins(400), dNum2DPBins(300), dNum2DThetaBins(140), dNum2DPhiBins(180), dNumDeltaTRFBins(500), dMinT(-5.0), dMaxT(5.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-5.0), dMaxVertexXY(5.0), dMinBeta(-0.2), dMaxBeta(1.2), dMinDeltaBeta(-1.0), dMaxDeltaBeta(1.0), dMinDeltaTRF(-10.0), dMaxDeltaTRF(10.0){} unsigned int dNumPBins, dNumThetaBins, dNumPhiBins, dNumVertexZBins, dNumTBins, dNumVertexXYBins, dNumBetaBins, dNumDeltaBetaBins, dNum2DPBins, dNum2DThetaBins, dNum2DPhiBins, dNumDeltaTRFBins; double dMinT, dMaxT, dMinP, dMaxP, dMinTheta, dMaxTheta, dMinPhi, dMaxPhi, dMinVertexZ, dMaxVertexZ, dMinVertexXY, dMaxVertexXY, dMinBeta, dMaxBeta, dMinDeltaBeta, dMaxDeltaBeta, dMinDeltaTRF, dMaxDeltaTRF; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); void Fill_Hists(JEventLoop* locEventLoop, const DKinematicData* locKinematicData, const DEventRFBunch* locEventRFBunch, size_t locStepIndex); void Fill_BeamHists(const DKinematicData* locKinematicData, const DEventRFBunch* locEventRFBunch); const DParticleID* dParticleID; double dTargetZCenter; const DAnalysisUtilities* dAnalysisUtilities; TH2D* dBeamParticleHist_PVsTheta; TH2D* dBeamParticleHist_PhiVsTheta; TH1D* dBeamParticleHist_P; TH1D* dBeamParticleHist_Theta; TH1D* dBeamParticleHist_Phi; TH1D* dBeamParticleHist_VertexZ; TH1D* dBeamParticleHist_VertexT; TH2D* dBeamParticleHist_VertexYVsX; TH1D* dBeamParticleHist_DeltaTRF; TH2D* dBeamParticleHist_DeltaTRFVsBeamE; deque > dHistDeque_PVsTheta; deque > dHistDeque_BetaVsP; deque > dHistDeque_DeltaBetaVsP; deque > dHistDeque_PhiVsTheta; deque > dHistDeque_P; deque > dHistDeque_Theta; deque > dHistDeque_Phi; deque > dHistDeque_VertexZ; deque > dHistDeque_VertexT; deque > dHistDeque_VertexYVsX; deque dHistDeque_MaxTrackDeltaZ; deque dHistDeque_MaxTrackDeltaT; deque dHistDeque_MaxTrackDOCA; set dPreviouslyHistogrammedBeamParticles; set > > dPreviouslyHistogrammedParticles; }; class DHistogramAction_ThrownParticleKinematics : public DAnalysisAction { public: DHistogramAction_ThrownParticleKinematics(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_ThrownParticleKinematics", false, locActionUniqueString), dNumPBins(1200), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(800), dNumVertexXYBins(400), dNum2DPBins(1200), dNum2DThetaBins(140), dNum2DPhiBins(180), dMinT(-20.0), dMaxT(20.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-10.0), dMaxVertexXY(10.0) { dFinalStatePIDs.clear(); dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dFinalStatePIDs.push_back(Electron); dFinalStatePIDs.push_back(MuonMinus); } DHistogramAction_ThrownParticleKinematics(string locActionUniqueString) : DAnalysisAction(NULL, "Hist_ThrownParticleKinematics", false, locActionUniqueString), dNumPBins(1200), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(800), dNumVertexXYBins(400), dNum2DPBins(1200), dNum2DThetaBins(140), dNum2DPhiBins(180), dMinT(-20.0), dMaxT(20.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-10.0), dMaxVertexXY(10.0) { dFinalStatePIDs.clear(); dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dFinalStatePIDs.push_back(Electron); dFinalStatePIDs.push_back(MuonMinus); } DHistogramAction_ThrownParticleKinematics(void) : DAnalysisAction(NULL, "Hist_ThrownParticleKinematics", false, ""), dNumPBins(1200), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(800), dNumVertexXYBins(400), dNum2DPBins(1200), dNum2DThetaBins(140), dNum2DPhiBins(180), dMinT(-20.0), dMaxT(20.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-10.0), dMaxVertexXY(10.0) { dFinalStatePIDs.clear(); dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dFinalStatePIDs.push_back(Electron); dFinalStatePIDs.push_back(MuonMinus); } unsigned int dNumPBins, dNumThetaBins, dNumPhiBins, dNumVertexZBins, dNumTBins, dNumVertexXYBins, dNum2DPBins, dNum2DThetaBins, dNum2DPhiBins; double dMinT, dMaxT, dMinP, dMaxP, dMinTheta, dMaxTheta, dMinPhi, dMaxPhi, dMinVertexZ, dMaxVertexZ, dMinVertexXY, dMaxVertexXY; deque dFinalStatePIDs; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo = NULL); TH1D* dBeamParticle_P; map dHistMap_PVsTheta; map dHistMap_PhiVsTheta; map dHistMap_P; map dHistMap_Theta; map dHistMap_Phi; map dHistMap_VertexZ; map dHistMap_VertexYVsX; map dHistMap_VertexT; }; class DHistogramAction_ReconnedThrownKinematics : public DAnalysisAction { public: DHistogramAction_ReconnedThrownKinematics(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_ReconnedThrownKinematics", false, locActionUniqueString), dMinThrownMatchFOM(5.73303E-7), dNumPBins(1200), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(800), dNumVertexXYBins(400), dNum2DPBins(1200), dNum2DThetaBins(140), dNum2DPhiBins(180), dMinT(-20.0), dMaxT(20.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-10.0), dMaxVertexXY(10.0) { dFinalStatePIDs.clear(); dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dFinalStatePIDs.push_back(Electron); dFinalStatePIDs.push_back(MuonMinus); } DHistogramAction_ReconnedThrownKinematics(string locActionUniqueString) : DAnalysisAction(NULL, "Hist_ReconnedThrownKinematics", false, locActionUniqueString), dMinThrownMatchFOM(5.73303E-7), dNumPBins(1200), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(800), dNumVertexXYBins(400), dNum2DPBins(1200), dNum2DThetaBins(140), dNum2DPhiBins(180), dMinT(-20.0), dMaxT(20.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-10.0), dMaxVertexXY(10.0) { dFinalStatePIDs.clear(); dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dFinalStatePIDs.push_back(Electron); dFinalStatePIDs.push_back(MuonMinus); } DHistogramAction_ReconnedThrownKinematics(void) : DAnalysisAction(NULL, "Hist_ReconnedThrownKinematics", false, ""), dMinThrownMatchFOM(5.73303E-7), dNumPBins(1200), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(800), dNumVertexXYBins(400), dNum2DPBins(1200), dNum2DThetaBins(140), dNum2DPhiBins(180), dMinT(-20.0), dMaxT(20.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-10.0), dMaxVertexXY(10.0) { dFinalStatePIDs.clear(); dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dFinalStatePIDs.push_back(Electron); dFinalStatePIDs.push_back(MuonMinus); } double dMinThrownMatchFOM; unsigned int dNumPBins, dNumThetaBins, dNumPhiBins, dNumVertexZBins, dNumTBins, dNumVertexXYBins, dNum2DPBins, dNum2DThetaBins, dNum2DPhiBins; double dMinT, dMaxT, dMinP, dMaxP, dMinTheta, dMaxTheta, dMinPhi, dMaxPhi, dMinVertexZ, dMaxVertexZ, dMinVertexXY, dMaxVertexXY; deque dFinalStatePIDs; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo = NULL); TH1D* dBeamParticle_P; map dHistMap_PVsTheta; map dHistMap_PhiVsTheta; map dHistMap_P; map dHistMap_Theta; map dHistMap_Phi; map dHistMap_VertexZ; map dHistMap_VertexYVsX; map dHistMap_VertexT; }; class DHistogramAction_DetectedParticleKinematics : public DAnalysisAction { public: DHistogramAction_DetectedParticleKinematics(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_DetectedParticleKinematics", false, locActionUniqueString), dMinimumPIDFOM(5.73303E-7), dMinimumTrackingFOM(5.73303E-7), dNumPBins(1200), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(800), dNumVertexXYBins(400), dNumBetaBins(400), dNumDeltaBetaBins(400), dNum2DPBins(1200), dNum2DThetaBins(140), dNum2DPhiBins(180), dNumTrackFOMBins(250), dNum2DVertexZBins(200), dMinT(-20.0), dMaxT(20.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-10.0), dMaxVertexXY(10.0), dMinBeta(-0.2), dMaxBeta(1.2), dMinDeltaBeta(-1.0), dMaxDeltaBeta(1.0) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dFinalStatePIDs.push_back(Electron); dFinalStatePIDs.push_back(MuonMinus); } DHistogramAction_DetectedParticleKinematics(string locActionUniqueString) : DAnalysisAction(NULL, "Hist_DetectedParticleKinematics", false, locActionUniqueString), dMinimumPIDFOM(5.73303E-7), dMinimumTrackingFOM(5.73303E-7), dNumPBins(1200), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(800), dNumVertexXYBins(400), dNumBetaBins(400), dNumDeltaBetaBins(400), dNum2DPBins(1200), dNum2DThetaBins(140), dNum2DPhiBins(180), dNumTrackFOMBins(250), dNum2DVertexZBins(200), dMinT(-20.0), dMaxT(20.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-10.0), dMaxVertexXY(10.0), dMinBeta(-0.2), dMaxBeta(1.2), dMinDeltaBeta(-1.0), dMaxDeltaBeta(1.0) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dFinalStatePIDs.push_back(Electron); dFinalStatePIDs.push_back(MuonMinus); } DHistogramAction_DetectedParticleKinematics(void) : DAnalysisAction(NULL, "Hist_DetectedParticleKinematics", false, ""), dMinimumPIDFOM(5.73303E-7), dMinimumTrackingFOM(5.73303E-7), dNumPBins(1200), dNumThetaBins(560), dNumPhiBins(360), dNumVertexZBins(600), dNumTBins(800), dNumVertexXYBins(400), dNumBetaBins(400), dNumDeltaBetaBins(400), dNum2DPBins(1200), dNum2DThetaBins(140), dNum2DPhiBins(180), dNumTrackFOMBins(250), dNum2DVertexZBins(200), dMinT(-20.0), dMaxT(20.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinPhi(-180.0), dMaxPhi(180.0), dMinVertexZ(0.0), dMaxVertexZ(200.0), dMinVertexXY(-10.0), dMaxVertexXY(10.0), dMinBeta(-0.2), dMaxBeta(1.2), dMinDeltaBeta(-1.0), dMaxDeltaBeta(1.0) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dFinalStatePIDs.push_back(Electron); dFinalStatePIDs.push_back(MuonMinus); } double dMinimumPIDFOM, dMinimumTrackingFOM; unsigned int dNumPBins, dNumThetaBins, dNumPhiBins, dNumVertexZBins, dNumTBins, dNumVertexXYBins, dNumBetaBins, dNumDeltaBetaBins, dNum2DPBins, dNum2DThetaBins, dNum2DPhiBins, dNumTrackFOMBins, dNum2DVertexZBins; double dMinT, dMaxT, dMinP, dMaxP, dMinTheta, dMaxTheta, dMinPhi, dMaxPhi, dMinVertexZ, dMaxVertexZ, dMinVertexXY, dMaxVertexXY, dMinBeta, dMaxBeta, dMinDeltaBeta, dMaxDeltaBeta; deque dFinalStatePIDs; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); const DParticleID* dParticleID; const DAnalysisUtilities* dAnalysisUtilities; TH1D* dBeamParticle_P; map dHistMap_PVsTheta; map dHistMap_PhiVsTheta; map dHistMap_BetaVsP; map dHistMap_DeltaBetaVsP; map dHistMap_P; map dHistMap_Theta; map dHistMap_Phi; map dHistMap_VertexZ; map dHistMap_TrackingFOMVsVertexZ; map dHistMap_VertexZVsTheta; map dHistMap_VertexYVsX; map dHistMap_VertexT; }; class DHistogramAction_GenReconTrackComparison : public DAnalysisAction { public: DHistogramAction_GenReconTrackComparison(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_GenReconTrackComparison", false, locActionUniqueString), dNumDeltaPOverPBins(500), dNumDeltaThetaBins(240), dNumDeltaPhiBins(400), dNumDeltaTBins(500), dNumDeltaVertexZBins(300), dNum2DPBins(600), dNum2DThetaBins(140), dNumRFDeltaTBins(202), dNumPullBins(1000), dNum2DPullBins(500), dMinDeltaPOverP(-0.4), dMaxDeltaPOverP(0.4), dMinDeltaTheta(-1.0), dMaxDeltaTheta(1.0), dMinDeltaPhi(-6.0), dMaxDeltaPhi(6.0), dMinDeltaT(-5.0), dMaxDeltaT(5.0), dMinDeltaVertexZ(-15.0), dMaxDeltaVertexZ(15.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinRFDeltaT(-10.1), dMaxRFDeltaT(10.1) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dPullTypes.resize(8); dPullTypes[0] = d_EPull; dPullTypes[1] = d_PxPull; dPullTypes[2] = d_PyPull; dPullTypes[3] = d_PzPull; dPullTypes[4] = d_XxPull; dPullTypes[5] = d_XyPull; dPullTypes[6] = d_XzPull; dPullTypes[7] = d_TPull; } DHistogramAction_GenReconTrackComparison(string locActionUniqueString) : DAnalysisAction(NULL, "Hist_GenReconTrackComparison", false, locActionUniqueString), dNumDeltaPOverPBins(500), dNumDeltaThetaBins(240), dNumDeltaPhiBins(400), dNumDeltaTBins(500), dNumDeltaVertexZBins(300), dNum2DPBins(600), dNum2DThetaBins(140), dNumRFDeltaTBins(202), dNumPullBins(1000), dNum2DPullBins(500), dMinDeltaPOverP(-0.4), dMaxDeltaPOverP(0.4), dMinDeltaTheta(-1.0), dMaxDeltaTheta(1.0), dMinDeltaPhi(-6.0), dMaxDeltaPhi(6.0), dMinDeltaT(-5.0), dMaxDeltaT(5.0), dMinDeltaVertexZ(-15.0), dMaxDeltaVertexZ(15.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinRFDeltaT(-10.1), dMaxRFDeltaT(10.1) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dPullTypes.resize(8); dPullTypes[0] = d_EPull; dPullTypes[1] = d_PxPull; dPullTypes[2] = d_PyPull; dPullTypes[3] = d_PzPull; dPullTypes[4] = d_XxPull; dPullTypes[5] = d_XyPull; dPullTypes[6] = d_XzPull; dPullTypes[7] = d_TPull; } DHistogramAction_GenReconTrackComparison(void) : DAnalysisAction(NULL, "Hist_GenReconTrackComparison", false, ""), dNumDeltaPOverPBins(500), dNumDeltaThetaBins(240), dNumDeltaPhiBins(400), dNumDeltaTBins(500), dNumDeltaVertexZBins(300), dNum2DPBins(600), dNum2DThetaBins(140), dNumRFDeltaTBins(202), dNumPullBins(1000), dNum2DPullBins(500), dMinDeltaPOverP(-0.4), dMaxDeltaPOverP(0.4), dMinDeltaTheta(-1.0), dMaxDeltaTheta(1.0), dMinDeltaPhi(-6.0), dMaxDeltaPhi(6.0), dMinDeltaT(-5.0), dMaxDeltaT(5.0), dMinDeltaVertexZ(-15.0), dMaxDeltaVertexZ(15.0), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dMinRFDeltaT(-10.1), dMaxRFDeltaT(10.1) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); dPullTypes.resize(8); dPullTypes[0] = d_EPull; dPullTypes[1] = d_PxPull; dPullTypes[2] = d_PyPull; dPullTypes[3] = d_PzPull; dPullTypes[4] = d_XxPull; dPullTypes[5] = d_XyPull; dPullTypes[6] = d_XzPull; dPullTypes[7] = d_TPull; } unsigned int dNumDeltaPOverPBins, dNumDeltaThetaBins, dNumDeltaPhiBins, dNumDeltaTBins, dNumDeltaVertexZBins, dNum2DPBins, dNum2DThetaBins, dNumRFDeltaTBins, dNumPullBins, dNum2DPullBins; double dMinDeltaPOverP, dMaxDeltaPOverP, dMinDeltaTheta, dMaxDeltaTheta, dMinDeltaPhi, dMaxDeltaPhi, dMinDeltaT, dMaxDeltaT, dMinDeltaVertexZ, dMaxDeltaVertexZ; double dMinP, dMaxP, dMinTheta, dMaxTheta, dMinRFDeltaT, dMaxRFDeltaT; deque dFinalStatePIDs; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo = NULL); deque dPullTypes; double dTargetZCenter; TH1D* dRFBeamBunchDeltaT_Hist; map dHistMap_DeltaPOverP; map dHistMap_DeltaTheta; map dHistMap_DeltaPhi; map dHistMap_DeltaT; map dHistMap_DeltaT_TOF; map dHistMap_DeltaT_BCAL; map dHistMap_DeltaT_FCAL; map dHistMap_DeltaVertexZ; map dHistMap_DeltaPOverPVsP; map dHistMap_DeltaPOverPVsTheta; map dHistMap_DeltaThetaVsP; map dHistMap_DeltaThetaVsTheta; map dHistMap_DeltaPhiVsP; map dHistMap_DeltaPhiVsTheta; map dHistMap_DeltaTVsTheta; map dHistMap_DeltaTVsP; map dHistMap_DeltaVertexZVsTheta; map dHistMap_PVsTheta_LargeDeltaT; map > dHistMap_Pulls; map > dHistMap_PullsVsP; map > dHistMap_PullsVsTheta; map dHistMap_TimePull_CDC; map dHistMap_TimePull_ST; map dHistMap_TimePull_BCAL; map dHistMap_TimePull_TOF; map dHistMap_TimePull_FCAL; map dHistMap_TimePullVsTheta_CDC; map dHistMap_TimePullVsTheta_BCAL; map dHistMap_TimePullVsTheta_ST; map dHistMap_TimePullVsP_CDC; map dHistMap_TimePullVsP_BCAL; map dHistMap_TimePullVsP_ST; map dHistMap_TimePullVsP_TOF; map dHistMap_TimePullVsP_FCAL; }; class DHistogramAction_TOFHitStudy : public DAnalysisAction { public: DHistogramAction_TOFHitStudy(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_TOFHitStudy", false, locActionUniqueString), dNumDeltaTBins(400), dNumDeltaXBins(400), dNumdEBins(400), dNum2DPBins(400), dMinDeltaT(-1.0), dMaxDeltaT(1.0), dMinDeltaX(-6.0), dMaxDeltaX(6.0), dMindE(3.0), dMaxdE(20.0), dMinP(0.0), dMaxP(12.0) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); } DHistogramAction_TOFHitStudy(string locActionUniqueString) : DAnalysisAction(NULL, "Hist_TOFHitStudy", false, locActionUniqueString), dNumDeltaTBins(400), dNumDeltaXBins(400), dNumdEBins(400), dNum2DPBins(400), dMinDeltaT(-1.0), dMaxDeltaT(1.0), dMinDeltaX(-6.0), dMaxDeltaX(6.0), dMindE(3.0), dMaxdE(20.0), dMinP(0.0), dMaxP(12.0) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); } DHistogramAction_TOFHitStudy(void) : DAnalysisAction(NULL, "Hist_TOFHitStudy", false, ""), dNumDeltaTBins(400), dNumDeltaXBins(400), dNumdEBins(400), dNum2DPBins(400), dMinDeltaT(-1.0), dMaxDeltaT(1.0), dMinDeltaX(-6.0), dMaxDeltaX(6.0), dMindE(3.0), dMaxdE(20.0), dMinP(0.0), dMaxP(12.0) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); } unsigned int dNumDeltaTBins, dNumDeltaXBins, dNumdEBins, dNum2DPBins; double dMinDeltaT, dMaxDeltaT, dMinDeltaX, dMaxDeltaX, dMindE, dMaxdE, dMinP, dMaxP; deque dFinalStatePIDs; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo = NULL); map dHistMap_DeltaT; map dHistMap_DeltaX; map dHistMap_DeltaY; map dHistMap_dE; map dHistMap_DeltaTVsP; map dHistMap_DeltaXVsP; map dHistMap_DeltaYVsP; map dHistMap_dEVsP; }; class DHistogramAction_NumReconstructedObjects : public DAnalysisAction { public: DHistogramAction_NumReconstructedObjects(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_NumReconstructedObjects", false, locActionUniqueString), dMaxNumObjects(40), dMaxNumCDCHits(400), dMaxNumFDCHits(2000), dMaxNumTOFCalorimeterHits(400){} DHistogramAction_NumReconstructedObjects(string locActionUniqueString) : DAnalysisAction(NULL, "Hist_NumReconstructedObjects", false, ""), dMaxNumObjects(40), dMaxNumCDCHits(400), dMaxNumFDCHits(2000), dMaxNumTOFCalorimeterHits(400){} DHistogramAction_NumReconstructedObjects(void) : DAnalysisAction(NULL, "Hist_NumReconstructedObjects", false, ""), dMaxNumObjects(40), dMaxNumCDCHits(400), dMaxNumFDCHits(2000), dMaxNumTOFCalorimeterHits(400){} unsigned int dMaxNumObjects; unsigned int dMaxNumCDCHits; unsigned int dMaxNumFDCHits; unsigned int dMaxNumTOFCalorimeterHits; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo = NULL); TH1D* dHist_NumPosTimeBasedTracks; TH1D* dHist_NumNegTimeBasedTracks; TH1D* dHist_NumPosWireBasedTracks; TH1D* dHist_NumNegWireBasedTracks; TH1D* dHist_NumPosTrackCandidates; TH1D* dHist_NumNegTrackCandidates; TH1D* dHist_NumPosTrackCandidates_CDC; TH1D* dHist_NumNegTrackCandidates_CDC; TH1D* dHist_NumPosTrackCandidates_FDC; TH1D* dHist_NumNegTrackCandidates_FDC; TH1D* dHist_NumBeamPhotons; TH1D* dHist_NumFCALShowers; TH1D* dHist_NumBCALShowers; TH1D* dHist_NumNeutralShowers; TH1D* dHist_NumTOFPoints; TH1D* dHist_NumSCHits; TH1D* dHist_NumTrackBCALMatches; TH1D* dHist_NumTrackFCALMatches; TH1D* dHist_NumTrackTOFMatches; TH1D* dHist_NumTrackSCMatches; TH1D* dHist_NumCDCHits; TH1D* dHist_NumFDCHits; TH1D* dHist_NumTOFHits; TH1D* dHist_NumBCALHits; TH1D* dHist_NumFCALHits; }; class DHistogramAction_TrackMultiplicity : public DAnalysisAction { public: DHistogramAction_TrackMultiplicity(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_TrackMultiplicity", false, locActionUniqueString), dMaxNumTracks(40), dMinThrownMatchFOM(5.73303E-7) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); } DHistogramAction_TrackMultiplicity(string locActionUniqueString) : DAnalysisAction(NULL, "Hist_TrackMultiplicity", false, ""), dMaxNumTracks(40), dMinThrownMatchFOM(5.73303E-7) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); } DHistogramAction_TrackMultiplicity(void) : DAnalysisAction(NULL, "Hist_TrackMultiplicity", false, ""), dMaxNumTracks(40), dMinThrownMatchFOM(5.73303E-7) { dFinalStatePIDs.push_back(Gamma); dFinalStatePIDs.push_back(Neutron); dFinalStatePIDs.push_back(PiPlus); dFinalStatePIDs.push_back(KPlus); dFinalStatePIDs.push_back(Proton); dFinalStatePIDs.push_back(PiMinus); dFinalStatePIDs.push_back(KMinus); } unsigned int dMaxNumTracks; double dMinThrownMatchFOM; deque dFinalStatePIDs; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo = NULL); TH2D* dHist_NumReconstructedTracks; }; class DHistogramAction_TruePID : public DAnalysisAction { public: DHistogramAction_TruePID(const DReaction* locReaction, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_TruePID", false, locActionUniqueString), dNumPBins(300), dNum2DPBins(150), dNumThetaBins(140), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dInitialPID(Unknown), dMinMassSq(1.0), dMaxMassSq(0.0), dMinThrownMatchFOM(-1.0){} DHistogramAction_TruePID(const DReaction* locReaction, Particle_t locInitialPID, double locMinMassSq, double locMaxMassSq, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_TruePID", false, locActionUniqueString), dNumPBins(300), dNum2DPBins(150), dNumThetaBins(140), dMinP(0.0), dMaxP(12.0), dMinTheta(0.0), dMaxTheta(140.0), dInitialPID(locInitialPID), dMinMassSq(locMinMassSq), dMaxMassSq(locMaxMassSq), dMinThrownMatchFOM(-1.0){} unsigned int dNumPBins, dNum2DPBins, dNumThetaBins; double dMinP, dMaxP, dMinTheta, dMaxTheta; private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); void Initialize(JEventLoop* locEventLoop); Particle_t dInitialPID; double dMinMassSq, dMaxMassSq; public: double dMinThrownMatchFOM; private: const DAnalysisUtilities* dAnalysisUtilities; TH1D* dHist_TruePIDStatus; TH1D* dHist_TruePIDStatus_SignalRegion; deque > dHistDeque_P_CorrectID; deque > dHistDeque_P_IncorrectID; deque > dHistDeque_PVsTheta_CorrectID; deque > dHistDeque_PVsTheta_IncorrectID; set > > dPreviouslyHistogrammedParticles; }; class DHistogramAction_InvariantMass : public DAnalysisAction { public: DHistogramAction_InvariantMass(const DReaction* locReaction, Particle_t locInitialPID, bool locUseKinFitResultsFlag, unsigned int locNumMassBins, double locMinMass, double locMaxMass, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_InvariantMass", locUseKinFitResultsFlag, locActionUniqueString), dEnableDoubleCounting(false), dInitialPID(locInitialPID), dNumMassBins(locNumMassBins), dMinMass(locMinMass), dMaxMass(locMaxMass){} bool dEnableDoubleCounting; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); Particle_t dInitialPID; unsigned int dNumMassBins; double dMinMass, dMaxMass; const DAnalysisUtilities* dAnalysisUtilities; TH1D* dHist_InvaraintMass; set > > dPreviousSourceObjects; }; class DHistogramAction_MissingMass : public DAnalysisAction { public: DHistogramAction_MissingMass(const DReaction* locReaction, bool locUseKinFitResultsFlag, unsigned int locNumMassBins, double locMinMass, double locMaxMass, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_MissingMass", locUseKinFitResultsFlag, locActionUniqueString), dEnableDoubleCounting(false), dNumMassBins(locNumMassBins), dMinMass(locMinMass), dMaxMass(locMaxMass), dMissingMassOffOfStepIndex(-1){} //E.g. If: //g, p -> K+, K+, Xi- // Xi- -> pi-, Lambda // Lambda -> (p), pi- //And: //locMissingMassOffOfStepIndex = 0, locMissingMassOffOfPIDs = K+, K+ //Then: Will histogram missing-mass: g, p -> K+, K+, (X) //Also: //locMissingMassOffOfStepIndex = 1, locMissingMassOffOfPID = pi- //Then: Will histogram missing-mass: g, p -> K+, K+, pi- //But: //locMissingMassOffOfStepIndex = 0, locMissingMassOffOfPIDs = K+ //Then: Will histogram only missing-mass: g, p -> K+_1, (X) and NOT K+_2!!! DHistogramAction_MissingMass(const DReaction* locReaction, int locMissingMassOffOfStepIndex, deque locMissingMassOffOfPIDs, bool locUseKinFitResultsFlag, unsigned int locNumMassBins, double locMinMass, double locMaxMass, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_MissingMass", locUseKinFitResultsFlag, locActionUniqueString), dEnableDoubleCounting(false), dNumMassBins(locNumMassBins), dMinMass(locMinMass), dMaxMass(locMaxMass), dMissingMassOffOfStepIndex(locMissingMassOffOfStepIndex), dMissingMassOffOfPIDs(locMissingMassOffOfPIDs) {} DHistogramAction_MissingMass(const DReaction* locReaction, int locMissingMassOffOfStepIndex, Particle_t locMissingMassOffOfPID, bool locUseKinFitResultsFlag, unsigned int locNumMassBins, double locMinMass, double locMaxMass, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_MissingMass", locUseKinFitResultsFlag, locActionUniqueString), dEnableDoubleCounting(false), dNumMassBins(locNumMassBins), dMinMass(locMinMass), dMaxMass(locMaxMass), dMissingMassOffOfStepIndex(locMissingMassOffOfStepIndex), dMissingMassOffOfPIDs(deque(1, locMissingMassOffOfPID)) {} bool dEnableDoubleCounting; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); unsigned int dNumMassBins; double dMinMass, dMaxMass; int dMissingMassOffOfStepIndex; deque dMissingMassOffOfPIDs; TH1D* dHist_MissingMass; const DAnalysisUtilities* dAnalysisUtilities; set > > dPreviousSourceObjects; }; class DHistogramAction_MissingMassSquared : public DAnalysisAction { public: DHistogramAction_MissingMassSquared(const DReaction* locReaction, bool locUseKinFitResultsFlag, unsigned int locNumMassBins, double locMinMassSq, double locMaxMassSq, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_MissingMassSquared", locUseKinFitResultsFlag, locActionUniqueString), dEnableDoubleCounting(false), dNumMassBins(locNumMassBins), dMinMassSq(locMinMassSq), dMaxMassSq(locMaxMassSq), dMissingMassOffOfStepIndex(-1){} //E.g. If: //g, p -> K+, K+, Xi- // Xi- -> pi-, Lambda // Lambda -> (p), pi- //And: //locMissingMassOffOfStepIndex = 0, locMissingMassOffOfPIDs = K+, K+ //Then: Will histogram missing-mass: g, p -> K+, K+, (X) //Also: //locMissingMassOffOfStepIndex = 1, locMissingMassOffOfPID = pi- //Then: Will histogram missing-mass: g, p -> K+, K+, pi- //But: //locMissingMassOffOfStepIndex = 0, locMissingMassOffOfPIDs = K+ //Then: Will histogram only missing-mass: g, p -> K+_1, (X) and NOT K+_2!!! DHistogramAction_MissingMassSquared(const DReaction* locReaction, int locMissingMassOffOfStepIndex, deque locMissingMassOffOfPIDs, bool locUseKinFitResultsFlag, unsigned int locNumMassBins, double locMinMassSq, double locMaxMassSq, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_MissingMass", locUseKinFitResultsFlag, locActionUniqueString), dEnableDoubleCounting(false), dNumMassBins(locNumMassBins), dMinMassSq(locMinMassSq), dMaxMassSq(locMaxMassSq), dMissingMassOffOfStepIndex(locMissingMassOffOfStepIndex), dMissingMassOffOfPIDs(locMissingMassOffOfPIDs) {} DHistogramAction_MissingMassSquared(const DReaction* locReaction, int locMissingMassOffOfStepIndex, Particle_t locMissingMassOffOfPID, bool locUseKinFitResultsFlag, unsigned int locNumMassBins, double locMinMassSq, double locMaxMassSq, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_MissingMass", locUseKinFitResultsFlag, locActionUniqueString), dEnableDoubleCounting(false), dNumMassBins(locNumMassBins), dMinMassSq(locMinMassSq), dMaxMassSq(locMaxMassSq), dMissingMassOffOfStepIndex(locMissingMassOffOfStepIndex), dMissingMassOffOfPIDs(deque(1, locMissingMassOffOfPID)) {} bool dEnableDoubleCounting; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); unsigned int dNumMassBins; double dMinMassSq, dMaxMassSq; int dMissingMassOffOfStepIndex; deque dMissingMassOffOfPIDs; TH1D* dHist_MissingMassSquared; const DAnalysisUtilities* dAnalysisUtilities; set > > dPreviousSourceObjects; }; class DHistogramAction_KinFitResults : public DAnalysisAction { public: DHistogramAction_KinFitResults(const DReaction* locReaction, double locPullHistConfidenceLevelCut, string locActionUniqueString = "") : DAnalysisAction(locReaction, "Hist_KinFitResults", true, locActionUniqueString), dNumConfidenceLevelBins(400), dNumPullBins(200), dMinPull(-4.0), dMaxPull(4.0), dPullHistConfidenceLevelCut(locPullHistConfidenceLevelCut){} unsigned int dNumConfidenceLevelBins, dNumPullBins; double dMinPull, dMaxPull; void Initialize(JEventLoop* locEventLoop); private: bool Perform_Action(JEventLoop* locEventLoop, const DParticleCombo* locParticleCombo); void Create_ParticlePulls(bool locIsBeamFlag, string locStepROOTName, Particle_t locPID, map& locParticlePulls, const string& locKinFitTypeString); double dPullHistConfidenceLevelCut; const DAnalysisUtilities* dAnalysisUtilities; TH1D* dHist_ConfidenceLevel; map, map > dHistMap_Pulls; //size_t is step index, 2nd is particle TH1D* dHist_RFTimePull; map dHistMap_BeamPulls; }; #endif // _DHistogramActions_