Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 12 additions & 0 deletions sbncode/CAFMaker/CAFMakerParams.h
Original file line number Diff line number Diff line change
Expand Up @@ -338,6 +338,18 @@ namespace caf
"crttracks" // sbnd
};

Atom<string> SBNDFrameShiftInfoLabel {
Name("SBNDFrameShiftInfoLabel"),
Comment("Label of sbnd frame shift."),
"frameshift" // sbnd
};

Atom<string> SBNDTimingInfoLabel {
Name("SBNDTimingInfoLabel"),
Comment("Label of sbnd timing shift."),
"frameshift" // sbnd
};

Atom<string> CRTPMTLabel {
Name("CRTPMTLabel"),
Comment("Label for the CRTPMT Matched variables from the crtpmt data product"),
Expand Down
74 changes: 73 additions & 1 deletion sbncode/CAFMaker/CAFMaker_module.cc
Original file line number Diff line number Diff line change
Expand Up @@ -316,6 +316,9 @@ class CAFMaker : public art::EDProducer {
void FixPMTReferenceTimes(StandardRecord &rec, double PMT_reference_time);
void FixCRTReferenceTimes(StandardRecord &rec, double CRTT0_reference_time, double CRTT1_reference_time);

void SBNDShiftCRTReference(StandardRecord &rec, double SBNDFrame);
void SBNDShiftPMTReference(StandardRecord &rec, double SBNDFrame);

/// Equivalent of FindManyP except a return that is !isValid() prints a
/// messsage and aborts if StrictMode is true.
template <class T, class U>
Expand Down Expand Up @@ -499,6 +502,41 @@ void CAFMaker::BlindEnergyParameters(StandardRecord* brec) {
}
}

void CAFMaker::SBNDShiftCRTReference(StandardRecord &rec, double SBNDFrame){

//CRT Space Point
for (SRCRTSpacePoint &sp: rec.crt_spacepoints){
sp.time += SBNDFrame; //ns
}

//CRT Track
for (SRSBNDCRTTrack &trk: rec.sbnd_crt_tracks){
trk.time += SBNDFrame; //ns
}

//TODO: CRT Space Point and Track Match
//for (SRPFP &pfp: rec.reco.pfp) {
// pfp.trk.crtspacepoint.spacepoint.time += SBNDFrame;
// pfp.trk.crtsbndtrack.track.time += SBNDFrame;
//}
}

void CAFMaker::SBNDShiftPMTReference(StandardRecord &rec, double SBNDFrame){

double SBNDFrame_us = SBNDFrame / 1000.0; //convert ns to us

//Op Flash
for (SROpFlash &opf: rec.opflashes) {
opf.time += SBNDFrame_us;
opf.firsttime += SBNDFrame_us;
}

//OpT0 match to slice
for (SRSlice &s: rec.slc) {
s.opt0.time += SBNDFrame_us;
}
}

void CAFMaker::FixPMTReferenceTimes(StandardRecord &rec, double PMT_reference_time) {
// Fix the flashes
for (SROpFlash &f: rec.opflashes) {
Expand Down Expand Up @@ -1602,6 +1640,8 @@ void CAFMaker::produce(art::Event& evt) noexcept {
std::vector<caf::SRCRTTrack> srcrttracks;
std::vector<caf::SRCRTSpacePoint> srcrtspacepoints;
std::vector<caf::SRSBNDCRTTrack> srsbndcrttracks;
caf::SRSBNDFrameShiftInfo srsbndframeshiftinfo;
caf::SRSBNDTimingInfo srsbndtiminginfo;

if(fDet == kICARUS)
{
Expand Down Expand Up @@ -1650,6 +1690,22 @@ void CAFMaker::produce(art::Event& evt) noexcept {
FillSBNDCRTTrack(sbndcrttracks[i], srsbndcrttracks.back());
}
}

art::Handle<raw::FrameShiftInfo> sbndframeshiftinfo_handle;
GetByLabelStrict(evt, fParams.SBNDFrameShiftInfoLabel(), sbndframeshiftinfo_handle);
// fill into event
if (sbndframeshiftinfo_handle.isValid()) {
raw::FrameShiftInfo const& sbndframeshiftinfo(*sbndframeshiftinfo_handle);
FillSBNDFrameShiftInfo(sbndframeshiftinfo, srsbndframeshiftinfo);
}

art::Handle<raw::TimingInfo> sbndtiminginfo_handle;
GetByLabelStrict(evt, fParams.SBNDTimingInfoLabel(), sbndtiminginfo_handle);
// fill into event
if (sbndtiminginfo_handle.isValid()) {
raw::TimingInfo const& sbndtiminginfo(*sbndtiminginfo_handle);
FillSBNDTimingInfo(sbndtiminginfo, srsbndtiminginfo);
}
}

// Get all of the CRTPMT Matches
Expand Down Expand Up @@ -2367,14 +2423,17 @@ void CAFMaker::produce(art::Event& evt) noexcept {
rec.nsbnd_crt_tracks = srsbndcrttracks.size();
rec.opflashes = srflashes;
rec.nopflashes = srflashes.size();
rec.sbnd_frames = srsbndframeshiftinfo;
rec.sbnd_timings = srsbndtiminginfo;

if (fParams.FillTrueParticles()) {
rec.true_particles = true_particles;
}
rec.ntrue_particles = true_particles.size();
rec.crtpmt_matches = srcrtpmtmatches;
rec.ncrtpmt_matches = srcrtpmtmatches.size();

// Fix the Reference time
// ICARUS: Fix the Reference time
//
// We want MC and Data to have the same reference time.
// In MC/LArSoft the "reference time" is canonically defined
Expand Down Expand Up @@ -2406,6 +2465,19 @@ void CAFMaker::produce(art::Event& evt) noexcept {
FixPMTReferenceTimes(rec, PMT_reference_time);

// TODO: TPC?

// SBND: Fix the Reference time in data depending on the stream (See FrameShift module on sbndcode repo)
if (isRealData & (fDet == kSBND))
{
mf::LogInfo("CAFMaker") << "Setting Reference Timing for timing object in SBND \n"
<< " Shift Apply At Caf Level = " << rec.sbnd_frames.frameApplyAtCaf << " ns\n";

//shift reference frame for CRT objects: crt trk, crt sp, crt sp match, crt trk match
SBNDShiftCRTReference(rec, rec.sbnd_frames.frameApplyAtCaf);

//shift reference frame for PMT objects: opflash, opt0
SBNDShiftPMTReference(rec, rec.sbnd_frames.frameApplyAtCaf);
}

// Get metadata information for header
unsigned int run = evt.run();
Expand Down
27 changes: 27 additions & 0 deletions sbncode/CAFMaker/FillReco.cxx
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,33 @@ namespace caf
srsbndcrttrack.tof = track.ToF();
}

void FillSBNDFrameShiftInfo(const raw::FrameShiftInfo &frame,
caf::SRSBNDFrameShiftInfo &srsbndframe,
bool allowEmpty)
{
srsbndframe.timingType = frame.timingType;
srsbndframe.frameTdcCrtt1 = frame.frameTdcCrtt1;
srsbndframe.frameTdcBes = frame.frameTdcBes;
srsbndframe.frameTdcRwm = frame.frameTdcRwm;
srsbndframe.frameHltCrtt1 = frame.frameHltCrtt1;
srsbndframe.frameHltBeamGate = frame.frameHltBeamGate;
srsbndframe.frameApplyAtCaf = frame.frameApplyAtCaf;
}

void FillSBNDTimingInfo(const raw::TimingInfo &timing,
caf::SRSBNDTimingInfo &srsbndtiming,
bool allowEmpty)
{
srsbndtiming.rawDAQHeaderTimestamp = timing.rawDAQHeaderTimestamp;
srsbndtiming.tdcCrtt1 = timing.tdcCrtt1;
srsbndtiming.tdcBes = timing.tdcBes;
srsbndtiming.tdcRwm = timing.tdcRwm;
srsbndtiming.tdcEtrig = timing.tdcEtrig;
srsbndtiming.hltCrtt1 = timing.hltCrtt1;
srsbndtiming.hltEtrig = timing.hltEtrig;
srsbndtiming.hltBeamGate = timing.hltBeamGate;
}

void FillCRTPMTMatch(const sbn::crt::CRTPMTMatching &match,
caf::SRCRTPMTMatch &srmatch,
bool allowEmpty){
Expand Down
9 changes: 9 additions & 0 deletions sbncode/CAFMaker/FillReco.h
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@
#include "sbnobj/Common/PMT/Data/PMTBeamSignal.hh"
#include "nusimdata/SimulationBase/MCParticle.h"
#include "nusimdata/SimulationBase/MCTruth.h"
#include "sbndcode/Timing/SBNDRawTimingObj.h"

#include "sbnanaobj/StandardRecord/SRSlice.h"
#include "sbnanaobj/StandardRecord/StandardRecord.h"
Expand Down Expand Up @@ -281,6 +282,14 @@ namespace caf
caf::SRPFP& srpfp,
bool allowEmpty = false);

void FillSBNDFrameShiftInfo(const raw::FrameShiftInfo &frame,
caf::SRSBNDFrameShiftInfo &srsbndframe,
bool allowEmpty = false);

void FillSBNDTimingInfo(const raw::TimingInfo &timing,
caf::SRSBNDTimingInfo &srsbndtiming,
bool allowEmpty = false);

template<class T, class U>
void CopyPropertyIfSet( const std::map<std::string, T>& props, const std::string& search, U& value );
}
Expand Down