// // this stress test for TMVA is a shorter version of the extended TMVA testsuite // generated by script tmvaValidation/testsuite/RootTest/buildRootTest.sh // // Eckhard von Toerne, Dec 2010 // /* if working, it creates output like this: ****************************************************************** * TMVA - S T R E S S and U N I T test suite (FAST) ****************************************************************** Event [107/107]..................................................OK VariableInfo [31/31].............................................OK DataSetInfo [20/20]..............................................OK DataSet [15/15]..................................................OK Factory [11/11]..................................................OK Reader [2/2].....................................................OK CutsGA [3/3].....................................................OK LikelihoodD [4/4]................................................OK PDERS [4/4]......................................................OK PDEFoam [4/4]....................................................OK KNN [4/4]........................................................OK Fisher [4/4].....................................................OK BoostedFisher [4/4]..............................................OK LD [4/4].........................................................OK MLP [4/4]........................................................OK MLPBFGS [4/4]....................................................OK SVM [4/4]........................................................OK BDTG [4/4].......................................................OK BDT [4/4]........................................................OK Regression_LD [4/4]..............................................OK Regression_MLPBFGSN [4/4]........................................OK Regression_BDTG2 [4/4]...........................................OK Event [107/107]..................................................OK VariableInfo [31/31].............................................OK DataSetInfo [20/20]..............................................OK DataSet [15/15]..................................................OK Factory [11/11]..................................................OK Reader [2/2].....................................................OK CutsGA [3/3].....................................................OK LikelihoodD [4/4]................................................OK PDERS [4/4]......................................................OK PDEFoam [4/4]....................................................OK KNN [4/4]........................................................OK Fisher [4/4].....................................................OK BoostedFisher [4/4]..............................................OK LD [4/4].........................................................OK MLP [4/4]........................................................OK MLPBFGS [4/4]....................................................OK SVM [4/4]........................................................OK BDTG [4/4].......................................................OK BDT [4/4]........................................................OK Regression_LD [4/4]..............................................OK Regression_MLPBFGSN [4/4]........................................OK Regression_BDTG2 [4/4]...........................................OK ****************************************************************** * SYS: Linux linux-7p93 2.6.27.7-9-default #1 SMP 2008-12-04 18:10: * SYS: "openSUSE 11.1 (x86_64)" ****************************************************************** * CPUTIME = 90.2 * Root5.27/07 20100929/1318 ****************************************************************** */ // including file tmvaut/UnitTest.h #ifndef UNITTEST_H #define UNITTEST_H // Author: Christoph Rosemann Dec. 2009 // TMVA unit tests #include #include #include // The following have underscores because // they are macros. For consistency, // succeed_() also has an underscore. #define test_(cond) \ do_test(cond, #cond, __FILE__, __LINE__) #define fail_(str) \ do_fail(str, __FILE__, __LINE__) namespace UnitTesting { class UnitTest { public: UnitTest(const std::string & xname="", const std::string & filename="", std::ostream* osptr = &std::cout); virtual ~UnitTest(){} virtual void run() = 0; long getNumPassed() const; long getNumFailed() const; const std::ostream* getStream() const; void setStream(std::ostream* osptr); void succeed_(); long report() const; virtual void reset(); void intro() const; const std::string & name() const; protected: void do_test(bool cond, const std::string& lbl, const char* fname, long lineno); void do_fail(const std::string& lbl, const char* fname, long lineno); bool floatCompare(float x1, float x2); private: std::ostream* osptr; long nPass; long nFail; mutable std::string fName; std::string fFileName; // Disallowed: UnitTest(const UnitTest&); UnitTest& operator=(const UnitTest&); }; inline UnitTest::UnitTest(const std::string & xname, const std::string & filename, std::ostream* sptr) : fName(xname), fFileName(filename) { this->osptr = sptr; nPass = nFail = 0; } inline long UnitTest::getNumPassed() const { return nPass; } inline long UnitTest::getNumFailed() const { return nFail; } inline const std::ostream* UnitTest::getStream() const { return osptr; } inline void UnitTest::setStream(std::ostream* sptr) { this->osptr = sptr; } inline void UnitTest::succeed_() { ++nPass; } inline void UnitTest::reset() { nPass = nFail = 0; } } // namespace UnitTesting #endif // UNITTEST_H // including file tmvaut/UnitTest.cxx #include #include #include "TString.h" #include "TMath.h" #include using namespace std; using namespace UnitTesting; void UnitTest::do_test(bool cond, const std::string& lbl, const char* fname, long lineno) { if (!cond) do_fail(lbl, fname, lineno); else succeed_(); } void UnitTest::do_fail(const std::string& lbl, const char* /* fname */ , long lineno) { ++nFail; if (osptr) { *osptr << "failure: " << setw(76) << std::left << lbl << std::right << " [line " << setw(3) << lineno << "]\n"; } } bool UnitTest::floatCompare(float x1, float x2) { bool ret = (TMath::Abs(x1-x2)<1.e-9); // fix me, empirical number if (!ret) cout << "warning floatCompare: x1="< #include namespace UnitTesting { class UnitTestSuiteError : public std::logic_error { public: UnitTestSuiteError(const std::string& s = "") : logic_error(s) {} }; class UnitTestSuite { public: UnitTestSuite(const std::string& title, std::ostream* sptr = &std::cout); std::string getName() const; long getNumPassed() const; long getNumFailed() const; const std::ostream* getStream() const; void setStream(std::ostream* osptr); void addTest(UnitTest* t) throw (UnitTestSuiteError); void addSuite(const UnitTestSuite&); void run(); // Calls Test::run() repeatedly void intro() const; long report() const; void free(); // Deletes tests private: std::string name; std::ostream* osptr; std::vector tests; void reset(); // Disallowed ops: UnitTestSuite(const UnitTestSuite&); UnitTestSuite& operator=(const UnitTestSuite&); }; inline UnitTestSuite::UnitTestSuite(const std::string& title, std::ostream* sptr) : name(title) { this->osptr = sptr; } inline std::string UnitTestSuite::getName() const { return name; } inline const std::ostream* UnitTestSuite::getStream() const { return osptr; } inline void UnitTestSuite::setStream(std::ostream* sptr) { this->osptr = sptr; } } // namespace UnitTesting #endif // UNITTESTSUITE_H // including file tmvaut/UnitTestSuite.cxx #include #include #include using namespace std; using namespace UnitTesting; void UnitTestSuite::addTest(UnitTest* t) throw(UnitTestSuiteError) { // Verify test is valid and has a stream: if (t == 0) throw UnitTestSuiteError("Null test in UnitTestSuite::addTest"); else if (osptr && !t->getStream()) t->setStream(osptr); tests.push_back(t); t->reset(); } void UnitTestSuite::addSuite(const UnitTestSuite& s) { for (size_t i = 0; i < s.tests.size(); ++i) { assert(tests[i]); addTest(s.tests[i]); } } void UnitTestSuite::free() { for (size_t i = 0; i < tests.size(); ++i) { delete tests[i]; tests[i] = 0; } } void UnitTestSuite::run() { reset(); for (size_t i = 0; i < tests.size(); ++i) { assert(tests[i]); tests[i]->intro(); tests[i]->run(); #ifndef FULL tests[i]->report(); #endif } } void UnitTestSuite::intro() const { if (osptr) { *osptr << "******************************************************************" << endl; *osptr << "* TMVA - S T R E S S and U N I T test suite "; #ifdef FULL *osptr << "(FULL)"<< endl; #else *osptr << "(FAST)"<< endl; #endif //*osptr << " *" << endl; *osptr << "******************************************************************" << endl; } } long UnitTestSuite::report() const { if (osptr) { long totFail = 0; #ifdef FULL *osptr << "************************************************************************************************" << endl; *osptr << "* TMVA - U N I T test : Summary *" << endl; *osptr << "************************************************************************************************" << endl; #endif size_t i; for (i = 0; i < tests.size(); ++i) { assert(tests[i]); #ifdef FULL *osptr << "Test " << setw(2) << i << " : "; #endif totFail += tests[i]->report(); } return totFail; } else return getNumFailed(); } long UnitTestSuite::getNumPassed() const { long totPass = 0; for (size_t i = 0; i < tests.size(); ++i) { assert(tests[i]); totPass += tests[i]->getNumPassed(); } return totPass; } long UnitTestSuite::getNumFailed() const { long totFail = 0; for (size_t i = 0; i < tests.size(); ++i) { assert(tests[i]); totFail += tests[i]->getNumFailed(); } return totFail; } void UnitTestSuite::reset() { for (size_t i = 0; i < tests.size(); ++i) { assert(tests[i]); tests[i]->reset(); } } // including file tmvaut/utDataSetInfo.h #ifndef UTDATASETINFO_H #define UTDATASETINFO_H // Author: Christoph Rosemann Dec. 2009 // TMVA unit tests #include #include "TString.h" #include "TCut.h" #include "TMatrixDfwd.h" #include "TMVA/VariableInfo.h" namespace TMVA { class DataSetInfo; class ClassInfo; class Event; } class utDataSetInfo : public UnitTesting::UnitTest { public: utDataSetInfo(); void run(); private: void testConstructor(); void testMethods(); TMVA::DataSetInfo* datasetinfo; // the members needed for the creation and comparison of instances TString name; TString expression; TString title; TString unit; Double_t min; Double_t max; Int_t varcounter; char vartype; Bool_t normalized; void* external; TString norm; TString classname; TCut cut1; TCut cut2; TString splitoption; TMatrixD* matrix; TString histname; TString histtitle; TString weightexpr; TMVA::Event* event; // TMVA::ClassInfo* classinfo; TMVA::VariableInfo varinfo; std::vector vecvarinfo; }; #endif // UTDATASETINFO_H // including file tmvaut/utDataSetInfo.cxx #include "TMatrixD.h" #include "TMVA/DataSetInfo.h" #include "TMVA/ClassInfo.h" #include "TMVA/Event.h" using namespace std; using namespace UnitTesting; using namespace TMVA; utDataSetInfo::utDataSetInfo() : UnitTest("DataSetInfo", __FILE__) { name = "name"; expression = "expression"; title = "title"; unit = "unit"; min = 2.781828; max = 3.1416; vartype = 'D'; varcounter = 123; normalized = kFALSE; external = &max; norm = "norm"; classname = "classname"; cut1 = "x<1."; cut2 = "y>2."; splitoption = "splitoption"; matrix = new TMatrixD(); histname = "histname"; histtitle = "histtitle"; weightexpr = "weightexpr"; event = new Event(); varinfo = VariableInfo( expression, title, unit, varcounter, vartype, external, min, max, normalized); vecvarinfo.push_back(varinfo); vecvarinfo.push_back(varinfo); } void utDataSetInfo::run() { testConstructor(); testMethods(); } void utDataSetInfo::testConstructor() { datasetinfo = new DataSetInfo(name); datasetinfo->SetMsgType(TMVA::kWARNING); test_(datasetinfo->GetName() == name); } void utDataSetInfo::testMethods() { // FIXME:this doesn't work straightforward // test_(datasetinfo->GetDataSet() == 0); // note: the "constructor"-like call is different from the /standard/ VariableInfo constructor datasetinfo->AddVariable(expression, title, unit, min, max, vartype, normalized, external); datasetinfo->AddVariable(varinfo); // note: the method has a different argument list than the other two datasetinfo->AddTarget(expression, title, unit, min, max, normalized, external); datasetinfo->AddTarget(varinfo); datasetinfo->AddSpectator(expression, title, unit, min, max, vartype, normalized, external); datasetinfo->AddSpectator(varinfo); datasetinfo->AddClass(classname); test_((datasetinfo->GetVariableInfos()).size() == vecvarinfo.size()); test_((datasetinfo->GetTargetInfos()).size() == vecvarinfo.size()); test_((datasetinfo->GetSpectatorInfos()).size() == vecvarinfo.size()); test_(datasetinfo->GetNVariables() == vecvarinfo.size()); test_(datasetinfo->GetNTargets() == vecvarinfo.size()); test_(datasetinfo->GetNSpectators() == vecvarinfo.size()); datasetinfo->SetNormalization(norm); test_(datasetinfo->GetNormalization() == norm); // there is no comparison operator for VariableInfo, this will be broken if the implementation changes /* for(vector::const_iterator varinf = vecvarinfo.begin(); varinf < vecvarinfo.end(); ++varinf) { unsigned int index = vecvarinfo.begin() - varinf; test_(datasetinfo->GetVariableInfo(index) == varinfo); // doesn't work! } */ test_(datasetinfo->GetClassNameMaxLength() == classname.Length() ); test_(datasetinfo->GetNClasses() == 1); test_(datasetinfo->IsSignal(event) == kTRUE); /* // classification information ClassInfo* GetClassInfo( Int_t clNum ) const; ClassInfo* GetClassInfo( const TString& name ) const; */ test_(datasetinfo->HasCuts() == kFALSE); // why does this fail? datasetinfo->SetCut(cut1, classname); test_(datasetinfo->HasCuts() == kTRUE); test_(datasetinfo->GetCut(0) == cut1); // test_(datasetinfo->GetCut(1) == cut2); // there is no guard against using the wrong index test_(datasetinfo->GetCut(classname) == cut1); datasetinfo->AddCut(cut2, classname); cut1 += cut2; test_(TString(datasetinfo->GetCut(classname)) == TString(cut1)); datasetinfo->SetSplitOptions(splitoption); test_(datasetinfo->GetSplitOptions() == splitoption); test_(datasetinfo->GetWeightExpression(0) == ""); datasetinfo->SetWeightExpression(weightexpr); test_(datasetinfo->GetWeightExpression(0) == weightexpr); datasetinfo->SetCorrelationMatrix(classname,matrix); // datasetinfo->PrintCorrelationMatrix(classname);// this is insecure! test_(datasetinfo->FindVarIndex(expression) == 0); vector vars = datasetinfo->GetListOfVariables(); /* void ClearDataSet() const; Int_t FindVarIndex( const TString& ) const; std::vector GetListOfVariables() const; const TMatrixD* CorrelationMatrix ( const TString& className ) const; void SetCorrelationMatrix ( const TString& className, TMatrixD* matrix ); TH2* CreateCorrelationMatrixHist( const TMatrixD* m, const TString& hName, const TString& hTitle ) const; */ /* unclear to me, what to test: void SetRootDir(TDirectory* d) { fOwnRootDir = d; } TDirectory* GetRootDir() const { return fOwnRootDir; } */ } // including file tmvaut/utDataSet.h #ifndef UTDATASET_H #define UTDATASET_H // Author: Christoph Rosemann Dec. 2009 // TMVA unit tests #include namespace TMVA { class DataSet; class DataSetInfo; class Event; } class utDataSet : public UnitTesting::UnitTest { public: utDataSet(); void run(); private: void testMethods(); TMVA::DataSet* dataset; TMVA::DataSetInfo* datasetinfo; TMVA::Event* event0; TMVA::Event* event1; TMVA::Event* event2; TMVA::Event* event3; TMVA::Event* event4; // std::vector* vecevent; // TMVA::Results* result; }; #endif // UTDATASET_H // including file tmvaut/utDataSet.cxx #include "TMVA/VariableInfo.h" #include "TMVA/Types.h" #include "TMVA/Event.h" #include "TMVA/DataSet.h" #include "TMVA/DataSetInfo.h" #include "TString.h" using namespace std; using namespace TMVA; utDataSet::utDataSet() : UnitTest("DataSet", __FILE__) { // event; // vecevent; // results; TString xname = "name"; TString expression1 = "expression1"; TString expression2 = "expression2"; TString expression3 = "expression3"; TString title = "title"; TString unit = "unit"; char vartype = 'D'; Float_t min = 2.781828; Float_t max = 3.1416; Bool_t normalized = kFALSE; TString classname = "classname"; void* external = &max; UInt_t _testClassVal = 2; // the test values for initialisation vector _testValueVec, _testTargetVec, _testSpectatorVec; _testValueVec.push_back(1.); _testValueVec.push_back(2.); _testValueVec.push_back(3.); _testTargetVec.push_back(11.); _testTargetVec.push_back(12.); _testTargetVec.push_back(13.); _testSpectatorVec.push_back(25.); Float_t _testWeight = 3.1415; Float_t _testBoostWeight = 0.1234; event0 = new Event( _testValueVec, _testTargetVec, _testSpectatorVec, _testClassVal, _testWeight, _testBoostWeight); event1 = new Event( _testValueVec, _testTargetVec, _testSpectatorVec, _testClassVal, _testWeight, _testBoostWeight); event2 = new Event( _testValueVec, _testTargetVec, _testSpectatorVec, _testClassVal, _testWeight, _testBoostWeight); event3 = new Event( _testValueVec, _testTargetVec, _testSpectatorVec, _testClassVal, _testWeight, _testBoostWeight); event4 = new Event( _testValueVec, _testTargetVec, _testSpectatorVec, _testClassVal, _testWeight, _testBoostWeight); UInt_t varcounter = 0; VariableInfo* varinfo1 = new VariableInfo( expression1, title, unit, varcounter++, vartype, external, min, max, normalized); VariableInfo* varinfo2 = new VariableInfo( expression2, title, unit, varcounter++, vartype, external, min, max, normalized); VariableInfo* varinfo3 = new VariableInfo( expression3, title, unit, varcounter++, vartype, external, min, max, normalized); datasetinfo = new DataSetInfo(xname); datasetinfo->AddVariable(*varinfo1); datasetinfo->AddVariable(*varinfo2); datasetinfo->AddVariable(*varinfo3); datasetinfo->AddTarget(*varinfo1); datasetinfo->AddTarget(*varinfo2); datasetinfo->AddTarget(*varinfo3); datasetinfo->AddSpectator(*varinfo1); dataset = new DataSet(*datasetinfo); } void utDataSet::run() { testMethods(); } void utDataSet::testMethods() { test_(dataset->GetNEvents() == 0); dataset->AddEvent(event0, Types::kTraining); dataset->AddEvent(event1, Types::kTraining); dataset->AddEvent(event2, Types::kTesting); dataset->AddEvent(event3, Types::kMaxTreeType); dataset->AddEvent(event4, Types::kValidation); test_(dataset->GetNEvents(Types::kTraining) == 2); test_(dataset->GetNEvents(Types::kTesting) == 1); //test_(dataset->GetNEvents(Types::kMaxTreeType) == 1); //ToDo check this isuue test_(dataset->GetNEvents(Types::kValidation) == 1); //test_(dataset->GetNEvents(Types::kTrainingOriginal) == 0);//ToDo check this issue test_(dataset->GetNTrainingEvents() == 2); test_(dataset->GetNTestEvents() == 1); test_(dataset->GetNVariables() == 3); test_(dataset->GetNTargets() == 3); test_(dataset->GetNSpectators() == 1); // this is only a temporary solution for the testing // FIXME:: Extend to a real test! test_(dataset->GetEvent()); test_(dataset->GetEvent(0)); test_(dataset->GetTrainingEvent(0)); test_(dataset->GetTestEvent(0)); test_(dataset->GetEvent(1, Types::kTraining)); // calls to these function will cause the program to crash // test_(dataset->GetNEvtSigTest() == 1); // test_(dataset->GetNEvtBkgdTest() == 1); // test_(dataset->GetNEvtSigTrain() == 1); // test_(dataset->GetNEvtBkgdTrain() == 1); test_(dataset->HasNegativeEventWeights() == kFALSE); /* function still to develop tests for: void SetCurrentEvent( Long64_t ievt ) const { fCurrentEventIdx = ievt; } void SetCurrentType ( Types::ETreeType type ) const { fCurrentTreeIdx = TreeIndex(type); } void SetEventCollection( std::vector*, Types::ETreeType ); const std::vector& GetEventCollection( Types::ETreeType type = Types::kMaxTreeType ) const; const TTree* GetEventCollectionAsTree(); Results* GetResults ( const TString &,Types::ETreeType type, Types::EAnalysisType analysistype ); void DivideTrainingSet( UInt_t blockNum ); void MoveTrainingBlock( Int_t blockInd,Types::ETreeType dest, Bool_t applyChanges = kTRUE ); void IncrementNClassEvents( Int_t type, UInt_t classNumber ); Long64_t GetNClassEvents ( Int_t type, UInt_t classNumber ); void ClearNClassEvents ( Int_t type ); TTree* GetTree( Types::ETreeType type ); void InitSampling( Float_t fraction, Float_t weight, UInt_t seed = 0 ); void EventResult( Bool_t successful, Long64_t evtNumber = -1 ); void CreateSampling() const; UInt_t TreeIndex(Types::ETreeType type) const; */ } // including file tmvaut/utEvent.h #ifndef UTEVENT_H #define UTEVENT_H // Author: Christoph Rosemann Dec. 2009 // TMVA unit tests #include #ifndef ROOT_Rtypes #include "Rtypes.h" #endif namespace TMVA { class Event; } class utEvent : public UnitTesting::UnitTest { public: utEvent(); void run(); private: // the test calls in different blocks // the distinctions are arbitrary: void _testConstructor1(); void _testConstructor2(); void _testConstructor3(); void _testConstructor4(); void _testConstructor5(); void _testConstructor6(); void _testMutators(); // there are six different constructors: TMVA::Event* _eventC1; TMVA::Event* _eventC2; TMVA::Event* _eventC3; TMVA::Event* _eventC4; TMVA::Event* _eventC5; TMVA::Event* _eventC6; // the values needed to create all "Event" objects in all ways std::vector _testValueVec; std::vector _testPointerVec; std::vector _testTargetVec; std::vector _testSpectatorVec; std::vector _compareValueVec; std::vector _compareTargetVec; std::vector _compareSpectatorVec; Float_t _t, _u, _v; Float_t _testScale; UInt_t _testClassVal; Float_t _testWeight; Float_t _testBoostWeight; UInt_t _testNVar; }; #endif // UTEVENT_H // including file tmvaut/utEvent.cxx #include "TMath.h" #include "TMVA/Event.h" using namespace std; using namespace TMVA; utEvent::utEvent() : UnitTest("Event", __FILE__) { // the test values for initialisation _testValueVec.push_back(1.); _testValueVec.push_back(2.); _testValueVec.push_back(3.); _t = 1.; _u = 2.; _v = 3.; _testPointerVec.push_back(&_t); _testPointerVec.push_back(&_u); _testPointerVec.push_back(&_v); _testTargetVec.push_back(11.); _testTargetVec.push_back(12.); _testTargetVec.push_back(13.); _testSpectatorVec.push_back(25.); _testScale = 2.7818; _testClassVal = 2; _testWeight = 3.1415; _testBoostWeight = 0.1234; _testNVar = 3; } void utEvent::run() { _testConstructor1(); _testConstructor3(); _testConstructor2(); // constructor 3 must be called before... _testConstructor4(); _testConstructor5(); _testConstructor6(); } void utEvent::_testConstructor1() { _eventC1 = new Event(); test_(_eventC1->IsDynamic() == false); test_(floatCompare(_eventC1->GetWeight(), 1.)); test_(floatCompare(_eventC1->GetOriginalWeight(), 1.)); test_(floatCompare(_eventC1->GetBoostWeight(),1.)); test_(_eventC1->GetWeight() == 1.); test_(_eventC1->GetOriginalWeight() == 1.); test_(_eventC1->GetBoostWeight() == 1.); test_(_eventC1->GetClass() == 0); test_(_eventC1->GetNVariables() == 0); test_(_eventC1->GetNTargets() == 0); test_(_eventC1->GetNSpectators() == 0); _testMutators(); } void utEvent::_testConstructor2() { _eventC2 = new Event(*_eventC3); test_(_eventC2->IsDynamic() == false); test_(floatCompare(_eventC2->GetWeight(), _testWeight*_testBoostWeight)); test_(floatCompare(_eventC2->GetOriginalWeight(), _testWeight)); test_(floatCompare(_eventC2->GetBoostWeight(), _testBoostWeight)); test_(_eventC2->GetClass() == _testClassVal); test_(_eventC2->GetNVariables() == (UInt_t)_testValueVec.size()); test_(_eventC2->GetNTargets() == (UInt_t)_testTargetVec.size()); test_(_eventC2->GetNSpectators() == (UInt_t)_testSpectatorVec.size()); // ? const std::vector* GetVariableArrangement() const { return fVariableArrangement; } _compareValueVec = _eventC2->GetValues(); for(vector::const_iterator it = _testValueVec.begin(); it < _testValueVec.end(); ++it) { unsigned int index = it - _testValueVec.begin(); test_(_eventC2->GetValue(index) == *it); test_(_compareValueVec.at(index) == *it); } _compareTargetVec = _eventC2->GetTargets(); for(vector::const_iterator it = _testTargetVec.begin(); it < _testTargetVec.end(); ++it) { unsigned int index = it - _testTargetVec.begin(); test_(_eventC2->GetTarget(index) == *it); test_(_compareTargetVec.at(index) == *it); } _compareSpectatorVec = _eventC2->GetSpectators(); for(vector::const_iterator it = _testSpectatorVec.begin(); it < _testSpectatorVec.end(); ++it) { unsigned int index = it - _testSpectatorVec.begin(); test_(_eventC2->GetSpectator(index) == *it); test_(_compareSpectatorVec.at(index) == *it); } } void utEvent::_testConstructor3() { _eventC3 = new Event( _testValueVec, _testTargetVec, _testSpectatorVec, _testClassVal, _testWeight, _testBoostWeight); test_(_eventC3->IsDynamic() == false); test_(floatCompare(_eventC3->GetWeight(), _testWeight*_testBoostWeight)); test_(floatCompare(_eventC3->GetOriginalWeight(), _testWeight)); test_(floatCompare(_eventC3->GetBoostWeight(), _testBoostWeight)); test_(_eventC3->GetClass() == _testClassVal); test_(_eventC3->GetNVariables() == (UInt_t)_testValueVec.size()); test_(_eventC3->GetNTargets() == (UInt_t)_testTargetVec.size()); test_(_eventC3->GetNSpectators() == (UInt_t)_testSpectatorVec.size()); // ? const std::vector* GetVariableArrangement() const { return fVariableArrangement; } _compareValueVec = _eventC3->GetValues(); for(vector::const_iterator it = _testValueVec.begin(); it < _testValueVec.end(); ++it) { unsigned int index = it - _testValueVec.begin(); test_(_eventC3->GetValue(index) == *it); test_(_compareValueVec.at(index) == *it); } _compareTargetVec = _eventC3->GetTargets(); for(vector::const_iterator it = _testTargetVec.begin(); it < _testTargetVec.end(); ++it) { unsigned int index = it - _testTargetVec.begin(); test_(_eventC3->GetTarget(index) == *it); test_(_compareTargetVec.at(index) == *it); } _compareSpectatorVec = _eventC3->GetSpectators(); for(vector::const_iterator it = _testSpectatorVec.begin(); it < _testSpectatorVec.end(); ++it) { unsigned int index = it - _testSpectatorVec.begin(); test_(_eventC3->GetSpectator(index) == *it); test_(_compareSpectatorVec.at(index) == *it); } } void utEvent::_testConstructor4() { _eventC4 = new Event( _testValueVec, _testTargetVec, _testClassVal, _testWeight, _testBoostWeight); test_(_eventC4->IsDynamic() == false); test_(floatCompare(_eventC4->GetWeight(), _testWeight*_testBoostWeight)); test_(floatCompare(_eventC4->GetOriginalWeight(), _testWeight)); test_(floatCompare(_eventC4->GetBoostWeight(), _testBoostWeight)); test_(_eventC4->GetClass() == _testClassVal); test_(_eventC4->GetNVariables() == (UInt_t)_testValueVec.size()); test_(_eventC4->GetNTargets() == (UInt_t)_testTargetVec.size()); _compareValueVec = _eventC4->GetValues(); for(vector::const_iterator it = _testValueVec.begin(); it < _testValueVec.end(); ++it) { unsigned int index = it - _testValueVec.begin(); test_(_eventC4->GetValue(index) == *it); test_(_compareValueVec.at(index) == *it); } _compareTargetVec = _eventC4->GetTargets(); for(vector::const_iterator it = _testTargetVec.begin(); it < _testTargetVec.end(); ++it) { unsigned int index = it - _testTargetVec.begin(); test_(_eventC4->GetTarget(index) == *it); test_(_compareTargetVec.at(index) == *it); } } void utEvent::_testConstructor5() { _eventC5 = new Event( _testValueVec, _testClassVal, _testWeight, _testBoostWeight); test_(_eventC5->IsDynamic() == false); test_(floatCompare(_eventC5->GetWeight(), _testWeight*_testBoostWeight)); test_(floatCompare(_eventC5->GetOriginalWeight(), _testWeight)); test_(floatCompare(_eventC5->GetBoostWeight(), _testBoostWeight)); test_(_eventC5->GetClass() == _testClassVal); test_(_eventC5->GetNVariables() == (UInt_t)_testValueVec.size()); _compareValueVec = _eventC5->GetValues(); for(vector::const_iterator it = _testValueVec.begin(); it < _testValueVec.end(); ++it) { unsigned int index = it - _testValueVec.begin(); test_(_eventC5->GetValue(index) == *it); test_(_compareValueVec.at(index) == *it); } } void utEvent::_testConstructor6() { const vector* _constPointerToPointerVec = &_testPointerVec; _eventC6 = new Event( _constPointerToPointerVec, _testNVar); // TODO I don't understand what the constructor is for // or in what cases it should be used test_(_eventC6->IsDynamic() == true); // test_(_eventC6->GetWeight() == 1.); // test_(_eventC6->GetOriginalWeight() == 1.); // test_(_eventC6->GetBoostWeight() == 1.); // test_(_eventC6->GetClass() == _testClassVal); // test_(_eventC6->GetNVariables() == (UInt_t)_testValueVec.size()); // ? const std::vector* GetVariableArrangement() const { return fVariableArrangement; } // _compareValueVec = _eventC6->GetValues(); // for(vector::const_iterator it = _testValueVec.begin(); it < _testValueVec.end(); ++it) // { // unsigned int index = it - _testValueVec.begin(); // test_(_eventC6->GetValue(index) == *it); // test_(_compareValueVec.at(index) == *it); // } } void utEvent::_testMutators() { // the empty/default constructor is taken for these tests _eventC1->SetWeight(_testWeight); test_(_eventC1->GetWeight() == _testWeight); //_eventC1->ScaleWeight(_testScale); //test_(floatCompare((float) _eventC1->GetWeight(), _testWeight*_testScale)); test_(true); _eventC1->SetBoostWeight(_testBoostWeight); test_(floatCompare( _eventC1->GetBoostWeight() , _testBoostWeight)); _eventC1->ScaleBoostWeight(_testScale); test_(floatCompare( _eventC1->GetBoostWeight(), _testBoostWeight*_testScale)); _eventC1->SetClass(_testClassVal); test_(_eventC1->GetClass() == (UInt_t)_testClassVal); // check variables for(vector::const_iterator it = _testValueVec.begin(); it < _testValueVec.end(); ++it) { unsigned int index = it - _testValueVec.begin(); _eventC1->SetVal(index, *it); } _compareValueVec = _eventC1->GetValues(); for(vector::const_iterator it = _testValueVec.begin(); it < _testValueVec.end(); ++it) { unsigned int index = it - _testValueVec.begin(); test_(_eventC1->GetValue(index) == *it); test_(_compareValueVec.at(index) == *it); } // check targets for(vector::const_iterator it = _testTargetVec.begin(); it < _testTargetVec.end(); ++it) { unsigned int index = it - _testTargetVec.begin(); _eventC1->SetTarget(index, *it); } _compareTargetVec = _eventC1->GetTargets(); for(vector::const_iterator it = _testTargetVec.begin(); it < _testTargetVec.end(); ++it) { unsigned int index = it - _testTargetVec.begin(); test_(_eventC1->GetTarget(index) == *it); test_(_compareTargetVec.at(index) == *it); } // check spectators for(vector::const_iterator it = _testSpectatorVec.begin(); it < _testSpectatorVec.end(); ++it) { unsigned int index = it - _testSpectatorVec.begin(); _eventC1->SetSpectator(index, *it); } _compareSpectatorVec = _eventC1->GetSpectators(); for(vector::const_iterator it = _testSpectatorVec.begin(); it < _testSpectatorVec.end(); ++it) { unsigned int index = it - _testSpectatorVec.begin(); test_(_eventC1->GetSpectator(index) == *it); test_(_compareSpectatorVec.at(index) == *it); } _eventC1->SetClass(_testClassVal); test_(_eventC1->GetClass() == (UInt_t)_testClassVal); // ?? _eventC1->SetVariableArrangement( std::vector* const m ) const; } // including file tmvaut/utReader.h #ifndef UTREADER_H #define UTREADER_H // Author: E. v. Toerne, Nov 2011, implementing unit tests by C. Rosemann // TMVA unit tests // // this class acts as interface to several reader applications #include #include #include #include #include "TTree.h" #include "TString.h" #include "TMVA/Reader.h" #include "TMVA/Types.h" namespace UnitTesting { class utReader : public UnitTest { public: utReader(const char* theOption=""); virtual ~utReader(); virtual void run(); protected: private: // disallow copy constructor and assignment utReader(const utReader&); utReader& operator=(const utReader&); }; } // namespace UnitTesting #endif // // including file tmvaut/utReader.cxx #include #include #include #include #include "TTree.h" #include "TString.h" #include "TMVA/Reader.h" #include "TMVA/Types.h" using namespace std; using namespace UnitTesting; using namespace TMVA; utReader::utReader(const char* /*theOption*/) : UnitTest(string("Reader")) { } utReader::~utReader(){ } void utReader::run() { float xtest,xtest2; Reader* reader2 = new Reader(); Reader* reader3 = new Reader(); reader2->AddVariable("test", &xtest); reader2->AddVariable("test2", &xtest2); reader3->AddVariable("test", &xtest); delete reader2; delete reader3; test_(1>0); const int nTest=3; int ievt; vector testvar(10); std::vector< TMVA::Reader* > reader(nTest); for (int iTest=0;iTestAddVariable( "var0" ,&testvar[0]); reader[iTest]->AddVariable( "var1" ,&testvar[1]); reader[iTest]->AddSpectator( "ievt" ,&ievt); reader[iTest]->BookMVA( "LD method", "weights/TMVATest_LD.weights.xml") ; } if (iTest==1){ reader[iTest]->AddVariable( "var0" ,&testvar[0]); reader[iTest]->AddVariable( "var1" ,&testvar[1]); reader[iTest]->AddVariable( "var2" ,&testvar[2]); reader[iTest]->AddSpectator( "ievt" ,&ievt); reader[iTest]->BookMVA( "LD method", "weights/TMVATest3Var_LD.weights.xml") ; } if (iTest==2){ reader[iTest]->AddVariable( "var0" ,&testvar[0]); reader[iTest]->AddVariable( "var1" ,&testvar[1]); reader[iTest]->AddVariable( "var2" ,&testvar[2]); reader[iTest]->AddVariable( "ivar0" ,&testvar[3]); reader[iTest]->AddVariable( "ivar1" ,&testvar[4]); reader[iTest]->AddSpectator( "ievt" ,&ievt); reader[iTest]->BookMVA( "LD method", "weights/TMVATest3VarF2VarI_LD.weights.xml") ; } } reader[0]->EvaluateMVA( "LD method"); reader[1]->EvaluateMVA( "LD method"); reader[2]->EvaluateMVA( "LD method"); test_(1>0); } // including file tmvaut/utFactory.h #ifndef UTFACTORY_H #define UTFACTORY_H // Author: E. v. Toerne, Nov 2011, implementing unit tests by C. Rosemann // TMVA unit tests // // this class acts as interface to several factory applications #include #include #include #include #include "TTree.h" #include "TString.h" #include "TMVA/Factory.h" #include "TMVA/Types.h" namespace UnitTesting { class utFactory : public UnitTest { public: utFactory(const char* theOption=""); virtual ~utFactory(); virtual void run(); protected: virtual TTree* create_Tree(const char* opt=""); virtual bool operateSingleFactory(const char* factoryname, const char* opt=""); virtual bool addEventsToFactoryByHand(const char* factoryname, const char* opt=""); private: // disallow copy constructor and assignment utFactory(const utFactory&); utFactory& operator=(const utFactory&); }; } // namespace UnitTesting #endif // // including file tmvaut/utFactory.cxx #include #include #include #include #include #include "TMath.h" #include "TTree.h" #include "TFile.h" #include "TSystem.h" #include "TString.h" #include "TMVA/Factory.h" #include "TMVA/MethodBase.h" #include "TMVA/Types.h" using namespace std; using namespace UnitTesting; using namespace TMVA; utFactory::utFactory(const char* /*theOption*/) : UnitTest(string("Factory")) { } utFactory::~utFactory(){ } TTree* utFactory::create_Tree(const char* opt) { TString option = opt; const int nmax=100; const int nvar=3, nfval=2, nivar=2, nclass=3; float weight=1.; vector var(nvar), fval(nfval); // fix me hardcoded nvar vector ivar(nivar), nevt(nclass); Int_t iclass, ievt=0,i=0; TTree* tree = new TTree( "Tree", "Tree"); for (i=0; iBranch(Form( "var%i", i), &var[i], Form( "var%i/F", i )); for (i=0; iBranch(Form( "fval%i", i), &fval[i], Form( "fval%i/F", i )); for (i=0; iBranch(Form( "ivar%i", i), &ivar[i], Form( "ivar%i/I", i )); tree->Branch("iclass",&iclass,"iclass/I"); tree->Branch("ievt",&ievt,"ievt/I"); tree->Branch("weight",&weight,"weight/F"); TRandom3 R( 99 ); do { for (i=0; i 0) iclass=0; // signal else iclass=1; // background nevt[iclass]++; //std::cout << xout<< " " <Fill(); } while ( TMath::Min(nevt[0],TMath::Min(nevt[1],nevt[2])) < nmax); //tree->Print(); return tree; } bool utFactory::addEventsToFactoryByHand(const char* factoryname, const char* opt) { #ifdef COUTDEBUG std::cout <<"addEventsToFactoryByHand option="<AddVariable( "var0", "Variable 0", 'F' ); factory->AddVariable( "var1", "Variable 1", 'F' ); vector vars(2); TRandom3 r(99); double weight = 1.; for (int i=0;i<100;i++){ if (useWeights){ vars[0]= 4. * (r.Rndm()-0.5); vars[1]= 4. * (r.Rndm()-0.5); weight = TMath::Gaus(vars[0],1.,1.)*TMath::Gaus(vars[1],0.,1.); if (useNegWeights && i>90) weight = -weight; } else { vars[0]=r.Gaus(1.,1.); vars[1]=r.Gaus(0.,1.); } factory->AddSignalTrainingEvent( vars, weight ); factory->AddSignalTestEvent( vars, weight ); } for (int i=0;i<100;i++){ vars[0]= 4. * (r.Rndm()-0.5); vars[1]= 4. * (r.Rndm()-0.5); weight = 1.; factory->AddBackgroundTrainingEvent( vars, weight); factory->AddBackgroundTestEvent( vars, weight); } if (prepareString=="") prepareString = "nTrain_Signal=0:nTrain_Background=0:SplitMode=Random:NormMode=NumEvents:!V" ; factory->PrepareTrainingAndTestTree( "", "", prepareString); factory->BookMethod(_methodTitle,_methodTitle, "!H:!V"); factory->TrainAllMethods(); factory->TestAllMethods(); factory->EvaluateAllMethods(); MethodBase* theMethod = dynamic_cast (factory->GetMethod(_methodTitle)); double ROCValue = theMethod->GetROCIntegral(); //cout << "ROC="<Close(); if (outputFile) delete outputFile; return (ROCValue>0.6); } bool utFactory::operateSingleFactory(const char* factoryname, const char* opt) { if (TString(factoryname)=="") factoryname = "TMVATest"; #ifdef COUTDEBUG std::cout <<"operateSingleFactory option="<Write(); inFile->Close(); if (inFile) delete inFile; inFile = TFile::Open( "weights/input.root"); tree = (TTree*) inFile->Get("Tree"); } else if (! (option.Contains("LateTreeBooking"))) tree = create_Tree(); TString _methodTitle="LD",_methodOption="!H:!V"; // fix me TString prepareString=""; string factoryOptions( "!V:Silent:Transformations=I,D:AnalysisType=Classification:!Color:!DrawProgressBar" ); TString outfileName( "weights/TMVA.root" ); TFile* outputFile = TFile::Open( outfileName, "RECREATE" ); if (option.Contains("LateTreeBooking") && option.Contains("MemoryResidentTree")) tree = create_Tree(); Factory* factory = new Factory(factoryname,outputFile,factoryOptions); factory->AddVariable( "var0", "Variable 0", 'F' ); factory->AddVariable( "var1", "Variable 1", 'F' ); if (option.Contains("var2")) factory->AddVariable( "var2", "Var 2", 'F' ); if (option.Contains("ivar0")) factory->AddVariable( "ivar0", "Var i0", 'I' ); if (option.Contains("ivar1")) factory->AddVariable( "ivar1", "Var i1", 'I' ); factory->AddSpectator( "ievt", 'I' ); factory->AddSignalTree(tree); factory->AddBackgroundTree(tree); if (prepareString=="") prepareString = "nTrain_Signal=0:nTrain_Background=0:SplitMode=Random:NormMode=NumEvents:!V" ; // this crashes "nTrain_Signal=0:nTrain_Background=0:SplitMode=Random:NormMode=NumEvents:!V" ; factory->PrepareTrainingAndTestTree( "iclass==0", "iclass==1", prepareString); if (option.Contains("StringMethodBooking")) factory->BookMethod("LD","LD","!H:!V"); else factory->BookMethod(TMVA::Types::kLD,"LD","!H:!V"); //factory->BookMethod(_methodType, _methodTitle, _methodOption); factory->TrainAllMethods(); factory->TestAllMethods(); factory->EvaluateAllMethods(); MethodBase* theMethod = dynamic_cast (factory->GetMethod(_methodTitle)); double ROCValue = theMethod->GetROCIntegral(); delete tree; delete factory; outputFile->Close(); if (option.Contains("InputFile")){ inFile->Close(); } if (outputFile) delete outputFile; if (inFile) delete inFile; Bool_t ret = (ROCValue>0.6); if (!ret) { std::cout <<"FAILURE with operateSingleFactory option="<MakeDirectory("weights"); #ifdef COUTDEBUG std::cout << "creating directory weights"< #include "TString.h" namespace TMVA { class VariableInfo; } class utVariableInfo : public UnitTesting::UnitTest { public: utVariableInfo(); void run(); private: // the test calls in different blocks // the distinctions are arbitrary: void _testConstructor1(); void _testConstructor2(); void _testConstructor3(); void _testMethods(); // there are six different constructors: TMVA::VariableInfo* _varinfoC1; TMVA::VariableInfo* _varinfoC2; TMVA::VariableInfo* _varinfoC3; // the values needed to create all "VariableInfo" objects in all ways TString expression; TString title; TString unit; Int_t varCounter; char varType; Double_t min; Double_t max; Bool_t normalized; void* external; Float_t mean; Float_t rms; }; #endif // UTVARIABLEINFO_H // including file tmvaut/utVariableInfo.cxx #include "TMath.h" #include "TMVA/VariableInfo.h" using namespace std; using namespace UnitTesting; using namespace TMVA; utVariableInfo::utVariableInfo() : UnitTest("VariableInfo", __FILE__) { expression = "expression"; title = "title"; unit = "unit"; varCounter = 123; varType = 'D'; min = 2.781828; max = 3.1416; normalized = kTRUE; external = &max; mean = 42.; rms = 47.11; } void utVariableInfo::run() { _testConstructor1(); _testConstructor2(); _testConstructor3(); _testMethods(); } void utVariableInfo::_testConstructor1() { _varinfoC1 = new VariableInfo( expression, title, unit, varCounter, varType, external, min, max, normalized); test_(_varinfoC1->GetExpression() == expression); // test_(_varinfoC1->GetInternalName() == ); // test_(_varinfoC1->GetLabel() test_(_varinfoC1->GetTitle() == title); test_(_varinfoC1->GetUnit() == unit); test_(_varinfoC1->GetVarType() == varType); test_(_varinfoC1->GetMin() == min); test_(_varinfoC1->GetMax() == max); // test_(_varinfoC1->GetMean() == 0.); // test_(_varinfoC1->GetRMS() == 0.); test_(_varinfoC1->GetExternalLink() == external); } void utVariableInfo::_testConstructor2() { _varinfoC2 = new VariableInfo(); test_(_varinfoC2->GetExpression() == ""); // test_(_varinfoC2->GetInternalName() == ); // test_(_varinfoC2->GetLabel() test_(_varinfoC2->GetTitle() == ""); test_(_varinfoC2->GetUnit() == ""); test_(_varinfoC2->GetVarType() == '\0'); test_(_varinfoC2->GetMin() == 1e30); test_(_varinfoC2->GetMax() == -1e30); // test_(_varinfoC2->GetMean() == 0.); // test_(_varinfoC2->GetRMS() == 0.); // test_(_varinfoC2->GetExternalLink() == external); } void utVariableInfo::_testConstructor3() { _varinfoC3 = new VariableInfo(*_varinfoC1); test_(_varinfoC3->GetExpression() == expression); // test_(_varinfoC3->GetInternalName() == ); // test_(_varinfoC3->GetLabel() test_(_varinfoC3->GetTitle() == title); test_(_varinfoC3->GetUnit() == unit); test_(_varinfoC3->GetVarType() == varType); test_(_varinfoC3->GetMin() == min); test_(_varinfoC3->GetMax() == max); // test_(_varinfoC3->GetMean() == 0.); // test_(_varinfoC3->GetRMS() == 0.); test_(_varinfoC3->GetExternalLink() == external); } void utVariableInfo::_testMethods() { _varinfoC2->SetMin(min); _varinfoC2->SetMax(max); _varinfoC2->SetMean(mean); _varinfoC2->SetRMS(rms); _varinfoC2->SetExternalLink(external); test_(_varinfoC2->GetMin() == min); test_(_varinfoC2->GetMax() == max); test_(_varinfoC2->GetMean() == mean); test_(_varinfoC2->GetRMS() == rms); _varinfoC2->ResetMinMax(); test_(_varinfoC2->GetMin() == 1e30); test_(_varinfoC2->GetMax() == -1e30); // test assignment *_varinfoC2 = *_varinfoC1; test_(_varinfoC2->GetExpression() == expression); // test_(_varinfoC2->GetTitle() == title); // title is not copied // test_(_varinfoC2->GetUnit() == unit); // unit is not copied test_(_varinfoC2->GetVarType() == varType); test_(_varinfoC2->GetMin() == min); test_(_varinfoC2->GetMax() == max); test_(_varinfoC2->GetExternalLink() == external); } // including file tmvaut/MethodUnitTestWithROCLimits.h #ifndef METHODUNITTESTWITHROCLIMITS_H #define METHODUNITTESTWITHROCLIMITS_H // Author: Christoph Rosemann Jul 2010 // TMVA unit tests // // this class acts as interface to create, train and evaluate the method // specified in the constructor // as additional argument the limits of the ROC integral can be given // to determine the performance #include #include #include #include #include "TTree.h" #include "TString.h" #include "TMVA/Factory.h" #include "TMVA/MethodBase.h" #include "TMVA/Types.h" namespace UnitTesting { class MethodUnitTestWithROCLimits : public UnitTest { public: MethodUnitTestWithROCLimits(const TMVA::Types::EMVA& theMethod, const TString& methodTitle, const TString& theOption, double lowLimit = 0., double upLimit = 1., const std::string & name="", const std::string & filename="", std::ostream* osptr = &std::cout); virtual ~MethodUnitTestWithROCLimits(); virtual void run(); protected: TTree* theTree; private: TMVA::Factory* _factory; TMVA::MethodBase* _theMethod; TMVA::Types::EMVA _methodType; TString _methodTitle; TString _methodOption; double _upROCLimit; double _lowROCLimit; double _ROCValue; //TString _OutputROOTFile; std::vector* _VariableNames; std::vector* _TreeVariableNames; bool ROCIntegralWithinInterval(); // disallow copy constructor and assignment MethodUnitTestWithROCLimits(const MethodUnitTestWithROCLimits&); MethodUnitTestWithROCLimits& operator=(const MethodUnitTestWithROCLimits&); }; } // namespace UnitTesting #endif // METHODUNITTESTWITHROCLIMITS_H // including file tmvaut/MethodUnitTestWithROCLimits.cxx #include "TFile.h" #include "TROOT.h" #include "TSystem.h" #include "TMath.h" #include "TMVA/MethodBase.h" #include "TMVA/Reader.h" #include #include #include using namespace std; using namespace UnitTesting; using namespace TMVA; MethodUnitTestWithROCLimits::MethodUnitTestWithROCLimits(const Types::EMVA& theMethod, const TString& methodTitle, const TString& theOption, double lowLimit, double upLimit, const std::string & /* xname */ ,const std::string & /* filename */ , std::ostream* /* sptr */ ) : UnitTest((string)methodTitle, __FILE__), _methodType(theMethod) , _methodTitle(methodTitle), _methodOption(theOption), _upROCLimit(upLimit), _lowROCLimit(lowLimit), _VariableNames(0), _TreeVariableNames(0) { _VariableNames = new std::vector(0); _TreeVariableNames = new std::vector(0); _VariableNames->push_back("var1+var2"); _VariableNames->push_back("var1-var2"); _VariableNames->push_back("var3"); _VariableNames->push_back("var4"); _TreeVariableNames->push_back("myvar1"); _TreeVariableNames->push_back("myvar2"); _TreeVariableNames->push_back("var3"); _TreeVariableNames->push_back("var4"); } MethodUnitTestWithROCLimits::~MethodUnitTestWithROCLimits() { } bool MethodUnitTestWithROCLimits::ROCIntegralWithinInterval() { return (_ROCValue <= _upROCLimit) && (_ROCValue >= _lowROCLimit); } void MethodUnitTestWithROCLimits::run() { TString outfileName( "weights/TMVA.root" ); TFile* outputFile = TFile::Open( outfileName, "RECREATE" ); // FIXME:: if file can't be created do something more? if(!outputFile) return; // FIXME:: make the factory option mutable? // absolute silence options: string factoryOptions( "!V:Silent:AnalysisType=Classification:!Color:!DrawProgressBar" ); if (_methodOption.Contains("VarTransform")) factoryOptions+=":Transformations=I;D;P;G"; Factory* factory = new Factory( "TMVAUnitTesting", outputFile, factoryOptions ); // factory->AddVariable( "myvar1 := var1+var2", 'F' ); // factory->AddVariable( "myvar2 := var1-var2", "Expression 2", "", 'F' ); factory->AddVariable( Form("%s := %s",_TreeVariableNames->at(0).Data(), _VariableNames->at(0).Data()), 'F' ); factory->AddVariable( Form("%s := %s",_TreeVariableNames->at(1).Data(), _VariableNames->at(1).Data()), "Expression 2", "",'F' ); factory->AddVariable( _VariableNames->at(2), "Variable 3", "units", 'F' ); factory->AddVariable( _VariableNames->at(3), "Variable 4", "units", 'F' ); TFile* input(0); FileStat_t stat; TString fname = "../tmva/test/data/toy_sigbkg.root"; //tmva_example.root"; const char *fcname = gSystem->ExpandPathName("$ROOTSYS/tmva/test/data/toy_sigbkg.root"); if(!gSystem->GetPathInfo(fname,stat)) { input = TFile::Open( fname ); } else if(!gSystem->GetPathInfo("../"+fname,stat)) { input = TFile::Open( "../"+fname ); } else if(fcname && !gSystem->GetPathInfo(fcname,stat)) { input = TFile::Open( fcname ); } else { input = TFile::Open( "http://root.cern.ch/files/tmva_class_example.root" ); } delete [] fcname; if (input == NULL) { cerr << "broken/inaccessible input file" << endl; } TTree *signal = (TTree*)input->Get("TreeS"); TTree *background = (TTree*)input->Get("TreeB"); factory->AddSignalTree(signal); factory->AddBackgroundTree(background); factory->SetBackgroundWeightExpression("weight"); TCut mycuts = ""; TCut mycutb = ""; // FIXME:: make options string mutable? factory->PrepareTrainingAndTestTree( mycuts, mycutb, "nTrain_Signal=1000:nTrain_Background=1000:nTest_Signal=5000:nTest_Background=5000:SplitMode=Random:NormMode=NumEvents:!V" ); factory->BookMethod(_methodType, _methodTitle, _methodOption); factory->TrainAllMethods(); factory->TestAllMethods(); factory->EvaluateAllMethods(); _theMethod = dynamic_cast (factory->GetMethod(_methodTitle)); if (_methodType == TMVA::Types::kCuts) { // ToDo make class variable _theEffi Double_t err=0.; Double_t effi = _theMethod->GetEfficiency("Efficiency:0.1", Types::kTesting,err); #ifdef COUTDEBUG std::cout << "Cuts Signal effi at for Background effi of 0.1 = " << effi<<" low limit="<<_lowROCLimit<<" high limit="<<_upROCLimit<=_lowROCLimit); } else { _ROCValue = _theMethod->GetROCIntegral(); #ifdef COUTDEBUG std::cout << "ROC integral = "<<_ROCValue <<" low limit="<<_lowROCLimit<<" high limit="<<_upROCLimit<Get("TestTree")); for (UInt_t i=0;i<_VariableNames->size();i++) testTree->SetBranchAddress(_TreeVariableNames->at(i),&testvar[i]); testTree->SetBranchAddress(_methodTitle.Data(),&testTreeVal); std::vector variableNames2; variableNames2.push_back("var0"); variableNames2.push_back("var1"); TFile* testFile2 = new TFile("weights/ByHand.root"); TTree* testTree2 = (TTree*)(testFile2->Get("TestTree")); testTree2->SetBranchAddress("var0",&dummy[0]); testTree2->SetBranchAddress("var1",&dummy[1]); TString readerName = _methodTitle + TString(" method"); TString readerOption="!Color:Silent"; TString dir = "weights/TMVAUnitTesting_"; TString weightfile=dir+_methodTitle+".weights.xml"; TString weightfile2="weights/ByHand_BDT.weights.xml"; //TMVATest3VarF2VarI_BDT.weights.xml TString readerName2 = "BDT method"; double diff, maxdiff = 0., sumdiff=0., previousVal=0.; int stuckCount=0, nevt= TMath::Min((int) testTree->GetEntries(),100); const float effS=0.301; TMVA::Reader* reader2=0; std::vector< TMVA::Reader* > reader(nTest); for (int iTest=0;iTestGetEntry(ievt); if (testTree2) testTree2->GetEntry(ievt); for (UInt_t i=0;i<_VariableNames->size();i++){ testvarDouble[i]= testvar[i]; testvarFloat[i]= testvar[i]; } if (iTest==0){ if (_methodType==Types::kCuts) readerVal = reader[iTest]->EvaluateMVA( readerName, effS ); else readerVal=reader[iTest]->EvaluateMVA( readerName); } else if (iTest==1){ if (_methodType==Types::kCuts) readerVal = reader[iTest]->EvaluateMVA( testvarFloat, readerName, effS ); else readerVal=reader[iTest]->EvaluateMVA( testvarFloat, readerName); } else if (iTest==2){ if (_methodType==Types::kCuts) readerVal = reader[iTest]->EvaluateMVA( testvarDouble, readerName, effS ); else readerVal=reader[iTest]->EvaluateMVA( testvarDouble, readerName); } else if (iTest==3 ){ double dummy3 = reader2->EvaluateMVA( testvarDouble, readerName2); if (_methodType==Types::kCuts) readerVal = reader[iTest]->EvaluateMVA( testvarDouble, readerName, effS ); else readerVal=reader[iTest]->EvaluateMVA( testvarDouble, readerName); dummy3 += reader2->EvaluateMVA( testvarDouble, readerName2); } else if (iTest==4){ double dummy4 = reader2->EvaluateMVA( testvarDouble, readerName); if (_methodType==Types::kCuts) readerVal = reader[iTest]->EvaluateMVA( testvarDouble, readerName, effS ); else readerVal=reader[iTest]->EvaluateMVA( testvarDouble, readerName); dummy4 += reader2->EvaluateMVA( testvarDouble, readerName); } else if (iTest==5){ double dummy5 = reader2->EvaluateMVA( readerName2); if (_methodType==Types::kCuts) readerVal = reader[iTest]->EvaluateMVA( readerName, effS ); else readerVal=reader[iTest]->EvaluateMVA( readerName); dummy5 += reader2->EvaluateMVA( readerName2); } else { std::cout << "ERROR, undefined iTest value "< maxdiff ? diff : maxdiff; sumdiff += diff; } if (ievt>0 && iTest ==0 && TMath::Abs(readerVal-previousVal)<1.e-6) stuckCount++; if (iTest ==0 ) previousVal=readerVal; } } Bool_t ok=false; sumdiff=sumdiff/nevt; if (_methodType!=Types::kCuts){ test_(maxdiff <1.e-4); test_(sumdiff <1.e-5); test_(stuckCountClose(); for (int i=0;iGetPathInfo(macroFileName.Data(),stat2)) { gSystem->Unlink(macroFileName.Data()); //gSystem->Exec(Form("rm %s",macroFileName.Data())); } ofstream fout( macroFileName ); fout << "// generic macro file to test TMVA reader and standalone C code " << std::endl; fout << "#include \"TFile.h\""<"< vars(4);" << std::endl; // fix me 4 fout << "std::vector val(4);" << std::endl; // fix me 4 fout << "bool ok=true;" << std::endl; // fix me 4 for (UInt_t i=0;i<_VariableNames->size();i++) fout << Form("vars[%d]=\"%s\";",i,_VariableNames->at(i).Data()) << std::endl; fout << Form("Read%s aa(vars);", _methodTitle.Data()) << std::endl; fout << "TFile* testFile = new TFile(\"weights/TMVA.root\");" << std::endl; // fix me hardcode TMVA.root fout << " TTree* testTree = (TTree*)(testFile->Get(\"TestTree\"));" << std::endl; fout << Form("vector testvar(%d);",(Int_t) _VariableNames->size()) << std::endl; fout << Form("vector testvarDouble(%d);", (Int_t) _VariableNames->size()) << std::endl; for (UInt_t j=0;j<_VariableNames->size();j++) fout << Form("testTree->SetBranchAddress(\"%s\",&testvar[%d]);",_TreeVariableNames->at(j).Data(),j) << std::endl; fout << "float testTreeVal,diff,nrm,maxdiff=0.,sumdiff=0.;" << std::endl; fout << Form("testTree->SetBranchAddress(\"%s\",&testTreeVal);",_methodTitle.Data()) << std::endl; fout << "Long64_t nevt= TMath::Min((int) testTree->GetEntries(),100);" << std::endl; fout << " for (Long64_t ievt=0; ievtGetEntry(ievt);" << std::endl; fout << Form("for (UInt_t i=0;i<%d;i++) testvarDouble[i]= testvar[i];",(Int_t) _VariableNames->size()) << std::endl; fout << "double ccode_val = aa.GetMvaValue(testvarDouble);" << std::endl; fout << "diff = TMath::Abs(ccode_val-testTreeVal);" << std::endl; fout << "nrm = TMath::Max(TMath::Abs(ccode_val),1.);" << std::endl; fout << "diff = diff/nrm;" << std::endl; fout << "if (diff>1.2) std::cout << \"ccode_val=\" << ccode_val <<\"testval=\" << testTreeVal < maxdiff ? diff : maxdiff;" << std::endl; fout << "sumdiff += diff;" << std::endl; fout << "}" << std::endl; fout << "sumdiff=sumdiff/testTree->GetEntries();" << std::endl; fout << "if (maxdiff >1.e-2) std::cout << \"maxdiff=\"<2.e-4) ok=false;" << std::endl; fout << "testFile->Close();" << std::endl; fout << "if (!ok) {" << std::endl; fout << "std::cout << \"maxdiff=\"<ProcessLine(Form(".L %s+",macroFileName.Data())); test_(gROOT->ProcessLine(Form("%s()",macroName.Data()))); } } // including file tmvaut/RegressionUnitTestWithDeviation.h #ifndef REGRESSIONUNITTESTWITHDEVIATION_H #define REGRESSIONUNITTESTWITHDEVIATION_H // Author: Christoph Rosemann Oct 2010 // TMVA unit tests // // this class acts as interface to create, train and evaluate the method // specified in the constructor // additionally the regression performance is evaluated #include #include #include #include "TTree.h" #include "TString.h" #include "TMVA/Factory.h" #include "TMVA/MethodBase.h" #include "TMVA/Types.h" namespace UnitTesting { class RegressionUnitTestWithDeviation : public UnitTest { public: RegressionUnitTestWithDeviation(const TMVA::Types::EMVA& theMethod, const TString& methodTitle, const TString& theOption, double lowFullLimit = 0., double upFullLimit = 10., double low90PercentLimit = 0., double up90PercentLimit = 0., const std::string & name="", const std::string & filename="", std::ostream* osptr = &std::cout); virtual ~RegressionUnitTestWithDeviation(); virtual void run(); protected: TTree* theTree; private: TMVA::Factory* _factory; TMVA::MethodBase* _theMethod; TMVA::Types::EMVA _methodType; TString _methodTitle; TString _methodOption; double _lowerFullDeviationLimit; double _upperFullDeviationLimit; double _lower90PercentDeviationLimit; double _upper90PercentDeviationLimit; double _theFullDeviation; double _the90PercentDeviation; bool DeviationWithinLimits(); // disallow copy constructor and assignment RegressionUnitTestWithDeviation(const RegressionUnitTestWithDeviation&); RegressionUnitTestWithDeviation& operator=(const RegressionUnitTestWithDeviation&); }; } // namespace UnitTesting #endif // REGRESSIONUNITTESTWITHDEVIATION_H // including file tmvaut/RegressionUnitTestWithDeviation.cxx #include "TFile.h" #include "TSystem.h" #include "TMVA/MethodBase.h" #include "TMVA/Reader.h" #include using namespace std; using namespace UnitTesting; using namespace TMVA; RegressionUnitTestWithDeviation::RegressionUnitTestWithDeviation(const Types::EMVA& theMethod, const TString& methodTitle, const TString& theOption, double lowFullLimit, double upFullLimit,double low90PercentLimit, double up90PercentLimit, const std::string & /* xname */ ,const std::string & /* filename */ , std::ostream* /* sptr */) : UnitTest(string("Regression_")+(string)methodTitle, __FILE__), _methodType(theMethod) , _methodTitle(methodTitle), _methodOption(theOption), _lowerFullDeviationLimit(lowFullLimit), _upperFullDeviationLimit(upFullLimit), _lower90PercentDeviationLimit(low90PercentLimit), _upper90PercentDeviationLimit(up90PercentLimit) { } RegressionUnitTestWithDeviation::~RegressionUnitTestWithDeviation() { } bool RegressionUnitTestWithDeviation::DeviationWithinLimits() { return (_the90PercentDeviation<= _upper90PercentDeviationLimit) && (_the90PercentDeviation >= _lower90PercentDeviationLimit) && (_theFullDeviation <= _upperFullDeviationLimit) && (_theFullDeviation>= _lowerFullDeviationLimit); } void RegressionUnitTestWithDeviation::run() { // FIXME:: create _this_ file or rather somewhere else? TString outfileName( "weights/TMVARegUT.root" ); TFile* outputFile = TFile::Open( outfileName, "RECREATE" ); // FIXME:: if file can't be created do something more? if(!outputFile) return; // FIXME:: make the factory option mutable? // absolute silence options: string factoryOptions( "!V:Silent:Transformations=I;D;P;G,D:AnalysisType=Regression:!Color:!DrawProgressBar" ); Factory* factory = new Factory( "TMVARegressionUnitTesting", outputFile, factoryOptions ); factory->AddVariable( "var1", "Variable 1", "units", 'F' ); // fix me factory->AddVariable( "var2", "Variable 2", "units", 'F' ); // fix me TString _targetname="fvalue"; factory->AddTarget ( _targetname.Data() ); // fix me _targetname.Data() TFile* input(0); FileStat_t stat; // FIXME:: give the filename of the sample somewhere else? TString fname = "../tmva/test/tmva_reg_example.root"; if(!gSystem->GetPathInfo(fname,stat)) { input = TFile::Open( fname ); } else if(!gSystem->GetPathInfo("../"+fname,stat)) { input = TFile::Open( "../"+fname ); } else { input = TFile::Open( "http://root.cern.ch/files/tmva_reg_example.root" ); } if (input == NULL) { cerr << "broken/inaccessible input file" << endl; } TTree *regTree = (TTree*)input->Get("TreeR"); Double_t regWeight = 1.0; factory->AddRegressionTree( regTree, regWeight ); factory->SetWeightExpression( "var1", "Regression" ); TCut mycut = ""; // for example: TCut mycut = "abs(var1)<0.5 && abs(var2-0.5)<1"; factory->PrepareTrainingAndTestTree( mycut, "nTrain_Regression=500:nTest_Regression=500:SplitMode=Random:NormMode=NumEvents:!V" ); factory->BookMethod(_methodType, _methodTitle, _methodOption); factory->TrainAllMethods(); factory->TestAllMethods(); factory->EvaluateAllMethods(); _theMethod = dynamic_cast (factory->GetMethod(_methodTitle)); _theMethod->GetRegressionDeviation(0,TMVA::Types::kTesting, _theFullDeviation,_the90PercentDeviation); if (DeviationWithinLimits()){ #ifdef COUTDEBUG cout << "deviation, dev90= " << _theFullDeviation << ", " << _the90PercentDeviation << endl; cout << "Full limits " << _lowerFullDeviationLimit << " " << _upperFullDeviationLimit << ", 90% limits " << _lower90PercentDeviationLimit << " " << _upper90PercentDeviationLimit << endl; #endif } else { cout << "Failure "<<_methodTitle<<", deviation, dev90= " << _theFullDeviation << ", " << _the90PercentDeviation << endl; cout << "Full limits " << _lowerFullDeviationLimit << " " << _upperFullDeviationLimit << ", 90% limits " << _lower90PercentDeviationLimit << " " << _upper90PercentDeviationLimit << endl; } test_(DeviationWithinLimits()); outputFile->Close(); delete factory; // reader tests // setup test tree access TFile* testFile = new TFile("weights/TMVARegUT.root"); // fix me hardcoded file name TTree* testTree = (TTree*)(testFile->Get("TestTree")); const int nTest=3; // 3 reader usages float testTarget,readerVal=0.; vector* _VariableNames = new std::vector(0); // fix me, move to constructor _VariableNames->push_back("var1"); _VariableNames->push_back("var2"); vector testvar(_VariableNames->size()); vector dummy(_VariableNames->size()); vector dummy2(_VariableNames->size()); vector testvarFloat(_VariableNames->size()); vector testvarDouble(_VariableNames->size()); for (UInt_t i=0;i<_VariableNames->size();i++) testTree->SetBranchAddress(_VariableNames->at(i),&testvar[i]); testTree->SetBranchAddress(_methodTitle.Data(),&testTarget); TString readerName = _methodTitle + TString(" method"); TString dir = "weights/TMVARegressionUnitTesting_"; TString weightfile=dir+_methodTitle+".weights.xml"; double diff, maxdiff = 0., sumdiff=0., previousVal=0.; int stuckCount=0, nevt= TMath::Min((int) testTree->GetEntries(),50); std::vector< TMVA::Reader* > reader(nTest); for (int iTest=0;iTestsize();i++) reader[iTest]->AddVariable( _VariableNames->at(i),&testvar[i]); reader[iTest] ->BookMVA( readerName, weightfile) ; // run the reader application and compare to test tree for (Long64_t ievt=0;ievtGetEntry(ievt); for (UInt_t i=0;i<_VariableNames->size();i++){ testvarDouble[i]= testvar[i]; testvarFloat[i]= testvar[i]; } if (iTest==0){ readerVal=(reader[iTest]->EvaluateRegression( readerName))[0];} else if (iTest==1){ readerVal=(reader[iTest]->EvaluateRegression( readerName)).at(0);} else if (iTest==2){ readerVal=reader[iTest]->EvaluateRegression( 0, readerName);} else { std::cout << "ERROR, undefined iTest value "< maxdiff ? diff : maxdiff; sumdiff += diff; if (ievt>0 && iTest ==0 && TMath::Abs(readerVal-previousVal)<1.e-6) stuckCount++; //if (ievt<3) std::cout << "i="<= _lowROCLimit); } void MethodUnitTestWithComplexData::run() { // FIXME:: create _this_ file or rather somewhere else? TString outfileName( "weights/TMVA.root" ); TFile* outputFile = TFile::Open( outfileName, "RECREATE" ); // FIXME:: if file can't be created do something more? if(!outputFile) return; // FIXME:: make the factory option mutable? // absolute silence options: string factoryOptions( "!V:Silent:Transformations=I;D;P;G,D:AnalysisType=Classification:!Color:!DrawProgressBar" ); Factory* factory = new Factory( "TMVAUnitTesting", outputFile, factoryOptions ); factory->AddVariable( "var0", "Variable 0", 'F' ); factory->AddVariable( "var1", "Variable 1", 'F' ); factory->AddVariable( "var2", "Variable 2", 'F' ); factory->AddVariable( "var3", "Variable 3", 'F' ); factory->AddSpectator( "is1", 'I' ); factory->AddSpectator( "evtno", 'I' ); TFile* input(0); // FIXME:: give the filename of the sample somewhere else? TString fname = "weights/tmva_complex_data.root"; input = TFile::Open( fname ); if (input == NULL) create_data("weights/tmva_complex_data.root"); input = TFile::Open( fname ); if (input == NULL) { cerr << "broken/inaccessible input file" << endl; } TTree *sig1 = (TTree*)input->Get("TreeS1"); TTree *sig2 = (TTree*)input->Get("TreeS2"); TTree *sigfull = (TTree*)input->Get("TreeSFull"); TTree *bgd1 = (TTree*)input->Get("TreeB1"); TTree *bgd2 = (TTree*)input->Get("TreeB2"); TTree *bgdfull = (TTree*)input->Get("TreeBFull"); if (_treeString.Contains("sig1")) factory->AddSignalTree(sig1); if (_treeString.Contains("sig2")) factory->AddSignalTree(sig2); if (_treeString.Contains("sigfull")) factory->AddSignalTree(sigfull); if (_treeString.Contains("bgd1")) factory->AddBackgroundTree(bgd1); if (_treeString.Contains("bgd2")) factory->AddBackgroundTree(bgd2); if (_treeString.Contains("bgdfull")) factory->AddBackgroundTree(bgdfull); factory->SetSignalWeightExpression("weight"); factory->SetBackgroundWeightExpression("weight"); TCut mycuts = ""; TCut mycutb = ""; if (_prepareString=="") _prepareString = "nTrain_Signal=200:nTrain_Background=200:SplitMode=Random:NormMode=NumEvents:!V" ; factory->PrepareTrainingAndTestTree( mycuts, mycutb, _prepareString); factory->BookMethod(_methodType, _methodTitle, _methodOption); factory->TrainAllMethods(); factory->TestAllMethods(); factory->EvaluateAllMethods(); _theMethod = dynamic_cast (factory->GetMethod(_methodTitle)); if (_methodType == TMVA::Types::kCuts) { // ToDo make class variable _theEffi Double_t err=0.; Double_t effi = _theMethod->GetEfficiency("Efficiency:0.1", Types::kTesting,err); #ifdef COUTDEBUG std::cout << "Cuts Signal effi at for Background effi of 0.1 = " << effi<<" low limit="<<_lowROCLimit<<" high limit="<<_upROCLimit<=_lowROCLimit); } else { _ROCValue = _theMethod->GetROCIntegral(); #ifdef COUTDEBUG std::cout << "ROC integral = "<<_ROCValue <<" low limit="<<_lowROCLimit<<" high limit="<<_upROCLimit<Close(); delete factory; } bool MethodUnitTestWithComplexData::create_data(const char* filename, int nmax) { TFile* dataFile = TFile::Open(filename,"RECREATE"); int nvar = 4; int nsig = 0, nbgd=0; Float_t weight=1; Float_t xvar[100]; int is1,evtno=0; // create signal and background trees TTree* treeS1 = new TTree( "TreeS1", "TreeS1", 1 ); TTree* treeB1 = new TTree( "TreeB1", "TreeB1", 1 ); TTree* treeS2 = new TTree( "TreeS2", "TreeS2", 1 ); TTree* treeB2 = new TTree( "TreeB2", "TreeB2", 1 ); TTree* treeSFull = new TTree( "TreeSFull", "TreeSFull", 1 ); TTree* treeBFull = new TTree( "TreeBFull", "TreeBFull", 1 ); for (Int_t ivar=0; ivarBranch( TString(Form( "var%i", ivar )).Data(), &xvar[ivar], TString(Form( "var%i/F", ivar)).Data() ); treeB1->Branch( TString(Form( "var%i", ivar )).Data(), &xvar[ivar], TString(Form( "var%i/F", ivar)).Data() ); treeS2->Branch( TString(Form( "var%i", ivar )).Data(), &xvar[ivar], TString(Form( "var%i/F", ivar)).Data() ); treeB2->Branch( TString(Form( "var%i", ivar )).Data(), &xvar[ivar], TString(Form( "var%i/F", ivar)).Data() ); treeBFull->Branch( TString(Form( "var%i", ivar )).Data(), &xvar[ivar], TString(Form( "var%i/F", ivar)).Data() ); treeSFull->Branch( TString(Form( "var%i", ivar )).Data(), &xvar[ivar], TString(Form( "var%i/F", ivar)).Data() ); } treeS1->Branch("weight", &weight, "weight/F"); treeB1->Branch("weight", &weight, "weight/F"); treeS2->Branch("weight", &weight, "weight/F"); treeB2->Branch("weight", &weight, "weight/F"); treeSFull->Branch("weight", &weight, "weight/F"); treeBFull->Branch("weight", &weight, "weight/F"); treeS1->Branch("is1", &is1, "is1/I"); treeB1->Branch("is1", &is1, "is1/I"); treeS2->Branch("is1", &is1, "is1/I"); treeB2->Branch("is1", &is1, "is1/I"); treeSFull->Branch("is1", &is1, "is1/I"); treeBFull->Branch("is1", &is1, "is1/I"); treeS1->Branch("evtno", &evtno, "evtno/I"); treeB1->Branch("evtno", &evtno, "evtno/I"); treeS2->Branch("evtno", &evtno, "evtno/I"); treeB2->Branch("evtno", &evtno, "evtno/I"); treeSFull->Branch("evtno", &evtno, "evtno/I"); treeBFull->Branch("evtno", &evtno, "evtno/I"); TRandom R( 100 ); do { for (Int_t ivar=0; ivar0); //if (nsig<10) cout << "xout = " << xout<< (isSignal? " signal": " bbg") << endl; if (isSignal) { treeSFull->Fill(); if (is) treeS1->Fill(); else treeS2->Fill(); nsig++; evtno++; } else { treeBFull->Fill(); if (is) treeB1->Fill(); else treeB2->Fill(); nbgd++; evtno++; } } while ( nsig < nmax || nbgd < nmax); dataFile->Write(); dataFile->Close(); return true; } // including file stressTMVA.cxx // Authors: Christoph Rosemann, Eckhard von Toerne July 2010 // TMVA unit tests #include "Riostream.h" #include "TSystem.h" #include "TROOT.h" #include "TBenchmark.h" #include "TApplication.h" #include "TMVA/Types.h" using namespace UnitTesting; using namespace std; void addClassificationTests( UnitTestSuite& TMVA_test, bool full=true) { TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kCuts, "CutsGA", "H:!V:FitMethod=GA:CutRangeMin[0]=-10:CutRangeMax[0]=10:VarProp[1]=FMax:EffSel:Steps=20:Cycles=4:PopSize=300:SC_steps=10:SC_rate=5:SC_factor=0.95" , 0.4, 0.98) ); if (full){ TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kCuts, "Cuts", "!H:!V:FitMethod=MC:EffSel:SampleSize=20000:VarProp=FSmart", 0.4, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kCuts, "CutsD", "!H:!V:FitMethod=MC:EffSel:SampleSize=20000:VarProp=FSmart:VarTransform=Decorrelate" , 0.6, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kCuts, "CutsPCA", "!H:!V:FitMethod=MC:EffSel:SampleSize=20000:VarProp=FSmart:VarTransform=PCA" , 0.4, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kCuts, "CutsSA", "!H:!V:FitMethod=SA:EffSel:MaxCalls=15000:KernelTemp=IncAdaptive:InitialTemp=1e+6:MinTemp=1e-6:Eps=1e-10:UseDefaultScale" , 0.4, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kLikelihood, "Likelihood", "H:!V:TransformOutput:PDFInterpol=Spline2:NSmoothSig[0]=20:NSmoothBkg[0]=20:NSmoothBkg[1]=10:NSmooth=1:NAvEvtPerBin=50" , 0.7, 0.98) ); } TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kLikelihood, "LikelihoodD", "!H:!V:!TransformOutput:PDFInterpol=Spline2:NSmoothSig[0]=20:NSmoothBkg[0]=20:NSmooth=5:NAvEvtPerBin=50:VarTransform=Decorrelate" , 0.88, 0.98) ); if (full){ TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kLikelihood, "LikelihoodPCA", "!H:!V:!TransformOutput:PDFInterpol=Spline2:NSmoothSig[0]=20:NSmoothBkg[0]=20:NSmooth=5:NAvEvtPerBin=50:VarTransform=PCA" , 0.88, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kLikelihood, "LikelihoodMIX", "!H:!V:!TransformOutput:PDFInterpolSig[0]=KDE:PDFInterpolBkg[0]=KDE:PDFInterpolSig[1]=KDE:PDFInterpolBkg[1]=KDE:PDFInterpolSig[2]=Spline2:PDFInterpolBkg[2]=Spline2:PDFInterpolSig[3]=Spline2:PDFInterpolBkg[3]=Spline2:KDEtype=Gauss:KDEiter=Nonadaptive:KDEborder=None:NAvEvtPerBin=50" , 0.7, 0.98) ); } TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kPDERS, "PDERS", "!H:!V:NormTree=T:VolumeRangeMode=Adaptive:KernelEstimator=Gauss:GaussSigma=0.1:NEventsMin=100:NEventsMax=600" , 0.8, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kPDERS, "PDERSkNN", "!H:!V:VolumeRangeMode=kNN:KernelEstimator=Gauss:GaussSigma=0.3:NEventsMin=400:NEventsMax=600" , 0.8, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kPDERS, "PDERSD", "!H:!V:VolumeRangeMode=Adaptive:KernelEstimator=Gauss:GaussSigma=0.3:NEventsMin=100:NEventsMax=600:VarTransform=Decorrelate" , 0.88, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kPDERS, "PDERSPCA", "!H:!V:VolumeRangeMode=Adaptive:KernelEstimator=Gauss:GaussSigma=0.3:NEventsMin=100:NEventsMax=600:VarTransform=PCA" , 0.88, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kPDEFoam, "PDEFoam", "H:!V:SigBgSeparate=F:TailCut=0.001:VolFrac=0.0333:nActiveCells=500:nSampl=2000:nBin=5:Nmin=100:Kernel=None:Compress=T" , 0.8, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kKNN, "KNN", "H:nkNN=20:ScaleFrac=0.8:SigmaFact=1.0:Kernel=Gaus:UseKernel=F:UseWeight=T:!Trim" , 0.8, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kHMatrix, "HMatrix", "!H:!V:VarTransform=G" , 0.88, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kFisher, "Fisher", "H:!V:Fisher:CreateMVAPdfs:PDFInterpolMVAPdf=Spline2:NbinsMVAPdf=60:NsmoothMVAPdf=10" , 0.88, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kFisher, "FisherG", "H:!V:VarTransform=Gauss" , 0.88, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kFisher, "BoostedFisher", "H:!V:Boost_Num=10:Boost_Transform=log:Boost_Type=AdaBoost:Boost_AdaBoostBeta=0.2", 0.88, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits(TMVA::Types::kLD, "LD","!H:!V", 0.88, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kLD, "LD2", "H:!V:VarTransform=None" , 0.88, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kLD, "LDN", "H:!V:VarTransform=N" , 0.88, 0.98) ); TString baseFDAstring="!H:!V:Formula=(0)+(1)*x0+(2)*x1+(3)*x2+(4)*x3:ParRanges=(-1,1);(-10,10);(-10,10);(-10,10);(-10,10):"; if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kFDA, "FDA_MC", baseFDAstring+"FitMethod=MC:SampleSize=5000:Sigma=0.1" , 0.8, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kFDA, "FDA_GA", baseFDAstring+"FitMethod=GA:PopSize=100:Cycles=3:Steps=20:Trim=True:SaveBestGen=1" , 0.88, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kFDA, "FDA_SA", baseFDAstring+"FitMethod=SA:MaxCalls=5000:KernelTemp=IncAdaptive:InitialTemp=1e+6:MinTemp=1e-6:Eps=1e-10:UseDefaultScale" , 0.88, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kMLP, "MLP", "H:!V:NeuronType=tanh:VarTransform=N:NCycles=200:HiddenLayers=N+5:TestRate=5:!UseRegulator" , 0.88, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kMLP, "MLPBFGS", "H:!V:NeuronType=tanh:VarTransform=N:NCycles=200:HiddenLayers=N+5:TestRate=5:TrainingMethod=BFGS:!UseRegulator" , 0.88, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kMLP, "MLPBNN", "H:!V:NeuronType=tanh:VarTransform=N:NCycles=200:HiddenLayers=N+5:TestRate=5:TrainingMethod=BFGS:UseRegulator" , 0.88, 0.98) ); // BFGS training with bayesian regulators if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kCFMlpANN, "CFMlpANN", "!H:!V:NCycles=200:HiddenLayers=N+1,N" , 0.7, 0.98) ); // n_cycles:#nodes:#nodes:... if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kTMlpANN, "TMlpANN", "!H:!V:NCycles=200:HiddenLayers=N+1,N:LearningMethod=BFGS:ValidationFraction=0.3" , 0.7, 0.98) ); // n_cycles:#nodes:#nodes:... TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kSVM, "SVM", "Gamma=0.25:Tol=0.001:VarTransform=Norm" , 0.88, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kBDT, "BDTG", "!H:!V:NTrees=400:BoostType=Grad:Shrinkage=0.30:UseBaggedBoost:GradBaggingFraction=0.6:SeparationType=GiniIndex:nCuts=20:MaxDepth=2" , 0.88, 0.98) ); TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kBDT, "BDT", "!H:!V:NTrees=400:nEventsMin=100:MaxDepth=3:BoostType=AdaBoost:SeparationType=GiniIndex:nCuts=10:PruneMethod=NoPruning" , 0.88, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kBDT, "BDTB", "!H:!V:NTrees=400:nEventsMin=100:BoostType=Bagging:SeparationType=GiniIndex:nCuts=20:PruneMethod=NoPruning" , 0.8, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kBDT, "BDTD", "!H:!V:NTrees=400:nEventsMin=200:MaxDepth=3:BoostType=AdaBoost:SeparationType=GiniIndex:nCuts=10:PruneMethod=NoPruning:VarTransform=Decorrelate" , 0.88, 0.98) ); if (full) TMVA_test.addTest(new MethodUnitTestWithROCLimits( TMVA::Types::kRuleFit, "RuleFit", "H:!V:RuleFitModule=RFTMVA:Model=ModRuleLinear:MinImp=0.001:RuleMinDist=0.001:NTrees=20:fEventsMin=0.01:fEventsMax=0.5:GDTau=-1.0:GDTauPrec=0.01:GDStep=0.01:GDNSteps=10000:GDErrScale=1.02" , 0.88, 0.98) ); } void addRegressionTests( UnitTestSuite& TMVA_test, bool full=true) { TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kLD, "LD", "!H:!V:VarTransform=None", 15., 25., 10., 20. )); // full low/high , 90 low/high TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kMLP, "MLPBFGSN", "!H:!V:VarTransform=Norm:NeuronType=tanh:NCycles=300:HiddenLayers=N+20:TestRate=6:TrainingMethod=BFGS:Sampling=0.3:SamplingEpoch=0.8:ConvergenceImprove=1e-7:ConvergenceTests=15:!UseRegulator:VarTransform=N" , 0.4, 0.85, 0.3, 0.55 )); if (full) TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kBDT, "BDTG","!H:!V:NTrees=1000::BoostType=Grad:Shrinkage=0.3:!UseBaggedBoost:SeparationType=GiniIndex:nCuts=20:MinNodeSize=.2:MaxDepth=3" , 5., 8., 3., 5. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kBDT, "BDTG2","!H:!V:NTrees=2000::BoostType=Grad:Shrinkage=0.1:UseBaggedBoost:GradBaggingFraction=0.5:nCuts=20:MaxDepth=3" , 2., 5., 1., 3. )); if (!full) return; TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kPDERS, "PDERS", "!H:!V:NormTree=T:VolumeRangeMode=Adaptive:KernelEstimator=Gauss:GaussSigma=1.0:NEventsMin=10:NEventsMax=60:VarTransform=None", 10., 15., 5., 10. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kPDERS, "PDERSkNN", "!H:!V:VolumeRangeMode=kNN:KernelEstimator=Gauss:GaussSigma=1.0:NEventsMin=10:NEventsMax=60" , 10., 15., 5., 10. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kPDEFoam, "PDEFoam", "!H:!V:MultiTargetRegression=F:TargetSelection=Mpv:TailCut=0.001:VolFrac=0.0333:nActiveCells=500:nSampl=5000:nBin=7:Compress=T:Kernel=Gauss:Nmin=10:VarTransform=None", 10., 15., 4., 6. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kKNN, "KNN", "nkNN=20:ScaleFrac=0.8:SigmaFact=1.0:Kernel=Gaus:UseKernel=F:UseWeight=T:!Trim" , 10., 15., 4., 6. )); TString baseRegFDAstring="!H:!V:Formula=(0)+(1)*x0+(2)*x1+(3)*x0*x1+(4)*x0*x0+(5)*x1*x1:ParRanges=(-1,1);(-2,2);(-2,2);(-2,2);(-2,2);(-2,2):"; TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kFDA, "FDA_MC", baseRegFDAstring+"FitMethod=MC:SampleSize=1000:Sigma=0.1:VarTransform=N", 15., 25., 10., 20. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kFDA, "FDA_GA", baseRegFDAstring+"FitMethod=GA:PopSize=100:Cycles=3:Steps=30:Trim=True:SaveBestGen=1:VarTransform=Norm", 0.5, 1.0, 0.5 , 0.8 )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kFDA, "FDA_MT", baseRegFDAstring+"FitMethod=MINUIT:ErrorLevel=1:PrintLevel=-1:FitStrategy=2:UseImprove:UseMinos:SetBatch" , 100., 250., 100., 200. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kFDA, "FDA_GAMT",baseRegFDAstring+"FitMethod=GA:Converger=MINUIT:ErrorLevel=1:PrintLevel=-1:FitStrategy=0:UseImprove:UseMinos:SetBatch:Cycles=1:PopSize=20:Steps=5:Trim" , 100., 250., 100., 220. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kMLP, "MLPBFGS", "!H:!V:VarTransform=Norm:NeuronType=tanh:NCycles=300:HiddenLayers=N+20:TestRate=6:TrainingMethod=BFGS:Sampling=0.3:SamplingEpoch=0.8:ConvergenceImprove=1e-6:ConvergenceTests=15:!UseRegulator" , 0.4, 0.8, 0.2, 0.5 )); // this does not work satisfactory TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kMLP, "MLP", "!H:!V:VarTransform=Norm:NeuronType=tanh:NCycles=300:HiddenLayers=N+20:TestRate=6:TrainingMethod=BP:Sampling=0.3:SamplingEpoch=0.8:ConvergenceImprove=1e-6:ConvergenceTests=15:!UseRegulator" , 0.4, 0.8, 0.2, 0.5 )); // SVM regression does not work TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kSVM, "SVM", "Gamma=0.25:Tol=0.001:VarTransform=Norm" , 0., 1., 0., 1. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kBDT, "BDT","!H:!V", 8., 15., 5., 10. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kBDT, "BDTN","!H:!V:VarTransform=N", 8., 15., 5., 10. )); TMVA_test.addTest(new RegressionUnitTestWithDeviation( TMVA::Types::kBDT, "BDT2","!H:!V:NTrees=500:nEventsMin=20:BoostType=AdaBoostR2:SeparationType=GiniIndex:nCuts=20:PruneMethod=CostComplexity:PruneStrength=3", 15., 20., 10., 20. )); } void addDataInputTests( UnitTestSuite& TMVA_test, bool full=true) { if (!full) return; TString lhstring = "!H:!V:!TransformOutput:PDFInterpol=Spline2:NSmoothSig[0]=20:NSmoothBkg[0]=20:NSmooth=5:NAvEvtPerBin=50:VarTransform=Decorrelate"; TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sig1_bgd1"), TString("nTrain_Signal=500:nTrain_Background=500:SplitMode=random:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.48, 0.52) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sig1_bgd1"), TString("nTrain_Signal=500:nTrain_Background=500:SplitMode=block:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.48, 0.52) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sig1_bgd1"), TString("nTrain_Signal=500:nTrain_Background=500:SplitMode=alternate:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.48, 0.52) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sigfull_bgdfull"), TString("nTrain_Signal=500:nTrain_Background=500:SplitMode=Random:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.9, 0.95) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sigfull_bgdfull"), TString("nTrain_Signal=500:nTrain_Background=500:SplitMode=alternate:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.9, 0.95) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sigfull_bgdfull"), TString("nTrain_Signal=500:nTrain_Background=500:SplitMode=block:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.9, 0.95) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sig1_sig2_bgd1_bgd2"), TString("nTrain_Signal=500:nTrain_Background=500:nTest_Signal=500:nTest_Background=500:SplitMode=random:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.9, 0.95) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sig1_sig2_bgd1_bgd2"), TString("nTrain_Signal=500:nTrain_Background=500:nTest_Signal=500:nTest_Background=500:SplitMode=block:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.2, 0.45) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sig1_sig2_bgd1_bgd2"), TString("nTrain_Signal=500:nTrain_Background=500:nTest_Signal=500:nTest_Background=500:SplitMode=alternate:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.45, 0.52) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sig1_sig2_bgd1_bgd2"), TString("SplitMode=random:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.9, 0.95) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sig1_sig2_bgd1_bgd2"), TString("SplitMode=alternate:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.9, 0.95) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(TString("sig1_sig2_bgd1_bgd2"), TString("SplitMode=block:NormMode=NumEvents:!V"), TMVA::Types::kLikelihood, "LikelihoodD", lhstring , 0.9, 0.994) ); } void addComplexClassificationTests( UnitTestSuite& TMVA_test, bool full=true ) { if (!full) return; TString trees="sigfull_bgdfull"; TString prep="nTrain_Signal=2000:nTrain_Background=2000:nTest_Signal=1000:nTest_Background=1000:!V"; // complex data tests Fisher for comparison TMVA_test.addTest(new MethodUnitTestWithComplexData( trees, prep,TMVA::Types::kFisher, "Fisher", "H:!V:VarTransform=Gauss", 0.93, 0.945) ); // complex data tests with MLP TMVA_test.addTest(new MethodUnitTestWithComplexData(trees, prep, TMVA::Types::kMLP, "MLP", "H:!V:RandomSeed=9:NeuronType=tanh:VarTransform=N:NCycles=50:HiddenLayers=N+10:TestRate=5:TrainingMethod=BFGS:!UseRegulator" , 0.955, 0.975) ); TMVA_test.addTest(new MethodUnitTestWithComplexData(trees, prep, TMVA::Types::kMLP, "MLP", "H:!V:RandomSeed=9:NeuronType=tanh:VarTransform=N:NCycles=50:HiddenLayers=N+10:TestRate=5:TrainingMethod=BP:!UseRegulator" , 0.955, 0.975) ); // BDT TMVA_test.addTest(new MethodUnitTestWithComplexData(trees, prep, TMVA::Types::kBDT, "BDTG8_50", "!H:!V:NTrees=50:BoostType=Grad:Shrinkage=0.30:UseBaggedBoost:BaggedSampleFraction=0.6:nCuts=20:MaxDepth=3:SeparationType=GiniIndex" , 0.950, 0.975) ); // SVM TMVA_test.addTest(new MethodUnitTestWithComplexData(trees, prep, TMVA::Types::kSVM, "SVM", "Gamma=0.4:Tol=0.001" , 0.955, 0.975) ); } int main(int argc, char **argv) { TApplication theApp("App", &argc, argv); gBenchmark = new TBenchmark(); gBenchmark->Start("stress"); bool full=false; #ifdef FULL full=true; //std::cout << running longer tests<GetPathInfo("./weights",stat)) { #ifdef WIN32 gSystem->Exec("erase /f /q weights\\*.*"); #else gSystem->Exec("rm -rf weights/*"); #endif #endif gBenchmark->Stop("stress"); Bool_t UNIX = strcmp(gSystem->GetName(), "Unix") == 0; printf("******************************************************************\n"); if (UNIX) { TString sp = gSystem->GetFromPipe("uname -a"); sp.Resize(60); printf("* SYS: %s\n",sp.Data()); if (strstr(gSystem->GetBuildNode(),"Linux")) { sp = gSystem->GetFromPipe("lsb_release -d -s"); printf("* SYS: %s\n",sp.Data()); } if (strstr(gSystem->GetBuildNode(),"Darwin")) { sp = gSystem->GetFromPipe("sw_vers -productVersion"); sp += " Mac OS X "; printf("* SYS: %s\n",sp.Data()); } } else { const char *os = gSystem->Getenv("OS"); if (!os) printf("* SYS: Windows 95\n"); else printf("* SYS: %s %s \n",os,gSystem->Getenv("PROCESSOR_IDENTIFIER")); } //printf("******************************************************************\n"); //gBenchmark->Print("stress"); Float_t ct = gBenchmark->GetCpuTime("stress"); printf("******************************************************************\n"); printf("* CPUTIME =%6.1f * Root%-8s %d/%d\n",ct ,gROOT->GetVersion(),gROOT->GetVersionDate(),gROOT->GetVersionTime()); printf("******************************************************************\n"); }