#include #include #include #include #include #include #include using namespace RAT; using namespace RAT::Classifiers; using namespace RAT::DS; #include using namespace std; void ITR::Initialise( const std::string& param) { fIndex = param; } void ITR::BeginOfRun( DS::Run& ) { DB *db = DB::Get(); string index; if( fIndex.empty() ) { try{ index = db->GetLink("GEO","inner_av")->GetS("material"); } catch(DBNotFoundError & ){ try{ // If we are in a partial-fill geometry, use the upper // material index = db->GetLink("GEO","inner_av")->GetS("material_top"); } catch(DBNotFoundError & ) { Log::Die("ITR: inner_av material and material_top " "undefined. Try something like:\n" "/rat/db/set GEO[inner_av] material " "\"te_labppo_scintillator\" or " "/rat/db/set GEO[inner_av] material_top " "\"te_labppo_scintillator\""); } } } else { index = fIndex; } DBLinkPtr dbITRLink; try{ (dbITRLink = db->GetLink("CLASSIFIER_ITR",index))->GetS("index"); } catch(DBNotFoundError & ){ warn << "Warning : ITR::BeginOfRun: No full (ITR) definition for " + index + " using defaults instead.\n"; dbITRLink = db->GetLink("CLASSIFIER_ITR"); } fLowerTimeLimit = dbITRLink->GetD("t1"); fUpperTimeLimit = dbITRLink->GetD("t2"); fLightPath = DU::Utility::Get()->GetLightPathCalculator(); } void ITR::DefaultSeed() { fEventPos = TVector3(); fEventTime = 0.0; fSeedVertex.SetPosition( fEventPos, false, true ); fSeedVertex.SetTime( fEventTime, false, true ); } void ITR::SetSeed( const DS::FitResult& seed ) { try { fSeedVertex = seed.GetVertex(0); } catch( FitResult::NoVertexError& error ) { // Nothing to seed from, strange request return; } try { fEventPos = fSeedVertex.GetPosition(); } catch( FitVertex::NoValueError& error ) { /* No data to seed from */ } try { fEventTime = fSeedVertex.GetTime(); } catch( FitVertex::NoValueError& error ) { /* No data to seed from */ } } DS::ClassifierResult ITR::GetClassification() { fClassifierResult.Reset(); if( fPMTData.empty() ) return fClassifierResult; SelectPMTData( fSeedVertex ); const DU::PMTInfo& pmtInfo = DU::Utility::Get()->GetPMTInfo(); int numInTime = 0; for( vector::const_iterator iPMT = fSelectedPMTData.begin(); iPMT != fSelectedPMTData.end(); ++iPMT ) { const TVector3 pmtPos = pmtInfo.GetPosition( iPMT->GetID() ); fLightPath.CalcByPosition(fEventPos, pmtPos); double distInInnerAV = fLightPath.GetDistInInnerAV(); double distInAV = fLightPath.GetDistInAV(); double distInWater = fLightPath.GetDistInWater(); const double transitTime = DU::Utility::Get()->GetEffectiveVelocity().CalcByDistance( distInInnerAV, distInAV, distInWater ); const double corTime = iPMT->GetTime() - transitTime - fEventTime; if( corTime < fUpperTimeLimit && corTime > fLowerTimeLimit ) { numInTime++; } } fClassifierResult.SetClassification( "ITR", static_cast( numInTime ) / static_cast( fSelectedPMTData.size() ) ); fClassifierResult.SetValid( true ); return fClassifierResult; }