// $Id$ // // File: DParticleCombo_factory_PreKinFit.h // Created: Tue Aug 9 14:29:24 EST 2011 // Creator: pmatt (on Linux ifarml6 2.6.18-128.el5 x86_64) // #ifndef _DParticleCombo_factory_PreKinFit_ #define _DParticleCombo_factory_PreKinFit_ #include #include #include #include "JANA/JFactory.h" #include "JANA/JObject.h" #include "particleType.h" #include "PID/DChargedTrackHypothesis.h" #include "PID/DNeutralParticleHypothesis.h" #include "PID/DKinematicData.h" #include "PID/DChargedTrack.h" #include "PID/DBeamPhoton.h" #include "PID/DNeutralShower.h" #include "PID/DEventRFBunch.h" #include "PID/DVertex.h" #include #include #include "ANALYSIS/DParticleCombo.h" #include "ANALYSIS/DCutActions.h" #include "ANALYSIS/DMCThrownMatching.h" #include "ANALYSIS/DParticleComboStep.h" #include "ANALYSIS/DParticleComboBlueprint.h" #include "ANALYSIS/DAnalysisUtilities.h" class DParticleCombo_factory_PreKinFit : public jana::JFactory { public: DParticleCombo_factory_PreKinFit():root_hists_created(false){}; ~DParticleCombo_factory_PreKinFit(){}; const char* Tag(void){return "PreKinFit";} void Reset_Pools(void); size_t Get_ParticleComboStepPoolSize(void) const{return dParticleComboStepPool_All.size();}; size_t Get_KinematicDataPoolSize(void) const{return dKinematicDataPool_All.size();}; private: jerror_t init(void); ///< Called once at program start. jerror_t brun(jana::JEventLoop *locEventLoop, int runnumber); ///< Called everytime a new run number is detected. jerror_t evnt(jana::JEventLoop *locEventLoop, int eventnumber); ///< Called every event. jerror_t erun(void); ///< Called everytime run number changes, provided brun has been called. jerror_t fini(void); ///< Called after last event of last event source has been processed. const DKinematicData* Get_DetectedParticle(const DReaction* locReaction, const DEventRFBunch* locEventRFBunch, const DParticleComboBlueprintStep* locParticleComboBlueprintStep, size_t locParticleIndex); DKinematicData* Create_Target(Particle_t locPID); bool Cut_PIDFOM(const DReaction* locReaction, const DChargedTrackHypothesis* locChargedTrackHypothesis) const; bool Cut_PIDFOM(const DReaction* locReaction, const DNeutralParticleHypothesis* locNeutralParticleHypothesis) const; bool Cut_NumBeamPhotonsInBunch(const DReaction* locReaction, size_t locNumBeamPhotonsInBunch) const; void Build_BeamPhotonCombos(DParticleCombo* locParticleCombo, const DParticleComboBlueprint* locParticleComboBlueprint, const DEventRFBunch* locEventRFBunch, const set& locInputCandidatePhotons, vector& locBuiltParticleCombos); DParticleComboStep* Clone_ParticleComboStep(const DParticleComboStep* locParticleComboStep); void Reset_KinematicData(DKinematicData* locKinematicData); DParticleComboStep* Get_ParticleComboStepResource(void); DParticleCombo* Get_ParticleComboResource(void); DKinematicData* Get_KinematicDataResource(void); DBeamPhoton* Get_BeamPhotonResource(void); void Recycle_Data(const DParticleCombo* locParticleCombo, const DParticleComboBlueprint* locParticleComboBlueprint, bool locAllButFirstStepFlag); void Recycle_Data_BeamStep(const DParticleCombo* locParticleCombo, const DParticleComboBlueprint* locParticleComboBlueprint, const DEventRFBunch* locEventRFBunch); deque dParticleComboStepPool_All; deque dParticleComboStepPool_Available; deque dKinematicDataPool_All; deque dKinematicDataPool_Available; map dComboBlueprintStepMap; map, set > dComboBlueprintBeamStepMap; size_t MAX_DParticleComboStepPoolSize; size_t MAX_DKinematicDataPoolSize; // PRE-DPARTICLECOMBO CUT VALUES //bool = true/false for cut enabled/disabled, double = cut value //Command-line values will override these values pair dMinChargedPIDFOM; //the minimum PID FOM for a particle used for this DReaction pair dMinPhotonPIDFOM; //the minimum PID FOM for a neutral particle used for this DReaction pair dMaxPhotonRFDeltaT; //the maximum photon-rf time difference: used for photon selection pair dMaxNumBeamPhotonsInBunch; //cut out combos with more than this # of beam photons surviving the RF delta-t cut int dDebugLevel; double dTargetCenterZ; double dMinThrownMatchFOM; const DAnalysisUtilities* dAnalysisUtilities; bool root_hists_created; vector dReactions; map dMCReactionExactMatchFlags; map dTrueComboCuts; map dNumGoodPreComboSelectionActions; map > > > dValidChargedHypotheses; map > > > dValidNeutralHypotheses; map > dHistMap_PIDFOM_All; map > dHistMap_PIDFOM_True; map dHistMap_PhotonRFDeltaT_All; map dHistMap_PhotonRFDeltaT_True; //for the true combo (MC event) (includes true beam photon): delta-t between selected photon & RF time map dHistMap_NumSurvivingBeamParticles; map dHistMap_NumBlueprintsSurvivedCut; map dHistMap_NumBlueprintsSurvivedCut1D; map dHistMap_NumEventsSurvivedCut_All; map dHistMap_NumEventsSurvivedCut_True; }; #endif // _DParticleCombo_factory_PreKinFit_