Logo ROOT   6.16/01
Reference Guide
RooErrorVar.cxx
Go to the documentation of this file.
1/*****************************************************************************
2 * Project: RooFit *
3 * Package: RooFitCore *
4 * @(#)root/roofitcore:$Id$
5 * Authors: *
6 * WV, Wouter Verkerke, UC Santa Barbara, verkerke@slac.stanford.edu *
7 * DK, David Kirkby, UC Irvine, dkirkby@uci.edu *
8 * *
9 * Copyright (c) 2000-2005, Regents of the University of California *
10 * and Stanford University. All rights reserved. *
11 * *
12 * Redistribution and use in source and binary forms, *
13 * with or without modification, are permitted according to the terms *
14 * listed in LICENSE (http://roofit.sourceforge.net/license.txt) *
15 *****************************************************************************/
16
17/**
18\file RooErrorVar.cxx
19\class RooErrorVar
20\ingroup Roofitcore
21
22RooErrorVar is an auxilary class that represents the error
23of a RooRealVar as a seperate object. The main reason of
24existence of this class is to facilitate the reuse of existing
25techniques to perform calculations that involve a RooRealVars
26error, such as calculating the pull value.
27**/
28
29#include "RooFit.h"
30#include "Riostream.h"
31
32#include "RooErrorVar.h"
33#include "RooErrorVar.h"
34#include "RooAbsBinning.h"
35#include "RooStreamParser.h"
36#include "RooRangeBinning.h"
37#include "RooMsgService.h"
38
39
40
41using namespace std;
42
44;
45
46
47
48////////////////////////////////////////////////////////////////////////////////
49/// Construct an lvalue variable representing the error of RooRealVar input
50
51RooErrorVar::RooErrorVar(const char *name, const char *title, const RooRealVar& input) :
53 _realVar("realVar","RooRealVar with error",this,(RooAbsReal&)input)
54{
55 _binning = new RooUniformBinning(-1,1,100) ;
56}
57
58
59
60////////////////////////////////////////////////////////////////////////////////
61
62RooErrorVar::RooErrorVar(const RooErrorVar& other, const char* name) :
64 _realVar("realVar",this,other._realVar)
65{
66 _binning = other._binning->clone() ;
67
68 // Copy constructor
69
70 TIterator* iter = other._altBinning.MakeIterator() ;
71 RooAbsBinning* binning ;
72 while((binning=(RooAbsBinning*)iter->Next())) {
73 _altBinning.Add(binning->clone()) ;
74 }
75 delete iter ;
76}
77
78
79
80////////////////////////////////////////////////////////////////////////////////
81/// Destructor
82
84{
85 delete _binning ;
86}
87
88
89
90////////////////////////////////////////////////////////////////////////////////
91/// Return value, i.e. error on input variable
92
94{
95 return evaluate();
96}
97
98
99
100////////////////////////////////////////////////////////////////////////////////
101/// Return true if we have binning with given name
102
104{
106}
107
108
109
110////////////////////////////////////////////////////////////////////////////////
111/// Return binning with given name. If no binning exists with such a name, clone the default
112/// binning on the fly if so requested
113
114const RooAbsBinning& RooErrorVar::getBinning(const char* name, Bool_t verbose, Bool_t createOnTheFly) const
115{
116 return const_cast<RooErrorVar*>(this)->getBinning(name,verbose,createOnTheFly) ;
117}
118
119
120
121////////////////////////////////////////////////////////////////////////////////
122/// Return binning with given name. If no binning exists with such a name, clone the default
123/// binning on the fly if so requested
124
125RooAbsBinning& RooErrorVar::getBinning(const char* name, Bool_t /*verbose*/, Bool_t createOnTheFly)
126{
127 // Return default (normalization) binning and range if no name is specified
128 if (name==0) {
129 return *_binning ;
130 }
131
132 // Check if binning with this name has been created already
134 if (binning) {
135 return *binning ;
136 }
137
138 // Return default binning if binning is not found and no creation is requested
139 if (!createOnTheFly) {
140 return *_binning ;
141 }
142
143 // Create a new RooRangeBinning with this name with default range
144 binning = new RooRangeBinning(getMin(),getMax(),name) ;
145 coutI(Contents) << "RooErrorVar::getBinning(" << GetName() << ") new range named '"
146 << name << "' created with default bounds" << endl ;
147
148 _altBinning.Add(binning) ;
149
150 return *binning ;
151}
152
153////////////////////////////////////////////////////////////////////////////////
154/// Get a list of all binning names. An empty name implies the default binning.
155/// A 0 pointer should be passed to getBinning in this case.
156
157std::list<std::string> RooErrorVar::getBinningNames() const
158{
159 std::list<std::string> binningNames(1, "");
160
162 const RooAbsArg* binning = 0;
163 while((binning = iter.next())) {
164 const char* name = binning->GetName();
165 binningNames.push_back(name);
166 }
167 return binningNames;
168}
169
170////////////////////////////////////////////////////////////////////////////////
171/// Store given binning with this variable under the given name
172
173void RooErrorVar::setBinning(const RooAbsBinning& binning, const char* name)
174{
175 if (!name) {
176 if (_binning) delete _binning ;
177 _binning = binning.clone() ;
178 } else {
179
180 // Remove any old binning with this name
182 if (oldBinning) {
183 _altBinning.Remove(oldBinning) ;
184 delete oldBinning ;
185 }
186
187 // Insert new binning in list of alternative binnings
188 RooAbsBinning* newBinning = binning.clone() ;
189 newBinning->SetName(name) ;
190 newBinning->SetTitle(name) ;
191 _altBinning.Add(newBinning) ;
192
193 }
194
195
196}
197
198
199
200////////////////////////////////////////////////////////////////////////////////
201/// Set the lower bound of the range with the given name to the given value
202/// If name is a null pointer, set the lower bound of the default range
203
204void RooErrorVar::setMin(const char* name, Double_t value)
205{
206 // Set new minimum of fit range
207 RooAbsBinning& binning = getBinning(name) ;
208
209 // Check if new limit is consistent
210 if (value >= getMax()) {
211 coutW(InputArguments) << "RooErrorVar::setMin(" << GetName()
212 << "): Proposed new fit min. larger than max., setting min. to max." << endl ;
213 binning.setMin(getMax()) ;
214 } else {
215 binning.setMin(value) ;
216 }
217
218 // Clip current value in window if it fell out
219 if (!name) {
220 Double_t clipValue ;
221 if (!inRange(_value,0,&clipValue)) {
222 setVal(clipValue) ;
223 }
224 }
225
226 setShapeDirty() ;
227}
228
229
230////////////////////////////////////////////////////////////////////////////////
231/// Set the upper bound of the range with the given name to the given value
232/// If name is a null pointer, set the upper bound of the default range
233
234void RooErrorVar::setMax(const char* name, Double_t value)
235{
236 // Set new maximum of fit range
237 RooAbsBinning& binning = getBinning(name) ;
238
239 // Check if new limit is consistent
240 if (value < getMin()) {
241 coutW(InputArguments) << "RooErrorVar::setMax(" << GetName()
242 << "): Proposed new fit max. smaller than min., setting max. to min." << endl ;
243 binning.setMax(getMin()) ;
244 } else {
245 binning.setMax(value) ;
246 }
247
248 // Clip current value in window if it fell out
249 if (!name) {
250 Double_t clipValue ;
251 if (!inRange(_value,0,&clipValue)) {
252 setVal(clipValue) ;
253 }
254 }
255
256 setShapeDirty() ;
257}
258
259
260
261////////////////////////////////////////////////////////////////////////////////
262/// Set the upper and lower lower bound of the range with the given name to the given values
263/// If name is a null pointer, set the upper and lower bounds of the default range
264
265void RooErrorVar::setRange( const char* name, Double_t min, Double_t max)
266{
268
269 // Set new fit range
270 RooAbsBinning& binning = getBinning(name,kFALSE) ;
271
272 // Check if new limit is consistent
273 if (min>max) {
274 coutW(InputArguments) << "RooErrorVar::setRange(" << GetName()
275 << "): Proposed new fit max. smaller than min., setting max. to min." << endl ;
276 binning.setRange(min,min) ;
277 } else {
278 binning.setRange(min,max) ;
279 }
280
281 if (!exists) {
282 coutI(InputArguments) << "RooErrorVar::setRange(" << GetName()
283 << ") new range named '" << name << "' created with bounds ["
284 << min << "," << max << "]" << endl ;
285 }
286
287 setShapeDirty() ;
288}
289
290
291
292////////////////////////////////////////////////////////////////////////////////
293/// Read object contents from given stream
294
295Bool_t RooErrorVar::readFromStream(istream& is, Bool_t /*compact*/, Bool_t verbose)
296{
297 TString token,errorPrefix("RooErrorVar::readFromStream(") ;
298 errorPrefix.Append(GetName()) ;
299 errorPrefix.Append(")") ;
300 RooStreamParser parser(is,errorPrefix) ;
301 Double_t value(0) ;
302
303 // Compact mode: Read single token
304 if (parser.readDouble(value,verbose)) return kTRUE ;
305 if (isValidReal(value,verbose)) {
306 setVal(value) ;
307 return kFALSE ;
308 } else {
309 return kTRUE ;
310 }
311}
312
313
314
315////////////////////////////////////////////////////////////////////////////////
316/// Write value to stream
317
318void RooErrorVar::writeToStream(ostream& os, Bool_t /*compact*/) const
319{
320 os << getVal() ;
321}
322
323
324////////////////////////////////////////////////////////////////////////////////
325/// Force the internal value cache to be up to date
326
328{
329 _value = evaluate() ;
330}
331
332
333
#define coutI(a)
Definition: RooMsgService.h:31
#define coutW(a)
Definition: RooMsgService.h:33
const Bool_t kFALSE
Definition: RtypesCore.h:88
bool Bool_t
Definition: RtypesCore.h:59
double Double_t
Definition: RtypesCore.h:55
const Bool_t kTRUE
Definition: RtypesCore.h:87
#define ClassImp(name)
Definition: Rtypes.h:363
RooAbsArg is the common abstract base class for objects that represent a value (of arbitrary type) an...
Definition: RooAbsArg.h:66
void setShapeDirty() const
Definition: RooAbsArg.h:442
RooAbsBinning is the abstract base class for RooRealVar binning definitions This class defines the in...
Definition: RooAbsBinning.h:26
virtual RooAbsBinning * clone(const char *name=0) const =0
virtual void setMin(Double_t xlo)
Definition: RooAbsBinning.h:51
virtual void setMax(Double_t xhi)
Definition: RooAbsBinning.h:55
RooAbsRealLValue is the common abstract base class for objects that represent a real value that may a...
virtual Double_t getMax(const char *name=0) const
virtual Bool_t isValidReal(Double_t value, Bool_t printError=kFALSE) const
Check if given value is valid.
virtual Bool_t inRange(const char *name) const
Check if current value is inside range with given name.
virtual Double_t getMin(const char *name=0) const
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
Definition: RooAbsReal.h:53
Double_t _value
Definition: RooAbsReal.h:391
Double_t getVal(const RooArgSet *set=0) const
Evaluate object. Returns either cached value or triggers a recalculation.
Definition: RooAbsReal.h:64
RooArgSet is a container object that can hold multiple RooAbsArg objects.
Definition: RooArgSet.h:28
RooErrorVar is an auxilary class that represents the error of a RooRealVar as a seperate object.
Definition: RooErrorVar.h:28
void setBinning(const RooAbsBinning &binning, const char *name=0)
Store given binning with this variable under the given name.
void setRange(Double_t min, Double_t max)
Definition: RooErrorVar.h:69
void syncCache(const RooArgSet *set=0)
Optional alternative ranges and binnings.
void setMin(Double_t value)
Definition: RooErrorVar.h:61
void setMax(Double_t value)
Definition: RooErrorVar.h:65
virtual Double_t getValV(const RooArgSet *set=0) const
Return value, i.e. error on input variable.
Definition: RooErrorVar.cxx:93
virtual Double_t evaluate() const
Evaluate this PDF / function / constant. Needs to be overridden by all derived classes.
Definition: RooErrorVar.h:41
virtual Bool_t readFromStream(std::istream &is, Bool_t compact, Bool_t verbose=kFALSE)
Read object contents from given stream.
RooLinkedList _altBinning
Definition: RooErrorVar.h:107
Bool_t hasBinning(const char *name) const
Return true if we have binning with given name.
virtual void setVal(Double_t value)
Definition: RooErrorVar.h:46
virtual ~RooErrorVar()
Destructor.
Definition: RooErrorVar.cxx:83
RooAbsBinning * _binning
Definition: RooErrorVar.h:112
virtual void writeToStream(std::ostream &os, Bool_t compact) const
Write value to stream.
std::list< std::string > getBinningNames() const
Get a list of all binning names.
const RooAbsBinning & getBinning(const char *name=0, Bool_t verbose=kTRUE, Bool_t createOnTheFly=kFALSE) const
Return binning with given name.
RooAbsArg * next()
TObject * FindObject(const char *name) const
Return pointer to obejct with given name.
TIterator * MakeIterator(Bool_t dir=kTRUE) const
Return an iterator over this list.
RooFIter fwdIterator() const
virtual void Add(TObject *arg)
Definition: RooLinkedList.h:62
virtual Bool_t Remove(TObject *arg)
Remove object from collection.
RooRangeBinning is binning/range definition that only defines a range but no binning.
RooRealVar represents a fundamental (non-derived) real valued object.
Definition: RooRealVar.h:36
Bool_t readDouble(Double_t &value, Bool_t zapOnError=kFALSE)
Read the next token and convert it to a Double_t.
RooUniformBinning is an implementation of RooAbsBinning that provides a uniform binning in 'n' bins b...
Iterator abstract base class.
Definition: TIterator.h:30
virtual TObject * Next()=0
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
Definition: TNamed.cxx:164
virtual void SetName(const char *name)
Set the name of the TNamed.
Definition: TNamed.cxx:140
virtual const char * GetName() const
Returns name of object.
Definition: TNamed.h:47
@ InputArguments
Definition: RooGlobalFunc.h:58
STL namespace.