// @(#)root/tmva $Id: TActivationTanh.h 20882 2007-11-19 11:31:26Z rdm $ // Author: Matt Jachowski /********************************************************************************** * Project: TMVA - a Root-integrated toolkit for multivariate data analysis * * Package: TMVA * * Class : TMVA::TActivationTanh * * Web : http://tmva.sourceforge.net * * * * Description: * * Tanh activation function for TNeuron * * * * Authors (alphabetical): * * Matt Jachowski - 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_TActivationTanh #define ROOT_TMVA_TActivationTanh ////////////////////////////////////////////////////////////////////////// // // // TActivationTanh // // // // Tanh activation function for TNeuron // // // ////////////////////////////////////////////////////////////////////////// #include "TFormula.h" #include "TString.h" #ifndef ROOT_TMVA_TActivation #include "TMVA/TActivation.h" #endif namespace TMVA { class TActivationTanh : public TActivation { public: TActivationTanh(); ~TActivationTanh(); // 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 -1; } // 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 tanh sigmoid TFormula* fEqnDerivative; // equation of tanh sigmoid derivative ClassDef(TActivationTanh,0) // Tanh sigmoid activation function for TNeuron }; } // namespace TMVA #endif