// @(#)root/tmva $Id$ // Author: Andreas Hoecker, Joerg Stelzer, Helge Voss, Kai Voss /********************************************************************************** * Project: TMVA - a Root-integrated toolkit for multivariate data analysis * * Package: TMVA * * Class : TSpline2 * * Web : http://tmva.sourceforge.net * * * * Description: * * Quadratic spline class; uses quadrax function for interpolation * * * * Authors (alphabetical): * * Andreas Hoecker - CERN, Switzerland * * Helge Voss - MPI-K Heidelberg, Germany * * Kai Voss - U. of Victoria, Canada * * * * Copyright (c) 2005: * * CERN, Switzerland * * U. of Victoria, Canada * * MPI-K Heidelberg, Germany * * * * Redistribution and use in source and binary forms, with or without * * modification, are permitted according to the terms listed in LICENSE * * (http://tmva.sourceforge.net/LICENSE) * **********************************************************************************/ #ifndef ROOT_TMVA_TSpline2 #define ROOT_TMVA_TSpline2 ////////////////////////////////////////////////////////////////////////// // // // TSpline2 // // // // Quadratic interpolation class (using quadrax) // // // ////////////////////////////////////////////////////////////////////////// #include "TSpline.h" namespace TMVA { class TSpline2 : public TSpline { public: TSpline2( const TString& title, TGraph* theGraph ); virtual ~TSpline2( void ); virtual Double_t Eval( Double_t x ) const; // dummy implementations virtual void BuildCoeff( void ); virtual void GetKnot( Int_t i, Double_t& x, Double_t& y ) const; private: TGraph *fGraph; // graph that is splined Double_t Quadrax( Float_t dm, Float_t dm1, Float_t dm2, Float_t dm3, Float_t cos1, Float_t cos2, Float_t cos3 ) const; ClassDef(TSpline2,0); //Quadratic interpolation class (using quadrax) }; } // namespace TMVA #endif