#include "RooFit.h"
#include "RooAbsOptGoodnessOfFit.h"
#include "RooAbsOptGoodnessOfFit.h"
#include "RooAbsPdf.h"
#include "RooAbsData.h"
#include "RooArgSet.h"
#include "RooRealVar.h"
#include "RooErrorHandler.h"
#include "RooGlobalFunc.h"
ClassImp(RooAbsOptGoodnessOfFit)
;
RooAbsOptGoodnessOfFit::RooAbsOptGoodnessOfFit(const char *name, const char *title, RooAbsPdf& pdf, RooAbsData& data,
const RooArgSet& projDeps, const char* rangeName, Int_t nCPU, Bool_t verbose, Bool_t splitCutRange) :
RooAbsGoodnessOfFit(name,title,pdf,data,projDeps,rangeName, nCPU, verbose, splitCutRange),
_projDeps(0)
{
if (operMode()!=Slave) {
_normSet = 0 ;
return ;
}
RooArgSet obs(*data.get()) ;
obs.remove(projDeps,kTRUE,kTRUE) ;
if (pdf.recursiveCheckObservables(&obs)) {
cout << "RooAbsOptGoodnessOfFit: ERROR in PDF dependents, abort" << endl ;
RooErrorHandler::softAbort() ;
return ;
}
RooArgSet* pdfDepSet = pdf.getObservables(&data) ;
const RooArgSet* dataDepSet = data.get() ;
TIterator* iter = pdfDepSet->createIterator() ;
RooAbsArg* arg ;
while((arg=(RooAbsArg*)iter->Next())) {
RooRealVar* pdfReal = dynamic_cast<RooRealVar*>(arg) ;
if (!pdfReal) continue ;
RooRealVar* datReal = dynamic_cast<RooRealVar*>(dataDepSet->find(pdfReal->GetName())) ;
if (!datReal) continue ;
if (pdfReal->getMin()<(datReal->getMin()-1e-6)) {
cout << "RooAbsOptGoodnessOfFit: ERROR minimum of PDF variable " << arg->GetName()
<< "(" << pdfReal->getMin() << ") is smaller than that of "
<< arg->GetName() << " in the dataset (" << datReal->getMin() << ")" << endl ;
RooErrorHandler::softAbort() ;
return ;
}
if (pdfReal->getMax()>(datReal->getMax()+1e-6)) {
cout << "RooAbsOptGoodnessOfFit: ERROR maximum of PDF variable " << arg->GetName()
<< " is smaller than that of " << arg->GetName() << " in the dataset" << endl ;
RooErrorHandler::softAbort() ;
return ;
}
}
if (rangeName) {
_dataClone = ((RooAbsData&)data).reduce(RooFit::SelectVars(*pdfDepSet),RooFit::CutRange(rangeName)) ;
} else {
_dataClone = ((RooAbsData&)data).reduce(RooFit::SelectVars(*pdfDepSet)) ;
}
if (rangeName) {
TIterator* iter2 = _dataClone->get()->createIterator() ;
while((arg=(RooAbsArg*)iter2->Next())) {
RooRealVar* pdfReal = dynamic_cast<RooRealVar*>(arg) ;
if (pdfReal) {
pdfReal->setRange("NormalizationRange",pdfReal->getMin(),pdfReal->getMax()) ;
pdfReal->setRange(pdfReal->getMin(rangeName),pdfReal->getMax(rangeName)) ;
}
}
if (!_splitRange) {
iter->Reset() ;
while((arg=(RooAbsArg*)iter->Next())) {
RooRealVar* pdfReal = dynamic_cast<RooRealVar*>(arg) ;
if (pdfReal) {
pdfReal->setRange("fit",pdfReal->getMin(rangeName),pdfReal->getMax(rangeName)) ;
}
}
}
delete iter2 ;
}
delete iter ;
delete pdfDepSet ;
setEventCount(_dataClone->numEntries()) ;
RooArgSet tmp("PdfBranchNodeList") ;
pdf.branchNodeServerList(&tmp) ;
_pdfCloneSet = (RooArgSet*) tmp.snapshot(kFALSE) ;
_pdfClone = (RooAbsPdf*) _pdfCloneSet->find(pdf.GetName()) ;
if (rangeName) {
_pdfClone->fixAddCoefNormalization(*_dataClone->get()) ;
_pdfClone->fixAddCoefRange("NormalizationRange") ;
}
_pdfClone->attachDataSet(*_dataClone) ;
_normSet = (RooArgSet*) data.get()->snapshot(kFALSE) ;
if (projDeps.getSize()>0) {
_projDeps = (RooArgSet*) projDeps.snapshot(kFALSE) ;
_normSet->remove(*_projDeps,kTRUE,kTRUE) ;
RooArgSet *projDataDeps = (RooArgSet*) _dataClone->get()->selectCommon(*_projDeps) ;
projDataDeps->setAttribAll("projectedDependent") ;
delete projDataDeps ;
}
RooArgSet* params = _pdfClone->getParameters(_dataClone) ;
_paramSet.add(*params) ;
delete params ;
if (_projDeps) {
RooArgSet *projDataDeps = (RooArgSet*) _dataClone->get()->selectCommon(*_projDeps) ;
projDataDeps->setAttribAll("projectedDependent") ;
delete projDataDeps ;
}
_pdfClone->optimizeDirty(*_dataClone,_normSet,_verbose) ;
}
RooAbsOptGoodnessOfFit::RooAbsOptGoodnessOfFit(const RooAbsOptGoodnessOfFit& other, const char* name) :
RooAbsGoodnessOfFit(other,name)
{
if (operMode()!=Slave) {
_normSet = other._normSet ? ((RooArgSet*) other._normSet->snapshot()) : 0 ;
return ;
}
_pdfCloneSet = (RooArgSet*) other._pdfCloneSet->snapshot(kFALSE) ;
_pdfClone = (RooAbsPdf*) _pdfCloneSet->find(other._pdfClone->GetName()) ;
TIterator* iter = _pdfCloneSet->createIterator() ;
RooAbsArg* branch ;
while((branch=(RooAbsArg*)iter->Next())) {
branch->setOperMode(other._pdfCloneSet->find(branch->GetName())->operMode()) ;
}
delete iter ;
_dataClone = (RooAbsData*) other._dataClone->cacheClone(_pdfCloneSet) ;
_pdfClone->attachDataSet(*_dataClone) ;
_normSet = (RooArgSet*) other._normSet->snapshot() ;
if (other._projDeps) {
_projDeps = (RooArgSet*) other._projDeps->snapshot() ;
} else {
_projDeps = 0 ;
}
}
RooAbsOptGoodnessOfFit::~RooAbsOptGoodnessOfFit()
{
if (operMode()==Slave) {
delete _pdfCloneSet ;
delete _dataClone ;
delete _normSet ;
delete _projDeps ;
}
}
Double_t RooAbsOptGoodnessOfFit::combinedValue(RooAbsReal** array, Int_t n) const
{
Double_t sum(0) ;
Int_t i ;
for (i=0 ; i<n ; i++) {
Double_t tmp = array[i]->getVal() ;
if (tmp==0) return 0 ;
sum += tmp ;
}
return sum ;
}
Bool_t RooAbsOptGoodnessOfFit::redirectServersHook(const RooAbsCollection& newServerList, Bool_t mustReplaceAll, Bool_t nameChange, Bool_t isRecursive)
{
RooAbsGoodnessOfFit::redirectServersHook(newServerList,mustReplaceAll,nameChange,isRecursive) ;
if (operMode()!=Slave) return kFALSE ;
Bool_t ret = _pdfClone->recursiveRedirectServers(newServerList,kFALSE,nameChange) ;
return ret ;
}
void RooAbsOptGoodnessOfFit::printCompactTreeHook(ostream& os, const char* indent)
{
RooAbsGoodnessOfFit::printCompactTreeHook(os,indent) ;
if (operMode()!=Slave) return ;
TString indent2(indent) ;
indent2 += ">>" ;
_pdfClone->printCompactTree(os,indent2) ;
}
void RooAbsOptGoodnessOfFit::constOptimize(ConstOpCode opcode)
{
RooAbsGoodnessOfFit::constOptimize(opcode);
if (operMode()!=Slave) return ;
if (_verbose) {
cout << "RooAbsOptGoodnessOfFit::constOptimize(" << GetName() << ") Action=" ;
}
switch(opcode) {
case Activate:
if (_verbose) cout << "Activate" << endl ;
_pdfClone->doConstOpt(*_dataClone,_normSet,_verbose) ;
break ;
case DeActivate:
if (_verbose) cout << "DeActivate" << endl ;
_pdfClone->undoConstOpt(*_dataClone,_normSet,_verbose) ;
break ;
case ConfigChange:
if (_verbose) cout << "ConfigChange" << endl ;
_pdfClone->undoConstOpt(*_dataClone,_normSet,_verbose) ;
_pdfClone->doConstOpt(*_dataClone,_normSet,_verbose) ;
break ;
case ValueChange:
if (_verbose) cout << "ValueChange" << endl ;
_pdfClone->undoConstOpt(*_dataClone,_normSet,_verbose) ;
_pdfClone->doConstOpt(*_dataClone,_normSet,_verbose) ;
break ;
}
}
ROOT page - Class index - Class Hierarchy - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.