ATLAS Offline Software
Loading...
Searching...
No Matches
mu2tau.py
Go to the documentation of this file.
1# Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration
2
3from AthenaCommon import Logging
4from ...decorators import timed
5from ...utility import LHE
6import shutil
7
8
9logger = Logging.logging.getLogger("PowhegControl")
10
11
12@timed("mu2tau")
13def mu2tau(powheg_LHE_output):
14 """! Post-process existing events from muons to taus
15
16 @param powheg_LHE_output Name of LHE file produced by PowhegBox.
17
18 @author Jan Kretzschmar <jan.kretzschmar@cern.ch>
19 """
20 logger.warning("Converting LHE events from muon to tau decays. Tau mass must be restored by showering program, ensure to validate physics.")
21
22 # Get opening and closing strings
23 preamble = LHE.preamble(powheg_LHE_output)
24 postamble = LHE.postamble(powheg_LHE_output)
25
26 n_events = 0
27 powheg_LHE_tau = "{}.tau".format(powheg_LHE_output)
28 with open(powheg_LHE_tau, "w") as f_output:
29 f_output.write("{}\n".format(preamble))
30 for input_event in LHE.event_iterator(powheg_LHE_output):
31 is_event_changed, output_event = LHE.mu2tau(input_event)
32 f_output.write(output_event)
33 n_events += [0, 1][is_event_changed]
34 f_output.write(postamble)
35 logger.info("Changed mu->tau in {} events!".format(n_events))
36
37 # Make a backup of the original events
38 shutil.move(powheg_LHE_output, "{}.mu2tau_backup".format(powheg_LHE_output))
39 shutil.move(powheg_LHE_tau, powheg_LHE_output)
40
41
42