A++ » INCLUDE » TSVDUnfold

class TSVDUnfold: public TObject


TSVDUnfold

Data unfolding using Singular Value Decomposition (hep-ph/9509307)
Authors: Kerstin Tackmann, Andreas Hoecker, Heiko Lacker


Function Members (Methods)

public:
virtual~TSVDUnfold()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
Double_tComputeChiSquared(const TH1D& truspec, const TH1D& unfspec)
virtual voidTObject::Copy(TObject& object) const
virtual voidTObject::Delete(Option_t* option = "")MENU
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() constMENU
virtual TObject*TObject::DrawClone(Option_t* option = "") constMENU
virtual voidTObject::Dump() constMENU
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
TH2D*GetAdetCovMatrix(Int_t ntoys, Int_t seed = 1)
TH2D*GetBCov() const
TH1D*GetD() const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
Int_tGetKReg() const
virtual const char*TObject::GetName() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
TH1D*GetSV() const
virtual const char*TObject::GetTitle() const
TH2D*GetUnfoldCovMatrix(const TH2D* cov, Int_t ntoys, Int_t seed = 1)
virtual UInt_tTObject::GetUniqueID() const
TH2D*GetXinv() const
TH2D*GetXtau() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual voidTObject::Inspect() constMENU
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Bool_tTObject::Notify()
voidTObject::Obsolete(const char* method, const char* asOfVers, const char* removedFromVers) const
voidTObject::operator delete(void* ptr)
voidTObject::operator delete(void* ptr, void* vp)
voidTObject::operator delete[](void* ptr)
voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
TSVDUnfold&operator=(const TSVDUnfold&)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTObject::Print(Option_t* option = "") const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(ostream& out, Option_t* option = "")
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
voidSetNormalize(Bool_t normalize)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector& insp) const
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
TSVDUnfold(const TSVDUnfold& other)
TSVDUnfold(const TH1D* bdat, const TH1D* bini, const TH1D* xini, const TH2D* Adet)
TSVDUnfold(const TH1D* bdat, TH2D* Bcov, const TH1D* bini, const TH1D* xini, const TH2D* Adet)
TH1D*Unfold(Int_t kreg)
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()
private:
static TVectorDCompProd(const TVectorD& vec1, const TVectorD& vec2)
voidFillCurvatureMatrix(TMatrixD& tCurv, TMatrixD& tC) const
static Double_tGetCurvature(const TVectorD& vec, const TMatrixD& curv)
static voidH2M(const TH2D* histo, TMatrixD& mat)
static voidH2V(const TH1D* histo, TVectorD& vec)
static voidH2Verr(const TH1D* histo, TVectorD& vec)
voidInitHistos()
static voidM2H(const TMatrixD& mat, TH2D& histo)
static TMatrixDMatDivVec(const TMatrixD& mat, const TVectorD& vec, Int_t zero = 0)
static voidRegularisedSymMatInvert(TMatrixDSym& mat, Double_t eps = 0.001)
static voidV2H(const TVectorD& vec, TH1D& histo)
static TVectorDVecDiv(const TVectorD& vec1, const TVectorD& vec2, Int_t zero = 0)

Data Members

public:
static TObject::(anonymous)TObject::kBitMask
static TObject::EStatusBitsTObject::kCanDelete
static TObject::EStatusBitsTObject::kCannotPick
static TObject::EStatusBitsTObject::kHasUUID
static TObject::EStatusBitsTObject::kInvalidObject
static TObject::(anonymous)TObject::kIsOnHeap
static TObject::EStatusBitsTObject::kIsReferenced
static TObject::EStatusBitsTObject::kMustCleanup
static TObject::EStatusBitsTObject::kNoContextMenu
static TObject::(anonymous)TObject::kNotDeleted
static TObject::EStatusBitsTObject::kObjInCanvas
static TObject::(anonymous)TObject::kOverwrite
static TObject::(anonymous)TObject::kSingleKey
static TObject::(anonymous)TObject::kWriteDelete
static TObject::(anonymous)TObject::kZombie
private:
const TH2D*fAdetDetector response matrix
TH2D*fBcovcovariance matrix of measured distribution (data)
const TH1D*fBdatmeasured distribution (data)
const TH1D*fBinireconstructed distribution (MC)
TH1D*fDHist! Distribution of d (for checking regularization)
Int_tfDdim! Derivative for curvature matrix
Int_tfKReg! Regularisation parameter
Bool_tfMatToyMode! Internal switch for evaluation of statistical uncertainties from response matrix
Int_tfNdim! Truth and reconstructed dimensions
Bool_tfNormalize! Normalize unfolded spectrum to 1
TH1D*fSVHist! Distribution of singular values
Bool_tfToyMode! Internal switch for covariance matrix propagation
TH1D*fToyhisto! Toy MC histogram
TH2D*fToymat! Toy MC detector response matrix
const TH1D*fXinitruth distribution (MC)
TH2D*fXinv! Computed inverse of covariance matrix
TH2D*fXtau! Computed regularized covariance matrix

Class Charts

Inheritance Chart:
TObject
TSVDUnfold

Function documentation

TSVDUnfold(const TH1D* bdat, const TH1D* bini, const TH1D* xini, const TH2D* Adet)
 Constructor
 Initialisation of unfolding
 "bdat" - measured data distribution (number of events)
 "Bcov" - covariance matrix for measured data distribution
 "bini" - reconstructed MC distribution (number of events)
 "xini" - truth MC distribution (number of events)
 "Adet" - detector response matrix (number of events)
TSVDUnfold(const TH1D* bdat, TH2D* Bcov, const TH1D* bini, const TH1D* xini, const TH2D* Adet)
TSVDUnfold(const TSVDUnfold& other)
virtual ~TSVDUnfold()
 Destructor
void SetNormalize(Bool_t normalize)
 Set option to normalize unfolded spectrum to unit area
 "normalize" - switch
{ fNormalize = normalize; }
TH1D* Unfold(Int_t kreg)
 Do the unfolding
 "kreg"   - number of singular values used (regularisation)
TH2D* GetUnfoldCovMatrix(const TH2D* cov, Int_t ntoys, Int_t seed = 1)
 Determine for given input error matrix covariance matrix of unfolded
 spectrum from toy simulation
 "cov"    - covariance matrix on the measured spectrum, to be propagated
 "ntoys"  - number of pseudo experiments used for the propagation
 "seed"   - seed for pseudo experiments
TH2D* GetAdetCovMatrix(Int_t ntoys, Int_t seed = 1)
 Determine covariance matrix of unfolded spectrum from finite statistics in
 response matrix
 "ntoys"  - number of pseudo experiments used for the propagation
 "seed"   - seed for pseudo experiments
Int_t GetKReg() const
 Regularisation parameter
{ return fKReg; }
TH1D* GetD() const
 Obtain the distribution of |d| (for determining the regularization)
TH1D* GetSV() const
 Obtain the distribution of singular values
TH2D* GetXtau() const
 Obtain the computed regularized covariance matrix
TH2D* GetXinv() const
 Obtain the computed inverse of the covariance matrix
TH2D* GetBCov() const
Obtain the covariance matrix on the data
Double_t ComputeChiSquared(const TH1D& truspec, const TH1D& unfspec)
 Helper functions
void FillCurvatureMatrix(TMatrixD& tCurv, TMatrixD& tC) const
 Helper functions for vector and matrix operations
Double_t GetCurvature(const TVectorD& vec, const TMatrixD& curv)
void InitHistos()
void H2V(const TH1D* histo, TVectorD& vec)
 Helper functions
void H2Verr(const TH1D* histo, TVectorD& vec)
void V2H(const TVectorD& vec, TH1D& histo)
void H2M(const TH2D* histo, TMatrixD& mat)
void M2H(const TMatrixD& mat, TH2D& histo)
TMatrixD MatDivVec(const TMatrixD& mat, const TVectorD& vec, Int_t zero = 0)
TVectorD CompProd(const TVectorD& vec1, const TVectorD& vec2)
TVectorD VecDiv(const TVectorD& vec1, const TVectorD& vec2, Int_t zero = 0)
void RegularisedSymMatInvert(TMatrixDSym& mat, Double_t eps = 0.001)