// @(#)root/tmva $Id$   
// Author: Andreas Hoecker, Joerg Stelzer, Helge Voss

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Class  : TSpline1                                                              *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description:                                                                   *
 *      Implementation (see header for description)                               *
 *                                                                                *
 * 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)                                          *
 **********************************************************************************/

//_______________________________________________________________________
//                                                                      
// Linear interpolation of TGraph
//_______________________________________________________________________

#include "TMath.h"

#include "TMVA/TSpline1.h"

ClassImp(TMVA::TSpline1)

//_______________________________________________________________________
TMVA::TSpline1::TSpline1( const TString& title, TGraph* theGraph )
   : fGraph( theGraph )
{
   // constructor from TGraph
   // TSpline is a TNamed object
   SetNameTitle( title, title );  
}

//_______________________________________________________________________
TMVA::TSpline1::~TSpline1( void )
{
   // destructor
   if (fGraph) delete fGraph; // ROOT's spline classes also own the TGraph
}

//_______________________________________________________________________
Double_t TMVA::TSpline1::Eval( Double_t x ) const
{  
   // returns linearly interpolated TGraph entry around x
   Int_t ibin = TMath::BinarySearch( fGraph->GetN(),
                                     fGraph->GetX(),
                                     x );
   Int_t nbin = fGraph->GetN();

   // sanity checks
   if (ibin < 0    ) ibin = 0;
   if (ibin >= nbin) ibin = nbin - 1;

   Int_t nextbin = ibin;
   if ((x > fGraph->GetX()[ibin] && ibin != nbin-1) || ibin == 0) 
      nextbin++;
   else
      nextbin--;  

   // linear interpolation
   Double_t dx = fGraph->GetX()[ibin] - fGraph->GetX()[nextbin];
   Double_t dy = fGraph->GetY()[ibin] - fGraph->GetY()[nextbin];
   return fGraph->GetY()[ibin] + (x - fGraph->GetX()[ibin]) * dy/dx;
}

//_______________________________________________________________________
void TMVA::TSpline1::BuildCoeff( void )
{
   // no coefficients to precompute
}

//_______________________________________________________________________
void TMVA::TSpline1::GetKnot( Int_t /* i*/, Double_t&  /*x*/, Double_t& /*y*/ ) const
{
   // no knots
}

 TSpline1.cxx:1
 TSpline1.cxx:2
 TSpline1.cxx:3
 TSpline1.cxx:4
 TSpline1.cxx:5
 TSpline1.cxx:6
 TSpline1.cxx:7
 TSpline1.cxx:8
 TSpline1.cxx:9
 TSpline1.cxx:10
 TSpline1.cxx:11
 TSpline1.cxx:12
 TSpline1.cxx:13
 TSpline1.cxx:14
 TSpline1.cxx:15
 TSpline1.cxx:16
 TSpline1.cxx:17
 TSpline1.cxx:18
 TSpline1.cxx:19
 TSpline1.cxx:20
 TSpline1.cxx:21
 TSpline1.cxx:22
 TSpline1.cxx:23
 TSpline1.cxx:24
 TSpline1.cxx:25
 TSpline1.cxx:26
 TSpline1.cxx:27
 TSpline1.cxx:28
 TSpline1.cxx:29
 TSpline1.cxx:30
 TSpline1.cxx:31
 TSpline1.cxx:32
 TSpline1.cxx:33
 TSpline1.cxx:34
 TSpline1.cxx:35
 TSpline1.cxx:36
 TSpline1.cxx:37
 TSpline1.cxx:38
 TSpline1.cxx:39
 TSpline1.cxx:40
 TSpline1.cxx:41
 TSpline1.cxx:42
 TSpline1.cxx:43
 TSpline1.cxx:44
 TSpline1.cxx:45
 TSpline1.cxx:46
 TSpline1.cxx:47
 TSpline1.cxx:48
 TSpline1.cxx:49
 TSpline1.cxx:50
 TSpline1.cxx:51
 TSpline1.cxx:52
 TSpline1.cxx:53
 TSpline1.cxx:54
 TSpline1.cxx:55
 TSpline1.cxx:56
 TSpline1.cxx:57
 TSpline1.cxx:58
 TSpline1.cxx:59
 TSpline1.cxx:60
 TSpline1.cxx:61
 TSpline1.cxx:62
 TSpline1.cxx:63
 TSpline1.cxx:64
 TSpline1.cxx:65
 TSpline1.cxx:66
 TSpline1.cxx:67
 TSpline1.cxx:68
 TSpline1.cxx:69
 TSpline1.cxx:70
 TSpline1.cxx:71
 TSpline1.cxx:72
 TSpline1.cxx:73
 TSpline1.cxx:74
 TSpline1.cxx:75
 TSpline1.cxx:76
 TSpline1.cxx:77
 TSpline1.cxx:78
 TSpline1.cxx:79
 TSpline1.cxx:80
 TSpline1.cxx:81
 TSpline1.cxx:82
 TSpline1.cxx:83
 TSpline1.cxx:84
 TSpline1.cxx:85
 TSpline1.cxx:86
 TSpline1.cxx:87
 TSpline1.cxx:88
 TSpline1.cxx:89
 TSpline1.cxx:90
 TSpline1.cxx:91