107std::map<RooAbsArg*,std::unique_ptr<TRefArray>> RooAbsArg::_ioEvoList;
108std::stack<RooAbsArg*> RooAbsArg::_ioReadStack ;
127 if (
name ==
nullptr || strlen(
name) == 0) {
128 throw std::logic_error(
"Each RooFit object needs a name. "
129 "Objects representing the same entity (e.g. an observable 'x') are identified using their name.");
141 _boolAttrib(other._boolAttrib),
142 _stringAttrib(other._stringAttrib),
143 _deleteWatch(other._deleteWatch),
145 _isConstant(other._isConstant),
146 _localNoInhibitDirty(other._localNoInhibitDirty)
150 bool valueProp, shapeProp ;
152 valueProp = server->_clientListValue.containsByNamePtr(&other);
153 shapeProp = server->_clientListShape.containsByNamePtr(&other);
175 for (
auto client : clientListTmp) {
176 client->setAttribute(
"ServerDied") ;
177 std::stringstream
attr;
178 attr <<
"ServerDied:" <<
GetName() <<
"(" <<
reinterpret_cast<std::size_t
>(
this) <<
")";
179 client->setAttribute(
attr.str().c_str());
180 client->removeServer(*
this,
true);
185 cxcoutD(Tracing) <<
"RooAbsArg::dtor(" <<
GetName() <<
"," <<
this <<
") DeleteWatch: object is being destroyed" << endl ;
190 << client->GetName() <<
"\" should have been deleted first" << endl ;
227 if(std::string{
"Constant"} ==
name) {
279 map<string,string>::const_iterator iter =
_stringAttrib.find(key) ;
281 return iter->second.c_str() ;
332 cxcoutF(LinkStateMgmt) <<
"RooAbsArg::addServer(" <<
this <<
"," <<
GetName()
333 <<
"): PROHIBITED SERVER ADDITION REQUESTED: adding server " << server.
GetName()
334 <<
"(" << &server <<
") for " << (valueProp?
"value ":
"") << (shapeProp?
"shape":
"") << endl ;
335 throw std::logic_error(
"PROHIBITED SERVER ADDITION REQUESTED in RooAbsArg::addServer");
338 cxcoutD(LinkStateMgmt) <<
"RooAbsArg::addServer(" <<
this <<
"," <<
GetName() <<
"): adding server " << server.
GetName()
339 <<
"(" << &server <<
") for " << (valueProp?
"value ":
"") << (shapeProp?
"shape":
"") << endl ;
369 for (
const auto arg : serverList) {
383 std::stringstream ss;
384 ss <<
"RooAbsArg::addServer(" <<
this <<
"," <<
GetName() <<
"): PROHIBITED SERVER REMOVAL REQUESTED: removing server "
385 << server.
GetName() <<
"(" << &server <<
")";
386 cxcoutF(LinkStateMgmt) << ss.str() << std::endl;
387 throw std::runtime_error(ss.str());
391 cxcoutD(LinkStateMgmt) <<
"RooAbsArg::removeServer(" <<
GetName() <<
"): removing server "
392 << server.
GetName() <<
"(" << &server <<
")" << endl ;
425 coutW(LinkStateMgmt) <<
"replaceServer()"
426 <<
" is unsafe, because the server list will be out of sync with the proxy objects!"
427 <<
" If you want to safely replace a server, use RooAbsArg::redirectServers()."
428 <<
" See the docs to replaceServers() for more info." << std::endl;
433 addServer(newServer, propValue, propShape, count);
443 coutE(LinkStateMgmt) <<
"RooAbsArg::changeServer(" <<
GetName() <<
"): Server "
444 << server.
GetName() <<
" not registered" << endl ;
450 coutE(LinkStateMgmt) <<
"RooAbsArg::changeServer(" <<
GetName() <<
"): Server "
451 << server.
GetName() <<
" doesn't have us registered as client" << endl ;
513 if ((doBranch&&doLeaf) ||
518 list->
add(*arg,
true) ;
526 bool isValueSrv = server->_clientListValue.containsByNamePtr(arg);
527 if (valueOnly && !isValueSrv) {
588 std::vector<RooAbsArg*> branchList;
590 if (server->isValueServer(*
this)) {
591 if (server->isFundamental()) {
592 if (!nset || !server->dependsOn(*nset)) {
593 nodeParamServers.
add(*server);
596 branchList.push_back(server);
605 params.
add(nodeParamServers,
true) ;
608 std::sort(branchList.begin(), branchList.end());
609 const auto last = std::unique(branchList.begin(), branchList.end());
610 for (
auto serverIt = branchList.begin(); serverIt < last; ++serverIt) {
611 (*serverIt)->addParameters(params, nset);
627 std::vector<RooAbsArg*> branchList;
629 if (server->isValueServer(*
this)) {
630 if (server->isFundamental()) {
631 if (!nset || !server->dependsOn(*nset)) {
635 branchList.push_back(server);
641 std::sort(branchList.begin(), branchList.end());
642 const auto last = std::unique(branchList.begin(), branchList.end());
643 for (
auto serverIt = branchList.begin(); serverIt < last; ++serverIt) {
644 res += (*serverIt)->getParametersSizeEstimate(nset);
666 auto nsetObs = getColonSeparatedNameString(observables ? *observables :
RooArgSet());
669 outputSet.
add(*paramSet);
675 outputSet.
setName(
"parameters");
686 outputSet.
add(tempList,
true);
691 auto nsetObs = getColonSeparatedNameString(observables ? *observables :
RooArgSet());
756 outputSet.
setName(
"dependents");
758 if (!dataList)
return false;
761 RooArgSet leafList(
"leafNodeServerList") ;
765 for (
const auto arg : leafList) {
766 if (arg->dependsOnValue(*dataList) && arg->isLValue()) {
767 outputSet.
add(*arg) ;
771 for (
const auto arg : leafList) {
772 if (arg->dependsOn(*dataList) && arg->isLValue()) {
773 outputSet.
add(*arg) ;
835 if (arg->getAttribute(
"ServerDied")) {
836 coutE(LinkStateMgmt) <<
"RooAbsArg::recursiveCheckObservables(" <<
GetName() <<
"): ERROR: one or more servers of node "
837 << arg->GetName() <<
" no longer exists!" << endl ;
841 ret |= arg->checkObservables(nset) ;
857 for (
auto server : serverList) {
858 if (
dependsOn(*server,ignoreArg,valueOnly)) {
870 if (
this==ignoreArg)
return false ;
873 if (testArgNamePtr ==
namePtr())
return true ;
887 if ( !valueOnly || server->isValueServer(*
this)) {
888 if (server->dependsOn(testArgNamePtr,ignoreArg,valueOnly)) {
949 if (source==
nullptr) {
951 }
else if (source==
this) {
953 coutE(LinkStateMgmt) <<
"RooAbsArg::setValueDirty(" <<
GetName()
954 <<
"): cyclical dependency detected, source = " << source->
GetName() << endl ;
961 cxcoutD(LinkStateMgmt) <<
"RooAbsArg::setValueDirty(" << (source?source->
GetName():
"self") <<
"->" <<
GetName() <<
"," <<
this
962 <<
"): dirty flag " << (
_valueDirty?
"already ":
"") <<
"raised" << endl ;
969 client->setValueDirty(source) ;
983 cxcoutD(LinkStateMgmt) <<
"RooAbsArg::setShapeDirty(" <<
GetName()
984 <<
"): dirty flag " << (
_shapeDirty?
"already ":
"") <<
"raised" << endl ;
993 if (source==
nullptr) {
995 }
else if (source==
this) {
997 coutE(LinkStateMgmt) <<
"RooAbsArg::setShapeDirty(" <<
GetName()
998 <<
"): cyclical dependency detected" << endl ;
1006 client->setShapeDirty(source) ;
1007 client->setValueDirty(source) ;
1046 if (newSetOrig.
empty() || (newSetOrig.
size() == 1 && newSetOrig[0] ==
this))
return false ;
1049 std::unique_ptr<RooArgSet> newSetOwned;
1053 newSetOwned = std::make_unique<RooArgSet>();
1054 for (
auto arg : *newSet) {
1056 if (
string(
"REMOVAL_DUMMY")==arg->GetName()) {
1058 if (arg->getAttribute(
"REMOVE_ALL")) {
1059 newSetOwned->add(*arg) ;
1061 newSetOwned->add(*arg) ;
1064 newSetOwned->add(*arg) ;
1067 newSet = newSetOwned.
get();
1076 if (mustReplaceAll) {
1077 std::stringstream ss;
1078 ss <<
"RooAbsArg::redirectServers(" << (
void*)
this <<
"," <<
GetName() <<
"): server " << oldServer->
GetName()
1079 <<
" (" << (
void*)oldServer <<
") not redirected" << (nameChange?
"[nameChange]":
"");
1080 const std::string errorMsg = ss.str();
1081 coutE(LinkStateMgmt) << errorMsg << std::endl;
1082 throw std::runtime_error(errorMsg);
1087 if (newServer !=
this) {
1101 bool ret2 =
p->changePointer(*newSet,nameChange,
false) ;
1103 if (mustReplaceAll && !ret2) {
1105 coutE(LinkStateMgmt) <<
"RooAbsArg::redirectServers(" <<
GetName()
1106 <<
"): ERROR, proxy '" <<
p->name()
1107 <<
"' with arg '" << (ap ? ap->absArg()->GetName() :
"<could not cast>") <<
"' could not be adjusted" << endl;
1122 const int clientListRefCount = oldServer->
_clientList.Remove(
this,
true);
1123 const int clientListValueRefCount = oldServer->
_clientListValue.Remove(
this,
true);
1124 const int clientListShapeRefCount = oldServer->
_clientListShape.Remove(
this,
true);
1126 newServer->
_clientList.Add(
this, clientListRefCount);
1137 bool isRecursionStep)
1155 bool nameChange =
false;
1162 auto newServerFound = replacements.
find(oldServer);
1163 RooAbsArg *newServer = newServerFound != replacements.end() ? newServerFound->second :
nullptr;
1165 if (!newServer || newServer ==
this) {
1169 if (nameChange ==
false)
1170 nameChange = strcmp(newServerFound->first->GetName(), newServerFound->second->GetName()) != 0;
1173 newList.
add(*newServer);
1178 if (newList.
empty())
1187 p->changePointer(replacements);
1207 newServer = newSet.
find(*
this) ;
1212 TString nameAttrib(
"ORIGNAME:") ;
1215 if (
auto tmp = std::unique_ptr<RooAbsCollection>{newSet.
selectByAttrib(nameAttrib,
true)}) {
1224 std::stringstream ss;
1225 ss <<
"RooAbsArg::redirectServers(" <<
GetName() <<
"): FATAL Error, " << tmp->size() <<
" servers with "
1226 << nameAttrib <<
" attribute";
1227 coutF(LinkStateMgmt) << ss.str() << std::endl;
1229 throw std::runtime_error(ss.str());
1233 newServer= tmp->first();
1243 bool recurseInNewSet, std::set<RooAbsArg const *> &callStack)
1247 auto it = callStack.lower_bound(arg);
1248 if (it != callStack.end() && arg == *it) {
1251 callStack.insert(it, arg);
1262 oocxcoutD(arg, LinkStateMgmt) <<
"RooAbsArg::recursiveRedirectServers(" << arg <<
"," << arg->
GetName()
1263 <<
") newSet = " << newSet <<
" mustReplaceAll = " << (mustReplaceAll ?
"T" :
"F")
1264 <<
" nameChange = " << (nameChange ?
"T" :
"F")
1265 <<
" recurseInNewSet = " << (recurseInNewSet ?
"T" :
"F") << endl;
1268 ret |= arg->
redirectServers(newSet, mustReplaceAll, nameChange,
true);
1271 for (
const auto server : arg->servers()) {
1272 ret |= recursiveRedirectServersImpl(server, newSet, mustReplaceAll, nameChange, recurseInNewSet, callStack);
1275 callStack.erase(arg);
1292 bool recurseInNewSet)
1295 std::set<const RooAbsArg *> callStack;
1297 return recursiveRedirectServersImpl(
this, newSet, mustReplaceAll, nameChange, recurseInNewSet, callStack);
1335 coutE(LinkStateMgmt) <<
"RooAbsArg::registerProxy(" <<
GetName() <<
"): proxy named "
1337 <<
" already registered" << endl ;
1379 coutE(LinkStateMgmt) <<
"RooAbsArg::registerProxy(" <<
GetName() <<
"): proxy named "
1380 << proxy.
GetName() <<
" already registered" << endl ;
1414 coutE(LinkStateMgmt) <<
"RooAbsArg::registerProxy(" <<
GetName() <<
"): proxy named "
1415 << proxy.
GetName() <<
" already registered" << endl ;
1424 cout <<
"RooAbsArg::registerProxy(" <<
GetName() <<
") proxy registration failure! nold=" << nProxyOld <<
" nnew=" <<
_proxyList.
GetEntries() << endl ;
1485 p->changeNormSet(nset);
1501 coutE(Contents) <<
"RooAbsArg::attachToTree(" <<
GetName()
1502 <<
"): Cannot be attached to a TTree" << endl ;
1566 if (
p==
nullptr) continue ;
1593 os <<
indent <<
"--- RooAbsArg ---" << endl;
1595 os <<
indent <<
" Value State: " ;
1597 case ADirty: os <<
"FORCED DIRTY" ; break ;
1598 case AClean: os <<
"FORCED clean" ; break ;
1604 os <<
indent <<
" Attributes: " ;
1608 os <<
indent <<
" Address: " << (
void*)
this << endl;
1610 os <<
indent <<
" Clients: " << endl;
1612 os <<
indent <<
" (" << (
void*)client <<
","
1620 os <<
indent <<
" Servers: " << endl;
1622 os <<
indent <<
" (" << (
void*)server <<
","
1623 << (server->_clientListValue.containsByNamePtr(
this)?
"V":
"-")
1624 << (server->_clientListShape.containsByNamePtr(
this)?
"S":
"-")
1630 os <<
indent <<
" Proxies: " << std::endl;
1633 if (!proxy) continue ;
1634 os <<
indent <<
" " << proxy->
name() <<
" -> " ;
1635 if(
auto * argProxy =
dynamic_cast<RooArgProxy*
>(proxy)) {
1636 if (
RooAbsArg* parg = argProxy->absArg()) {
1639 os <<
" (empty)" << std::endl;
1650 throw std::runtime_error(
"Unsupported proxy type.");
1688 set<string>::const_iterator iter =
_boolAttrib.begin() ;
1691 os << (
first?
" [":
",") << *iter ;
1695 if (!
first) os <<
"] " ;
1712 for(
auto const& branch : branches) {
1713 branch->redirectServers(set,
false,
false);
1761 branch->printDirty(
false) ;
1767 case AClean: cout <<
"FORCED clean" ; break ;
1768 case ADirty: cout <<
"FORCED DIRTY" ; break ;
1790 coutI(Optimization) <<
"RooAbsArg::optimizeCacheMode(" <<
GetName() <<
") nodes " << opt <<
" depend on observables, "
1791 <<
"changing cache operation mode from change tracking to unconditional evaluation" << endl ;
1822 auto obj = processedNodes.
findArg(
this);
1823 assert(obj !=
this);
1826 cxcoutI(Optimization) <<
"RooAbsArg::optimizeCacheMode(" <<
GetName()
1827 <<
" node " <<
this <<
" exists already as " << obj <<
" but with the SAME name !" << endl;
1829 processedNodes.
Add(
this);
1835 cxcoutI(Integration) <<
"RooAbsArg::optimizeCacheMode(" <<
GetName() <<
") integral depends on value of one or more observables and will be evaluated for every event" << endl ;
1837 optimizedNodes.
add(*
this,
true) ;
1851 server->optimizeCacheMode(observables,optimizedNodes,processedNodes) ;
1866 coutI(Optimization) <<
"RooAbsArg::findConstantNodes(" <<
GetName() <<
"): components "
1867 << cacheList <<
" depend exclusively on constant parameters and will be precalculated and cached" << endl ;
1886 if (processedNodes.
findArg(
this)) {
1889 processedNodes.
Add(
this) ;
1897 if (!param->isConstant()) {
1918 cxcoutD(Optimization) <<
"RooAbsArg::findConstantNodes(" <<
GetName() <<
") adding self to list of constant nodes" << endl ;
1921 cacheList.
add(*
this,
false) ;
1929 if (server->isDerived()) {
1930 server->findConstantNodes(observables,cacheList,processedNodes) ;
1954 server->constOptimizeTestStatistic(opcode,doAlsoTrackingOpt) ;
1979 clientV->setOperMode(
mode) ;
2024 case Auto: os <<
" [Auto," << (
isValueDirty()?
"Dirty":
"Clean") <<
"] " ; break ;
2025 case AClean: os <<
" [ACLEAN] " ; break ;
2026 case ADirty: os <<
" [ADIRTY] " ; break ;
2053 if (nLevel==0) return ;
2056 if (rmodel && rmodel->isConvolved())
return ;
2084 TString cleanName(rawBranchName) ;
2172 ofstream ofs(fileName) ;
2174 coutE(InputArguments) <<
"RooAbsArg::graphVizTree() ERROR: Cannot open graphViz output file with name " << fileName << endl ;
2191 coutE(InputArguments) <<
"RooAbsArg::graphVizTree() ERROR: output stream provided as input argument is in invalid state" << endl ;
2198 os <<
"digraph \"" <<
GetName() <<
"\"{" << endl ;
2206 string nodeName = node->GetName();
2207 string nodeTitle = node->GetTitle();
2208 string nodeLabel = (useTitle && !nodeTitle.empty()) ? nodeTitle : nodeName;
2211 string::size_type position = nodeLabel.find(
'#') ;
2212 while(useLatex && position!=nodeLabel.npos){
2213 nodeLabel.replace(position, 1,
"\\");
2216 string typeFormat =
"\\texttt{";
2217 string nodeType = (useLatex) ? typeFormat+node->ClassName()+
"}" : node->ClassName();
2219 if (
auto realNode =
dynamic_cast<RooAbsReal*
>(node)) {
2220 nodeLabel += delimiter + std::to_string(realNode->getVal());
2223 os <<
"\"" << nodeName <<
"\" [ color=" << (node->isFundamental()?
"blue":
"red")
2224 <<
", label=\"" << nodeType << delimiter << nodeLabel <<
"\"];" << endl ;
2229 set<pair<RooAbsArg*,RooAbsArg*> > links ;
2233 for(
auto const& link : links) {
2234 os <<
"\"" << link.first->GetName() <<
"\" -> \"" << link.second->GetName() <<
"\";" << endl ;
2250 linkSet.insert(make_pair(
this,server)) ;
2251 server->graphVizAddConnections(linkSet) ;
2345 if (tmp) suffix += tmp ;
2347 return Form(
"%s",suffix.c_str()) ;
2357 for(
auto const& arg : branches) {
2398 _ioReadStack.push(
this) ;
2400 _ioReadStack.pop() ;
2422 auto iter = _ioEvoList.find(
this);
2423 if (iter != _ioEvoList.end()) {
2428 for (
int i = 0; i < iter->second->GetEntriesFast(); i++) {
2432 _ioEvoList.erase(iter);
2450 for (
const auto& iter : _ioEvoList) {
2453 if (!iter.first->_proxyList.GetEntriesFast())
2454 iter.first->_proxyList.Expand(iter.second->GetEntriesFast());
2455 for (
int i = 0; i < iter.second->GetEntriesFast(); i++) {
2456 iter.first->_proxyList.Add(iter.second->At(i));
2480 auto refArray = std::make_unique<TRefArray>();
2481 refArray->Streamer(R__b) ;
2485 RooAbsArg::_ioEvoList[RooAbsArg::_ioReadStack.top()] = std::move(refArray);
2493 for(
TObject * tmpObj : *
this) {
2494 refArray.
Add(tmpObj) ;
2507 std::stringstream s;
2509 s <<
"An instance of " << raa->
ClassName() <<
".";
2521 for(
auto * server :
servers()) {
2522 server->applyWeightSquared(flag);
2529 auto newArg = std::unique_ptr<RooAbsArg>{
static_cast<RooAbsArg *
>(
Clone())};
2547 std::stringstream errorMsg;
2548 errorMsg <<
"Translate function for class \"" <<
ClassName() <<
"\" has not yet been implemented.";
2549 coutE(Minimization) << errorMsg.str() << std::endl;
2550 throw std::runtime_error(errorMsg.str().c_str());
2559 if (
_dataToken != std::numeric_limits<std::size_t>::max()) {
2560 std::stringstream errMsg;
2561 errMsg <<
"The data token for \"" <<
GetName() <<
"\" is already set!"
2562 <<
" Are you trying to evaluate the same object by multiple RooFit::Evaluator instances?"
2563 <<
" This is not allowed.";
2564 throw std::runtime_error(errMsg.str());
istream & operator>>(istream &is, RooAbsArg &arg)
Istream operator.
static Roo_reg_AGKInteg1D instance
TBuffer & operator<<(TBuffer &buf, const Tmpl *obj)
static void indent(ostringstream &buf, int indent_level)
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
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 index
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 GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t attr
Option_t Option_t TPoint TPoint const char mode
char * Form(const char *fmt,...)
Formats a string in a circular formatting buffer.
Common abstract base class for objects that represent a value and a "shape" in RooFit.
RooExpensiveObjectCache & expensiveObjectCache() const
bool overlaps(const RooAbsArg &testArg, bool valueOnly=false) const
Test if any of the nodes of tree are shared with that of the given tree.
void replaceServer(RooAbsArg &oldServer, RooAbsArg &newServer, bool valueProp, bool shapeProp)
Replace 'oldServer' with 'newServer', specifying whether the new server has value or shape server pro...
bool _isConstant
De-duplicated name pointer. This will be equal for all objects with the same name.
void Print(Option_t *options=nullptr) const override
Print the object to the defaultPrintStream().
bool dependsOn(const RooAbsCollection &serverList, const RooAbsArg *ignoreArg=nullptr, bool valueOnly=false) const
Test whether we depend on (ie, are served by) any object in the specified collection.
void attachToStore(RooAbsDataStore &store)
Attach this argument to the data store such that it reads data from there.
bool recursiveRedirectServers(const RooAbsCollection &newServerList, bool mustReplaceAll=false, bool nameChange=false, bool recurseInNewSet=true)
Recursively replace all servers with the new servers in newSet.
const TNamed * namePtr() const
De-duplicated pointer to this object's name.
const char * aggregateCacheUniqueSuffix() const
void printArgs(std::ostream &os) const override
Print object arguments, ie its proxies.
void printClassName(std::ostream &os) const override
Print object class name.
ProxyListCache _proxyListCache
RooWorkspace * _myws
Prevent 'AlwaysDirty' mode for this node.
~RooAbsArg() override
Destructor.
void attachDataStore(const RooAbsDataStore &set)
Replace server nodes with names matching the dataset variable names with those data set variables,...
RooArgSet * _ownedComponents
void printAddress(std::ostream &os) const override
Print address of this RooAbsArg.
void setShapeDirty()
Notify that a shape-like property (e.g. binning) has changed.
void setDataToken(std::size_t index)
Sets the token for retrieving results in the BatchMode. For internal use only.
void registerProxy(RooArgProxy &proxy)
Register an RooArgProxy in the proxy list.
void setOperMode(OperMode mode, bool recurseADirty=true)
Set the operation mode of this node.
bool callRedirectServersHook(RooAbsCollection const &newSet, bool mustReplaceAll, bool nameChange, bool isRecursionStep)
Private helper function for RooAbsArg::redirectServers().
void attachArgs(const RooAbsCollection &set)
Bind this node to objects in set.
void setStringAttribute(const Text_t *key, const Text_t *value)
Associate string 'value' to this object under key 'key'.
RooFit::OwningPtr< RooArgSet > getDependents(const RooArgSet &set) const
bool isShapeServer(const RooAbsArg &arg) const
Check if this is serving shape to arg.
bool isShapeDirty() const
static void ioStreamerPass2Finalize()
Method called by workspace container to finalize schema evolution issues that cannot be handled in a ...
RooFit::OwningPtr< RooArgSet > getParameters(const RooAbsData *data, bool stripDisconnected=true) const
Create a list of leaf nodes in the arg tree starting with ourself as top node that don't match any of...
void addParameters(RooAbsCollection ¶ms, const RooArgSet *nset=nullptr, bool stripDisconnected=true) const
Add all parameters of the function and its daughters to params.
void removeServer(RooAbsArg &server, bool force=false)
Unregister another RooAbsArg as a server to us, ie, declare that we no longer depend on its value and...
RooFit::OwningPtr< RooArgSet > getObservables(const RooArgSet &set, bool valueOnly=true) const
Given a set of possible observables, return the observables that this PDF depends on.
void setTransientAttribute(const Text_t *name, bool value=true)
Set (default) or clear a named boolean attribute of this object.
void graphVizAddConnections(std::set< std::pair< RooAbsArg *, RooAbsArg * > > &)
Utility function that inserts all point-to-point client-server connections between any two RooAbsArgs...
void unRegisterProxy(RooArgProxy &proxy)
Remove proxy from proxy list.
void SetName(const char *name) override
Set the name of the TNamed.
std::set< std::string > _boolAttrib
void unRegisterCache(RooAbsCache &cache)
Unregister a RooAbsCache. Called from the RooAbsCache destructor.
RefCountList_t _clientListValue
bool addOwnedComponents(const RooAbsCollection &comps)
Take ownership of the contents of 'comps'.
void printAttribList(std::ostream &os) const
Transient boolean attributes (not copied in ctor)
void printTree(std::ostream &os, TString indent="") const override
Print object tree structure.
void SetNameTitle(const char *name, const char *title) override
Set all the TNamed parameters (name and title).
friend void RooRefArray::Streamer(TBuffer &)
const Text_t * getStringAttribute(const Text_t *key) const
Get string attribute mapped under key 'key'.
bool findConstantNodes(const RooArgSet &observables, RooArgSet &cacheList)
Find branch nodes with all-constant parameters, and add them to the list of nodes that can be cached ...
static bool _verboseDirty
cache of the list of proxies. Avoids type casting.
void addServerList(RooAbsCollection &serverList, bool valueProp=true, bool shapeProp=false)
Register a list of RooAbsArg as servers to us by calling addServer() for each arg in the list.
virtual bool readFromStream(std::istream &is, bool compact, bool verbose=false)=0
bool redirectServers(const RooAbsCollection &newServerList, bool mustReplaceAll=false, bool nameChange=false, bool isRecursionStep=false)
Replace all direct servers of this object with the new servers in newServerList.
static void setDirtyInhibit(bool flag)
Control global dirty inhibit mode.
virtual void printCompactTreeHook(std::ostream &os, const char *ind="")
Hook function interface for object to insert additional information when printed in the context of a ...
const TNamed * _namePtr
Pointer to global cache manager for any expensive components created by this object.
void printCompactTree(const char *indent="", const char *fileName=nullptr, const char *namePat=nullptr, RooAbsArg *client=nullptr)
Print tree structure of expression tree on stdout, or to file if filename is specified.
virtual std::unique_ptr< RooAbsArg > compileForNormSet(RooArgSet const &normSet, RooFit::Detail::CompileContext &ctx) const
virtual void getParametersHook(const RooArgSet *, RooArgSet *, bool) const
virtual void ioStreamerPass2()
Method called by workspace container to finalize schema evolution issues that cannot be handled in a ...
RooFit::OwningPtr< RooArgSet > getComponents() const
Create a RooArgSet with all components (branch nodes) of the expression tree headed by this object.
bool _prohibitServerRedirect
Set of owned component.
virtual const char * cacheUniqueSuffix() const
RefCountListLegacyIterator_t * makeLegacyIterator(const RefCountList_t &list) const
const RefCountList_t & servers() const
List of all servers of this object.
std::size_t _dataToken
In which workspace do I live, if any.
bool dependsOnValue(const RooAbsCollection &serverList, const RooAbsArg *ignoreArg=nullptr) const
Check whether this object depends on values from an element in the serverList.
void addServer(RooAbsArg &server, bool valueProp=true, bool shapeProp=false, std::size_t refCount=1)
Register another RooAbsArg as a server to us, ie, declare that we depend on it.
virtual void translate(RooFit::Detail::CodeSquashContext &ctx) const
This function defines a translation for each RooAbsReal based object that can be used to express the ...
void removeStringAttribute(const Text_t *key)
Delete a string attribute with a given key.
Int_t Compare(const TObject *other) const override
Utility function used by TCollection::Sort to compare contained TObjects We implement comparison by n...
Int_t defaultPrintContents(Option_t *opt) const override
Define default contents to print.
virtual bool isDerived() const
Does value or shape of this arg depend on any other arg?
virtual void attachToTree(TTree &t, Int_t bufSize=32000)=0
Overloadable function for derived classes to implement attachment as branch to a TTree.
void printComponentTree(const char *indent="", const char *namePat=nullptr, Int_t nLevel=999)
Print tree structure of expression tree on given ostream, only branch nodes are printed.
virtual void constOptimizeTestStatistic(ConstOpCode opcode, bool doAlsoTrackingOpt=true)
Interface function signaling a request to perform constant term optimization.
void setValueDirty()
Mark the element dirty. This forces a re-evaluation when a value is requested.
bool getAttribute(const Text_t *name) const
Check if a named attribute is set. By default, all attributes are unset.
static void verboseDirty(bool flag)
Activate verbose messaging related to dirty flag propagation.
RooFit::OwningPtr< RooArgSet > getVariables(bool stripDisconnected=true) const
Return RooArgSet with all variables (tree leaf nodes of expression tree)
RooAbsCache * getCache(Int_t index) const
Return registered cache object by index.
virtual void writeToStream(std::ostream &os, bool compact) const =0
void printMultiline(std::ostream &os, Int_t contents, bool verbose=false, TString indent="") const override
Implement multi-line detailed printing.
virtual RooAbsArg * cloneTree(const char *newname=nullptr) const
Clone tree expression of objects.
void registerCache(RooAbsCache &cache)
Register RooAbsCache with this object.
virtual void optimizeCacheMode(const RooArgSet &observables)
Activate cache mode optimization with given definition of observables.
RefCountList_t _clientListShape
virtual void attachToVStore(RooVectorDataStore &vstore)=0
TString cleanBranchName() const
Construct a mangled name from the actual name that is free of any math symbols that might be interpre...
bool inhibitDirty() const
Delete watch flag.
bool observableOverlaps(const RooAbsData *dset, const RooAbsArg &testArg) const
Test if any of the dependents of the arg tree (as determined by getObservables) overlaps with those o...
void changeServer(RooAbsArg &server, bool valueProp, bool shapeProp)
Change dirty flag propagation mask for specified server.
Int_t numProxies() const
Return the number of registered proxies.
void printName(std::ostream &os) const override
Print object name.
bool isValueDirty() const
bool _localNoInhibitDirty
Cached isConstant status.
virtual void printMetaArgs(std::ostream &) const
virtual void applyWeightSquared(bool flag)
Disables or enables the usage of squared weights.
static bool _inhibitDirty
void setAttribute(const Text_t *name, bool value=true)
Set (default) or clear a named boolean attribute of this object.
void setProxyNormSet(const RooArgSet *nset)
Forward a change in the cached normalization argset to all the registered proxies.
void branchNodeServerList(RooAbsCollection *list, const RooAbsArg *arg=nullptr, bool recurseNonDerived=false) const
Fill supplied list with all branch nodes of the arg tree starting with ourself as top node.
RefCountList_t _clientList
void printDirty(bool depth=true) const
Print information about current value dirty state information.
RooAbsProxy * getProxy(Int_t index) const
Return the nth proxy from the proxy list.
TObject * Clone(const char *newname=nullptr) const override
Make a clone of an object using the Streamer facility.
RefCountList_t _serverList
void leafNodeServerList(RooAbsCollection *list, const RooAbsArg *arg=nullptr, bool recurseNonDerived=false) const
Fill supplied list with all leaf nodes of the arg tree, starting with ourself as top node.
RooExpensiveObjectCache * _eocache
Prohibit server redirects – Debugging tool.
virtual bool isFundamental() const
Is this object a fundamental type that can be added to a dataset? Fundamental-type subclasses overrid...
virtual bool isValid() const
WVE (08/21/01) Probably obsolete now.
std::set< std::string > _boolAttribTransient
void printTitle(std::ostream &os) const override
Print object title.
virtual bool redirectServersHook(const RooAbsCollection &newServerList, bool mustReplaceAll, bool nameChange, bool isRecursiveStep)
Function that is called at the end of redirectServers().
std::size_t getParametersSizeEstimate(const RooArgSet *nset=nullptr) const
Obtain an estimate of the number of parameters of the function and its daughters.
void graphVizTree(const char *fileName, const char *delimiter="\n", bool useTitle=false, bool useLatex=false)
Create a GraphViz .dot file visualizing the expression tree headed by this RooAbsArg object.
void substituteServer(RooAbsArg *oldServer, RooAbsArg *newServer)
Set by the RooFitDriver for this arg to retrieve its result in the run context.
bool getTransientAttribute(const Text_t *name) const
Check if a named attribute is set.
virtual void operModeHook()
bool recursiveCheckObservables(const RooArgSet *nset) const
Recursively call checkObservables on all nodes in the expression tree.
bool isValueServer(const RooAbsArg &arg) const
Check if this is serving values to arg.
std::map< std::string, std::string > _stringAttrib
Int_t numCaches() const
Return number of registered caches.
virtual bool checkObservables(const RooArgSet *nset) const
Overloadable function in which derived classes can implement consistency checks of the variables.
RooAbsArg()
Default constructor.
void attachDataSet(const RooAbsData &set)
Replace server nodes with names matching the dataset variable names with those data set variables,...
TIteratorToSTLInterface< RefCountList_t::Container_t > RefCountListLegacyIterator_t
std::vector< RooAbsCache * > _cacheList
void treeNodeServerList(RooAbsCollection *list, const RooAbsArg *arg=nullptr, bool doBranch=true, bool doLeaf=true, bool valueOnly=false, bool recurseNonDerived=false) const
Fill supplied list with nodes of the arg tree, following all server links, starting with ourself as t...
RooAbsArg * findNewServer(const RooAbsCollection &newSet, bool nameChange) const
Find the new server in the specified set that matches the old server.
OperMode operMode() const
Query the operation mode of this node.
Abstract base class for data members of RooAbsArgs that cache other (composite) RooAbsArg expressions...
virtual void operModeHook()
Interface for operation mode changes.
virtual void findConstantNodes(const RooArgSet &, RooArgSet &, RooLinkedList &)
Interface for constant term node finding calls.
virtual void printCompactTreeHook(std::ostream &, const char *)
Interface for printing of cache guts in tree mode printing.
virtual bool redirectServersHook(const RooAbsCollection &, bool, bool, bool)
Interface for server redirect calls.
virtual void optimizeCacheMode(const RooArgSet &, RooArgSet &, RooLinkedList &)
Interface for processing of cache mode optimization calls.
Abstract container object that can hold multiple RooAbsArg objects.
RooAbsCollection * selectByAttrib(const char *name, bool value) const
Create a subset of the current collection, consisting only of those elements with the specified attri...
Storage_t const & get() const
Const access to the underlying stl container.
const char * GetName() const override
Returns name of object.
virtual bool add(const RooAbsArg &var, bool silent=false)
Add the specified argument to list.
Storage_t::size_type size() const
void reserve(Storage_t::size_type count)
void clear()
Clear contents. If the collection is owning, it will also delete the contents.
virtual bool addOwned(RooAbsArg &var, bool silent=false)
Add an argument and transfer the ownership to the collection.
void sort(bool reverse=false)
Sort collection using std::sort and name comparison.
void setName(const char *name)
RooAbsArg * find(const char *name) const
Find object with given name in list.
RooAbsDataStore is the abstract base class for data collection that use a TTree as internal storage m...
virtual const RooArgSet * get(Int_t index) const =0
Abstract base class for binned and unbinned datasets.
virtual const RooArgSet * get() const
RooAbsProxy is the abstract interface for proxy classes.
virtual const char * name() const
Abstract base class for objects that represent a real value and implements functionality common to al...
RooArgList is a container object that can hold multiple RooAbsArg objects.
Abstract interface for RooAbsArg proxy classes.
bool isShapeServer() const
Returns true if contents is shape server of owner.
RooAbsArg * absArg() const
Return pointer to contained argument.
bool isValueServer() const
Returns true of contents is value server of owner.
RooArgSet is a container object that can hold multiple RooAbsArg objects.
RooConstVar represent a constant real-valued object.
RooExpensiveObjectCache is a singleton class that serves as repository for objects that are expensive...
static RooExpensiveObjectCache & instance()
Return reference to singleton instance.
A class to maintain the context for squashing of RooFit models into code.
void markAsCompiled(RooAbsArg &arg) const
void compileServers(RooAbsArg &arg, RooArgSet const &normSet)
Switches the message service to a different level while the instance is alive.
RooLinkedList is an collection class for internal use, storing a collection of RooAbsArg pointers in ...
RooAbsArg * findArg(const RooAbsArg *) const
Return pointer to object with given name in collection.
virtual void Add(TObject *arg)
TObject * FindObject(const char *name) const override
Return pointer to object with given name.
RooNameReg is a registry for const char* names.
@ kRenamedArg
TNamed flag to indicate that some RooAbsArg has been renamed (flag set in new name)
const TNamed * constPtr(const char *stringPtr)
Return a unique TNamed pointer for given C++ string.
static RooNameReg & instance()
Return reference to singleton instance.
static void incrementRenameCounter()
The renaming counter has to be incremented every time a RooAbsArg is renamed.
RooPlotable is a 'mix-in' base class that define the standard RooFit plotting and printing methods.
virtual StyleOption defaultPrintStyle(Option_t *opt) const
virtual void printStream(std::ostream &os, Int_t contents, StyleOption style, TString indent="") const
Print description of object on ostream, printing contents set by contents integer,...
virtual void printValue(std::ostream &os) const
Interface to print value of object.
Performs hybrid numerical/analytical integrals of RooAbsReal objects.
RooRealVar represents a variable that can be changed from the outside.
TClass * IsA() const override
void Streamer(TBuffer &) override
Stream an object of class RooRefArray.
RooResolutionModel is the base class for PDFs that represent a resolution model that can be convolute...
RooTreeDataStore is a TTree-backed data storage.
RooVectorDataStore uses std::vectors to store data columns.
const RooArgSet * set(RooStringView name)
Return pointer to previously defined named set with given nmame If no such set is found a null pointe...
bool defineSetInternal(const char *name, const RooArgSet &aset)
Buffer base class used for serializing objects.
virtual Version_t ReadVersion(UInt_t *start=nullptr, UInt_t *bcnt=nullptr, const TClass *cl=nullptr)=0
virtual void SetByteCount(UInt_t cntpos, Bool_t packInVersion=kFALSE)=0
virtual Int_t CheckByteCount(UInt_t startpos, UInt_t bcnt, const TClass *clss)=0
virtual Int_t ReadClassBuffer(const TClass *cl, void *pointer, const TClass *onfile_class=nullptr)=0
virtual UInt_t WriteVersion(const TClass *cl, Bool_t useBcnt=kFALSE)=0
virtual Int_t WriteClassBuffer(const TClass *cl, void *pointer)=0
TIterator and GenericRooFIter front end with STL back end.
The TNamed class is the base class for all named ROOT classes.
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
const char * GetName() const override
Returns name of object.
const char * GetTitle() const override
Returns title of object.
virtual void SetName(const char *name)
Set the name of the TNamed.
Int_t GetEntriesFast() const
virtual void Expand(Int_t newSize)
Expand or shrink the array to newSize elements.
virtual void Compress()
Remove empty slots from array.
Int_t GetEntries() const override
Return the number of objects in array (i.e.
TObject * At(Int_t idx) const override
TObject * Remove(TObject *obj) override
Remove object from array.
TObject * FindObject(const char *name) const override
Find an object in this collection using its name.
void Add(TObject *obj) override
Mother of all ROOT objects.
virtual const char * GetName() const
Returns name of object.
virtual const char * ClassName() const
Returns name of class to which the object belongs.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
An array of references to TObjects.
void Add(TObject *obj) override
void Streamer(TBuffer &) override
Stream all objects in the array to or from the I/O buffer.
const char * Data() const
TString & ReplaceAll(const TString &s1, const TString &s2)
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
TString & Append(const char *cs)
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
A TTree represents a columnar dataset.
T * OwningPtr
An alias for raw pointers for indicating that the return type of a RooFit function is an owning point...
RooAbsArg * cloneTreeWithSameParametersImpl(RooAbsArg const &arg, RooArgSet const *observables)
std::string getColonSeparatedNameString(RooArgSet const &argSet, char delim=':')
std::vector< RooAbsProxy * > cache