From 51d04de2d482e57d9f43ae365c36b46e02b02137 Mon Sep 17 00:00:00 2001 From: Eduardo Rodrigues Date: Fri, 9 Aug 2024 17:21:36 +0200 Subject: [PATCH] EvtGen uses GeV, not the standard HEP system of units, hence MeV! (#455) * Add hepunits as an explicit dependency * Adapt to the fact that EvtGen uses GeV rather than MeV! * Adapt tests accordingly, and enhance them * style: pre-commit fixes * Fix a silly typo! * Please MyPy since the try statement accommodates the optional return --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> --- pyproject.toml | 1 + src/decaylanguage/dec/dec.py | 18 +++++++++++++----- tests/data/defs-aliases-chargeconj.dec | 12 ++++++++++-- tests/dec/test_dec.py | 3 ++- 4 files changed, 26 insertions(+), 8 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index c4beda1f..9a6786aa 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -48,6 +48,7 @@ dependencies = [ "numpy>=1.12", "pandas>=0.22", "particle>=0.22.0", + "hepunits>=2.0.0", "plumbum>=1.7.0", ] dynamic = ["version"] diff --git a/src/decaylanguage/dec/dec.py b/src/decaylanguage/dec/dec.py index 12833eaa..02059558 100644 --- a/src/decaylanguage/dec/dec.py +++ b/src/decaylanguage/dec/dec.py @@ -47,6 +47,7 @@ from pathlib import Path from typing import Any, Callable, Iterable +from hepunits import GeV from lark import Lark, Token, Transformer, Tree, Visitor from lark.lexer import TerminalDef from particle import Particle @@ -460,9 +461,12 @@ def get_particle_property_definitions(self) -> dict[str, dict[str, float]]: Note ---- - 1) Particles are often defined via aliases and post-processing may be needed + 1) Masses and widths are in GeV in EvtGen, hence the "Particle " statement + needs to use GeV! A conversion to MeV may be done on the fly when information is required + from the Particle package, which uses MeV, the (standard) HEP System of Units. + 2) Particles are often defined via aliases and post-processing may be needed to match the mass and width to the actual particle. - 2) The mass (width) parameter is compulsory (optional). + 3) The mass (width) parameter is compulsory (optional). When not specified, the width is taken from the particle or alias. """ self._check_parsing() @@ -1629,9 +1633,12 @@ def get_particle_property_definitions(parsed_file: Tree) -> dict[str, dict[str, Note ---- - 1) Particles are often defined via aliases and post-processing may be needed + 1) Masses and widths are in GeV in EvtGen, hence the "Particle " statement + needs to use GeV! A conversion to MeV may be done on the fly when information is required + from the Particle package, which uses MeV, the (standard) HEP System of Units. + 2) Particles are often defined via aliases and post-processing may be needed to match the mass and width to the actual particle. - 2) The mass (width) parameter is compulsory (optional). + 3) The mass (width) parameter is compulsory (optional). When not specified, the width is taken from the particle or alias. Parameters @@ -1650,7 +1657,8 @@ def get_set_width_or_default(children: list[Tree]) -> float: token_name: str = children[0].value try: pname: str = aliases.get(token_name, token_name) if aliases else token_name - return Particle.from_evtgen_name(pname).width # type: ignore[return-value] + # Convert the width to GeV ! + return Particle.from_evtgen_name(pname).width / GeV # type: ignore[operator] except Exception as err: raise RuntimeError( f"Particle name/alias {token_name!r} not found! Check your dec file(s)!" diff --git a/tests/data/defs-aliases-chargeconj.dec b/tests/data/defs-aliases-chargeconj.dec index aa9692d4..cb850f95 100644 --- a/tests/data/defs-aliases-chargeconj.dec +++ b/tests/data/defs-aliases-chargeconj.dec @@ -253,6 +253,7 @@ ChargeConj Omega_cc+sig anti-Omega_cc-sig # Specifications typically relevant when dealing with lineshapes, # and typically using particle name aliases +# Important note on values below: masses and widths are in GeV in EvtGen! # Alias MyK*0 K*0 Particle MyK*0 0.892 0.051 # To set a particle mass and width @@ -280,9 +281,16 @@ LSNONRELBW rho0 BlattWeisskopf rho0 3.0 IncludeBirthFactor rho0 no IncludeDecayFactor rho0 yes -# Redefined particles only need to specify the mass, and the width is optional +# +# Redefined particles only need to specify the mass, and the width is optional, +# in which case the value is taken from the alias +# and will correspond to the nominal mass as provided by the Particle package Alias MyRho0 rho0 -Particle MyRho0 0.8 +Particle MyRho0 0.77 +# +# Redefine one of the mass or width of a particle (not an alias, as in the cases above) +# Unlike above, the width is taken from the particle since no alias is present +Particle chi_c0 3.42 # Pythia 8 parameter modifications # (Very important that there are no blank spaces in the parameter string!) diff --git a/tests/dec/test_dec.py b/tests/dec/test_dec.py index 9a5e8be2..21c4a712 100644 --- a/tests/dec/test_dec.py +++ b/tests/dec/test_dec.py @@ -197,7 +197,8 @@ def test_particle_property_definitions(): "MyK*0": {"mass": 0.892, "width": 0.051}, "MyPhi": {"mass": 1.02, "width": 0.004}, "rho0": {"mass": 0.8, "width": 0.2}, - "MyRho0": {"mass": 0.8, "width": 147.4}, + "MyRho0": {"mass": 0.77, "width": 0.1474}, + "chi_c0": {"mass": 3.42, "width": 0.0107}, }