// $Id$ // // File: DAnalysisResults_factory_PreKinFit.cc // Created: Tue Aug 9 14:29:24 EST 2011 // Creator: pmatt (on Linux ifarml6 2.6.18-128.el5 x86_64) // #include "DAnalysisResults_factory_PreKinFit.h" //------------------ // init //------------------ jerror_t DAnalysisResults_factory_PreKinFit::init(void) { dDebugLevel = 0; dROOTObjectsCreatedFlag = false; return NOERROR; } //------------------ // brun //------------------ jerror_t DAnalysisResults_factory_PreKinFit::brun(jana::JEventLoop *locEventLoop, int runnumber) { dApplication = dynamic_cast(locEventLoop->GetJApplication()); gPARMS->SetDefaultParameter("ANALYSIS:DEBUGLEVEL", dDebugLevel); if(dROOTObjectsCreatedFlag) return NOERROR; vector locReactions; Get_Reactions(locEventLoop, locReactions); //MAKE CONTROL HISTOGRAMS string locHistName, locHistTitle, locDirName, locDirTitle; const DReaction* locReaction; TDirectoryFile* locDirectoryFile; string locReactionName; TH1D* loc1DHist; TH2D* loc2DHist; size_t locNumActions; dApplication->RootWriteLock(); //to prevent undefined behavior due to directory changes, etc. if(dROOTObjectsCreatedFlag) // hists created in the meantime { dApplication->RootUnLock(); //unlock return NOERROR; } TDirectoryFile* locBaseDirectory = static_cast(gDirectory->GetDirectory("/")); for(size_t loc_i = 0; loc_i < locReactions.size(); ++loc_i) { locReaction = locReactions[loc_i]; locReactionName = locReaction->Get_ReactionName(); locNumActions = locReaction->Get_NumAnalysisActions(); deque locActionNames; for(size_t loc_j = 0; loc_j < locNumActions; ++loc_j) locActionNames.push_back(locReaction->Get_AnalysisAction(loc_j)->Get_ActionName()); locDirName = locReactionName; locDirTitle = locReactionName; locBaseDirectory->cd(); locDirectoryFile = static_cast(locBaseDirectory->GetDirectory(locDirName.c_str())); if(locDirectoryFile == NULL) locDirectoryFile = new TDirectoryFile(locDirName.c_str(), locDirTitle.c_str()); locDirectoryFile->cd(); locHistName = "NumParticleCombos"; loc1DHist = static_cast(locDirectoryFile->Get(locHistName.c_str())); if(loc1DHist == NULL) { locHistTitle = locReactionName + string(";# Track Combinations;# Events"); loc1DHist = new TH1D(locHistName.c_str(), locHistTitle.c_str(), 100, -0.5, 99.5); } dHistMap_NumParticleCombos[locReaction] = loc1DHist; locHistName = "NumEventsSurvivedAction"; loc1DHist = static_cast(locDirectoryFile->Get(locHistName.c_str())); if(loc1DHist == NULL) { locHistTitle = locReactionName + string(";;# Events Survived Action"); loc1DHist = new TH1D(locHistName.c_str(), locHistTitle.c_str(), locNumActions + 2, -0.5, locNumActions + 2.0 - 0.5); //+2 for input & # tracks loc1DHist->GetXaxis()->SetBinLabel(1, "Input"); // a new event loc1DHist->GetXaxis()->SetBinLabel(2, "Minimum # Tracks"); // at least one DParticleCombo object before any actions for(size_t loc_j = 0; loc_j < locActionNames.size(); ++loc_j) loc1DHist->GetXaxis()->SetBinLabel(3 + loc_j, locActionNames[loc_j].c_str()); } dHistMap_NumEventsSurvivedAction[locReaction] = loc1DHist; locHistName = "NumCombosSurvivedAction"; loc2DHist = static_cast(locDirectoryFile->Get(locHistName.c_str())); if(loc2DHist == NULL) { locHistTitle = locReactionName + string(";;# Particle Combos Survived Action"); loc2DHist = new TH2D(locHistName.c_str(), locHistTitle.c_str(), locNumActions + 1, -0.5, locNumActions + 1 - 0.5, 100, -0.5, 99.5); //+1 for # tracks loc2DHist->GetXaxis()->SetBinLabel(1, "Minimum # Tracks"); // at least one DParticleCombo object before any actions for(size_t loc_j = 0; loc_j < locActionNames.size(); ++loc_j) loc2DHist->GetXaxis()->SetBinLabel(2 + loc_j, locActionNames[loc_j].c_str()); } dHistMap_NumCombosSurvivedAction[locReaction] = loc2DHist; locHistName = "NumCombosSurvivedAction1D"; loc1DHist = static_cast(locDirectoryFile->Get(locHistName.c_str())); if(loc1DHist == NULL) { locHistTitle = locReactionName + string(";;# Particle Combos Survived Action"); loc1DHist = new TH1D(locHistName.c_str(), locHistTitle.c_str(), locNumActions + 1, -0.5, locNumActions + 1 - 0.5); //+1 for # tracks loc1DHist->GetXaxis()->SetBinLabel(1, "Minimum # Tracks"); // at least one DParticleCombo object before any actions for(size_t loc_j = 0; loc_j < locActionNames.size(); ++loc_j) loc1DHist->GetXaxis()->SetBinLabel(2 + loc_j, locActionNames[loc_j].c_str()); } dHistMap_NumCombosSurvivedAction1D[locReaction] = loc1DHist; locDirectoryFile->cd(".."); } //Make Reaction-Independent Analysis Actions vector locMCThrowns; locEventLoop->Get(locMCThrowns); dReactionIndependentAnalysisActions.push_back(new DHistogramAction_TrackMultiplicity(NULL)); dReactionIndependentAnalysisActions.push_back(new DHistogramAction_DetectedParticleKinematics(NULL)); if(!locMCThrowns.empty()) { dReactionIndependentAnalysisActions.push_back(new DHistogramAction_ThrownParticleKinematics(NULL)); dReactionIndependentAnalysisActions.push_back(new DHistogramAction_GenReconTrackComparison(NULL)); } dROOTObjectsCreatedFlag = true; dApplication->RootUnLock(); //unlock dParticleComboBlueprintFactory = static_cast(locEventLoop->GetFactory("DParticleComboBlueprint")); dParticleComboFactory = static_cast(locEventLoop->GetFactory("DParticleCombo")); dParticleComboFactory_PreKinFit = static_cast(locEventLoop->GetFactory("DParticleCombo", "PreKinFit")); dKinFitResultsFactory = static_cast(locEventLoop->GetFactory("DKinFitResults")); return NOERROR; } void DAnalysisResults_factory_PreKinFit::Get_Reactions(jana::JEventLoop* locEventLoop, vector& locReactions) const { // Get list of factories and find all the ones producing // DReaction objects. (A simpler way to do this would be to // just use locEventLoop->Get(...), but then only one plugin could // be used at a time.) locReactions.clear(); vector locFactories = locEventLoop->GetFactories(); for(size_t loc_i = 0; loc_i < locFactories.size(); ++loc_i) { JFactory* locFactory = dynamic_cast* >(locFactories[loc_i]); if(locFactory == NULL) continue; // Found a factory producing DReactions. The reaction objects are // produced at the init stage and are persistent through all event // processing so we can grab the list here and append it to our // overall list. vector locReactionsSubset; locFactory->Get(locReactionsSubset); locReactions.insert(locReactions.end(), locReactionsSubset.begin(), locReactionsSubset.end()); } } //------------------ // evnt //------------------ jerror_t DAnalysisResults_factory_PreKinFit::evnt(jana::JEventLoop* locEventLoop, int eventnumber) { //RESET POOLS FIRST!!! dParticleComboBlueprintFactory->Reset_Pools(); dParticleComboFactory->Reset_Pools(); dParticleComboFactory_PreKinFit->Reset_Pools(); dKinFitResultsFactory->Reset_NewEvent(); vector locReactions; Get_Reactions(locEventLoop, locReactions); vector locParticleCombos; locEventLoop->Get(locParticleCombos, "PreKinFit"); const DReaction* locReaction; DAnalysisResults* locAnalysisResults; DAnalysisAction* locAnalysisAction; if(dDebugLevel > 0) cout << "# DReactions: " << locReactions.size() << endl; if(dDebugLevel > 0) cout << "Total # PreKinFit DParticleCombos: " << locParticleCombos.size() << endl; //Execute reaction-independent analysis actions deque > locSurvivingParticleCombos_Dummy(1, pair(NULL, true)); for(size_t loc_i = 0; loc_i < dReactionIndependentAnalysisActions.size(); ++loc_i) (*dReactionIndependentAnalysisActions[loc_i])(locEventLoop, locSurvivingParticleCombos_Dummy); //EXECUTE! for(size_t loc_i = 0; loc_i < locReactions.size(); ++loc_i) { locAnalysisResults = new DAnalysisResults(); locReaction = locReactions[loc_i]; locAnalysisResults->Set_Reaction(locReaction); //select the particle combos belonging to this reaction deque > locSurvivingParticleCombos; for(size_t loc_j = 0; loc_j < locParticleCombos.size(); ++loc_j) { if(locParticleCombos[loc_j]->Get_Reaction() == locReaction) locSurvivingParticleCombos.push_back(pair(locParticleCombos[loc_j], true)); } if(dDebugLevel > 0) cout << "Evaluating DReaction: " << locReaction->Get_ReactionName() << endl; if(dDebugLevel > 0) cout << "# DParticleCombos in this DReaction: " << locSurvivingParticleCombos.size() << endl; //execute the actions size_t locNumAnalysisActions = locReaction->Get_NumAnalysisActions(); deque locNumParticleCombosSurvivedActions(1, locSurvivingParticleCombos.size()); //first cut is "are there enough tracks" for(size_t loc_j = 0; loc_j < locNumAnalysisActions; ++loc_j) { if(locSurvivingParticleCombos.empty()) break; locAnalysisAction = locReaction->Get_AnalysisAction(loc_j); if(locAnalysisAction->Get_UseKinFitResultsFlag()) break; //need to kinfit first!!! if(dDebugLevel > 0) cout << "Execute Action # " << loc_j + 1 << ": " << locAnalysisAction->Get_ActionName() << " on " << locSurvivingParticleCombos.size() << " surviving DParticleCombos." << endl; (*locAnalysisAction)(locEventLoop, locSurvivingParticleCombos); //EXECUTE! //remove failed particle combos size_t locNumPreActionParticleCombos = locSurvivingParticleCombos.size(); deque >::iterator locIterator; for(locIterator = locSurvivingParticleCombos.begin(); locIterator != locSurvivingParticleCombos.end();) { if(!locIterator->second) { //failed the cut locAnalysisResults->Add_FailedParticleCombo(locIterator->first, loc_j); locIterator = locSurvivingParticleCombos.erase(locIterator); } else ++locIterator; } locNumParticleCombosSurvivedActions.push_back(locSurvivingParticleCombos.size()); if(dDebugLevel > 0) cout << locNumPreActionParticleCombos - locNumParticleCombosSurvivedActions.back() << " combos failed the action." << endl; } for(size_t loc_j = 0; loc_j < locSurvivingParticleCombos.size(); ++loc_j) locAnalysisResults->Add_PassedParticleCombo(locSurvivingParticleCombos[loc_j].first); //fill histograms dApplication->RootWriteLock(); dHistMap_NumEventsSurvivedAction[locReaction]->Fill(0); //initial: a new event dHistMap_NumParticleCombos[locReaction]->Fill(locNumParticleCombosSurvivedActions[0]); for(size_t loc_j = 0; loc_j < locNumParticleCombosSurvivedActions.size(); ++loc_j) { if(locNumParticleCombosSurvivedActions[loc_j] > 0) dHistMap_NumEventsSurvivedAction[locReaction]->Fill(loc_j + 1); //+1 because 0 is initial (no cuts at all) dHistMap_NumCombosSurvivedAction[locReaction]->Fill(loc_j, locNumParticleCombosSurvivedActions[loc_j]); for(size_t loc_k = 0; loc_k < locNumParticleCombosSurvivedActions[loc_j]; ++loc_k) dHistMap_NumCombosSurvivedAction1D[locReaction]->Fill(loc_j); } for(size_t loc_j = locNumParticleCombosSurvivedActions.size(); loc_j < (locNumAnalysisActions + 1); ++loc_j) dHistMap_NumCombosSurvivedAction[locReaction]->Fill(loc_j, 0); dApplication->RootUnLock(); _data.push_back(locAnalysisResults); } return NOERROR; } //------------------ // erun //------------------ jerror_t DAnalysisResults_factory_PreKinFit::erun(void) { return NOERROR; } //------------------ // fini //------------------ jerror_t DAnalysisResults_factory_PreKinFit::fini(void) { return NOERROR; }