From 607eb7e66e2dc9d835430910b74ba52e645963db Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Niccol=C3=B2=20Laurenti?= Date: Tue, 2 Apr 2024 11:36:00 +0200 Subject: [PATCH] Use additional class for asymptotic limits --- src/yadism/coefficient_functions/asy/f2_nc.py | 42 ++++++++++--------- src/yadism/coefficient_functions/asy/fl_nc.py | 26 ++++++------ 2 files changed, 36 insertions(+), 32 deletions(-) diff --git a/src/yadism/coefficient_functions/asy/f2_nc.py b/src/yadism/coefficient_functions/asy/f2_nc.py index df4a451e..2abdd115 100644 --- a/src/yadism/coefficient_functions/asy/f2_nc.py +++ b/src/yadism/coefficient_functions/asy/f2_nc.py @@ -6,9 +6,16 @@ from . import raw_nc -class AsyLLGluon(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, '2', 'g', "abmp") - +class AsyGluon(pc.NeutralCurrentBaseAsy): + hs3 = adani.HighScaleSplitLogs(3, "2", "g", "gm") + + +class AsySinglet(pc.NeutralCurrentBaseAsy): + hs3 = adani.HighScaleSplitLogs(3, "2", "q", "exact") + + +class AsyLLGluon(AsyGluon): + def NLO(self): def cg_LL_NLO(z, args): L = args[0] @@ -32,9 +39,8 @@ def cg_LL_N3LO(z, args): return RSL(cg_LL_N3LO, args=[self.L, self.nf]) -class AsyNLLGluon(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, '2', 'g', "abmp") - +class AsyNLLGluon(AsyGluon): + def NLO(self): def cg_NLL_NLO(z, _args): return raw_nc.c2g1am0_a0(z) @@ -57,8 +63,7 @@ def cg_NLL_N3LO(z, args): return RSL(cg_NLL_N3LO, args=[self.L, self.nf]) -class AsyNNLLGluon(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, '2', 'g', "abmp") +class AsyNNLLGluon(AsyGluon): def NNLO(self): def cg_NNLL_NNLO(z, _args): @@ -75,21 +80,21 @@ def cg_NNLL_N3LO(z, args): return RSL(cg_NNLL_N3LO, args=[self.L, self.nf]) -class AsyNNNLLGluon(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, '2', 'g', "abmp") - variation_map = {-1: 2, 0:0, 1:1} +class AsyNNNLLGluon(AsyGluon): + variation_map = {-1: 2, 0: 0, 1: 1} def N3LO(self): def cg_NNNLL_N3LO(z, args): nf = int(args[0]) variation = int(args[1]) - return self.hs3.N3LL(z, nf, variation).ToVect()[self.variation_map[variation]] + return self.hs3.N3LL(z, nf, variation).ToVect()[ + self.variation_map[variation] + ] return RSL(cg_NNNLL_N3LO, args=[self.nf, self.n3lo_cf_variation]) -class AsyLLSinglet(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, '2', 'q', "exact") +class AsyLLSinglet(AsySinglet): def NNLO(self): def cps_LL_NNLO(z, args): @@ -107,8 +112,7 @@ def cps_LL_N3LO(z, args): return RSL(cps_LL_N3LO, args=[self.L, self.nf]) -class AsyNLLSinglet(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, '2', 'q', "exact") +class AsyNLLSinglet(AsySinglet): def NNLO(self): def cps_NLL_NNLO(z, args): @@ -126,8 +130,7 @@ def cps_NLL_N3LO(z, args): return RSL(cps_NLL_N3LO, args=[self.L, self.nf]) -class AsyNNLLSinglet(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, '2', 'q', "exact") +class AsyNNLLSinglet(AsySinglet): def NNLO(self): def cps_NNLL_NNLO(z, _args): @@ -144,8 +147,7 @@ def cps_NNLL_N3LO(z, args): return RSL(cps_NNLL_N3LO, args=[self.L, self.nf]) -class AsyNNNLLSinglet(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, '2', 'q', "exact") +class AsyNNNLLSinglet(AsySinglet): def N3LO(self): def cps_NNNLL_N3LO(z, args): diff --git a/src/yadism/coefficient_functions/asy/fl_nc.py b/src/yadism/coefficient_functions/asy/fl_nc.py index 18d968ed..d3378a0b 100644 --- a/src/yadism/coefficient_functions/asy/fl_nc.py +++ b/src/yadism/coefficient_functions/asy/fl_nc.py @@ -10,8 +10,15 @@ class AsyLLGluon(EmptyPartonicChannel): pass -class AsyNLLGluon(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, 'L', 'g') +class AsyGluon(pc.NeutralCurrentBaseAsy): + hs3 = adani.HighScaleSplitLogs(3, "L", "g", "gm") + + +class AsySinglet(pc.NeutralCurrentBaseAsy): + hs3 = adani.HighScaleSplitLogs(3, "L", "q", "exact") + + +class AsyNLLGluon(AsyGluon): def NLO(self): def cg_NLL_NLO(z, _args): @@ -34,8 +41,7 @@ def cg_NLL_N3LO(z, args): return RSL(cg_NLL_N3LO, args=[self.L]) -class AsyNNLLGluon(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, 'L', 'g') +class AsyNNLLGluon(AsyGluon): def NNLO(self): def cg_NNLL_NNLO(z, _args): @@ -52,8 +58,7 @@ def cg_NNLL_N3LO(z, args): return RSL(cg_NNLL_N3LO, args=[self.L, self.nf]) -class AsyNNNLLGluon(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, 'L', 'g') +class AsyNNNLLGluon(AsyGluon): def N3LO(self): def cg_NNNLL_N3LO(z, args): @@ -67,8 +72,7 @@ class AsyLLSinglet(EmptyPartonicChannel): pass -class AsyNLLSinglet(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, 'L', 'q') +class AsyNLLSinglet(AsySinglet): def NNLO(self): def cps_NLL_NNLO(z, args): @@ -85,8 +89,7 @@ def cps_NLL_N3LO(z, args): return RSL(cps_NLL_N3LO, args=[self.L]) -class AsyNNLLSinglet(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, 'L', 'q') +class AsyNNLLSinglet(AsySinglet): def NNLO(self): def cps_NNLL_NNLO(z, _args): @@ -102,8 +105,7 @@ def cps_NNLL_N3LO(z, args): return RSL(cps_NNLL_N3LO, args=[self.L]) -class AsyNNNLLSinglet(pc.NeutralCurrentBaseAsy): - hs3 = adani.HighScaleSplitLogs(3, 'L', 'q') +class AsyNNNLLSinglet(AsySinglet): def N3LO(self): def cps_NNNLL_N3LO(z, args):