"""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
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 get_version(self) -> str:
p = os.path.expanduser(self.get_path())
ret = self._sub_run([p, "--version"])
return ret.split("\n")[-2]
[docs] def _check_path(self) -> bool:
if os.path.exists(
os.path.expanduser(self.get_path() + "/build/bin/resummino")):
self.set_path(self.get_path() + "/build/bin/resummino")
return True
if os.path.exists(
os.path.expanduser(self.get_path() + "/bin/resummino")):
self.set_path(self.get_path() + "/bin/resummino")
return True
if self.get_path().endswith("resummino"):
return True
return False
[docs] def _is_valid(self, file: str, p: Input, d, **kwargs) -> bool:
if not super()._is_valid(file, p, d):
return False
return is_valid(file, p, d, **kwargs)
[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