// SimpleInterval is a concrete implementation of the ConfInterval interface.
// It implements simple 1-dimensional intervals in a range [a,b].
// In addition, you can ask it for the upper- or lower-bound.
// END_HTML
#ifndef RooStats_SimpleInterval
#include "RooStats/SimpleInterval.h"
#endif
#include "RooAbsReal.h"
#include "RooRealVar.h"
#include <string>
using namespace std;
ClassImp(RooStats::SimpleInterval) ;
using namespace RooStats;
SimpleInterval::SimpleInterval(const char* name) :
ConfInterval(name), fLowerLimit(0), fUpperLimit(0), fConfidenceLevel(0)
{
}
SimpleInterval::SimpleInterval(const SimpleInterval& other, const char* name)
: ConfInterval(name)
, fParameters(other.fParameters)
, fLowerLimit(other.fLowerLimit)
, fUpperLimit(other.fUpperLimit)
, fConfidenceLevel(other.fConfidenceLevel)
{
}
SimpleInterval&
SimpleInterval::operator=(const SimpleInterval& other)
{
if (&other==this) {
return *this ;
}
ConfInterval::operator = (other);
fParameters.removeAll();
fParameters.add(other.fParameters);
fLowerLimit = other.fLowerLimit;
fUpperLimit = other.fUpperLimit;
fConfidenceLevel = other.fConfidenceLevel;
return *this ;
}
SimpleInterval::SimpleInterval(const char* name, const RooRealVar & var, Double_t lower, Double_t upper, Double_t cl) :
ConfInterval(name), fParameters(var), fLowerLimit(lower), fUpperLimit(upper), fConfidenceLevel(cl)
{
}
SimpleInterval::~SimpleInterval()
{
}
Bool_t SimpleInterval::IsInInterval(const RooArgSet ¶meterPoint) const
{
if( !this->CheckParameters(parameterPoint) )
return false;
if(parameterPoint.getSize() != 1 )
return false;
RooAbsReal* point = dynamic_cast<RooAbsReal*> (parameterPoint.first());
if (point == 0)
return false;
if ( point->getVal() > fUpperLimit || point->getVal() < fLowerLimit)
return false;
return true;
}
RooArgSet* SimpleInterval::GetParameters() const
{
return new RooArgSet(fParameters);
}
Bool_t SimpleInterval::CheckParameters(const RooArgSet ¶meterPoint) const
{
if (parameterPoint.getSize() != fParameters.getSize() ) {
std::cout << "size is wrong, parameters don't match" << std::endl;
return false;
}
if ( ! parameterPoint.equals( fParameters ) ) {
std::cout << "size is ok, but parameters don't match" << std::endl;
return false;
}
return true;
}