ROOT logo
// @(#)root/roostats:$Id: HypoTestResult.h 36602 2010-11-11 16:52:13Z moneta $
// Author: Kyle Cranmer, Lorenzo Moneta, Gregory Schott, Wouter Verkerke, Sven Kreiss
/*************************************************************************
 * Copyright (C) 1995-2008, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/

#ifndef ROOSTATS_HypoTestResult
#define ROOSTATS_HypoTestResult

#ifndef ROOT_TNamed
#include "TNamed.h"
#endif

#ifndef ROOSTATS_RooStatsUtils
#include "RooStats/RooStatsUtils.h"
#endif

#ifndef ROOSTATS_SamplingDistribution
#include "RooStats/SamplingDistribution.h"
#endif

namespace RooStats {

   class HypoTestResult : public TNamed {

   public:
      
      // default constructor
      explicit HypoTestResult(const char* name = 0);

      // constructor from name, null and alternate p values 
      HypoTestResult(const char* name, Double_t nullp, Double_t altp);

      // destructor 
      virtual ~HypoTestResult();

      // add values from another HypoTestResult
      virtual void Append(const HypoTestResult *other);

      // Return p-value for null hypothesis
      virtual Double_t NullPValue() const { return fNullPValue; }

      // Return p-value for alternate hypothesis
      virtual Double_t AlternatePValue() const { return fAlternatePValue; }

      // Convert  NullPValue into a "confidence level"
      virtual Double_t CLb() const { return 1.-NullPValue(); }

      // Convert  AlternatePValue into a "confidence level"
      virtual Double_t CLsplusb() const { return AlternatePValue(); }

      // CLs is simply CLs+b/CLb (not a method, but a quantity)
      virtual Double_t CLs() const {
         double thisCLb = CLb();
         if (thisCLb == 0) {
            std::cout << "Error: Cannot compute CLs because CLb = 0. Returning CLs = -1\n";
            return -1;
         }
         double thisCLsb = CLsplusb();
         return thisCLsb / thisCLb;
      }

      // familiar name for the Null p-value in terms of 1-sided Gaussian significance
      virtual Double_t Significance() const {return RooStats::PValueToSignificance( NullPValue() ); }

      SamplingDistribution* GetNullDistribution(void) const { return fNullDistr; }
      SamplingDistribution* GetAltDistribution(void) const { return fAltDistr; }
      Double_t GetTestStatisticData(void) const { return fTestStatisticData; }
      Bool_t HasTestStatisticData(void) const;

      void SetAltDistribution(SamplingDistribution *alt);
      void SetNullDistribution(SamplingDistribution *null);
      void SetTestStatisticData(const Double_t tsd);

      void SetPValueIsRightTail(Bool_t pr);
      Bool_t GetPValueIsRightTail(void) const { return fPValueIsRightTail; }

      /// The error on the "confidence level" of the null hypothesis
      Double_t CLbError() const;

      /// The error on the "confidence level" of the alternative hypothesis
      Double_t CLsplusbError() const;

      /// The error on the ratio CLs+b/CLb
      Double_t CLsError() const;

      Double_t NullPValueError() const;


      void Print(const Option_t* = "") const {
         // Print out some information about the results

         cout << endl << "Results " << GetName() << ": " << endl;
         if(HasTestStatisticData()  &&  fNullDistr) {
            cout << " - Null p-value = " << NullPValue() << " +/- " << NullPValueError() << endl;
            cout << " - Significance = " << Significance() << " sigma" << endl;
         }
         if(fAltDistr)
            cout << " - Number of S+B toys: " << fAltDistr->GetSize() << std::endl;
         if(fNullDistr)
            cout << " - Number of B toys: " << fNullDistr->GetSize() << std::endl;
         if(HasTestStatisticData())
            cout << " - Test statistic evaluated on data: " << fTestStatisticData << std::endl;
         if(HasTestStatisticData()  &&  fNullDistr)
            cout << " - CL_b: " << CLb() << " +/- " << CLbError() << std::endl;
         if(HasTestStatisticData()  &&  fAltDistr)
            cout << " - CL_s+b: " << CLsplusb() << " +/- " << CLsplusbError() << std::endl;
         if(HasTestStatisticData()  &&  fAltDistr  &&  fNullDistr)
            cout << " - CL_s: " << CLs() << " +/- " << CLsError()  << std::endl;

         return;
      }

   private:
      void UpdatePValue(const SamplingDistribution* distr, Double_t *pvalue, Bool_t pIsRightTail);


   protected:

      mutable Double_t fNullPValue; // p-value for the null hypothesis (small number means disfavored)
      mutable Double_t fAlternatePValue; // p-value for the alternate hypothesis (small number means disfavored)
      Double_t fTestStatisticData; // result of the test statistic evaluated on data
      SamplingDistribution *fNullDistr;
      SamplingDistribution *fAltDistr;
      Bool_t fPValueIsRightTail;

      ClassDef(HypoTestResult,1)  // Base class to represent results of a hypothesis test

   };
}


#endif
 HypoTestResult.h:1
 HypoTestResult.h:2
 HypoTestResult.h:3
 HypoTestResult.h:4
 HypoTestResult.h:5
 HypoTestResult.h:6
 HypoTestResult.h:7
 HypoTestResult.h:8
 HypoTestResult.h:9
 HypoTestResult.h:10
 HypoTestResult.h:11
 HypoTestResult.h:12
 HypoTestResult.h:13
 HypoTestResult.h:14
 HypoTestResult.h:15
 HypoTestResult.h:16
 HypoTestResult.h:17
 HypoTestResult.h:18
 HypoTestResult.h:19
 HypoTestResult.h:20
 HypoTestResult.h:21
 HypoTestResult.h:22
 HypoTestResult.h:23
 HypoTestResult.h:24
 HypoTestResult.h:25
 HypoTestResult.h:26
 HypoTestResult.h:27
 HypoTestResult.h:28
 HypoTestResult.h:29
 HypoTestResult.h:30
 HypoTestResult.h:31
 HypoTestResult.h:32
 HypoTestResult.h:33
 HypoTestResult.h:34
 HypoTestResult.h:35
 HypoTestResult.h:36
 HypoTestResult.h:37
 HypoTestResult.h:38
 HypoTestResult.h:39
 HypoTestResult.h:40
 HypoTestResult.h:41
 HypoTestResult.h:42
 HypoTestResult.h:43
 HypoTestResult.h:44
 HypoTestResult.h:45
 HypoTestResult.h:46
 HypoTestResult.h:47
 HypoTestResult.h:48
 HypoTestResult.h:49
 HypoTestResult.h:50
 HypoTestResult.h:51
 HypoTestResult.h:52
 HypoTestResult.h:53
 HypoTestResult.h:54
 HypoTestResult.h:55
 HypoTestResult.h:56
 HypoTestResult.h:57
 HypoTestResult.h:58
 HypoTestResult.h:59
 HypoTestResult.h:60
 HypoTestResult.h:61
 HypoTestResult.h:62
 HypoTestResult.h:63
 HypoTestResult.h:64
 HypoTestResult.h:65
 HypoTestResult.h:66
 HypoTestResult.h:67
 HypoTestResult.h:68
 HypoTestResult.h:69
 HypoTestResult.h:70
 HypoTestResult.h:71
 HypoTestResult.h:72
 HypoTestResult.h:73
 HypoTestResult.h:74
 HypoTestResult.h:75
 HypoTestResult.h:76
 HypoTestResult.h:77
 HypoTestResult.h:78
 HypoTestResult.h:79
 HypoTestResult.h:80
 HypoTestResult.h:81
 HypoTestResult.h:82
 HypoTestResult.h:83
 HypoTestResult.h:84
 HypoTestResult.h:85
 HypoTestResult.h:86
 HypoTestResult.h:87
 HypoTestResult.h:88
 HypoTestResult.h:89
 HypoTestResult.h:90
 HypoTestResult.h:91
 HypoTestResult.h:92
 HypoTestResult.h:93
 HypoTestResult.h:94
 HypoTestResult.h:95
 HypoTestResult.h:96
 HypoTestResult.h:97
 HypoTestResult.h:98
 HypoTestResult.h:99
 HypoTestResult.h:100
 HypoTestResult.h:101
 HypoTestResult.h:102
 HypoTestResult.h:103
 HypoTestResult.h:104
 HypoTestResult.h:105
 HypoTestResult.h:106
 HypoTestResult.h:107
 HypoTestResult.h:108
 HypoTestResult.h:109
 HypoTestResult.h:110
 HypoTestResult.h:111
 HypoTestResult.h:112
 HypoTestResult.h:113
 HypoTestResult.h:114
 HypoTestResult.h:115
 HypoTestResult.h:116
 HypoTestResult.h:117
 HypoTestResult.h:118
 HypoTestResult.h:119
 HypoTestResult.h:120
 HypoTestResult.h:121
 HypoTestResult.h:122
 HypoTestResult.h:123
 HypoTestResult.h:124
 HypoTestResult.h:125
 HypoTestResult.h:126
 HypoTestResult.h:127
 HypoTestResult.h:128
 HypoTestResult.h:129
 HypoTestResult.h:130
 HypoTestResult.h:131
 HypoTestResult.h:132
 HypoTestResult.h:133
 HypoTestResult.h:134
 HypoTestResult.h:135
 HypoTestResult.h:136
 HypoTestResult.h:137