#ifndef BDT_Reg__HH
#define BDT_Reg__HH
#include <iostream>
#include <iomanip>
#include <fstream>
#include "TMVA/tmvaglob.h"
#include "RQ_OBJECT.h"
#include "TROOT.h"
#include "TStyle.h"
#include "TPad.h"
#include "TCanvas.h"
#include "TLine.h"
#include "TFile.h"
#include "TColor.h"
#include "TPaveText.h"
#include "TObjString.h"
#include "TControlBar.h"
#include "TGWindow.h"
#include "TGButton.h"
#include "TGLabel.h"
#include "TGNumberEntry.h"
#include "TMVA/DecisionTree.h"
#include "TMVA/Tools.h"
#include "TXMLEngine.h"
#include "TMVA/BDT.h"
namespace TMVA{
class StatDialogBDTReg {
RQ_OBJECT("StatDialogBDTReg")
public:
StatDialogBDTReg( const TGWindow* p, TString wfile = "weights/TMVARegression_BDT.weights.xml",
TString methName = "BDT", Int_t itree = 0 );
virtual ~StatDialogBDTReg() {
TMVA::DecisionTreeNode::fgIsTraining=false;
fThis = 0;
fMain->CloseWindow();
fMain->Cleanup();
if(gROOT->GetListOfCanvases()->FindObject(fCanvas))
delete fCanvas;
}
void DrawTree( Int_t itree );
void RaiseDialog() { if (fMain) { fMain->RaiseWindow(); fMain->Layout(); fMain->MapWindow(); } }
private:
TGMainFrame *fMain;
Int_t fItree;
Int_t fNtrees;
TCanvas* fCanvas;
TGNumberEntry* fInput;
TGHorizontalFrame* fButtons;
TGTextButton* fDrawButton;
TGTextButton* fCloseButton;
void UpdateCanvases();
TMVA::DecisionTree* ReadTree( TString * &vars, Int_t itree );
void DrawNode( TMVA::DecisionTreeNode *n,
Double_t x, Double_t y, Double_t xscale, Double_t yscale, TString* vars );
void GetNtrees();
TString fWfile;
TString fMethName;
public:
static void Delete() { if (fThis != 0) { delete fThis; fThis = 0; } }
void SetItree();
void Redraw();
void Close();
private:
static StatDialogBDTReg* fThis;
};
static std::vector<TControlBar*> BDTReg_Global__cbar;
void BDT_Reg( const TString& fin = "TMVAReg.root" );
void BDTReg_DeleteTBar(int i);
void BDT_Reg( Int_t itree, TString wfile = "weights/TMVARegression_BDT.weights.xml", TString methName = "BDT", Bool_t useTMVAStyle = kTRUE );
}
#endif