Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
RooUnblindCPAsymVar.cxx
Go to the documentation of this file.
1/*****************************************************************************
2 * Project: RooFit *
3 * Package: RooFitModels *
4 * @(#)root/roofit:$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/** \class RooUnblindCPAsymVar
18 \ingroup Roofit
19
20Implementation of BlindTools' CP asymmetry blinding method
21A RooUnblindCPAsymVar object is a real valued function
22object, constructed from a blind value holder and a
23set of unblinding parameters. When supplied to a PDF
24in lieu of a regular parameter, the blind value holder
25supplied to the unblinded objects will in a fit be minimized
26to blind value corresponding to the actual minimum of the
27parameter. The transformation is chosen such that the
28the error on the blind parameters is identical to that
29of the unblind parameter
30**/
31
32#include "RooArgSet.h"
33#include "RooUnblindCPAsymVar.h"
34
35
36using namespace std;
37
39
40////////////////////////////////////////////////////////////////////////////////
41/// Default constructor
42
44{
45}
46
47////////////////////////////////////////////////////////////////////////////////
48/// Constructor from a given RooAbsReal (to hold the blind value) and a set of blinding parameters
49
50RooUnblindCPAsymVar::RooUnblindCPAsymVar(const char *name, const char *title,
51 const char *blindString, RooAbsReal& cpasym)
52 : RooAbsHiddenReal(name,title),
53 _asym("asym","CP Asymmetry",this,cpasym),
54 _blindEngine(blindString)
55{
56}
57
58////////////////////////////////////////////////////////////////////////////////
59/// Constructor from a given RooAbsReal (to hold the blind value) and a set of blinding parameters
60
61RooUnblindCPAsymVar::RooUnblindCPAsymVar(const char *name, const char *title,
62 const char *blindString, RooAbsReal& cpasym, RooAbsCategory& blindState)
63 : RooAbsHiddenReal(name,title,blindState),
64 _asym("asym","CP Asymmetry",this,cpasym),
65 _blindEngine(blindString)
66{
67}
68
69////////////////////////////////////////////////////////////////////////////////
70/// Copy constructor
71
73 RooAbsHiddenReal(other, name),
74 _asym("asym",this,other._asym),
75 _blindEngine(other._blindEngine)
76{
77}
78
79////////////////////////////////////////////////////////////////////////////////
80/// Copy constructor
81
83{
84}
85
86////////////////////////////////////////////////////////////////////////////////
87
89{
90 if (isHidden()) {
91 // Blinding active for this event
93 } else {
94 // Blinding not active for this event
95 return _asym ;
96 }
97}
#define ClassImp(name)
Definition Rtypes.h:377
char name[80]
Definition TGX11.cxx:110
A space to attach TBranches.
RooAbsHiddenReal is a base class for objects that want to hide their return value from interactive us...
bool isHidden() const
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
Definition RooAbsReal.h:62
double UnHideAsym(double AsymPrime) const
Implementation of BlindTools' CP asymmetry blinding method A RooUnblindCPAsymVar object is a real val...
~RooUnblindCPAsymVar() override
Copy constructor.
double evaluate() const override
Evaluate this PDF / function / constant. Needs to be overridden by all derived classes.
RooUnblindCPAsymVar()
Default constructor.