ROOT
6.06/09
Reference Guide
ROOT Home Page
Main Page
Related Pages
User's Classes
Namespaces
All Classes
Files
Release Notes
File List
File Members
roofit
roofit
inc
RooBlindTools.h
Go to the documentation of this file.
1
/*****************************************************************************
2
* Project: RooFit *
3
* Package: RooFitModels *
4
* File: $Id: RooBlindTools.h,v 1.10 2007/05/11 10:15:52 verkerke Exp $
5
* Authors: *
6
* AR, Aaron Roodman, Stanford University, roodman@slac.stanford.edu *
7
* WV, Wouter Verkerke, UC Santa Barbara, verkerke@slac.stanford.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
#ifndef ROO_BLIND_TOOLS
17
#define ROO_BLIND_TOOLS
18
19
// ---------------------
20
// -- Class Interface --
21
// ---------------------
22
23
#include "
Rtypes.h
"
24
#include "
TString.h
"
25
26
class
RooBlindTools
{
27
28
//--------------------
29
// Instance Members --
30
//--------------------
31
32
public
:
33
34
enum
blindMode
{
35
full
=0,
// blind both parameters and data
36
dataonly
// blind data only
37
38
};
39
40
public
:
41
42
// Constructors
43
RooBlindTools
() {} ;
44
45
RooBlindTools
46
(
const
char
*
stSeed
,
// blinding seed string
47
blindMode
Mode
=
full
,
// blinding mode
48
Double_t
centralValue=0.0,
// Central value for Precision measurements
49
Double_t
sigmaOffset=1.0,
// range for Offset
50
Bool_t
s2bMode=
kFALSE
// Use sin2beta modifications?
51
);
52
53
// Copy
54
RooBlindTools
(
const
RooBlindTools
& );
55
56
// Destructor
57
virtual
~RooBlindTools
( );
58
59
// Operators
60
61
Double_t
Randomizer
(
const
char
*StringAlphabet)
const
;
62
63
Double_t
PseudoRandom
(
Int_t
Seed)
const
;
64
65
Double_t
MakeOffset
(
const
char
*StringAlphabet)
const
;
66
67
Double_t
MakeGaussianOffset
(
const
char
*StringAlphabet)
const
;
68
69
Double_t
MakeSignFlip
(
const
char
*StringAlphabet)
const
;
70
71
Int_t
SignOfTag
(
Double_t
STag)
const
;
72
73
Double_t
HideDeltaZ
(
Double_t
DeltaZ,
Double_t
STag)
const
;
74
75
Double_t
HiDelZPdG
(
Double_t
DeltaZ,
Double_t
STag,
Double_t
PdG)
const
;
76
77
Double_t
UnHideDeltaZ
(
Double_t
DeltaZPrime,
Double_t
STag)
const
;
78
79
Double_t
UnHiDelZPdG
(
Double_t
DeltaZPrime,
Double_t
STag,
Double_t
PdG)
const
;
80
81
Double_t
HideAsym
(
Double_t
Asym)
const
;
82
83
Double_t
HiAsPdG
(
Double_t
Asym,
Double_t
PdG)
const
;
84
85
Double_t
UnHideAsym
(
Double_t
AsymPrime)
const
;
86
87
Double_t
UnHiAsPdG
(
Double_t
AsymPrime,
Double_t
PdG)
const
;
88
89
Double_t
HideDeltaM
(
Double_t
DeltaM)
const
;
90
91
Double_t
UnHideDeltaM
(
Double_t
DeltaMPrime)
const
;
92
93
Double_t
MysteryPhase
()
const
;
94
95
Double_t
RandomizeTag
(
Double_t
STag,
Int_t
EventNumber)
const
;
96
97
Double_t
HidePrecision
(
Double_t
Precision
)
const
;
98
99
Double_t
UnHidePrecision
(
Double_t
PrecisionPrime)
const
;
100
101
Double_t
HideOffset
(
Double_t
Precision
)
const
;
102
103
Double_t
UnHideOffset
(
Double_t
PrecisionBlind )
const
;
104
105
Double_t
HideUniform
(
Double_t
Precision
)
const
;
106
107
Double_t
UnHideUniform
(
Double_t
PrecisionBlind )
const
;
108
109
110
const
char
*
stSeed
()
const
{
return
_stSeed
;}
111
112
const
blindMode
&
mode
()
const
{
return
_mode
;}
113
114
void
setMode
(
blindMode
bmode) {
_mode
=bmode;}
115
116
Double_t
getPrecisionCentralValue
()
const
{
return
_PrecisionCentralValue
;}
117
118
Double_t
getPrecisionOffsetScale
()
const
{
return
_PrecisionOffsetScale
;}
119
120
private
:
121
122
// Friends
123
// Data members
124
125
TString
_stSeed
;
126
Double_t
_DeltaZOffset
;
127
Double_t
_DeltaZSignFlip
;
128
Double_t
_DeltaZScale
;
129
Double_t
_AsymOffset
;
130
Double_t
_AsymSignFlip
;
131
Double_t
_DeltaMScale
;
132
Double_t
_DeltaMOffset
;
133
Double_t
_MysteryPhase
;
134
Double_t
_STagConstant
;
135
Double_t
_PrecisionSignFlip
;
136
Double_t
_PrecisionOffsetScale
;
137
Double_t
_PrecisionOffset
;
138
Double_t
_PrecisionUniform
;
139
Double_t
_PrecisionCentralValue
;
140
blindMode
_mode
;
141
Bool_t
_s2bMode
;
142
143
// setup data members from string seed
144
void
setup
(
const
char
*
stSeed
);
145
146
protected
:
147
148
// Helper functions
149
ClassDef
(
RooBlindTools
,1)
// Root implementation of BlindTools
150
};
151
152
#endif
153
154
RooBlindTools::setMode
void setMode(blindMode bmode)
Definition:
RooBlindTools.h:114
RooBlindTools::HideAsym
Double_t HideAsym(Double_t Asym) const
Definition:
RooBlindTools.cxx:172
RooBlindTools::SignOfTag
Int_t SignOfTag(Double_t STag) const
Definition:
RooBlindTools.cxx:453
RooBlindTools::MysteryPhase
Double_t MysteryPhase() const
Definition:
RooBlindTools.cxx:217
RooBlindTools::MakeOffset
Double_t MakeOffset(const char *StringAlphabet) const
Definition:
RooBlindTools.cxx:405
Rtypes.h
RooBlindTools::UnHideOffset
Double_t UnHideOffset(Double_t PrecisionBlind) const
Definition:
RooBlindTools.cxx:276
RooBlindTools::dataonly
Definition:
RooBlindTools.h:36
RooBlindTools::_stSeed
TString _stSeed
Definition:
RooBlindTools.h:125
ROOT::Math::MCIntegration::Mode
Mode
Definition:
MCIntegrationTypes.h:51
RooBlindTools::HideDeltaZ
Double_t HideDeltaZ(Double_t DeltaZ, Double_t STag) const
Definition:
RooBlindTools.cxx:121
RooBlindTools::MakeGaussianOffset
Double_t MakeGaussianOffset(const char *StringAlphabet) const
Definition:
RooBlindTools.cxx:417
RooBlindTools::_DeltaZScale
Double_t _DeltaZScale
Definition:
RooBlindTools.h:128
TString
Basic string class.
Definition:
TString.h:137
RooBlindTools::HideUniform
Double_t HideUniform(Double_t Precision) const
Definition:
RooBlindTools.cxx:306
Int_t
int Int_t
Definition:
RtypesCore.h:41
Bool_t
bool Bool_t
Definition:
RtypesCore.h:59
kFALSE
const Bool_t kFALSE
Definition:
Rtypes.h:92
RooBlindTools::stSeed
const char * stSeed() const
Definition:
RooBlindTools.h:110
RooBlindTools::RandomizeTag
Double_t RandomizeTag(Double_t STag, Int_t EventNumber) const
Definition:
RooBlindTools.cxx:317
RooBlindTools::_STagConstant
Double_t _STagConstant
Definition:
RooBlindTools.h:134
RooBlindTools::UnHideUniform
Double_t UnHideUniform(Double_t PrecisionBlind) const
Definition:
RooBlindTools.cxx:296
RooBlindTools::mode
const blindMode & mode() const
Definition:
RooBlindTools.h:112
RooBlindTools::UnHideDeltaZ
Double_t UnHideDeltaZ(Double_t DeltaZPrime, Double_t STag) const
Definition:
RooBlindTools.cxx:141
RooBlindTools::setup
void setup(const char *stSeed)
Definition:
RooBlindTools.cxx:72
ClassDef
#define ClassDef(name, id)
Definition:
Rtypes.h:254
RooBlindTools::PseudoRandom
Double_t PseudoRandom(Int_t Seed) const
Definition:
RooBlindTools.cxx:381
RooBlindTools::getPrecisionCentralValue
Double_t getPrecisionCentralValue() const
Definition:
RooBlindTools.h:116
RooBlindTools::getPrecisionOffsetScale
Double_t getPrecisionOffsetScale() const
Definition:
RooBlindTools.h:118
RooBlindTools::_DeltaZSignFlip
Double_t _DeltaZSignFlip
Definition:
RooBlindTools.h:127
RooBlindTools::MakeSignFlip
Double_t MakeSignFlip(const char *StringAlphabet) const
Definition:
RooBlindTools.cxx:437
TString.h
RooBlindTools::UnHidePrecision
Double_t UnHidePrecision(Double_t PrecisionPrime) const
Definition:
RooBlindTools.cxx:237
RooBlindTools::UnHiDelZPdG
Double_t UnHiDelZPdG(Double_t DeltaZPrime, Double_t STag, Double_t PdG) const
Definition:
RooBlindTools.cxx:151
RooBlindTools::HiDelZPdG
Double_t HiDelZPdG(Double_t DeltaZ, Double_t STag, Double_t PdG) const
Definition:
RooBlindTools.cxx:131
RooBlindTools::_PrecisionSignFlip
Double_t _PrecisionSignFlip
Definition:
RooBlindTools.h:135
RooBlindTools::UnHiAsPdG
Double_t UnHiAsPdG(Double_t AsymPrime, Double_t PdG) const
Definition:
RooBlindTools.cxx:206
RooBlindTools::_mode
blindMode _mode
Definition:
RooBlindTools.h:140
RooBlindTools::_DeltaZOffset
Double_t _DeltaZOffset
Definition:
RooBlindTools.h:126
RooBlindTools::_PrecisionCentralValue
Double_t _PrecisionCentralValue
Definition:
RooBlindTools.h:139
RooBlindTools
Definition:
RooBlindTools.h:26
RooBlindTools::_AsymSignFlip
Double_t _AsymSignFlip
Definition:
RooBlindTools.h:130
RooBlindTools::Randomizer
Double_t Randomizer(const char *StringAlphabet) const
Definition:
RooBlindTools.cxx:336
RooBlindTools::HideDeltaM
Double_t HideDeltaM(Double_t DeltaM) const
Definition:
RooBlindTools.cxx:195
RooBlindTools::RooBlindTools
RooBlindTools()
Definition:
RooBlindTools.h:43
RooBlindTools::_DeltaMScale
Double_t _DeltaMScale
Definition:
RooBlindTools.h:131
RooBlindTools::_AsymOffset
Double_t _AsymOffset
Definition:
RooBlindTools.h:129
RooFit::Precision
RooCmdArg Precision(Double_t prec)
Definition:
RooGlobalFunc.cxx:48
RooBlindTools::_PrecisionOffsetScale
Double_t _PrecisionOffsetScale
Definition:
RooBlindTools.h:136
Double_t
double Double_t
Definition:
RtypesCore.h:55
RooBlindTools::~RooBlindTools
virtual ~RooBlindTools()
Definition:
RooBlindTools.cxx:112
RooBlindTools::HidePrecision
Double_t HidePrecision(Double_t Precision) const
Definition:
RooBlindTools.cxx:257
RooBlindTools::_PrecisionUniform
Double_t _PrecisionUniform
Definition:
RooBlindTools.h:138
RooBlindTools::UnHideDeltaM
Double_t UnHideDeltaM(Double_t DeltaMPrime) const
Definition:
RooBlindTools.cxx:184
RooBlindTools::_MysteryPhase
Double_t _MysteryPhase
Definition:
RooBlindTools.h:133
RooBlindTools::_DeltaMOffset
Double_t _DeltaMOffset
Definition:
RooBlindTools.h:132
RooBlindTools::full
Definition:
RooBlindTools.h:35
RooBlindTools::HiAsPdG
Double_t HiAsPdG(Double_t Asym, Double_t PdG) const
Definition:
RooBlindTools.cxx:226
RooBlindTools::_PrecisionOffset
Double_t _PrecisionOffset
Definition:
RooBlindTools.h:137
RooBlindTools::UnHideAsym
Double_t UnHideAsym(Double_t AsymPrime) const
Definition:
RooBlindTools.cxx:161
RooBlindTools::HideOffset
Double_t HideOffset(Double_t Precision) const
Definition:
RooBlindTools.cxx:286
RooBlindTools::blindMode
blindMode
Definition:
RooBlindTools.h:34
RooBlindTools::_s2bMode
Bool_t _s2bMode
Definition:
RooBlindTools.h:141