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

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Class  : TActivationTanh                                                       *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description:                                                                   *
 *      Tanh activation function (sigmoid normalized in [-1,1] for an ANN.        *
 *                                                                                *
 * 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)                                          *
 **********************************************************************************/
  
//_______________________________________________________________________
//                                                                      
//  Tanh activation function for ANN. This really simple implementation
//  uses TFormulas and should probably be replaced with something more
//  efficient later.
//                                                                      
//_______________________________________________________________________

#include <iostream>

#include "TFormula.h"
#include "TString.h"
#include "TMath.h"

#ifndef ROOT_TMVA_TActivationTanh
#include "TMVA/TActivationTanh.h"
#endif

static const Int_t  UNINITIALIZED = -1;

ClassImp(TMVA::TActivationTanh)

//______________________________________________________________________________
TMVA::TActivationTanh::TActivationTanh()
{
   // constructor for tanh sigmoid (normalized in [-1,1])

   fEqn = new TFormula("sigmoid", "TMath::TanH(x)");
   fEqnDerivative = 
      new TFormula("derivative", "1-(TMath::TanH(x))^2");
}

//______________________________________________________________________________
TMVA::TActivationTanh::~TActivationTanh()
{
   // destructor

   if (fEqn != NULL) delete fEqn;
   if (fEqnDerivative != NULL) delete fEqnDerivative;
}

//______________________________________________________________________________
Double_t TMVA::TActivationTanh::Eval(Double_t arg)
{
   // evaluate the tanh

   if (fEqn == NULL) return UNINITIALIZED;
   return fEqn->Eval(arg);
}

//______________________________________________________________________________
Double_t TMVA::TActivationTanh::EvalDerivative(Double_t arg)
{
   // evaluate the derivative

   if (fEqnDerivative == NULL) return UNINITIALIZED;
   return fEqnDerivative->Eval(arg);
}

//______________________________________________________________________________
TString TMVA::TActivationTanh::GetExpression()
{
   // get expressions for the tanh and its derivative

   TString expr = "";

   if (fEqn == NULL) expr += "<null>";
   else              expr += fEqn->GetExpFormula();

   expr += "\t\t";

   if (fEqnDerivative == NULL) expr += "<null>";
   else                        expr += fEqnDerivative->GetExpFormula();

   return expr;
}

//______________________________________________________________________________
void TMVA::TActivationTanh::MakeFunction( std::ostream& fout, const TString& fncName ) 
{
   // writes the sigmoid activation function source code
   fout << "double " << fncName << "(double x) const {" << std::endl;
   fout << "   // hyperbolic tan" << std::endl;
   fout << "   return tanh(x);" << std::endl;
   fout << "}" << std::endl;
}
 TActivationTanh.cxx:1
 TActivationTanh.cxx:2
 TActivationTanh.cxx:3
 TActivationTanh.cxx:4
 TActivationTanh.cxx:5
 TActivationTanh.cxx:6
 TActivationTanh.cxx:7
 TActivationTanh.cxx:8
 TActivationTanh.cxx:9
 TActivationTanh.cxx:10
 TActivationTanh.cxx:11
 TActivationTanh.cxx:12
 TActivationTanh.cxx:13
 TActivationTanh.cxx:14
 TActivationTanh.cxx:15
 TActivationTanh.cxx:16
 TActivationTanh.cxx:17
 TActivationTanh.cxx:18
 TActivationTanh.cxx:19
 TActivationTanh.cxx:20
 TActivationTanh.cxx:21
 TActivationTanh.cxx:22
 TActivationTanh.cxx:23
 TActivationTanh.cxx:24
 TActivationTanh.cxx:25
 TActivationTanh.cxx:26
 TActivationTanh.cxx:27
 TActivationTanh.cxx:28
 TActivationTanh.cxx:29
 TActivationTanh.cxx:30
 TActivationTanh.cxx:31
 TActivationTanh.cxx:32
 TActivationTanh.cxx:33
 TActivationTanh.cxx:34
 TActivationTanh.cxx:35
 TActivationTanh.cxx:36
 TActivationTanh.cxx:37
 TActivationTanh.cxx:38
 TActivationTanh.cxx:39
 TActivationTanh.cxx:40
 TActivationTanh.cxx:41
 TActivationTanh.cxx:42
 TActivationTanh.cxx:43
 TActivationTanh.cxx:44
 TActivationTanh.cxx:45
 TActivationTanh.cxx:46
 TActivationTanh.cxx:47
 TActivationTanh.cxx:48
 TActivationTanh.cxx:49
 TActivationTanh.cxx:50
 TActivationTanh.cxx:51
 TActivationTanh.cxx:52
 TActivationTanh.cxx:53
 TActivationTanh.cxx:54
 TActivationTanh.cxx:55
 TActivationTanh.cxx:56
 TActivationTanh.cxx:57
 TActivationTanh.cxx:58
 TActivationTanh.cxx:59
 TActivationTanh.cxx:60
 TActivationTanh.cxx:61
 TActivationTanh.cxx:62
 TActivationTanh.cxx:63
 TActivationTanh.cxx:64
 TActivationTanh.cxx:65
 TActivationTanh.cxx:66
 TActivationTanh.cxx:67
 TActivationTanh.cxx:68
 TActivationTanh.cxx:69
 TActivationTanh.cxx:70
 TActivationTanh.cxx:71
 TActivationTanh.cxx:72
 TActivationTanh.cxx:73
 TActivationTanh.cxx:74
 TActivationTanh.cxx:75
 TActivationTanh.cxx:76
 TActivationTanh.cxx:77
 TActivationTanh.cxx:78
 TActivationTanh.cxx:79
 TActivationTanh.cxx:80
 TActivationTanh.cxx:81
 TActivationTanh.cxx:82
 TActivationTanh.cxx:83
 TActivationTanh.cxx:84
 TActivationTanh.cxx:85
 TActivationTanh.cxx:86
 TActivationTanh.cxx:87
 TActivationTanh.cxx:88
 TActivationTanh.cxx:89
 TActivationTanh.cxx:90
 TActivationTanh.cxx:91
 TActivationTanh.cxx:92
 TActivationTanh.cxx:93
 TActivationTanh.cxx:94
 TActivationTanh.cxx:95
 TActivationTanh.cxx:96
 TActivationTanh.cxx:97
 TActivationTanh.cxx:98
 TActivationTanh.cxx:99
 TActivationTanh.cxx:100
 TActivationTanh.cxx:101
 TActivationTanh.cxx:102
 TActivationTanh.cxx:103
 TActivationTanh.cxx:104
 TActivationTanh.cxx:105
 TActivationTanh.cxx:106
 TActivationTanh.cxx:107
 TActivationTanh.cxx:108
 TActivationTanh.cxx:109