// Author: David Lawrence June 25, 2004 // // // MyProcessor.cc // #include #include #include using namespace std; #include #include #include #include #include #include #include #include #include #include #include "hdview2.h" #include "hdv_mainframe.h" #include "MyProcessor.h" #include "TRACKING/DTrackHit.h" #include "TRACKING/DQuickFit.h" #include "TRACKING/DMagneticFieldStepper.h" #include "TRACKING/DTrackCandidate_factory.h" #include "TRACKING/DMCTrackHit.h" #include "TRACKING/DMCThrown.h" #include "TRACKING/DTrackWireBased.h" #include "TRACKING/DTrackTimeBased.h" #include "PID/DParticle.h" #include "TRACKING/DReferenceTrajectory.h" #include "JANA/JGeometry.h" #include "TRACKING/DMCTrajectoryPoint.h" #include "FCAL/DFCALHit.h" #include "FDC/DFDCGeometry.h" #include "CDC/DCDCTrackHit.h" #include "FDC/DFDCPseudo.h" #include "FDC/DFDCIntersection.h" #include "HDGEOMETRY/DGeometry.h" #include "FCAL/DFCALGeometry.h" #include "FCAL/DFCALHit.h" #include "PID/DPhoton.h" #include "BCAL/DHDDMBCALHit.h" extern hdv_mainframe *hdvmf; // This is declared in hdv_mainframe.cc, but as static so we need to do it here as well (yechh!) static float FCAL_Zmin = 622.8; static vector >fdcwires; MyProcessor *gMYPROC=NULL; //------------------------------------------------------------------ // MyProcessor //------------------------------------------------------------------ MyProcessor::MyProcessor() { Bfield = NULL; loop = NULL; // Tell factory to keep around a few density histos //gPARMS->SetParameter("TRKFIND:MAX_DEBUG_BUFFERS", 16); gMYPROC = this; } //------------------------------------------------------------------ // ~MyProcessor //------------------------------------------------------------------ MyProcessor::~MyProcessor() { } //------------------------------------------------------------------ // init //------------------------------------------------------------------ jerror_t MyProcessor::init(void) { // Make sure detectors have been drawn //if(!drew_detectors)DrawDetectors(); vector loops = app->GetJEventLoops(); if(loops.size()>0){ vector facnames; loops[0]->GetFactoryNames(facnames); hdvmf = new hdv_mainframe(gClient->GetRoot(), 1000, 600); hdvmf->SetCandidateFactories(facnames); hdvmf->SetWireBasedTrackFactories(facnames); hdvmf->SetTimeBasedTrackFactories(facnames); hdvmf->SetReconstructedFactories(facnames); hdvmf->SetParticleFactories(facnames); } return NOERROR; } //------------------------------------------------------------------ // brun //------------------------------------------------------------------ jerror_t MyProcessor::brun(JEventLoop *eventloop, int runnumber) { // Read in Magnetic field map DApplication* dapp = dynamic_cast(eventloop->GetJApplication()); Bfield = dapp->GetBfield(); const DGeometry *dgeom = dapp->GetDGeometry(runnumber); dgeom->GetFDCWires(fdcwires); RootGeom = dapp->GetRootGeom(); geom = dapp->GetDGeometry(runnumber); MATERIAL_MAP_MODEL="DGeometry"; gPARMS->SetDefaultParameter("TRKFIT:MATERIAL_MAP_MODEL", MATERIAL_MAP_MODEL); return NOERROR; } //------------------------------------------------------------------ // evnt //------------------------------------------------------------------ jerror_t MyProcessor::evnt(JEventLoop *eventLoop, int eventnumber) { if(!eventLoop)return NOERROR; loop = eventLoop; last_jevent.FreeEvent(); last_jevent = loop->GetJEvent(); cout<<"----------- New Event "<SetEvent(eventnumber); hdvmf->SetSource(last_jevent.GetJEventSource()->GetSourceName()); hdvmf->DoMyRedraw(); return NOERROR; } //------------------------------------------------------------------ // FillGraphics //------------------------------------------------------------------ void MyProcessor::FillGraphics(void) { /// Create "graphics" objects for this event given the current GUI settings. /// /// This method will create DGraphicSet objects that represent tracks, hits, /// and showers for the event. It creates objects for both hits and /// reconstructed entities. The "graphics" objects created here are /// really just collections of 3D space points with flags indicating /// whether they should be drawn as markers or lines and with what /// color and size. The actual graphics objects are created for the /// various views of the detector in hdv_mainframe. graphics.clear(); graphics_xyA.clear(); // The objects placed in these will be deleted by hdv_mainframe graphics_xyB.clear(); // The objects placed in these will be deleted by hdv_mainframe graphics_xz.clear(); // The objects placed in these will be deleted by hdv_mainframe graphics_yz.clear(); // The objects placed in these will be deleted by hdv_mainframe if(!loop)return; // BCAL hits if(hdvmf->GetCheckButton("bcal")){ vector bcalhits; loop->Get(bcalhits); for(unsigned int i=0; iGetBCALPolyLine(hit->module, hit->layer, hit->sector); if(!poly)continue; double a = hit->E/0.02; double f = sqrt(a>1.0 ? 1.0:a<0.0 ? 0.0:a); double grey = 0.8; double s = 1.0 - f; float r = s*grey; float g = s*grey; float b = f*(1.0-grey) + grey; poly->SetFillColor(TColor::GetColor(r,g,b)); //poly->SetLineColor(TColor::GetColor(r,g,b)); //poly->SetLineWidth(3.0); poly->SetFillStyle(3001); } } // FCAL hits if(hdvmf->GetCheckButton("fcal")){ vector fcalhits; loop->Get(fcalhits); for(unsigned int i=0; iGetFCALPolyLine(hit->x, hit->y); if(!poly)continue; double a = hit->E/0.005; double f = sqrt(a>1.0 ? 1.0:a<0.0 ? 0.0:a); double grey = 0.8; double s = 1.0 - f; float r = s*grey; float g = s*grey; float b = f*(1.0-grey) + grey; poly->SetFillColor(TColor::GetColor(r,g,b)); } } // CDC hits if(hdvmf->GetCheckButton("cdc")){ vector cdctrackhits; loop->Get(cdctrackhits); for(unsigned int i=0; iwire; int color = (cdctrackhits[i]->tdrift>-20 && cdctrackhits[i]->tdrift<400) ? kCyan:kYellow; DGraphicSet gset(color, kLine, 1.0); gset.points.push_back(wire->origin-(wire->L/2.0)*wire->udir); gset.points.push_back(wire->origin+(wire->L/2.0)*wire->udir); graphics.push_back(gset); // Rings for drift times. // NOTE: These are not perfect since they still have TOF in them if(hdvmf->GetCheckButton("cdcdrift") && wire->stereo==0.0){ double x = wire->origin.X(); double y = wire->origin.Y(); double dist1 = cdctrackhits[i]->dist; TEllipse *e = new TEllipse(x, y, dist1, dist1); e->SetLineColor(38); graphics_xyA.push_back(e); double dist2 = dist1 - 4.0*55.0E-4; // what if our TOF was 4ns? e = new TEllipse(x, y, dist2, dist2); e->SetLineColor(38); graphics_xyA.push_back(e); } } } // FDC wire if(hdvmf->GetCheckButton("fdcwire")){ vector fdchits; loop->Get(fdchits); for(unsigned int i=0; itype!=0)continue; const DFDCWire *wire =fdcwires[fdchit->gLayer-1][fdchit->element-1]; if(!wire){ _DBG_<<"Couldn't find wire for gLayer="<gLayer<<" and element="<element<t>-50 && fdchit->t<400) ? kCyan:kYellow; DGraphicSet gset(color, kLine, 1.0); gset.points.push_back(wire->origin-(wire->L/2.0)*wire->udir); gset.points.push_back(wire->origin+(wire->L/2.0)*wire->udir); graphics.push_back(gset); } } // FDC intersection hits if(hdvmf->GetCheckButton("fdcintersection")){ vector fdcints; loop->Get(fdcints); DGraphicSet gsetp(46, kMarker, 0.5); for(unsigned int i=0; ipos); } graphics.push_back(gsetp); } // FDC psuedo hits if(hdvmf->GetCheckButton("fdcpseudo")){ vector fdcpseudos; loop->Get(fdcpseudos); DGraphicSet gsetp(38, kMarker, 0.5); for(unsigned int i=0; iwire; // Pseudo point TVector3 pos(fdcpseudos[i]->x, fdcpseudos[i]->y, wire->origin.Z()); gsetp.points.push_back(pos); } graphics.push_back(gsetp); } // DMCThrown if(hdvmf->GetCheckButton("thrown")){ vector mcthrown; loop->Get(mcthrown); for(unsigned int i=0; icharge()==0.0) color = kGreen; if(mcthrown[i]->charge() >0.0) color = kBlue; if(mcthrown[i]->charge() <0.0) color = kRed; switch(mcthrown[i]->type){ case Gamma: case Positron: case Electron: size = 1.0; break; case Pi0: case PiPlus: case PiMinus: size = 2.0; break; case Neutron: case Proton: case AntiProton: size = 3.0; break; } AddKinematicDataTrack(mcthrown[i], color, size); } } // CDC Truth points if(hdvmf->GetCheckButton("cdctruth")){ vector mctrackhits; loop->Get(mctrackhits); DGraphicSet gset(12, kMarker, 0.5); for(unsigned int i=0; isystem != SYS_CDC)continue; TVector3 pos(hit->r*cos(hit->phi), hit->r*sin(hit->phi), hit->z); gset.points.push_back(pos); } graphics.push_back(gset); } // FDC Truth points if(hdvmf->GetCheckButton("fdctruth")){ vector mctrackhits; loop->Get(mctrackhits); DGraphicSet gset(12, kMarker, 0.5); for(unsigned int i=0; isystem != SYS_FDC)continue; TVector3 pos(hit->r*cos(hit->phi), hit->r*sin(hit->phi), hit->z); gset.points.push_back(pos); } graphics.push_back(gset); } // TOF Truth points if(hdvmf->GetCheckButton("toftruth")){ vector mctrackhits; loop->Get(mctrackhits); DGraphicSet gset(kBlack, kMarker, 0.5); for(unsigned int i=0; isystem != SYS_TOF)continue; TVector3 pos(hit->r*cos(hit->phi), hit->r*sin(hit->phi), hit->z); gset.points.push_back(pos); } graphics.push_back(gset); } // BCAL Truth points if(hdvmf->GetCheckButton("bcaltruth")){ vector mctrackhits; loop->Get(mctrackhits); DGraphicSet gset(kBlack, kMarker, 1.0); for(unsigned int i=0; isystem != SYS_BCAL)continue; TVector3 pos(hit->r*cos(hit->phi), hit->r*sin(hit->phi), hit->z); gset.points.push_back(pos); } graphics.push_back(gset); } // FCAL Truth points if(hdvmf->GetCheckButton("fcaltruth")){ vector fcalgeometries; vector mcfcalhits; loop->Get(fcalgeometries); loop->Get(mcfcalhits); if(fcalgeometries.size()>0){ const DFCALGeometry *fgeom = fcalgeometries[0]; DGraphicSet gset(kBlack, kMarker, 0.25); for(unsigned int i=0; ipositionOnFace(hit->row, hit->column); TVector3 pos(pos_face.X(), pos_face.Y(), FCAL_Zmin); gset.points.push_back(pos); } graphics.push_back(gset); } } // DMCTrajectoryPoints if(hdvmf->GetCheckButton("trajectories")){ vector mctrajectorypoints; loop->Get(mctrajectorypoints); int colors[] = {kBlack, kMagenta, kGreen, 13, 14, 39}; int Ncolors = 1; int Ntraj=0; DGraphicSet gset(colors[Ntraj%Ncolors], kLine, 3.0); TVector3 last_point; for(unsigned int i=0; ix, pt->y, pt->z); if(i>0){ if((v-last_point).Mag() > 10.0){ graphics.push_back(gset); gset.points.clear(); gset.color = colors[(++Ntraj)%Ncolors]; } } gset.points.push_back(v); last_point = v; } graphics.push_back(gset); } // DTrackCandidate if(hdvmf->GetCheckButton("candidates")){ vector trackcandidates; loop->Get(trackcandidates, hdvmf->GetFactoryTag("DTrackCandidate")); for(unsigned int i=0; icharge() >0.0) color += 100; // lighter shade //if(trackcandidates[i]->charge() <0.0) color += 150; // darker shade AddKinematicDataTrack(trackcandidates[i], color, size); } } // DTrackWireBased if(hdvmf->GetCheckButton("wiretracks")){ vector wiretracks; loop->Get(wiretracks, hdvmf->GetFactoryTag("DTrackWireBased")); for(unsigned int i=0; iGetCheckButton("timetracks")){ vector timetracks; loop->Get(timetracks, hdvmf->GetFactoryTag("DTrackTimeBased")); for(unsigned int i=0; iGetCheckButton("particles")){ vector particles; loop->Get(particles, hdvmf->GetFactoryTag("DParticle")); for(unsigned int i=0; icharge()>0) color=kMagenta; if (fabs(particles[i]->charge())<1.e-3) color=kGreen+2; if (particles[i]->mass()>0.9) size=2.5; AddKinematicDataTrack(particles[i],color,size); } } } //------------------------------------------------------------------ // UpdateTrackLabels //------------------------------------------------------------------ void MyProcessor::UpdateTrackLabels(void) { // Get the label pointers string name, tag; map > &thrownlabs = hdvmf->GetThrownLabels(); map > &reconlabs = hdvmf->GetReconstructedLabels(); hdvmf->GetReconFactory(name, tag); // Get Thrown particles vector throwns; if(loop)loop->Get(throwns); // Get the track info as DKinematicData objects vector trks; if(name=="DParticle"){ vector particles; if(loop)loop->Get(particles, tag.c_str()); for(unsigned int i=0; i timetracks; if(loop)loop->Get(timetracks, tag.c_str()); for(unsigned int i=0; i wiretracks; if(loop)loop->Get(wiretracks, tag.c_str()); for(unsigned int i=0; i candidates; if(loop)loop->Get(candidates, tag.c_str()); for(unsigned int i=0; i photons; if(loop)loop->Get(photons, tag.c_str()); for(unsigned int i=0; i >::iterator iter; for(iter=reconlabs.begin(); iter!=reconlabs.end(); iter++){ vector &labs = iter->second; for(unsigned int i=1; iSetText("--------"); } } for(iter=thrownlabs.begin(); iter!=thrownlabs.end(); iter++){ vector &labs = iter->second; for(unsigned int i=1; iSetText("--------"); } } // Loop over thrown particles and fill in labels int ii=0; for(unsigned int i=0; itype==0)continue; int row = thrownlabs["trk"].size()-(ii++)-1; if(row<1)break; stringstream trkno, type, p, theta, phi, z; trkno<SetText(trkno.str().c_str()); thrownlabs["type"][row]->SetText(ParticleType((Particle_t)trk->type)); p<momentum().Mag(); thrownlabs["p"][row]->SetText(p.str().c_str()); theta<momentum().Theta()*TMath::RadToDeg(); thrownlabs["theta"][row]->SetText(theta.str().c_str()); double myphi = trk->momentum().Phi(); if(myphi<0.0)myphi+=2.0*M_PI; phi<SetText(phi.str().c_str()); z<position().Z(); thrownlabs["z"][row]->SetText(z.str().c_str()); } // Loop over tracks and fill in labels for(unsigned int i=0; iSetText(trkno.str().c_str()); double mass = trk->mass(); if(fabs(mass-0.13957)<1.0E-4)type<<"pi"; else if(fabs(mass-0.93827)<1.0E-4)type<<"proton"; else if(fabs(mass-0.493677)<1.0E-4)type<<"K"; else if(fabs(mass-0.000511)<1.0E-4)type<<"e"; else if (fabs(mass)<1.e-4 && fabs(trk->charge())<1.e-4) type << "gamma"; else type<<"q="; if (fabs(trk->charge())>1.e-4){ type<<(trk->charge()>0 ? "+":"-"); } reconlabs["type"][row]->SetText(type.str().c_str()); p<momentum().Mag(); reconlabs["p"][row]->SetText(p.str().c_str()); theta<momentum().Theta()*TMath::RadToDeg(); reconlabs["theta"][row]->SetText(theta.str().c_str()); double myphi = trk->momentum().Phi(); if(myphi<0.0)myphi+=2.0*M_PI; phi<SetText(phi.str().c_str()); z<position().Z(); reconlabs["z"][row]->SetText(z.str().c_str()); // Get chisq and Ndof for DTrackTimeBased or DTrackWireBased objects const DTrackTimeBased *timetrack=dynamic_cast(trk); const DTrackWireBased *track=dynamic_cast(trk); const DParticle *part=dynamic_cast(trk); if(timetrack){ chisq_per_dof<chisq/timetrack->Ndof; Ndof<Ndof; }else if(track){ chisq_per_dof<chisq/track->Ndof; Ndof<Ndof; }else if (part && fabs(part->charge())>0.1){ chisq_per_dof<chisq/part->Ndof; Ndof<Ndof; } else{ chisq_per_dof<<"N/A"; Ndof<<"N/A"; } reconlabs["chisq/Ndof"][row]->SetText(chisq_per_dof.str().c_str()); reconlabs["Ndof"][row]->SetText(Ndof.str().c_str()); } } //------------------------------------------------------------------ // AddKinematicDataTrack //------------------------------------------------------------------ void MyProcessor::AddKinematicDataTrack(const DKinematicData* kd, int color, double size) { // Create a reference trajectory with the given kinematic data and swim // it through the detector. DReferenceTrajectory rt(Bfield); if(MATERIAL_MAP_MODEL=="DRootGeom"){ rt.SetDRootGeom(RootGeom); rt.SetDGeometry(NULL); }else if(MATERIAL_MAP_MODEL=="DGeometry"){ rt.SetDRootGeom(NULL); rt.SetDGeometry(geom); }else if(MATERIAL_MAP_MODEL!="NONE"){ _DBG_<<"WARNING: Invalid value for TRKFIT:MATERIAL_MAP_MODEL (=\""<mass()); rt.Swim(kd->position(), kd->momentum(), kd->charge()); // Create a new graphics set and fill it with all of the trajectory points DGraphicSet gset(color, kLine, size); DReferenceTrajectory::swim_step_t *step = rt.swim_steps; for(int i=0; iorigin); } // Push the graphics set onto the stack graphics.push_back(gset); } //------------------------------------------------------------------ // GetFactoryNames //------------------------------------------------------------------ void MyProcessor::GetFactoryNames(vector &facnames) { vector loops = app->GetJEventLoops(); if(loops.size()>0){ vector facnames; loops[0]->GetFactoryNames(facnames); } } //------------------------------------------------------------------ // GetFactories //------------------------------------------------------------------ void MyProcessor::GetFactories(vector &factories) { vector loops = app->GetJEventLoops(); if(loops.size()>0){ factories = loops[0]->GetFactories(); } } //------------------------------------------------------------------ // GetNrows //------------------------------------------------------------------ unsigned int MyProcessor::GetNrows(const string &factory, string tag) { vector loops = app->GetJEventLoops(); if(loops.size()>0){ // Here is something a little tricky. The GetFactory() method of JEventLoop // gets the factory of the specified data name and tag, but without trying // to substitute a user-specified tag (a'la -PDEFTAG:XXX=YYY) as is done // on normal Get() method calls. Therefore, we have to check for the default // tags ourselves and substitute it "by hand". if(tag==""){ map default_tags = loops[0]->GetDefaultTags(); map::const_iterator iter = default_tags.find(factory); if(iter!=default_tags.end())tag = iter->second.c_str(); } JFactory_base *fac = loops[0]->GetFactory(factory, tag.c_str()); // Since calling GetNrows will cause the program to quit if there is // not a valid event, then first check that there is one before calling it if(loops[0]->GetJEvent().GetJEventSource() == NULL)return 0; return fac==NULL ? 0:(unsigned int)fac->GetNrows(); } return 0; } //------------------------------------------------------------------ // GetDReferenceTrajectory //------------------------------------------------------------------ void MyProcessor::GetDReferenceTrajectory(string dataname, string tag, unsigned int index, DReferenceTrajectory* &rt, vector &cdchits) { _DBG__; // initialize rt to NULL in case we don't find the one requested rt = NULL; cdchits.clear(); // Get pointer to the JEventLoop so we can get at the data vector loops = app->GetJEventLoops(); if(loops.size()==0)return; JEventLoop* &loop = loops[0]; // Variables to hold track parameters DVector3 pos, mom(0,0,0); double q=0.0; double mass; // Find the specified track if(dataname=="DParticle"){ vector particles; loop->Get(particles, tag.c_str()); if(index>=particles.size())return; q = particles[index]->charge(); pos = particles[index]->position(); mom = particles[index]->momentum(); particles[index]->Get(cdchits); mass = particles[index]->mass(); } if(dataname=="DTrackTimeBased"){ vector timetracks; loop->Get(timetracks, tag.c_str()); if(index>=timetracks.size())return; q = timetracks[index]->charge(); pos = timetracks[index]->position(); mom = timetracks[index]->momentum(); timetracks[index]->Get(cdchits); mass = timetracks[index]->mass(); } if(dataname=="DTrackWireBased"){ vector wiretracks; loop->Get(wiretracks, tag.c_str()); if(index>=wiretracks.size())return; q = wiretracks[index]->charge(); pos = wiretracks[index]->position(); mom = wiretracks[index]->momentum(); wiretracks[index]->Get(cdchits); mass = wiretracks[index]->mass(); } if(dataname=="DTrackCandidate"){ vector tracks; loop->Get(tracks, tag.c_str()); if(index>=tracks.size())return; q = tracks[index]->charge(); pos = tracks[index]->position(); mom = tracks[index]->momentum(); tracks[index]->Get(cdchits); mass = tracks[index]->mass(); } if(dataname=="DMCThrown"){ vector tracks; loop->Get(tracks, tag.c_str()); if(index>=tracks.size())return; const DMCThrown *t = tracks[index]; q = t->charge(); pos = t->position(); mom = t->momentum(); tracks[index]->Get(cdchits); mass = tracks[index]->mass(); _DBG_<<"mass="<SetDRootGeom(RootGeom); rt->SetDGeometry(NULL); }else if(MATERIAL_MAP_MODEL=="DGeometry"){ rt->SetDRootGeom(NULL); rt->SetDGeometry(geom); }else if(MATERIAL_MAP_MODEL!="NONE"){ _DBG_<<"WARNING: Invalid value for TRKFIT:MATERIAL_MAP_MODEL (=\""<Swim(pos, mom, q); } //------------------------------------------------------------------ // GetAllWireHits //------------------------------------------------------------------ void MyProcessor::GetAllWireHits(vector > &allhits) { /// Argument is vector of pairs that contain a pointer to the /// DCoordinateSystem representing a wire and a double that /// represents the drift distance. To get info on the specific /// wire, one needs to attempt a dynamic_cast to both a DCDCWire /// and a DFDCWire and access the parameters of whichever one succeeds. // Get pointer to the JEventLoop so we can get at the data vector loops = app->GetJEventLoops(); if(loops.size()==0)return; JEventLoop* &loop = loops[0]; // Get CDC wire hits vector cdchits; loop->Get(cdchits); for(unsigned int i=0; i hit; hit.first = cdchits[i]->wire; hit.second = cdchits[i]->dist; allhits.push_back(hit); } // Get FDC wire hits vector fdchits; loop->Get(fdchits); for(unsigned int i=0; i hit; hit.first = fdchits[i]->wire; hit.second = fdchits[i]->dist; allhits.push_back(hit); } }