diff --git a/CMakeLists.txt b/CMakeLists.txt index 67b832fba..664e62aa5 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -19,7 +19,7 @@ cmake_minimum_required(VERSION 3.20 FATAL_ERROR) find_package(cetmodules 3.24.01 REQUIRED) project(icaruscode VERSION 10.20.07 LANGUAGES CXX) -#set(${PROJECT_NAME}_CMAKE_PROJECT_VERSION_STRING 10.15.00) +#set(${PROJECT_NAME}_CMAKE_PROJECT_VERSION_STRING 10.06.00.06-p05) #project(icaruscode LANGUAGES CXX) message(STATUS @@ -54,6 +54,7 @@ find_package(ifbeam REQUIRED ) find_package(ifdhc REQUIRED ) find_package(ifdh_art REQUIRED ) find_package(Range-v3 REQUIRED ) +find_package(sbnalg REQUIRED ) find_package(sbnobj REQUIRED ) find_package(icarus_signal_processing REQUIRED ) find_package(icarusalg REQUIRED ) diff --git a/fcl/gen/corsika/ci_prodcorsika_proton_intime_icarus_bnb.fcl b/fcl/archives/LegacyLArG4/ci_prodcorsika_proton_intime_icarus_bnb.fcl similarity index 100% rename from fcl/gen/corsika/ci_prodcorsika_proton_intime_icarus_bnb.fcl rename to fcl/archives/LegacyLArG4/ci_prodcorsika_proton_intime_icarus_bnb.fcl diff --git a/fcl/gen/genie/dirt_icarus_bnb.fcl b/fcl/archives/LegacyLArG4/dirt_icarus_bnb.fcl similarity index 100% rename from fcl/gen/genie/dirt_icarus_bnb.fcl rename to fcl/archives/LegacyLArG4/dirt_icarus_bnb.fcl diff --git a/fcl/gen/genie/2d_drift_sim/dirt_icarus_bnb_sce_2d_drift_sim_on.fcl b/fcl/archives/LegacyLArG4/dirt_icarus_bnb_sce_2d_drift_sim_on.fcl similarity index 100% rename from fcl/gen/genie/2d_drift_sim/dirt_icarus_bnb_sce_2d_drift_sim_on.fcl rename to fcl/archives/LegacyLArG4/dirt_icarus_bnb_sce_2d_drift_sim_on.fcl diff --git a/fcl/gen/genie/dirt_icarus_bnb_sce_on.fcl b/fcl/archives/LegacyLArG4/dirt_icarus_bnb_sce_on.fcl similarity index 100% rename from fcl/gen/genie/dirt_icarus_bnb_sce_on.fcl rename to fcl/archives/LegacyLArG4/dirt_icarus_bnb_sce_on.fcl diff --git a/fcl/gen/corsika/prodcorsika_proton_intime_icarus_bnb.fcl b/fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_bnb.fcl similarity index 100% rename from fcl/gen/corsika/prodcorsika_proton_intime_icarus_bnb.fcl rename to fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_bnb.fcl diff --git a/fcl/gen/corsika/2d_drift_sim/prodcorsika_proton_intime_icarus_bnb_sce_2d_drift_on.fcl b/fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_bnb_sce_2d_drift_on.fcl similarity index 100% rename from fcl/gen/corsika/2d_drift_sim/prodcorsika_proton_intime_icarus_bnb_sce_2d_drift_on.fcl rename to fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_bnb_sce_2d_drift_on.fcl diff --git a/fcl/gen/corsika/prodcorsika_proton_intime_icarus_bnb_sce_on.fcl b/fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_bnb_sce_on.fcl similarity index 100% rename from fcl/gen/corsika/prodcorsika_proton_intime_icarus_bnb_sce_on.fcl rename to fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_bnb_sce_on.fcl diff --git a/fcl/gen/corsika/prodcorsika_proton_intime_icarus_numi.fcl b/fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_numi.fcl similarity index 100% rename from fcl/gen/corsika/prodcorsika_proton_intime_icarus_numi.fcl rename to fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_numi.fcl diff --git a/fcl/gen/corsika/2d_drift_sim/prodcorsika_proton_intime_icarus_numi_sce_2d_drift_on.fcl b/fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_numi_sce_2d_drift_on.fcl similarity index 100% rename from fcl/gen/corsika/2d_drift_sim/prodcorsika_proton_intime_icarus_numi_sce_2d_drift_on.fcl rename to fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_numi_sce_2d_drift_on.fcl diff --git a/fcl/gen/corsika/prodcorsika_proton_intime_icarus_numi_sce_on.fcl b/fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_numi_sce_on.fcl similarity index 100% rename from fcl/gen/corsika/prodcorsika_proton_intime_icarus_numi_sce_on.fcl rename to fcl/archives/LegacyLArG4/prodcorsika_proton_intime_icarus_numi_sce_on.fcl diff --git a/icaruscode/PMT/prodsingle_full_optical_electronic.fcl b/fcl/archives/LegacyLArG4/prodsingle_full_optical_electronic.fcl similarity index 100% rename from icaruscode/PMT/prodsingle_full_optical_electronic.fcl rename to fcl/archives/LegacyLArG4/prodsingle_full_optical_electronic.fcl diff --git a/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_laronly.fcl b/fcl/archives/LegacyLArG4/standard_g4_icarus_21apr21_laronly.fcl similarity index 98% rename from icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_laronly.fcl rename to fcl/archives/LegacyLArG4/standard_g4_icarus_21apr21_laronly.fcl index 4ee184939..a63a98ac5 100644 --- a/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_laronly.fcl +++ b/fcl/archives/LegacyLArG4/standard_g4_icarus_21apr21_laronly.fcl @@ -1,5 +1,4 @@ #include "services_icarus_simulation.fcl" -#include "largeantmodules_icarus.fcl" #include "mcreco.fcl" process_name: G4 diff --git a/fcl/caf/cafmaker_add_detsim2d_icarus.fcl b/fcl/caf/cafmaker_add_detsim2d_icarus.fcl index 005c164a6..543a85f48 100644 --- a/fcl/caf/cafmaker_add_detsim2d_icarus.fcl +++ b/fcl/caf/cafmaker_add_detsim2d_icarus.fcl @@ -3,16 +3,3 @@ physics.producers.cafmaker.SimChannelLabel: "merge" # 2D, YZ sim # SimChannel's get re-made by 2D drift simulation -- use these to backtrack services.BackTrackerService.BackTracker.SimChannelModuleLabel: "merge" - -# MCReco also needs correct SimChannels -# need to use new config names to make MCParticle/SimChannel labels different -physics.producers.mcreco.G4ModName: @erase -physics.producers.mcreco.MCParticleLabel: "largeant" -physics.producers.mcreco.SimChannelLabel: "merge" - -# Mini production, pre signal shape tuning -# this_cal_constants: [1.343e-2, 1.338e-2, 0.01227] -# Post signal shape tuning, post gain fixing -# See docdb 32139 -this_cal_constants: [1.343e-2, 1.338e-2, 0.0128041] -#include "set_caf_calconst.fcl" diff --git a/fcl/caf/cafmaker_add_overlay_icarus.fcl b/fcl/caf/cafmaker_add_overlay_icarus.fcl new file mode 100644 index 000000000..f45301336 --- /dev/null +++ b/fcl/caf/cafmaker_add_overlay_icarus.fcl @@ -0,0 +1,7 @@ +physics.producers.cafmaker.CRTHitLabel: overlayCRTHit + +services.BackTrackerService.BackTracker.OverrideRealData: true +services.ParticleInventoryService.ParticleInventory.OverrideRealData: true + +physics.producers.cafmaker.OverrideRealData: true +physics.producers.cafmaker.CreateBlindedCAF: false diff --git a/fcl/caf/cafmaker_defs.fcl b/fcl/caf/cafmaker_defs.fcl index 50de910f3..1779def80 100644 --- a/fcl/caf/cafmaker_defs.fcl +++ b/fcl/caf/cafmaker_defs.fcl @@ -14,7 +14,7 @@ #include "eventweight_genie_sbn.fcl" #include "eventweight_genie_systtools.fcl" #include "eventweight_flux_sbn.fcl" -#include "mcreco.fcl" +#include "eventweight_geant4_sbn.fcl" #include "mcsproducer.fcl" #include "rangeproducer.fcl" #include "flashmatch_simple_icarus.fcl" @@ -87,8 +87,6 @@ recoana_datacalo_producers.vertexStubCryoW.NormTools: @local::icarus_calonormtoo # Producers for making analysis level products recoana_caf_preprocess_producers: { - mcreco: @local::standard_mcreco - pandoraTrackMCSCryoE: @local::mcs_sbn pandoraTrackMCSCryoW: @local::mcs_sbn @@ -105,6 +103,7 @@ recoana_caf_preprocess_producers: { genieweight: @local::sbn_eventweight_genie systtools: @local::sbn_systtools fluxweight: @local::sbn_eventweight_flux + geant4weight: @local::sbn_eventweight_geant4 } # Overwrite labels @@ -124,6 +123,7 @@ recoana_caf_preprocess_producers.pandoraPidGausCryoW.CalorimetryModuleLabel: "pa recoana_caf_preprocess_producers.genieweight.weight_functions: @local::recoana_caf_preprocess_producers.genieweight.weight_functions_genie recoana_caf_preprocess_producers.fluxweight.weight_functions: @local::recoana_caf_preprocess_producers.fluxweight.weight_functions_flux +recoana_caf_preprocess_producers.geant4weight.weight_functions: @local::recoana_caf_preprocess_producers.geant4weight.weight_functions_reint # Producers for making SCE products recoana_sce_producers: { @@ -228,7 +228,7 @@ caf_preprocess_sce_producers: { } # Sequences -caf_preprocess_sequence: [ mcreco, +caf_preprocess_sequence: [ # Calorimetry pandoraCaloGausCryoE, pandoraCaloGausCryoW, pandoraPidGausCryoE, pandoraPidGausCryoW, @@ -256,9 +256,9 @@ caf_preprocess_data_sequence: [ ShowerCosmicDistCryoE, ShowerCosmicDistCryoW ] -caf_preprocess_evtw_sequence: [@sequence::caf_preprocess_sequence, rns, genieweight, fluxweight] +caf_preprocess_evtw_sequence: [@sequence::caf_preprocess_sequence, rns, genieweight, fluxweight, geant4weight] -caf_preprocess_sce_sequence: [ mcreco, +caf_preprocess_sce_sequence: [ # Run the SCE correction pandoraGausSCECryoE, pandoraGausSCECryoW, # Then remake tracks @@ -278,7 +278,7 @@ caf_preprocess_sce_sequence: [ mcreco, # TODO: rns?? ] -caf_preprocess_sce_evtw_sequence: [@sequence::caf_preprocess_sce_sequence, rns, genieweight, fluxweight] +caf_preprocess_sce_evtw_sequence: [@sequence::caf_preprocess_sce_sequence, rns, genieweight, fluxweight, geant4weight] # CAFMaker config cafmaker: @local::standard_cafmaker @@ -313,6 +313,7 @@ cafmaker.OpFlashLabel: "opflash" # cafmaker.TriggerLabel: "daqTrigger" # see also https://github.com/SBNSoftware/icaruscode/issues/556 cafmaker.TriggerLabel: "emuTrigger" cafmaker.UnshiftedTriggerLabel: "emuTriggerUnshifted" +cafmaker.CRTSimChanLabel: "shifted" cafmaker.FlashTrigLabel: "" # unavailable cafmaker.SimChannelLabel: "largeant" cafmaker.SystWeightLabels: ["genieweight", "fluxweight"] diff --git a/fcl/caf/cafmakerjob_icarus_detsim2d_overlay.fcl b/fcl/caf/cafmakerjob_icarus_detsim2d_overlay.fcl index 171ce0b0b..f8d4e8652 100644 --- a/fcl/caf/cafmakerjob_icarus_detsim2d_overlay.fcl +++ b/fcl/caf/cafmakerjob_icarus_detsim2d_overlay.fcl @@ -1,7 +1,8 @@ #include "cafmakerjob_icarus.fcl" -#include "cafmaker_add_detsim2d_icarus.fcl" -services.BackTrackerService.BackTracker.OverrideRealData: true -services.ParticleInventoryService.ParticleInventory.OverrideRealData: true +# overwrite the producers to use data versions +physics.producers: @local::caf_preprocess_data_producers +physics.runprod: [ @sequence::caf_preprocess_data_sequence, cafmaker] -physics.producers.cafmaker.OverrideRealData: true +#include "cafmaker_add_detsim2d_icarus.fcl" +#include "cafmaker_add_overlay_icarus.fcl" diff --git a/fcl/caf/cafmakerjob_icarus_detsim2d_overlay_simpledet.fcl b/fcl/caf/cafmakerjob_icarus_detsim2d_overlay_simpledet.fcl new file mode 100644 index 000000000..fe75e0903 --- /dev/null +++ b/fcl/caf/cafmakerjob_icarus_detsim2d_overlay_simpledet.fcl @@ -0,0 +1,4 @@ +#include "cafmakerjob_icarus_detsim2d_overlay.fcl" + +physics.producers.cafmaker.SimChannelLabel: "daq:simpleSC" +services.BackTrackerService.BackTracker.SimChannelModuleLabel: "daq:simpleSC" diff --git a/fcl/caf/cafmakerjob_icarus_detsim2d_simpledet.fcl b/fcl/caf/cafmakerjob_icarus_detsim2d_simpledet.fcl new file mode 100644 index 000000000..1c8b09582 --- /dev/null +++ b/fcl/caf/cafmakerjob_icarus_detsim2d_simpledet.fcl @@ -0,0 +1,4 @@ +#include "cafmakerjob_icarus_detsim2d.fcl" + +physics.producers.cafmaker.SimChannelLabel: "daq:simpleSC" +services.BackTrackerService.BackTracker.SimChannelModuleLabel: "daq:simpleSC" diff --git a/fcl/caf/cafmakerjob_icarus_detsim2d_systtools_and_fluxwgt_overlay.fcl b/fcl/caf/cafmakerjob_icarus_detsim2d_systtools_and_fluxwgt_overlay.fcl index ded9909e6..a80878e66 100644 --- a/fcl/caf/cafmakerjob_icarus_detsim2d_systtools_and_fluxwgt_overlay.fcl +++ b/fcl/caf/cafmakerjob_icarus_detsim2d_systtools_and_fluxwgt_overlay.fcl @@ -1,5 +1,10 @@ #include "cafmakerjob_icarus_detsim2d_systtools_and_fluxwgt.fcl" -services.BackTrackerService.BackTracker.OverrideRealData: true -services.ParticleInventoryService.ParticleInventory.OverrideRealData: true -physics.producers.cafmaker.OverrideRealData: true +# overwrite the producers to use data versions +physics.producers: @local::caf_preprocess_data_producers +physics.runprod: [ @sequence::caf_preprocess_data_sequence, rns, systtools, geant4weight, fluxweight, cafmaker] + +physics.producers.cafmaker.SystWeightLabels: ["systtools", "geant4weight", "fluxweight"] + +#include "cafmaker_add_detsim2d_icarus.fcl" +#include "cafmaker_add_overlay_icarus.fcl" diff --git a/fcl/caf/cafmakerjob_icarus_sce_systtools.fcl b/fcl/caf/cafmakerjob_icarus_sce_systtools.fcl index 6b5e0cbc0..031ea2cfb 100644 --- a/fcl/caf/cafmakerjob_icarus_sce_systtools.fcl +++ b/fcl/caf/cafmakerjob_icarus_sce_systtools.fcl @@ -1,6 +1,6 @@ #include "cafmakerjob_icarus_sce.fcl" -physics.runprod: [ @sequence::caf_preprocess_sce_sequence, rns, systtools, cafmaker ] +physics.runprod: [ @sequence::caf_preprocess_sce_sequence, rns, systtools, geant4weight, cafmaker ] -physics.producers.cafmaker.SystWeightLabels: ["systtools"] +physics.producers.cafmaker.SystWeightLabels: ["systtools", "geant4weight"] diff --git a/fcl/caf/cafmakerjob_icarus_sce_systtools_and_fluxwgt.fcl b/fcl/caf/cafmakerjob_icarus_sce_systtools_and_fluxwgt.fcl index e4732e3ec..9a33ddb9c 100644 --- a/fcl/caf/cafmakerjob_icarus_sce_systtools_and_fluxwgt.fcl +++ b/fcl/caf/cafmakerjob_icarus_sce_systtools_and_fluxwgt.fcl @@ -1,6 +1,6 @@ #include "cafmakerjob_icarus_sce.fcl" -physics.runprod: [ @sequence::caf_preprocess_sce_sequence, rns, systtools, fluxweight, cafmaker ] +physics.runprod: [ @sequence::caf_preprocess_sce_sequence, rns, systtools, geant4weight, fluxweight, cafmaker ] -physics.producers.cafmaker.SystWeightLabels: ["systtools", "fluxweight"] +physics.producers.cafmaker.SystWeightLabels: ["systtools", "geant4weight", "fluxweight"] diff --git a/fcl/caf/cafmakerjob_icarus_systtools.fcl b/fcl/caf/cafmakerjob_icarus_systtools.fcl index 94ebf3e09..d5c0670ce 100644 --- a/fcl/caf/cafmakerjob_icarus_systtools.fcl +++ b/fcl/caf/cafmakerjob_icarus_systtools.fcl @@ -1,6 +1,6 @@ #include "cafmakerjob_icarus.fcl" -physics.runprod: [ @sequence::caf_preprocess_sequence, rns, systtools, cafmaker ] +physics.runprod: [ @sequence::caf_preprocess_sequence, rns, systtools, geant4weight, cafmaker ] -physics.producers.cafmaker.SystWeightLabels: ["systtools"] +physics.producers.cafmaker.SystWeightLabels: ["systtools", "geant4weight"] diff --git a/fcl/caf/cafmakerjob_icarus_systtools_and_fluxwgt.fcl b/fcl/caf/cafmakerjob_icarus_systtools_and_fluxwgt.fcl index 7ba1d48a3..b456f0c17 100644 --- a/fcl/caf/cafmakerjob_icarus_systtools_and_fluxwgt.fcl +++ b/fcl/caf/cafmakerjob_icarus_systtools_and_fluxwgt.fcl @@ -1,6 +1,6 @@ #include "cafmakerjob_icarus.fcl" -physics.runprod: [ @sequence::caf_preprocess_sequence, rns, systtools, fluxweight, cafmaker ] +physics.runprod: [ @sequence::caf_preprocess_sequence, rns, systtools, geant4weight, fluxweight, cafmaker ] -physics.producers.cafmaker.SystWeightLabels: ["systtools", "fluxweight"] +physics.producers.cafmaker.SystWeightLabels: ["systtools", "geant4weight", "fluxweight"] diff --git a/fcl/configurations/calibration_database_GlobalTags_icarus.fcl b/fcl/configurations/calibration_database_GlobalTags_icarus.fcl index 5d080878d..e09eec522 100644 --- a/fcl/configurations/calibration_database_GlobalTags_icarus.fcl +++ b/fcl/configurations/calibration_database_GlobalTags_icarus.fcl @@ -5,8 +5,8 @@ BEGIN_PROLOG ICARUS_Calibration_GlobalTags: { - @table::TPC_CalibrationTags_Jan2025 - @table::PMT_CalibrationTags_Run3_Feb2025 + @table::TPC_CalibrationTags_Oct2025 + @table::PMT_CalibrationTags_Oct2025 @table::CRT_CalibrationTags_Oct2023 } diff --git a/fcl/configurations/calibration_database_PMT_TagSets_icarus.fcl b/fcl/configurations/calibration_database_PMT_TagSets_icarus.fcl index aaa87828a..1719359ac 100644 --- a/fcl/configurations/calibration_database_PMT_TagSets_icarus.fcl +++ b/fcl/configurations/calibration_database_PMT_TagSets_icarus.fcl @@ -79,4 +79,26 @@ PMT_CalibrationTags_Run3_Feb2025: { # Run 3: run>=11590 } +# These are the standard tags for analyses on Run 1, Run 2, Run 3 and Run 4 data (as of Oct 2025) +# These tagged versions of the databases contain tables relevant for Run 1, Run 2, Run 3 and Run 4. +# Notes: +# - New cosmics corrections for Run 4 (run>=12837) +PMT_CalibrationTags_Oct2025: { + pmt_cables_delays_data: "v2r5" # tables for run>=0 (null) + # Run 1: run>=8046 + # Run 2: run>=9301, run>=9628, run>=9773 + # Run 3: run>=10369, run>=10441, run>=10865 + # Run 4: run>=12040, run>=12455, run>=12777 + pmt_laser_timing_data: "v2r3" # tables for run>=0 (null) + # Run 1: run>=8046 + # Run 2: run>=9301, run>=9628, run>=9773 + # Run 3: run>=10908, run>=11590 + # Run 4: run>=12058, run>=12837 + pmt_cosmics_timing_data: "v2r3" # tables for run>=0 (null) + # Run 1: run>=8046 + # Run 2: run>=9301, run>=9628, run>=9773 + # Run 3: run>=11590 + # Run 4: run>=12837 +} + END_PROLOG diff --git a/fcl/configurations/calibration_database_TPC_TagSets_icarus.fcl b/fcl/configurations/calibration_database_TPC_TagSets_icarus.fcl index 828e8d8a3..544c8216c 100644 --- a/fcl/configurations/calibration_database_TPC_TagSets_icarus.fcl +++ b/fcl/configurations/calibration_database_TPC_TagSets_icarus.fcl @@ -37,4 +37,26 @@ TPC_CalibrationTags_Jan2025: { } +## TPC_CalibrationTags_Jul2025 +# Update to 2D deconv tags. Change TPC equalization to be per-plane +TPC_CalibrationTags_Jul2025: { + + tpc_channelstatus_data: "v3r4" + tpc_elifetime_data: "v3r0" + tpc_dqdxcalibration_allplanes_data: "v1r0" + tpc_yz_correction_allplanes_data: "v2r0" + +} + +## TPC_CalibrationTags_Oct2025 +# Include Run 4 in calibrations +TPC_CalibrationTags_Oct2025: { + + tpc_channelstatus_data: "v4r0" + tpc_elifetime_data: "v3r1" + tpc_dqdxcalibration_allplanes_data: "v1r1" + tpc_yz_correction_allplanes_data: "v2r1" + +} + END_PROLOG diff --git a/fcl/configurations/larg4_icarus_defs.fcl b/fcl/configurations/larg4_icarus_defs.fcl new file mode 100644 index 000000000..37513a638 --- /dev/null +++ b/fcl/configurations/larg4_icarus_defs.fcl @@ -0,0 +1,146 @@ +# File: icarus_larg4_defs.fcl +# Purpose: definitions for standard LArG4 jobs +# +# This collection of presets can be used as building blocks for a full LArG4 +# job configuration. Essential parts are: +# +# services: { +# @table::icarus_larg4_services +# +# # ... additional services as needed +# } +# +# physics.producers: { +# @table::icarus_larg4_standard_producers +# +# # ... additional services as needed +# } +# +# physics.simulate: [ +# @sequence::icarus_larg4_standard_path +# # , additional labels as needed +# ] +# +# Note that `icarus_larg4_services` only provides service specific to LArG4; +# for a full, and possibly overfull, set of services, use `icarus_all_larg4_services`. +# +# A complete example can be found in `larg4_icarus.fcl`. +# + +#include "services_icarus_simulation.fcl" +#include "larg4_services_icarus.fcl" + +#include "LArG4.fcl" +#include "ionandscint_icarus.fcl" +#include "PDFastSim_icarus.fcl" +#include "simdrift_icarus.fcl" +#include "g4inforeducer.fcl" +#include "icarus_genericCRT.fcl" +#include "simplemerge_icarus.fcl" + +BEGIN_PROLOG + + +# ------------------------------------------------------------------------------ +# --- ICARUS "standard" configuration +# --- +# +# (note overrides at the bottom) +# +# The service sets include: +# - `icarus_larg4_services`: only the services needed only by LArG4 +# - `icarus_all_larg4_services`: all services needed for a job including LArG4 +# +# Note that currently `icarus_g4_services` is directly taken from `larg4_services_icarus.fcl`. +# + +# --- +# --- services +# --- +icarus_g4_services: { + + @table::icarus_g4_services # from `larg4_services_icarus.fcl` (FHiCL will not recourse) + + # icarus_g4_services.ParticleListAction.KeepDroppedParticlesInVolumes: ["volDetEnclosure"] +} + +icarus_all_larg4_services: { + @table::icarus_g4_services + @table::icarus_larg4_services +} + +# avoid huge log files +icarus_all_larg4_services.message.destinations.LogErrorFile.categories.SimDriftElectrons: { limit: 0 } +icarus_all_larg4_services.message.destinations.LogStandardOut.categories.SimDriftElectrons: { limit: 0 } + +# Setup hack for 2D +icarus_all_larg4_services.SpaceChargeService.is2DdriftSimHack: true + + +# --- +# --- modules +# --- +icarus_larg4_standard_producers: { + + # A dummy module that forces the G4 physics list to be loaded + loader: { module_type: "PhysListLoader" } + + # The geant4 step + largeant: { + + @table::standard_larg4 # from `LArG4.fcl` (in LArSoft/larg4) + + # Store MCParticleLite in G4 to store dropped particles from KeepEMShowerDaughters: false + StoreDroppedMCParticles: false + + } + + # Creation of ionization electrons and scintillation photons (keep ionization name for compatibility) + ionization: @local::icarus_ionandscint + + # Light propogation + pdfastsim: @local::icarus_pdfastsim_pvs + + # Electron propogation + simdrift: @local::icarus_simdrift + + # needs to run right after largeant + sedlite: { + @table::sbn_largeant_info_reducer # from `g4inforeducer.fcl` (in LArSoft/larg4!!) + + SimEnergyDepositLabel: "largeant:LArG4DetectorServicevolTPCActive" + useOrigTrackID: true # needed since origTrackID not filled for sedlite in SBND + + } + + # Generic CRT + genericcrt: @local::icarus_genericCRT + + # simplemerge for ML + simplemerge: @local::simplemerge + +} + +# Store MCParticleLite in G4 to store dropped particles from KeepEMShowerDaughters: false +icarus_larg4_standard_producers.largeant.StoreDroppedMCParticles: false + + +# --- +# --- paths +# --- +icarus_larg4_standard_path: [ + loader + , largeant + , ionization + , pdfastsim + , simdrift + , sedlite + , genericcrt + , simplemerge +] + + +# ------------------------------------------------------------------------------ + +END_PROLOG + diff --git a/fcl/detsim/detsim_2d_icarus_refactored.fcl b/fcl/detsim/detsim_2d_icarus_refactored.fcl index 993ce8586..799170d15 100644 --- a/fcl/detsim/detsim_2d_icarus_refactored.fcl +++ b/fcl/detsim/detsim_2d_icarus_refactored.fcl @@ -19,7 +19,7 @@ physics: { crtdaq: @local::icarus_crtsim opdaq: @local::icarus_simpmt - daq: @local::icarus_simwire_wirecell_filtersed + daq: @local::icarus_simwire_wirecell_shifted rns: { module_type: "RandomNumberSaver" } } # producers diff --git a/fcl/detsim/detsim_2d_icarus_refactored_overlay.fcl b/fcl/detsim/detsim_2d_icarus_refactored_overlay.fcl new file mode 100644 index 000000000..bf9754683 --- /dev/null +++ b/fcl/detsim/detsim_2d_icarus_refactored_overlay.fcl @@ -0,0 +1,3 @@ +#include "detsim_2d_icarus_refactored.fcl" + +physics.producers.daq: @local::icarus_simwire_wirecell_shifted_overlay diff --git a/fcl/detsim/detsim_2d_icarus_refactored_yzsim_Run4.fcl b/fcl/detsim/detsim_2d_icarus_refactored_yzsim_Run4.fcl new file mode 100644 index 000000000..f2a5339a3 --- /dev/null +++ b/fcl/detsim/detsim_2d_icarus_refactored_yzsim_Run4.fcl @@ -0,0 +1,3 @@ +#include "detsim_2d_icarus_refactored_yzsim.fcl" + +physics.producers.daq.wcls_main.params.YZScaleMapJson: "yzmap_gain_icarus_v4_run4.json" diff --git a/fcl/detsim/detsim_2d_icarus_refactored_yzsim_overlay_Run4.fcl b/fcl/detsim/detsim_2d_icarus_refactored_yzsim_overlay_Run4.fcl new file mode 100644 index 000000000..92158743e --- /dev/null +++ b/fcl/detsim/detsim_2d_icarus_refactored_yzsim_overlay_Run4.fcl @@ -0,0 +1,3 @@ +#include "detsim_2d_icarus_refactored_yzsim_overlay.fcl" + +physics.producers.daq.wcls_main.params.YZScaleMapJson: "yzmap_gain_icarus_v4_run4.json" diff --git a/fcl/g4/larg4_icarus.fcl b/fcl/g4/larg4_icarus.fcl index 00d058e99..6f3fb953a 100644 --- a/fcl/g4/larg4_icarus.fcl +++ b/fcl/g4/larg4_icarus.fcl @@ -1,21 +1,10 @@ -#include "LArG4.fcl" +#include "larg4_icarus_defs.fcl" #include "services_icarus_simulation.fcl" -#include "larg4_services_icarus.fcl" #include "rootoutput_icarus.fcl" -#include "ionandscint_icarus.fcl" -#include "simdrift_icarus.fcl" -#include "PDFastSim_icarus.fcl" -#include "icarus_genericCRT.fcl" -#include "g4inforeducer.fcl" -#include "simplemerge_icarus.fcl" - process_name: G4 -services: { - @table::icarus_g4_services - @table::icarus_larg4_services -} +services: @local::icarus_all_larg4_services source: { @@ -30,69 +19,28 @@ physics: { rns: { module_type: "RandomNumberSaver" } - # A dummy module that forces the G4 physics list to be loaded - loader: { module_type: "PhysListLoader" } - - # The geant4 step - largeant: @local::standard_larg4 - - # Creation of ionization electrons and scintillation photons (keep ionization name for compatibility) - ionization: @local::icarus_ionandscint - - # Light propogation - pdfastsim: @local::icarus_pdfastsim_pvs - - # Electron propogation - simdrift: @local::icarus_simdrift - - # needs to run right after largeant - sedlite: @local::sbn_largeant_info_reducer - - - # Generic CRT - genericcrt: @local::icarus_genericCRT - - # simplemerge for ML - simplemerge: @local::simplemerge + @table::icarus_larg4_standard_producers # from larg4_icarus_defs.fcl } # All producers and filters modules for this path, order matters simulate: [ rns - , loader - , largeant - , ionization - , pdfastsim - , simdrift - , sedlite - , genericcrt - , simplemerge + , @sequence::icarus_larg4_standard_path # from larg4_icarus_defs.fcl ] # The output stream, there could be more than one if using filters stream1: [ rootoutput ] - # Contains the paths that modify the art::event + # Contains the paths that modify the art::Event trigger_paths: [ simulate ] # Contains the paths that do not modify the art::Event end_paths: [ stream1 ] } -# Store MCParticleLite in G4 to store dropped particles from KeepEMShowerDaughters: false -physics.producers.largeant.StoreDroppedMCParticles: false -#services.ParticleListAction.KeepDroppedParticlesInVolumes: ["volDetEnclosure"] # ------------------------------------------------------------------------------ -# Setup hack for 2D -services.SpaceChargeService.is2DdriftSimHack: true -#info reducer -physics.producers.sedlite.SimEnergyDepositLabel: "largeant:LArG4DetectorServicevolTPCActive" -physics.producers.sedlite.useOrigTrackID: true #needed since origTrackID not filled for sedlite in SBND -# avoid huge log files -services.message.destinations.LogErrorFile.categories.SimDriftElectrons: { limit: 0 } -services.message.destinations.LogStandardOut.categories.SimDriftElectrons: { limit: 0 } +outputs.rootoutput: @local::icarus_rootoutput # from rootoutput_icarus.fcl -outputs.rootoutput: @local::icarus_rootoutput diff --git a/fcl/g4/larg4_icarus_cosmics_sce_filterdirt.fcl b/fcl/g4/larg4_icarus_cosmics_sce_filterdirt.fcl new file mode 100644 index 000000000..f4c0d3a52 --- /dev/null +++ b/fcl/g4/larg4_icarus_cosmics_sce_filterdirt.fcl @@ -0,0 +1,11 @@ +#include "simenergydep_faketrigger_icarus.fcl" +#include "icarus_siminfomixer.fcl" +#include "larg4_icarus_cosmics.fcl" + +physics.filters.dirtfilter: @local::icarus_simenergydepfaketriggerfilter +physics.producers.potinevent: @local::icarus_subrunpotinevent # so the sim info mixer can grab it + +outputs.rootoutput.SelectEvents: [simulate] +physics.simulate: [@sequence::physics.simulate, potinevent, dirtfilter] + +#include "enable_spacecharge_icarus.fcl" diff --git a/fcl/g4/larg4_icarus_cosmics_sce_filterwiremod.fcl b/fcl/g4/larg4_icarus_cosmics_sce_filterwiremod.fcl new file mode 100644 index 000000000..9233641b1 --- /dev/null +++ b/fcl/g4/larg4_icarus_cosmics_sce_filterwiremod.fcl @@ -0,0 +1,8 @@ +#include "filter_wiremod_sbn.fcl" +#include "larg4_icarus_cosmics_sce.fcl" + + +# Insert the sim channel filter and only save events that pass it +physics.filters.requiresimchan: @local::filter_primary_simchan +physics.simulate: [@sequence::physics.simulate, "requiresimchan"] +outputs.rootoutput.SelectEvents: ["simulate"] diff --git a/fcl/gen/corsika/prodwiremod_icarus.fcl b/fcl/gen/corsika/prodwiremod_icarus.fcl new file mode 100644 index 000000000..2ceb4ba7c --- /dev/null +++ b/fcl/gen/corsika/prodwiremod_icarus.fcl @@ -0,0 +1,76 @@ +#include "corsika_icarus.fcl" +#include "beamgates_icarus.fcl" +#include "services_common_icarus.fcl" +#include "services_icarus_simulation.fcl" +#include "wiremodmuon_sbn.fcl" + +process_name: WireModMuon + +services: +{ + #FileCatalogMetadata: @local::art_file_catalog_mc + @table::icarus_gen_services +} + +#Start each new event with an empty event. +source: +{ + module_type: EmptyEvent + timestampPlugin: { plugin_type: "GeneratedEventTimestamp" } + maxEvents: 10 # Number of events to create + firstRun: 1 # Run number to use for this file + firstEvent: 1 # number of first event in the file +} + +# Define and configure some modules to do work on each event. +# First modules are defined; they are scheduled later. +# Modules are grouped by type. +physics: +{ + + producers: + { + generator: { + @table::icarus_corsika_cmc + @table::wiremodmuon_icarus + } + beamgate: @local::icarus_standardbeamgate_BNB # from beamgates_icarus.fcl + rns: { module_type: "RandomNumberSaver" } + } + + #define the producer and filter modules for this path, order matters, + #filters reject all following items. see lines starting physics.producers below + simulate: [ rns, generator, beamgate ] + + #define the output stream, there could be more than one if using filters + stream1: [ out1 ] + + #trigger_paths is a keyword and contains the paths that modify the art::event, + #ie filters and producers + trigger_paths: [simulate] + + #end_paths is a keyword and contains the paths that do not modify the art::Event, + #ie analyzers and output streams. these all run simultaneously + end_paths: [stream1] +} + +#block to define where the output goes. if you defined a filter in the physics +#block and put it in the trigger_paths then you need to put a SelectEvents: {SelectEvents: [XXX]} +#entry in the output stream you want those to go to, where XXX is the label of the filter module(s) +outputs: +{ + out1: + { + module_type: RootOutput + fileName: "prodwiremod_standard_icarus_%tc-%p.root" + dataTier: "simulated" + compressionLevel: 1 + fastCloning: false + saveMemoryObjectThreshold: 0 + } +} + +# Allow info messages from generator +# services.message.destinations.LogStandardOut.categories.WireModMuon.limit: 0 + +services.TFileService.fileName: "Supplemental-prodwiremod_standard_icarus_%tc-%p.root" diff --git a/fcl/gen/corsika/prodwiremod_icarus_overlays.fcl b/fcl/gen/corsika/prodwiremod_icarus_overlays.fcl new file mode 100644 index 000000000..d15630731 --- /dev/null +++ b/fcl/gen/corsika/prodwiremod_icarus_overlays.fcl @@ -0,0 +1,3 @@ +#include "prodwiremod_icarus.fcl" + +#include "enable_overlay_gen.fcl" diff --git a/fcl/gen/cosmics/simulation_cosmics_icarus_common.fcl b/fcl/gen/cosmics/simulation_cosmics_icarus_common.fcl index 65769e848..7a3787b6a 100644 --- a/fcl/gen/cosmics/simulation_cosmics_icarus_common.fcl +++ b/fcl/gen/cosmics/simulation_cosmics_icarus_common.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "cry.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/prodcorsika_genie_icarus_Jun2021.fcl b/fcl/gen/genie/prodcorsika_genie_icarus_Jun2021.fcl index b8094aec8..5cb6ceca2 100644 --- a/fcl/gen/genie/prodcorsika_genie_icarus_Jun2021.fcl +++ b/fcl/gen/genie/prodcorsika_genie_icarus_Jun2021.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "corsika_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/prodcorsika_genie_standard_icarus.fcl b/fcl/gen/genie/prodcorsika_genie_standard_icarus.fcl index e7287ed58..6fd37598c 100644 --- a/fcl/gen/genie/prodcorsika_genie_standard_icarus.fcl +++ b/fcl/gen/genie/prodcorsika_genie_standard_icarus.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "corsika_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/prodcorsika_genie_standard_icarus_Aug2018_nue.fcl b/fcl/gen/genie/prodcorsika_genie_standard_icarus_Aug2018_nue.fcl index f34187000..244b85a08 100644 --- a/fcl/gen/genie/prodcorsika_genie_standard_icarus_Aug2018_nue.fcl +++ b/fcl/gen/genie/prodcorsika_genie_standard_icarus_Aug2018_nue.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "corsika_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/prodcorsika_genie_standard_icarus_Aug2018_numu.fcl b/fcl/gen/genie/prodcorsika_genie_standard_icarus_Aug2018_numu.fcl index 3350f668f..e68f8bb01 100644 --- a/fcl/gen/genie/prodcorsika_genie_standard_icarus_Aug2018_numu.fcl +++ b/fcl/gen/genie/prodcorsika_genie_standard_icarus_Aug2018_numu.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "corsika_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/prodcorsika_genie_standard_icarus_workshop.fcl b/fcl/gen/genie/prodcorsika_genie_standard_icarus_workshop.fcl index ea5195270..4b6d5d4ce 100644 --- a/fcl/gen/genie/prodcorsika_genie_standard_icarus_workshop.fcl +++ b/fcl/gen/genie/prodcorsika_genie_standard_icarus_workshop.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "corsika_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/prodcorsika_overlay_protononly_icarus.fcl b/fcl/gen/genie/prodcorsika_overlay_protononly_icarus.fcl index 2439b418c..077b340ad 100644 --- a/fcl/gen/genie/prodcorsika_overlay_protononly_icarus.fcl +++ b/fcl/gen/genie/prodcorsika_overlay_protononly_icarus.fcl @@ -9,7 +9,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "corsika_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_Aug2018_nue.fcl b/fcl/gen/genie/simulation_genie_icarus_Aug2018_nue.fcl index dd8578d15..37fb1b987 100644 --- a/fcl/gen/genie/simulation_genie_icarus_Aug2018_nue.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_Aug2018_nue.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_Aug2018_numu.fcl b/fcl/gen/genie/simulation_genie_icarus_Aug2018_numu.fcl index 8cccbd870..3e6876e76 100644 --- a/fcl/gen/genie/simulation_genie_icarus_Aug2018_numu.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_Aug2018_numu.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_Mar2019.fcl b/fcl/gen/genie/simulation_genie_icarus_Mar2019.fcl index ec826b175..3bd4de04b 100644 --- a/fcl/gen/genie/simulation_genie_icarus_Mar2019.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_Mar2019.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_Mar2019_nue.fcl b/fcl/gen/genie/simulation_genie_icarus_Mar2019_nue.fcl index 592f76d6a..a2aeecaa2 100644 --- a/fcl/gen/genie/simulation_genie_icarus_Mar2019_nue.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_Mar2019_nue.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_Mar2019_nue_oscillated.fcl b/fcl/gen/genie/simulation_genie_icarus_Mar2019_nue_oscillated.fcl index 84cc4d358..1a564cc9f 100644 --- a/fcl/gen/genie/simulation_genie_icarus_Mar2019_nue_oscillated.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_Mar2019_nue_oscillated.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_bnb_volDetEnclosure_fiducial.fcl b/fcl/gen/genie/simulation_genie_icarus_bnb_volDetEnclosure_fiducial.fcl new file mode 100644 index 000000000..09612bf48 --- /dev/null +++ b/fcl/gen/genie/simulation_genie_icarus_bnb_volDetEnclosure_fiducial.fcl @@ -0,0 +1,3 @@ +#include "simulation_genie_icarus_bnb_volDetEnclosure.fcl" + +physics.producers.generator.FiducialCut: "mbox: -378.49,-191.86,-904.950652270838,378.49,144.96,904.950652270838" diff --git a/fcl/gen/genie/simulation_genie_icarus_bnb_volWorld_DetEnclosurerockbox.fcl b/fcl/gen/genie/simulation_genie_icarus_bnb_volWorld_DetEnclosurerockbox.fcl new file mode 100644 index 000000000..aa800408b --- /dev/null +++ b/fcl/gen/genie/simulation_genie_icarus_bnb_volWorld_DetEnclosurerockbox.fcl @@ -0,0 +1,21 @@ +#include "filterMCTruthVolume.fcl" +#include "simulation_genie_icarus_bnb_volDetEnclosure.fcl" + +# change "generator" to "mcgen"-- we'll have a filter module to replicate generator +physics.producers.mcgen: @local::physics.producers.generator +physics.producers.mcgen.TopVolume: "volWorld" +physics.producers.mcgen.FiducialCut: "rockbox:(-378.49,-191.86,-904.950652270838)(+378.49,+144.96,+904.950652270838),1,800,0.00425,1.3,1" +physics.producers.mcgen.FluxFiles: ["gsimple_bnb_neutrino_icarus_dirt_*.root"] +physics.producers.mcgen.FluxSearchPaths: "/cvmfs/sbn.osgstorage.org/pnfs/fnal.gov/usr/sbn/persistent/stash/physics-gputnam/icarus-bnb-dirt/" +physics.producers.generator: @erase + +# Reject neutrino interactions inside volDetEnclosure +physics.filters.generator: @local::filtermctruthvolume + +physics.simulate: [rns, mcgen, generator, beamgate] + +outputs.rootoutput.outputCommands: [ + "keep *_*_*_*", + "drop *_mcgen_*_*" +] +outputs.rootoutput.SelectEvents: ["simulate"] diff --git a/fcl/gen/genie/simulation_genie_icarus_bnb_volWorld_rockbox.fcl b/fcl/gen/genie/simulation_genie_icarus_bnb_volWorld_rockbox.fcl new file mode 100644 index 000000000..f8a411f55 --- /dev/null +++ b/fcl/gen/genie/simulation_genie_icarus_bnb_volWorld_rockbox.fcl @@ -0,0 +1,6 @@ +#include "simulation_genie_icarus_bnb_volDetEnclosure.fcl" + +physics.producers.generator.TopVolume: "volWorld" +physics.producers.generator.FiducialCut: "rockbox:(-378.49,-191.86,-904.950652270838)(+378.49,+144.96,+904.950652270838),1,800,0.00425,1.3,1" +physics.producers.generator.FluxFiles: ["gsimple_bnb_neutrino_icarus_dirt_*.root"] +physics.producers.generator.FluxSearchPaths: "/cvmfs/sbn.osgstorage.org/pnfs/fnal.gov/usr/sbn/persistent/stash/physics-gputnam/icarus-bnb-dirt/" diff --git a/fcl/gen/genie/simulation_genie_icarus_simple.fcl b/fcl/gen/genie/simulation_genie_icarus_simple.fcl index aae9f315a..58e5ed401 100644 --- a/fcl/gen/genie/simulation_genie_icarus_simple.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_simple.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus_bnb.fcl" #include "beamgates_icarus.fcl" #include "mcreco.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_simple_workshop.fcl b/fcl/gen/genie/simulation_genie_icarus_simple_workshop.fcl index ff19cebfd..8a8234263 100644 --- a/fcl/gen/genie/simulation_genie_icarus_simple_workshop.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_simple_workshop.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_workshopMar2018.fcl b/fcl/gen/genie/simulation_genie_icarus_workshopMar2018.fcl index ec3c430d6..9ed705e20 100644 --- a/fcl/gen/genie/simulation_genie_icarus_workshopMar2018.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_workshopMar2018.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_workshopMar2018_nuecc.fcl b/fcl/gen/genie/simulation_genie_icarus_workshopMar2018_nuecc.fcl index a95d2a52b..861051faa 100644 --- a/fcl/gen/genie/simulation_genie_icarus_workshopMar2018_nuecc.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_workshopMar2018_nuecc.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/genie/simulation_genie_icarus_workshopMar2018_numucc.fcl b/fcl/gen/genie/simulation_genie_icarus_workshopMar2018_numucc.fcl index 83d735d0a..e97ba61b7 100644 --- a/fcl/gen/genie/simulation_genie_icarus_workshopMar2018_numucc.fcl +++ b/fcl/gen/genie/simulation_genie_icarus_workshopMar2018_numucc.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/gen/numi/simulation_numi.fcl b/fcl/gen/numi/simulation_numi.fcl index db159f2c3..dbc5455c9 100644 --- a/fcl/gen/numi/simulation_numi.fcl +++ b/fcl/gen/numi/simulation_numi.fcl @@ -2,7 +2,6 @@ #include "singles.fcl" #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus_numioffaxis.fcl" #include "beamgates_icarus.fcl" #include "mcreco.fcl" diff --git a/fcl/gen/numi/simulation_numi_nue.fcl b/fcl/gen/numi/simulation_numi_nue.fcl index 669e9f969..f32ad3a58 100644 --- a/fcl/gen/numi/simulation_numi_nue.fcl +++ b/fcl/gen/numi/simulation_numi_nue.fcl @@ -2,7 +2,6 @@ #include "singles.fcl" #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus_numioffaxis.fcl" #include "beamgates_icarus.fcl" #include "mcreco.fcl" diff --git a/fcl/gen/numi/simulation_numi_numu.fcl b/fcl/gen/numi/simulation_numi_numu.fcl index 6f789ce62..d0e786728 100644 --- a/fcl/gen/numi/simulation_numi_numu.fcl +++ b/fcl/gen/numi/simulation_numi_numu.fcl @@ -2,7 +2,6 @@ #include "singles.fcl" #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "genie_icarus_numioffaxis.fcl" #include "beamgates_icarus.fcl" #include "mcreco.fcl" diff --git a/fcl/gen/overlay/prodoverlay_proton_sbnflux_icarus.fcl b/fcl/gen/overlay/prodoverlay_proton_sbnflux_icarus.fcl index e0f2de650..71d2ae45f 100644 --- a/fcl/gen/overlay/prodoverlay_proton_sbnflux_icarus.fcl +++ b/fcl/gen/overlay/prodoverlay_proton_sbnflux_icarus.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "corsika_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/fcl/overlays/dirt_gen_overlay_siminfomixer.fcl b/fcl/overlays/dirt_gen_overlay_siminfomixer.fcl new file mode 100644 index 000000000..ebb55b3dd --- /dev/null +++ b/fcl/overlays/dirt_gen_overlay_siminfomixer.fcl @@ -0,0 +1,111 @@ +#include "services_common_icarus.fcl" +#include "icarus_siminfomixer.fcl" + +services: +{ + @table::icarus_common_services + + scheduler: { defaultExceptions: false } # Make all uncaught exceptions fatal. + # Load the service that manages root files for histograms. + TFileService: { fileName: "siminfomixer.root" } + + RandomNumberGenerator: {} #ART native random number generator +} + +process_name : SimInfoMixer #The process name must NOT contain any underscores + +source: +{ + module_type: RootInput + saveMemoryObjectThreshold: 0 + maxEvents: -1 +} + +outputs: { + out: { module_type: RootOutput + fileName: "%ifb_%tc_mixed.root" + compressionLevel: 1 + dataTier: "generated" + SelectEvents: ["mixer_path"] + } +} + +physics: { + + producers : { + } + + analyzers: { + } + + filters : { + generator: @local::icarus_siminfomixer + beamgate: @local::icarus_siminfomixer + largeant: @local::icarus_siminfomixer + ionization: @local::icarus_siminfomixer + simplemerge: @local::icarus_siminfomixer + genericcrt: @local::icarus_siminfomixer + sedlite: @local::icarus_siminfomixer + simdrift: @local::icarus_siminfomixer + pdfastsim: @local::icarus_siminfomixer + } + + mixer_path : [ generator, beamgate, largeant, ionization, simplemerge, genericcrt, sedlite, simdrift, pdfastsim] + trigger_paths : [ mixer_path ] + + output : [ out ] + end_paths: [ output ] + +} + +physics.filters.generator.MCTruthInputModuleLabels: ["generator::GenGenie"] +physics.filters.generator.GTruthInputModuleLabels: ["generator::GenGenie"] +physics.filters.generator.MCTruthGTruthAssnsInputModuleLabels: ["generator::GenGenie"] +physics.filters.generator.MCFluxInputModuleLabels: ["generator::GenGenie"] +physics.filters.generator.MCTruthMCFluxAssnsInputModuleLabels: ["generator::GenGenie"] +physics.filters.generator.FillPOTInfo: true +physics.filters.generator.POTSummaryTag: "potinevent:SubRunPOT:G4" + +physics.filters.beamgate.BeamGateInputModuleLabels: ["beamgate::GenGenie"] + +physics.filters.largeant.SimEnergyDepositInputModuleLabels: [ + "largeant:LArG4DetectorServicevolTPCPlaneV:G4", + "largeant:LArG4DetectorServicevolTPC0:G4", + "largeant:LArG4DetectorServicevolTPCPlaneU:G4", + "largeant:LArG4DetectorServicevolTPCPlaneY:G4", + "largeant:LArG4DetectorServicevolTPCActive:G4" +] +physics.filters.largeant.AuxDetHitInputModuleLabels: [ + "largeant:LArG4DetectorServicevolAuxDetSensitiveCERNbot:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveMINOScut309:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveMINOS:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveMINOScut256:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveDC:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveMINOScut508:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveMINOScut497:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveMINOScut325:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveMINOScut485:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveCERNtop:G4", + "largeant:LArG4DetectorServicevolAuxDetSensitiveMINOScut400:G4" +] +physics.filters.largeant.MCParticleInputModuleLabels: [ + "largeant::G4", + "largeant:droppedMCParticles:G4" +] +physics.filters.largeant.MCTruthInputModuleLabels: ["generator::GenGenie"] +physics.filters.largeant.MCTruthMCParticleAssnsInputModuleLabels: ["largeant::G4"] + +physics.filters.ionization.SimEnergyDepositInputModuleLabels: [ + "ionization::G4", + "ionization:priorSCE:G4" +] + +physics.filters.simplemerge.MCParticleInputModuleLabels: ["simplemerge::G4"] + +physics.filters.genericcrt.AuxDetSimChannelInputModuleLabels: ["genericcrt::G4"] + +physics.filters.sedlite.SimEnergyDepositLiteInputModuleLabels: ["sedlite::G4"] + +physics.filters.simdrift.SimChannelInputModuleLabels: ["simdrift::G4"] + +physics.filters.pdfastsim.SimPhotonsInputModuleLabels: ["pdfastsim::G4"] diff --git a/fcl/overlays/overlay_waveforms.fcl b/fcl/overlays/overlay_waveforms.fcl index f3ba7a1ae..48714f826 100644 --- a/fcl/overlays/overlay_waveforms.fcl +++ b/fcl/overlays/overlay_waveforms.fcl @@ -108,5 +108,4 @@ outputs.rootOutput.outputCommands: ["keep *_*_*_*", "drop *_gaushitTPC*_*_*", "drop *_ophit*_*_*", "drop *_opflash*_*_*", - "drop *_crthit*_*_*", "drop *_crttrack*_*_*"] #TODO: drop raw waveforms that arent from this module. Keep wf from this module to feed to later stages diff --git a/fcl/overlays/simulation_genie_icarus_bnb_overlays_volDetEnclosure_fiducial.fcl b/fcl/overlays/simulation_genie_icarus_bnb_overlays_volDetEnclosure_fiducial.fcl new file mode 100644 index 000000000..6ed23513d --- /dev/null +++ b/fcl/overlays/simulation_genie_icarus_bnb_overlays_volDetEnclosure_fiducial.fcl @@ -0,0 +1,3 @@ +#include "simulation_genie_icarus_bnb_overlays_volDetEnclosure.fcl" + +physics.producers.generator.FiducialCut: "mbox: -378.49,-191.86,-904.950652270838,378.49,144.96,904.950652270838" diff --git a/fcl/reco/CMakeLists.txt b/fcl/reco/CMakeLists.txt index de9682fc7..565e07219 100644 --- a/fcl/reco/CMakeLists.txt +++ b/fcl/reco/CMakeLists.txt @@ -13,6 +13,7 @@ add_subdirectory(ForCITests) #add_subdirectory(archive) add_subdirectory(Definitions) add_subdirectory(larcv) +add_subdirectory(wires) add_subdirectory(ntuple) add_subdirectory(Stage0) add_subdirectory(Stage1) diff --git a/fcl/reco/Definitions/enable_overlay_stage1.fcl b/fcl/reco/Definitions/enable_overlay_stage1.fcl index 71707c38e..68715ee7c 100644 --- a/fcl/reco/Definitions/enable_overlay_stage1.fcl +++ b/fcl/reco/Definitions/enable_overlay_stage1.fcl @@ -12,3 +12,6 @@ physics.producers.crttrack.DataLabelHits: "overlayCRTHit" # overlay PMT waveforms physics.analyzers.simpleLightAna.OpDetWaveformLabels: ["overlayOpWaveforms"] + +# Set Supera config +physics.analyzers.superaMC.supera_params: "supera_icarus_MC_all_cryo_PMT_CRT_overlay.fcl" diff --git a/fcl/reco/Definitions/stage1_icarus_defs.fcl b/fcl/reco/Definitions/stage1_icarus_defs.fcl index 22b46744c..ffea118ee 100644 --- a/fcl/reco/Definitions/stage1_icarus_defs.fcl +++ b/fcl/reco/Definitions/stage1_icarus_defs.fcl @@ -43,6 +43,10 @@ icarus_stage1_producers: cluster3DCryoW: @local::icarus_cluster3d cluster3DCryoE: @local::icarus_cluster3d + ### Hit combiner + combineHitsCryoE: @local::icarus_hitmerger_cryoE + combineHitsCryoW: @local::icarus_hitmerger_cryoW + ### pandora pandoraGausCryoW: @local::icarus_pandora pandoraTrackGausCryoW: @local::icarus_pandoraTrackCreation @@ -192,11 +196,17 @@ icarus_WestHits_TPC: [ gaushit1dTPCWW, gaushit1dTPCWE ] icarus_EastHits2d_TPC: [ gaushit2dTPCEW, - gaushit2dTPCEE + gaushit2dTPCEE, + combineHitsCryoE, + gaushitPT2dTPCEW, + gaushitPT2dTPCEE ] icarus_WestHits2d_TPC: [ gaushit2dTPCWW, - gaushit2dTPCWE + gaushit2dTPCWE, + combineHitsCryoW, + gaushitPT2dTPCWW, + gaushitPT2dTPCWE ] # Set up filtering of cluster3D hits by cryostat @@ -314,6 +324,16 @@ icarus_stage1_producers.gaushit2dTPCWW.HitFinderToolVec.CandidateHitsPlane1.RoiT icarus_stage1_producers.gaushit2dTPCWW.HitFinderToolVec.CandidateHitsPlane2.RoiThreshold: 5. icarus_stage1_producers.gaushit2dTPCWW.HitFilterAlg.MinPulseHeight: [3., 3., 3.] +# Setup version of hit finder's with Pulse Trains ("PT"s) enabled +icarus_stage1_producers.gaushitPT2dTPCEE: @local::icarus_stage1_producers.gaushit2dTPCEE +icarus_stage1_producers.gaushitPT2dTPCEE.LongMaxHits: [10, 10, 10] +icarus_stage1_producers.gaushitPT2dTPCEW: @local::icarus_stage1_producers.gaushit2dTPCEW +icarus_stage1_producers.gaushitPT2dTPCEW.LongMaxHits: [10, 10, 10] +icarus_stage1_producers.gaushitPT2dTPCWE: @local::icarus_stage1_producers.gaushit2dTPCWE +icarus_stage1_producers.gaushitPT2dTPCWE.LongMaxHits: [10, 10, 10] +icarus_stage1_producers.gaushitPT2dTPCWW: @local::icarus_stage1_producers.gaushit2dTPCWW +icarus_stage1_producers.gaushitPT2dTPCWW.LongMaxHits: [10, 10, 10] + ## Overrides for filtering of cluster3D hits icarus_stage1_filters.TPCHitFilterCryoW.HitDataLabelVec: ["cluster3DCryoW"] icarus_stage1_filters.TPCHitFilterCryoW.MaximumHits: 60000 @@ -323,7 +343,8 @@ icarus_stage1_filters.TPCHitFilterCryoE.MaximumHits: 60000 ## Definitions for running the 3D clustering by Cryostat icarus_stage1_producers.cluster3DCryoW.MakeSpacePointsOnly: true -icarus_stage1_producers.cluster3DCryoW.Hit3DBuilderAlg.HitFinderTagVec: ["gaushit2dTPCWW", "gaushit2dTPCWE"] +# use the "PT" (pulse train) hits as input to cluster3D +icarus_stage1_producers.cluster3DCryoW.Hit3DBuilderAlg.HitFinderTagVec: ["gaushitPT2dTPCWW", "gaushitPT2dTPCWE"] icarus_stage1_producers.cluster3DCryoW.Hit3DBuilderAlg.PulseHeightFraction: 0. #0.75 #0.25 icarus_stage1_producers.cluster3DCryoW.Hit3DBuilderAlg.PHLowSelection: 0. #4.0 # 20. icarus_stage1_producers.cluster3DCryoW.Hit3DBuilderAlg.MaxHitChiSquare: 1000000. @@ -331,7 +352,7 @@ icarus_stage1_producers.cluster3DCryoW.Hit3DBuilderAlg.MaxMythicalChiSquare: icarus_stage1_producers.cluster3DCryoW.Hit3DBuilderAlg.OutputHistograms: false icarus_stage1_producers.cluster3DCryoE.MakeSpacePointsOnly: true -icarus_stage1_producers.cluster3DCryoE.Hit3DBuilderAlg.HitFinderTagVec: ["gaushit2dTPCEW", "gaushit2dTPCEE"] +icarus_stage1_producers.cluster3DCryoE.Hit3DBuilderAlg.HitFinderTagVec: ["gaushitPT2dTPCEW", "gaushitPT2dTPCEE"] icarus_stage1_producers.cluster3DCryoE.Hit3DBuilderAlg.PulseHeightFraction: 0. #0.75 #0.25 icarus_stage1_producers.cluster3DCryoE.Hit3DBuilderAlg.PHLowSelection: 0. #4.0 # 20. icarus_stage1_producers.cluster3DCryoE.Hit3DBuilderAlg.MaxHitChiSquare: 1000000. @@ -339,13 +360,17 @@ icarus_stage1_producers.cluster3DCryoE.Hit3DBuilderAlg.MaxMythicalChiSquare: icarus_stage1_producers.cluster3DCryoE.Hit3DBuilderAlg.OutputHistograms: false ### Definitions for a pandora by cryostat -icarus_stage1_producers.pandoraGausCryoW.HitFinderModuleLabel: "cluster3DCryoW" +icarus_stage1_producers.pandoraGausCryoW.HitFinderModuleLabel: "combineHitsCryoW" +# icarus_stage1_producers.pandoraGausCryoW.HitFinderModuleLabel: "" +# icarus_stage1_producers.pandoraGausCryoW.HitCollectionTool.OverrhideHitLabels: ["gaushit2dTPCWW", "gaushit2dTPCWE"] icarus_stage1_producers.pandoraTrackGausCryoW.PFParticleLabel: "pandoraGausCryoW" icarus_stage1_producers.pandoraTrackGausCryoW.UseAllParticles: true icarus_stage1_producers.pandoraKalmanTrackGausCryoW.inputCollection: "pandoraGausCryoW" icarus_stage1_producers.pandoraKalmanTrackGausCryoW.trackInputTag: "pandoraTrackGausCryoW" -icarus_stage1_producers.pandoraGausCryoE.HitFinderModuleLabel: "cluster3DCryoE" +icarus_stage1_producers.pandoraGausCryoE.HitFinderModuleLabel: "combineHitsCryoE" +# icarus_stage1_producers.pandoraGausCryoE.HitFinderModuleLabel: "" +# icarus_stage1_producers.pandoraGausCryoE.HitCollectionTool.OverrhideHitLabels: ["gaushit2dTPCEW", "gaushit2dTPCEE"] icarus_stage1_producers.pandoraTrackGausCryoE.PFParticleLabel: "pandoraGausCryoE" icarus_stage1_producers.pandoraTrackGausCryoE.UseAllParticles: true icarus_stage1_producers.pandoraKalmanTrackGausCryoE.inputCollection: "pandoraGausCryoE" @@ -358,10 +383,20 @@ icarus_stage1_producers.caloskimCalorimetryCryoW.TrackModuleLabel: #icarus_stage1_producers.pandoraGausCryoW.ConfigFile: "PandoraSettings_Master_ICARUS_RawICARUS.xml" #icarus_stage1_producers.pandoraGausCryoE.ConfigFile: "PandoraSettings_Master_ICARUS_RawICARUS.xml" +# Also fix hit label for CRT-(pandora) TPC tagging +icarus_stage1_producers.CRTT0Tagging.HitLabel: ["combineHitsCryoE", "combineHitsCryoW"] + +# Override labels for ntupler +icarus_stage1_analyzers.caloskimE.HITproducer: "combineHitsCryoE" +icarus_stage1_analyzers.caloskimW.HITproducer: "combineHitsCryoW" + ## Definitions for shower finding (both single and by cryostat) icarus_stage1_producers.SBNShowerGausCryoW.PFParticleLabel: "pandoraGausCryoW" icarus_stage1_producers.SBNShowerGausCryoW.UseAllParticles: true icarus_stage1_producers.SBNShowerGausCryoE.PFParticleLabel: "pandoraGausCryoE" icarus_stage1_producers.SBNShowerGausCryoE.UseAllParticles: true +# Set supera input fcl files +icarus_stage1_analyzers.superaMC.supera_params: "supera_icarus_MC_all_cryo_PMT_CRT_v10.fcl" + END_PROLOG diff --git a/fcl/reco/Stage0/data/CMakeLists.txt b/fcl/reco/Stage0/data/CMakeLists.txt index 2bda0f610..9b8e98380 100644 --- a/fcl/reco/Stage0/data/CMakeLists.txt +++ b/fcl/reco/Stage0/data/CMakeLists.txt @@ -1,3 +1,5 @@ +add_subdirectory(partial) + cet_enable_asserts() install_fhicl() diff --git a/fcl/reco/Stage0/data/partial/CMakeLists.txt b/fcl/reco/Stage0/data/partial/CMakeLists.txt new file mode 100644 index 000000000..13355789a --- /dev/null +++ b/fcl/reco/Stage0/data/partial/CMakeLists.txt @@ -0,0 +1 @@ +install_fhicl() diff --git a/fcl/reco/Stage0/data/partial/decodePMT_icarus.fcl b/fcl/reco/Stage0/data/partial/decodePMT_icarus.fcl new file mode 100644 index 000000000..d22be3e79 --- /dev/null +++ b/fcl/reco/Stage0/data/partial/decodePMT_icarus.fcl @@ -0,0 +1,145 @@ +# +# File: decodePMT_icarus.fcl +# Purpose: PMT readout fragment decoding for studies in ICARUS. +# Author: Gianluca Petrillo (petrillo@slac.stanford.edu) +# Date: May 12, 2021 +# +# +# PMT waveform decoding is performed, extensive debugging messages are +# included in the `debug.log` log file, and ROOT trees are produced for studies. +# This configuration, as is, is not meant for production. +# +# +# Input +# ------ +# +# * artDAQ fragments from all 24 PMT readout boards, named +# `daq:ContainerCAENV1730` +# * trigger fragment `daq:ICARUSTriggerUDP` (will be decoded as well) +# * DAQ configuration as FHiCL in the art/ROOT input file +# +# This configuration requires a data fragment for each PMT readout board +# which is mentioned in `physics.producers.daqPMT.DecoderTool.BoardSetup`, +# which by default is all 24. If the input run misses some PMT readout boards, +# use `decodePMT_icarus_incomplete.fcl` instead. +# +# +# Output +# ------- +# +# Only new data products are written in the art/ROOT output file, including: +# +# * `daqPMT` (std::vector): decoded waveforms, +# with our best reconstruction for their time stamps in LArSoft reference +# +# +# The `Trees-*.root` file (from `TFileService`) includes ROOT tree +# `PMTfragments`. +# +# +# +# Service configuration +# ---------------------- +# +# * `DetectorClocksService` is essential to assign a correct waveform timestamp +# * `Geometry` service bundle is required by `DetectorClocksService` +# * `IICARUSChannelMap` to relate PMT fragment IDs to channels +# * `TFileService` used to write trees (not needed if all trees are disabled) +# +# + + +# ------------------------------------------------------------------------------ +#include "services_common_icarus.fcl" +#include "channelmapping_icarus.fcl" +#include "timing_icarus.fcl" + +#include "rootoutput_icarus.fcl" +#include "decoderdefs_icarus.fcl" + +# ------------------------------------------------------------------------------ +process_name: DecodePMT + + +# ------------------------------------------------------------------------------ +services: { + + @table::icarus_art_services + message: @local::icarus_message_services_interactive_debug + + @table::icarus_geometry_services + DetectorClocksService: @local::icarus_detectorclocks + IICARUSChannelMap: @local::icarus_channelmappinggservice + IPMTTimingCorrectionService: @local::icarus_pmttimingservice + + TFileService: { fileName: "Trees-%ifb_%tc-%p.root" } +} + + +# ------------------------------------------------------------------------------ +physics: { + + producers: { + + triggerconfig: @local::extractTriggerConfig + pmtconfig: @local::extractPMTconfig + + daqTrigger: @local::decodeTriggerAutodetect + + daqPMT: @local::decodePMT + + } + + decoding: [ triggerconfig, pmtconfig, daqTrigger, daqPMT ] + streams: [ rootoutput ] +} + + +# ------------------------------------------------------------------------------ +outputs: { + rootoutput: { + @table::icarus_rootoutput + dataTier: "decoded" + fileProperties: { maxInputFiles: 1 } + checkFileName: false + compressionLevel: 501 + + outputCommands: [ "drop *_*_*_*", "keep *_*_*_DecodePMT" ] + } # rootoutput +} # outputs + + +# ------------------------------------------------------------------------------ + +physics.producers.daqTrigger.DecoderTool.Decoders[0].ToolConfig.TrigConfigLabel: triggerconfig +physics.producers.daqTrigger.DecoderTool.Decoders[1].ToolConfig.TrigConfigLabel: triggerconfig +physics.producers.daqTrigger.DecoderTool.Decoders[2].ToolConfig.TrigConfigLabel: triggerconfig +physics.producers.daqPMT.PMTconfigTag: pmtconfig # required +physics.producers.daqPMT.TriggerTag: daqTrigger # required + +# services.Geometry.Name: icarus_splitwires # for runs < 548x + +# +# customization of PMT decoding +# + +physics.producers.daqPMT.SurviveExceptions: false +physics.producers.daqPMT.DiagnosticOutput: true +physics.producers.daqPMT.PacketDump: false +physics.producers.daqPMT.RequireKnownBoards: true +physics.producers.daqPMT.RequireBoardConfig: true +physics.producers.daqPMT.DataTrees: [ "PMTfragments" ] + +# +# customization of trigger decoding +# + +physics.producers.daqTrigger.DecoderTool.Decoders[0].ToolConfig.DiagnosticOutput: true +physics.producers.daqTrigger.DecoderTool.Decoders[1].ToolConfig.DiagnosticOutput: true +physics.producers.daqTrigger.DecoderTool.Decoders[2].ToolConfig.DiagnosticOutput: true +physics.producers.daqTrigger.DecoderTool.Decoders[0].ToolConfig.Debug: false +physics.producers.daqTrigger.DecoderTool.Decoders[1].ToolConfig.Debug: false +physics.producers.daqTrigger.DecoderTool.Decoders[2].ToolConfig.Debug: false + + +# ------------------------------------------------------------------------------ diff --git a/fcl/reco/Stage0/data/partial/decodePMT_icarus_incomplete.fcl b/fcl/reco/Stage0/data/partial/decodePMT_icarus_incomplete.fcl new file mode 100644 index 000000000..038a09480 --- /dev/null +++ b/fcl/reco/Stage0/data/partial/decodePMT_icarus_incomplete.fcl @@ -0,0 +1,15 @@ +# +# File: decodePMT_icarus_incomplete.fcl +# Purpose: PMT readout fragment decoding for studies in ICARUS. +# Author: Gianluca Petrillo (petrillo@slac.stanford.edu) +# Date: May 12, 2021 +# +# This is a version of `decodePMT_icarus.fcl` which will ignore missing PMT +# readout fragments. +# +# See the documentation on `decodePMT_icarus.fcl` for everything else. +# + +#include "decodePMT_icarus.fcl" + +physics.producers.daqPMT.RequireBoardConfig: false diff --git a/fcl/reco/Stage0/data/partial/decodePMT_icarus_standalone.fcl b/fcl/reco/Stage0/data/partial/decodePMT_icarus_standalone.fcl new file mode 100644 index 000000000..fa70378a8 --- /dev/null +++ b/fcl/reco/Stage0/data/partial/decodePMT_icarus_standalone.fcl @@ -0,0 +1,69 @@ +# +# File: decodePMT_icarus_standalone.fcl +# Purpose: PMT readout fragment decoding for studies in ICARUS. +# Author: Gianluca Petrillo (petrillo@slac.stanford.edu) +# Date: June 10, 2021 +# +# This configuration expects only PMT fragments, and not even all of them: +# as a consequence many timestamp corrections will be skipped. +# PMT waveform decoding is performed, extensive debugging messages are +# included in the `debug.log` log file, and ROOT trees are produced for studies. +# This configuration, as is, is not meant for production. +# +# +# Input +# ------ +# +# * artDAQ fragments from PMT readout boards, named +# `daq:ContainerCAENV1730` or `daq:CAENV1730` (not both!) +# +# +# Output +# ------- +# +# Only new data products are written in the art/ROOT output file, including: +# +# * `daqPMT` (std::vector): decoded waveforms, +# with our best reconstruction for their time stamps in LArSoft reference +# +# +# The `Trees-*.root` file (from `TFileService`) includes ROOT tree +# `PMTfragments`. +# +# +# +# Service configuration +# ---------------------- +# +# * `DetectorClocksService` is essential to assign a correct waveform timestamp +# * `Geometry` service bundle is required by `DetectorClocksService` +# * `IICARUSChannelMap` to relate PMT fragment IDs to channels +# * `TFileService` used to write trees (not needed if all trees are disabled) +# +# + + +# ------------------------------------------------------------------------------ +#include "decodePMT_icarus.fcl" + + +# ------------------------------------------------------------------------------ +physics.decoding: [ daqPMT ] + + +# ------------------------------------------------------------------------------ + +physics.producers.daqPMT.PMTconfigTag: @erase # required +physics.producers.daqPMT.TriggerTag: @erase # required + +# +# customization of PMT decoding +# + +physics.producers.daqPMT.SurviveExceptions: false +physics.producers.daqPMT.DiagnosticOutput: true +physics.producers.daqPMT.PacketDump: true +physics.producers.daqPMT.RequireKnownBoards: false +physics.producers.daqPMT.RequireBoardConfig: false + +# ------------------------------------------------------------------------------ diff --git a/fcl/reco/Stage0/data/partial/decodePMT_icarus_treeonly.fcl b/fcl/reco/Stage0/data/partial/decodePMT_icarus_treeonly.fcl new file mode 100644 index 000000000..5e34eefad --- /dev/null +++ b/fcl/reco/Stage0/data/partial/decodePMT_icarus_treeonly.fcl @@ -0,0 +1,68 @@ +# +# File: decodePMT_icarus_treeonly.fcl +# Purpose: Runs PMT decoding to build a PMT diagnostic tree. +# Author: Gianluca Petrillo (petrillo@slac.stanford.edu) +# Date: September 25, 2022 +# +# It does not save any waveform. +# +# Input +# ------ +# +# * artDAQ fragments from all 24 PMT readout boards, named +# `daq:ContainerCAENV1730` (or any standard ICARUS name) +# * trigger fragment (autodetected among ICARUS standard names) +# * DAQ configuration as FHiCL in the art/ROOT input file +# +# This configuration requires a data fragment for each PMT readout board +# which is mentioned in `physics.producers.daqPMT.DecoderTool.BoardSetup`, +# which by default is all 24. +# +# +# Output +# ------- +# +# In the plain ROOT output file (names `Tree-....root`) a diagnostic tree +# is stored with one entry per PMT data fragment (see `decodePMT_icarus.fcl` +# and the decoder module `DaqDecodeICARUSPMT`), as `daqPMT/PMTfragments`. +# +# All standard trigger and PMT decoding data products are produced with the +# standard names (`daqTrigger` and `daqPMT` respectively). +# The noticeable exception is PMT raw waveforms not the corrections: +# neither are saved. +# +# The log file also dump the trigger information. +# +# + + +# ------------------------------------------------------------------------------ +#include "decodePMT_icarus.fcl" + +# add a trigger dumper to the output on console +physics.analyzers.dumptrigger: { + module_type: DumpTrigger + TriggerTag: "daqTrigger" +} + +physics.dumpers: [ dumptrigger ] +physics.end_paths: [ streams, dumpers ] + +outputs.rootoutput.fileProperties: @erase # don't go one output file per input file +outputs.rootoutput.outputCommands: [ + @sequence::outputs.rootoutput.outputCommands + , "drop raw::OpDetWaveforms_daqPMT_*_DecodePMT" +] + +# disable abundant output on console and the optical waveforms +physics.producers.daqPMT.SaveCorrectionsFrom: [] +physics.producers.daqPMT.DiagnosticOutput: false +physics.producers.daqTrigger.DecoderTool.Decoders[0].ToolConfig.DiagnosticOutput: false +physics.producers.daqTrigger.DecoderTool.Decoders[1].ToolConfig.DiagnosticOutput: false +physics.producers.daqTrigger.DecoderTool.Decoders[2].ToolConfig.DiagnosticOutput: false + +services.message.destinations.LogDebugFile: @erase +services.message.destinations.LogSeeds: @erase +services.TimeTracker: {} # no DB file +services.MemoryTracker: @erase + diff --git a/fcl/reco/Stage0/data/partial/decodeTrigger_icarus.fcl b/fcl/reco/Stage0/data/partial/decodeTrigger_icarus.fcl new file mode 100644 index 000000000..d041c0023 --- /dev/null +++ b/fcl/reco/Stage0/data/partial/decodeTrigger_icarus.fcl @@ -0,0 +1,56 @@ +#include "services_common_icarus.fcl" +#include "channelmapping_icarus.fcl" +#include "rootoutput_icarus.fcl" +#include "decoderdefs_icarus.fcl" + +process_name: DecodeTrg + +services: { + + @table::icarus_art_services + message: @local::icarus_message_services_interactive_debug + + @table::icarus_geometry_services + DetectorClocksService: @local::icarus_detectorclocks + IICARUSChannelMap: @local::icarus_channelmappinggservice # from channelmapping_icarus.fcl +} + + +physics: { + + producers: { + +// pmtconfig: @local::extractPMTconfig + triggerconfig: @local::extractTriggerConfig + + daqTrigger: @local::decodeTriggerAutodetect + +// daqPMT: @local::decodePMT + + } + +// decoding: [ PMTconfig, triggerconfig, daqTrigger, daqPMT ] + decoding: [ triggerconfig, daqTrigger ] + streams: [ rootoutput ] +} + +outputs: { + rootoutput: { + @table::icarus_rootoutput + dataTier: "decoded" + fileProperties: { maxInputFiles: 1 } + checkFileName: false + compressionLevel: 501 + + outputCommands: [ "drop *_*_*_*", "keep *_*_*_DecodeTrg" ] + } # rootoutput +} # outputs + + +physics.producers.daqTrigger.DecoderTool.TrigConfigLabel: triggerconfig +physics.producers.daqTrigger.DecoderTool.Decoders[0].ToolConfig.DiagnosticOutput: true +physics.producers.daqTrigger.DecoderTool.Decoders[0].ToolConfig.Debug: true +physics.producers.daqTrigger.DecoderTool.Decoders[1].ToolConfig.DiagnosticOutput: true +physics.producers.daqTrigger.DecoderTool.Decoders[1].ToolConfig.Debug: true +physics.producers.daqTrigger.DecoderTool.Decoders[2].ToolConfig.DiagnosticOutput: true +physics.producers.daqTrigger.DecoderTool.Decoders[2].ToolConfig.Debug: true diff --git a/fcl/reco/Stage0/data/partial/stage0_run2_icarus_opdetonly.fcl b/fcl/reco/Stage0/data/partial/stage0_run2_icarus_opdetonly.fcl new file mode 100644 index 000000000..a7abf2d87 --- /dev/null +++ b/fcl/reco/Stage0/data/partial/stage0_run2_icarus_opdetonly.fcl @@ -0,0 +1,19 @@ +# +# File: stage0_run2_icarus_opdetonly.fcl +# Purpose: Runs the optical detector and trigger reconstruction parts of Stage0 +# Author: Gianluca Petrillo (petrillo@slac.stanford.edu) +# Date: August 29, 2023 +# +# Written for icaruscode v09_72_00_05p1. +# + +#include "stage0_run2_icarus.fcl" + +source.maxEvents: @erase + +physics.path: [ @sequence::icarus_stage0_PMT ] + +physics.end_paths: [ streamROOT ] + +# be unstoppable +physics.producers.daqPMT.SurviveExceptions: true diff --git a/fcl/reco/Stage0/data/stage0_daqPMT_drop.fcl b/fcl/reco/Stage0/data/stage0_daqPMT_drop.fcl index 844c9871b..f8c65b010 100644 --- a/fcl/reco/Stage0/data/stage0_daqPMT_drop.fcl +++ b/fcl/reco/Stage0/data/stage0_daqPMT_drop.fcl @@ -2,6 +2,8 @@ ## This fhicl file is used to drop daqPMT from the stage0 file ## +#include "services_common_icarus.fcl" + process_name: daqPMTdrop outputs: { diff --git a/fcl/reco/Stage0/data/stage0_run2_icarus.fcl b/fcl/reco/Stage0/data/stage0_run2_icarus.fcl index bf5b6dbea..31e98f9d5 100644 --- a/fcl/reco/Stage0/data/stage0_run2_icarus.fcl +++ b/fcl/reco/Stage0/data/stage0_run2_icarus.fcl @@ -27,7 +27,6 @@ outputs.rootOutput.outputCommands: [ "drop *_*_*_DAQ*", "drop *_ophituncorrected_*_*", "drop *_daqPMTonbeam_*_*", - "drop *_daqCRT_*_*", "drop *_daqTPCROI_*_*", "drop *_decon2droiEE_*_*", "drop *_decon2droiEW_*_*", diff --git a/fcl/reco/Stage0/mc/stage0_run2_icarus_mc.fcl b/fcl/reco/Stage0/mc/stage0_run2_icarus_mc.fcl index 3456eee69..533e5d486 100644 --- a/fcl/reco/Stage0/mc/stage0_run2_icarus_mc.fcl +++ b/fcl/reco/Stage0/mc/stage0_run2_icarus_mc.fcl @@ -16,7 +16,6 @@ physics.producers: { @table::icarus_stage0_producers physics.path: [ @sequence::icarus_stage0_mc_PMT, MCDecodeTPCROI, @sequence::icarus_stage0_multiTPC, - simChannelROI, @sequence::icarus_stage0_mc_crthit, @sequence::icarus_stage0_mc_crtreco ] @@ -35,7 +34,11 @@ outputs.rootOutput.outputCommands: ["keep *_*_*_*", "drop *_MCDecodeTPCROI_*_*", "drop *_decon1droi_*_*", "drop recob::Wire*_roifinder*_*_*", - "keep *_daq_simpleSC*_*"] + "drop *_overlayOpWaveforms_*_*", + "drop raw::OpDetWaveform*_shifted_*_*", + "keep *_daq_simpleSC*_*", + "keep *_daqPMT_*_*" +] # Set the expected input for ophit physics.producers.ophit.InputModule: "shifted" diff --git a/fcl/reco/Stage0/mc/stage0_run2_wc_icarus_mc.fcl b/fcl/reco/Stage0/mc/stage0_run2_wc_icarus_mc.fcl index ed15d7f0d..d0a3118a0 100644 --- a/fcl/reco/Stage0/mc/stage0_run2_wc_icarus_mc.fcl +++ b/fcl/reco/Stage0/mc/stage0_run2_wc_icarus_mc.fcl @@ -33,7 +33,11 @@ outputs.rootOutput.outputCommands: ["keep *_*_*_*", "drop *_decon1droi_*_*", "drop *_decon2droi*_*_*", "drop recob::Wire*_roifinder*_*_*", - "keep *_daq_simpleSC*_*"] + "drop *_overlayOpWaveforms_*_*", + "drop raw::OpDetWaveform*_shifted_*_*", + "keep *_daq_simpleSC*_*", + "keep *_daqPMT_*_*" +] # Set the expected input for ophit physics.producers.ophit.InputModule: "shifted" diff --git a/fcl/reco/Stage0/mc/stage0_run2_wc_icarus_mc_notriggersim.fcl b/fcl/reco/Stage0/mc/stage0_run2_wc_icarus_mc_notriggersim.fcl index 9d738f348..54f81872a 100644 --- a/fcl/reco/Stage0/mc/stage0_run2_wc_icarus_mc_notriggersim.fcl +++ b/fcl/reco/Stage0/mc/stage0_run2_wc_icarus_mc_notriggersim.fcl @@ -1,6 +1,7 @@ #include "stage0_run2_wc_icarus_mc.fcl" # restore non-shifted labels +physics.producers.ophit.InputModule: "opdaq" physics.producers.emuTrigger.BeamGates: "beamgate" physics.producers.mcophit.SimPhotonsProducer: "pdfastsim" physics.producers.opdetonbeam.Waveforms: "opdaq" diff --git a/fcl/reco/Stage1/data/stage1_run2_1d_icarus.fcl b/fcl/reco/Stage1/data/stage1_run2_1d_icarus.fcl index 4a6e28986..1ce43a36c 100644 --- a/fcl/reco/Stage1/data/stage1_run2_1d_icarus.fcl +++ b/fcl/reco/Stage1/data/stage1_run2_1d_icarus.fcl @@ -11,3 +11,11 @@ physics.reco: [ @sequence::icarus_filter1D_cluster3D, physics.producers.cluster3DCryoW.Hit3DBuilderAlg.HitFinderTagVec: ["gaushit1dTPCWW", "gaushit1dTPCWE"] physics.producers.cluster3DCryoE.Hit3DBuilderAlg.HitFinderTagVec: ["gaushit1dTPCEW", "gaushit1dTPCEE"] + +physics.producers.pandoraGausCryoE.HitFinderModuleLabel: "cluster3DCryoE" +physics.producers.pandoraGausCryoW.HitFinderModuleLabel: "cluster3DCryoW" + +physics.producers.CRTT0Tagging.HitLabel: ["cluster3DCryoE", "cluster3DCryoW"] + +physics.analyzers.caloskimE.HITproducer: "cluster3DCryoE" +physics.analyzers.caloskimW.HITproducer: "cluster3DCryoW" diff --git a/fcl/reco/Stage1/mc/stage1_run2_icarus_MC.fcl b/fcl/reco/Stage1/mc/stage1_run2_icarus_MC.fcl index 0009c0806..0db3cffcb 100644 --- a/fcl/reco/Stage1/mc/stage1_run2_icarus_MC.fcl +++ b/fcl/reco/Stage1/mc/stage1_run2_icarus_MC.fcl @@ -118,6 +118,10 @@ services.message.destinations : limit: -1 reportEvery: 1 } + SimDriftElectrons: + { + limit: 0 + } } } } diff --git a/fcl/reco/Stage1/mc/stage1_run2_icarus_MC_simpledet.fcl b/fcl/reco/Stage1/mc/stage1_run2_icarus_MC_simpledet.fcl new file mode 100644 index 000000000..788f343ed --- /dev/null +++ b/fcl/reco/Stage1/mc/stage1_run2_icarus_MC_simpledet.fcl @@ -0,0 +1,6 @@ +#include "stage1_run2_icarus_MC.fcl" + +physics.producers.mcreco.SimChannelLabel: "shifted" +physics.analyzers.caloskimE.SimChannelproducer: "daq:simpleSC" +physics.analyzers.caloskimW.SimChannelproducer: "daq:simpleSC" +services.BackTrackerService.BackTracker.SimChannelModuleLabel: "daq:simpleSC" diff --git a/fcl/reco/Stage1/mc/stage1_run2_icarus_MC_wiremod.fcl b/fcl/reco/Stage1/mc/stage1_run2_icarus_MC_wiremod.fcl new file mode 100644 index 000000000..ec614e45a --- /dev/null +++ b/fcl/reco/Stage1/mc/stage1_run2_icarus_MC_wiremod.fcl @@ -0,0 +1,17 @@ +#include "stage1_run2_icarus_MC.fcl" + +# select all T0-tagged tracks +physics.analyzers.caloskimE.SelectionTools: [ + { + tool_type: TrackCaloSkimmerSelectClearCosmicMuon + RequireT0: true + } +] + +physics.analyzers.caloskimW.SelectionTools: [ + { + tool_type: TrackCaloSkimmerSelectClearCosmicMuon + RequireT0: true + } +] + diff --git a/fcl/reco/Stage1/overlay/stage1_run2_icarus_overlay_simpledet.fcl b/fcl/reco/Stage1/overlay/stage1_run2_icarus_overlay_simpledet.fcl new file mode 100644 index 000000000..4a8aafe51 --- /dev/null +++ b/fcl/reco/Stage1/overlay/stage1_run2_icarus_overlay_simpledet.fcl @@ -0,0 +1,6 @@ +#include "stage1_run2_icarus_overlay.fcl" + +physics.producers.mcreco.SimChannelLabel: "sedlite" +physics.analyzers.caloskimE.SimChannelproducer: "daq:simpleSC" +physics.analyzers.caloskimW.SimChannelproducer: "daq:simpleSC" +services.BackTrackerService.BackTracker.SimChannelModuleLabel: "daq:simpleSC" diff --git a/fcl/reco/Stage1/overlay/stage1_run2_icarus_overlay_wiremod.fcl b/fcl/reco/Stage1/overlay/stage1_run2_icarus_overlay_wiremod.fcl new file mode 100644 index 000000000..300430f78 --- /dev/null +++ b/fcl/reco/Stage1/overlay/stage1_run2_icarus_overlay_wiremod.fcl @@ -0,0 +1,4 @@ +#include "stage1_run2_icarus_MC_wiremod.fcl" + +#include "enable_overlay_stage1.fcl" + diff --git a/fcl/reco/wires/CMakeLists.txt b/fcl/reco/wires/CMakeLists.txt new file mode 100644 index 000000000..2bda0f610 --- /dev/null +++ b/fcl/reco/wires/CMakeLists.txt @@ -0,0 +1,3 @@ +cet_enable_asserts() + +install_fhicl() diff --git a/fcl/reco/wires/restorewires_icarus.fcl b/fcl/reco/wires/restorewires_icarus.fcl new file mode 100644 index 000000000..723c92e43 --- /dev/null +++ b/fcl/reco/wires/restorewires_icarus.fcl @@ -0,0 +1,60 @@ +# Configuration for running the Calibration NTupler +# on a stage-1 reco file +# +#include "services_common_icarus.fcl" +#include "wirechannelroiconverters_sbn.fcl" + +process_name: ntuple + +services: +{ + @table::icarus_wirecalibration_services +} + +#source is a root file +source: +{ + module_type: RootInput + maxEvents: 10 # Number of events to create + saveMemoryObjectThreshold: 0 +} + +# only do analysis +physics: +{ + + producers: { + channel2wire: @local::channelroitowire + } + + filters: {} + + analyzers: + { + } + + out: [rootOutput] + reco: [channel2wire] + trigger_paths: [reco] + end_paths: [out] +} + +physics.producers.channel2wire.WireModuleLabelVec: ["wire2channelroi2d:PHYSCRATEDATATPCEE", "wire2channelroi2d:PHYSCRATEDATATPCEW", "wire2channelroi2d:PHYSCRATEDATATPCWE", "wire2channelroi2d:PHYSCRATEDATATPCWW"] +physics.producers.channel2wire.OutInstanceLabelVec: ["PHYSCRATEDATATPCWW","PHYSCRATEDATATPCWE","PHYSCRATEDATATPCEW","PHYSCRATEDATATPCEE"] + +physics.analyzers.caloskimE.SelectEvents: [ ] +physics.analyzers.caloskimW.SelectEvents: [ ] +physics.analyzers.simpleLightAna.SelectEvents: [ ] +physics.analyzers.supera.SelectEvents: [ ] + +outputs: +{ + rootOutput: + { + module_type: RootOutput + dataTier: "reconstructed" + compressionLevel: 1 + saveMemoryObjectThreshold: 0 + fileName: "%ifb_%tc-%p.root" + } +} diff --git a/fcl/standard/CMakeLists.txt b/fcl/standard/CMakeLists.txt index 9714229ee..178294463 100644 --- a/fcl/standard/CMakeLists.txt +++ b/fcl/standard/CMakeLists.txt @@ -1,8 +1,5 @@ -# Install fcl files +cet_enable_asserts() -install_fhicl() - -# Also put a copy in the source tree. - -FILE(GLOB fcl_files *.fcl) -install_source( EXTRAS ${fcl_files} ) +add_subdirectory(mc) +add_subdirectory(data) +add_subdirectory(overlay) diff --git a/fcl/standard/data/CMakeLists.txt b/fcl/standard/data/CMakeLists.txt new file mode 100644 index 000000000..9714229ee --- /dev/null +++ b/fcl/standard/data/CMakeLists.txt @@ -0,0 +1,8 @@ +# Install fcl files + +install_fhicl() + +# Also put a copy in the source tree. + +FILE(GLOB fcl_files *.fcl) +install_source( EXTRAS ${fcl_files} ) diff --git a/fcl/standard/standard_data_caf_icarus.fcl b/fcl/standard/data/standard_data_caf_icarus.fcl similarity index 100% rename from fcl/standard/standard_data_caf_icarus.fcl rename to fcl/standard/data/standard_data_caf_icarus.fcl diff --git a/fcl/standard/standard_data_larcv_icarus.fcl b/fcl/standard/data/standard_data_larcv_icarus.fcl similarity index 100% rename from fcl/standard/standard_data_larcv_icarus.fcl rename to fcl/standard/data/standard_data_larcv_icarus.fcl diff --git a/fcl/standard/data/standard_data_stage0_icarus.fcl b/fcl/standard/data/standard_data_stage0_icarus.fcl new file mode 100644 index 000000000..34926a6ea --- /dev/null +++ b/fcl/standard/data/standard_data_stage0_icarus.fcl @@ -0,0 +1 @@ +#include "stage0_run2_wcdnn_icarus.fcl" diff --git a/fcl/standard/data/standard_data_stage1_icarus.fcl b/fcl/standard/data/standard_data_stage1_icarus.fcl new file mode 100644 index 000000000..99c103424 --- /dev/null +++ b/fcl/standard/data/standard_data_stage1_icarus.fcl @@ -0,0 +1 @@ +#include "stage1_run2_icarus.fcl" diff --git a/fcl/standard/data/standard_data_stage1larcv_icarus.fcl b/fcl/standard/data/standard_data_stage1larcv_icarus.fcl new file mode 100644 index 000000000..074299416 --- /dev/null +++ b/fcl/standard/data/standard_data_stage1larcv_icarus.fcl @@ -0,0 +1 @@ +#include "stage1_run2_larcv_icarus.fcl" diff --git a/fcl/standard/mc/CMakeLists.txt b/fcl/standard/mc/CMakeLists.txt new file mode 100644 index 000000000..9714229ee --- /dev/null +++ b/fcl/standard/mc/CMakeLists.txt @@ -0,0 +1,8 @@ +# Install fcl files + +install_fhicl() + +# Also put a copy in the source tree. + +FILE(GLOB fcl_files *.fcl) +install_source( EXTRAS ${fcl_files} ) diff --git a/fcl/standard/standard_mc_all_detsim_icarus.fcl b/fcl/standard/mc/standard_mc_all_detsim_icarus.fcl similarity index 100% rename from fcl/standard/standard_mc_all_detsim_icarus.fcl rename to fcl/standard/mc/standard_mc_all_detsim_icarus.fcl diff --git a/fcl/standard/standard_mc_all_larcv_icarus.fcl b/fcl/standard/mc/standard_mc_all_larcv_icarus.fcl similarity index 100% rename from fcl/standard/standard_mc_all_larcv_icarus.fcl rename to fcl/standard/mc/standard_mc_all_larcv_icarus.fcl diff --git a/fcl/standard/mc/standard_mc_all_stage0_icarus.fcl b/fcl/standard/mc/standard_mc_all_stage0_icarus.fcl new file mode 100644 index 000000000..c90fdc3b2 --- /dev/null +++ b/fcl/standard/mc/standard_mc_all_stage0_icarus.fcl @@ -0,0 +1 @@ +#include "stage0_run2_wcdnn_icarus_mc.fcl" diff --git a/fcl/standard/mc/standard_mc_all_stage1_icarus.fcl b/fcl/standard/mc/standard_mc_all_stage1_icarus.fcl new file mode 100644 index 000000000..7f5fe82b0 --- /dev/null +++ b/fcl/standard/mc/standard_mc_all_stage1_icarus.fcl @@ -0,0 +1 @@ +#include "stage1_run2_icarus_MC.fcl" diff --git a/fcl/standard/standard_mc_beamcosmics_caf_icarus.fcl b/fcl/standard/mc/standard_mc_beamcosmics_caf_icarus.fcl similarity index 100% rename from fcl/standard/standard_mc_beamcosmics_caf_icarus.fcl rename to fcl/standard/mc/standard_mc_beamcosmics_caf_icarus.fcl diff --git a/fcl/standard/mc/standard_mc_beamcosmics_g4_icarus.fcl b/fcl/standard/mc/standard_mc_beamcosmics_g4_icarus.fcl new file mode 100644 index 000000000..a42168087 --- /dev/null +++ b/fcl/standard/mc/standard_mc_beamcosmics_g4_icarus.fcl @@ -0,0 +1 @@ +#include "larg4_icarus_cosmics_sce.fcl" diff --git a/fcl/standard/standard_mc_intime_caf_icarus.fcl b/fcl/standard/mc/standard_mc_intime_caf_icarus.fcl similarity index 100% rename from fcl/standard/standard_mc_intime_caf_icarus.fcl rename to fcl/standard/mc/standard_mc_intime_caf_icarus.fcl diff --git a/fcl/standard/mc/standard_mc_intime_g4_icarus.fcl b/fcl/standard/mc/standard_mc_intime_g4_icarus.fcl new file mode 100644 index 000000000..e3695ae4b --- /dev/null +++ b/fcl/standard/mc/standard_mc_intime_g4_icarus.fcl @@ -0,0 +1 @@ +#include "larg4_icarus_intime_sce.fcl" diff --git a/fcl/standard/standard_mc_mpvmpr_stage1larcv_icarus.fcl b/fcl/standard/mc/standard_mc_mpvmpr_stage1larcv_icarus.fcl similarity index 100% rename from fcl/standard/standard_mc_mpvmpr_stage1larcv_icarus.fcl rename to fcl/standard/mc/standard_mc_mpvmpr_stage1larcv_icarus.fcl diff --git a/fcl/standard/overlay/CMakeLists.txt b/fcl/standard/overlay/CMakeLists.txt new file mode 100644 index 000000000..9714229ee --- /dev/null +++ b/fcl/standard/overlay/CMakeLists.txt @@ -0,0 +1,8 @@ +# Install fcl files + +install_fhicl() + +# Also put a copy in the source tree. + +FILE(GLOB fcl_files *.fcl) +install_source( EXTRAS ${fcl_files} ) diff --git a/fcl/standard/overlay/standard_overlay_caf_icarus.fcl b/fcl/standard/overlay/standard_overlay_caf_icarus.fcl new file mode 100644 index 000000000..ff0de4039 --- /dev/null +++ b/fcl/standard/overlay/standard_overlay_caf_icarus.fcl @@ -0,0 +1 @@ +#include "cafmakerjob_icarus_detsim2d_systtools_and_fluxwgt_overlay.fcl" diff --git a/fcl/standard/overlay/standard_overlay_detsim_icarus.fcl b/fcl/standard/overlay/standard_overlay_detsim_icarus.fcl new file mode 100644 index 000000000..d5a62b5cc --- /dev/null +++ b/fcl/standard/overlay/standard_overlay_detsim_icarus.fcl @@ -0,0 +1 @@ +#include "detsim_2d_icarus_refactored_overlay.fcl" diff --git a/fcl/standard/overlay/standard_overlay_overlay_icarus.fcl b/fcl/standard/overlay/standard_overlay_overlay_icarus.fcl new file mode 100644 index 000000000..6d70a1ace --- /dev/null +++ b/fcl/standard/overlay/standard_overlay_overlay_icarus.fcl @@ -0,0 +1 @@ +#include "overlay_waveforms.fcl" diff --git a/fcl/standard/overlay/standard_overlay_stage0_icarus.fcl b/fcl/standard/overlay/standard_overlay_stage0_icarus.fcl new file mode 100644 index 000000000..58de7ed2f --- /dev/null +++ b/fcl/standard/overlay/standard_overlay_stage0_icarus.fcl @@ -0,0 +1 @@ +#include "stage0_run2_wcdnn_icarus_overlay.fcl" diff --git a/fcl/standard/overlay/standard_overlay_stage1_icarus.fcl b/fcl/standard/overlay/standard_overlay_stage1_icarus.fcl new file mode 100644 index 000000000..2ec9c1f23 --- /dev/null +++ b/fcl/standard/overlay/standard_overlay_stage1_icarus.fcl @@ -0,0 +1 @@ +#include "stage1_run2_icarus_overlay.fcl" diff --git a/fcl/standard/standard_data_stage0_icarus.fcl b/fcl/standard/standard_data_stage0_icarus.fcl deleted file mode 100644 index 655847775..000000000 --- a/fcl/standard/standard_data_stage0_icarus.fcl +++ /dev/null @@ -1 +0,0 @@ -#include "stage0_run2_icarus.fcl" diff --git a/fcl/standard/standard_data_stage1_icarus.fcl b/fcl/standard/standard_data_stage1_icarus.fcl deleted file mode 100644 index 88289d934..000000000 --- a/fcl/standard/standard_data_stage1_icarus.fcl +++ /dev/null @@ -1 +0,0 @@ -#include "stage1_run2_1d_icarus.fcl" diff --git a/fcl/standard/standard_data_stage1larcv_icarus.fcl b/fcl/standard/standard_data_stage1larcv_icarus.fcl deleted file mode 100644 index be9e0d00d..000000000 --- a/fcl/standard/standard_data_stage1larcv_icarus.fcl +++ /dev/null @@ -1 +0,0 @@ -#include "stage1_run2_1d_larcv_icarus.fcl" diff --git a/fcl/standard/standard_mc_all_stage0_icarus.fcl b/fcl/standard/standard_mc_all_stage0_icarus.fcl deleted file mode 100644 index feb8aca63..000000000 --- a/fcl/standard/standard_mc_all_stage0_icarus.fcl +++ /dev/null @@ -1 +0,0 @@ -#include "stage0_run2_icarus_mc.fcl" diff --git a/fcl/standard/standard_mc_all_stage1_icarus.fcl b/fcl/standard/standard_mc_all_stage1_icarus.fcl deleted file mode 100644 index 86d4b0eba..000000000 --- a/fcl/standard/standard_mc_all_stage1_icarus.fcl +++ /dev/null @@ -1 +0,0 @@ -#include "stage1_run2_1d_icarus_MC.fcl" diff --git a/fcl/standard/standard_mc_all_stage1larcv_icarus.fcl b/fcl/standard/standard_mc_all_stage1larcv_icarus.fcl deleted file mode 100644 index caf161ca4..000000000 --- a/fcl/standard/standard_mc_all_stage1larcv_icarus.fcl +++ /dev/null @@ -1 +0,0 @@ -#include "stage1_run2_1d_larcv_icarus_MC.fcl" diff --git a/fcl/standard/standard_mc_beamcosmics_g4_icarus.fcl b/fcl/standard/standard_mc_beamcosmics_g4_icarus.fcl deleted file mode 100644 index 687f1fe35..000000000 --- a/fcl/standard/standard_mc_beamcosmics_g4_icarus.fcl +++ /dev/null @@ -1 +0,0 @@ -#include "larg4_icarus_cosmics_sce_2d_drift.fcl" diff --git a/fcl/standard/standard_mc_intime_g4_icarus.fcl b/fcl/standard/standard_mc_intime_g4_icarus.fcl deleted file mode 100644 index 05c30a5c9..000000000 --- a/fcl/standard/standard_mc_intime_g4_icarus.fcl +++ /dev/null @@ -1 +0,0 @@ -#include "larg4_icarus_intime_sce_2d_drift.fcl" diff --git a/fcl/supera/supera_icarus_MC_all_cryo_PMT_CRT_overlay.fcl b/fcl/supera/supera_icarus_MC_all_cryo_PMT_CRT_overlay.fcl new file mode 100644 index 000000000..bf92f117f --- /dev/null +++ b/fcl/supera/supera_icarus_MC_all_cryo_PMT_CRT_overlay.fcl @@ -0,0 +1,199 @@ +ProcessDriver: { + + Verbosity: 2 + EnableFilter: true + RandomAccess: false + ProcessType: ["SuperaMCTruth","SuperaBBoxInteraction","SuperaMCParticleCluster","SuperaSimEnergyDeposit","SuperaSpacePoint","SuperaSpacePoint","Tensor3DFromCluster3D","CombineTensor3D","ThresholdTensor3D","CombineTensor3D","ParticleCorrector","EmptyTensorFilter","RescaleChargeTensor3D","RescaleChargeTensor3D","SuperaOptical","SuperaCRT"] + ProcessName: ["MultiPartVrtx","SuperaBBoxInteraction","SuperaMCParticleCluster","SuperaSimEnergyDeposit","SuperaSpacePointCryoE","SuperaSpacePointCryoW","Tensor3DFromCluster3D","CombineTensor3DGhost","ThresholdTensor3D","CombineTensor3D","ParticleCorrector","EmptyTensorFilter","RescaleChargeTensor3DCryoE","RescaleChargeTensor3DCryoW","SuperaOptical","SuperaCRT"] + + IOManager: { + Verbosity: 2 + Name: "IOManager" + IOMode: 1 + OutFileName: "out_test.root" + InputFiles: [] + InputDirs: [] + StoreOnlyType: [] + StoreOnlyName: [] + } + + ProcessList: { + SuperaCRT: { + CRTHitProducers: ["overlayCRTHit"] + CRTHitOutputs: ["crthit"] + } + + SuperaOptical: { + OpFlashProducers: ["opflashCryoE","opflashCryoW"] + OpFlashOutputs: ["cryoE","cryoW"] + } + + EmptyTensorFilter: { + Tensor3DProducerList: ["pcluster_semantics_ghost"] + MinVoxel3DCountList: [1] + } + + RescaleChargeTensor3DCryoE: { + HitKeyProducerList: ["reco_cryoE_hit_key0","reco_cryoE_hit_key1","reco_cryoE_hit_key2"] + HitChargeProducerList: ["reco_cryoE_hit_charge0","reco_cryoE_hit_charge1","reco_cryoE_hit_charge2"] + OutputProducer: "reco_cryoE_rescaled" + ReferenceProducer: "pcluster" + } + + RescaleChargeTensor3DCryoW: { + HitKeyProducerList: ["reco_cryoW_hit_key0","reco_cryoW_hit_key1","reco_cryoW_hit_key2"] + HitChargeProducerList: ["reco_cryoW_hit_charge0","reco_cryoW_hit_charge1","reco_cryoW_hit_charge2"] + OutputProducer: "reco_cryoW_rescaled" + ReferenceProducer: "pcluster" + } + + ThresholdTensor3D: { # fill with ghost value (5) + TargetProducer: "pcluster_semantics_ghost" + OutputProducer: "pcluster_semantics_ghost" + PaintValue: 5 + } + + CombineTensor3DGhost: { # Combine voxels of cryoE and cryoW + OutputProducer: "pcluster_semantics_ghost" + Tensor3DProducers: ["reco_cryoE","reco_cryoW"] + PoolType: 0 + } + + CombineTensor3D: { + Tensor3DProducers: ["pcluster_semantics_ghost","pcluster_semantics"] + OutputProducer: "pcluster_semantics_ghost" + PoolType: 0 + } + + SuperaMCParticleCluster: { + OutputLabel: "pcluster" + LArMCParticleProducer: "simplemerge" + LArMCShowerProducer: "mcreco" + LArMCTrackProducer: "mcreco" + #LArMCMiniPartProducer: #"largeant" + DeltaSize: 10 + #LArSimEnergyDepositProducer: "largeant TPCActive" + LArSimEnergyDepositLiteProducer: "filtersed" + Meta3DFromCluster3D: "mcst" + Meta2DFromTensor2D: "" + Verbosity: 2 + UseSimEnergyDeposit: false #true + UseSimEnergyDepositLite: false #true + UseSimEnergyDepositPoints: false #true + UseOrigTrackID: true + CryostatList: [0,0,0,0,1,1,1,1] + TPCList: [0,1,2,3,0,1,2,3] + PlaneList: [] + #SemanticPriority: [2,1,0,3,4] # 0-4 for shower track michel delta LE-scattering + SemanticPriority: [1,2,0,3,4] # 0-4 for shower track michel delta LE-scattering + CheckParticleValidity: false #set false, but this needs to be checked later + + SuperaTrue2RecoVoxel3D: { + DebugMode: false + Verbosity: 2 + Meta3DFromCluster3D: "pcluster" + #LArSimChProducer: "largeant" + LArSimChProducer: "merge" + LArSpacePointProducers: ["cluster3DCryoE","cluster3DCryoW"] + TwofoldMatching: true + UseTruePosition: true + HitThresholdNe: 100 + HitWindowTicks: 15 #5 + HitWindowNSigma: 3 + HitPeakFinding: false + PostAveraging: true + PostAveragingThreshold_cm: 0.425 + DumpToCSV: false + RecoChargeRange: [-1000,50000] + VoxelDistanceThreshold: 3. + UseOrigTrackID: true + } + } + + MultiPartVrtx: { + Verbosity: 2 + #LArMCTruthProducer: "generator" + MCTruthProducers: ["generator","cosmgen"] + OutParticleLabel: "mpv" + Origin: 0 + } + + SuperaBBoxInteraction: { + Verbosity: 2 + LArMCTruthProducer: "generator" + #LArSimEnergyDepositProducer: "largeant TPCActive" + LArSimEnergyDepositLiteProducer: "filtersed" + UseSEDLite: true + Origin: 0 + Cluster3DLabels: ["mcst","pcluster","sed","masked_true2reco"] + Tensor3DLabels: ["reco_cryoE","reco_cryoW","pcluster_index","masked_true"] + #BBoxSize: [230.4,230.4,230.4] + BBoxSize: [1843.2,1843.2,1843.2] # Covers the whole detector with the smallest possible cube -> yields 6144 = 1024*6 px + #BBoxBottom: [-460.8,-230.4,-921.6] + #BBoxSize: [1789.902,1789.902,1789.902] + #BBoxBottom: [-358.49,-181.86,-894.951] # geometry from icarus_complete_20210527_no_overburden.gdml + #BBoxBottom: [-412.788,-181.86,-894.951] # geometry from icarus_complete_20210527_no_overburden.gdml taking readout window into account + # 358.49+340*1.6/10 = 412.89 + BBoxBottom: [-412.89,-181.86,-894.951] # geometry from icarus_complete_20210527_no_overburden.gdml taking readout window into account + UseFixedBBox: true + VoxelSize: [0.3,0.3,0.3] + CryostatList: [0,0,0,0,1,1,1,1] + TPCList: [0,1,2,3,0,1,2,3] + } + + SuperaSimEnergyDeposit: { + Verbosity: 2 + #LArSimEnergyDepositProducer: "largeant TPCActive" + LArSimEnergyDepositLiteProducer: "filtersed" + LArMCShowerProducer: "mcreco" + UseSEDLite: true + ParticleProducer: "pcluster" + OutCluster3DLabel: "sed" + StoreLength: false + StoreCharge: false + StorePhoton: false + StoreDiffTime: false + StoreAbsTime: true + StoreDEDX: false + TPCList: [0,1,2,3,0,1,2,3] + CryostatList: [0,0,0,0,1,1,1,1] + } + + ParticleCorrector: { + Verbosity: 2 + Cluster3DProducer: "pcluster_highE" + ParticleProducer: "pcluster" + OutputProducer: "corrected" + VoxelMinValue: -1000 + } + + + Tensor3DFromCluster3D: { + Verbosity: 2 + Cluster3DProducerList: ["pcluster","sed"] + OutputProducerList: ["pcluster","sed"] + PITypeList: [1,1] + FixedPIList: [0.,0.] + } + + SuperaSpacePointCryoE: { + Verbosity: 2 + SpacePointProducers: ["cluster3DCryoE"] + OutputLabel: "reco_cryoE" + DropOutput: ["hit_amp","hit_time","hit_rms","hit_mult","nhits","occupancy"] + StoreWireInfo: true + RecoChargeRange: [-1000, 50000] + } + + SuperaSpacePointCryoW: { + Verbosity: 2 + SpacePointProducers: ["cluster3DCryoW"] + OutputLabel: "reco_cryoW" + DropOutput: ["hit_amp","hit_time","hit_rms","hit_mult","nhits","occupancy"] + StoreWireInfo: true + RecoChargeRange: [-1000, 50000] + } + + } +} + diff --git a/fcl/supera/supera_icarus_MC_all_cryo_PMT_CRT_v10.fcl b/fcl/supera/supera_icarus_MC_all_cryo_PMT_CRT_v10.fcl new file mode 100644 index 000000000..0a6b52ed5 --- /dev/null +++ b/fcl/supera/supera_icarus_MC_all_cryo_PMT_CRT_v10.fcl @@ -0,0 +1,199 @@ +ProcessDriver: { + + Verbosity: 2 + EnableFilter: true + RandomAccess: false + ProcessType: ["SuperaMCTruth","SuperaBBoxInteraction","SuperaMCParticleCluster","SuperaSimEnergyDeposit","SuperaSpacePoint","SuperaSpacePoint","Tensor3DFromCluster3D","CombineTensor3D","ThresholdTensor3D","CombineTensor3D","ParticleCorrector","EmptyTensorFilter","RescaleChargeTensor3D","RescaleChargeTensor3D","SuperaOptical","SuperaCRT"] + ProcessName: ["MultiPartVrtx","SuperaBBoxInteraction","SuperaMCParticleCluster","SuperaSimEnergyDeposit","SuperaSpacePointCryoE","SuperaSpacePointCryoW","Tensor3DFromCluster3D","CombineTensor3DGhost","ThresholdTensor3D","CombineTensor3D","ParticleCorrector","EmptyTensorFilter","RescaleChargeTensor3DCryoE","RescaleChargeTensor3DCryoW","SuperaOptical","SuperaCRT"] + + IOManager: { + Verbosity: 2 + Name: "IOManager" + IOMode: 1 + OutFileName: "out_test.root" + InputFiles: [] + InputDirs: [] + StoreOnlyType: [] + StoreOnlyName: [] + } + + ProcessList: { + SuperaCRT: { + CRTHitProducers: ["crthit"] + CRTHitOutputs: ["crthit"] + } + + SuperaOptical: { + OpFlashProducers: ["opflashCryoE","opflashCryoW"] + OpFlashOutputs: ["cryoE","cryoW"] + } + + EmptyTensorFilter: { + Tensor3DProducerList: ["pcluster_semantics_ghost"] + MinVoxel3DCountList: [1] + } + + RescaleChargeTensor3DCryoE: { + HitKeyProducerList: ["reco_cryoE_hit_key0","reco_cryoE_hit_key1","reco_cryoE_hit_key2"] + HitChargeProducerList: ["reco_cryoE_hit_charge0","reco_cryoE_hit_charge1","reco_cryoE_hit_charge2"] + OutputProducer: "reco_cryoE_rescaled" + ReferenceProducer: "pcluster" + } + + RescaleChargeTensor3DCryoW: { + HitKeyProducerList: ["reco_cryoW_hit_key0","reco_cryoW_hit_key1","reco_cryoW_hit_key2"] + HitChargeProducerList: ["reco_cryoW_hit_charge0","reco_cryoW_hit_charge1","reco_cryoW_hit_charge2"] + OutputProducer: "reco_cryoW_rescaled" + ReferenceProducer: "pcluster" + } + + ThresholdTensor3D: { # fill with ghost value (5) + TargetProducer: "pcluster_semantics_ghost" + OutputProducer: "pcluster_semantics_ghost" + PaintValue: 5 + } + + CombineTensor3DGhost: { # Combine voxels of cryoE and cryoW + OutputProducer: "pcluster_semantics_ghost" + Tensor3DProducers: ["reco_cryoE","reco_cryoW"] + PoolType: 0 + } + + CombineTensor3D: { + Tensor3DProducers: ["pcluster_semantics_ghost","pcluster_semantics"] + OutputProducer: "pcluster_semantics_ghost" + PoolType: 0 + } + + SuperaMCParticleCluster: { + OutputLabel: "pcluster" + LArMCParticleProducer: "simplemerge" + LArMCShowerProducer: "mcreco" + LArMCTrackProducer: "mcreco" + #LArMCMiniPartProducer: #"largeant" + DeltaSize: 10 + #LArSimEnergyDepositProducer: "largeant TPCActive" + LArSimEnergyDepositLiteProducer: "filtersed" + Meta3DFromCluster3D: "mcst" + Meta2DFromTensor2D: "" + Verbosity: 2 + UseSimEnergyDeposit: false #true + UseSimEnergyDepositLite: false #true + UseSimEnergyDepositPoints: false #true + UseOrigTrackID: true + CryostatList: [0,0,0,0,1,1,1,1] + TPCList: [0,1,2,3,0,1,2,3] + PlaneList: [] + #SemanticPriority: [2,1,0,3,4] # 0-4 for shower track michel delta LE-scattering + SemanticPriority: [1,2,0,3,4] # 0-4 for shower track michel delta LE-scattering + CheckParticleValidity: false #set false, but this needs to be checked later + + SuperaTrue2RecoVoxel3D: { + DebugMode: false + Verbosity: 2 + Meta3DFromCluster3D: "pcluster" + #LArSimChProducer: "largeant" + LArSimChProducer: "merge" + LArSpacePointProducers: ["cluster3DCryoE","cluster3DCryoW"] + TwofoldMatching: true + UseTruePosition: true + HitThresholdNe: 100 + HitWindowTicks: 15 #5 + HitWindowNSigma: 3 + HitPeakFinding: false + PostAveraging: true + PostAveragingThreshold_cm: 0.425 + DumpToCSV: false + RecoChargeRange: [-1000,50000] + VoxelDistanceThreshold: 3. + UseOrigTrackID: true + } + } + + MultiPartVrtx: { + Verbosity: 2 + #LArMCTruthProducer: "generator" + MCTruthProducers: ["generator","cosmgen"] + OutParticleLabel: "mpv" + Origin: 0 + } + + SuperaBBoxInteraction: { + Verbosity: 2 + LArMCTruthProducer: "generator" + #LArSimEnergyDepositProducer: "largeant TPCActive" + LArSimEnergyDepositLiteProducer: "filtersed" + UseSEDLite: true + Origin: 0 + Cluster3DLabels: ["mcst","pcluster","sed","masked_true2reco"] + Tensor3DLabels: ["reco_cryoE","reco_cryoW","pcluster_index","masked_true"] + #BBoxSize: [230.4,230.4,230.4] + BBoxSize: [1843.2,1843.2,1843.2] # Covers the whole detector with the smallest possible cube -> yields 6144 = 1024*6 px + #BBoxBottom: [-460.8,-230.4,-921.6] + #BBoxSize: [1789.902,1789.902,1789.902] + #BBoxBottom: [-358.49,-181.86,-894.951] # geometry from icarus_complete_20210527_no_overburden.gdml + #BBoxBottom: [-412.788,-181.86,-894.951] # geometry from icarus_complete_20210527_no_overburden.gdml taking readout window into account + # 358.49+340*1.6/10 = 412.89 + BBoxBottom: [-412.89,-181.86,-894.951] # geometry from icarus_complete_20210527_no_overburden.gdml taking readout window into account + UseFixedBBox: true + VoxelSize: [0.3,0.3,0.3] + CryostatList: [0,0,0,0,1,1,1,1] + TPCList: [0,1,2,3,0,1,2,3] + } + + SuperaSimEnergyDeposit: { + Verbosity: 2 + #LArSimEnergyDepositProducer: "largeant TPCActive" + LArSimEnergyDepositLiteProducer: "filtersed" + LArMCShowerProducer: "mcreco" + UseSEDLite: true + ParticleProducer: "pcluster" + OutCluster3DLabel: "sed" + StoreLength: false + StoreCharge: false + StorePhoton: false + StoreDiffTime: false + StoreAbsTime: true + StoreDEDX: false + TPCList: [0,1,2,3,0,1,2,3] + CryostatList: [0,0,0,0,1,1,1,1] + } + + ParticleCorrector: { + Verbosity: 2 + Cluster3DProducer: "pcluster_highE" + ParticleProducer: "pcluster" + OutputProducer: "corrected" + VoxelMinValue: -1000 + } + + + Tensor3DFromCluster3D: { + Verbosity: 2 + Cluster3DProducerList: ["pcluster","sed"] + OutputProducerList: ["pcluster","sed"] + PITypeList: [1,1] + FixedPIList: [0.,0.] + } + + SuperaSpacePointCryoE: { + Verbosity: 2 + SpacePointProducers: ["cluster3DCryoE"] + OutputLabel: "reco_cryoE" + DropOutput: ["hit_amp","hit_time","hit_rms","hit_mult","nhits","occupancy"] + StoreWireInfo: true + RecoChargeRange: [-1000, 50000] + } + + SuperaSpacePointCryoW: { + Verbosity: 2 + SpacePointProducers: ["cluster3DCryoW"] + OutputLabel: "reco_cryoW" + DropOutput: ["hit_amp","hit_time","hit_rms","hit_mult","nhits","occupancy"] + StoreWireInfo: true + RecoChargeRange: [-1000, 50000] + } + + } +} + diff --git a/icaruscode/Analysis/anaraw_purity_icarus_DQM.fcl b/icaruscode/Analysis/anaraw_purity_icarus_DQM.fcl index fe7c20962..c8411ef50 100644 --- a/icaruscode/Analysis/anaraw_purity_icarus_DQM.fcl +++ b/icaruscode/Analysis/anaraw_purity_icarus_DQM.fcl @@ -2,7 +2,6 @@ #include "singles.fcl" #include "larproperties.fcl" #include "magfield_larsoft.fcl" -#include "largeantmodules.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" #include "reco_icarus.fcl" diff --git a/icaruscode/Analysis/anaraw_purity_icarus_DQM_multipletpc.fcl b/icaruscode/Analysis/anaraw_purity_icarus_DQM_multipletpc.fcl index f38b543bd..22cbb3803 100644 --- a/icaruscode/Analysis/anaraw_purity_icarus_DQM_multipletpc.fcl +++ b/icaruscode/Analysis/anaraw_purity_icarus_DQM_multipletpc.fcl @@ -4,7 +4,6 @@ #include "magfield_larsoft.fcl" #include "hitalgorithms.fcl" #include "clustermodules.fcl" -#include "largeantmodules.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" #include "reco_icarus.fcl" diff --git a/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_noob.fcl b/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_noob.fcl index 11fad6336..85b9b5a0d 100644 --- a/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_noob.fcl +++ b/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_noob.fcl @@ -1,5 +1,4 @@ #include "services_icarus_simulation.fcl" -#include "largeantmodules_icarus.fcl" #include "mcreco.fcl" process_name: G4 diff --git a/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_ob.fcl b/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_ob.fcl index 1fdc8445a..a1094c23a 100644 --- a/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_ob.fcl +++ b/icaruscode/Analysis/overburden/standard_g4_icarus_21apr21_ob.fcl @@ -1,5 +1,4 @@ #include "services_icarus_simulation.fcl" -#include "largeantmodules_icarus.fcl" #include "mcreco.fcl" process_name: G4 diff --git a/icaruscode/Analysis/trigger/CMakeLists.txt b/icaruscode/Analysis/trigger/CMakeLists.txt index 93695d925..5a5c9e3af 100644 --- a/icaruscode/Analysis/trigger/CMakeLists.txt +++ b/icaruscode/Analysis/trigger/CMakeLists.txt @@ -77,6 +77,7 @@ cet_build_plugin(TimeTrackTreeStorageCRT art::module icaruscode_CRTUtils icaruscode::PMT_Algorithms icaruscode::Decode_DataProducts + sbnalg::Utilities larcore::Geometry_Geometry_service larcorealg::Geometry lardataobj::AnalysisBase diff --git a/icaruscode/Analysis/trigger/TimeTrackTreeStorageCRT_module.cc b/icaruscode/Analysis/trigger/TimeTrackTreeStorageCRT_module.cc index 1cfa533e5..7aca675ce 100644 --- a/icaruscode/Analysis/trigger/TimeTrackTreeStorageCRT_module.cc +++ b/icaruscode/Analysis/trigger/TimeTrackTreeStorageCRT_module.cc @@ -17,7 +17,7 @@ #include "icaruscode/Utilities/TrajectoryUtils.h" #include "icaruscode/Utilities/ArtAssociationCaches.h" // OneToOneAssociationCache #include "icarusalg/Utilities/TrackTimeInterval.h" -#include "icarusalg/Utilities/AssnsCrosser.h" +#include "sbnalg/Utilities/AssnsCrosser.h" #include "sbnobj/Common/CRT/CRTHit.hh" #include "sbnobj/Common/Trigger/ExtraTriggerInfo.h" @@ -697,7 +697,7 @@ void sbn::TimeTrackTreeStorage::analyze(art::Event const& e) art::FindOneP TrackT0s(tracks,e,fT0selProducer); // t0 from TPC (cathode crossing tracks) - icarus::ns::util::AssnsCrosser const + sbn::ns::util::AssnsCrosser const TrackTPCt0s{ e, fPFPproducer, fT0Producer }; // optical flashes diff --git a/icaruscode/CRT/CRTDataAnalysis_module.cc b/icaruscode/CRT/CRTDataAnalysis_module.cc index 2a639fb96..bcfa376b9 100644 --- a/icaruscode/CRT/CRTDataAnalysis_module.cc +++ b/icaruscode/CRT/CRTDataAnalysis_module.cc @@ -82,48 +82,41 @@ namespace crt { public: struct Config { - // Save some typing: using Name = fhicl::Name; using Comment = fhicl::Comment; - - fhicl::Atom CRTHitLabel { Name("CRTHitLabel"), Comment("tag of the input data product with reconstructed CRT hits") }; - fhicl::Atom CRTDAQLabel { Name("CRTDAQLabel"), Comment("tag of the input data product with calibrated CRT data") }; - fhicl::Atom TriggerLabel { Name("TriggerLabel"), - Comment("Label for the Trigger fragment label") - }; + Comment("Label for the Trigger fragment label") + }; fhicl::Atom CRTPMTLabel { - Name("CRTPMTLabel"), - Comment("Label for the CRTPMT Matched variables from the crtpmt data product") - }; + Name("CRTPMTLabel"), + Comment("Label for the CRTPMT Matched variables from the crtpmt data product") + }; fhicl::Atom QPed { - Name("QPed"), - Comment("Pedestal offset [ADC]") - }; + Name("QPed"), + Comment("Pedestal offset [ADC]") + }; fhicl::Atom QSlope { - Name("QSlope"), - Comment("Pedestal slope [ADC/photon]") - }; - + Name("QSlope"), + Comment("Pedestal slope [ADC/photon]") + }; fhicl::Atom PEThresh { - Name("PEThresh"), - Comment("threshold in photoelectrons above which charge amplitudes used in hit reco") - }; - + Name("PEThresh"), + Comment("threshold in photoelectrons above which charge amplitudes used in hit reco") + }; fhicl::Atom CrtWindow { - Name("CrtWindow"), - Comment("window for looking data [ns]") - }; + Name("CrtWindow"), + Comment("window for looking data [ns]") + }; }; // Config using Parameters = art::EDAnalyzer::Table; @@ -209,6 +202,8 @@ namespace crt { vector> fDetPDG; /// signal inducing particle(s)' PDG code //CRT hit product vars + int fHitRun; + int fHitSubRun; int fHitEvent; float fXHit; ///< reconstructed X position of CRT hit (cm) float fYHit; ///< reconstructed Y position of CRT hit (cm) @@ -354,7 +349,7 @@ namespace crt { fHitNtuple = tfs->make("HitTree", "MyCRTHit"); fCRTPMTNtuple = tfs->make("CRTPMTTree", "MyCRTPMTMatch"); - // Define the branches of our DetSim n-tuple + // Define the branches of our CRTData (DAQTree) ntuples fDAQNtuple->Branch("event", &fDetEvent, "event/I"); fDAQNtuple->Branch("run", &fDetRun, "run/I"); fDAQNtuple->Branch("subrun", &fDetSubRun, "subrun/I"); @@ -371,10 +366,12 @@ namespace crt { fDAQNtuple->Branch("subSys", &fDetSubSys, "subSys/I"); fDAQNtuple->Branch("gate_type", &m_gate_type, "gate_type/b"); fDAQNtuple->Branch("gate_start_timestamp", &m_gate_start_timestamp, "gate_start_timestamp/l"); + fDAQNtuple->Branch("trigger_timestamp", &m_trigger_timestamp, "trigger_timestamp/l"); + - // Define the branches of our SimHit n-tuple - fHitNtuple->Branch("run", &fDetRun, "run/I"); - fHitNtuple->Branch("subrun", &fDetSubRun, "subrun/I"); + // Define the branches of our CRTHits (HitTree) ntuples + fHitNtuple->Branch("run", &fHitRun, "run/I"); + fHitNtuple->Branch("subrun", &fHitSubRun, "subrun/I"); fHitNtuple->Branch("event", &fHitEvent, "event/I"); fHitNtuple->Branch("nHit", &fNHit, "nHit/I"); fHitNtuple->Branch("x", &fXHit, "x/F"); @@ -459,7 +456,7 @@ namespace crt { art::Handle trigger_handle; event.getByLabel( fTriggerLabel, trigger_handle ); if( trigger_handle.isValid() ) { - sbn::triggerSource bit = trigger_handle->sourceType; + sbn::triggerSource bit = trigger_handle->sourceType; m_gate_type = value(bit); m_gate_name = bitName(bit); m_trigger_timestamp = trigger_handle->triggerTimestamp; @@ -468,7 +465,7 @@ namespace crt { } else{ - mf::LogError("CRTDataAnalysis") << "No raw::Trigger associated to label: " << fTriggerLabel.label() << "\n" ; + mf::LogError("CRTDataAnalysis") << "No raw::Trigger associated to label: " << fTriggerLabel.label() << "\n" ; } } else { @@ -498,39 +495,33 @@ namespace crt { /// Here t0 - trigger time -ve, only adding 1s makes the value +ve or -ve // if (std::fabs(int64_t(crtList[febdat_i]->fTs0 - m_trigger_timestamp) + 1e9) > fCrtWindow) continue; if ( type == 'm'){ - for(int chan=0; chan<32; chan++) { - std::pair const chg_cal = fChannelMap->getSideCRTCalibrationMap((int)crtList[febdat_i]->fMac5,chan); - float pe = (crtList[febdat_i]->fAdc[chan]-chg_cal.second)/chg_cal.first; - // In order to have Reset TS1 hits in CRTData from Side CRT, we have to explicitly include them - // The current threshold cut (6.5 PE) was applied to filter out noise, but this also filters out - // Reset events which are random trigger around the pedestal. These Reset hits are removed in - // CRT Hit reconstruction. Top CRT has in internal triggering logic and threshold that screens - // from the noise (hence presel = true for all the hits). - // Please revise this in the future if also T0 Reset hits need to be kept in CRTData. - // To do so, include !0crtList[febdat_i]->IsReference_TS0() - if(pe<=fPEThresh && !crtList[febdat_i]->IsReference_TS1()) continue; - presel = true; - } - }else if ( type == 'c' ) { - - presel = true; - - }else if ( type == 'd'){ - for(int chan=0; chan<64; chan++) { - float pe = (crtList[febdat_i]->fAdc[chan]-fQPed)/fQSlope; - if(pe<=fPEThresh) continue; - presel = true; - } - } - if (presel) crtData.push_back(crtList[febdat_i]); + for(int chan=0; chan<32; chan++) { + std::pair const chg_cal = fChannelMap->getSideCRTCalibrationMap((int)crtList[febdat_i]->fMac5,chan); + float pe = (crtList[febdat_i]->fAdc[chan]-chg_cal.second)/chg_cal.first; + // In order to have Reset TS1 hits in CRTData from Side CRT, we have to explicitly include them + // The current threshold cut (6.5 PE) was applied to filter out noise, but this also filters out + // Reset events which are random trigger around the pedestal. These Reset hits are removed in + // CRT Hit reconstruction. Top CRT has in internal triggering logic and threshold that screens + // from the noise (hence presel = true for all the hits). + // Please revise this in the future if also T0 Reset hits need to be kept in CRTData. + // To do so, include !0crtList[febdat_i]->IsReference_TS0() + if(pe<=fPEThresh && !crtList[febdat_i]->IsReference_TS1()) continue; + presel = true; + } + } else if ( type == 'c' ) { + presel = true; + } else if ( type == 'd'){ + for(int chan=0; chan<64; chan++) { + float pe = (crtList[febdat_i]->fAdc[chan]-fQPed)/fQSlope; + if(pe<=fPEThresh) continue; + presel = true; + } + } + if (presel) crtData.push_back(crtList[febdat_i]); presel = false; } // end of crtList - - mf::LogError("CRTDataAnalysis") << "about to loop over " << crtData.size() <<" crtData entries \n"; for (size_t febdat_i=0; febdat_ifAdc[ch]; - std::pair const chg_cal = fChannelMap->getSideCRTCalibrationMap((int)fMac5,ch); - if (fDetSubSys == 0 || fDetSubSys == 1){ - float pe = (fADC[ch]-chg_cal.second)/chg_cal.first; - if (pe < 0) continue; - fPE[ch] = pe; - }else{ - float pe = (fADC[ch]-fQPed)/fQSlope; - if (pe < 0) continue; + for (int ch=0; chfAdc[ch]; + std::pair const chg_cal = fChannelMap->getSideCRTCalibrationMap((int)fMac5,ch); + if (fDetSubSys == 0 || fDetSubSys == 1){ + float pe = (fADC[ch]-chg_cal.second)/chg_cal.first; + if (pe < 0) continue; + fPE[ch] = pe; + } else { + float pe = (fADC[ch]-fQPed)/fQSlope; + if (pe < 0) continue; fPE[ch] = pe; - } - - } - + } + } fDAQNtuple->Fill(); - } //for CRT FEB events - - // Fill CRT Hit Tree art::Handle> crtHitHandle; @@ -573,143 +559,136 @@ namespace crt { std::vector ids; fNHit = 0; if (isCRTHit) { - - mf::LogError("CRTDataAnalysis") << "looping over reco hits..." << std::endl; - for ( auto const& hit : *crtHitHandle ) - { - fNHit++; - fHitEvent = fEvent; - fXHit = hit.x_pos; - fYHit = hit.y_pos; - fZHit = hit.z_pos; - fXErrHit = hit.x_err; - fYErrHit = hit.y_err; - fZErrHit = hit.z_err; - fT0Hit = hit.ts0_ns; - fT1Hit = hit.ts1_ns; - - fNHitFeb = hit.feb_id.size(); - fHitTotPe = hit.peshit; - int mactmp = hit.feb_id[0]; - fHitReg = fCrtutils->AuxDetRegionNameToNum(fCrtutils->MacToRegion(mactmp)); - fHitSubSys = fCrtutils->MacToTypeCode(mactmp); - std::fill( std::begin( fHitPE ), std::end( fHitPE ), -1 ); - std::fill( std::begin( fHitMac ), std::end( fHitMac ), -1 ); - std::fill( std::begin( fHitMac ), std::end( fHitChan ), -1 ); - m_gate_crt_diff = m_gate_start_timestamp - hit.ts0_ns; - m_crt_global_trigger = hit.ts0_ns - hit.ts1_ns; - m_crtGT_trig_diff = m_crt_global_trigger - (m_trigger_timestamp%1'000'000'000);//''' - auto ittmp = hit.pesmap.find(mactmp); - if (ittmp==hit.pesmap.end()) { - mf::LogError("CRTDataAnalysis") << "hitreg: " << fHitReg << std::endl; - mf::LogError("CRTDataAnalysis") << "fHitSubSys: "<< fHitSubSys << std::endl; - mf::LogError("CRTDataAnalysis") << "mactmp = " << mactmp << std::endl; - mf::LogError("CRTDataAnalysis") << "could not find mac in pesmap!" << std::endl; - continue; - } - fHitNChan=0; - if(fHitSubSys==0){ - std::map>>::const_iterator it; - for (it = hit.pesmap.begin(); it!=hit.pesmap.end();it++){ - std::vector> thisHit = it->second; - int hitsize = (int) thisHit.size(); - for(int k=0; k< hitsize; k++){ - fHitPE[thisHit[k].first]=thisHit[k].second; - fHitChan[thisHit[k].first]=thisHit[k].first; - fHitMac[thisHit[k].first]=(int)it->first; - if(thisHit[k].second>1) fHitNChan++; - } - } - } else if (fHitSubSys==1) { - int arrpos=-1; - std::map>>::const_iterator it; - for (it = hit.pesmap.begin(); it!=hit.pesmap.end();it++){ - std::vector> thisHit = it->second; - int hitsize = (int) thisHit.size(); - fHitNChan+=hitsize; - for(int k=0; k< hitsize; k++){ - arrpos++; - if(arrpos>=32) continue; - fHitPE[arrpos]=thisHit[k].second; - fHitMac[arrpos]=(int)it->first; - fHitChan[arrpos]=thisHit[k].first; - } - } - } - int chantmp = (*ittmp).second[0].first; - - fHitMod = fCrtutils->MacToAuxDetID(mactmp, chantmp); - fHitStrip = fCrtutils->ChannelToAuxDetSensitiveID(mactmp, chantmp); - - fHitNtuple->Fill(); - }//for CRT Hits + mf::LogError("CRTDataAnalysis") << "looping over reco hits..." << std::endl; + for ( auto const& hit : *crtHitHandle ){ + fNHit++; + fHitRun = fRun; + fHitSubRun = fSubRun; + fHitEvent = fEvent; + fXHit = hit.x_pos; + fYHit = hit.y_pos; + fZHit = hit.z_pos; + fXErrHit = hit.x_err; + fYErrHit = hit.y_err; + fZErrHit = hit.z_err; + fT0Hit = hit.ts0_ns; + fT1Hit = hit.ts1_ns; + + fNHitFeb = hit.feb_id.size(); + fHitTotPe = hit.peshit; + int mactmp = hit.feb_id[0]; + fHitReg = fCrtutils->AuxDetRegionNameToNum(fCrtutils->MacToRegion(mactmp)); + fHitSubSys = fCrtutils->MacToTypeCode(mactmp); + std::fill( std::begin( fHitPE ), std::end( fHitPE ), -1 ); + std::fill( std::begin( fHitMac ), std::end( fHitMac ), -1 ); + std::fill( std::begin( fHitChan ), std::end( fHitChan ), -1 ); + m_gate_crt_diff = m_gate_start_timestamp - hit.ts0_ns; + m_crt_global_trigger = hit.ts0_ns - hit.ts1_ns; + m_crtGT_trig_diff = m_crt_global_trigger - (m_trigger_timestamp%1'000'000'000);//''' + auto ittmp = hit.pesmap.find(mactmp); + if (ittmp==hit.pesmap.end()) { + mf::LogError("CRTDataAnalysis") << "hitreg: " << fHitReg << std::endl; + mf::LogError("CRTDataAnalysis") << "fHitSubSys: "<< fHitSubSys << std::endl; + mf::LogError("CRTDataAnalysis") << "mactmp = " << mactmp << std::endl; + mf::LogError("CRTDataAnalysis") << "could not find mac in pesmap!" << std::endl; + continue; + } + fHitNChan=0; + if(fHitSubSys==0){ + std::map>>::const_iterator it; + for (it = hit.pesmap.begin(); it!=hit.pesmap.end();it++){ + std::vector> thisHit = it->second; + int hitsize = (int) thisHit.size(); + for(int k=0; k< hitsize; k++){ + fHitPE[thisHit[k].first]=thisHit[k].second; + fHitChan[thisHit[k].first]=thisHit[k].first; + fHitMac[thisHit[k].first]=(int)it->first; + if(thisHit[k].second>1) fHitNChan++; + } + } + } else if (fHitSubSys==1) { + int arrpos=-1; + std::map>>::const_iterator it; + for (it = hit.pesmap.begin(); it!=hit.pesmap.end();it++){ + std::vector> thisHit = it->second; + int hitsize = (int) thisHit.size(); + fHitNChan+=hitsize; + for(int k=0; k< hitsize; k++){ + arrpos++; + if(arrpos>=32) continue; + fHitPE[arrpos]=thisHit[k].second; + fHitMac[arrpos]=(int)it->first; + fHitChan[arrpos]=thisHit[k].first; + } + } + } + int chantmp = (*ittmp).second[0].first; + fHitMod = fCrtutils->MacToAuxDetID(mactmp, chantmp); + fHitStrip = fCrtutils->ChannelToAuxDetSensitiveID(mactmp, chantmp); + fHitNtuple->Fill(); + }//for CRT Hits }//if CRT Hits - - else mf::LogError("CRTDataAnalysis") << "CRTHit products not found! (expected if decoder step)" << std::endl; - + else mf::LogError("CRTDataAnalysis") << "CRTHit products not found! (expected if decoder step)" << std::endl; //Fill CRTPMT Match TTree art::Handle> CRTPMTMatchingHandle; if ( event.getByLabel(fCRTPMTProducerLabel, CRTPMTMatchingHandle)){ - for (auto const& match: *CRTPMTMatchingHandle){ - int TopEn = 0, TopEx = 0, SideEn = 0, SideEx = 0; - fMatchEvent = fEvent; - fMatchRun = fRun; - fGateType = m_gate_type; - fFlashID = match.flashID; - fFlashTime_us = match.flashTime; - fFlashGateTime_ns = match.flashGateTime; - fFirstOpHitPeakTime = match.firstOpHitPeakTime; - fFirstOpHitStartTime = match.firstOpHitStartTime; - fFlashInGate = match.flashInGate; - fFlashInBeam = match.flashInBeam; - fFlashPE = match.flashPE; - fFlashPos_x = match.flashPosition.X(); - fFlashPos_y = match.flashPosition.Y(); - fFlashPos_z = match.flashPosition.Z(); - fFlashYWidth = match.flashYWidth; - fFlashZWidth = match.flashZWidth; - fFlashClassification = match.flashClassification; - nMatchedCRTHits = match.matchedCRTHits.size(); - for(auto const& crthit: match.matchedCRTHits){ - CRTHitPos_x.push_back(crthit.position.X()); - CRTHitPos_y.push_back(crthit.position.Y()); - CRTHitPos_z.push_back(crthit.position.Z()); - fCRTPMTTimeDiff_ns.push_back(1e3*crthit.PMTTimeDiff); - fCRTTime_us.push_back(crthit.time); - fCRTSys.push_back(crthit.sys); - fCRTRegion.push_back(crthit.region); - int fMatchType = static_cast(fFlashClassification); - if(fMatchType == 1 || fMatchType == 3 || fMatchType == 6 || fMatchType == 7 || fMatchType == 11) TopEn++; - if(fMatchType == 4 || fMatchType == 13) TopEx++; - if(fMatchType == 2 || fMatchType == 12) SideEn++; - if(fMatchType == 3 || fMatchType == 5 || fMatchType == 7 || fMatchType == 14) SideEx++; - } - fNtopCRTBefore = TopEn; - fNtopCRTAfter = TopEx; - fNsideCRTBefore = SideEn; - fNsideCRTAfter = SideEx; - fCRTPMTNtuple->Fill(); - ClearVecs(); + int TopEn = 0, TopEx = 0, SideEn = 0, SideEx = 0; + fMatchEvent = fEvent; + fMatchRun = fRun; + fGateType = m_gate_type; + fFlashID = match.flashID; + fFlashTime_us = match.flashTime; + fFlashGateTime_ns = match.flashGateTime; + fFirstOpHitPeakTime = match.firstOpHitPeakTime; + fFirstOpHitStartTime = match.firstOpHitStartTime; + fFlashInGate = match.flashInGate; + fFlashInBeam = match.flashInBeam; + fFlashPE = match.flashPE; + fFlashPos_x = match.flashPosition.X(); + fFlashPos_y = match.flashPosition.Y(); + fFlashPos_z = match.flashPosition.Z(); + fFlashYWidth = match.flashYWidth; + fFlashZWidth = match.flashZWidth; + fFlashClassification = match.flashClassification; + nMatchedCRTHits = match.matchedCRTHits.size(); + for(auto const& crthit: match.matchedCRTHits){ + CRTHitPos_x.push_back(crthit.position.X()); + CRTHitPos_y.push_back(crthit.position.Y()); + CRTHitPos_z.push_back(crthit.position.Z()); + fCRTPMTTimeDiff_ns.push_back(1e3*crthit.PMTTimeDiff); + fCRTTime_us.push_back(crthit.time); + fCRTSys.push_back(crthit.sys); + fCRTRegion.push_back(crthit.region); + int fMatchType = static_cast(fFlashClassification); + if(fMatchType == 1 || fMatchType == 3 || fMatchType == 6 || fMatchType == 7 || fMatchType == 11) TopEn++; + if(fMatchType == 4 || fMatchType == 13) TopEx++; + if(fMatchType == 2 || fMatchType == 12) SideEn++; + if(fMatchType == 3 || fMatchType == 5 || fMatchType == 7 || fMatchType == 14) SideEx++; + } + fNtopCRTBefore = TopEn; + fNtopCRTAfter = TopEx; + fNsideCRTBefore = SideEn; + fNsideCRTAfter = SideEx; + fCRTPMTNtuple->Fill(); + ClearVecs(); } // for match in handle } // if valid label else{ mf::LogError("CRTDataAnalysis") << "not Valid CRTPMTProducer label!\n"; } - - - } // CRTDataAnalysis::analyze() - - void CRTDataAnalysis::ClearVecs(){ - CRTHitPos_x.clear(); - CRTHitPos_y.clear(); - CRTHitPos_z.clear(); - fCRTPMTTimeDiff_ns.clear(); - fCRTTime_us.clear(); - fCRTSys.clear(); - fCRTRegion.clear(); - } + } // CRTDataAnalysis::analyze() + + void CRTDataAnalysis::ClearVecs(){ + CRTHitPos_x.clear(); + CRTHitPos_y.clear(); + CRTHitPos_z.clear(); + fCRTPMTTimeDiff_ns.clear(); + fCRTTime_us.clear(); + fCRTSys.clear(); + fCRTRegion.clear(); + } DEFINE_ART_MODULE(CRTDataAnalysis) diff --git a/icaruscode/Filters/CMakeLists.txt b/icaruscode/Filters/CMakeLists.txt index cc5bdcf9e..2cc1cbf31 100644 --- a/icaruscode/Filters/CMakeLists.txt +++ b/icaruscode/Filters/CMakeLists.txt @@ -46,6 +46,8 @@ cet_build_plugin(FilterParticlesActiveVolume art::module LIBRARIES ${MODULE_LIBR cet_build_plugin(TriggerTypeFilter art::module LIBRARIES ${MODULE_LIBRARIES}) cet_build_plugin(FilterCRTPMTMatching art::module LIBRARIES ${MODULE_LIBRARIES}) cet_build_plugin(FilterDirts art::module LIBRARIES ${MODULE_LIBRARIES}) +cet_build_plugin(SimEnergyDepFakeTriggerFilterICARUS art::module LIBRARIES ${MODULE_LIBRARIES}) +cet_build_plugin(FilterMCTruthVolume art::module LIBRARIES ${MODULE_LIBRARIES}) # install_headers() install_fhicl() diff --git a/icaruscode/Filters/FilterMCTruthVolume_module.cc b/icaruscode/Filters/FilterMCTruthVolume_module.cc new file mode 100644 index 000000000..8aac0b1fa --- /dev/null +++ b/icaruscode/Filters/FilterMCTruthVolume_module.cc @@ -0,0 +1,145 @@ +//////////////////////////////////////////////////////////////////////// +// FilterMCTruthVolume_module.cc +// +// art::EDFilter that selects events containing at least one MCTruth +// neutrino interaction with a vertex __outside__ a user-specified box. +// Produces filtered MCTruth, GTruth, and MCFlux collections with +// their associations. Passes through POT summary at the SubRun level. +//////////////////////////////////////////////////////////////////////// + +#include "art/Framework/Core/EDFilter.h" +#include "art/Framework/Core/ModuleMacros.h" +#include "art/Framework/Principal/Event.h" +#include "art/Framework/Principal/Handle.h" +#include "art/Framework/Principal/SubRun.h" +#include "art/Persistency/Common/PtrMaker.h" +#include "canvas/Persistency/Common/Assns.h" +#include "canvas/Persistency/Common/FindOneP.h" +#include "canvas/Utilities/InputTag.h" +#include "fhiclcpp/ParameterSet.h" +#include "messagefacility/MessageLogger/MessageLogger.h" + +#include "larcoreobj/SummaryData/POTSummary.h" +#include "nusimdata/SimulationBase/MCTruth.h" +#include "nusimdata/SimulationBase/GTruth.h" +#include "nusimdata/SimulationBase/MCFlux.h" + +#include +#include +#include + +class FilterMCTruthVolume : public art::EDFilter { +public: + explicit FilterMCTruthVolume(fhicl::ParameterSet const& pset); + + bool filter(art::Event& evt) override; + bool endSubRun(art::SubRun& sr) override; + +private: + art::InputTag fMCTruthLabel; + art::InputTag fPOTLabel; + std::array fVolumeLow; + std::array fVolumeHigh; + + bool inVolume(double x, double y, double z) const; +}; + +// --------------------------------------------------------------------------- +FilterMCTruthVolume::FilterMCTruthVolume(fhicl::ParameterSet const& pset) + : EDFilter{pset} + , fMCTruthLabel{pset.get("MCTruthLabel", "generator")} + , fPOTLabel{pset.get("POTLabel", "generator")} +{ + auto lo = pset.get>("VolumeLow"); + auto hi = pset.get>("VolumeHigh"); + if (lo.size() != 3 || hi.size() != 3) + throw art::Exception(art::errors::Configuration) + << "VolumeLow and VolumeHigh must each have exactly 3 elements (x, y, z)."; + std::copy(lo.begin(), lo.end(), fVolumeLow.begin()); + std::copy(hi.begin(), hi.end(), fVolumeHigh.begin()); + + produces>(); + produces>(); + produces>(); + produces>(); + produces>(); + produces(); +} + +// --------------------------------------------------------------------------- +bool FilterMCTruthVolume::inVolume(double x, double y, double z) const +{ + return x >= fVolumeLow[0] && x <= fVolumeHigh[0] && + y >= fVolumeLow[1] && y <= fVolumeHigh[1] && + z >= fVolumeLow[2] && z <= fVolumeHigh[2]; +} + +// --------------------------------------------------------------------------- +bool FilterMCTruthVolume::filter(art::Event& evt) +{ + auto outMCTruth = std::make_unique>(); + auto outGTruth = std::make_unique>(); + auto outMCFlux = std::make_unique>(); + auto assnsTG = std::make_unique>(); + auto assnsTF = std::make_unique>(); + + auto const& mctruthHandle = evt.getValidHandle>(fMCTruthLabel); + + art::FindOneP findGTruth(mctruthHandle, evt, fMCTruthLabel); + art::FindOneP findMCFlux(mctruthHandle, evt, fMCTruthLabel); + + art::PtrMaker makeTruthPtr(evt); + art::PtrMaker makeGTruthPtr(evt); + art::PtrMaker makeMCFluxPtr(evt); + + for (size_t i = 0; i < mctruthHandle->size(); ++i) { + auto const& mct = mctruthHandle->at(i); + + if (!mct.NeutrinoSet()) continue; + + double vx = mct.GetNeutrino().Nu().Vx(); + double vy = mct.GetNeutrino().Nu().Vy(); + double vz = mct.GetNeutrino().Nu().Vz(); + + if (inVolume(vx, vy, vz)) continue; + + outMCTruth->push_back(mct); + size_t idx = outMCTruth->size() - 1; + + if (findGTruth.isValid()) { + auto const& gtp = findGTruth.at(i); + if (gtp.isNonnull()) { + outGTruth->push_back(*gtp); + assnsTG->addSingle(makeTruthPtr(idx), makeGTruthPtr(outGTruth->size() - 1)); + } + } + + if (findMCFlux.isValid()) { + auto const& mfp = findMCFlux.at(i); + if (mfp.isNonnull()) { + outMCFlux->push_back(*mfp); + assnsTF->addSingle(makeTruthPtr(idx), makeMCFluxPtr(outMCFlux->size() - 1)); + } + } + } + + bool pass = !outMCTruth->empty(); + + evt.put(std::move(outMCTruth)); + evt.put(std::move(outGTruth)); + evt.put(std::move(outMCFlux)); + evt.put(std::move(assnsTG)); + evt.put(std::move(assnsTF)); + + return pass; +} + +// --------------------------------------------------------------------------- +bool FilterMCTruthVolume::endSubRun(art::SubRun& sr) +{ + auto const& potHandle = sr.getValidHandle(fPOTLabel); + sr.put(std::make_unique(*potHandle), art::subRunFragment()); + return true; +} + +DEFINE_ART_MODULE(FilterMCTruthVolume) diff --git a/icaruscode/Filters/SimEnergyDepFakeTriggerFilterICARUS_module.cc b/icaruscode/Filters/SimEnergyDepFakeTriggerFilterICARUS_module.cc new file mode 100644 index 000000000..91bf126d7 --- /dev/null +++ b/icaruscode/Filters/SimEnergyDepFakeTriggerFilterICARUS_module.cc @@ -0,0 +1,58 @@ +#include "art/Framework/Core/EDFilter.h" +#include "art/Framework/Core/ModuleMacros.h" +#include "art/Framework/Principal/Event.h" + +#include "lardataobj/Simulation/SimEnergyDeposit.h" + +namespace filt { + +class SimEnergyDepFakeTriggerFilterICARUS : public art::EDFilter { + public: + explicit SimEnergyDepFakeTriggerFilterICARUS(fhicl::ParameterSet const& pset); + virtual bool filter(art::Event& e) override; + + private: + const double fBeamTimeMin; // Minimum time of beam window [us] + const double fBeamTimeMax; // Maximum time of beam window [us] + const double fEnergyDeposit; // Minimum energy deposit in TPC for trigger [MeV] + const double fMaxEnergyDeposit; // Maximum energy deposit in TPC for trigger [MeV] + + const std::string fSimEnergyDepModuleName; +}; + +SimEnergyDepFakeTriggerFilterICARUS::SimEnergyDepFakeTriggerFilterICARUS(fhicl::ParameterSet const& pset) + : EDFilter(pset) + , fBeamTimeMin(pset.get("BeamTimeMin")) + , fBeamTimeMax(pset.get("BeamTimeMax")) + , fEnergyDeposit(pset.get("EnergyDeposit")) + , fMaxEnergyDeposit(pset.get("MaxEnergyDeposit", std::numeric_limits::max())) + , fSimEnergyDepModuleName(pset.get("SimEnergyDepModuleName")) +{ +} + +bool SimEnergyDepFakeTriggerFilterICARUS::filter(art::Event& e) +{ + const art::ValidHandle>& + energyDeps(e.getValidHandle>(fSimEnergyDepModuleName)); + + double energy(0); + + for (const sim::SimEnergyDeposit& energyDep : *energyDeps) { + // Check particle time is within the beam time + const double time(energyDep.Time() * 1e-3); // [ns] -> [us] + if (time < fBeamTimeMin || time > fBeamTimeMax) + continue; + + // Add up the energy deposit inside the TPC + energy += energyDep.Energy(); // [MeV] + } + + std::cout << "SAW E= " << energy << " inside window. Threshold is: " << fEnergyDeposit << std::endl; + // If the energy deposit within the beam time is greater than some limit then trigger the event + return (energy > fEnergyDeposit) && (energy < fMaxEnergyDeposit); +} + +DEFINE_ART_MODULE(SimEnergyDepFakeTriggerFilterICARUS) + +} + diff --git a/icaruscode/Filters/filterMCTruthVolume.fcl b/icaruscode/Filters/filterMCTruthVolume.fcl new file mode 100644 index 000000000..32978a7cd --- /dev/null +++ b/icaruscode/Filters/filterMCTruthVolume.fcl @@ -0,0 +1,11 @@ +BEGIN_PROLOG + +filtermctruthvolume: { + module_type: FilterMCTruthVolume + MCTruthLabel: "mcgen" + POTLabel: "mcgen" + VolumeLow: [-571.55, -352.067, -1187.04] + VolumeHigh: [+571.55, +619.033, +1566.2] +} + +END_PROLOG diff --git a/icaruscode/Filters/filter_genie_active_interaction.fcl b/icaruscode/Filters/filter_genie_active_interaction.fcl index c149775f9..209bcf4f1 100644 --- a/icaruscode/Filters/filter_genie_active_interaction.fcl +++ b/icaruscode/Filters/filter_genie_active_interaction.fcl @@ -4,7 +4,6 @@ #include "magfield_larsoft.fcl" #include "FilterNeutrinoActive.fcl" #include "FilterNeutrinoInteraction.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/icaruscode/Filters/filter_particle_active.fcl b/icaruscode/Filters/filter_particle_active.fcl index cb21cdb7c..21b858da8 100644 --- a/icaruscode/Filters/filter_particle_active.fcl +++ b/icaruscode/Filters/filter_particle_active.fcl @@ -3,7 +3,6 @@ #include "larproperties.fcl" #include "magfield_larsoft.fcl" #include "FilterParticleActive.fcl" -#include "largeantmodules.fcl" #include "genie_icarus.fcl" #include "mcreco.fcl" #include "services_common_icarus.fcl" diff --git a/icaruscode/Filters/simenergydep_faketrigger_icarus.fcl b/icaruscode/Filters/simenergydep_faketrigger_icarus.fcl new file mode 100644 index 000000000..535c5ba2f --- /dev/null +++ b/icaruscode/Filters/simenergydep_faketrigger_icarus.fcl @@ -0,0 +1,15 @@ +BEGIN_PROLOG + +icarus_simenergydepfaketriggerfilter: +{ + module_type: "SimEnergyDepFakeTriggerFilterICARUS" + + BeamTimeMin: -0.2 # Minimum time of beam window [us] + BeamTimeMax: 1.9 # Maximum time of beam window [us] + EnergyDeposit: 5 # Minimum energy deposit in TPC for trigger [MeV] + + # By default, take only the energy deposits within the TPC active volume + SimEnergyDepModuleName: "largeant:LArG4DetectorServicevolTPCActive" # Name of SimEnergyDeposit producer module +} + +END_PROLOG diff --git a/icaruscode/LArG4/largeantmodules_icarus.fcl b/icaruscode/LArG4/largeantmodules_icarus.fcl deleted file mode 100644 index 4713578a2..000000000 --- a/icaruscode/LArG4/largeantmodules_icarus.fcl +++ /dev/null @@ -1,9 +0,0 @@ -#include "largeantmodules.fcl" - -BEGIN_PROLOG - -icarus_largeant: @local::standard_largeant - -icarus_largeantana: @local::standard_largeantana - -END_PROLOG diff --git a/icaruscode/Overlays/CMakeLists.txt b/icaruscode/Overlays/CMakeLists.txt index 19322d16d..f42d8d6b7 100644 --- a/icaruscode/Overlays/CMakeLists.txt +++ b/icaruscode/Overlays/CMakeLists.txt @@ -23,6 +23,13 @@ cet_build_plugin( gallery::gallery ) +cet_build_plugin( + SubRunPOTInEvent art::EDProducer + LIBRARIES + PRIVATE + larcoreobj::SummaryData +) + # This is what's needed for building the WireCellubsim WCT component art_make_library( LIBRARY_NAME WireCellICARUSDrifter diff --git a/icaruscode/Overlays/SimInfoOverlayFilter_module.cc b/icaruscode/Overlays/SimInfoOverlayFilter_module.cc index d694f29f4..ccb60a36c 100644 --- a/icaruscode/Overlays/SimInfoOverlayFilter_module.cc +++ b/icaruscode/Overlays/SimInfoOverlayFilter_module.cc @@ -742,7 +742,7 @@ void mix::SimInfoOverlayFilter::MakePOTMap(){ fSR_SpillsPerEvent.clear(); fSR_GoodSpillsPerEvent.clear(); - unsigned int current_sr = 0; + int current_sr = -1; unsigned int events_in_sr = 0; double current_sr_POT = 0; @@ -752,16 +752,17 @@ void mix::SimInfoOverlayFilter::MakePOTMap(){ // Iterate through all events in auxillary file, count how many are in each subrun while(!gEvent.atEnd()){ + if (current_sr == -1) current_sr = gEvent.eventAuxiliary().subRun(); - if(gEvent.eventAuxiliary().subRun() != current_sr){ - if(current_sr != 0){ - fSR_POTPerEvent[current_sr] = current_sr_POT/events_in_sr; - fSR_GoodPOTPerEvent[current_sr] = current_sr_GoodPOT/events_in_sr; - fSR_SpillsPerEvent[current_sr] = (double)current_sr_Spills/events_in_sr; - fSR_GoodSpillsPerEvent[current_sr] = (double)current_sr_GoodSpills/events_in_sr; - } + if((int)gEvent.eventAuxiliary().subRun() != current_sr){ + fSR_POTPerEvent[current_sr] = current_sr_POT/events_in_sr; + fSR_GoodPOTPerEvent[current_sr] = current_sr_GoodPOT/events_in_sr; + fSR_SpillsPerEvent[current_sr] = (double)current_sr_Spills/events_in_sr; + fSR_GoodSpillsPerEvent[current_sr] = (double)current_sr_GoodSpills/events_in_sr; events_in_sr = 0; current_sr = gEvent.eventAuxiliary().subRun(); + + std::cout << "Label: " << fPOTSummaryTag << " with POT: " << current_sr_POT << " from NEvent: " << events_in_sr << " in SubRun: " << current_sr << std::endl; } gallery::Handle< sumdata::POTSummary > potsum_handle; @@ -779,15 +780,17 @@ void mix::SimInfoOverlayFilter::MakePOTMap(){ } // Add the last sr - if(current_sr != 0){ + if(current_sr != -1){ fSR_POTPerEvent[current_sr] = current_sr_POT/events_in_sr; fSR_GoodPOTPerEvent[current_sr] = current_sr_GoodPOT/events_in_sr; fSR_SpillsPerEvent[current_sr] = (double)current_sr_Spills/events_in_sr; fSR_GoodSpillsPerEvent[current_sr] = (double)current_sr_GoodSpills/events_in_sr; + + std::cout << "Label: " << fPOTSummaryTag << " with POT: " << current_sr_POT << " from NEvent: " << events_in_sr << " in SubRun: " << current_sr << std::endl; } - // std::map::iterator it; - // for (it = fSR_POTPerEvent.begin(); it != fSR_POTPerEvent.end(); it++) std::cout << "SR=" << it->first << " POT/Event=" << it->second << std::endl; + std::map::iterator it; + for (it = fSR_POTPerEvent.begin(); it != fSR_POTPerEvent.end(); it++) std::cout << "SR=" << it->first << " POT/Event=" << it->second << std::endl; gEvent.first(); } @@ -850,4 +853,4 @@ void mix::SimInfoOverlayFilter::respondToOpenOutputFiles(art::FileBlock const & { } -DEFINE_ART_MODULE(mix::SimInfoOverlayFilter) \ No newline at end of file +DEFINE_ART_MODULE(mix::SimInfoOverlayFilter) diff --git a/icaruscode/Overlays/SubRunPOTInEvent_module.cc b/icaruscode/Overlays/SubRunPOTInEvent_module.cc new file mode 100644 index 000000000..60a97a2db --- /dev/null +++ b/icaruscode/Overlays/SubRunPOTInEvent_module.cc @@ -0,0 +1,90 @@ +//////////////////////////////////////////////////////////////////////// +// Class: SubRunPOTInEvent +// Plugin Type: producer (art v3_00_00) +// File: SubRunPOTInEvent_module.cc +// +// Generated at Mon Jan 21 09:09:38 2019 by Wesley Ketchum using cetskelgen +// from cetlib version v3_04_00. +// +// This module directly copies the subrun POT info into every event. +// **IT IS NOT A POT PER EVENT IT IS NOT A POT PER EVENT** +// **IT IS NOT A POT PER EVENT IT IS NOT A POT PER EVENT** +// **IT IS NOT A POT PER EVENT IT IS NOT A POT PER EVENT** +// **IT IS NOT A POT PER EVENT IT IS NOT A POT PER EVENT** +// **IT IS NOT A POT PER EVENT IT IS NOT A POT PER EVENT** +// **IT IS NOT A POT PER EVENT IT IS NOT A POT PER EVENT** +// +//////////////////////////////////////////////////////////////////////// + +#include "art/Framework/Core/EDProducer.h" +#include "art/Framework/Core/ModuleMacros.h" +#include "art/Framework/Principal/Event.h" +#include "art/Framework/Principal/Handle.h" +#include "art/Framework/Principal/Run.h" +#include "art/Framework/Principal/SubRun.h" +#include "canvas/Utilities/InputTag.h" +#include "fhiclcpp/ParameterSet.h" +#include "messagefacility/MessageLogger/MessageLogger.h" + +#include + +#include "larcoreobj/SummaryData/POTSummary.h" + +namespace mix { + class SubRunPOTInEvent; +} + + +class mix::SubRunPOTInEvent : public art::EDProducer { +public: + explicit SubRunPOTInEvent(fhicl::ParameterSet const& p); + // The compiler-generated destructor is fine for non-base + // classes without bare pointers or other resource use. + + // Plugins should not be copied or assigned. + SubRunPOTInEvent(SubRunPOTInEvent const&) = delete; + SubRunPOTInEvent(SubRunPOTInEvent&&) = delete; + SubRunPOTInEvent& operator=(SubRunPOTInEvent const&) = delete; + SubRunPOTInEvent& operator=(SubRunPOTInEvent&&) = delete; + + // Required functions. + void produce(art::Event& e) override; + + // Selected optional functions. + void beginSubRun(art::SubRun& sr) override; + +private: + + art::InputTag fInputTag; + sumdata::POTSummary fSubRunPOT; + +}; + + +mix::SubRunPOTInEvent::SubRunPOTInEvent(fhicl::ParameterSet const& p) + : EDProducer{p} // , + // More initializers here. +{ + fInputTag = p.get("InputTag"); + + produces("SubRunPOT"); +} + +void mix::SubRunPOTInEvent::produce(art::Event& e) +{ + std::unique_ptr srpot_ptr(new sumdata::POTSummary(fSubRunPOT)); + e.put(std::move(srpot_ptr),"SubRunPOT"); +} + +void mix::SubRunPOTInEvent::beginSubRun(art::SubRun& sr) +{ + art::Handle srpot_handle; + sr.getByLabel(fInputTag,srpot_handle); + if(srpot_handle.isValid()) fSubRunPOT = *srpot_handle; + else std::cout << "BAD SUBRUNPOT\n"; + + std::cout << "GOT POT: " << fSubRunPOT.totgoodpot << std::endl; +} + +DEFINE_ART_MODULE(mix::SubRunPOTInEvent) + diff --git a/icaruscode/PMT/CMakeLists.txt b/icaruscode/PMT/CMakeLists.txt index a34d31b95..4265812a8 100644 --- a/icaruscode/PMT/CMakeLists.txt +++ b/icaruscode/PMT/CMakeLists.txt @@ -260,7 +260,7 @@ cet_build_plugin(ReassociatePMTbaselines art::module icaruscode::IcarusObj icaruscode::PMT_Algorithms icaruscode::PMT_Data - icarusalg::Utilities + sbnalg::Utilities sbnobj::ICARUS_PMT_Data lardata::headers lardataalg::headers diff --git a/icaruscode/PMT/OpReco/driver/gen_fakeflash.fcl b/icaruscode/PMT/OpReco/driver/gen_fakeflash.fcl index 36c0d5d68..6d456ef67 100644 --- a/icaruscode/PMT/OpReco/driver/gen_fakeflash.fcl +++ b/icaruscode/PMT/OpReco/driver/gen_fakeflash.fcl @@ -1,7 +1,6 @@ #include "services_icarus_simulation.fcl" #include "singles_icarus.fcl" #include "services_common_icarus.fcl" -#include "largeantmodules_icarus.fcl" #include "detsimmodules_ICARUS.fcl" #include "opdetsim_pmt_icarus.fcl" #include "icarus_opana_modules.fcl" diff --git a/icaruscode/PMT/OpReco/driver/gen_fakephotons.fcl b/icaruscode/PMT/OpReco/driver/gen_fakephotons.fcl index c3625d0de..4eb5253ec 100644 --- a/icaruscode/PMT/OpReco/driver/gen_fakephotons.fcl +++ b/icaruscode/PMT/OpReco/driver/gen_fakephotons.fcl @@ -1,7 +1,6 @@ #include "services_icarus_simulation.fcl" #include "singles_icarus.fcl" #include "services_common_icarus.fcl" -#include "largeantmodules_icarus.fcl" #include "detsimmodules_ICARUS.fcl" #include "opdetsim_pmt_icarus.fcl" #include "icarus_opana_modules.fcl" diff --git a/icaruscode/PMT/OpReco/driver/gen_protons.fcl b/icaruscode/PMT/OpReco/driver/gen_protons.fcl index 7ce79eb2e..8ef1a8e14 100644 --- a/icaruscode/PMT/OpReco/driver/gen_protons.fcl +++ b/icaruscode/PMT/OpReco/driver/gen_protons.fcl @@ -2,7 +2,7 @@ #include "services_icarus_simulation.fcl" #include "singles_icarus.fcl" #include "services_common_icarus.fcl" -#include "largeantmodules_icarus.fcl" +#include "larg4_icarus_defs.fcl" #include "detsimmodules_ICARUS.fcl" #include "opdetsim_pmt_icarus.fcl" #include "icarus_opana_modules.fcl" @@ -36,13 +36,15 @@ physics: producers: { generator: @local::icarus_singlep - largeant: @local::icarus_largeant - opdaq: @local::icarus_simpmt_nonoise - rns: { module_type: "RandomNumberSaver" } + loader: @local::icarus_larg4_standard_producers.loader + largeant: @local::icarus_larg4_standard_producers.largeant + pdfastsim: @local::icarus_larg4_standard_producers.pdfastsim + opdaq: @local::icarus_simpmt_nonoise + rns: { module_type: "RandomNumberSaver" } } analyzers: {} - produce: [ rns, generator, largeant, opdaq ] + produce: [ rns, generator, loader, largeant, pdfastsim, opdaq ] analyze: [] store: [ out1 ] trigger_paths: [produce] diff --git a/icaruscode/PMT/OpReco/driver/run_opflash_electron.fcl b/icaruscode/PMT/OpReco/driver/run_opflash_electron.fcl index 96f4cce7a..8b9a03816 100644 --- a/icaruscode/PMT/OpReco/driver/run_opflash_electron.fcl +++ b/icaruscode/PMT/OpReco/driver/run_opflash_electron.fcl @@ -5,7 +5,7 @@ #include "icarus_ophitfinder.fcl" #include "icarus_flashfinder.fcl" #include "icarus_opana_modules.fcl" -#include "largeantmodules_icarus.fcl" +#include "larg4_icarus_defs.fcl" #include "detsimmodules_ICARUS.fcl" #include "opdetsim_pmt_icarus.fcl" @@ -44,7 +44,9 @@ physics: { #generator: @local::FakeFlash generator: @local::icarus_singlep - largeant: @local::icarus_largeant + loader: @local::icarus_larg4_standard_producers.loader + largeant: @local::icarus_larg4_standard_producers.largeant + pdfastsim: @local::icarus_larg4_standard_producers.pdfastsim #opdaq: @local::icarus_simpmt_nonoise opdaq: @local::icarus_simpmt rns: { module_type: "RandomNumberSaver" } @@ -61,7 +63,7 @@ physics: opflashana: @local::ICARUSOpFlashAna particleana: @local::ICARUSParticleAna } - produce: [ rns, generator, largeant, opdaq, ophit, mcophit, mcflash, cheatflash, opflash ] + produce: [ rns, generator, loader, largeant, pdfastsim, opdaq, ophit, mcophit, mcflash, cheatflash, opflash ] analyze: [ ophitana, opflashana, particleana ] store: [ out1 ] trigger_paths: [ produce ] @@ -107,7 +109,7 @@ physics.producers.generator.AngleDist: 0 # 0 = uniform, 1 = gaussian #physics.producers.opdaq.QE: 1.0 physics.producers.opdaq.DarkNoiseRate: 0.0 physics.producers.opdaq.FluctuateGain: true -physics.producers.opdaq.InputModule: "largeant" #"generator" +physics.producers.opdaq.InputModule: "pdfastsim" physics.producers.opdaq.ThresholdADC: 5 #physics.producers.mcophit.SimPhotonsProducer: "generator" @@ -134,4 +136,4 @@ services.message.destinations : } # restore legacy G4 labels -physics.producers.mcophit.SimPhotonsProducer: "largeant" +physics.producers.mcophit.SimPhotonsProducer: "pdfastsim" diff --git a/icaruscode/PMT/OpReco/driver/run_opflash_protons.fcl b/icaruscode/PMT/OpReco/driver/run_opflash_protons.fcl index 23a44c66d..9f73ca9c9 100644 --- a/icaruscode/PMT/OpReco/driver/run_opflash_protons.fcl +++ b/icaruscode/PMT/OpReco/driver/run_opflash_protons.fcl @@ -5,7 +5,7 @@ #include "icarus_ophitfinder.fcl" #include "icarus_flashfinder.fcl" #include "icarus_opana_modules.fcl" -#include "largeantmodules_icarus.fcl" +#include "larg4_icarus_defs.fcl" #include "detsimmodules_ICARUS.fcl" #include "opdetsim_pmt_icarus.fcl" @@ -43,9 +43,11 @@ physics: producers: { #generator: @local::FakeFlash - generator: @local::icarus_singlep - largeant: @local::icarus_largeant - #opdaq: @local::icarus_simpmt_nonoise + generator: @local::icarus_singlep + loader: @local::icarus_larg4_standard_producers.loader + largeant: @local::icarus_larg4_standard_producers.largeant + pdfastsim: @local::icarus_larg4_standard_producers.pdfastsim + #opdaq: @local::icarus_simpmt_nonoise opdaq: @local::icarus_simpmt rns: { module_type: "RandomNumberSaver" } ophitdebugger: @local::icarus_ophitdebugger @@ -53,15 +55,15 @@ physics: ophit: @local::icarus_ophit mcflash: @local::ICARUSMCOpFlash #cheatflash: @local::ICARUSMCOpFlash - cheatflash: @local::ICARUSSimpleFlash + cheatflash: @local::ICARUSSimpleFlash opflash: @local::ICARUSSimpleFlash } analyzers: { ophitana: @local::ICARUSOpHitAna opflashana: @local::ICARUSOpFlashAna - particleana: @local::ICARUSParticleAna + particleana: @local::ICARUSParticleAna } - produce: [ rns, generator, largeant, opdaq, ophitdebugger, ophit, mcophit, mcflash, cheatflash, opflash ] + produce: [ rns, generator, loader, largeant, pdfastsim, opdaq, ophitdebugger, ophit, mcophit, mcflash, cheatflash, opflash ] analyze: [ ophitana, opflashana, particleana ] store: [ out1 ] trigger_paths: [ produce ] @@ -107,7 +109,7 @@ physics.producers.generator.AngleDist: 1 #physics.producers.opdaq.QE: 1.0 physics.producers.opdaq.DarkNoiseRate: 0.0 physics.producers.opdaq.FluctuateGain: true -physics.producers.opdaq.InputModule: "largeant" #"generator" +physics.producers.opdaq.InputModule: "pdfastsim" physics.producers.opdaq.ThresholdADC: 5 #physics.producers.mcophit.SimPhotonsProducer: "generator" @@ -134,4 +136,4 @@ services.message.destinations : } # restore legacy G4 labels -physics.producers.mcophit.SimPhotonsProducer: "largeant" +physics.producers.mcophit.SimPhotonsProducer: "pdfastsim" diff --git a/icaruscode/PMT/OpReco/driver/study_ophit_singlep.fcl b/icaruscode/PMT/OpReco/driver/study_ophit_singlep.fcl index a2bc3ccca..060b1ba65 100644 --- a/icaruscode/PMT/OpReco/driver/study_ophit_singlep.fcl +++ b/icaruscode/PMT/OpReco/driver/study_ophit_singlep.fcl @@ -1,7 +1,7 @@ #include "services_icarus_simulation.fcl" #include "singles_icarus.fcl" -#include "largeantmodules_icarus.fcl" +#include "larg4_icarus_defs.fcl" #include "detsimmodules_ICARUS.fcl" #include "opdetsim_pmt_icarus.fcl" #include "icarus_ophitfinder.fcl" @@ -29,10 +29,12 @@ physics: producers: { generator: @local::icarus_singlep - largeant: @local::icarus_largeant - opdaq: @local::icarus_simpmt_nonoise - mcophit: @local::ICARUSMCOpHit - rns: { module_type: "RandomNumberSaver" } + loader: @local::icarus_larg4_standard_producers.loader + largeant: @local::icarus_larg4_standard_producers.largeant + pdfastsim: @local::icarus_larg4_standard_producers.pdfastsim + opdaq: @local::icarus_simpmt_nonoise + mcophit: @local::ICARUSMCOpHit + rns: { module_type: "RandomNumberSaver" } ophitpeak: @local::icarus_ophit ophitstart: @local::icarus_ophit mcflash: @local::ICARUSMCOpFlash @@ -42,7 +44,7 @@ physics: ophittuple: @local::ICARUSOpHitTuple opflashana: @local::ICARUSOpFlashAna } - produce: [ rns, generator, largeant, opdaq, mcophit, ophitstart, ophitpeak, mcflash, opflash ] + produce: [ rns, generator, loader, largeant, pdfastsim, opdaq, mcophit, ophitstart, ophitpeak, mcflash, opflash ] analyze: [ ophittuple, opflashana ] store: [ out1 ] trigger_paths: [ produce ] @@ -68,7 +70,8 @@ physics.producers.generator.SigmaThetaXZ: [ 0. ] physics.producers.generator.SigmaThetaYZ: [ 0. ] physics.producers.generator.AngleDist: 1 -physics.producers.mcophit.SimPhotonsProducer: "largeant" +# new LArG4 optical products are produced by `pdfastsim`, not `largeant` +physics.producers.mcophit.SimPhotonsProducer: "pdfastsim" physics.producers.ophitstart.UseStartTime: true physics.producers.ophitpeak.UseStartTime: false #physics.analyzers.ophittuple.OpDetWaveformProducer: "opdaq" diff --git a/icaruscode/PMT/ReassociatePMTbaselines_module.cc b/icaruscode/PMT/ReassociatePMTbaselines_module.cc index 3b0906d76..e7b2399eb 100644 --- a/icaruscode/PMT/ReassociatePMTbaselines_module.cc +++ b/icaruscode/PMT/ReassociatePMTbaselines_module.cc @@ -10,7 +10,7 @@ #include "icaruscode/PMT/Algorithms/OpDetWaveformMetaUtils.h" // OpDetWaveformMetaMaker #include "icaruscode/PMT/Data/WaveformRMS.h" #include "icaruscode/IcarusObj/OpDetWaveformMeta.h" -#include "icarusalg/Utilities/AssnsCrosser.h" +#include "sbnalg/Utilities/AssnsCrosser.h" #include "sbnobj/ICARUS/PMT/Data/WaveformBaseline.h" // LArSoft libraries @@ -480,9 +480,9 @@ void icarus::trigger::ReassociatePMTbaselines::produce // associate original metadata with (original) baselines: auto const metaToBaseline = makeAssnsCrosser(event, - icarus::ns::util::startFrom{} - , icarus::ns::util::hopTo { fOriginalWaveformTag } - , icarus::ns::util::hopTo { fBaselineTag } + sbn::ns::util::startFrom{} + , sbn::ns::util::hopTo { fOriginalWaveformTag } + , sbn::ns::util::hopTo { fBaselineTag } ); // find which original metadata we need diff --git a/icaruscode/PMT/coordinate.fcl b/icaruscode/PMT/coordinate.fcl index 00f139eac..4bc683cfb 100644 --- a/icaruscode/PMT/coordinate.fcl +++ b/icaruscode/PMT/coordinate.fcl @@ -1,7 +1,6 @@ #include "services_common_icarus.fcl" #include "services_icarus_simulation.fcl" #include "singles_icarus.fcl" -#include "largeantmodules_icarus.fcl" #include "detsimmodules_ICARUS.fcl" #include "mccheatermodules.fcl" #include "photpropservices.fcl" diff --git a/icaruscode/PMT/icarus_prodsingle_buildopticallibrary.fcl b/icaruscode/PMT/icarus_prodsingle_buildopticallibrary.fcl deleted file mode 100644 index 42137a1d7..000000000 --- a/icaruscode/PMT/icarus_prodsingle_buildopticallibrary.fcl +++ /dev/null @@ -1,149 +0,0 @@ -#include "backtrackerservice.fcl" -#include "particleinventoryservice.fcl" - -#include "services_icarus_simulation.fcl" -#include "singles_icarus.fcl" - -#include "services_common_icarus.fcl" -#include "largeantmodules_icarus.fcl" - -#include "detsimmodules.fcl" -#include "photpropservices.fcl" -#include "opticaldetectormodules.fcl" -#include "opticaldetectorservices.fcl" - -#include "lightsource.fcl" - -process_name: LibraryBuild - -services: -{ - # Load the service that manages root files for histograms. - TFileService: { fileName: "PhotonLibraryFile.root" } - TimeTracker: {} - RandomNumberGenerator: {} #ART native random number generator - @table::icarus_simulation_services - BackTrackerService: @local::standard_backtrackerservice # defined in backtracker.fcl - ParticleInventoryService: @local::standard_particleinventoryservice - - OpDetResponseInterface: @local::standard_opdetresponse -} - -services.PhotonVisibilityService: @local::standard_photonvisibilityservice_buildlib -services.PhotonVisibilityService.DoNotLoadLibrary: true -services.PhotonVisibilityService.LibraryBuildJob: true -services.PhotonVisibilityService.UseCryoBoundary: false - -//version51 e 27Sep -//services.PhotonVisibilityService.XMin: 230 #-300 -//services.PhotonVisibilityService.XMax: 250 #-150 -//services.PhotonVisibilityService.YMin: -35 #-150 -//services.PhotonVisibilityService.YMax: -15 #150 -//services.PhotonVisibilityService.ZMin: -10 #-1000 -//services.PhotonVisibilityService.ZMax: 10 #1000 - -//version51_near e senza crt e arcathode -//services.PhotonVisibilityService.XMin: 320 #-300 -//services.PhotonVisibilityService.XMax: 340 #-150 -//services.PhotonVisibilityService.YMin: -35 #-150 -//services.PhotonVisibilityService.YMax: -15 #150 -//services.PhotonVisibilityService.ZMin: -10 #-1000 -//services.PhotonVisibilityService.ZMax: 10 #1000 - -//version test_final -services.PhotonVisibilityService.XMin: -366 -services.PhotonVisibilityService.XMax: -66 -services.PhotonVisibilityService.YMin: -210 -services.PhotonVisibilityService.YMax: 180 -services.PhotonVisibilityService.ZMin: -995 -services.PhotonVisibilityService.ZMax: 965 - -//services.PhotonVisibilityService.NX: 4 -//services.PhotonVisibilityService.NY: 4 -//services.PhotonVisibilityService.NZ: 4 - -services.PhotonVisibilityService.NX: 60 -services.PhotonVisibilityService.NY: 78 -services.PhotonVisibilityService.NZ: 392 - -#services.Geometry.GDML: "test_final.gdml" - -# services.PhotonVisibilityService: @local::standard_photonvisibilityservice -# services.LArFFT: "" - services.SignalShapingServiceICARUS: @erase - -#Start each new event with an empty event. -source: -{ - module_type: EmptyEvent - timestampPlugin: { plugin_type: "GeneratedEventTimestamp" } - maxEvents: 100000 # Number of events to create -# maxEvents: 64 # Number of events to create -# maxEvents: 4680 # Number of events to create - firstRun: 1 # Run number to use for this file - firstEvent: 1 # number of first event in the file -} - -# Define and configure some modules to do work on each event. -# First modules are defined; they are scheduled later. -# Modules are grouped by type. -physics: -{ - - producers: - { - generator: @local::standard_lightsource - largeant: @local::icarus_largeant - } - - analyzers: - { - pmtresponse: @local::standard_simphotoncounter - } - - #define the producer and filter modules for this path, order matters, - #filters reject all following items. see lines starting physics.producers below - simulate: [ generator, largeant ] - analyzeIt: [ pmtresponse ] - - #trigger_paths is a keyword and contains the paths that modify the art::event, - #ie filters and producers - trigger_paths: [simulate] - - #end_paths is a keyword and contains the paths that do not modify the art::Event, - #ie analyzers and output streams. these all run simultaneously - end_paths: [analyzeIt] -} - - -# Begin optical specific parts: - -# set quantum efficiency supressed scint yield to 0.03 * 24000 -services.LArPropertiesService.ScintYield: 24000 - -# enable optical physics in LArG4 - services.LArG4Parameters.EnabledPhysics: [ "Em", - "Optical", - "SynchrotronAndGN", - "Ion", - "Hadron", - "Decay", - "HadronElastic", - "Stopping", - "NeutronTrackingCut" ] - -# enable this custom physics list -services.LArG4Parameters.UseCustomPhysics: true - -physics.producers.generator.N: 400000 - - -# do not allow lightsource to write output into root file -//physics.producers.generator.FillTree: true -physics.producers.generator.FillTree: false -physics.analyzers.pmtresponse.MakeAllPhotonsTree: false - -physics.analyzers.pmtresponse.MakeDetectedPhotonsTree: false -physics.analyzers.pmtresponse.MakeSimPhotonsTree: false -physics.analyzers.pmtresponse.MakeEventsTree: false -physics.analyzers.pmtresponse.MakeLightAnalysisTree: false diff --git a/icaruscode/PMT/icarus_prodsingle_fastoptical.fcl b/icaruscode/PMT/icarus_prodsingle_fastoptical.fcl index 5f28a084a..d8a3cce4f 100644 --- a/icaruscode/PMT/icarus_prodsingle_fastoptical.fcl +++ b/icaruscode/PMT/icarus_prodsingle_fastoptical.fcl @@ -3,7 +3,6 @@ #include "backtrackerservice.fcl" #include "particleinventoryservice.fcl" #include "singles_icarus.fcl" -#include "largeantmodules_icarus.fcl" #include "detsimmodules_ICARUS.fcl" #include "mccheatermodules.fcl" #include "photpropservices.fcl" diff --git a/icaruscode/PMT/optical_electronic.fcl b/icaruscode/PMT/optical_electronic.fcl index e50c1ca7a..caeb78eba 100644 --- a/icaruscode/PMT/optical_electronic.fcl +++ b/icaruscode/PMT/optical_electronic.fcl @@ -2,7 +2,6 @@ #include "services_icarus_simulation.fcl" #include "backtracker.fcl" #include "singles_icarus.fcl" -#include "largeantmodules_icarus.fcl" #include "detsimmodules_ICARUS.fcl" #include "mccheatermodules.fcl" #include "photpropservices.fcl" diff --git a/icaruscode/PMT/photonlibrary_builder_icarus.fcl b/icaruscode/PMT/photonlibrary_builder_icarus.fcl index 21b3329ad..11f903bbe 100644 --- a/icaruscode/PMT/photonlibrary_builder_icarus.fcl +++ b/icaruscode/PMT/photonlibrary_builder_icarus.fcl @@ -3,7 +3,7 @@ # Purpose: main configuration file for simulation of scintillation visibility # Author: Gianluca Petrillo (petrillo@slac.stanford.edu) # Date: July 16, 2020 -# Version: 1.0 +# Version: 2.0alpha # # This configuration is base for the simulation of a few voxels of the # photon visibility lookup table ("photon library") for ICARUS. @@ -12,17 +12,19 @@ # This is the merge and optimization of `icarus_prodsingle_buildopticallibrary.fcl` # from `icaruscode` `v08_57_00` plus `prova_source.fcl`. # +# NOTE (petrillo@slac.stanford.edu, 20260529) +# This configuration has been updated to parse with LArSoft's "new" LArG4 +# but it has not been tested at all. Especially important is to verify that +# the physics list is correctly acquired by GEANT4. # # services #include "services_icarus_simulation.fcl" - -# modules -#include "opticaldetectormodules.fcl" #include "opticaldetectorservices.fcl" -#include "emptyevent_icarus.fcl" -#include "largeantmodules_icarus.fcl" + +# presets +#include "larg4_icarus_defs.fcl" process_name: LibraryBuild @@ -34,14 +36,12 @@ process_name: LibraryBuild services: { - @table::icarus_g4_services + @table::icarus_all_larg4_services # from `larg4_icarus_defs.fcl` # events are generated anew each time: default per-event policy is ineffective - NuRandomService: @local::random_NuRandomService - - OpDetResponse: @local::standard_opdetresponse + NuRandomService: @local::random_NuRandomService # via `services_icarus_simulation.fcl` - SpaceChargeService: @erase + OpDetResponse: @local::standard_opdetresponse # from `opticaldetectorservices.fcl` } # services @@ -52,7 +52,7 @@ services.Geometry.DisableWiresInG4: false # we need to account for wire shadow services.LArG4Parameters: { # customization - @table::services.LArG4Parameters + @table::services.LArG4Parameters # from `services_icarus_simulation.fcl` # enable this custom LArG4 physics list # with optical physics instead of fast scintillation @@ -163,7 +163,7 @@ physics: { } # generator # -------------------------------------------------------------------------- - largeant: @local::icarus_largeant + @table::icarus_larg4_standard_producers # -------------------------------------------------------------------------- @@ -173,6 +173,7 @@ physics: { pmtresponse: { module_type: SimPhotonCounter GeneratorModule: "generator" + InputModule: "pdfastsim" Verbosity: 0 # quiet! MakeAllPhotonsTree: false MakeDetectedPhotonsTree: false @@ -182,7 +183,7 @@ physics: { } } # analyzers - simulate: [ generator, largeant ] + simulate: [ generator, @sequence::icarus_larg4_standard_path ] analyzeIt: [ pmtresponse ] } # physics diff --git a/icaruscode/PMT/photonlibrary_volumetest_icarus.fcl b/icaruscode/PMT/photonlibrary_volumetest_icarus.fcl index c7d2b5883..408a25831 100644 --- a/icaruscode/PMT/photonlibrary_volumetest_icarus.fcl +++ b/icaruscode/PMT/photonlibrary_volumetest_icarus.fcl @@ -77,7 +77,6 @@ #include "opticaldetectormodules.fcl" #include "opticaldetectorservices.fcl" #include "emptyevent_icarus.fcl" -#include "largeantmodules_icarus.fcl" # base configuration #include "photonlibrary_builder_icarus.fcl" diff --git a/icaruscode/PMT/prodsingle_optical_electronic.fcl b/icaruscode/PMT/prodsingle_optical_electronic.fcl index b4c2ca2cd..40f54ac0c 100644 --- a/icaruscode/PMT/prodsingle_optical_electronic.fcl +++ b/icaruscode/PMT/prodsingle_optical_electronic.fcl @@ -3,7 +3,6 @@ #include "backtrackerservice.fcl" #include "particleinventoryservice.fcl" #include "singles_icarus.fcl" -#include "largeantmodules_icarus.fcl" #include "detsimmodules_ICARUS.fcl" #include "mccheatermodules.fcl" #include "photpropservices.fcl" diff --git a/icaruscode/PMT/prova_source.fcl b/icaruscode/PMT/prova_source.fcl index b8ade6289..8d9af76ea 100644 --- a/icaruscode/PMT/prova_source.fcl +++ b/icaruscode/PMT/prova_source.fcl @@ -1,5 +1,5 @@ #include "singles.fcl" -#include "largeantmodules.fcl" +#include "larg4_icarus_defs.fcl" #include "detsimmodules.fcl" #include "mccheatermodules.fcl" #include "photpropservices.fcl" @@ -54,8 +54,10 @@ physics: producers: { - generator: @local::standard_lightsource - largeant: @local::standard_largeant + generator: @local::standard_lightsource + loader: @local::icarus_larg4_standard_producers.loader + largeant: @local::icarus_larg4_standard_producers.largeant + pdfastsim: @local::icarus_larg4_standard_producers.pdfastsim } analyzers: @@ -65,7 +67,7 @@ physics: #define the producer and filter modules for this path, order matters, #filters reject all following items. see lines starting physics.producers below - simulate: [ generator, largeant ] + simulate: [ generator, loader, largeant, pdfastsim ] analyzeIt: [ pmtresponse ] #analyzeIt: [] #define the output stream, there could be more than one if using filters @@ -140,3 +142,6 @@ physics.analyzers.pmtresponse.MakeAllPhotonsTree: true physics.analyzers.pmtresponse.MakeDetectedPhotonsTree: true physics.analyzers.pmtresponse.MakeSimPhotonssTree: true physics.analyzers.pmtresponse.MakeEventsTree: true + +# new LArG4 optical products are produced by `pdfastsim`, not `largeant` +physics.analyzers.pmtresponse.InputModule: [ "pdfastsim" ] diff --git a/icaruscode/PMT/startingpmtcalibtime.fcl b/icaruscode/PMT/startingpmtcalibtime.fcl index b0e67e4c9..5a592215e 100644 --- a/icaruscode/PMT/startingpmtcalibtime.fcl +++ b/icaruscode/PMT/startingpmtcalibtime.fcl @@ -1,7 +1,6 @@ #include "services_common_icarus.fcl" #include "services_icarus_simulation.fcl" #include "singles_icarus.fcl" -#include "largeantmodules_icarus.fcl" #include "detsimmodules_ICARUS.fcl" #include "mccheatermodules.fcl" #include "photpropservices.fcl" diff --git a/icaruscode/PMT/trigger_info.fcl b/icaruscode/PMT/trigger_info.fcl index a0a44be24..e05f2e3d6 100644 --- a/icaruscode/PMT/trigger_info.fcl +++ b/icaruscode/PMT/trigger_info.fcl @@ -1,7 +1,6 @@ #include "services_common_icarus.fcl" #include "services_icarus_simulation.fcl" #include "singles_icarus.fcl" -#include "largeantmodules_icarus.fcl" #include "detsimmodules_ICARUS.fcl" #include "mccheatermodules.fcl" #include "photpropservices.fcl" diff --git a/icaruscode/TPC/Calorimetry/CMakeLists.txt b/icaruscode/TPC/Calorimetry/CMakeLists.txt index a3b1709c5..45b214a16 100644 --- a/icaruscode/TPC/Calorimetry/CMakeLists.txt +++ b/icaruscode/TPC/Calorimetry/CMakeLists.txt @@ -47,6 +47,8 @@ cet_build_plugin(NormalizeDriftSQLite art::tool LIBRARIES ${TOOL_LIBRARIES}) cet_build_plugin(NormalizeDrift art::tool LIBRARIES ${TOOL_LIBRARIES}) cet_build_plugin(NormalizeTPCSQL art::tool LIBRARIES ${TOOL_LIBRARIES}) cet_build_plugin(NormalizeTPC art::tool LIBRARIES ${TOOL_LIBRARIES}) +cet_build_plugin(NormalizeTPCPerPlaneSQL art::tool LIBRARIES ${TOOL_LIBRARIES}) +cet_build_plugin(NormalizeTPCPerPlane art::tool LIBRARIES ${TOOL_LIBRARIES}) cet_build_plugin(NormalizeTPCLocal art::tool LIBRARIES ${TOOL_LIBRARIES}) cet_build_plugin(NormalizeWire art::tool LIBRARIES ${TOOL_LIBRARIES}) cet_build_plugin(NormalizeYZSQL art::tool LIBRARIES ${TOOL_LIBRARIES}) diff --git a/icaruscode/TPC/Calorimetry/NormalizeTPCPerPlaneSQL_tool.cc b/icaruscode/TPC/Calorimetry/NormalizeTPCPerPlaneSQL_tool.cc new file mode 100644 index 000000000..6ed734b13 --- /dev/null +++ b/icaruscode/TPC/Calorimetry/NormalizeTPCPerPlaneSQL_tool.cc @@ -0,0 +1,121 @@ +// Framework Includes +#include "art/Framework/Core/EDProducer.h" +#include "art/Framework/Principal/Event.h" +#include "art/Framework/Principal/Handle.h" +#include "art/Framework/Services/Registry/ServiceHandle.h" +#include "art/Persistency/Common/PtrMaker.h" +#include "art/Utilities/ToolMacros.h" +#include "cetlib/cpu_timer.h" +#include "fhiclcpp/ParameterSet.h" +#include "messagefacility/MessageLogger/MessageLogger.h" + +#include "larevt/CalibrationDBI/Providers/DBFolder.h" + +// Tool include +#include "larreco/Calorimetry/INormalizeCharge.h" + +// Services +#include "lardata/DetectorInfoServices/DetectorClocksService.h" + +// Lab helpers +#include "wda.h" + +// C++ +#include + +namespace icarus { + namespace calo { + +class NormalizeTPCPerPlaneSQL : public INormalizeCharge +{ +public: + NormalizeTPCPerPlaneSQL(fhicl::ParameterSet const &pset); + + void configure(const fhicl::ParameterSet& pset) override; + double Normalize(double dQdx, const art::Event &e, const recob::Hit &h, const geo::Point_t &location, const geo::Vector_t &direction, double t0) override; + +private: + // Configuration + std::string fDBFileName; + std::string fDBTag; + bool fVerbose; + + lariov::DBFolder fDB; + + // Class to hold data from DB + class ScaleInfo { + public: + std::map scale; + }; + + // Helpers + ScaleInfo GetScaleInfo(uint64_t run); + + // Cache run requests + std::map fScaleInfos; +}; + +DEFINE_ART_CLASS_TOOL(NormalizeTPCPerPlaneSQL) + + } // end namespace calo +} // end namespace icarus + + +icarus::calo::NormalizeTPCPerPlaneSQL::NormalizeTPCPerPlaneSQL(fhicl::ParameterSet const &pset): + fDBFileName(pset.get("DBFileName")), + fDBTag(pset.get("DBTag")), + fVerbose(pset.get("Verbose", false)), + fDB(fDBFileName, "", "", fDBTag, true, false) {} + +void icarus::calo::NormalizeTPCPerPlaneSQL::configure(const fhicl::ParameterSet& pset) {} + +icarus::calo::NormalizeTPCPerPlaneSQL::ScaleInfo icarus::calo::NormalizeTPCPerPlaneSQL::GetScaleInfo(uint64_t run) { + // check the cache + if (fScaleInfos.count(run)) { + return fScaleInfos.at(run); + } + + // Look up the run + // + // Translate the run into a fake "timestamp" + fDB.UpdateData((run+1000000000)*1000000000); + + // Collect the run info + ScaleInfo thisscale; + + // Iterate over the rows + for (unsigned ch = 0; ch < 12; ch++) { + double scale; + fDB.GetNamedChannelData(ch, "scale", scale); + + thisscale.scale[ch] = scale; + } + // Set the cache + fScaleInfos[run] = thisscale; + + return thisscale; +} + +double icarus::calo::NormalizeTPCPerPlaneSQL::Normalize(double dQdx, const art::Event &e, + const recob::Hit &hit, const geo::Point_t &location, const geo::Vector_t &direction, double t0) { + // Get the info + ScaleInfo i = GetScaleInfo(e.id().runID().run()); + + // Lookup the TPC, cryo + unsigned tpc = hit.WireID().TPC; + unsigned cryo = hit.WireID().Cryostat; + unsigned plane = hit.WireID().Plane; + + // Get the TPC-Plane index + unsigned itpc_plane = 2*cryo + tpc/2 + plane*4; + + double scale = 1; + + // TODO: what to do if no scale is found? throw an exception?? + if (i.scale.count(itpc_plane)) scale = i.scale.at(itpc_plane); + + if (fVerbose) std::cout << "NormalizeTPCPerPlaneSQL Tool -- Data at Cryo: " << cryo << " TPC: " << tpc << " Plane: " << plane << " itpc_plane: " << itpc_plane << " scale: " << scale << std::endl; + + return dQdx * scale; +} + diff --git a/icaruscode/TPC/Calorimetry/NormalizeTPCPerPlane_tool.cc b/icaruscode/TPC/Calorimetry/NormalizeTPCPerPlane_tool.cc new file mode 100644 index 000000000..5ed3854ef --- /dev/null +++ b/icaruscode/TPC/Calorimetry/NormalizeTPCPerPlane_tool.cc @@ -0,0 +1,158 @@ +// Framework Includes +#include "art/Framework/Core/EDProducer.h" +#include "art/Framework/Principal/Event.h" +#include "art/Framework/Principal/Handle.h" +#include "art/Framework/Services/Registry/ServiceHandle.h" +#include "art/Persistency/Common/PtrMaker.h" +#include "art/Utilities/ToolMacros.h" +#include "cetlib/cpu_timer.h" +#include "fhiclcpp/ParameterSet.h" +#include "messagefacility/MessageLogger/MessageLogger.h" + +// Tool include +#include "larreco/Calorimetry/INormalizeCharge.h" + +// Services +#include "lardata/DetectorInfoServices/DetectorClocksService.h" + +// Lab helpers +#include "wda.h" + +// C++ +#include + +namespace icarus { + namespace calo { + +class NormalizeTPCPerPlane : public INormalizeCharge +{ +public: + NormalizeTPCPerPlane(fhicl::ParameterSet const &pset); + + void configure(const fhicl::ParameterSet& pset) override; + double Normalize(double dQdx, const art::Event &e, const recob::Hit &h, const geo::Point_t &location, const geo::Vector_t &direction, double t0) override; + +private: + // Configuration + int fTimeout; + std::string fURL; + bool fVerbose; + + // Class to hold data from DB + class ScaleInfo { + public: + std::map scale; + }; + + // Helpers + ScaleInfo GetScaleInfo(uint64_t run); + std::string URL(uint64_t run); + + // Cache run requests + std::map fScaleInfos; +}; + +DEFINE_ART_CLASS_TOOL(NormalizeTPCPerPlane) + + } // end namespace calo +} // end namespace icarus + + +icarus::calo::NormalizeTPCPerPlane::NormalizeTPCPerPlane(fhicl::ParameterSet const &pset) { + this->configure(pset); +} + +void icarus::calo::NormalizeTPCPerPlane::configure(const fhicl::ParameterSet& pset) { + fURL = pset.get("URL"); + fTimeout = pset.get("Timeout"); + fVerbose = pset.get("Verbose", false); +} + +std::string icarus::calo::NormalizeTPCPerPlane::URL(uint64_t run) { + return fURL + std::to_string(run); +} + +icarus::calo::NormalizeTPCPerPlane::ScaleInfo icarus::calo::NormalizeTPCPerPlane::GetScaleInfo(uint64_t run) { + // check the cache + if (fScaleInfos.count(run)) { + return fScaleInfos.at(run); + } + + // Otherwise, look it up + int error = 0; + std::string url = URL(run); + + if (fVerbose) std::cout << "NormalizeTPCPerPlane Tool -- New Scale info, requesting data from url:\n" << url << std::endl; + + Dataset d = getDataWithTimeout(url.c_str(), "", fTimeout, &error); + if (error) { + throw cet::exception("NormalizeTPCPerPlane") << "Calibration Database access failed. URL: (" << url << ") Error Code: " << error; + } + + if (fVerbose) std::cout << "NormalizeTPCPerPlane Tool -- Received HTTP response:\n" << getHTTPmessage(d) << std::endl; + + if (getHTTPstatus(d) != 200) { + throw cet::exception("NormalizeTPCPerPlane") + << "Calibration Database access failed. URL: (" << url + << "). HTTP error status: " << getHTTPstatus(d) << ". HTTP error message: " << getHTTPmessage(d); + } + + // Collect the run info + ScaleInfo thisscale; + + // Number of rows + int n_tuple = getNtuples(d); + if (n_tuple < 0) { + throw cet::exception("NormalizeTPCPerPlane") << "Calibration Database access failed. URL: (" << url << ") Bad Tuple Number: " << n_tuple; + } + + // Iterate over the rows + // The first 4 are metadata + for (unsigned row = 4; row < (unsigned)n_tuple; row++) { + Tuple tup = getTuple(d, row); + + int err = 0; + // Get the itpc number + int ch = getLongValue(tup, 0, &err); + if (err) { + throw cet::exception("NormalizeTPCPerPlane") << "Calibration Database access failed. URL: (" << url << ") Failed on tuple access, row: " << row << ", col 0. Error Code: " << err; + } + + // and the scale + double scale = getDoubleValue(tup, 3, &err); + if (err) { + throw cet::exception("NormalizeTPCPerPlane") << "Calibration Database access failed. URL: (" << url << ") Failed on tuple access, row: " << row << ", col 1. Error Code: " << err; + } + + thisscale.scale[ch] = scale; + } + + // Set the cache + fScaleInfos[run] = thisscale; + + return thisscale; +} + +double icarus::calo::NormalizeTPCPerPlane::Normalize(double dQdx, const art::Event &e, + const recob::Hit &hit, const geo::Point_t &location, const geo::Vector_t &direction, double t0) { + // Get the info + ScaleInfo i = GetScaleInfo(e.id().runID().run()); + + // Lookup the TPC, cryo + unsigned tpc = hit.WireID().TPC; + unsigned cryo = hit.WireID().Cryostat; + unsigned plane = hit.WireID().Plane; + + // Get the TPC-Plane index + unsigned itpc_plane = 2*cryo + tpc/2 + plane*4; + + double scale = 1; + + // TODO: what to do if no scale is found? throw an exception?? + if (i.scale.count(itpc_plane)) scale = i.scale.at(itpc_plane); + + if (fVerbose) std::cout << "NormalizeTPCPerPlane Tool -- Data at Cryo: " << cryo << " TPC: " << tpc << " Plane: " << plane << " itpc_plane: " << itpc_plane << " scale: " << scale << std::endl; + + return dQdx * scale; +} + diff --git a/icaruscode/TPC/Calorimetry/calorimetryICARUS.fcl b/icaruscode/TPC/Calorimetry/calorimetryICARUS.fcl index 6ca52f145..d482bb16e 100644 --- a/icaruscode/TPC/Calorimetry/calorimetryICARUS.fcl +++ b/icaruscode/TPC/Calorimetry/calorimetryICARUS.fcl @@ -6,10 +6,11 @@ BEGIN_PROLOG icarus_calorimetryalgdata: @local::standard_calorimetryalgdata icarus_calorimetryalgmc: @local::standard_calorimetryalgmc -# Calorimetry constants from G. Putnam (Nov 2022) -# Informed by MC calibration -- docdb 28639. -# NOTE: needs to be revisted if/when the data processing is updated -icarus_calorimetryalgmc.CalAreaConstants: [0.01343, 0.01338, 0.01219] +# GP 8/4/25: with re-calibration and application of EMB recombination, +# MC and data gains match. Note that we should not being making any +# updates to the MC that would cause the MC gain to differ from that of +# data. +icarus_calorimetryalgmc.CalAreaConstants: @local::icarus_data_calconst icarus_calorimetryalgmc.ModBoxA: 0.904 icarus_calorimetryalgmc.ModBoxBTF1: "[0]/TMath::Sqrt(TMath::Sin(x*TMath::Pi()/180)**2 + TMath::Cos(x*TMath::Pi()/180)**2/[1]**2)" icarus_calorimetryalgmc.ModBoxBParam: [0.204, 1.25] diff --git a/icaruscode/TPC/Calorimetry/normtools_icarus.fcl b/icaruscode/TPC/Calorimetry/normtools_icarus.fcl index 2a69eb647..0299e5892 100644 --- a/icaruscode/TPC/Calorimetry/normtools_icarus.fcl +++ b/icaruscode/TPC/Calorimetry/normtools_icarus.fcl @@ -24,9 +24,9 @@ yznorm: { } tpcgain: { - tool_type: NormalizeTPC + tool_type: NormalizeTPCPerPlane Timeout: 200 - URL: "https://dbdata0vm.fnal.gov:9443/icarus_con_prod/app/data?f=tpc_dqdxcalibration_data&t=" + URL: "https://dbdata0vm.fnal.gov:9443/icarus_con_prod/app/data?f=tpc_dqdxcalibration_allplanes_data&t=" Verbose: false } @@ -38,9 +38,9 @@ driftnorm_sql: { } tpcgain_sql: { - tool_type: NormalizeTPCSQL - DBFileName: tpc_dqdxcalibration_data - DBTag: @local::ICARUS_Calibration_GlobalTags.tpc_dqdxcalibration_data + tool_type: NormalizeTPCPerPlaneSQL + DBFileName: tpc_dqdxcalibration_allplanes_data + DBTag: @local::ICARUS_Calibration_GlobalTags.tpc_dqdxcalibration_allplanes_data Verbose: false } @@ -59,10 +59,11 @@ yznorm_sql: { } #icarus_calonormtools: [@local::driftnorm, @local::yznorm, @local::tpcgain] - icarus_calonormtools: [@local::driftnorm_sql, @local::yznorm_sql, @local::tpcgain_sql] +icarus_calonormtools: [@local::driftnorm_sql, @local::yznorm_sql, @local::tpcgain_sql] -# Gain with angular dep. recombination. Measurement from: https://arxiv.org/pdf/2407.12969 -# Assume equal on planes -- this is __wrong__ -- will need to be fixed when they are calibrated -icarus_data_calconst: [0.0133333, 0.0133333, 0.0133333] +# GP 8/4/25 -- Update gain to re-measurement with Run 2 stopping muons and +# fixed recombination. Details about this change are located in the Run 2+4 +# Calibration Tech Note (SBN DocDB 44460). +icarus_data_calconst: [0.016751, 0.012755, 0.012513] END_PROLOG diff --git a/icaruscode/TPC/ICARUSWireCell/detsimmodules_wirecell_ICARUS.fcl b/icaruscode/TPC/ICARUSWireCell/detsimmodules_wirecell_ICARUS.fcl index 6bc7c326f..8868eb3e1 100644 --- a/icaruscode/TPC/ICARUSWireCell/detsimmodules_wirecell_ICARUS.fcl +++ b/icaruscode/TPC/ICARUSWireCell/detsimmodules_wirecell_ICARUS.fcl @@ -2,6 +2,8 @@ #include "services_basic_icarus.fcl" // We need this for diffusion #include "simulationservices_icarus.fcl" +// lookup calibration tags +#include "calibration_database_GlobalTags_icarus.fcl" BEGIN_PROLOG @@ -35,6 +37,11 @@ icarus_simwire_wirecell: file_rcresp: "icarus_fnal_rc_tail.json" # use the RCResponse by default cathode_input_format: "array" # scalar (flat) or array (bent) SimEnergyDepositLabel: "ionization" + # yz map config -- default to Run 2 + YZScaleMapJson: "yzmap_gain_icarus_v4_run2.json" + YZMapJson: "yzmap_icarus_v3_run2.json" + DBFileName: "tpc_elifetime_data" + DBTag: @local::ICARUS_Calibration_GlobalTags.tpc_elifetime_data } structs: { # load values from simulationservices_icarus.fcl @@ -54,19 +61,18 @@ icarus_simwire_wirecell: overlay_drifter: false # default drifter by default # Gain and shaping time - gain0: 17.05212 # mV/fC - gain1: 12.6181926 # mV/fC - gain2: 13.0261362 # mV/fC + gain0: 18.0839 # mV/fC + gain1: 12.2379 # mV/fC + gain2: 13.8819 # mV/fC shaping0: 1.3 # us shaping1: 1.45 # us shaping2: 1.3 # us - # Time offsets for truth matching - time_offset_u: 0.0 # us - time_offset_v: 0.0 # us - time_offset_y: 0.0 # us - + # Time offsets for truth matching -- tuned to 2D deconvolution output + time_offset_u: 2.53 # us + time_offset_v: 2.41 # us + time_offset_y: 2.53 # us } } } @@ -81,6 +87,14 @@ icarus_simwire_wirecell_SConly.wcls_main.outputers:[ icarus_simwire_wirecell_shifted: @local::icarus_simwire_wirecell icarus_simwire_wirecell_shifted.wcls_main.params.SimEnergyDepositLabel: "shifted" +icarus_simwire_wirecell_shifted_overlay: @local::icarus_simwire_wirecell_shifted +icarus_simwire_wirecell_shifted_overlay.wcls_main.structs.coh_noise_scale: 0.0 # disable noise +icarus_simwire_wirecell_shifted_overlay.wcls_main.structs.int_noise_scale: 0.0 # ditto +icarus_simwire_wirecell_shifted_overlay.wcls_main.structs.overlay_drifter: true +icarus_simwire_wirecell_shifted_overlay.wcls_main.plugins: [@sequence::icarus_simwire_wirecell_shifted_overlay.wcls_main.plugins, "WireCellICARUSDrifter"] +icarus_simwire_wirecell_shifted_overlay.wcls_main.inputers: ["wclsSimDepoSetSource:electron", "wclsICARUSDrifter:drifter"] +icarus_simwire_wirecell_shifted_overlay.wcls_main.params.cathode_input_format: "scalar" + icarus_simwire_wirecell_filtersed: @local::icarus_simwire_wirecell icarus_simwire_wirecell_filtersed.wcls_main.params.SimEnergyDepositLabel: "filtersed" diff --git a/icaruscode/TPC/ICARUSWireCell/icarus/sim.jsonnet b/icaruscode/TPC/ICARUSWireCell/icarus/sim.jsonnet index e11d5c8d5..bd64391bf 100644 --- a/icaruscode/TPC/ICARUSWireCell/icarus/sim.jsonnet +++ b/icaruscode/TPC/ICARUSWireCell/icarus/sim.jsonnet @@ -111,8 +111,8 @@ function(params, tools) { ar39activity: 0, // no simulated activity // DB config - DBFileName: "tpc_elifetime_data", - DBTag: "v2r1", + DBFileName: std.extVar("DBFileName"), + DBTag: std.extVar("DBTag"), ELifetimeCorrection: true, Verbose: false, TPC: 0, diff --git a/icaruscode/TPC/ICARUSWireCell/icarus/wcls-multitpc-sim-drift-simchannel-refactored.jsonnet b/icaruscode/TPC/ICARUSWireCell/icarus/wcls-multitpc-sim-drift-simchannel-refactored.jsonnet index e5a0210df..84e574bcb 100644 --- a/icaruscode/TPC/ICARUSWireCell/icarus/wcls-multitpc-sim-drift-simchannel-refactored.jsonnet +++ b/icaruscode/TPC/ICARUSWireCell/icarus/wcls-multitpc-sim-drift-simchannel-refactored.jsonnet @@ -166,12 +166,21 @@ local wcls_output = { sp_thresholds: wcls.output.thresholds(name='spthresholds', tags=['threshold']), }; -//local deposio = io.numpy.depos(output); -local drifter = sim.drifter; +local overlay_drifter = std.extVar("overlay_drifter"); + +local drifter = if overlay_drifter then { + local xregions = wc.unique_list(std.flattenArrays([v.faces for v in params.det.volumes])), + type: "wclsICARUSDrifter", + data: params.lar + sim.overlay_drifter_data { + TPC: 0, + charge_scale: 1 + }, + } else sim.drifter; + local setdrifter = g.pnode({ type: 'DepoSetDrifter', data: { - drifter: "Drifter" + drifter: if overlay_drifter then "wclsICARUSDrifter" else "Drifter" } }, nin=1, nout=1, uses=[drifter]); diff --git a/icaruscode/TPC/ICARUSWireCell/icarus/wcls-multitpc-sim-drift-simchannel-yzsim-refactored.jsonnet b/icaruscode/TPC/ICARUSWireCell/icarus/wcls-multitpc-sim-drift-simchannel-yzsim-refactored.jsonnet index db363894c..f2ed2310e 100644 --- a/icaruscode/TPC/ICARUSWireCell/icarus/wcls-multitpc-sim-drift-simchannel-yzsim-refactored.jsonnet +++ b/icaruscode/TPC/ICARUSWireCell/icarus/wcls-multitpc-sim-drift-simchannel-yzsim-refactored.jsonnet @@ -44,22 +44,22 @@ local params = base { // fields: [ std.extVar('files_fields'), ] fields: [ - "icarus_fnal_fit_ks_P0nom_P1bin0.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin1.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin2.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin3.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin4.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin5.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin6.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin7.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin8.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin9.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin10.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin11.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin12.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin13.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin14.json.bz2", - "icarus_fnal_fit_ks_P0nom_P1bin15.json.bz2"] + "icarus_fnal_fit_ks_P0nom_P1bin0_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin1_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin2_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin3_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin4_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin5_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin6_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin7_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin8_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin9_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin10_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin11_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin12_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin13_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin14_shifted.json.bz2", + "icarus_fnal_fit_ks_P0nom_P1bin15_shifted.json.bz2"] }, rc_resp: if std.extVar('file_rcresp') != "" then @@ -221,7 +221,7 @@ local scalers = [{ type: "Scaler", name: "scaler%d" %n, //%std.floor(n/45), data: params.lar { - yzmap_scale_filename: 'yzmap_gain_icarus_v3_run2.json', + yzmap_scale_filename: std.extVar('YZScaleMapJson'), bin_width: 10*wc.cm, tpc_width: 1500*wc.mm, bin_height: 10*wc.cm, @@ -416,7 +416,7 @@ local deposetfilteryz = [ g.pnode({ type: 'DepoSetFilterYZ', name: 'deposetfilteryz_resp%d-'%std.mod(r,15)+'plane%d-'%std.mod(std.floor(r/15),3)+tools.anodes[std.floor(r/45)].name, data: { - yzmap_filename: 'yzmap_icarus_v3_run2.json', + yzmap_filename: std.extVar('YZMapJson'), bin_width: 10*wc.cm, tpc_width: 1500*wc.mm, bin_height: 10*wc.cm, diff --git a/icaruscode/TPC/SignalProcessing/HitFinder/HitMerger_module.cc b/icaruscode/TPC/SignalProcessing/HitFinder/HitMerger_module.cc index 993b74ed3..a03d5a6b6 100644 --- a/icaruscode/TPC/SignalProcessing/HitFinder/HitMerger_module.cc +++ b/icaruscode/TPC/SignalProcessing/HitFinder/HitMerger_module.cc @@ -37,6 +37,8 @@ #include "lardata/DetectorInfoServices/DetectorPropertiesService.h" #include "lardata/DetectorInfoServices/LArPropertiesService.h" +#include "sbnobj/ICARUS/TPC/ChannelROI.h" + class HitMerger : public art::EDProducer { public: @@ -62,8 +64,13 @@ class HitMerger : public art::EDProducer /** * @brief Create raw::RawDigit to recob::Hit associations */ - void makeRawDigitAssns(const art::Event&, art::Assns&, RecobHitToPtrMap&) const; + + /** + * @brief Create recob::ChannelROI to recob::Hit associations + */ + void makeChanROIAssns(const art::Event&, art::Assns&, RecobHitToPtrMap&) const; + // define vector for hits to make sure of uniform use using HitPtrVector = std::vector>; @@ -87,6 +94,7 @@ HitMerger::HitMerger(fhicl::ParameterSet const & pset) : EDProducer{pset} produces< std::vector>(); produces< art::Assns>(); produces< art::Assns>(); + produces< art::Assns>(); // Report. mf::LogInfo("HitMerger") << "HitMerger configured\n"; @@ -139,6 +147,9 @@ void HitMerger::produce(art::Event & evt) /// Associations with raw digits. std::unique_ptr> rawDigitAssns(new art::Assns); + /// Associations with channel ROIs. + std::unique_ptr> chanROIAssns(new art::Assns); + RecobHitToPtrMap recobHitToPtrMap; // Use this handy art utility to make art::Ptr objects to the new recob::Hits for use in the output phase @@ -172,11 +183,14 @@ void HitMerger::produce(art::Event & evt) makeWireAssns(evt, *wireAssns, recobHitToPtrMap); makeRawDigitAssns(evt, *rawDigitAssns, recobHitToPtrMap); + + makeChanROIAssns(evt, *chanROIAssns, recobHitToPtrMap); // Move everything into the event evt.put(std::move(outputHitPtrVec)); evt.put(std::move(wireAssns)); evt.put(std::move(rawDigitAssns)); + evt.put(std::move(chanROIAssns)); return; } @@ -264,6 +278,48 @@ void HitMerger::makeRawDigitAssns(const art::Event& evt, art::Assns &chanROIAssns, RecobHitToPtrMap& recobHitPtrMap) const +{ + // Let's make sure the input associations container is empty + chanROIAssns = art::Assns(); + + // First task is to recover all of the previous chanROI <--> hit associations and map them by channel number + // Create the temporary container + std::unordered_map> channelToChanROIMap; + + // Go through the list of input sources and fill out the map + for(const auto& inputTag : HitMergerfHitProducerLabelVec) + { + art::ValidHandle> hitHandle = evt.getValidHandle>(inputTag); + + art::FindOneP hitToChanROIAssns(hitHandle, evt, inputTag); + + if (hitToChanROIAssns.isValid()) + { + for(size_t chanROIIdx = 0; chanROIIdx < hitToChanROIAssns.size(); chanROIIdx++) + { + art::Ptr chanROI = hitToChanROIAssns.at(chanROIIdx); + + channelToChanROIMap[chanROI->Channel()] = chanROI; + } + } + } + + // Now fill the container + for(const auto& hitPtrPair : recobHitPtrMap) + { + raw::ChannelID_t channel = hitPtrPair.first->Channel(); + + std::unordered_map>::iterator chanChanROIItr = channelToChanROIMap.find(channel); + + if (!(chanChanROIItr != channelToChanROIMap.end())) continue; + + chanROIAssns.addSingle(chanChanROIItr->second, hitPtrPair.second); + } + + return; +} //---------------------------------------------------------------------------- /// End job method. diff --git a/icaruscode/TPC/SignalProcessing/HitFinder/hitfindermodules_icarus.fcl b/icaruscode/TPC/SignalProcessing/HitFinder/hitfindermodules_icarus.fcl index fdce3c80e..093524b07 100644 --- a/icaruscode/TPC/SignalProcessing/HitFinder/hitfindermodules_icarus.fcl +++ b/icaruscode/TPC/SignalProcessing/HitFinder/hitfindermodules_icarus.fcl @@ -124,5 +124,15 @@ icarus_hitconverter: DaignosticOutput: false } +icarus_hitmerger_cryoE: { + module_type: HitMerger + HitProducerLabelVec: ["gaushit2dTPCEW", "gaushit2dTPCEE"] +} + +icarus_hitmerger_cryoW: { + module_type: HitMerger + HitProducerLabelVec: ["gaushit2dTPCWW", "gaushit2dTPCWE"] +} + END_PROLOG diff --git a/icaruscode/TPC/SignalProcessing/RawDigitFilter/tpcnoise.fcl b/icaruscode/TPC/SignalProcessing/RawDigitFilter/tpcnoise.fcl index 542522f18..e99674e11 100644 --- a/icaruscode/TPC/SignalProcessing/RawDigitFilter/tpcnoise.fcl +++ b/icaruscode/TPC/SignalProcessing/RawDigitFilter/tpcnoise.fcl @@ -1,11 +1,3 @@ -# #include "seedservice.fcl" -# #include "singles.fcl" -# #include "larproperties.fcl" -# #include "magfield_larsoft.fcl" -# #include "largeantmodules.fcl" -# #include "mcreco.fcl" -#include "services_common_icarus.fcl" -#include "reco_icarus.fcl" #include "reco_icarus_driver_common.fcl" process_name: TPCNoise @@ -17,11 +9,6 @@ source: maxEvents: 10 # Number of events to create } -#services: -#{ -# TFileService: { fileName: "Run4398" } -#} - # Define and configure some modules to do work on each event. # First modules are defined; they are scheduled later. # Modules are grouped by type. diff --git a/icaruscode/TPC/SignalProcessing/RawDigitFilter/tpcnoiseMC.fcl b/icaruscode/TPC/SignalProcessing/RawDigitFilter/tpcnoiseMC.fcl index df8e102a2..ba133722b 100644 --- a/icaruscode/TPC/SignalProcessing/RawDigitFilter/tpcnoiseMC.fcl +++ b/icaruscode/TPC/SignalProcessing/RawDigitFilter/tpcnoiseMC.fcl @@ -1,11 +1,3 @@ -# #include "seedservice.fcl" -# #include "singles.fcl" -# #include "larproperties.fcl" -# #include "magfield_larsoft.fcl" -# #include "largeantmodules.fcl" -# #include "mcreco.fcl" -#include "services_common_icarus.fcl" -#include "reco_icarus.fcl" #include "reco_icarus_driver_common.fcl" process_name: TPCNoise @@ -17,11 +9,6 @@ source: maxEvents: 10 # Number of events to create } -#services: -#{ -# TFileService: { fileName: "Run4398" } -#} - # Define and configure some modules to do work on each event. # First modules are defined; they are scheduled later. # Modules are grouped by type.