00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026 #include "RooFit.h"
00027 #include "Riostream.h"
00028
00029 #include "RooRealBinding.h"
00030 #include "RooAbsReal.h"
00031 #include "RooArgSet.h"
00032 #include "RooAbsRealLValue.h"
00033 #include "RooNameReg.h"
00034 #include "RooMsgService.h"
00035
00036 #include <assert.h>
00037
00038
00039
00040 ClassImp(RooRealBinding)
00041 ;
00042
00043
00044
00045 RooRealBinding::RooRealBinding(const RooAbsReal& func, const RooArgSet &vars, const RooArgSet* nset, Bool_t clipInvalid, const TNamed* rangeName) :
00046 RooAbsFunc(vars.getSize()), _func(&func), _vars(0), _nset(nset), _clipInvalid(clipInvalid), _xsave(0), _rangeName(rangeName)
00047 {
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058 _vars= new RooAbsRealLValue*[getDimension()];
00059 if(0 == _vars) {
00060 _valid= kFALSE;
00061 return;
00062 }
00063
00064 RooAbsArg *var = 0;
00065 TIterator* iter = vars.createIterator() ;
00066 Int_t index(0) ;
00067 while((var=(RooAbsArg*)iter->Next())) {
00068 _vars[index]= dynamic_cast<RooAbsRealLValue*>(var);
00069 if(0 == _vars[index]) {
00070 oocoutE((TObject*)0,InputArguments) << "RooRealBinding: cannot bind to " << var->GetName() << endl ;
00071 _valid= kFALSE;
00072 }
00073 index++ ;
00074 }
00075 delete iter ;
00076 _xvecValid = kTRUE ;
00077 }
00078
00079
00080
00081 RooRealBinding::RooRealBinding(const RooRealBinding& other, const RooArgSet* nset) :
00082 RooAbsFunc(other), _func(other._func), _nset(nset?nset:other._nset), _xvecValid(other._xvecValid),
00083 _clipInvalid(other._clipInvalid), _xsave(0), _rangeName(other._rangeName)
00084 {
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095 _vars= new RooAbsRealLValue*[getDimension()];
00096
00097 for(unsigned int index=0 ; index<getDimension() ; index++) {
00098 _vars[index]= other._vars[index] ;
00099 }
00100 }
00101
00102
00103
00104 RooRealBinding::~RooRealBinding()
00105 {
00106
00107
00108 if(0 != _vars) delete[] _vars;
00109 if (_xsave) delete[] _xsave ;
00110 }
00111
00112
00113
00114
00115 void RooRealBinding::saveXVec() const
00116 {
00117
00118
00119 if (!_xsave) {
00120 _xsave = new Double_t[getDimension()] ;
00121 for (UInt_t i=0 ; i<getDimension() ; i++) {
00122 _xsave[i] = _vars[i]->getVal() ;
00123 }
00124 }
00125 }
00126
00127
00128
00129 void RooRealBinding::restoreXVec() const
00130 {
00131
00132
00133
00134 if (!_xsave) {
00135 return ;
00136 }
00137 for (UInt_t i=0 ; i<getDimension() ; i++) {
00138 _vars[i]->setVal(_xsave[i]) ;
00139 }
00140 }
00141
00142
00143
00144
00145 void RooRealBinding::loadValues(const Double_t xvector[]) const
00146 {
00147
00148
00149
00150 _xvecValid = kTRUE ;
00151 for(UInt_t index= 0; index < _dimension; index++) {
00152 if (_clipInvalid && !_vars[index]->isValidReal(xvector[index])) {
00153 _xvecValid = kFALSE ;
00154 } else {
00155 _vars[index]->setVal(xvector[index],RooNameReg::instance().constStr(_rangeName));
00156 }
00157 }
00158 }
00159
00160
00161
00162 Double_t RooRealBinding::operator()(const Double_t xvector[]) const
00163 {
00164
00165
00166 assert(isValid());
00167 _ncall++ ;
00168 loadValues(xvector);
00169
00170 return _xvecValid ? _func->getVal(_nset) : 0. ;
00171 }
00172
00173
00174
00175 Double_t RooRealBinding::getMinLimit(UInt_t index) const
00176 {
00177
00178 assert(isValid());
00179
00180 return _vars[index]->getMin(RooNameReg::str(_rangeName));
00181 }
00182
00183
00184
00185 Double_t RooRealBinding::getMaxLimit(UInt_t index) const
00186 {
00187
00188
00189 assert(isValid());
00190 return _vars[index]->getMax(RooNameReg::str(_rangeName));
00191 }
00192
00193
00194
00195 const char* RooRealBinding::getName() const
00196 {
00197
00198
00199 return _func->GetName() ;
00200 }
00201
00202
00203
00204 std::list<Double_t>* RooRealBinding::plotSamplingHint(RooAbsRealLValue& obs, Double_t xlo, Double_t xhi) const
00205 {
00206 return _func->plotSamplingHint(obs,xlo,xhi) ;
00207 }