Logo ROOT   6.30.04
Reference Guide
 All Namespaces Files Pages
TGraphAsymmErrors.h
Go to the documentation of this file.
1 // @(#)root/hist:$Id$
2 // Author: Rene Brun 03/03/99
3 
4 /*************************************************************************
5  * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6  * All rights reserved. *
7  * *
8  * For the licensing terms see $ROOTSYS/LICENSE. *
9  * For the list of contributors see $ROOTSYS/README/CREDITS. *
10  *************************************************************************/
11 
12 #ifndef ROOT_TGraphAsymmErrors
13 #define ROOT_TGraphAsymmErrors
14 
15 
16 //////////////////////////////////////////////////////////////////////////
17 // //
18 // TGraphAsymmErrors //
19 // //
20 // a Graph with asymmetric error bars //
21 // //
22 //////////////////////////////////////////////////////////////////////////
23 
24 #include "TGraph.h"
25 
26 class TGraphAsymmErrors : public TGraph {
27 
28 protected:
29  Double_t *fEXlow; ///<[fNpoints] array of X low errors
30  Double_t *fEXhigh; ///<[fNpoints] array of X high errors
31  Double_t *fEYlow; ///<[fNpoints] array of Y low errors
32  Double_t *fEYhigh; ///<[fNpoints] array of Y high errors
33 
34  virtual void SwapPoints(Int_t pos1, Int_t pos2);
35 
36  virtual Double_t** Allocate(Int_t size);
37  virtual void CopyAndRelease(Double_t **newarrays,
38  Int_t ibegin, Int_t iend, Int_t obegin);
39  virtual Bool_t CopyPoints(Double_t **arrays, Int_t ibegin, Int_t iend,
40  Int_t obegin);
41  Bool_t CtorAllocate();
42  virtual void FillZero(Int_t begin, Int_t end,
43  Bool_t from_ctor = kTRUE);
44  virtual Bool_t DoMerge(const TGraph * g);
45 
46 public:
47  TGraphAsymmErrors();
48  TGraphAsymmErrors(Int_t n);
49  TGraphAsymmErrors(Int_t n, const Float_t *x, const Float_t *y, const Float_t *exl=0, const Float_t *exh=0, const Float_t *eyl=0, const Float_t *eyh=0);
50  TGraphAsymmErrors(Int_t n, const Double_t *x, const Double_t *y, const Double_t *exl=0, const Double_t *exh=0, const Double_t *eyl=0, const Double_t *eyh=0);
51  TGraphAsymmErrors(const TVectorF &vx, const TVectorF &vy, const TVectorF &vexl, const TVectorF &vexh, const TVectorF &veyl, const TVectorF &veyh);
52  TGraphAsymmErrors(const TVectorD &vx, const TVectorD &vy, const TVectorD &vexl, const TVectorD &vexh, const TVectorD &veyl, const TVectorD &veyh);
53  TGraphAsymmErrors(const TGraphAsymmErrors &gr);
54  TGraphAsymmErrors& operator=(const TGraphAsymmErrors &gr);
55  TGraphAsymmErrors(const TH1 *h);
56  TGraphAsymmErrors(const TH1* pass, const TH1* total, Option_t *option="");
57  TGraphAsymmErrors(const char *filename, const char *format="%lg %lg %lg %lg %lg %lg", Option_t *option="");
58 
59  virtual ~TGraphAsymmErrors();
60 
61  virtual void Apply(TF1 *f);
62  virtual void BayesDivide(const TH1* pass, const TH1* total, Option_t *opt="");
63  virtual void Divide(const TH1* pass, const TH1* total, Option_t *opt="cp");
64  virtual void ComputeRange(Double_t &xmin, Double_t &ymin, Double_t &xmax, Double_t &ymax) const;
65  Double_t GetErrorX(Int_t bin) const;
66  Double_t GetErrorY(Int_t bin) const;
67  Double_t GetErrorXlow(Int_t i) const;
68  Double_t GetErrorXhigh(Int_t i) const;
69  Double_t GetErrorYlow(Int_t i) const;
70  Double_t GetErrorYhigh(Int_t i) const;
71  Double_t *GetEXlow() const {return fEXlow;}
72  Double_t *GetEXhigh() const {return fEXhigh;}
73  Double_t *GetEYlow() const {return fEYlow;}
74  Double_t *GetEYhigh() const {return fEYhigh;}
75  virtual Int_t Merge(TCollection* list);
76  virtual void Print(Option_t *chopt="") const;
77  virtual void SavePrimitive(std::ostream &out, Option_t *option = "");
78  virtual void SetPointError(Double_t exl, Double_t exh, Double_t eyl, Double_t eyh); // *MENU*
79  virtual void SetPointError(Int_t i, Double_t exl, Double_t exh, Double_t eyl, Double_t eyh);
80  virtual void SetPointEXlow(Int_t i, Double_t exl);
81  virtual void SetPointEXhigh(Int_t i, Double_t exh);
82  virtual void SetPointEYlow(Int_t i, Double_t eyl);
83  virtual void SetPointEYhigh(Int_t i, Double_t eyh);
84 
85  ClassDef(TGraphAsymmErrors,3) //A graph with asymmetric error bars
86 };
87 
88 #endif