Ignore:
Timestamp:
06/10/05 13:10:09 (20 years ago)
Author:
tbretz
Message:
*** empty log message ***
Location:
trunk/MagicSoft/Mars/mranforest
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • trunk/MagicSoft/Mars/mranforest/MRFEnergyEst.cc

    r7130 r7142  
    6969//
    7070MRFEnergyEst::MRFEnergyEst(const char *name, const char *title)
    71     : fNumTrees(-1), fNumTry(-1), fNdSize(-1), fData(0), fEnergyEst(0),
    72     fTestMatrix(0)
     71    : fNumTrees(-1), fNumTry(-1), fNdSize(-1), fDebug(kFALSE),
     72    fData(0), fEnergyEst(0), fTestMatrix(0)
    7373{
    7474    fName  = name  ? name  : gsDefName.Data();
     
    9191    }
    9292
    93     const Int_t ncols = matrixtrain.GetM().GetNcols();
    94     const Int_t nrows = matrixtrain.GetM().GetNrows();
     93    const TMatrix &m = matrixtrain.GetM();
     94
     95    const Int_t ncols = m.GetNcols();
     96    const Int_t nrows = m.GetNrows();
    9597    if (ncols<=0 || nrows <=0)
    9698    {
     
    114116    }
    115117
     118    const Int_t nobs = 3; // Number of obsolete columns
     119
    116120    MDataArray usedrules;
    117     for(Int_t i=0; i<ncols-3; i++) // -3 is important!!!
     121    for(Int_t i=0; i<ncols-nobs; i++) // -3 is important!!!
    118122        usedrules.AddEntry((*matrixtrain.GetColumns())[i].GetRule());
    119 
    120     const TMatrix &m = matrixtrain.GetM();
    121123
    122124    // training of RF for each energy bin
     
    140142        }
    141143
    142         const Bool_t valid = irow1*irow0>0;
    143 
    144         if (!valid)
     144        const Bool_t invalid = irow1==0 || irow0==0;
     145
     146        if (invalid)
    145147            *fLog << warn << "WARNING - Skipping";
    146148        else
    147149            *fLog << inf << "Training RF for";
    148150
    149         *fLog << " energy bin " << ie << " (" << grid[ie] << ", " << grid[ie+1] << ")" << endl;
    150 
    151         if (!valid)
     151        *fLog << " energy bin " << ie << " (" << grid[ie] << ", " << grid[ie+1] << ") " << irow0 << " " << irow1 << endl;
     152
     153        if (invalid)
    152154            continue;
    153155
    154         gLog.SetNullOutput(kTRUE);
     156        if (fDebug)
     157            gLog.SetNullOutput(kTRUE);
    155158
    156159        // last column must be removed (true energy col.)
    157         mat1.ResizeTo(irow1, ncols-1);
    158         mat0.ResizeTo(irow0, ncols-1);
     160        mat1.ResizeTo(irow1, ncols-nobs);
     161        mat0.ResizeTo(irow0, ncols-nobs);
    159162
    160163        // create MHMatrix as input for RF
     
    183186        evtloop.SetParList(&plist);
    184187
    185         gLog.SetNullOutput(kFALSE);
     188        if (fDebug)
     189            gLog.SetNullOutput(kFALSE);
    186190
    187191        if (!evtloop.Eventloop())
    188192            return kFALSE;
    189193
     194        const Double_t E = (log10(grid[ie])+log10(grid[ie+1]))/2;
     195
    190196        // save whole forest
    191197        MRanForest *forest=(MRanForest*)plist.FindObject("MRanForest");
    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);
     198        const TString title = Form("%.10f", E);
    194199        forest->SetTitle(title);
    195200        forest->Write(title);
     
    203208    return kTRUE;
    204209}
    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())
    220     {
    221         *fLog << err << dbginf << "Reading RFs failed... aborting." << endl;
    222         return kFALSE;
    223     }
    224 
    225     const Int_t nbins=fEForests.GetSize();
    226 
    227     Double_t elow =  FLT_MAX;
    228     Double_t eup  = -FLT_MAX;
    229 
    230     for(Int_t j=0;j<nbins;j++)
    231     {
    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();
    240     for(Int_t i=0;i<nrows;i++)
    241     {
    242         Double_t etrue = m(i,ncols-1);
    243         Double_t eest  = 0;
    244         Double_t hsum  = 0;
    245 
    246         for(Int_t j=0;j<nbins;j++)
    247         {
    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;
    255         }
    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 */
    299 Int_t MRFEnergyEst::ReadForests(MParList *plist)
     210
     211Int_t MRFEnergyEst::ReadForests(MParList &plist)
    300212{
    301213    TFile fileRF(fFileName,"read");
     
    321233
    322234        fEForests.Add(forest);
    323 
    324     }
    325 
    326     if (plist)
    327     {
    328         fData = (MDataArray*)plist->FindCreateObj("MDataArray");
    329         fData->Read("rules");
    330     }
    331 
    332     fileRF.Close();
     235    }
     236
     237    if (fData->Read("rules")<=0)
     238    {
     239        *fLog << err << "ERROR - Reading 'rules' from file " << fFileName << endl;
     240        return kFALSE;
     241    }
    333242
    334243    return kTRUE;
     
    341250        return kFALSE;
    342251
    343     if (!ReadForests(plist))
     252    fData = (MDataArray*)plist->FindCreateObj("MDataArray");
     253    if (!fData)
     254        return kFALSE;
     255
     256    if (!ReadForests(*plist))
    344257    {
    345258        *fLog << err << "Reading RFs failed... aborting." << endl;
    346259        return kFALSE;
    347260    }
     261
     262    *fLog << inf << "RF read from " << fFileName << endl;
    348263
    349264    if (fTestMatrix)
    350265        return kTRUE;
    351266
    352     if (!fData)
    353     {
    354         *fLog << err << "MDataArray not found... aborting." << endl;
    355         return kFALSE;
    356     }
     267    fData->Print();
    357268
    358269    if (!fData->PreProcess(plist))
     
    387298
    388299        hsum += h;
    389         eest += h*e;
    390     }
    391 
    392     fEnergyEst->SetVal(eest/hsum);
     300        eest += e*h;
     301    }
     302
     303    fEnergyEst->SetVal(pow(10, eest/hsum));
    393304    fEnergyEst->SetReadyToSave();
    394305
    395306    return kTRUE;
    396307}
     308
     309// --------------------------------------------------------------------------
     310//
     311//
     312Int_t MRFEnergyEst::ReadEnv(const TEnv &env, TString prefix, Bool_t print)
     313{
     314    Bool_t rc = kFALSE;
     315    if (IsEnvDefined(env, prefix, "FileName", print))
     316    {
     317        rc = kTRUE;
     318        SetFileName(GetEnvValue(env, prefix, "FileName", fFileName));
     319    }
     320    if (IsEnvDefined(env, prefix, "Debug", print))
     321    {
     322        rc = kTRUE;
     323        SetDebug(GetEnvValue(env, prefix, "Debug", fDebug));
     324    }
     325    return rc;
     326}
  • trunk/MagicSoft/Mars/mranforest/MRFEnergyEst.h

    r7134 r7142  
    2323    Int_t        fNdSize;    // Training parameters
    2424
     25    Bool_t       fDebug;     // Debugging of eventloop while training on/off
     26
    2527    TString      fFileName;
    2628    TObjArray    fEForests;
     
    3436    Int_t Process();
    3537
    36     Int_t ReadForests(MParList *plist=NULL);
     38    Int_t ReadForests(MParList &plist);
     39
     40    Int_t ReadEnv(const TEnv &env, TString prefix, Bool_t print);
    3741
    3842public:
     
    4145    void  SetFileName(TString str)     { fFileName = str; }
    4246
    43     void  SetNumTrees(Int_t n=-1)   { fNumTrees = n; }
    44     void  SetNdSize(Int_t n=-1)     { fNdSize   = n; }
    45     void  SetNumTry(Int_t n=-1)     { fNumTry   = n; }
     47    void  SetNumTrees(Int_t n=-1)      { fNumTrees = n; }
     48    void  SetNdSize(Int_t n=-1)        { fNdSize   = n; }
     49    void  SetNumTry(Int_t n=-1)        { fNumTry   = n; }
    4650
    4751    void  SetTestMatrix(MHMatrix *m=0) { fTestMatrix=m; }
    4852    void  InitMapping(MHMatrix *m=0)   { fTestMatrix=m; }
     53
     54    void SetDebug(Bool_t b=kTRUE)      { fDebug = b; }
    4955
    5056    Int_t Train(const MHMatrix &n, const TArrayD &grid);
  • trunk/MagicSoft/Mars/mranforest/MRanTree.cc

    r4647 r7142  
    447447    // are coded into fBestVar:
    448448    // status of node kt = TMath::Sign(1,fBestVar[kt])
    449     // class  of node kt = fBestVar[kt]+2 (class defined by larger
    450     //  node population, actually not used)
     449    // class  of node kt = fBestVar[kt]+2
     450    //  (class defined by larger node population, actually not used)
    451451    // hadronness assigned to node kt = fBestSplit[kt]
    452452
     
    463463}
    464464
    465 Double_t MRanTree::TreeHad(const TMatrixRow &event)
     465Double_t MRanTree::TreeHad(const TMatrixFRow_const &event)
    466466{
    467467    Int_t kt=0;
     
    504504Bool_t MRanTree::AsciiWrite(ostream &out) const
    505505{
    506     TString str;
     506    out.width(5);
     507    out << fNumNodes << endl;
     508
    507509    Int_t k;
    508 
    509     out.width(5);out<<fNumNodes<<endl;
    510 
    511     for (k=0;k<fNumNodes;k++)
    512     {
    513         str=Form("%f",GetBestSplit(k));
     510    for (k=0; k<fNumNodes; k++)
     511    {
     512        TString str=Form("%f", GetBestSplit(k));
    514513
    515514        out.width(5);  out << k;
     
    521520        out.width(5);  out << GetNodeClass(k);
    522521    }
    523     out<<endl;
    524 
    525     return k==fNumNodes;
    526 }
     522    out << endl;
     523
     524    return kTRUE;
     525}
  • trunk/MagicSoft/Mars/mranforest/MRanTree.h

    r2307 r7142  
    1616class TMatrix;
    1717class TMatrixRow;
     18class TMatrixFRow_const;
    1819class TVector;
    1920class TRandom;
     
    8485
    8586    Double_t TreeHad(const TVector &event);
    86     Double_t TreeHad(const TMatrixRow &event);
     87    Double_t TreeHad(const TMatrixFRow_const &event);
    8788    Double_t TreeHad(const TMatrix &m, Int_t ievt);
    8889    Double_t TreeHad();
Note: See TracChangeset for help on using the changeset viewer.