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

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Class  : TMVA::TNeuronInputAbs                                                 *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description:                                                                   *
 *      TNeuron input calculator -- calculates the sum of the absolute values     *
 *      of the weighted inputs                                                    *
 *                                                                                *
 * 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_TNeuronInputAbs
#define ROOT_TMVA_TNeuronInputAbs

//////////////////////////////////////////////////////////////////////////
//                                                                      //
// TNeuronInputAbs                                                      //
//                                                                      //
// TNeuron input calculator -- calculates the sum of the absolute       //
// values of the weighted inputs                                        //
//                                                                      //
//////////////////////////////////////////////////////////////////////////

// ROOT_VERSION(5,15,02) = (5<<16)+(15<<8)+2 = 364802
// we use the hardcoded number here since CINT does not easily understand macros
// we tried using rootcints -p option, but that causes rootcint to pick up
// things from the ROOT version of TMVA

// #if ROOT_VERSION_CODE >= 364802
#ifndef ROOT_TMathBase
#include "TMathBase.h"
#endif
// #else
// #ifndef ROOT_TMath
// #include "TMath.h"
// #endif
// #endif

#ifndef ROOT_TObject
#include "TObject.h"
#endif
#ifndef ROOT_TString
#include "TString.h"
#endif

#ifndef ROOT_TMVA_TNeuronInput
#include "TMVA/TNeuronInput.h"
#endif

#ifndef ROOT_TMVA_TNeuron
#include "TMVA/TNeuron.h"
#endif

namespace TMVA {
  
   class TNeuronInputAbs : public TNeuronInput {
    
   public:

      TNeuronInputAbs() {}
      virtual ~TNeuronInputAbs() {}

      // calculate the input value for the neuron
      Double_t GetInput( const TNeuron* neuron ) const {
         if (neuron->IsInputNeuron()) return 0;
         Double_t result = 0;
         for (Int_t i=0; i < neuron->NumPreLinks(); i++)
            result += TMath::Abs(neuron->PreLinkAt(i)->GetWeightedValue());
         return result;
      }

      // name of the class
      TString GetName() { return "Sum of weighted activations (absolute value)"; }

      ClassDef(TNeuronInputAbs,0) // Calculates the sum of the absolute values of the weighted inputs
   };

} // namespace TMVA

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