From e0c6ed10fcedc1053843a6b4e585ecd7660516c1 Mon Sep 17 00:00:00 2001
From: Oleksandr Zenaiev <oleksandr.zenaiev@cern.ch>
Date: Sun, 24 Jan 2021 20:01:46 +0100
Subject: [PATCH 1/2] default LHAPDF members in profiler

---
 src/Profiler.cc | 47 +++++++++++++++++++++++------------------------
 1 file changed, 23 insertions(+), 24 deletions(-)

diff --git a/src/Profiler.cc b/src/Profiler.cc
index 14ae95b22..84cb448c2 100644
--- a/src/Profiler.cc
+++ b/src/Profiler.cc
@@ -222,14 +222,11 @@ namespace xfitter
     YAML::Node const members = node["members"];
     YAML::Node const error_type_override = node["error_type_override"];
     //Sanity checks
-    if ( !sets || !members  ) {
-      hf_errlog(2018082401,"S: Profiler: missing set or member parameters for evolution "+evolName);  // XXXXXXXXXXXXXXXX
+    if ( !sets  ) {
+      hf_errlog(2018082401,"S: Profiler: missing set parameters for evolution "+evolName);  // XXXXXXXXXXXXXXXX
     }
-    if(!sets.IsSequence()||!members.IsSequence()||(error_type_override&&!error_type_override.IsSequence())){
-      hf_errlog(2018082402,"S: Profiler: sets, members and (optional) error_type_override must be sequence");  // XXXXXXXXXXXXXXXX
-    }
-    if(sets.size()!=members.size()){
-      hf_errlog(2018082403,"S: Profiler: sets and members must be the same length");  // XXXXXXXXXXXXXXXX
+    if(!sets.IsSequence()||(error_type_override&&!error_type_override.IsSequence())){
+      hf_errlog(2018082402,"S: Profiler: sets and (optional) error_type_override must be sequence");  // XXXXXXXXXXXXXXXX
     }
     if(error_type_override&&sets.size()!=error_type_override.size()){
       hf_errlog(2018082405,"S: Profiler: sets and error_type_override must be the same length");  // XXXXXXXXXXXXXXXX
@@ -240,31 +237,37 @@ namespace xfitter
     for (size_t i=0; i< endi; i++) {
       std::string pName = sets[i].as<string>();
 
-      if ( members[i].IsSequence() ) {
+      int central = 0;
+      int first = 1;
+      int last = 0;
+      if ( members && members[i].IsSequence() ) {
         int msize = members[i].size();
-
+        if(!members.IsSequence()){
+          hf_errlog(2018082402,"S: Profiler: members must be sequence");  // XXXXXXXXXXXXXXXX
+        }
+        if(sets.size()!=members.size()){
+          hf_errlog(2018082403,"S: Profiler: sets and members must be the same length");  // XXXXXXXXXXXXXXXX
+        }
         if ( msize != 3) {
           hf_errlog(2018082404,"S: Profiler: sets must be sequence of length 3");  // XXXXXXXXXXXXXXXX
         }
-
-        int central = members[i][0].as<int>();
-        int first   = members[i][1].as<int>();
-        int last = 0;
-
+        central = members[i][0].as<int>();
+        first   = members[i][1].as<int>();
         try {
           last =  members[i][2].as<int>();
         }
         catch (...) {
           last = 0; /// auto-decodez
         }
+      }
           
-        // save original
-        auto oSet   =Clone(gNode["set"]);
-        auto oMember=Clone(gNode["member"]);
+      // save original
+      auto oSet   =Clone(gNode["set"]);
+      auto oMember=Clone(gNode["member"]);
 
-        if ( ! oSet  || ! oMember ) {
-          hf_errlog(2018082410,"W: No central set or member variables for evolution : "+evolName);
-        }
+      if ( ! oSet  || ! oMember ) {
+        hf_errlog(2018082410,"W: No central set or member variables for evolution : "+evolName);
+      }
 
 	if (oSet.as<string>() != pName) {
 	  hf_errlog(2021011301,"W: Mismatch of the PDF set in the evolution and profiler: \033[1;31m" + oSet.as<string>() + " vs " + pName +  "\033[0m Could be ok, but beware.");
@@ -376,10 +379,6 @@ namespace xfitter
           hf_errlog(2018082441,"S: Profiler Unsupported PDF error type : "+errorType);
         }
         
-      }
-      else {
-        hf_errlog(2018082404,"S: Profiler: sets must be sequence of length 3");  // XXXXXXXXXXXXXXXX
-      }
     }
   }
   
-- 
GitLab


From 3da768c2029dc91cfd4ea08bc7ee11ce5aee5355 Mon Sep 17 00:00:00 2001
From: Oleksandr Zenaiev <oleksandr.zenaiev@cern.ch>
Date: Sun, 24 Jan 2021 20:15:25 +0100
Subject: [PATCH 2/2] modified HERAPDF2.0 profiler example to use default
 members for EIG variations

---
 examples/profilerLHAPDF-HERAPDF20/parameters.yaml | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/examples/profilerLHAPDF-HERAPDF20/parameters.yaml b/examples/profilerLHAPDF-HERAPDF20/parameters.yaml
index 25a40de46..c5697e463 100644
--- a/examples/profilerLHAPDF-HERAPDF20/parameters.yaml
+++ b/examples/profilerLHAPDF-HERAPDF20/parameters.yaml
@@ -156,7 +156,7 @@ Profiler:
   Evolutions:
     proton-LHAPDF:
       sets: [HERAPDF20_NNLO_EIG, HERAPDF20_NNLO_VAR, HERAPDF20_NNLO_VAR]
-      members: [[0,1,end],[0,1,10],[0,11,13]]
+      members: [,[0,1,10],[0,11,13]] # when omitted, default members is [0,1,end]
       error_type_override: [None,hessian,symmhessian] # treat parametrisation variations (members 11-13 from HERAPDF20_NNLO_VAR) as symmetric hessian
   Status: "On"               # "Off" to turn off profiler
   WriteTheo: "Asymmetric"            # Can be "Off", "On" or "Asymmetric" (to store asymmetric variations)
-- 
GitLab