ROOT logo
// @(#)root/roostats:$Id: NumEventsTestStat.h 31276 2009-11-18 15:06:42Z moneta $
// Author: Kyle Cranmer, Lorenzo Moneta, Gregory Schott, Wouter Verkerke
/*************************************************************************
 * 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_NumEventsTestStat
#define ROOSTATS_NumEventsTestStat

//_________________________________________________
/*
BEGIN_HTML
<p>
NumEventsTestStat is a simple implementation of the TestStatistic interface used for simple number counting.
It should probably support simple cuts as well.
</p>
END_HTML
*/
//

#ifndef ROOT_Rtypes
#include "Rtypes.h"
#endif

#include <vector>

//#include "RooStats/DistributionCreator.h"
#include "RooStats/SamplingDistribution.h"
#include "RooStats/TestStatistic.h"

#include "RooRealVar.h"

namespace RooStats {

  class NumEventsTestStat : public TestStatistic{

   public:
     NumEventsTestStat(RooAbsPdf& pdf) {
       fPdf = &pdf;
     }
     virtual ~NumEventsTestStat() {
       //       delete fRand;
       //       delete fTestStatistic;
     }
    
     // Main interface to evaluate the test statistic on a dataset
     virtual Double_t Evaluate(RooAbsData& data, RooArgSet& /*paramsOfInterest*/)  {       
       if(!&data){ cout << "problem with data" << endl;}
       
       RooMsgService::instance().setGlobalKillBelow(RooFit::FATAL) ;

       return data.numEntries();
     }

      // Get the TestStatistic
      virtual const RooAbsArg* GetTestStatistic()  const {return fPdf;}  

      virtual const TString GetVarName() const {return "Number of events";}
    
      
   private:
      RooAbsPdf* fPdf;

   protected:
      ClassDef(NumEventsTestStat,1)   
   };

}


#endif
 NumEventsTestStat.h:1
 NumEventsTestStat.h:2
 NumEventsTestStat.h:3
 NumEventsTestStat.h:4
 NumEventsTestStat.h:5
 NumEventsTestStat.h:6
 NumEventsTestStat.h:7
 NumEventsTestStat.h:8
 NumEventsTestStat.h:9
 NumEventsTestStat.h:10
 NumEventsTestStat.h:11
 NumEventsTestStat.h:12
 NumEventsTestStat.h:13
 NumEventsTestStat.h:14
 NumEventsTestStat.h:15
 NumEventsTestStat.h:16
 NumEventsTestStat.h:17
 NumEventsTestStat.h:18
 NumEventsTestStat.h:19
 NumEventsTestStat.h:20
 NumEventsTestStat.h:21
 NumEventsTestStat.h:22
 NumEventsTestStat.h:23
 NumEventsTestStat.h:24
 NumEventsTestStat.h:25
 NumEventsTestStat.h:26
 NumEventsTestStat.h:27
 NumEventsTestStat.h:28
 NumEventsTestStat.h:29
 NumEventsTestStat.h:30
 NumEventsTestStat.h:31
 NumEventsTestStat.h:32
 NumEventsTestStat.h:33
 NumEventsTestStat.h:34
 NumEventsTestStat.h:35
 NumEventsTestStat.h:36
 NumEventsTestStat.h:37
 NumEventsTestStat.h:38
 NumEventsTestStat.h:39
 NumEventsTestStat.h:40
 NumEventsTestStat.h:41
 NumEventsTestStat.h:42
 NumEventsTestStat.h:43
 NumEventsTestStat.h:44
 NumEventsTestStat.h:45
 NumEventsTestStat.h:46
 NumEventsTestStat.h:47
 NumEventsTestStat.h:48
 NumEventsTestStat.h:49
 NumEventsTestStat.h:50
 NumEventsTestStat.h:51
 NumEventsTestStat.h:52
 NumEventsTestStat.h:53
 NumEventsTestStat.h:54
 NumEventsTestStat.h:55
 NumEventsTestStat.h:56
 NumEventsTestStat.h:57
 NumEventsTestStat.h:58
 NumEventsTestStat.h:59
 NumEventsTestStat.h:60
 NumEventsTestStat.h:61
 NumEventsTestStat.h:62
 NumEventsTestStat.h:63
 NumEventsTestStat.h:64
 NumEventsTestStat.h:65
 NumEventsTestStat.h:66
 NumEventsTestStat.h:67
 NumEventsTestStat.h:68
 NumEventsTestStat.h:69
 NumEventsTestStat.h:70
 NumEventsTestStat.h:71
 NumEventsTestStat.h:72
 NumEventsTestStat.h:73
 NumEventsTestStat.h:74
 NumEventsTestStat.h:75