00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #include <vector>
00029
00030 #include "TH1.h"
00031
00032 #include "TMVA/Results.h"
00033 #include "TMVA/MsgLogger.h"
00034
00035
00036 TMVA::Results::Results( const DataSetInfo* dsi )
00037 : fTreeType(Types::kTraining),
00038 fDsi(dsi),
00039 fStorage( new TList() ),
00040 fHistAlias( new std::map<TString, TObject*> ),
00041 fLogger( new MsgLogger("Results", kINFO) )
00042 {
00043
00044 fStorage->SetOwner();
00045 }
00046
00047
00048 TMVA::Results::~Results()
00049 {
00050
00051
00052
00053 delete fStorage;
00054 delete fHistAlias;
00055 delete fLogger;
00056 }
00057
00058
00059 void TMVA::Results::Store( TObject* obj, const char* alias )
00060 {
00061 TListIter l(fStorage);
00062
00063 while (void* p = (void*)l()) {
00064 if(p==obj)
00065 *fLogger << kFATAL << "Histogram pointer " << p << " already exists in results storage" << Endl;
00066 }
00067
00068 TString as(obj->GetName());
00069 if (alias!=0) as=TString(alias);
00070 if (fHistAlias->find(as) != fHistAlias->end()) {
00071
00072 *fLogger << kFATAL << "Alias " << as << " already exists in results storage" << Endl;
00073 }
00074 if( obj->InheritsFrom(TH1::Class()) ) {
00075 ((TH1*)obj)->SetDirectory(0);
00076 }
00077 fStorage->Add( obj );
00078 fHistAlias->insert(std::pair<TString, TObject*>(as,obj));
00079 }
00080
00081
00082 TObject* TMVA::Results::GetObject(const TString & alias) const
00083 {
00084 std::map<TString, TObject*>::iterator it = fHistAlias->find(alias);
00085
00086 if (it != fHistAlias->end()) return it->second;
00087
00088
00089 return 0;
00090 }
00091
00092
00093
00094 TH1* TMVA::Results::GetHist(const TString & alias) const
00095 {
00096 return (TH1*)GetObject(alias);
00097 }
00098
00099
00100
00101 void TMVA::Results::Delete()
00102 {
00103
00104
00105 fStorage->Delete();
00106 fHistAlias->clear();
00107 }