// $Id$ // // File: DEventProcessor_p2pi.cc // Created: Wed Jan 21 16:28:09 EST 2015 // Creator: jrsteven (on Linux ifarm1401 2.6.32-431.el6.x86_64 x86_64) // #include "DEventProcessor_p2pi.h" // Routine used to create our DEventProcessor extern "C" { void InitPlugin(JApplication *locApplication) { InitJANAPlugin(locApplication); locApplication->AddProcessor(new DEventProcessor_p2pi()); //register this plugin locApplication->AddFactoryGenerator(new DFactoryGenerator_p2pi()); //register the factory generator } } // "C" //------------------ // init //------------------ jerror_t DEventProcessor_p2pi::init(void) { // This is called once at program startup. If you are creating // and filling historgrams in this plugin, you should lock the // ROOT mutex like this: // // japp->RootWriteLock(); // ... create historgrams or trees ... // japp->RootUnLock(); // return NOERROR; } //------------------ // brun //------------------ jerror_t DEventProcessor_p2pi::brun(jana::JEventLoop* locEventLoop, int locRunNumber) { // This is called whenever the run number changes // reaction independent actions dHistogramAction_TrackMultiplicity.Initialize(locEventLoop); dHistogramAction_ThrownParticleKinematics.Initialize(locEventLoop); dHistogramAction_DetectedParticleKinematics.Initialize(locEventLoop); dHistogramAction_GenReconTrackComparison.Initialize(locEventLoop); dHistogramAction_NumReconstructedObjects.Initialize(locEventLoop); //dHistogramAction_DetectorStudies.Initialize(locEventLoop); dHistogramAction_ReconnedThrownKinematics.Initialize(locEventLoop); //dHistogramAction_EventVertex.Initialize(locEventLoop); //Recommended: Create output ROOT TTrees (nothing is done if already created) const DEventWriterROOT* locEventWriterROOT = NULL; locEventLoop->GetSingle(locEventWriterROOT); locEventWriterROOT->Create_DataTrees(locEventLoop); return NOERROR; } //------------------ // evnt //------------------ jerror_t DEventProcessor_p2pi::evnt(jana::JEventLoop* locEventLoop, int locEventNumber) { // This is called for every event. Use of common resources like writing // to a file or filling a histogram should be mutex protected. Using // locEventLoop->Get(...) to get reconstructed objects (and thereby activating the // reconstruction algorithm) should be done outside of any mutex lock // since multiple threads may call this method at the same time. // // Here's an example: // // vector mydataclasses; // locEventLoop->Get(mydataclasses); // // japp->RootWriteLock(); // ... fill historgrams or trees ... // japp->RootUnLock(); // DOCUMENTATION: // ANALYSIS library: https://halldweb1.jlab.org/wiki/index.php/GlueX_Analysis_Software /*********************************************************** REQUIRED ***********************************************************/ // just select rho events vector locMCThrown; locEventLoop->Get(locMCThrown); #if 1 // select gamma p -> rho p exclusive for monitoring histograms if(!locMCThrown.empty()){ if(locMCThrown.size() != 4) return NOERROR; int nPiP = 0; int nPiM = 0; int nRho = 0; int nProton = 0; for(uint i=0; ipdgtype == 113){ nRho++; } if(locMCThrown[i]->type == 8){ nPiP++; } if(locMCThrown[i]->type == 9){ nPiM++; } if(locMCThrown[i]->type == 14){ nProton++; } } if(nPiP!=1 || nPiM!=1 || nRho!=1 || nProton!=1) return NOERROR; } // reaction independent actions (only for rho events) dHistogramAction_TrackMultiplicity(locEventLoop); dHistogramAction_DetectedParticleKinematics(locEventLoop); dHistogramAction_NumReconstructedObjects(locEventLoop); //dHistogramAction_DetectorStudies(locEventLoop); //dHistogramAction_EventVertex(locEventLoop); if(!locMCThrown.empty()){ dHistogramAction_ThrownParticleKinematics(locEventLoop); dHistogramAction_GenReconTrackComparison(locEventLoop); dHistogramAction_ReconnedThrownKinematics(locEventLoop); } #endif //REQUIRED: To run an analysis, You MUST call one at least of the below code fragments. //JANA is on-demand, so if you don't call one of these, then your analysis won't run. //Recommended: Write surviving particle combinations (if any) to output ROOT TTree //If no cuts are performed by the analysis actions added to a DReaction, then this saves all of its particle combinations. //The event writer gets the DAnalysisResults objects from JANA, performing the analysis. // string is DReaction factory tag: will fill trees for all DReactions that are defined in the specified factory const DEventWriterROOT* locEventWriterROOT = NULL; locEventLoop->GetSingle(locEventWriterROOT); locEventWriterROOT->Fill_DataTrees(locEventLoop, "p2pi"); return NOERROR; } //------------------ // erun //------------------ jerror_t DEventProcessor_p2pi::erun(void) { // This is called whenever the run number changes, before it is // changed to give you a chance to clean up before processing // events from the next run number. return NOERROR; } //------------------ // fini //------------------ jerror_t DEventProcessor_p2pi::fini(void) { // Called before program exit after event processing is finished. return NOERROR; }