Source code for model.model_utils
#!/usr/bin/python3
"""Helper functions calculations related to model parameters."""
import math
from simtools.utils import names
__all__ = [
"compute_telescope_transmission",
"is_two_mirror_telescope",
]
[docs]
def compute_telescope_transmission(pars: list[float], off_axis: float) -> float:
"""
Compute telescope transmission (0 < T < 1) for a given off-axis angle.
The telescope transmission depends on the MC model used.
Parameters
----------
pars: list of float
Parameters of the telescope transmission. Len(pars) should be 5 or 6.
off_axis: float
Off-axis angle in deg.
Returns
-------
float
Telescope transmission.
"""
_deg_to_rad = math.pi / 180.0
if pars[1] == 0:
return pars[0]
t = math.sin(off_axis * _deg_to_rad) / (pars[3] * _deg_to_rad)
return pars[0] / (1.0 + pars[2] * t ** pars[4])
[docs]
def is_two_mirror_telescope(telescope_model_name: str) -> bool:
"""
Determine if the telescope model is a two-mirror telescope.
Parameters
----------
telescope_model_name: str
Name of the telescope model.
Returns
-------
bool
True if it is a two-mirror telescope.
"""
tel_type = names.get_array_element_type_from_name(telescope_model_name)
if "SST" in tel_type or "SCT" in tel_type:
return True
return False