#include "DEventWriterREST.h" //file-scope so shared amongst threads; only accessed below via locks size_t gRESTNumOutputThreads = 0; map >* gRESTOutputFilePointers = NULL; DEventWriterREST::DEventWriterREST(JEventLoop* locEventLoop, string locOutputFileBaseName) : dOutputFileBaseName(locOutputFileBaseName) { japp->WriteLock("RESTWriter"); { ++gRESTNumOutputThreads; if(gRESTOutputFilePointers == NULL) gRESTOutputFilePointers = new map >(); } japp->Unlock("RESTWriter"); HDDM_USE_COMPRESSION = true; gPARMS->SetDefaultParameter("HDDM:USE_COMPRESSION", HDDM_USE_COMPRESSION, "Turn on/off compression of the output HDDM stream. Set to \"0\" to turn off (it's on by default)"); } bool DEventWriterREST::Write_RESTEvent(JEventLoop* locEventLoop, string locOutputFileNameSubString) const { string locOutputFileName = Get_OutputFileName(locOutputFileNameSubString); hddm_r::HDDM locRecord; hddm_r::ReconstructedPhysicsEventList res = locRecord.addReconstructedPhysicsEvents(1); // load the run and event numbers JEvent& event = locEventLoop->GetJEvent(); res().setRunNo(event.GetRunNumber()); res().setEventNo(event.GetEventNumber()); // push any DMCReaction objects to the output record std::vector reactions; locEventLoop->Get(reactions); for (size_t i=0; i < reactions.size(); i++) { hddm_r::ReactionList rea = res().addReactions(1); rea().setType(reactions[i]->type); rea().setWeight(reactions[i]->weight); rea().setEbeam(reactions[i]->beam.energy()); rea().setTargetType(reactions[i]->target.PID()); // Right now the DMCThrown object does not tell which of the listed // reactions gave rise to it, so associate them all to the first one. if (i == 0) { std::vector throwns; locEventLoop->Get(throwns); double vx,vy,vz,vt; vx = vy = vz = vt = -9999; hddm_r::VertexList ver = rea().getVertices(); for (size_t it=0; it < throwns.size(); ++it) { DVector3 orig(throwns[it]->x(),throwns[it]->y(),throwns[it]->z()); if (vx != throwns[it]->x() || vy != throwns[it]->y() || vz != throwns[it]->z() || vt != throwns[it]->time() ) { ver = rea().addVertices(1); hddm_r::OriginList ori = ver().addOrigins(1); ori().setT(vt=throwns[it]->time()); ori().setVx(vx=throwns[it]->x()); ori().setVy(vy=throwns[it]->y()); ori().setVz(vz=throwns[it]->z()); } hddm_r::ProductList pro = ver().addProducts(1); pro().setId(throwns[it]->myid); pro().setParentId(throwns[it]->parentid); int pdgtype = throwns[it]->pdgtype; if (pdgtype == 0) pdgtype = PDGtype((Particle_t)throwns[it]->type); pro().setPdgtype(pdgtype); hddm_r::MomentumList mom = pro().addMomenta(1); mom().setE(throwns[it]->energy()); mom().setPx(throwns[it]->px()); mom().setPy(throwns[it]->py()); mom().setPz(throwns[it]->pz()); } } } // push any DTagger objects to the output record std::vector taggerhits; locEventLoop->Get(taggerhits); for (size_t i=0; i < taggerhits.size(); i++) { hddm_r::TaggerHitList hit = res().addTaggerHits(1); hit().setT(taggerhits[i]->t); hit().setE(taggerhits[i]->E); } // push any DFCALShower objects to the output record std::vector fcalshowers; locEventLoop->Get(fcalshowers); for (size_t i=0; i < fcalshowers.size(); i++) { hddm_r::FcalShowerList fcal = res().addFcalShowers(1); DVector3 pos = fcalshowers[i]->getPosition(); DVector3 poserr = fcalshowers[i]->getPositionError(); fcal().setX(pos(0)); fcal().setY(pos(1)); fcal().setZ(pos(2)); fcal().setT(fcalshowers[i]->getTime()); fcal().setE(fcalshowers[i]->getEnergy()); fcal().setXerr(poserr(0)); fcal().setYerr(poserr(1)); fcal().setZerr(poserr(2)); fcal().setTerr(0); fcal().setEerr(0); fcal().setXycorr(0); fcal().setXzcorr(0); fcal().setYzcorr(0); fcal().setEzcorr(0); fcal().setTzcorr(0); } // push any DBCALShower objects to the output record std::vector bcalshowers; locEventLoop->Get(bcalshowers); for (size_t i=0; i < bcalshowers.size(); i++) { hddm_r::BcalShowerList bcal = res().addBcalShowers(1); DVector3 pos(bcalshowers[i]->x,bcalshowers[i]->y,bcalshowers[i]->z); bcal().setX(bcalshowers[i]->x); bcal().setY(bcalshowers[i]->y); bcal().setZ(bcalshowers[i]->z); bcal().setT(bcalshowers[i]->t); bcal().setE(bcalshowers[i]->E); bcal().setXerr(bcalshowers[i]->xErr); bcal().setYerr(bcalshowers[i]->yErr); bcal().setZerr(bcalshowers[i]->zErr); bcal().setTerr(bcalshowers[i]->tErr); bcal().setEerr(0); bcal().setXycorr(0); bcal().setXzcorr(0); bcal().setYzcorr(0); bcal().setEzcorr(0); bcal().setTzcorr(0); } // push any DTOFPoint objects to the output record std::vector tofpoints; locEventLoop->Get(tofpoints); for (size_t i=0; i < tofpoints.size(); i++) { hddm_r::TofPointList tof = res().addTofPoints(1); tof().setX(tofpoints[i]->pos(0)); tof().setY(tofpoints[i]->pos(1)); tof().setZ(tofpoints[i]->pos(2)); tof().setT(tofpoints[i]->t); tof().setDE(tofpoints[i]->dE); } // push any DSCHit objects to the output record std::vector starthits; locEventLoop->Get(starthits); for (size_t i=0; i < starthits.size(); i++) { hddm_r::StartHitList hit = res().addStartHits(1); hit().setSector(starthits[i]->sector); hit().setT(starthits[i]->t); hit().setDE(starthits[i]->dE); } // push any DTrackTimeBased objects to the output record std::vector tracks; locEventLoop->Get(tracks); for (size_t i=0; i < tracks.size(); ++i) { hddm_r::ChargedTrackList tra = res().addChargedTracks(1); tra().setCandidateId(tracks[i]->candidateid); tra().setPtype(tracks[i]->PID()); hddm_r::TrackFitList fit = tra().addTrackFits(1); fit().setNdof(tracks[i]->Ndof); fit().setChisq(tracks[i]->chisq); fit().setX0(tracks[i]->x()); fit().setY0(tracks[i]->y()); fit().setZ0(tracks[i]->z()); fit().setPx(tracks[i]->px()); fit().setPy(tracks[i]->py()); fit().setPz(tracks[i]->pz()); fit().setT0(tracks[i]->t0()); fit().setT0err(tracks[i]->t0_err()); fit().setT0det(tracks[i]->t0_detector()); DMatrixDSym errors = tracks[i]->TrackingErrorMatrix(); fit().setE11(errors(0,0)); fit().setE12(errors(0,1)); fit().setE13(errors(0,2)); fit().setE14(errors(0,3)); fit().setE15(errors(0,4)); fit().setE22(errors(1,1)); fit().setE23(errors(1,2)); fit().setE24(errors(1,3)); fit().setE25(errors(1,4)); fit().setE33(errors(2,2)); fit().setE34(errors(2,3)); fit().setE35(errors(2,4)); fit().setE44(errors(3,3)); fit().setE45(errors(3,4)); fit().setE55(errors(4,4)); if (tracks[i]->dNumHitsUsedFordEdx_FDC + tracks[i]->dNumHitsUsedFordEdx_CDC) { hddm_r::DEdxDCList elo = tra().addDEdxDCs(1); elo().setNsampleFDC(tracks[i]->dNumHitsUsedFordEdx_FDC); elo().setNsampleCDC(tracks[i]->dNumHitsUsedFordEdx_CDC); elo().setDxFDC(tracks[i]->ddx_FDC); elo().setDxCDC(tracks[i]->ddx_CDC); elo().setDEdxFDC(tracks[i]->ddEdx_FDC); elo().setDEdxCDC(tracks[i]->ddEdx_CDC); } } // push any DMCTrigger objects to the output record std::vector triggers; locEventLoop->Get(triggers); for (size_t i=0; i < triggers.size(); i++) { hddm_r::TriggerList trigger = res().addTriggers(1); trigger().setL1a(triggers[i]->L1a_fired); trigger().setL1b(triggers[i]->L1b_fired); trigger().setL1c(triggers[i]->L1c_fired); } // push any DDetectorMatches objects to the output record std::vector locDetectorMatches; locEventLoop->Get(locDetectorMatches); for(size_t loc_i = 0; loc_i < locDetectorMatches.size(); ++loc_i) { hddm_r::DetectorMatchesList matches = res().addDetectorMatcheses(1); for(size_t loc_j = 0; loc_j < tracks.size(); ++loc_j) { vector locShowerMatchParamsVector; locDetectorMatches[loc_i]->Get_BCALMatchParams(tracks[loc_j], locShowerMatchParamsVector); for(size_t loc_k = 0; loc_k < locShowerMatchParamsVector.size(); ++loc_k) { hddm_r::BcalMatchParamsList bcalList = matches().addBcalMatchParamses(1); bcalList().setTrack(loc_j); const DBCALShower* locBCALShower = static_cast(locShowerMatchParamsVector[loc_k].dShowerObject); size_t locBCALindex = 0; for(; locBCALindex < bcalshowers.size(); ++locBCALindex) { if(bcalshowers[locBCALindex] == locBCALShower) break; } bcalList().setShower(locBCALindex); bcalList().setDoca(locShowerMatchParamsVector[loc_k].dDOCAToShower); bcalList().setDx(locShowerMatchParamsVector[loc_k].dx); bcalList().setPathlength(locShowerMatchParamsVector[loc_k].dPathLength); bcalList().setTflight(locShowerMatchParamsVector[loc_k].dFlightTime); bcalList().setTflightvar(locShowerMatchParamsVector[loc_k].dFlightTimeVariance); } locDetectorMatches[loc_i]->Get_FCALMatchParams(tracks[loc_j], locShowerMatchParamsVector); for(size_t loc_k = 0; loc_k < locShowerMatchParamsVector.size(); ++loc_k) { hddm_r::FcalMatchParamsList fcalList = matches().addFcalMatchParamses(1); fcalList().setTrack(loc_j); const DFCALShower* locFCALShower = static_cast(locShowerMatchParamsVector[loc_k].dShowerObject); size_t locFCALindex = 0; for(; locFCALindex < fcalshowers.size(); ++locFCALindex) { if(fcalshowers[locFCALindex] == locFCALShower) break; } fcalList().setShower(locFCALindex); fcalList().setDoca(locShowerMatchParamsVector[loc_k].dDOCAToShower); fcalList().setDx(locShowerMatchParamsVector[loc_k].dx); fcalList().setPathlength(locShowerMatchParamsVector[loc_k].dPathLength); fcalList().setTflight(locShowerMatchParamsVector[loc_k].dFlightTime); fcalList().setTflightvar(locShowerMatchParamsVector[loc_k].dFlightTimeVariance); } vector locTOFHitMatchParamsVector; locDetectorMatches[loc_i]->Get_TOFMatchParams(tracks[loc_j], locTOFHitMatchParamsVector); for(size_t loc_k = 0; loc_k < locTOFHitMatchParamsVector.size(); ++loc_k) { hddm_r::TofMatchParamsList tofList = matches().addTofMatchParamses(1); tofList().setTrack(loc_j); size_t locTOFindex = 0; for(; locTOFindex < tofpoints.size(); ++locTOFindex) { if(tofpoints[locTOFindex] == locTOFHitMatchParamsVector[loc_k].dTOFPoint) break; } tofList().setHit(locTOFindex); tofList().setDEdx(locTOFHitMatchParamsVector[loc_k].dEdx); tofList().setDoca(locTOFHitMatchParamsVector[loc_k].dDOCAToHit); tofList().setPathlength(locTOFHitMatchParamsVector[loc_k].dPathLength); tofList().setTflight(locTOFHitMatchParamsVector[loc_k].dFlightTime); tofList().setTflightvar(locTOFHitMatchParamsVector[loc_k].dFlightTimeVariance); } vector locSCHitMatchParamsVector; locDetectorMatches[loc_i]->Get_SCMatchParams(tracks[loc_j], locSCHitMatchParamsVector); for(size_t loc_k = 0; loc_k < locSCHitMatchParamsVector.size(); ++loc_k) { hddm_r::ScMatchParamsList scList = matches().addScMatchParamses(1); scList().setTrack(loc_j); size_t locSCindex = 0; for(; locSCindex < starthits.size(); ++locSCindex) { if(starthits[locSCindex] == locSCHitMatchParamsVector[loc_k].dSCHit) break; } scList().setHit(locSCindex); scList().setDEdx(locSCHitMatchParamsVector[loc_k].dEdx); scList().setDeltaphi(locSCHitMatchParamsVector[loc_k].dDeltaPhiToHit); scList().setEhit(locSCHitMatchParamsVector[loc_k].dHitEnergy); scList().setPathlength(locSCHitMatchParamsVector[loc_k].dPathLength); scList().setTflight(locSCHitMatchParamsVector[loc_k].dFlightTime); scList().setTflightvar(locSCHitMatchParamsVector[loc_k].dFlightTimeVariance); scList().setThit(locSCHitMatchParamsVector[loc_k].dHitTime); scList().setThitvar(locSCHitMatchParamsVector[loc_k].dHitTimeVariance); } double locFlightTimePCorrelation = 0.0; if(locDetectorMatches[loc_i]->Get_FlightTimePCorrelation(tracks[loc_j], SYS_BCAL, locFlightTimePCorrelation)) { hddm_r::TflightPCorrelationList correlationList = matches().addTflightPCorrelations(1); correlationList().setTrack(loc_j); correlationList().setSystem(SYS_BCAL); correlationList().setCorrelation(locFlightTimePCorrelation); } if(locDetectorMatches[loc_i]->Get_FlightTimePCorrelation(tracks[loc_j], SYS_FCAL, locFlightTimePCorrelation)) { hddm_r::TflightPCorrelationList correlationList = matches().addTflightPCorrelations(1); correlationList().setTrack(loc_j); correlationList().setSystem(SYS_FCAL); correlationList().setCorrelation(locFlightTimePCorrelation); } if(locDetectorMatches[loc_i]->Get_FlightTimePCorrelation(tracks[loc_j], SYS_TOF, locFlightTimePCorrelation)) { hddm_r::TflightPCorrelationList correlationList = matches().addTflightPCorrelations(1); correlationList().setTrack(loc_j); correlationList().setSystem(SYS_TOF); correlationList().setCorrelation(locFlightTimePCorrelation); } if(locDetectorMatches[loc_i]->Get_FlightTimePCorrelation(tracks[loc_j], SYS_START, locFlightTimePCorrelation)) { hddm_r::TflightPCorrelationList correlationList = matches().addTflightPCorrelations(1); correlationList().setTrack(loc_j); correlationList().setSystem(SYS_START); correlationList().setCorrelation(locFlightTimePCorrelation); } } double locDistance = 0.0; for(size_t loc_j = 0; loc_j < bcalshowers.size(); ++loc_j) { if(!locDetectorMatches[loc_i]->Get_DistanceToNearestTrack(bcalshowers[loc_j], locDistance)) continue; hddm_r::BcalDOCAtoTrackList bcalDocaList = matches().addBcalDOCAtoTracks(1); bcalDocaList().setShower(loc_j); bcalDocaList().setDoca(locDistance); } for(size_t loc_j = 0; loc_j < fcalshowers.size(); ++loc_j) { if(!locDetectorMatches[loc_i]->Get_DistanceToNearestTrack(fcalshowers[loc_j], locDistance)) continue; hddm_r::FcalDOCAtoTrackList fcalDocaList = matches().addFcalDOCAtoTracks(1); fcalDocaList().setShower(loc_j); fcalDocaList().setDoca(locDistance); } } // write the resulting record to the output stream bool locWriteStatus = Write_RESTEvent(locOutputFileName, locRecord); locRecord.clear(); return locWriteStatus; } string DEventWriterREST::Get_OutputFileName(string locOutputFileNameSubString) const { string locOutputFileName = dOutputFileBaseName; if(locOutputFileNameSubString != "") locOutputFileName += string("_") + locOutputFileNameSubString; return (locOutputFileName + string(".hddm")); } bool DEventWriterREST::Write_RESTEvent(string locOutputFileName, hddm_r::HDDM& locRecord) const { japp->WriteLock("RESTWriter"); { //check to see if the REST file is open if(gRESTOutputFilePointers->find(locOutputFileName) != gRESTOutputFilePointers->end()) { //open: get pointer, write event hddm_r::ostream* locOutputRESTFileStream = (*gRESTOutputFilePointers)[locOutputFileName].second; *(locOutputRESTFileStream) << locRecord; japp->Unlock("RESTWriter"); return true; } //not open: open it pair locRESTFilePointers(NULL, NULL); locRESTFilePointers.first = new ofstream(locOutputFileName.c_str()); if(!locRESTFilePointers.first->is_open()) { //failed to open delete locRESTFilePointers.first; japp->Unlock("RESTWriter"); return false; } locRESTFilePointers.second = new hddm_r::ostream(*locRESTFilePointers.first); // enable on-the-fly bzip2 compression on output stream if(HDDM_USE_COMPRESSION) { jout << " Enabling bz2 compression of output HDDM file stream" << endl; locRESTFilePointers.second->setCompression(hddm_r::k_bz2_compression); }else{ jout << " HDDM compression disabled" << endl; } // write a comment record at the head of the file hddm_r::HDDM locCommentRecord; hddm_r::ReconstructedPhysicsEventList res = locCommentRecord.addReconstructedPhysicsEvents(1); hddm_r::CommentList comment = res().addComments(); comment().setText("this is a REST event stream, yadda yadda"); *(locRESTFilePointers.second) << locCommentRecord; locCommentRecord.clear(); //write the event *(locRESTFilePointers.second) << locRecord; //store the stream pointers (*gRESTOutputFilePointers)[locOutputFileName] = locRESTFilePointers; } japp->Unlock("RESTWriter"); return true; } DEventWriterREST::~DEventWriterREST(void) { japp->WriteLock("RESTWriter"); { --gRESTNumOutputThreads; if(gRESTNumOutputThreads > 0) { japp->Unlock("RESTWriter"); return; //not the last thread writing to REST files } if(gRESTOutputFilePointers == NULL) { japp->Unlock("RESTWriter"); return; //not the last thread writing to REST files } //last thread writing to REST files: close all files and free all memory map >::iterator locIterator; for(locIterator = gRESTOutputFilePointers->begin(); locIterator != gRESTOutputFilePointers->end(); ++locIterator) { string locOutputFileName = locIterator->first; if(locIterator->second.second != NULL) delete locIterator->second.second; if(locIterator->second.first != NULL) delete locIterator->second.first; std::cout << "Closed REST file " << locOutputFileName << std::endl; } delete gRESTOutputFilePointers; gRESTOutputFilePointers = NULL; } japp->Unlock("RESTWriter"); }