34void TMVA_Higgs_Classification() {
61 "!V:ROC:!Silent:Color:AnalysisType=Classification" );
83 Info(
"TMVA_Higgs_Classification",
"Download Higgs_data.root file");
87 Error(
"TMVA_Higgs_Classification",
"Input file cannot be downloaded - exit");
111 loader->AddVariable(
"m_jj");
112 loader->AddVariable(
"m_jjj");
113 loader->AddVariable(
"m_lv");
114 loader->AddVariable(
"m_jlv");
115 loader->AddVariable(
"m_bb");
116 loader->AddVariable(
"m_wbb");
117 loader->AddVariable(
"m_wwbb");
147 "nTrain_Signal=7000:nTrain_Background=7000:SplitMode=Random:NormMode=NumEvents:!V" );
161 "H:!V:TransformOutput:PDFInterpol=Spline2:NSmoothSig[0]=20:NSmoothBkg[0]=20:NSmoothBkg[1]=10:NSmooth=1:NAvEvtPerBin=50" );
166 "!H:!V:!TransformOutput:PDFInterpol=KDE:KDEtype=Gauss:KDEiter=Adaptive:KDEFineFactor=0.3:KDEborder=None:NAvEvtPerBin=50" );
172 factory.BookMethod(
loader,
TMVA::Types::kFisher,
"Fisher",
"H:!V:Fisher:VarTransform=None:CreateMVAPdfs:PDFInterpolMVAPdf=Spline2:NbinsMVAPdf=50:NsmoothMVAPdf=10" );
178 "!V:NTrees=200:MinNodeSize=2.5%:MaxDepth=2:BoostType=AdaBoost:AdaBoostBeta=0.5:UseBaggedBoost:BaggedSampleFraction=0.5:SeparationType=GiniIndex:nCuts=20" );
184 "!H:!V:NeuronType=tanh:VarTransform=N:NCycles=100:HiddenLayers=N+5:TestRate=5:!UseRegulator" );
262 TString layoutString (
"Layout=DENSE|64|TANH,DENSE|64|TANH,DENSE|64|TANH,DENSE|64|TANH,DENSE|1|LINEAR");
266 "ConvergenceSteps=10,BatchSize=128,TestRepetitions=1,"
267 "MaxEpochs=30,WeightDecay=1e-4,Regularization=None,"
268 "Optimizer=ADAM,ADAM_beta1=0.9,ADAM_beta2=0.999,ADAM_eps=1.E-7,"
269 "DropConfig=0.0+0.0+0.0+0.");
281 "WeightInitialization=XAVIER");
301 Info(
"TMVA_Higgs_Classification",
"Building deep neural network with keras ");
305 m.AddLine(
"import tensorflow");
306 m.AddLine(
"from tensorflow.keras.models import Sequential");
307 m.AddLine(
"from tensorflow.keras.optimizers import Adam");
308 m.AddLine(
"from tensorflow.keras.layers import Input, Dense");
310 m.AddLine(
"model = Sequential() ");
311 m.AddLine(
"model.add(Dense(64, activation='relu',input_dim=7))");
312 m.AddLine(
"model.add(Dense(64, activation='relu'))");
313 m.AddLine(
"model.add(Dense(64, activation='relu'))");
314 m.AddLine(
"model.add(Dense(64, activation='relu'))");
315 m.AddLine(
"model.add(Dense(2, activation='sigmoid'))");
316 m.AddLine(
"model.compile(loss = 'binary_crossentropy', optimizer = Adam(learning_rate = 0.001), weighted_metrics = ['accuracy'])");
317 m.AddLine(
"model.save('Higgs_model.h5')");
318 m.AddLine(
"model.summary()");
320 m.SaveSource(
"make_higgs_model.py");
327 Warning(
"TMVA_Higgs_Classification",
"Error creating Keras model file - skip using Keras");
330 Info(
"TMVA_Higgs_Classification",
"Booking tf.Keras Dense model");
333 "H:!V:VarTransform=None:FilenameModel=Higgs_model.h5:tf.keras:"
334 "FilenameTrainedModel=Higgs_trained_model.h5:NumEpochs=20:BatchSize=100:"
335 "GpuOptions=allow_growth=True");
346 factory.TrainAllMethods();
354 factory.TestAllMethods();
356 factory.EvaluateAllMethods();
360 auto c1 = factory.GetROCCurve(
loader);
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
void Error(const char *location, const char *msgfmt,...)
Use this function in case an error occurred.
void Warning(const char *location, const char *msgfmt,...)
Use this function in warning situations.
R__EXTERN TSystem * gSystem
A specialized string object used for TTree selections.
A ROOT file is an on-disk file, usually with extension .root, that stores objects in a file-system-li...
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=ROOT::RCompressionSetting::EDefaults::kUseCompiledDefault, Int_t netopt=0)
Create / open a file.
static Bool_t SetCacheFileDir(std::string_view cacheDir, Bool_t operateDisconnected=kTRUE, Bool_t forceCacheread=kFALSE)
Sets the directory where to locally stage/cache remote files.
This is the main MVA steering class.
static void PyInitialize()
Initialize Python interpreter.
Class supporting a collection of lines with C++ code.
virtual Int_t Exec(const char *shellcmd)
Execute a command.
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)
Returns FALSE if one can access a file using the specified access mode.
virtual void Setenv(const char *name, const char *value)
Set environment variable.
A TTree represents a columnar dataset.