Skip to content

Commit

Permalink
Merge branch 'feature/asutton_MCPMTWaveforms' of github.com:atcsutton…
Browse files Browse the repository at this point in the history
…/ToolAnalysis into feature/asutton_MCPMTWaveforms
  • Loading branch information
Andrew Sutton committed Dec 3, 2024
2 parents 4da2d42 + a81abc1 commit fc3c466
Show file tree
Hide file tree
Showing 63 changed files with 1,592 additions and 33 deletions.
24 changes: 24 additions & 0 deletions UserTools/MuonFitter/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
#MuonFitter Tool Documentation
***********************
Created by: Julie He

Maintained by: James Minock

Last updated: 10-2-2024
***********************

This Tool functions for vertex and energy reconstruction, with the primary purpose being vertex reconstruction. This Tool operates on a ML generated model that fits tank tracks according to MRD information.

This Tool is intended to act as a substitution to Michael's SimpleReconstruction Tool, filling "SimpleReco" values expected in PhaseIITreeMaker.

The vertex saved to "SimpleRecoVtx" is given in meters and is oriented such that the center of the tank is represented by (0,-0.1446,1.681).

There are additional variables created to be passed downstream including:

FittedTrackLengthInWater - estimated track length in water of tank

FittedMuonVertex - vertex of interaction assuming tank center at (0,0,0)

RecoMuonKE - estimated kinetic energy of reconstructed muon

Nlyrs - number of layers penetrated in MRD
72 changes: 68 additions & 4 deletions UserTools/NeutronMultiplicity/NeutronMultiplicity.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,7 @@ bool NeutronMultiplicity::Initialise(std::string configfile, DataModel &data){
bool NeutronMultiplicity::Execute(){

isMC = m_data->Stores.at("ANNIEEvent")->Get("MCFile",MCFile);
if (isMC) std::cout << "NeutronMultiplicity Tool: MCFile found!" << std::endl;

//Reset tree variables
this->ResetVariables();
Expand Down Expand Up @@ -334,6 +335,11 @@ bool NeutronMultiplicity::InitialiseHistograms(){
h_neutrons_energy_fv = new TH2F("h_neutrons_energy_fv","Neutron multiplicity vs muon energy (FV)",10,0,2000,20,0,20);
h_neutrons_energy_zoom = new TH2F("h_neutrons_energy_zoom","Neutron multiplicity vs muon energy",8,400,1200,20,0,20);
h_neutrons_energy_fv_zoom = new TH2F("h_neutrons_energy_fv_zoom","Neutron multiplicity vs muon energy (FV)",6,600,1200,20,0,20);
h_neutrons_energy_fv_down = new TH2F("h_neutrons_energy_fv_down","Neutron multiplicity vs muon energy (Downstream FV)",10,0,2000,20,0,20);
h_neutrons_energy_fv_cyl = new TH2F("h_neutrons_energy_fv_cyl","Neutron multiplicity vs muon energy (Cylindrical FV)",10,0,2000,20,0,20);
h_neutrons_q2 = new TH2F("h_neutrons_q2","Neutron multiplicity vs Q^{2}",100,0,2,20,0,20);
h_neutrons_q2_fv = new TH2F("h_neutrons_q2_fv","Neutron multiplicity vs Q^{2} (FV)",100,0,2,20,0,20);
h_neutrons_q2_fv_down = new TH2F("h_neutrons_q2_fv_down","Neutron multiplicity vs Q^{2} (Downstream FV)",100,0,2,20,0,20);
h_neutrons_costheta = new TH2F("h_neutrons_costheta","Neutron multiplicity vs muon angle",6,0.7,1.0,20,0,20);
h_neutrons_costheta_fv = new TH2F("h_neutrons_costheta_fv","Neutron multiplicity vs muon angle (FV)",6,0.7,1.0,20,0,20);
h_neutrons_pT = new TH2F("h_neutrons_pT","Neutron multiplicity vs transverse muon momentum",10,0,1000,20,0,20);
Expand Down Expand Up @@ -411,6 +417,26 @@ bool NeutronMultiplicity::InitialiseHistograms(){
h_neutrons_energy_fv_zoom->GetXaxis()->SetTitle("E_{#mu} [MeV]");
h_neutrons_energy_fv_zoom->GetYaxis()->SetTitle("Number of neutrons");

h_neutrons_energy_fv_down->SetStats(0);
h_neutrons_energy_fv_down->GetXaxis()->SetTitle("E_{#mu} [MeV]");
h_neutrons_energy_fv_down->GetYaxis()->SetTitle("Number of neutrons");

h_neutrons_energy_fv_cyl->SetStats(0);
h_neutrons_energy_fv_cyl->GetXaxis()->SetTitle("E_{#mu} [MeV]");
h_neutrons_energy_fv_cyl->GetYaxis()->SetTitle("Number of neutrons");

h_neutrons_q2->SetStats(0);
h_neutrons_q2->GetXaxis()->SetTitle("Q^{2} [(GeV/c)^{2}]");
h_neutrons_q2->GetYaxis()->SetTitle("Number of neutrons");

h_neutrons_q2_fv->SetStats(0);
h_neutrons_q2_fv->GetXaxis()->SetTitle("Q^{2} [(GeV/c)^{2}]");
h_neutrons_q2_fv->GetYaxis()->SetTitle("Number of neutrons");

h_neutrons_q2_fv_down->SetStats(0);
h_neutrons_q2_fv_down->GetXaxis()->SetTitle("Q^{2} [(GeV/c)^{2}]");
h_neutrons_q2_fv_down->GetYaxis()->SetTitle("Number of neutrons");

h_neutrons_costheta->SetStats(0);
h_neutrons_costheta->GetXaxis()->SetTitle("cos(#theta)");
h_neutrons_costheta->GetYaxis()->SetTitle("Number of neutrons");
Expand Down Expand Up @@ -610,6 +636,7 @@ bool NeutronMultiplicity::FillHistograms(){
h_neutrons_mrdstop->Fill(NumberNeutrons);
h_neutrons_energy->Fill(SimpleRecoEnergy,NumberNeutrons);
h_neutrons_energy_zoom->Fill(SimpleRecoEnergy,NumberNeutrons);
h_neutrons_q2->Fill(SimpleRecoQ2/1.e6,NumberNeutrons);
h_neutrons_costheta->Fill(SimpleRecoCosTheta,NumberNeutrons);
h_neutrons_pT->Fill(SimpleRecoPt,NumberNeutrons);
h_muon_energy->Fill(SimpleRecoEnergy);
Expand All @@ -634,6 +661,7 @@ bool NeutronMultiplicity::FillHistograms(){
h_muon_costheta_fv->Fill(SimpleRecoCosTheta);
h_neutrons_energy_fv->Fill(SimpleRecoEnergy,NumberNeutrons);
h_neutrons_energy_fv_zoom->Fill(SimpleRecoEnergy,NumberNeutrons);
h_neutrons_q2_fv->Fill(SimpleRecoQ2/1.e6,NumberNeutrons);
h_neutrons_costheta_fv->Fill(SimpleRecoCosTheta,NumberNeutrons);
h_neutrons_pT_fv->Fill(SimpleRecoPt,NumberNeutrons);
h_neutrons_mrdstop_fv->Fill(NumberNeutrons);
Expand All @@ -652,12 +680,22 @@ bool NeutronMultiplicity::FillHistograms(){
h_pmtvolneutrons_pT_fv->Fill(SimpleRecoPt,true_NCapturesPMTVol);
}
}
std::cout << " NM [debug] DownstreamFV/FullCylFV: " << DownstreamFV << "/" << FullCylFV << std::endl;
if (DownstreamFV == 1)
{
h_neutrons_energy_fv_down->Fill(SimpleRecoEnergy,NumberNeutrons);
h_neutrons_q2_fv_down->Fill(SimpleRecoQ2/1.e6,NumberNeutrons);
}
if (FullCylFV == 1) h_neutrons_energy_fv_cyl->Fill(SimpleRecoEnergy,NumberNeutrons);


h_muon_vtx_x->Fill(SimpleRecoVtx.X());
h_muon_vtx_y->Fill(SimpleRecoVtx.Y());
h_muon_vtx_z->Fill(SimpleRecoVtx.Z());
h_muon_vtx_yz->Fill(SimpleRecoVtx.Z()-1.681,SimpleRecoVtx.Y()-0.144);
h_muon_vtx_xz->Fill(SimpleRecoVtx.Z()-1.681,SimpleRecoVtx.X());
//h_muon_vtx_yz->Fill(SimpleRecoVtx.Z()-1.681,SimpleRecoVtx.Y()-0.144);
//h_muon_vtx_xz->Fill(SimpleRecoVtx.Z()-1.681,SimpleRecoVtx.X());
h_muon_vtx_yz->Fill(SimpleRecoVtx.Z(),SimpleRecoVtx.Y());
h_muon_vtx_xz->Fill(SimpleRecoVtx.Z(),SimpleRecoVtx.X());

reco_VtxX = SimpleRecoVtx.X();
reco_VtxY = SimpleRecoVtx.Y();
Expand Down Expand Up @@ -751,6 +789,10 @@ bool NeutronMultiplicity::SaveBoostStore(){
store_neutronmult->Set("NeutronEffMap",neutron_eff_map);
store_neutronmult->Set("PMTMRDCoinc",passPMTMRDCoincCut);
store_neutronmult->Set("NumMRDTracks",numtracksinev);
store_neutronmult->Set("DownstreamFV",DownstreamFV);
store_neutronmult->Set("FullCylFV",FullCylFV);
store_neutronmult->Set("SimpleRecoNeutrinoEnergy",SimpleRecoNeutrinoEnergy);
store_neutronmult->Set("SimpleRecoQ2",SimpleRecoQ2);

if (isMC){
store_neutronmult->Set("NeutrinoEnergy",true_Enu);
Expand Down Expand Up @@ -829,6 +871,10 @@ bool NeutronMultiplicity::ReadBoostStore(){
read_neutronmult->Get("NeutronEffMap",neutron_eff_map);
read_neutronmult->Get("PMTMRDCoinc",passPMTMRDCoincCut);
read_neutronmult->Get("NumMRDTracks",numtracksinev);
read_neutronmult->Get("DownstreamFV",DownstreamFV);
read_neutronmult->Get("FullCylFV",FullCylFV);
read_neutronmult->Get("SimpleRecoNeutrinoEnergy",SimpleRecoNeutrinoEnergy);
read_neutronmult->Get("SimpleRecoQ2",SimpleRecoQ2);

m_data->Stores["ANNIEEvent"]->Set("RunNumber",RunNumber);
m_data->Stores["ANNIEEvent"]->Set("EventNumber",EventNumber);
Expand All @@ -854,6 +900,10 @@ bool NeutronMultiplicity::ReadBoostStore(){
m_data->Stores["RecoEvent"]->Set("NeutronEffMap",neutron_eff_map);
m_data->Stores.at("RecoEvent")->Set("PMTMRDCoinc",passPMTMRDCoincCut);
m_data->Stores["MRDTracks"]->Set("NumMrdTracks",numtracksinev);
m_data->Stores["RecoEvent"]->Set("DownstreamFV",DownstreamFV);
m_data->Stores["RecoEvent"]->Set("FullCylFV",FullCylFV);
m_data->Stores["RecoEvent"]->Set("SimpleRecoNeutrinoEnergy",SimpleRecoNeutrinoEnergy);
m_data->Stores["RecoEvent"]->Set("SimpleRecoQ2",SimpleRecoQ2);

if (isMC){
read_neutronmult->Get("NeutrinoEnergy",true_Enu);
Expand Down Expand Up @@ -973,6 +1023,15 @@ bool NeutronMultiplicity::GetParticleInformation(){
bool get_simple_mrdstop = m_data->Stores["RecoEvent"]->Get("SimpleRecoMRDStop",SimpleRecoMRDStop);
if (!get_simple_mrdstop) Log("NeutronMultiplicity tool: No SimpleRecoMRDStop in RecoEvent!",v_error,verbosity);

bool get_simple_fvregion = m_data->Stores["RecoEvent"]->Get("DownstreamFV",DownstreamFV);
if (!get_simple_fvregion) Log("NeutronMultiplicity tool: No DownstreamFV in RecoEvent!",v_error,verbosity);
get_simple_fvregion = m_data->Stores["RecoEvent"]->Get("FullCylFV",FullCylFV);
if (!get_simple_fvregion) Log("NeutronMultiplicity tool: No FullCylFV in RecoEvent!",v_error,verbosity);
bool get_simple_nuenergy = m_data->Stores["RecoEvent"]->Get("SimpleRecoNeutrinoEnergy",SimpleRecoNeutrinoEnergy);
if (!get_simple_nuenergy) Log("NeutronMultiplicity tool: No SimpleRecoNeutrinoEnergy in RecoEvent!",v_error,verbosity);
bool get_simple_q2 = m_data->Stores["RecoEvent"]->Get("SimpleRecoQ2",SimpleRecoQ2);
if (!get_simple_q2) Log("NeutronMultiplicity tool: No SimpleRecoQ2 in RecoEvent!",v_error,verbosity);


bool get_pmtmrdcoinc = m_data->Stores.at("RecoEvent")->Get("PMTMRDCoinc",passPMTMRDCoincCut);
if (!get_pmtmrdcoinc) Log("NeutronMultiplicity tool: No PMTMRDCoinc in RecoEvent!",v_error,verbosity);
Expand Down Expand Up @@ -1006,7 +1065,7 @@ bool NeutronMultiplicity::GetMCTruthInformation(){
bool return_value = true;

//Get information from GENIE store
bool get_neutrino_energy = m_data->Stores["GenieInfo"]->Get("NeutrinoEnergy",true_Enu);
/* bool get_neutrino_energy = m_data->Stores["GenieInfo"]->Get("NeutrinoEnergy",true_Enu);
if (!get_neutrino_energy) Log("NeutronMultiplicity tool: No NeutrinoEnergy In GenieInfo!",v_error,verbosity);
true_Enu *= 1000; //convert to MeV for consistency
bool get_q2 = m_data->Stores["GenieInfo"]->Get("EventQ2",true_Q2);
Expand Down Expand Up @@ -1041,7 +1100,7 @@ bool NeutronMultiplicity::GetMCTruthInformation(){
bool get_p = m_data->Stores["GenieInfo"]->Get("NumFSProtons",true_PrimProt);
if (!get_p) Log("NeutronMultiplicity tool: No NumFSProtons In GenieInfo!",v_error,verbosity);
return_value = (get_neutrino_energy && get_q2 && get_cc && get_qel && get_res && get_dis && get_coh && get_mec && get_n && get_p);
return_value = (get_neutrino_energy && get_q2 && get_cc && get_qel && get_res && get_dis && get_coh && get_mec && get_n && get_p);*/
//Get information from RecoEvent store
RecoVertex* TrueVtx = nullptr;
auto get_muonMC = m_data->Stores.at("RecoEvent")->Get("TrueVertex",TrueVtx);
Expand Down Expand Up @@ -1141,6 +1200,11 @@ bool NeutronMultiplicity::GetMCTruthInformation(){

bool NeutronMultiplicity::ResetVariables(){

DownstreamFV = -9999;
FullCylFV = -9999;
SimpleRecoNeutrinoEnergy = -9999;
SimpleRecoQ2 = -9999;

SimpleRecoFlag = -9999;
SimpleRecoVtx = Position(-9999,-9999,-9999);
SimpleRecoStopVtx = Position(-9999,-9999,-9999);
Expand Down
9 changes: 9 additions & 0 deletions UserTools/NeutronMultiplicity/NeutronMultiplicity.h
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,10 @@ class NeutronMultiplicity: public Tool {
std::vector<std::string> input_filenames_;

//Reconstruction variables
int DownstreamFV;
int FullCylFV;
double SimpleRecoNeutrinoEnergy;
double SimpleRecoQ2;
int SimpleRecoFlag;
Position SimpleRecoVtx;
Position SimpleRecoStopVtx;
Expand Down Expand Up @@ -124,8 +128,13 @@ class NeutronMultiplicity: public Tool {
TH1F *h_neutrons_mrdstop_fv = nullptr;
TH2F *h_neutrons_energy = nullptr;
TH2F *h_neutrons_energy_fv = nullptr;
TH2F *h_neutrons_energy_fv_down = nullptr;
TH2F *h_neutrons_energy_fv_cyl = nullptr;
TH2F *h_neutrons_energy_zoom = nullptr;
TH2F *h_neutrons_energy_fv_zoom = nullptr;
TH2F *h_neutrons_q2 = nullptr;
TH2F *h_neutrons_q2_fv = nullptr;
TH2F *h_neutrons_q2_fv_down = nullptr;
TH2F *h_primneutrons_energy = nullptr;
TH2F *h_primneutrons_energy_fv = nullptr;
TH2F *h_primneutrons_energy_zoom = nullptr;
Expand Down
55 changes: 54 additions & 1 deletion UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,8 @@ bool PhaseIITreeMaker::Initialise(std::string configfile, DataModel &data){

m_variables.Get("Digit_fill",Digit_fill);

m_variables.Get("MuonFitter_fill", MuonFitter_fill);

std::string output_filename;
m_variables.Get("OutputFile", output_filename);
fOutput_tfile = new TFile(output_filename.c_str(), "recreate");
Expand Down Expand Up @@ -108,6 +110,15 @@ bool PhaseIITreeMaker::Initialise(std::string configfile, DataModel &data){
fPhaseIITankClusterTree->Branch("SiPM1NPulses",&fSiPM1NPulses,"SiPM1NPulses/I");
fPhaseIITankClusterTree->Branch("SiPM2NPulses",&fSiPM2NPulses,"SiPM2NPulses/I");
}
//MuonFitter reco track length, vtx, energy; juju
if (MuonFitter_fill)
{
fPhaseIITankClusterTree->Branch("recoMuonVtxX", &fRecoMuonVtxX, "recoMuonVtxX/D");
fPhaseIITankClusterTree->Branch("recoMuonVtxY", &fRecoMuonVtxY, "recoMuonVtxY/D");
fPhaseIITankClusterTree->Branch("recoMuonVtxZ", &fRecoMuonVtxZ, "recoMuonVtxZ/D");
fPhaseIITankClusterTree->Branch("recoTankTrack", &fRecoTankTrack, "recoTankTrack/D");
fPhaseIITankClusterTree->Branch("recoMuonKE", &fRecoMuonKE, "recoMuonKE/D");
}
// MC BNB spill structure timing - AssignBunchTimingMC tool
if(hasBNBtimingMC){
fPhaseIITankClusterTree->Branch("bunchTimes",&fbunchTimes,"bunchTimes/D");
Expand Down Expand Up @@ -433,6 +444,17 @@ bool PhaseIITreeMaker::Initialise(std::string configfile, DataModel &data){
fPhaseIITrigTree->Branch("weight_nucleonqexsec_FluxUnisim",&fnucleonqexsec);
fPhaseIITrigTree->Branch("weight_nucleontotxsec_FluxUnisim",&fnucleontotxsec);
}

//MuonFitter reco track length, vtx, energy; juju
if (MuonFitter_fill)
{
fPhaseIITrigTree->Branch("recoMuonVtxX", &fRecoMuonVtxX, "recoMuonVtxX/D");
fPhaseIITrigTree->Branch("recoMuonVtxY", &fRecoMuonVtxY, "recoMuonVtxY/D");
fPhaseIITrigTree->Branch("recoMuonVtxZ", &fRecoMuonVtxZ, "recoMuonVtxZ/D");
fPhaseIITrigTree->Branch("recoTankTrack", &fRecoTankTrack, "recoTankTrack/D");
fPhaseIITrigTree->Branch("recoMuonKE", &fRecoMuonKE, "recoMuonKE/D");
fPhaseIITrigTree->Branch("numMrdLayers", &fNumMrdLayers, "numMrdLayers/I");
}

// Reconstructed variables from each step in Muon Reco Analysis
// Currently output when RecoDebug_fill = 1 in config
Expand Down Expand Up @@ -656,6 +678,16 @@ bool PhaseIITreeMaker::Execute(){
}

if(SiPMPulseInfo_fill) this->LoadSiPMHits();
if (MuonFitter_fill)
{
Position tmp_vtx(-999,-999,-999);
m_data->CStore.Get("FittedMuonVertex", tmp_vtx);
fRecoMuonVtxX = tmp_vtx.X();
fRecoMuonVtxY = tmp_vtx.Y();
fRecoMuonVtxZ = tmp_vtx.Z();
m_data->CStore.Get("FittedTrackLengthInWater", fRecoTankTrack);
m_data->CStore.Get("RecoMuonKE", fRecoMuonKE);
}
fPhaseIITankClusterTree->Fill();
cluster_num += 1;
if (isData){
Expand Down Expand Up @@ -922,6 +954,18 @@ bool PhaseIITreeMaker::Execute(){
// FIll tree with all reconstruction information
if (RecoDebug_fill) this->FillRecoDebugInfo();

if (MuonFitter_fill)
{
Position tmp_vtx(-999,-999,-999);
m_data->CStore.Get("FittedMuonVertex", tmp_vtx);
fRecoMuonVtxX = tmp_vtx.X();
fRecoMuonVtxY = tmp_vtx.Y();
fRecoMuonVtxZ = tmp_vtx.Z();
m_data->CStore.Get("FittedTrackLengthInWater", fRecoTankTrack);
m_data->CStore.Get("RecoMuonKE", fRecoMuonKE);
m_data->CStore.Get("NLyers", fNumMrdLayers);
}

fPhaseIITrigTree->Fill();
}
return true;
Expand Down Expand Up @@ -1225,7 +1269,16 @@ void PhaseIITreeMaker::ResetVariables() {
fdigitT.clear();
}
//DIGITS


if (MuonFitter_fill)
{
fRecoMuonVtxX = -9999;
fRecoMuonVtxY = -9999;
fRecoMuonVtxZ = -9999;
fRecoTankTrack = -9999;
fRecoMuonKE = -9999;
fNumMrdLayers = -9999;
}
}

bool PhaseIITreeMaker::LoadTankClusterClassifiers(double cluster_time){
Expand Down
8 changes: 8 additions & 0 deletions UserTools/PhaseIITreeMaker/PhaseIITreeMaker.h
Original file line number Diff line number Diff line change
Expand Up @@ -437,6 +437,13 @@ class PhaseIITreeMaker: public Tool {
double fDeltaZenith;
double fDeltaAngle;

// MuonFitter vertex
double fRecoMuonVtxX;
double fRecoMuonVtxY;
double fRecoMuonVtxZ;
double fRecoTankTrack;
double fRecoMuonKE;
int fNumMrdLayers;

/// \brief Integer that determines the level of logging to perform
int verbosity = 0;
Expand Down Expand Up @@ -464,6 +471,7 @@ class PhaseIITreeMaker: public Tool {
bool muonTruthRecoDiff_fill = 0; //Output difference in tmuonruth and reconstructed values
bool SiPMPulseInfo_fill = 0;
bool Digit_fill = 0;
bool MuonFitter_fill = 0;
};


Expand Down
11 changes: 11 additions & 0 deletions UserTools/RingCounting/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,12 @@ reco_event_bs.Set("RingCountingSRPrediction", predicted_sr)
reco_event_bs.Set("RingCountingMRPrediction", predicted_mr)
```

and in case of using an ensemble with majority-voting the following variables are also set:
```
reco_event_bs.Set("RingCountingVotingSRPrediction", predicted_sr)
reco_event_bs.Set("RingCountingVotingMRPrediction", predicted_mr)
```

---
## Configuration

Expand All @@ -55,4 +61,9 @@ files_to_load configfiles/RingCounting/files_to_load.txt # txt file c
version 1_0_0 # Model version
model_path /exp/annie/app/users/dschmid/RingCountingStore/models/ # Model path
pmt_mask november_22 # Masked PMTs (name of hard-coded set of PMTs to ignore)
model_is_ensemble 1 # If set to 1, treat as ensemble
ensemble_model_count 13 # Number of models in ensemble
ensemble_prediction_combination_mode average # average/voting
```
Loading

0 comments on commit fc3c466

Please sign in to comment.