Skip to content

Commit

Permalink
Allow for ignoring asymmetric features
Browse files Browse the repository at this point in the history
  • Loading branch information
gipert committed Dec 4, 2024
1 parent e2a929b commit 9c60012
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 2 deletions.
11 changes: 9 additions & 2 deletions src/legendhpges/make_hpge.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
def make_hpge(
metadata: str | dict | AttrsDict,
registry: geant4.Registry = default_g4_registry,
allow_cylindrical_asymmetry: bool = True,
**kwargs,
) -> geant4.LogicalVolume:
"""Construct an HPGe detector logical volume based on the detector metadata.
Expand All @@ -32,6 +33,10 @@ def make_hpge(
detector static properties.
registry
pyg4ometry Geant4 registry instance.
allow_cylindrical_asymmetry
if true, use derived classes for detectors that break cylindrical
symmetry. Otherwise, just build them using the base class (i.e.
ignoring the non-symmetric features).
Other Parameters
----------------
Expand Down Expand Up @@ -80,7 +85,8 @@ def make_hpge(
kwargs["name"] = gedet_meta.name

if gedet_meta.type == "ppc":
if gedet_meta.name == "P00664B":
# asymmetric detector
if allow_cylindrical_asymmetry and gedet_meta.name == "P00664B":
gedet = P00664B(gedet_meta, registry=registry, **kwargs)
else:
gedet = PPC(gedet_meta, registry=registry, **kwargs)
Expand All @@ -91,7 +97,8 @@ def make_hpge(
elif gedet_meta.type == "icpc":
if gedet_meta.name == "V07646A":
gedet = V07646A(gedet_meta, registry=registry, **kwargs)
elif gedet_meta.name == "V02160A":
# asymmetric detector
elif allow_cylindrical_asymmetry and gedet_meta.name == "V02160A":
gedet = V02160A(gedet_meta, registry=registry, **kwargs)
elif gedet_meta.name == "V02162B":
gedet = V02162B(gedet_meta, registry=registry, **kwargs)
Expand Down
7 changes: 7 additions & 0 deletions tests/test_det_profile.py
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,13 @@ def test_make_p00664b():

assert len(gedet._decode_polycone_coord()[0]) == len(gedet.surfaces) + 1

gedet = make_hpge(
configs.P00664B, name="P00664B_bis", allow_cylindrical_asymmetry=False
)
assert isinstance(gedet, PPC)
assert not isinstance(gedet, P00664B)
assert isinstance(gedet.solid, geant4.solid.GenericPolycone)


def test_make_v02162b():
gedet = make_hpge(configs.V02162B)
Expand Down

0 comments on commit 9c60012

Please sign in to comment.