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

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Class  : TMVA::TActivationIdentity                                             *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description:                                                                   *
 *      Identity 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_TActivationIdentity
#define ROOT_TMVA_TActivationIdentity

//////////////////////////////////////////////////////////////////////////
//                                                                      //
// TActivationIdentity                                                  //
//                                                                      //
// Identity 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 TActivationIdentity : public TActivation {
      
   public:

      TActivationIdentity() {}
      ~TActivationIdentity() {}
     
      // evaluate the activation function
      virtual Double_t Eval(Double_t arg) { return arg; } // f(x) = x

      // evaluate the derivative of the activation function
      virtual Double_t EvalDerivative(Double_t) { 
         return 1; // f'(x) = 1
      } 

      // minimum of the range of the activation function
      virtual Double_t GetMin() { return 0; } // these should never be called

      // maximum of the range of the activation function
      virtual Double_t GetMax() { return 1; } // these should never be called

      // expression for activation function
      virtual TString GetExpression() { return "x\t1"; }

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

   private:

      ClassDef(TActivationIdentity,0) // Identity activation function for TNeuron
   };

} // namespace TMVA

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