Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add counters to propagation summary #3602

Merged
Merged
Show file tree
Hide file tree
Changes from 10 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -92,19 +92,24 @@ class RootPropagationSummaryWriter : public WriterT<PropagationSummaries> {
/// track number
int m_trackNr = 0;

// initial trajectory parameters
/// initial trajectory parameters
float m_d0 = 0;
float m_z0 = 0;
float m_phi = 0;
float m_theta = 0;
float m_qOverP = 0;
float m_t = 0;

// derived initial trajectory parameters
/// derived initial trajectory parameters
float m_eta = 0;
float m_pt = 0;
float m_p = 0;

/// Propagation summary statstics
int m_nSensitives = 0;
int m_nMaterials = 0;
int m_nPortals = 0;

// steper statistics
int m_nSteps = 0;
int m_nStepTrials = 0;
Expand Down
26 changes: 26 additions & 0 deletions Examples/Io/Root/src/RootPropagationSummaryWriter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,10 @@ RootPropagationSummaryWriter::RootPropagationSummaryWriter(
m_outputTree->Branch("pt", &m_pt);
m_outputTree->Branch("p", &m_p);

m_outputTree->Branch("nSensitives", &m_nSensitives);
m_outputTree->Branch("nMaterials", &m_nMaterials);
m_outputTree->Branch("nPortals", &m_nPortals);

m_outputTree->Branch("nSteps", &m_nSteps);
m_outputTree->Branch("nStepTrials", &m_nStepTrials);
m_outputTree->Branch("pathLength", &m_pathLength);
Expand Down Expand Up @@ -134,6 +138,28 @@ ProcessCode RootPropagationSummaryWriter::writeT(
m_nStepTrials = static_cast<int>(summary.nStepTrials);
m_pathLength = static_cast<int>(summary.pathLength);

m_nMaterials = 0;
m_nSensitives = 0;
m_nPortals = 0;

// Loop over the steps & count for the statistics
std::ranges::for_each(summary.steps, [&](const auto& step) {
// Check if the step is a sensitive step
if (step.geoID.sensitive() > 0) {
m_nSensitives++;
}
// Check if the step is a portal step
if (step.geoID.boundary() > 0) {
m_nPortals++;
}

if (step.surface != nullptr) {
// Check if the step is a material step
if (step.surface->surfaceMaterial() != nullptr) {
m_nMaterials++;
}
}
});
m_outputTree->Fill();
}

Expand Down
2 changes: 1 addition & 1 deletion Examples/Python/tests/root_file_hashes.txt
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ test_itk_seeding__estimatedparams.root: 7e3acb54fcaabae19fe5b8601bd5bd3e5f65d6a1
test_itk_seeding__performance_seeding.root: 78ebda54cd0f026ba4b7f316724ffd946de56a932735914baf1b7bba9505c29d
test_itk_seeding__particles.root: 0b6f4ad438010ac48803d48ed98e80b5e87d310bae6c2c02b16cd94d7a4d7d07
test_itk_seeding__particles_simulation.root: ef0246069aa697019f28a8b270a68de95312cae5f2f2c74848566c3ce4f70363
test_propagation__propagation_summary.root: 85d877c3a48a6235d3d5a398b47130d5d17d4d3724128ccb339d8174e71a5bb0
test_propagation__propagation_summary.root: 280c1a6fcfe71974ac39587b4afad27a31640bec42ca6537cc92e2d5e09d7ed6
test_material_recording__geant4_material_tracks.root: c022b9362249b29f57a07926b20644e3ab4ab8ebcf03f773fbf46c446fc1a0a1
test_truth_tracking_gsf[generic]__trackstates_gsf.root: 974968d9c867a18e2477fb241288e8d8a4a5e7499495d3e1a7b9cafa26c6dda5
test_truth_tracking_gsf[generic]__tracksummary_gsf.root: b698e3d21eacc34fc8b0ce1d3fbe07405a4b8b549e07f0160573e64c3b401f04
Expand Down
130 changes: 130 additions & 0 deletions Examples/Scripts/Propagation/propagation_summary.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,130 @@
import matplotlib.pyplot as plt
import numpy as np
import pandas as pd
import argparse
import uproot
import seaborn as sns

p = argparse.ArgumentParser()

p.add_argument(
"-i",
"--input",
nargs="+",
type=str,
default="",
help="Input file(s) with propagation summary",
)

p.add_argument(
"-l",
"--label",
nargs="+",
type=str,
default="",
help="Input label(s) for the propagation summary",
)

p.add_argument(
"-c",
"--color",
nargs="+",
type=str,
default="",
help="Input label(s) for the propagation summary",
)

p.add_argument(
"-m",
"--marker",
nargs="+",
type=str,
default=["o"],
choices=[
"o",
"s",
"D",
"v",
"^",
"<",
">",
"p",
"P",
"*",
"h",
"H",
"+",
"x",
"X",
"d",
],
help="Input label(s) for the propagation summary",
)

p.add_argument(
"-o",
"--output",
type=str,
default="",
help="Output file base name",
)

args = p.parse_args()

try:
asalzburger marked this conversation as resolved.
Show resolved Hide resolved

assert len(args.input) == len(args.label) == len(args.marker)

fig, ax = plt.subplots(1, 1, figsize=(11, 10))

eta_bins = np.linspace(-4, 4, 100)
eta_centers = 0.5 * (eta_bins[:-1] + eta_bins[1:])
eta_width = 8.0 / 100

for irfile, label, marker in zip(args.input, args.label, args.marker):
# load the tree
tree = uproot.open(args.input[ir] + ":" + "propagation_summary")
# get the numpy arrays
eta = tree["eta"].array(library="np")
phi = tree["phi"].array(library="np")
sens = tree["nSensitives"].array(library="np")
portals = tree["nPortals"].array(library="np")
materials = tree["nMaterials"].array(library="np")

df = pd.DataFrame(
{
"eta": eta,
"phi": phi,
"sens": sens,
"portals": portals,
"materials": materials,
}
)

df["eta_bin"] = np.digitize(eta, bins=eta_bins)

# grouby bin, so we can calculate stuff
eta_binned = df.groupby("eta_bin")
sens_result = eta_binned["sens"].agg(["mean", "sem"])
sens_result["eta"] = eta_centers
sens_result["xerr"] = eta_width / 2

sens_result.plot(
x="eta",
y="mean",
xerr="xerr",
yerr="sem",
linestyle="none",
capsize=1,
marker=args.marker[ir],
label=args.label[ir],
ax=ax,
)
ax.set_xlabel(r"$\eta$")
ax.set_ylabel("Avg. Number of sensitive modules / track")

fig.show()

except:
print("The number of input files and labels must match")
exit()
10 changes: 5 additions & 5 deletions Examples/Scripts/Python/geomodel.py
Original file line number Diff line number Diff line change
Expand Up @@ -129,16 +129,16 @@ def main():
# Read the geometry model from the database
gmTree = acts.geomodel.readFromDb(args.input)

gmFactoryConfig = gm.GeoModelDetectorSurfaceFactory.Config()
gmFactoryConfig = gm.GeoModelDetectorObjectFactory.Config()
gmFactoryConfig.materialList = args.material_list
gmFactoryConfig.nameList = args.name_list
gmFactoryConfig.convertSubVolumes = args.convert_subvols
gmFactory = gm.GeoModelDetectorSurfaceFactory(gmFactoryConfig, logLevel)
gmFactory = gm.GeoModelDetectorObjectFactory(gmFactoryConfig, logLevel)
# The options
gmFactoryOptions = gm.GeoModelDetectorSurfaceFactory.Options()
gmFactoryOptions = gm.GeoModelDetectorObjectFactory.Options()
gmFactoryOptions.queries = args.queries
# The Cache & construct call
gmFactoryCache = gm.GeoModelDetectorSurfaceFactory.Cache()
gmFactoryCache = gm.GeoModelDetectorObjectFactory.Cache()
gmFactory.construct(gmFactoryCache, gContext, gmTree, gmFactoryOptions)

# All surfaces from GeoModel
Expand Down Expand Up @@ -236,7 +236,7 @@ def main():
[[ivol, volumeOptions] for ivol in range(detector.numberVolumes())],
[
["xy", ["sensitives", "portals"], xyRange],
["zr", ["", "", "materials"], zrRange],
["zr", ["sensitives", "portals", "materials"], zrRange],
],
args.output + "_detector",
)
Expand Down
Loading