ROOT logo
/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitCore                                                       *
 * @(#)root/roofitcore:$Id: RooUniformBinning.cxx 28259 2009-04-16 16:21:16Z wouter $
 * Authors:                                                                  *
 *   WV, Wouter Verkerke, UC Santa Barbara, verkerke@slac.stanford.edu       *
 *   DK, David Kirkby,    UC Irvine,         dkirkby@uci.edu                 *
 *                                                                           *
 * Copyright (c) 2000-2005, Regents of the University of California          *
 *                          and Stanford University. All rights reserved.    *
 *                                                                           *
 * Redistribution and use in source and binary forms,                        *
 * with or without modification, are permitted according to the terms        *
 * listed in LICENSE (http://roofit.sourceforge.net/license.txt)             *
 *****************************************************************************/

//////////////////////////////////////////////////////////////////////////////
//
// BEGIN_HTML
// RooUniformBinning is an implementation of RooAbsBinning that provides
// a uniform binning in 'n' bins between the range end points. A RooUniformBinning
// is 'elastic': if the range changes the binning will change accordingly, unlike
// e.g. the binning of class RooBinning.
// END_HTML
//

#include "RooFit.h"

#include "RooUniformBinning.h"
#include "RooUniformBinning.h"
#include "RooMsgService.h"

#include "Riostream.h"


ClassImp(RooUniformBinning)
;



//_____________________________________________________________________________
RooUniformBinning::RooUniformBinning(const char* name) : 
  RooAbsBinning(name)
{  
  // Default Constructor
  _array = 0 ;
}


//_____________________________________________________________________________
RooUniformBinning::RooUniformBinning(Double_t xlo, Double_t xhi, Int_t nBins, const char* name) :
  RooAbsBinning(name),
  _array(0), 
  _nbins(nBins)
{
  // Construct range [xlo,xhi] with 'nBins' bins
  setRange(xlo,xhi) ;
}



//_____________________________________________________________________________
RooUniformBinning::~RooUniformBinning() 
{
  // Destructor
  if (_array) delete[] _array ;
}



//_____________________________________________________________________________
RooUniformBinning::RooUniformBinning(const RooUniformBinning& other, const char* name) :
  RooAbsBinning(name)
{
  // Copy constructor
  _array = 0 ;
  _xlo   = other._xlo ;
  _xhi   = other._xhi ;
  _nbins = other._nbins ;
  _binw  = other._binw ;  
}



//_____________________________________________________________________________
void RooUniformBinning::setRange(Double_t xlo, Double_t xhi) 
{
  // Change range to [xlo,xhi]. A changes in range automatically
  // adjusts the binning as well to nBins bins in the new range

  if (xlo>xhi) {
    coutE(InputArguments) << "RooUniformBinning::setRange: ERROR low bound > high bound" << endl ;
    return ;
  }
  
  _xlo = xlo ;
  _xhi = xhi ;
  _binw = (xhi-xlo)/_nbins ;

  // Delete any out-of-date boundary arrays at this point
  if (_array) {
    delete[] _array ;
    _array = 0 ;
  }
}



//_____________________________________________________________________________
Int_t RooUniformBinning::binNumber(Double_t x) const  
{
  // Return the index of the bin that encloses 'x'

  Int_t bin = Int_t((x - _xlo)/_binw) ;
  if (bin<0) return 0 ;
  if (bin>_nbins-1) return _nbins-1 ;
  return bin ;
}



//_____________________________________________________________________________
Double_t RooUniformBinning::binCenter(Int_t i) const 
{
  // Return the central value of the 'i'-th fit bin
  if (i<0 || i>=_nbins) {
    coutE(InputArguments) << "RooUniformBinning::binCenter ERROR: bin index " << i 
			  << " is out of range (0," << _nbins-1 << ")" << endl ;
    return 0 ;
  }

  return _xlo + (i + 0.5)*averageBinWidth() ;  
}




//_____________________________________________________________________________
Double_t RooUniformBinning::binWidth(Int_t /*bin*/) const 
{
  // Return the bin width (same for all bins)
  return _binw ;
}



//_____________________________________________________________________________
Double_t RooUniformBinning::binLow(Int_t i) const 
{
  // Return the low edge of the 'i'-th fit bin

  if (i<0 || i>=_nbins) {
    coutE(InputArguments) << "RooUniformBinning::binLow ERROR: bin index " << i 
			  << " is out of range (0," << _nbins-1 << ")" << endl ;
    return 0 ;
  }

  return _xlo + i*_binw ;
}



//_____________________________________________________________________________
Double_t RooUniformBinning::binHigh(Int_t i) const 
{
  // Return the high edge of the 'i'-th fit bin

  if (i<0 || i>=_nbins) {
    coutE(InputArguments) << "RooUniformBinning::fitBinHigh ERROR: bin index " << i 
			  << " is out of range (0," << _nbins-1 << ")" << endl ;
    return 0 ;
  }

  return _xlo + (i + 1)*_binw ;
}



//_____________________________________________________________________________
Double_t* RooUniformBinning::array() const 
{
  // Return an array of doubles with the bin boundaries
  if (_array) delete[] _array ;
  _array = new Double_t[_nbins+1] ;

  Int_t i ;
  for (i=0 ; i<=_nbins ; i++) {
    _array[i] = _xlo + i*_binw ;
  }
  return _array ;
}


 RooUniformBinning.cxx:1
 RooUniformBinning.cxx:2
 RooUniformBinning.cxx:3
 RooUniformBinning.cxx:4
 RooUniformBinning.cxx:5
 RooUniformBinning.cxx:6
 RooUniformBinning.cxx:7
 RooUniformBinning.cxx:8
 RooUniformBinning.cxx:9
 RooUniformBinning.cxx:10
 RooUniformBinning.cxx:11
 RooUniformBinning.cxx:12
 RooUniformBinning.cxx:13
 RooUniformBinning.cxx:14
 RooUniformBinning.cxx:15
 RooUniformBinning.cxx:16
 RooUniformBinning.cxx:17
 RooUniformBinning.cxx:18
 RooUniformBinning.cxx:19
 RooUniformBinning.cxx:20
 RooUniformBinning.cxx:21
 RooUniformBinning.cxx:22
 RooUniformBinning.cxx:23
 RooUniformBinning.cxx:24
 RooUniformBinning.cxx:25
 RooUniformBinning.cxx:26
 RooUniformBinning.cxx:27
 RooUniformBinning.cxx:28
 RooUniformBinning.cxx:29
 RooUniformBinning.cxx:30
 RooUniformBinning.cxx:31
 RooUniformBinning.cxx:32
 RooUniformBinning.cxx:33
 RooUniformBinning.cxx:34
 RooUniformBinning.cxx:35
 RooUniformBinning.cxx:36
 RooUniformBinning.cxx:37
 RooUniformBinning.cxx:38
 RooUniformBinning.cxx:39
 RooUniformBinning.cxx:40
 RooUniformBinning.cxx:41
 RooUniformBinning.cxx:42
 RooUniformBinning.cxx:43
 RooUniformBinning.cxx:44
 RooUniformBinning.cxx:45
 RooUniformBinning.cxx:46
 RooUniformBinning.cxx:47
 RooUniformBinning.cxx:48
 RooUniformBinning.cxx:49
 RooUniformBinning.cxx:50
 RooUniformBinning.cxx:51
 RooUniformBinning.cxx:52
 RooUniformBinning.cxx:53
 RooUniformBinning.cxx:54
 RooUniformBinning.cxx:55
 RooUniformBinning.cxx:56
 RooUniformBinning.cxx:57
 RooUniformBinning.cxx:58
 RooUniformBinning.cxx:59
 RooUniformBinning.cxx:60
 RooUniformBinning.cxx:61
 RooUniformBinning.cxx:62
 RooUniformBinning.cxx:63
 RooUniformBinning.cxx:64
 RooUniformBinning.cxx:65
 RooUniformBinning.cxx:66
 RooUniformBinning.cxx:67
 RooUniformBinning.cxx:68
 RooUniformBinning.cxx:69
 RooUniformBinning.cxx:70
 RooUniformBinning.cxx:71
 RooUniformBinning.cxx:72
 RooUniformBinning.cxx:73
 RooUniformBinning.cxx:74
 RooUniformBinning.cxx:75
 RooUniformBinning.cxx:76
 RooUniformBinning.cxx:77
 RooUniformBinning.cxx:78
 RooUniformBinning.cxx:79
 RooUniformBinning.cxx:80
 RooUniformBinning.cxx:81
 RooUniformBinning.cxx:82
 RooUniformBinning.cxx:83
 RooUniformBinning.cxx:84
 RooUniformBinning.cxx:85
 RooUniformBinning.cxx:86
 RooUniformBinning.cxx:87
 RooUniformBinning.cxx:88
 RooUniformBinning.cxx:89
 RooUniformBinning.cxx:90
 RooUniformBinning.cxx:91
 RooUniformBinning.cxx:92
 RooUniformBinning.cxx:93
 RooUniformBinning.cxx:94
 RooUniformBinning.cxx:95
 RooUniformBinning.cxx:96
 RooUniformBinning.cxx:97
 RooUniformBinning.cxx:98
 RooUniformBinning.cxx:99
 RooUniformBinning.cxx:100
 RooUniformBinning.cxx:101
 RooUniformBinning.cxx:102
 RooUniformBinning.cxx:103
 RooUniformBinning.cxx:104
 RooUniformBinning.cxx:105
 RooUniformBinning.cxx:106
 RooUniformBinning.cxx:107
 RooUniformBinning.cxx:108
 RooUniformBinning.cxx:109
 RooUniformBinning.cxx:110
 RooUniformBinning.cxx:111
 RooUniformBinning.cxx:112
 RooUniformBinning.cxx:113
 RooUniformBinning.cxx:114
 RooUniformBinning.cxx:115
 RooUniformBinning.cxx:116
 RooUniformBinning.cxx:117
 RooUniformBinning.cxx:118
 RooUniformBinning.cxx:119
 RooUniformBinning.cxx:120
 RooUniformBinning.cxx:121
 RooUniformBinning.cxx:122
 RooUniformBinning.cxx:123
 RooUniformBinning.cxx:124
 RooUniformBinning.cxx:125
 RooUniformBinning.cxx:126
 RooUniformBinning.cxx:127
 RooUniformBinning.cxx:128
 RooUniformBinning.cxx:129
 RooUniformBinning.cxx:130
 RooUniformBinning.cxx:131
 RooUniformBinning.cxx:132
 RooUniformBinning.cxx:133
 RooUniformBinning.cxx:134
 RooUniformBinning.cxx:135
 RooUniformBinning.cxx:136
 RooUniformBinning.cxx:137
 RooUniformBinning.cxx:138
 RooUniformBinning.cxx:139
 RooUniformBinning.cxx:140
 RooUniformBinning.cxx:141
 RooUniformBinning.cxx:142
 RooUniformBinning.cxx:143
 RooUniformBinning.cxx:144
 RooUniformBinning.cxx:145
 RooUniformBinning.cxx:146
 RooUniformBinning.cxx:147
 RooUniformBinning.cxx:148
 RooUniformBinning.cxx:149
 RooUniformBinning.cxx:150
 RooUniformBinning.cxx:151
 RooUniformBinning.cxx:152
 RooUniformBinning.cxx:153
 RooUniformBinning.cxx:154
 RooUniformBinning.cxx:155
 RooUniformBinning.cxx:156
 RooUniformBinning.cxx:157
 RooUniformBinning.cxx:158
 RooUniformBinning.cxx:159
 RooUniformBinning.cxx:160
 RooUniformBinning.cxx:161
 RooUniformBinning.cxx:162
 RooUniformBinning.cxx:163
 RooUniformBinning.cxx:164
 RooUniformBinning.cxx:165
 RooUniformBinning.cxx:166
 RooUniformBinning.cxx:167
 RooUniformBinning.cxx:168
 RooUniformBinning.cxx:169
 RooUniformBinning.cxx:170
 RooUniformBinning.cxx:171
 RooUniformBinning.cxx:172
 RooUniformBinning.cxx:173
 RooUniformBinning.cxx:174
 RooUniformBinning.cxx:175
 RooUniformBinning.cxx:176
 RooUniformBinning.cxx:177
 RooUniformBinning.cxx:178
 RooUniformBinning.cxx:179
 RooUniformBinning.cxx:180
 RooUniformBinning.cxx:181
 RooUniformBinning.cxx:182
 RooUniformBinning.cxx:183
 RooUniformBinning.cxx:184
 RooUniformBinning.cxx:185
 RooUniformBinning.cxx:186
 RooUniformBinning.cxx:187
 RooUniformBinning.cxx:188
 RooUniformBinning.cxx:189
 RooUniformBinning.cxx:190
 RooUniformBinning.cxx:191
 RooUniformBinning.cxx:192
 RooUniformBinning.cxx:193