76using std::string, std::make_unique, std::vector;
86#define NaN std::numeric_limits<double>::quiet_NaN()
95template <
typename Test,
template <
typename...>
class Ref>
99template <
template <
typename...>
class Ref,
typename... Args>
110template <
class MatrixT>
115 return mat.GetNrows();
121template <
class MatrixT>
124 if (!stream.good()) {
130 stream << std::setprecision(RooFit::SuperFloatPrecision::digits10) <<
matrix(i,
j) <<
"\t";
132 stream <<
matrix(i,
j) <<
"\t";
142template <
class MatrixT>
145 std::ofstream of(
fname);
147 std::cerr <<
"unable to read file '" <<
fname <<
"'!" << std::endl;
156#pragma GCC diagnostic push
157#pragma GCC diagnostic ignored "-Wshadow"
158#pragma GCC diagnostic ignored "-Wunused-local-typedefs"
159#include <boost/numeric/ublas/io.hpp>
160#include <boost/numeric/ublas/lu.hpp>
161#include <boost/numeric/ublas/matrix.hpp>
162#include <boost/numeric/ublas/matrix_expression.hpp>
163#include <boost/numeric/ublas/symmetric.hpp>
164#include <boost/numeric/ublas/triangular.hpp>
165#include <boost/operators.hpp>
167#pragma GCC diagnostic pop
169typedef boost::numeric::ublas::matrix<RooFit::SuperFloat>
Matrix;
176 for (
size_t i = 0; i <
mat.size1(); ++i) {
177 for (
size_t j = 0;
j <
mat.size2(); ++
j) {
178 std::cout << std::setprecision(RooFit::SuperFloatPrecision::digits10) <<
mat(i,
j) <<
" ,\t";
180 std::cout << std::endl;
198 return boost::numeric::ublas::identity_matrix<RooFit::SuperFloat>(
n);
208 for (
size_t i = 0; i <
n; ++i) {
209 for (
size_t j = 0;
j <
n; ++
j) {
221 size_t n =
in.GetNrows();
223 for (
size_t i = 0; i <
n; ++i) {
224 for (
size_t j = 0;
j <
n; ++
j) {
245 boost::numeric::ublas::permutation_matrix<size_t>
pm(
size(
matrix));
251 std::stringstream
ss;
257 }
catch (boost::numeric::ublas::internal_logic &error) {
314 std::cerr <<
" matrix is not invertible!" << std::endl;
316 double condition =
lu.GetCondition();
319 for (
size_t i = 0; i <
n; ++i) {
320 for (
size_t j = 0;
j <
n; ++
j) {
342typedef std::map<int, std::unique_ptr<RooAbsReal>> FormulaList;
350 retval.ReplaceAll(
"/",
"_");
351 retval.ReplaceAll(
"^",
"");
352 retval.ReplaceAll(
"*",
"X");
353 retval.ReplaceAll(
"[",
"");
354 retval.ReplaceAll(
"]",
"");
364 std::stringstream
ss;
369 ss <<
itr->GetName();
379template <
class A,
class B>
382 a =
static_cast<A
>(
b);
387template <
class MatrixT>
390 std::vector<std::vector<RooFit::SuperFloat>>
matrix;
391 std::vector<RooFit::SuperFloat>
line;
392 while (!stream.eof()) {
393 if (stream.peek() ==
'\n') {
401 while (stream.peek() ==
' ' || stream.peek() ==
'\t') {
404 if (stream.peek() ==
'\n') {
410 for (
size_t i = 0; i <
matrix.size(); ++i) {
412 std::cerr <<
"matrix read from stream doesn't seem to be square!" << std::endl;
414 for (
size_t j = 0;
j <
matrix[i].size(); ++
j) {
424template <
class MatrixT>
429 std::cerr <<
"unable to read file '" <<
fname <<
"'!" << std::endl;
446 const std::string
s_coup(
h_pc->GetXaxis()->GetBinLabel(
ibx));
484 std::cerr <<
"Error: unable to access data from folder '" <<
folderName <<
"' from file '" <<
inFile->GetName()
485 <<
"'!" << std::endl;
501template <
class AObjType>
514 <<
"'. contents are:";
517 while ((
f =
static_cast<TFolder *
>(next()))) {
520 std::cerr <<
errstr.str() << std::endl;
534 const std::string &key =
"param_card",
bool notFoundError =
true)
547 const std::vector<std::string> &names,
const std::string &key =
"param_card",
bool notFoundError =
true)
552 for (
size_t i = 0; i < names.size(); i++) {
553 const std::string
name(names[i]);
570 if (!file || !file->
IsOpen()) {
573 std::cerr <<
"could not open file '" <<
filename <<
"'!" << std::endl;
615 for (
auto itr : couplings) {
626 for (
const auto &
v :
vec) {
634template <
class T1,
class T2>
653 if (val >
p->getMax()) {
657 std::cerr <<
": parameter " <<
p->GetName() <<
" out of bounds: " << val <<
" > " <<
p->getMax() << std::endl;
664 std::cerr <<
": parameter " <<
p->GetName() <<
" out of bounds: " << val <<
" < " <<
p->getMin() << std::endl;
677template <
class T1,
class T2>
692template <
class T1,
class T2>
698 if (!param || param->isConstant())
705 const std::string param(
paramit.first);
733 for (
int i = 1; i <=
ax->GetNbins(); ++i) {
754 retval[param->GetName()] = param->getVal();
791 std::vector<double> bins;
792 for (
int i = 1; i <
n + 1; ++i) {
805 auto dh = std::make_unique<RooDataHist>(
histname.Data(),
histname.Data(), vars, hist.get());
833 physics.addOwned(std::move(obj));
855 TPair *pair =
dynamic_cast<TPair *
>(obj.get());
862 errstr <<
"Error: unable to retrieve cross section '" <<
varname <<
"' from folder '" <<
sample;
875 xs->setConstant(
true);
882 xs->setError(error->GetVal());
903 std::cerr <<
"cannot morph objects of class 'TPair' if parameter is not "
934 for (
size_t i = 0; i <
morphfunc.size(); ++i) {
972 for (
auto const &
vertex : vertices) {
978 std::cerr <<
"encountered invalid list of couplings in vertex!" << std::endl;
992template <
class MatrixT,
class T1,
class T2>
1003 std::cout <<
"unable to set parameters for sample " <<
sample <<
"!" << std::endl;
1007 std::cout <<
"unable to set parameters for sample " <<
sample <<
"!" << std::endl;
1011 for (
auto const &formula :
formulas) {
1012 if (!formula.second) {
1013 std::cerr <<
"Error: invalid formula encountered!" << std::endl;
1015 matrix(row, col) = formula.second->getVal();
1029 std::stringstream
ss;
1030 ss <<
"matrix is not square, consistency check failed: " <<
inputParameters.size() <<
" samples, "
1031 <<
formulas.size() <<
" expressions:" << std::endl;
1032 ss <<
"formulas: " << std::endl;
1033 for (
auto const &formula :
formulas) {
1034 ss << formula.second->GetTitle() << std::endl;
1036 ss <<
"samples: " << std::endl;
1040 std::cerr <<
ss.str() << std::endl;
1054 for (
size_t i = 0; i < dim; ++i) {
1055 for (
size_t j = 0;
j < dim; ++
j) {
1068template <
class List>
1075 std::cerr <<
"detected name conflict: cannot use sample '" <<
sample
1076 <<
"' - a parameter with the same name of type '" << arg->
ClassName() <<
"' is present in set '"
1077 << args.GetName() <<
"'!" << std::endl;
1089 const std::vector<std::vector<std::string>> &nonInterfering)
1109 std::cerr <<
"unable to set parameters for sample '" <<
sample <<
"'!" << std::endl;
1113 std::cerr <<
"internal error, number of operators inconsistent!" << std::endl;
1119 if (
obj0->getVal() != 0) {
1132 if (
flag->second == 0.) {
1147 for (
size_t i = 0; i <
morphfunc.size(); ++i) {
1152 for (
const auto &
group : nonInterfering) {
1164 reason =
"blacklisted interference term!";
1175 for (
int k = 0; k <
exponent; ++k) {
1177 if (
coupling->getAttribute(
"NewPhysics")) {
1184 reason =
"coupling " +
cname +
" was listed as leading-order-only";
1199 TString sval(obj->getStringAttribute(
"NewPhysics"));
1200 int val = atoi(
sval);
1204 reason =
"flag " + std::string(obj->GetName()) +
" is zero";
1213 const auto name = std::string(
mfname) +
"_pol" + std::to_string(i);
1226 const RooArgList &flags,
const std::vector<std::vector<std::string>> &nonInterfering)
1230 for (
const auto &vertices :
diagrams) {
1239 <<
"no formulas are non-zero, check if any if your couplings is floating and missing from your param_cards!"
1242 throw std::runtime_error(
errorMsg);
1259 std::stringstream title;
1280inline std::map<std::string, std::string>
1285 std::map<std::string, std::string> weights;
1288 std::stringstream str;
1296 str << val <<
"*(" <<
formulait.second->GetTitle() <<
")";
1300 weights[
sample] = str.str();
1335 args.
add(*(it.second));
1346 const std::vector<std::vector<std::string>> &nonInterfering,
const RooArgList &flags)
1349 std::vector<std::vector<RooArgList *>>
diagrams;
1363 template <
class List>
1371 std::cerr <<
"input matrix is empty, please provide suitable input samples!" << std::endl;
1384 oocxcoutW((
TObject *)
nullptr, Eval) <<
"Warning: The matrix inversion seems to be unstable. This can "
1385 "be a result to input samples that are not sufficiently "
1386 "different to provide any morphing power."
1389 oocxcoutW((
TObject *)
nullptr, Eval) <<
"Warning: Some weights are excessively large. This can be a "
1390 "result to input samples that are not sufficiently different to "
1391 "provide any morphing power."
1395 "encoded in your samples to cross-check:"
1407 oocxcoutW((
TObject *)
nullptr, Eval) << obj->GetName() <<
"=" << obj->getVal();
1430 std::cerr <<
"invalid bin width given!" << std::endl;
1434 std::cerr <<
"invalid observable given!" << std::endl;
1455 std::cerr <<
"unable to access physics object for " <<
prodname << std::endl;
1462 std::cerr <<
"unable to access weight object for " <<
prodname << std::endl;
1469 allowNegativeYields =
true;
1471 if (!allowNegativeYields) {
1476 max->addOwnedComponents(std::move(prod));
1489 std::cerr <<
"unable to access observable" << std::endl;
1492 std::cerr <<
"unable to access bin width" << std::endl;
1495 std::cerr <<
"no operators listed" << std::endl;
1498 std::cerr <<
"unable to access weight objects" << std::endl;
1504 std::cout.precision(std::numeric_limits<double>::digits);
1522 std::cerr <<
"Matrix inversion succeeded, but no observable was "
1523 "supplied. quitting..."
1647 <<
" does not match expected name " <<
obsname << std::endl;
1652 auto binWidth = std::make_unique<RooRealVar>(
sbw.Data(),
sbw.Data(), 1.);
1654 binWidth->setVal(
bw);
1655 binWidth->setConstant(
true);
1674 const size_t n(
size(cache->_inverse));
1680 coutE(ObjectHandling) <<
Form(
"unable to access formula for sample '%s'!",
sample.c_str()) << std::endl;
1683 cxcoutP(ObjectHandling) <<
"updating formula for sample '" <<
sample <<
"'" << std::endl;
1689 if (std::isnan(val)) {
1691 coutE(ObjectHandling) <<
"refusing to propagate NaN!" << std::endl;
1694 << val << std::endl;
1735 cxcoutP(InputArguments) <<
"initializing physics inputs from file " << file->
GetName() <<
" with object name(s) '"
1736 <<
obsName <<
"'" << std::endl;
1740 std::cerr <<
"unable to locate object '" <<
obsName <<
"' in folder '" << folderNames.front() <<
"'!"
1744 std::string classname = obj->ClassName();
1748 if (classname.find(
"TH1") != std::string::npos) {
1751 }
else if (classname.find(
"RooHistFunc") != std::string::npos ||
1752 classname.find(
"RooParamHistFunc") != std::string::npos ||
1753 classname.find(
"PiecewiseInterpolation") != std::string::npos) {
1755 }
else if (classname.find(
"TParameter<double>") != std::string::npos) {
1757 }
else if (classname.find(
"TParameter<float>") != std::string::npos) {
1759 }
else if (classname.find(
"TPair") != std::string::npos) {
1763 std::cerr <<
"cannot morph objects of class '" <<
mode->GetName() <<
"'!" << std::endl;
1774 std::cout << param.first <<
" = " << param.second;
1776 std::cout <<
" (const)";
1777 std::cout << std::endl;
1789 std::cout <<
folder << std::endl;
1829 std::vector<RooListProxy *> vertices;
1831 vertices.push_back(
new RooListProxy(
"!couplings",
"set of couplings in the vertex",
this,
true,
false));
1843 std::vector<RooListProxy *> vertices;
1845 cxcoutP(InputArguments) <<
"prod/dec couplings provided" << std::endl;
1849 new RooListProxy(
"!production",
"set of couplings in the production vertex",
this,
true,
false));
1850 vertices.push_back(
new RooListProxy(
"!decay",
"set of couplings in the decay vertex",
this,
true,
false));
1856 cxcoutP(InputArguments) <<
"adding non-own operators" << std::endl;
1871 std::stringstream
name;
1872 name <<
"noInterference";
1873 for (
auto c : nonInterfering) {
1877 for (
auto c : nonInterfering) {
1888 for (
size_t i = 0; i < nonInterfering.size(); ++i) {
1901 coutE(InputArguments) <<
"unable to open file '" <<
filename <<
"'!" << std::endl;
1908 auto nNP0 = std::make_unique<RooRealVar>(
"nNP0",
"nNP0", 1., 0, 1.);
1909 nNP0->setStringAttribute(
"NewPhysics",
"0");
1910 nNP0->setConstant(
true);
1912 auto nNP1 = std::make_unique<RooRealVar>(
"nNP1",
"nNP1", 1., 0, 1.);
1913 nNP1->setStringAttribute(
"NewPhysics",
"1");
1914 nNP1->setConstant(
true);
1916 auto nNP2 = std::make_unique<RooRealVar>(
"nNP2",
"nNP2", 1., 0, 1.);
1917 nNP2->setStringAttribute(
"NewPhysics",
"2");
1918 nNP2->setConstant(
true);
1920 auto nNP3 = std::make_unique<RooRealVar>(
"nNP3",
"nNP3", 1., 0, 1.);
1921 nNP3->setStringAttribute(
"NewPhysics",
"3");
1922 nNP3->setConstant(
true);
1924 auto nNP4 = std::make_unique<RooRealVar>(
"nNP4",
"nNP4", 1., 0, 1.);
1925 nNP4->setStringAttribute(
"NewPhysics",
"4");
1926 nNP4->setConstant(
true);
1937 _observables(
other._observables.GetName(),
this,
other._observables),
1939 _config(
other._config)
1941 for (
size_t j = 0;
j <
other._diagrams.size(); ++
j) {
1942 std::vector<RooListProxy *>
diagram;
1973 _observables(
"observable",
"morphing observable",
this,
true,
false),
1974 _binWidths(
"binWidths",
"set of bin width objects",
this,
true,
false)
1999 std::vector<bool> prod;
2000 std::vector<bool> dec;
2001 for (
int i = 0; i <
nboth; ++i) {
2002 prod.push_back(
true);
2003 dec.push_back(
true);
2005 for (
int i = 0; i <
nprod; ++i) {
2006 prod.push_back(
true);
2007 dec.push_back(
false);
2009 for (
int i = 0; i <
ndec; ++i) {
2010 prod.push_back(
false);
2011 dec.push_back(
true);
2027 for (
auto vertex : vertices) {
2041std::map<std::string, std::string>
2043 const std::vector<std::vector<std::string>> &
vertices_str)
2046 std::vector<RooArgList *> vertices;
2051 for (
const auto &
c :
vtx) {
2054 auto couplingOwner = std::make_unique<RooRealVar>(
c.c_str(),
c.c_str(), 1., 0., 10.);
2060 vertices.push_back(&
vertex);
2069std::map<std::string, std::string>
2071 const std::vector<RooArgList *> &vertices,
RooArgList &couplings)
2079std::map<std::string, std::string>
2081 const std::vector<RooArgList *> &vertices,
RooArgList &couplings,
2083 const std::vector<std::vector<std::string>> &nonInterfering)
2090 std::cerr <<
"input matrix is empty, please provide suitable input samples!" << std::endl;
2102 const std::vector<RooArgList *> &vertices,
RooArgList &couplings,
2105 const std::vector<std::vector<std::string>> &nonInterfering)
2112 std::cerr <<
"input matrix is empty, please provide suitable input samples!" << std::endl;
2125 const std::vector<RooArgList *> &vertices,
RooArgList &couplings)
2140 coutE(Eval) <<
"unable to retrieve morphing function" << std::endl;
2143 std::unique_ptr<RooArgSet> args{
mf->getComponents()};
2173 return dynamic_cast<RooAbsReal *
>(cache->_weights.find(
wname.c_str()));
2207 double val = obj->getVal();
2208 if (obj->isConstant())
2226 coutE(InputArguments) <<
"unable to open file '" <<
filename <<
"'!" << std::endl;
2253 cache->_inverse =
m;
2256 coutE(InputArguments) <<
"unable to open file '" <<
filename <<
"'!" << std::endl;
2271 coutE(Caching) <<
"unable to create cache!" << std::endl;
2290 coutE(Caching) <<
"unable to create cache!" << std::endl;
2315 cxcoutP(Caching) <<
"creating cache from getCache function for " <<
this << std::endl;
2316 cxcoutP(Caching) <<
"current storage has size " <<
_sampleMap.size() << std::endl;
2321 coutE(Caching) <<
"unable to create cache!" << std::endl;
2504 coutE(InputArguments) <<
"observable not available!" << std::endl;
2516 coutE(InputArguments) <<
"bin width not available!" << std::endl;
2535 auto mf = std::make_unique<RooRealSumFunc>(*(this->
getFunc()));
2538 const int nbins = observable->
getBins();
2540 auto hist = std::make_unique<TH1F>(
name.c_str(),
name.c_str(), nbins, observable->
getBinning().array());
2542 std::unique_ptr<RooArgSet> args{
mf->getComponents()};
2543 for (
int i = 0; i < nbins; ++i) {
2558 double weight = formula->
getVal();
2559 const double w2 =
dhist.weightSquared(i);
2560 unc2 +=
w2 * weight * weight;
2561 unc += sqrt(
w2) * weight;
2562 val +=
dhist.weight(i) * weight;
2567 return hist.release();
2576 auto mf = std::make_unique<RooRealSumFunc>(*(this->
getFunc()));
2578 coutE(InputArguments) <<
"unable to retrieve morphing function" << std::endl;
2579 std::unique_ptr<RooArgSet> args{
mf->getComponents()};
2581 if (prod->getVal() != 0) {
2652 return cache->_formulas.size();
2660 auto mf = std::make_unique<RooRealSumFunc>(*(this->
getFunc()));
2662 std::cerr <<
"Error: unable to retrieve morphing function" << std::endl;
2665 std::unique_ptr<RooArgSet> args{
mf->getComponents()};
2670 name.Prepend(
"phys_");
2671 if (!args->find(
name.Data())) {
2674 double val = formula->getVal();
2676 std::cout << formula->GetName() <<
": " << val <<
" = " << formula->GetTitle() << std::endl;
2696 return &(cache->_couplings);
2709 double val = var->
getVal();
2710 couplings[
name] = val;
2737 auto func = std::make_unique<RooRealSumFunc>(*(cache->_sumFunc));
2740 return std::make_unique<RooWrapperPdf>(
Form(
"pdf_%s", func->GetName()),
Form(
"pdf of %s", func->GetTitle()), *func);
2749 return cache->_sumFunc.get();
2766 return this->
createPdf()->expectedEvents(nset);
2776 return this->
createPdf()->expectedEvents(set);
2785 return createPdf()->expectedEvents(&nset);
2801 coutE(InputArguments) <<
"unable to find object " +
weightName << std::endl;
2815 double w = weight->getVal();
2855 for (
auto c : couplings) {
2856 std::cout <<
c.first <<
": " <<
c.second << std::endl;
2890 std::cerr <<
"unable to acquire in-built function!" << std::endl;
2967 coutE(Caching) <<
"unable to retrieve cache!" << std::endl;
2978 coutE(Caching) <<
"unable to retrieve cache!" << std::endl;
2991 coutE(Caching) <<
"unable to retrieve cache!" << std::endl;
2992 return cache->_condition;
2998std::unique_ptr<RooRatio>
3003 for (
auto it :
nr) {
3006 for (
auto it :
dr) {
3018std::vector<std::string>
asStringV(std::string
const &arg)
3020 std::vector<std::string> out;
3022 for (std::string &
tok :
ROOT::Split(arg,
",{}",
true)) {
3023 if (
tok[0] ==
'\'') {
3024 out.emplace_back(
tok.substr(1,
tok.size() - 2));
3026 throw std::runtime_error(
"Strings in factory expressions need to be in single quotes!");
3040 std::vector<std::string> args)
3043 const std::array<std::string, 4>
funcArgs{{
"fileName",
"observableName",
"couplings",
"folders"}};
3046 for (
unsigned int i = 1; i < args.size(); i++) {
3047 if (args[i].find(
"$fileName(") != 0 && args[i].find(
"$observableName(") != 0 &&
3048 args[i].find(
"$couplings(") != 0 && args[i].find(
"$folders(") != 0 && args[i].find(
"$NewPhysics(") != 0) {
3049 throw std::string(
Form(
"%s::create() ERROR: unknown token %s encountered",
instanceName, args[i].c_str()));
3053 for (
unsigned int i = 0; i < args.size(); i++) {
3054 if (args[i].find(
"$NewPhysics(") == 0) {
3058 if (
parts.size() == 2) {
3059 ft.ws().arg(
parts[0])->setAttribute(
"NewPhysics", atoi(
parts[1].c_str()));
3061 throw std::string(
Form(
"%s::create() ERROR: unknown token %s encountered, check input provided for %s",
3066 std::vector<string>
subargs =
ft.splitFunctionArgs(args[i].c_str());
3069 for (
auto const ¶m :
funcArgs) {
3070 if (args[i].find(param) != string::npos)
3075 Form(
"Incorrect number of arguments in %s, have %d, expect 1", args[i].c_str(), (
Int_t)
subargs.size()));
RooCollectionProxy< RooArgList > RooListProxy
ROOT::RRangeCast< T, true, Range_t > dynamic_range_cast(Range_t &&coll)
size_t size< TMatrixD >(const TMatrixD &mat)
void writeMatrixToStreamT(const MatrixT &matrix, std::ostream &stream)
write a matrix to a stream
size_t size(const MatrixT &matrix)
retrieve the size of a square matrix
static constexpr double morphUnityDeviation
Matrix makeSuperMatrix(const TMatrixD &in)
convert a TMatrixD into a Matrix
static constexpr double morphLargestWeight
void writeMatrixToFileT(const MatrixT &matrix, const char *fname)
write a matrix to a text file
double invertMatrix(const Matrix &matrix, Matrix &inverse)
TMatrixD makeRootMatrix(const Matrix &in)
convert a matrix into a TMatrixD
Matrix diagMatrix(size_t n)
create a new diagonal matrix of size n
void printMatrix(const TMatrixD &mat)
write a matrix
int Int_t
Signed integer 4 bytes (int)
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void input
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char filename
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char cname
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
Option_t Option_t TPoint TPoint const char mode
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t type
TMatrixT< Double_t > TMatrixD
char * Form(const char *fmt,...)
Formats a string in a circular formatting buffer.
std::string & operator+=(std::string &left, const TString &right)
TTime operator*(const TTime &t1, const TTime &t2)
const_iterator begin() const
const_iterator end() const
Common abstract base class for objects that represent a value and a "shape" in RooFit.
bool isConstant() const
Check if the "Constant" attribute is set.
bool addOwnedComponents(const RooAbsCollection &comps)
Take ownership of the contents of 'comps'.
Abstract base class for objects to be stored in RooAbsCache cache manager objects.
virtual bool add(const RooAbsArg &var, bool silent=false)
Add the specified argument to list.
Storage_t::size_type size() const
virtual bool addOwned(RooAbsArg &var, bool silent=false)
Add an argument and transfer the ownership to the collection.
RooAbsArg * find(const char *name) const
Find object with given name in list.
Abstract base class for objects that represent a real value that may appear on the left hand side of ...
Int_t numBins(const char *rangeName=nullptr) const override
virtual Int_t getBins(const char *name=nullptr) const
Get number of bins of currently defined range.
void setConstant(bool value=true)
virtual double getMax(const char *name=nullptr) const
Get maximum of currently defined range.
void setBin(Int_t ibin, const char *rangeName=nullptr) override
Set value to center of bin 'ibin' of binning 'rangeName' (or of default binning if no range is specif...
virtual double getMin(const char *name=nullptr) const
Get minimum of currently defined range.
Abstract base class for objects that represent a real value and implements functionality common to al...
double getVal(const RooArgSet *normalisationSet=nullptr) const
Evaluate object.
RooArgList is a container object that can hold multiple RooAbsArg objects.
RooAbsArg * at(Int_t idx) const
Return object at given index, or nullptr if index is out of range.
RooArgSet is a container object that can hold multiple RooAbsArg objects.
Implements a RooAbsBinning in terms of an array of boundary values, posing no constraints on the choi...
Int_t setObj(const RooArgSet *nset, T *obj, const TNamed *isetRangeName=nullptr)
Setter function without integration set.
T * getObj(const RooArgSet *nset, Int_t *sterileIndex=nullptr, const TNamed *isetRangeName=nullptr)
Getter function without integration set.
bool addOwned(RooAbsArg &var, bool silent=false) override
Overloaded RooCollection_t::addOwned() method insert object into owning set and registers object as s...
bool add(const RooAbsArg &var, bool valueServer, bool shapeServer, bool silent)
Overloaded RooCollection_t::add() method insert object into set and registers object as server to own...
Container class to hold N-dimensional binned data.
double weightSquared(std::size_t i) const
Return squared weight sum of i-th bin.
A real-valued function sampled from a multidimensional histogram.
static RooLagrangianMorphFunc::CacheElem * createCache(const RooLagrangianMorphFunc *func)
create all the temporary objects required by the class
void buildMatrix(const RooLagrangianMorphFunc::ParamMap &inputParameters, const RooLagrangianMorphFunc::FlagMap &inputFlags, const List &flags)
build and invert the morphing matrix
static RooLagrangianMorphFunc::CacheElem * createCache(const RooLagrangianMorphFunc *func, const Matrix &inverse)
create all the temporary objects required by the class function variant with precomputed inverse matr...
std::unique_ptr< RooRealSumFunc > _sumFunc
RooArgList containedArgs(Action) override
retrieve the list of contained args
void operModeHook(RooAbsArg::OperMode) override
Interface for changes of operation mode.
void createComponents(const RooLagrangianMorphFunc::ParamMap &inputParameters, const RooLagrangianMorphFunc::FlagMap &inputFlags, const char *funcname, const std::vector< std::vector< RooListProxy * > > &diagramProxyList, const std::vector< std::vector< std::string > > &nonInterfering, const RooArgList &flags)
create the basic objects required for the morphing
void buildMorphingFunction(const char *name, const RooLagrangianMorphFunc::ParamMap &inputParameters, const std::map< std::string, int > &storage, const RooArgList &physics, bool allowNegativeYields, RooRealVar *observable, RooRealVar *binWidth)
build the final morphing function
Class RooLagrangianMorphing is a implementation of the method of Effective Lagrangian Morphing,...
bool isParameterConstant(const char *paramname) const
return true if the parameter with the given name is set constant, false otherwise
bool isBinnedDistribution(const RooArgSet &obs) const override
check if this PDF is a binned distribution in the given observable
int nPolynomials() const
return the number of samples in this morphing function
void setParameter(const char *name, double value)
set one parameter to a specific value
RooArgSet createWeights(const ParamMap &inputs, const std::vector< RooArgList * > &vertices, RooArgList &couplings, const FlagMap &inputFlags, const RooArgList &flags, const std::vector< std::vector< std::string > > &nonInterfering)
create only the weight formulas. static function for external usage.
ParamSet getMorphParameters() const
retrieve the parameter set
double evaluate() const override
call getVal on the internal function
void disableInterference(const std::vector< const char * > &nonInterfering)
disable interference between terms
RooProduct * getSumElement(const char *name) const
return the RooProduct that is the element of the RooRealSumPdfi corresponding to the given sample nam...
RooRealVar * getBinWidth() const
retrieve the histogram observable
void writeMatrixToFile(const TMatrixD &matrix, const char *fname)
write a matrix to a file
RooRealVar * getParameter(const char *name) const
retrieve the RooRealVar object incorporating the parameter with the given name
bool useCoefficients(const TMatrixD &inverse)
setup the morphing function with a predefined inverse matrix call this function before any other afte...
const RooArgSet * getParameterSet() const
get the set of parameters
TMatrixD readMatrixFromStream(std::istream &stream)
read a matrix from a stream
std::vector< std::vector< std::string > > _nonInterfering
std::vector< std::string > getSamples() const
return the vector of sample names, used to build the morph func
int countSamples(std::vector< RooArgList * > &vertices)
calculate the number of samples needed to morph a certain physics process
void setCacheAndTrackHints(RooArgSet &) override
Retrieve the matrix of coefficients.
ParamSet getCouplings() const
retrieve a set of couplings (-?-)
void printSampleWeights() const
print the current sample weights
std::map< const std::string, double > ParamSet
void writeMatrixToStream(const TMatrixD &matrix, std::ostream &stream)
write a matrix to a stream
std::map< const std::string, ParamSet > ParamMap
bool updateCoefficients()
Retrieve the new physics objects and update the weights in the morphing function.
RooRealVar * getObservable() const
retrieve the histogram observable
int countContributingFormulas() const
count the number of formulas that correspond to the current parameter set
std::list< double > * plotSamplingHint(RooAbsRealLValue &, double, double) const override
retrieve the sample Hint
RooRealVar * getFlag(const char *name) const
retrieve the RooRealVar object incorporating the flag with the given name
void randomizeParameters(double z)
randomize the parameters a bit useful to test and debug fitting
bool isCouplingUsed(const char *couplname)
check if there is any morphing power provided for the given coupling morphing power is provided as so...
void readParameters(TDirectory *f)
read the parameters from the input file
double getScale()
get energy scale of the EFT expansion
double getCondition() const
Retrieve the condition of the coefficient matrix.
TMatrixD getMatrix() const
Retrieve the matrix of coefficients.
void printWeights() const
print the current sample weights
void printCouplings() const
print a set of couplings
TMatrixD readMatrixFromFile(const char *fname)
read a matrix from a text file
~RooLagrangianMorphFunc() override
default destructor
void printParameters() const
print the parameters and their current values
void printPhysics() const
print the current physics values
static std::unique_ptr< RooRatio > makeRatio(const char *name, const char *title, RooArgList &nr, RooArgList &dr)
Return the RooRatio form of products and denominators of morphing functions.
void setFlag(const char *name, double value)
set one flag to a specific value
TH1 * createTH1(const std::string &name)
retrieve a histogram output of the current morphing settings
double expectedUncertainty() const
return the expected uncertainty for the current parameter set
int nParameters() const
return the number of parameters in this morphing function
bool hasParameter(const char *paramname) const
check if a parameter of the given name is contained in the list of known parameters
bool checkObservables(const RooArgSet *nset) const override
check if observable exists in the RooArgSet (-?-)
bool hasCache() const
return true if a cache object is present, false otherwise
void printFlags() const
print the flags and their current values
void setScale(double val)
set energy scale of the EFT expansion
TMatrixD getInvertedMatrix() const
Retrieve the matrix of coefficients after inversion.
double analyticalIntegralWN(Int_t code, const RooArgSet *normSet, const char *rangeName=nullptr) const override
Retrieve the matrix of coefficients.
RooAbsArg::CacheMode canNodeBeCached() const override
Retrieve the matrix of coefficients.
void updateSampleWeights()
update sample weight (-?-)
void setParameters(const char *foldername)
set the morphing parameters to those supplied in the sample with the given name
RooObjCacheManager _cacheMgr
! The cache manager
bool isParameterUsed(const char *paramname) const
check if there is any morphing power provided for the given parameter morphing power is provided as s...
RooListProxy _observables
RooAbsPdf::ExtendMode extendMode() const
return extended mored capabilities
std::map< const std::string, FlagSet > FlagMap
bool forceAnalyticalInt(const RooAbsArg &arg) const override
Force analytical integration for the given observable.
void setParameterConstant(const char *paramname, bool constant) const
call setConstant with the boolean argument provided on the parameter with the given name
void disableInterferences(const std::vector< std::vector< const char * > > &nonInterfering)
disable interference between terms
void printSamples() const
print all the known samples to the console
double getParameterValue(const char *name) const
set one parameter to a specific value
void setup(bool ownParams=true)
setup this instance with the given set of operators and vertices if own=true, the class will own the ...
void printMetaArgs(std::ostream &os) const override
Retrieve the matrix of coefficients.
std::unique_ptr< RooWrapperPdf > createPdf() const
(currently similar to cloning the Pdf
RooAbsReal * getSampleWeight(const char *name)
retrieve the weight (prefactor) of a sample with the given name
std::map< std::string, std::string > createWeightStrings(const ParamMap &inputs, const std::vector< std::vector< std::string > > &vertices)
create only the weight formulas. static function for external usage.
Int_t getAnalyticalIntegralWN(RooArgSet &allVars, RooArgSet &numVars, const RooArgSet *normSet, const char *rangeName=nullptr) const override
Retrieve the mat.
std::vector< std::vector< RooListProxy * > > _diagrams
double expectedEvents() const
return the number of expected events for the current parameter set
std::map< std::string, int > _sampleMap
RooLagrangianMorphFunc::CacheElem * getCache() const
retrieve the cache object
RooRealVar * setupObservable(const char *obsname, TClass *mode, TObject *inputExample)
setup observable, recycle existing observable if defined
const RooArgList * getCouplingSet() const
get the set of couplings
RooRealSumFunc * getFunc() const
get the func
std::list< double > * binBoundaries(RooAbsRealLValue &, double, double) const override
retrieve the list of bin boundaries
void printEvaluation() const
print the contributing samples and their respective weights
bool writeCoefficients(const char *filename)
write the inverse matrix to a file
void collectInputs(TDirectory *f)
retrieve the physics inputs
void init()
initialise inputs required for the morphing function
RooLinearCombination is a class that helps perform linear combination of floating point numbers and p...
A histogram function that assigns scale parameters to every bin.
Represents the product of a given set of RooAbsReal objects.
std::list< double > * binBoundaries(RooAbsRealLValue &, double, double) const override
Retrieve bin boundaries if this distribution is binned in obs.
void printMetaArgs(std::ostream &os) const override
Customized printing of arguments of a RooRealSumFunc to more intuitively reflect the contents of the ...
Int_t getAnalyticalIntegralWN(RooArgSet &allVars, RooArgSet &numVars, const RooArgSet *normSet, const char *rangeName=nullptr) const override
Variant of getAnalyticalIntegral that is also passed the normalization set that should be applied to ...
CacheMode canNodeBeCached() const override
double analyticalIntegralWN(Int_t code, const RooArgSet *normSet, const char *rangeName=nullptr) const override
Implements the actual analytical integral(s) advertised by getAnalyticalIntegral.
bool isBinnedDistribution(const RooArgSet &obs) const override
Tests if the distribution is binned. Unless overridden by derived classes, this always returns false.
bool checkObservables(const RooArgSet *nset) const override
Overloadable function in which derived classes can implement consistency checks of the variables.
void setCacheAndTrackHints(RooArgSet &) override
std::list< double > * plotSamplingHint(RooAbsRealLValue &, double, double) const override
Interface for returning an optional hint for initial sampling points when constructing a curve projec...
bool forceAnalyticalInt(const RooAbsArg &arg) const override
Variable that can be changed from the outside.
void setVal(double value) override
Set value of variable to 'value'.
void setError(double value)
void setMin(const char *name, double value, bool shared=true)
Set minimum of name range to given value.
void setBins(Int_t nBins, const char *name=nullptr, bool shared=true)
Create a uniform binning under name 'name' for this variable.
void setBinning(const RooAbsBinning &binning, const char *name=nullptr, bool shared=true)
Add given binning under name 'name' with this variable.
void setMax(const char *name, double value, bool shared=true)
Set maximum of name range to given value.
const RooAbsBinning & getBinning(const char *name=nullptr, bool verbose=true, bool createOnTheFly=false, bool shared=true) const override
Return binning definition with name.
Class to manage histogram axis.
TClass instances represent classes, structs and namespaces in the ROOT type system.
static TClass * GetClass(const char *name, Bool_t load=kTRUE, Bool_t silent=kFALSE)
Static method returning pointer to TClass of the specified class name.
Describe directory structure in memory.
A file, usually with extension .root, that stores data and code in the form of serialized objects in ...
virtual Bool_t IsOpen() const
Returns kTRUE in case file is open and kFALSE if file is not open.
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=ROOT::RCompressionSetting::EDefaults::kUseCompiledDefault, Int_t netopt=0)
Create / open a file.
void Close(Option_t *option="") override
Close a file.
<div class="legacybox"><h2>Legacy Code</h2> TFolder is a legacy interface: there will be no bug fixes...
TH1 is the base class of all histogram classes in ROOT.
virtual Int_t GetNbinsX() const
virtual void SetBinError(Int_t bin, Double_t error)
Set the bin Error Note that this resets the bin eror option to be of Normal Type and for the non-empt...
virtual Double_t Integral(Option_t *option="") const
Return integral of bin contents.
virtual void SetBinContent(Int_t bin, Double_t content)
Set bin content see convention for numbering bins in TH1::GetBin In case the bin number is greater th...
virtual Double_t GetBinLowEdge(Int_t bin) const
Return bin lower edge for 1D histogram.
virtual Double_t GetBinContent(Int_t bin) const
Return content of bin number bin.
virtual Double_t GetBinWidth(Int_t bin) const
Return bin width for 1D histogram.
virtual void Scale(Double_t c1=1, Option_t *option="")
Multiply this histogram by a constant c1.
TMatrixTBase< Element > & ResizeTo(Int_t nrows, Int_t ncols, Int_t=-1) override
Set size of the matrix to nrows x ncols New dynamic elements are created, the overlapping part of the...
const char * GetName() const override
Returns name of object.
Mother of all ROOT objects.
virtual const char * ClassName() const
Returns name of class to which the object belongs.
Class used by TMap to store (key,value) pairs.
Random number generator class based on M.
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
RooCmdArg Silence(bool flag=true)
std::vector< std::string > Split(std::string_view str, std::string_view delims, bool skipEmpty=false)
Splits a string at each character in delims.
std::string observableName
std::vector< std::string > folderNames
std::vector< std::vector< const char * > > nonInterfering