27 using namespace RooStats;
31 if (fFitInfo !=
NULL) {
40 void FrequentistCalculator::PostHook()
const {
43 int FrequentistCalculator::PreNullHook(
RooArgSet *parameterPoint,
double obsTestStat)
const {
48 RooArgSet * allParams = fNullModel->GetPdf()->getParameters(*fData);
57 bool doProfile =
true;
59 if( fNullModel->GetNuisanceParameters() ) {
60 allButNuisance.
remove(*fNullModel->GetNuisanceParameters());
61 if( fConditionalMLEsNull ) {
63 *allParams = *fConditionalMLEsNull;
65 allButNuisance.
add( *fConditionalMLEsNull );
66 if (fNullModel->GetNuisanceParameters()) {
67 RooArgSet remain(*fNullModel->GetNuisanceParameters());
68 remain.
remove(*fConditionalMLEsNull,
true,
true);
69 if( remain.getSize() == 0 ) doProfile =
false;
81 if (fNullModel->GetConditionalObservables()) conditionalObs.
add(*fNullModel->GetConditionalObservables());
91 RooArgSet * detOutput = DetailedOutputAggregator::GetAsArgSet(result,
"fitNull_");
92 fFitInfo->addOwned(*detOutput);
103 if(fNullModel->GetNuisanceParameters())
104 parameterPoint->
add(*fNullModel->GetNuisanceParameters());
118 if(fNToysNull >= 0) toymcs->
SetNToys(fNToysNull);
126 if(GetTestStatSampler()->GetTestStatistic()->PValueIsRightTail()) {
135 GetNullModel()->LoadSnapshot();
142 int FrequentistCalculator::PreAltHook(
RooArgSet *parameterPoint,
double obsTestStat)
const {
147 RooArgSet * allParams = fAltModel->GetPdf()->getParameters(*fData);
150 bool doProfile =
true;
152 if( fAltModel->GetNuisanceParameters() ) {
153 allButNuisance.
remove(*fAltModel->GetNuisanceParameters());
154 if( fConditionalMLEsAlt ) {
156 *allParams = *fConditionalMLEsAlt;
158 allButNuisance.
add( *fConditionalMLEsAlt );
159 if (fAltModel->GetNuisanceParameters()) {
160 RooArgSet remain(*fAltModel->GetNuisanceParameters());
161 remain.
remove(*fConditionalMLEsAlt,
true,
true);
162 if( remain.getSize() == 0 ) doProfile =
false;
174 if (fAltModel->GetConditionalObservables()) conditionalObs.
add(*fAltModel->GetConditionalObservables());
185 RooArgSet * detOutput = DetailedOutputAggregator::GetAsArgSet(result,
"fitAlt_");
186 fFitInfo->addOwned(*detOutput);
197 if(fAltModel->GetNuisanceParameters())
198 parameterPoint->
add(*fAltModel->GetNuisanceParameters());
213 if(fNToysAlt >= 0) toymcs->
SetNToys(fNToysAlt);
221 if(GetTestStatSampler()->GetTestStatistic()->PValueIsRightTail()) {
RooCmdArg Offset(Bool_t flag=kTRUE)
Class RooProfileLL implements the profile likelihood estimator for a given likelihood and set of para...
void SetToysLeftTail(Double_t toys, Double_t threshold)
virtual void SetGlobalObservables(const RooArgSet &o)
RooCmdArg CloneData(Bool_t flag)
static RooMsgService & instance()
Return reference to singleton instance.
void SetToysRightTail(Double_t toys, Double_t threshold)
void SetToysBothTails(Double_t toys, Double_t low_threshold, Double_t high_threshold)
Double_t getVal(const RooArgSet *set=0) const
RooFit::MsgLevel globalKillBelow() const
virtual void SetNToys(const Int_t ntoy)
ClassImp(RooStats::FrequentistCalculator) using namespace RooStats
Does a frequentist hypothesis test.
void setGlobalKillBelow(RooFit::MsgLevel level)
ToyMCSampler is an implementation of the TestStatSampler interface.
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
Mother of all ROOT objects.
virtual Bool_t remove(const RooAbsArg &var, Bool_t silent=kFALSE, Bool_t matchByNameOnly=kFALSE)
Remove the specified argument from our list.
void RemoveConstantParameters(RooArgSet *set)
virtual RooAbsReal * createProfile(const RooArgSet ¶msOfInterest)
Create a RooProfileLL object that eliminates all nuisance parameters in the present function...
Hypothesis Test Calculator using a full frequentist procedure for sampling the test statistic distrib...
RooCmdArg ConditionalObservables(const RooArgSet &set)
virtual Bool_t add(const RooAbsArg &var, Bool_t silent=kFALSE)
Add element to non-owning set.
RooCmdArg Constrain(const RooArgSet ¶ms)