13def mu2tau(powheg_LHE_output):
14 """! Post-process existing events from muons to taus
16 @param powheg_LHE_output Name of LHE file produced by PowhegBox.
18 @author Jan Kretzschmar <jan.kretzschmar@cern.ch>
20 logger.warning(
"Converting LHE events from muon to tau decays. Tau mass must be restored by showering program, ensure to validate physics.")
23 preamble = LHE.preamble(powheg_LHE_output)
24 postamble = LHE.postamble(powheg_LHE_output)
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))
38 shutil.move(powheg_LHE_output,
"{}.mu2tau_backup".format(powheg_LHE_output))
39 shutil.move(powheg_LHE_tau, powheg_LHE_output)