// @(#)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 <Andreas.Hocker@cern.ch> - CERN, Switzerland              *
 *      Helge Voss      <Helge.Voss@cern.ch>     - MPI-K Heidelberg, Germany      *
 *      Kai Voss        <Kai.Voss@cern.ch>       - 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)                        //
//                                                                      //
//////////////////////////////////////////////////////////////////////////

#ifndef ROOT_TSpline
#include "TSpline.h"
#endif

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 


 TSpline2.h:1
 TSpline2.h:2
 TSpline2.h:3
 TSpline2.h:4
 TSpline2.h:5
 TSpline2.h:6
 TSpline2.h:7
 TSpline2.h:8
 TSpline2.h:9
 TSpline2.h:10
 TSpline2.h:11
 TSpline2.h:12
 TSpline2.h:13
 TSpline2.h:14
 TSpline2.h:15
 TSpline2.h:16
 TSpline2.h:17
 TSpline2.h:18
 TSpline2.h:19
 TSpline2.h:20
 TSpline2.h:21
 TSpline2.h:22
 TSpline2.h:23
 TSpline2.h:24
 TSpline2.h:25
 TSpline2.h:26
 TSpline2.h:27
 TSpline2.h:28
 TSpline2.h:29
 TSpline2.h:30
 TSpline2.h:31
 TSpline2.h:32
 TSpline2.h:33
 TSpline2.h:34
 TSpline2.h:35
 TSpline2.h:36
 TSpline2.h:37
 TSpline2.h:38
 TSpline2.h:39
 TSpline2.h:40
 TSpline2.h:41
 TSpline2.h:42
 TSpline2.h:43
 TSpline2.h:44
 TSpline2.h:45
 TSpline2.h:46
 TSpline2.h:47
 TSpline2.h:48
 TSpline2.h:49
 TSpline2.h:50
 TSpline2.h:51
 TSpline2.h:52
 TSpline2.h:53
 TSpline2.h:54
 TSpline2.h:55
 TSpline2.h:56
 TSpline2.h:57
 TSpline2.h:58
 TSpline2.h:59
 TSpline2.h:60
 TSpline2.h:61
 TSpline2.h:62
 TSpline2.h:63
 TSpline2.h:64
 TSpline2.h:65
 TSpline2.h:66
 TSpline2.h:67
 TSpline2.h:68
 TSpline2.h:69
 TSpline2.h:70
 TSpline2.h:71
 TSpline2.h:72
 TSpline2.h:73