Changeset 7130 for trunk/MagicSoft/Mars/mranforest
- Timestamp:
- 06/03/05 18:02:36 (20 years ago)
- Location:
- trunk/MagicSoft/Mars/mranforest
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/MagicSoft/Mars/mranforest/MRFEnergyEst.cc
r6932 r7130 57 57 #include "MParameters.h" 58 58 59 60 59 ClassImp(MRFEnergyEst); 61 60 … … 67 66 // -------------------------------------------------------------------------- 68 67 // 69 // 70 MRFEnergyEst::MRFEnergyEst(const char *name, const char *title):fNumTrees(-1) 71 { 72 //73 // set the name and title of this object74 // 68 // Default constructor. Set the name and title of this object 69 // 70 MRFEnergyEst::MRFEnergyEst(const char *name, const char *title) 71 : fNumTrees(-1), fNumTry(-1), fNdSize(-1), fData(0), fEnergyEst(0), 72 fTestMatrix(0) 73 { 75 74 fName = name ? name : gsDefName.Data(); 76 75 fTitle = title ? title : gsDefTitle.Data(); … … 79 78 // -------------------------------------------------------------------------- 80 79 // 81 // Delete the data chains 82 // 83 MRFEnergyEst::~MRFEnergyEst() 84 { 85 // delete fData; 86 } 87 88 // -------------------------------------------------------------------------- 89 Int_t MRFEnergyEst::Train() 90 { 91 if(!fMatrixTrain) 92 { 93 *fLog << err << dbginf << "fMatrixTrain not found... aborting." << endl; 94 return kFALSE; 95 } 96 97 if(!fMatrixTrain->GetColumns()) 98 { 99 *fLog << err << dbginf << "fMatrixTrain does not contain rules... aborting." << endl; 100 return kFALSE; 101 } 102 103 const Int_t ncols = (fMatrixTrain->GetM()).GetNcols(); 104 const Int_t nrows = (fMatrixTrain->GetM()).GetNrows(); 105 106 cout<<"ncols="<<ncols<<" nrows="<<nrows<<endl<<flush; 107 108 if(ncols<=0 || nrows <=0) 109 { 110 *fLog << err << dbginf << "No. of columns or no. of rows of fMatrixTrain equal 0 ... aborting." << endl; 80 // Train the RF with the goven MHMatrix. The last column must contain the 81 // True energy. 82 // 83 Int_t MRFEnergyEst::Train(const MHMatrix &matrixtrain, const TArrayD &grid) 84 { 85 gLog.Separator("MRFEnergyEst - Train"); 86 87 if (!matrixtrain.GetColumns()) 88 { 89 *fLog << err << "ERROR - MHMatrix does not contain rules... abort." << endl; 90 return kFALSE; 91 } 92 93 const Int_t ncols = matrixtrain.GetM().GetNcols(); 94 const Int_t nrows = matrixtrain.GetM().GetNrows(); 95 if (ncols<=0 || nrows <=0) 96 { 97 *fLog << err << "ERROR - No. of columns or no. of rows of matrixtrain equal 0 ... abort." << endl; 98 return kFALSE; 99 } 100 101 const Int_t nbins = grid.GetSize()-1; 102 if (nbins<=0) 103 { 104 *fLog << err << "ERROR - Energy grid not vaild... abort." << endl; 111 105 return kFALSE; 112 106 } 113 107 114 108 // rules (= combination of image par) to be used for energy estimation 115 MDataArray used_rules; 116 TString energy_rule; 117 for(Int_t i=0;i<ncols;i++) 118 { 119 MDataArray *rules=fMatrixTrain->GetColumns(); 120 MData &data=(*rules)[i]; 121 122 if(i<ncols-1) 123 used_rules.AddEntry(data.GetRule()); 124 else 125 energy_rule=data.GetRule(); 126 } 127 128 if(!energy_rule.Contains("fEnergy")) 129 { 130 *fLog << err << dbginf << "Can not accept "<<energy_rule<<" as true energy ... aborting." << endl; 131 return kFALSE; 132 } 133 134 TFile fileRF(fRFfileName,"recreate"); 135 if(!fileRF.IsOpen()) 136 { 137 *fLog << err << dbginf << "File to store RFs could not be opened... aborting." << endl; 138 return kFALSE; 139 } 140 141 TMatrix *mptr=(TMatrix*)&(fMatrixTrain->GetM()); 142 const Int_t nbins = fEnergyGrid.GetSize()-1; 143 if(nbins<=0) 144 { 145 *fLog << err << dbginf << "Energy grid not vaild... aborting." << endl; 146 return kFALSE; 147 } 109 TFile fileRF(fFileName, "recreate"); 110 if (!fileRF.IsOpen()) 111 { 112 *fLog << err << "ERROR - File to store RFs could not be opened... abort." << endl; 113 return kFALSE; 114 } 115 116 MDataArray usedrules; 117 for(Int_t i=0; i<ncols-3; i++) // -3 is important!!! 118 usedrules.AddEntry((*matrixtrain.GetColumns())[i].GetRule()); 119 120 const TMatrix &m = matrixtrain.GetM(); 148 121 149 122 // training of RF for each energy bin 150 Int_t numbins=0; 151 for(Int_t ie=0;ie<nbins;ie++) 152 { 153 TMatrix mat1(nrows,ncols); 154 TMatrix mat0(nrows,ncols); 123 for (Int_t ie=0; ie<nbins; ie++) 124 { 125 TMatrix mat1(nrows, ncols); 126 TMatrix mat0(nrows, ncols); 155 127 156 128 // prepare matrix for current energy bin … … 158 130 Int_t irow0=0; 159 131 160 for (Int_t j=0;j<nrows;j++)132 for (Int_t j=0; j<nrows; j++) 161 133 { 162 Double_t energy=(*mptr)(j,ncols-1); 163 if(energy>pow(10.,fEnergyGrid[ie]) && energy<=pow(10.,fEnergyGrid[ie+1])) 164 { 165 TMatrixRow(mat1, irow1) = TMatrixRow(*mptr,j); 166 irow1++; 167 }else{ 168 TMatrixRow(mat0, irow0) = TMatrixRow(*mptr,j); 169 irow0++; 170 } 134 const Double_t energy = m(j,ncols-1); 135 136 if (energy>grid[ie] && energy<=grid[ie+1]) 137 TMatrixFRow(mat1, irow1++) = TMatrixFRow_const(m,j); 138 else 139 TMatrixFRow(mat0, irow0++) = TMatrixFRow_const(m,j); 171 140 } 172 if(irow1*irow0==0)continue; 173 174 *fLog << inf << dbginf << "Training RF for energy bin "<<ie<< endl; 141 142 const Bool_t valid = irow1*irow0>0; 143 144 if (!valid) 145 *fLog << warn << "WARNING - Skipping"; 146 else 147 *fLog << inf << "Training RF for"; 148 149 *fLog << " energy bin " << ie << " (" << grid[ie] << ", " << grid[ie+1] << ")" << endl; 150 151 if (!valid) 152 continue; 153 154 gLog.SetNullOutput(kTRUE); 175 155 176 156 // last column must be removed (true energy col.) 177 mat1.ResizeTo(irow1, ncols-1);178 mat0.ResizeTo(irow0, ncols-1);157 mat1.ResizeTo(irow1, ncols-1); 158 mat0.ResizeTo(irow0, ncols-1); 179 159 180 160 // create MHMatrix as input for RF 181 MHMatrix matrix1(mat1,"MatrixHadrons"); 182 MHMatrix matrix0(mat0,"MatrixGammas"); 183 184 MDataArray *rules1=matrix1.GetColumns(); 185 MDataArray *rules0=matrix0.GetColumns(); 186 // rules of new matrices be re-set 187 if(rules1)delete rules1; rules1=new MDataArray(); 188 if(rules0)delete rules0; rules0=new MDataArray(); 189 190 for(Int_t i=0;i<ncols-1;i++) 191 { 192 //MDataArray *rules=fMatrixTrain->GetColumns(); 193 //MData &data=(*rules)[i]; 194 MData &data=used_rules[i]; 195 rules1->AddEntry(data.GetRule()); 196 rules0->AddEntry(data.GetRule()); 197 } 161 MHMatrix matrix1(mat1, "MatrixHadrons"); 162 MHMatrix matrix0(mat0, "MatrixGammas"); 163 164 matrix1.AddColumns(&usedrules); 165 matrix0.AddColumns(&usedrules); 198 166 199 167 // training of RF 168 MTaskList tlist; 200 169 MParList plist; 201 MTaskList tlist;202 170 plist.AddToList(&tlist); 203 171 plist.AddToList(&matrix0); … … 212 180 213 181 MEvtLoop evtloop; 182 evtloop.SetDisplay(fDisplay); 214 183 evtloop.SetParList(&plist); 215 184 216 //gLog.SetNullOutput(kTRUE); 217 218 if (!evtloop.Eventloop()) return kFALSE; 219 220 //gLog.SetNullOutput(kFALSE); 185 gLog.SetNullOutput(kFALSE); 186 187 if (!evtloop.Eventloop()) 188 return kFALSE; 221 189 222 190 // save whole forest 223 191 MRanForest *forest=(MRanForest*)plist.FindObject("MRanForest"); 224 forest->SetTitle(Form("%f",0.5*(fEnergyGrid[ie]+fEnergyGrid[ie+1]))); 225 forest->Write(Form("%d",numbins)); 226 numbins++; 192 const TString title = Form("%f", TMath::Sqrt(grid[ie]*grid[ie+1])); 193 //const TString title = Form("%f", (grid[ie]+grid[ie+1])/2); 194 forest->SetTitle(title); 195 forest->Write(title); 227 196 } 228 197 229 198 // save rules 230 used _rules.Write("rules");199 usedrules.Write("rules"); 231 200 232 201 fileRF.Close(); … … 234 203 return kTRUE; 235 204 } 236 237 Int_t MRFEnergyEst::Test() 238 { 239 if(!fMatrixTest) 240 { 241 *fLog << err << dbginf << "fMatrixTest not found... aborting." << endl; 242 return kFALSE; 243 } 244 245 const Int_t ncols = (fMatrixTest->GetM()).GetNcols(); 246 const Int_t nrows = (fMatrixTest->GetM()).GetNrows(); 247 248 if(ncols<=0 || nrows <=0) 249 { 250 *fLog << err << dbginf << "No. of columns or no. of rows of fMatrixTrain equal 0 ... aborting." << endl; 251 return kFALSE; 252 } 253 254 TMatrix *mptr=(TMatrix*)&(fMatrixTest->GetM()); 255 256 if(!ReadForests()) 205 /* 206 Int_t MRFEnergyEst::Test(const MHMatrix &matrixtest) 207 { 208 gLog.Separator("MRFEnergyEst - Test"); 209 210 const Int_t ncols = matrixtest.GetM().GetNcols(); 211 const Int_t nrows = matrixtest.GetM().GetNrows(); 212 213 if (ncols<=0 || nrows <=0) 214 { 215 *fLog << err << dbginf << "No. of columns or no. of rows of matrixtrain equal 0 ... aborting." << endl; 216 return kFALSE; 217 } 218 219 if (!ReadForests()) 257 220 { 258 221 *fLog << err << dbginf << "Reading RFs failed... aborting." << endl; … … 262 225 const Int_t nbins=fEForests.GetSize(); 263 226 264 Double_t e _low = 100;265 Double_t e _up = 0;227 Double_t elow = FLT_MAX; 228 Double_t eup = -FLT_MAX; 266 229 267 230 for(Int_t j=0;j<nbins;j++) 268 231 { 269 e_low = TMath::Min(atof((fEForests[j])->GetTitle()),e_low); 270 e_up = TMath::Max(atof((fEForests[j])->GetTitle()),e_up); 271 } 272 273 TH1F hres("hres","",1000,-10,10); 274 TH2F henergy("henergy","",100,e_low,e_up,100,e_low,e_up); 275 232 elow = TMath::Min(atof(fEForests[j]->GetTitle()), elow); 233 eup = TMath::Max(atof(fEForests[j]->GetTitle()), eup); 234 } 235 236 TH1F hres("hres", "", 1000, -10, 10); 237 TH2F henergy("henergy", "",100, elow, eup,100, elow, eup); 238 239 const TMatrix &m=matrixtest.GetM(); 276 240 for(Int_t i=0;i<nrows;i++) 277 241 { 278 Double_t e_true = (*mptr)(i,ncols-1); 279 Double_t e_est = 0; 280 //Double_t hmax = 0; 242 Double_t etrue = m(i,ncols-1); 243 Double_t eest = 0; 281 244 Double_t hsum = 0; 282 245 283 246 for(Int_t j=0;j<nbins;j++) 284 247 { 285 const TVector v=TMatrixRow(*mptr,i); 286 Double_t h = ((MRanForest*) (fEForests[j]))->CalcHadroness(v); 287 Double_t e = atof((fEForests[j])->GetTitle()); 288 /*if(h>=hmax) 289 { 290 hmax=h; 291 e_est=pow(10.,e); 292 }*/ 293 hsum+=h; 294 e_est+=h*e; 248 const TVector v = TMatrixFRow_const(m,i); 249 250 const Double_t h = ((MRanForest*)fEForests[j])->CalcHadroness(v); 251 const Double_t e = atof(fEForests[j]->GetTitle()); 252 253 hsum += h; 254 eest += h*e; 295 255 } 296 e_est/=hsum; 297 e_est=pow(10.,e_est); 298 299 if(e_true>80.) hres.Fill((e_est-e_true)/e_true); 300 henergy.Fill(log10(e_true),log10(e_est)); 301 } 302 303 if(TestBit(kEnableGraphicalOutput)) 304 { 305 if(gStyle) gStyle->SetOptFit(1); 306 // show results 307 TCanvas *c=MH::MakeDefCanvas("c","",300,900); 308 309 c->Divide(1,3); 310 c->cd(1); 311 henergy.SetTitle("Estimated vs true energy"); 312 henergy.GetXaxis()->SetTitle("log10(E_{true}[GeV])"); 313 henergy.GetYaxis()->SetTitle("log10(E_{est}[GeV])"); 314 henergy.DrawCopy(); 315 316 c->cd(2); 317 318 TH1F *hptr=(TH1F*)henergy.ProfileX("_px",1,100,"S"); 319 hptr->SetTitle("Estimated vs true energy - profile"); 320 hptr->GetXaxis()->SetTitle("log10(E_{true}[GeV])"); 321 hptr->GetYaxis()->SetTitle("log10(E_{est}[GeV])"); 322 hptr->DrawCopy(); 323 324 c->cd(3); 325 hres.Fit("gaus"); 326 hres.SetTitle("Energy resolution for E_{true}>80Gev"); 327 hres.GetXaxis()->SetTitle("(E_{estimated}-E_{true})/E_{true})"); 328 hres.GetYaxis()->SetTitle("counts"); 329 hres.DrawCopy(); 330 331 332 c->GetPad(1)->SetGrid(); 333 c->GetPad(2)->SetGrid(); 334 c->GetPad(3)->SetGrid(); 335 336 } 337 338 return kTRUE; 339 } 340 256 eest /= hsum; 257 eest = pow(10., eest); 258 259 //if (etrue>80.) 260 // hres.Fill((eest-etrue)/etrue); 261 262 henergy.Fill(log10(etrue),log10(eest)); 263 } 264 265 if(gStyle) 266 gStyle->SetOptFit(1); 267 268 // show results 269 TCanvas *c=MH::MakeDefCanvas("c","",300,900); 270 271 c->Divide(1,3); 272 c->cd(1); 273 henergy.SetTitle("Estimated vs true energy"); 274 henergy.GetXaxis()->SetTitle("log10(E_{true}[GeV])"); 275 henergy.GetYaxis()->SetTitle("log10(E_{est}[GeV])"); 276 henergy.DrawCopy(); 277 278 c->cd(2); 279 TH1F *hptr=(TH1F*)henergy.ProfileX("_px",1,100,"S"); 280 hptr->SetTitle("Estimated vs true energy - profile"); 281 hptr->GetXaxis()->SetTitle("log10(E_{true}[GeV])"); 282 hptr->GetYaxis()->SetTitle("log10(E_{est}[GeV])"); 283 hptr->DrawCopy(); 284 285 c->cd(3); 286 hres.Fit("gaus"); 287 hres.SetTitle("Energy resolution for E_{true}>80Gev"); 288 hres.GetXaxis()->SetTitle("(E_{estimated}-E_{true})/E_{true})"); 289 hres.GetYaxis()->SetTitle("counts"); 290 hres.DrawCopy(); 291 292 c->GetPad(1)->SetGrid(); 293 c->GetPad(2)->SetGrid(); 294 c->GetPad(3)->SetGrid(); 295 296 return kTRUE; 297 } 298 */ 341 299 Int_t MRFEnergyEst::ReadForests(MParList *plist) 342 300 { 343 TFile fileRF(f RFfileName,"read");344 if (!fileRF.IsOpen())301 TFile fileRF(fFileName,"read"); 302 if (!fileRF.IsOpen()) 345 303 { 346 304 *fLog << err << dbginf << "File containing RFs could not be opened... aborting." << endl; … … 348 306 } 349 307 350 TList *list=(TList*)fileRF.GetListOfKeys(); 351 const Int_t n=list->GetSize()-1;// subtract 1 since 1 key belongs to MDataArray 352 353 fEForests.Expand(n); 354 355 MRanForest forest; 356 for(Int_t i=0;i<n;i++) 357 { 358 forest.Read(Form("%d",i)); 359 MRanForest *curforest=(MRanForest*)forest.Clone(); 360 const char *energy=list->FindObject(Form("%d",i))->GetTitle(); 361 const char *bin =list->FindObject(Form("%d",i))->GetName(); 362 363 curforest->SetTitle(energy); 364 curforest->SetName(bin); 365 366 fEForests[i]=curforest; 367 } 368 369 if(plist) 370 { 371 fData=(MDataArray*)plist->FindCreateObj("MDataArray"); 308 fEForests.Delete(); 309 310 TIter Next(fileRF.GetListOfKeys()); 311 TObject *o=0; 312 while ((o=Next())) 313 { 314 MRanForest *forest; 315 fileRF.GetObject(o->GetName(), forest); 316 if (!forest) 317 continue; 318 319 forest->SetTitle(o->GetTitle()); 320 forest->SetBit(kCanDelete); 321 322 fEForests.Add(forest); 323 324 } 325 326 if (plist) 327 { 328 fData = (MDataArray*)plist->FindCreateObj("MDataArray"); 372 329 fData->Read("rules"); 373 330 } 331 374 332 fileRF.Close(); 375 333 … … 381 339 fEnergyEst = (MParameterD*)plist->FindCreateObj("MParameterD", "MEnergyEst"); 382 340 if (!fEnergyEst) 383 {384 *fLog << err << dbginf << "MEnergyEst [MParameterD] not found... aborting." << endl; 385 return kFALSE;386 }387 388 if(!ReadForests(plist))389 {390 *fLog << err << dbginf << "Reading RFs failed... aborting." << endl; 391 return kFALSE;392 }341 return kFALSE; 342 343 if (!ReadForests(plist)) 344 { 345 *fLog << err << "Reading RFs failed... aborting." << endl; 346 return kFALSE; 347 } 348 349 if (fTestMatrix) 350 return kTRUE; 393 351 394 352 if (!fData) 395 353 { 396 *fLog << err << dbginf <<"MDataArray not found... aborting." << endl;354 *fLog << err << "MDataArray not found... aborting." << endl; 397 355 return kFALSE; 398 356 } … … 400 358 if (!fData->PreProcess(plist)) 401 359 { 402 *fLog << err << dbginf << "PreProcessing of the MDataArray failed for the columnsfailed... aborting." << endl;360 *fLog << err << "PreProcessing of the MDataArray failed... aborting." << endl; 403 361 return kFALSE; 404 362 } … … 413 371 { 414 372 TVector event; 415 *fData >> event; 373 if (fTestMatrix) 374 *fTestMatrix >> event; 375 else 376 *fData >> event; 416 377 417 378 Double_t eest = 0; 418 //Double_t hmax = 0; 419 Double_t hsum = 0; 420 421 for(Int_t j=0;j<fEForests.GetSize();j++) 422 { 423 Double_t h = ((MRanForest*) (fEForests[j]))->CalcHadroness(event); 424 Double_t e = atof((fEForests[j])->GetTitle()); 425 /*if(h>=hmax) 426 { 427 hmax=h; 428 e_est=pow(10.,e); 429 }*/ 430 hsum+=h; 431 eest+=h*e; 432 } 433 eest/=hsum; 434 eest=pow(10.,eest); 435 436 fEnergyEst->SetVal(eest); 379 Double_t hsum = 0; 380 381 TIter Next(&fEForests); 382 MRanForest *rf = 0; 383 while ((rf=(MRanForest*)Next())) 384 { 385 const Double_t h = rf->CalcHadroness(event); 386 const Double_t e = atof(rf->GetTitle()); 387 388 hsum += h; 389 eest += h*e; 390 } 391 392 fEnergyEst->SetVal(eest/hsum); 437 393 fEnergyEst->SetReadyToSave(); 438 394 -
trunk/MagicSoft/Mars/mranforest/MRFEnergyEst.h
r6932 r7130 6 6 #endif 7 7 8 #ifndef ROOT_TArrayD9 #include <TArrayD.h>10 #endif11 12 8 #ifndef ROOT_TObjArray 13 9 #include <TObjArray.h> 14 10 #endif 11 12 class TArrayD; 15 13 16 14 class MHMatrix; … … 21 19 { 22 20 private: 23 Int_t fNumTrees;24 Int_t fNumTry;25 Int_t fNdSize;21 Int_t fNumTrees; // Training parameters 22 Int_t fNumTry; // Training parameters 23 Int_t fNdSize; // Training parameters 26 24 27 TString fRFfileName; 28 MHMatrix *fMatrixTrain; 29 MHMatrix *fMatrixTest; 30 TArrayD fEnergyGrid; 25 TString fFileName; 26 TObjArray fEForests; 31 27 32 28 MDataArray *fData; //! Used to store the MDataChains to get the event values 33 TObjArray fEForests;29 MParameterD *fEnergyEst; //! Used to storeestimated energy 34 30 35 M ParameterD *fEnergyEst;31 MHMatrix *fTestMatrix; 36 32 37 33 Int_t PreProcess(MParList *plist); … … 42 38 public: 43 39 MRFEnergyEst(const char *name=NULL, const char *title=NULL); 44 ~MRFEnergyEst();45 40 46 void SetMatrixTrain(MHMatrix *mat) { fMatrixTrain = mat; } 47 void SetMatrixTest( MHMatrix *mat) { fMatrixTest = mat; } 48 void SetFile(TString str) { fRFfileName = str; } 41 void SetFileName(TString str) { fFileName = str; } 49 42 50 void SetLogEnergyGrid(TArrayD &egrid) { fEnergyGrid = egrid ; } 43 void SetNumTrees(UShort_t n=-1) { fNumTrees = n; } 44 void SetNdSize(UShort_t n=-1) { fNdSize = n; } 45 void SetNumTry(UShort_t n=-1) { fNumTry = n; } 51 46 52 void SetNumTrees(UShort_t n=100) { fNumTrees = n; } 53 void SetNdSize(UShort_t n=1) { fNdSize = n; } 54 void SetNumTry(UShort_t n) { fNumTry = n; } 47 void SetTestMatrix(MHMatrix *m=0) { fTestMatrix=m; } 48 void InitMapping(MHMatrix *m=0) { fTestMatrix=m; } 55 49 56 Int_t Train(); 57 Int_t Test(); 50 Int_t Train(const MHMatrix &n, const TArrayD &grid); 58 51 59 52 ClassDef(MRFEnergyEst, 0) // Task -
trunk/MagicSoft/Mars/mranforest/MRanForestGrow.cc
r2207 r7130 46 46 using namespace std; 47 47 48 static const TString gsDefName = "MR anForestGrow";48 static const TString gsDefName = "MRead"; 49 49 static const TString gsDefTitle = "Tree Classification Loop 1/2"; 50 50 … … 55 55 // 56 56 MRanForestGrow::MRanForestGrow(const char *name, const char *title) 57 : fNumTrees(100),fNumTry(3),fNdSize(1)58 57 { 59 58 // … … 62 61 fName = name ? name : gsDefName.Data(); 63 62 fTitle = title ? title : gsDefTitle.Data(); 63 64 SetNumTrees(); 65 SetNumTry(); 66 SetNdSize(); 64 67 } 65 68 … … 124 127 Int_t MRanForestGrow::Process() 125 128 { 126 Bool_t not_last=fRanForest->GrowForest(); 129 const Bool_t not_last=fRanForest->GrowForest(); 130 127 131 fRanTree->SetReadyToSave(); 128 132 -
trunk/MagicSoft/Mars/mranforest/MRanForestGrow.h
r2207 r7130 2 2 #define MARS_MRanForestGrow 3 3 4 ///////////////////////////////////////////////////////////////////////////// 5 // // 6 // MRanForestGrow // 7 // // 8 // Task to grow (train) a random forest // 9 // // 10 ///////////////////////////////////////////////////////////////////////////// 11 12 #ifndef MARS_MTask 13 #include "MTask.h" 4 #ifndef MARS_MRead 5 #include "MRead.h" 14 6 #endif 15 7 … … 19 11 class MRanTree; 20 12 21 class MRanForestGrow : public M Task13 class MRanForestGrow : public MRead 22 14 { 23 15 private: … … 35 27 Int_t PostProcess(); 36 28 29 UInt_t GetEntries() { return fNumTrees; } 30 TString GetFileName() const { return "MRanForestGrow"; } 31 TString GetFullFileName() const { return "MRanForestGrow"; } 32 37 33 public: 38 34 MRanForestGrow(const char *name=NULL, const char *title=NULL); 39 35 40 void SetNumTrees(Int_t n ){ fNumTrees=n;}41 void SetNumTry(Int_t n) { fNumTry=n;}42 void SetNdSize(Int_t n) { fNdSize=n;}36 void SetNumTrees(Int_t n=-1) { fNumTrees=n>0?n:100; } 37 void SetNumTry(Int_t n=-1) { fNumTry =n>0?n: 3; } 38 void SetNdSize(Int_t n=-1) { fNdSize =n>0?n: 1; } 43 39 44 40 ClassDef(MRanForestGrow, 0) // Task to grow a random forest
Note:
See TracChangeset
for help on using the changeset viewer.