TSpline2.h

Go to the documentation of this file.
00001 // @(#)root/tmva $Id: TSpline2.h 29122 2009-06-22 06:51:30Z brun $
00002 // Author: Andreas Hoecker, Joerg Stelzer, Helge Voss, Kai Voss 
00003 
00004 /**********************************************************************************
00005  * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
00006  * Package: TMVA                                                                  *
00007  * Class  : TSpline2                                                              *
00008  * Web    : http://tmva.sourceforge.net                                           *
00009  *                                                                                *
00010  * Description:                                                                   *
00011  *      Quadratic spline class; uses quadrax function for interpolation           *
00012  *                                                                                *
00013  * Authors (alphabetical):                                                        *
00014  *      Andreas Hoecker <Andreas.Hocker@cern.ch> - CERN, Switzerland              *
00015  *      Helge Voss      <Helge.Voss@cern.ch>     - MPI-K Heidelberg, Germany      *
00016  *      Kai Voss        <Kai.Voss@cern.ch>       - U. of Victoria, Canada         *
00017  *                                                                                *
00018  * Copyright (c) 2005:                                                            *
00019  *      CERN, Switzerland                                                         * 
00020  *      U. of Victoria, Canada                                                    * 
00021  *      MPI-K Heidelberg, Germany                                                 * 
00022  *                                                                                *
00023  * Redistribution and use in source and binary forms, with or without             *
00024  * modification, are permitted according to the terms listed in LICENSE           *
00025  * (http://tmva.sourceforge.net/LICENSE)                                          *
00026  **********************************************************************************/
00027 
00028 #ifndef ROOT_TMVA_TSpline2
00029 #define ROOT_TMVA_TSpline2
00030 
00031 //////////////////////////////////////////////////////////////////////////
00032 //                                                                      //
00033 // TSpline2                                                             //
00034 //                                                                      //
00035 // Quadratic interpolation class (using quadrax)                        //
00036 //                                                                      //
00037 //////////////////////////////////////////////////////////////////////////
00038 
00039 #ifndef ROOT_TSpline
00040 #include "TSpline.h"
00041 #endif
00042 
00043 namespace TMVA {
00044 
00045    class TSpline2 : public TSpline {
00046 
00047    public:
00048   
00049       TSpline2( const TString& title, TGraph* theGraph );
00050       virtual ~TSpline2( void );
00051 
00052       virtual  Double_t Eval( Double_t x ) const;
00053 
00054       // dummy implementations
00055       virtual void BuildCoeff( void );
00056       virtual void GetKnot( Int_t i, Double_t& x, Double_t& y ) const;
00057 
00058    private:
00059 
00060       TGraph *fGraph;   // graph that is splined
00061       Double_t Quadrax( Float_t dm, Float_t dm1,
00062                         Float_t dm2, Float_t dm3,
00063                         Float_t cos1, Float_t cos2, 
00064                         Float_t cos3 ) const;
00065   
00066       ClassDef(TSpline2,0) //Quadratic interpolation class (using quadrax)
00067    };
00068 
00069 } // namespace TMVA
00070 
00071 #endif 
00072 
00073 

Generated on Tue Jul 5 14:27:39 2011 for ROOT_528-00b_version by  doxygen 1.5.1