Source code for hepi.resummino.run

"""Runs Resummino"""
from typing import List
from string import Template
import warnings
from hepi.input import Order
from hepi.results import Result
from hepi.run import RunParam, Runner
import pkgutil

from .. import Input, get_output_dir
import os.path
from .result import is_valid, parse_single
import os
import stat


[docs]class ResumminoRunner(Runner):
[docs] def orders(self) -> List[Order]: return [Order.LO, Order.NLO, Order.NLO_PLUS_NLL, Order.aNNLO_PLUS_NNLL]
[docs] def _check_path(self) -> bool: if os.path.exists(get_path() + "build/bin/resummino"): self.set_path(get_path() + "build/bin/resummino") return True if os.path.exists(get_path() + "bin/resummino"): self.set_path(get_path() + "bin/resummino") return True return True
[docs] def _check_input(self, p: Input, **kwargs) -> bool: if p.order == Order.aNNLO_PLUS_NNLL and ( p.has_gluino() and p.has_weakino()) or (p.has_squark() and p.has_weakino()): warnings.warn( "Resummino does not support stong-weak mixed aNNLO+NNLL.") return False return True
[docs] def _is_valid(self, file: str, p: Input, d) -> bool: if not super()._is_valid(file, p, d): return False return is_valid(file, p, d)
[docs] def _parse_file(self, file: str) -> Result: return parse_single(file)
[docs] def _prepare(self, p: Input, **kwargs) -> RunParam: rp = super()._prepare(p, **kwargs) if not rp.skip: data = pkgutil.get_data(__name__, "plot_template.in").decode('utf-8') flags = "" if p.order == Order.LO: flags = flags + "--lo" elif p.order == Order.NLO: flags = flags + "--nlo" elif p.order == Order.NLO_PLUS_NLL: flags = flags + "--nll" elif p.order == Order.aNNLO_PLUS_NNLL: flags = flags + "--nnll" else: raise ValueError( "Order not supported by resummino. Must be one of LO/NLO/NLO+NLL/aNNLO+NNLL." ) src = Template(data) result = src.substitute(p.__dict__) open(self.get_output_dir() + rp.name + ".in", "w").write(result) open(self.get_output_dir() + rp.name + ".sh", "w").write("#!/bin/sh\n" + get_path() + ' {} {} >> {}'.format( self.get_output_dir() + rp.name + ".in", flags, self.get_output_dir() + rp.name + ".out")) st = os.stat(self.get_output_dir() + rp.name + ".sh") os.chmod(self.get_output_dir() + rp.name + ".sh", st.st_mode | stat.S_IEXEC) open(self.get_output_dir() + rp.name + ".out", "w").write(result + "\n\n") sname = p.slha with open(self.get_output_dir() + sname, 'r') as f: open(self.get_output_dir() + rp.name + ".out", "a").write(f.read() + "\n\n") return rp
# Legacy
[docs]default_resummino_runner = ResumminoRunner("~/resummino/")
"""Default Resummino Runner to provide backward compatibility"""
[docs]run = default_resummino_runner.run
[docs]set_path = default_resummino_runner.set_path
[docs]get_path = default_resummino_runner.get_path