// @(#)root/tmva $Id$
// Author: Matt Jachowski

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Class  : TMVA::TActivationRadial                                               *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description:                                                                   *
 *      Radial basis activation function for TNeuron                              *
 *                                                                                *
 * Authors (alphabetical):                                                        *
 *      Matt Jachowski  <jachowski@stanford.edu> - Stanford University, USA       *
 *                                                                                *
 * Copyright (c) 2005:                                                            *
 *      CERN, Switzerland                                                         *
 *                                                                                *
 * 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_TActivationRadial
#define ROOT_TMVA_TActivationRadial

//////////////////////////////////////////////////////////////////////////
//                                                                      //
// TActivationRadial                                                    //
//                                                                      //
// Radial basis activation function for TNeuron                         //
//                                                                      //
//////////////////////////////////////////////////////////////////////////

#ifndef ROOT_TFormula
#include "TFormula.h"
#endif
#ifndef ROOT_TString
#include "TString.h"
#endif

#ifndef ROOT_TMVA_TActivation
#include "TMVA/TActivation.h"
#endif

namespace TMVA {
  
   class TActivationRadial : public TActivation {
    
   public:

      TActivationRadial();
      ~TActivationRadial();

      // evaluate the activation function
      Double_t Eval(Double_t arg);

      // evaluate the derivative of the activation function
      Double_t EvalDerivative(Double_t arg);

      // minimum of the range of the activation function
      Double_t GetMin() { return 0; }

      // maximum of the range of the activation function
      Double_t GetMax() { return 1; }

      // expression for the activation function
      TString GetExpression();

      // writer of function code
      virtual void MakeFunction(std::ostream& fout, const TString& fncName);

   private:

      TFormula* fEqn;                // equation of radial basis function
      TFormula* fEqnDerivative;      // equation of derivative

      ClassDef(TActivationRadial,0)  // Radial basis activation function for TNeuron
   };

} // namespace TMVA

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