// @(#)root/tmva $Id: TMVA_MethodANNBase.cxx,v 1.3 2006/05/10 07:36:12 brun Exp $
// Author: Andreas Hoecker, Helge Voss, Kai Voss
/**********************************************************************************
* Project: TMVA - a Root-integrated toolkit for multivariate data analysis *
* Package: TMVA *
* Class : TMVA_MethodANNBase *
* *
* Description: *
* Implementation (see header for description) *
* *
* Authors (alphabetical): *
* Andreas Hoecker <Andreas.Hocker@cern.ch> - CERN, Switzerland *
* Xavier Prudent <prudent@lapp.in2p3.fr> - LAPP, France *
* Helge Voss <Helge.Voss@cern.ch> - MPI-KP Heidelberg, Germany *
* Kai Voss <Kai.Voss@cern.ch> - U. of Victoria, Canada *
* *
* Copyright (c) 2005: *
* CERN, Switzerland, *
* U. of Victoria, Canada, *
* MPI-KP Heidelberg, Germany, *
* LAPP, Annecy, France *
* *
* Redistribution and use in source and binary forms, with or without *
* modification, are permitted according to the terms listed in LICENSE *
* (http://mva.sourceforge.net/license.txt) *
* *
**********************************************************************************/
//_______________________________________________________________________
//
// Base class for all MVA methods using artificial neural networks
//
//_______________________________________________________________________
#include "TMVA_MethodANNBase.h"
#include "TList.h"
#include "TMVA_Tools.h"
#include "TObjString.h"
#include "Riostream.h"
using std::vector;
ClassImp(TMVA_MethodANNBase)
//_______________________________________________________________________
TMVA_MethodANNBase::TMVA_MethodANNBase( void )
{}
//_______________________________________________________________________
vector<Int_t>* TMVA_MethodANNBase::ParseOptionString( TString theOptions, Int_t nvar,
vector<Int_t>* nodes )
{
// default settings (should be defined in theOption string)
TList* list = TMVA_Tools::ParseFormatLine( theOptions );
// format and syntax of option string: "3000:N:N+2:N-3:6"
//
// where:
// 3000 - number of training cycles (epochs)
// N - number of nodes in first hidden layer, where N is the number
// of discriminating variables used (note that the first ANN
// layer necessarily has N nodes, and hence is not given).
// N+2 - number of nodes in 2nd hidden layer (2 nodes more than
// number of variables)
// N-3 - number of nodes in 3rd hidden layer (3 nodes less than
// number of variables)
// 6 - 6 nodes in last (4th) hidden layer (note that the last ANN
// layer in MVA has 2 nodes, each one for signal and background
// classes)
// sanity check
if (list->GetSize() < 1) {
cout << "--- Fatal error in NN parser (1): unrecognized option string: " << theOptions
<< " ==> exit(1)" << endl;
exit(1);
}
// add number of cycles
nodes->push_back( atoi( ((TObjString*)list->At(0))->GetString() ) );
Int_t a;
if (list->GetSize() > 1) {
for (Int_t i=1; i<list->GetSize(); i++) {
TString s = ((TObjString*)list->At(i))->GetString();
s.ToUpper();
if (s(0) == 'N') {
if (s.Length() > 1) nodes->push_back( nvar + atoi(&s[1]) );
else nodes->push_back( nvar );
}
else if ((a = atoi( s )) > 0) nodes->push_back( atoi(s ) );
else {
cout << "--- Fatal error in NN parser (1): unrecognized option string: " << theOptions
<< " ==> exit(1)" << endl;
exit(1);
}
}
}
return nodes;
}
ROOT page - Class index - Class Hierarchy - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.