function[ml] = ml_vol(Data,p,o,q,GarchType)
[tab_ml,~]  = fit_garch_ml(Data.train,p,o,q,GarchType);
ml.tab_ml   = tab_ml(:,{'par_mfe','tpar_mfe'});
ml.par      = ml.tab_ml.par_mfe;
ml.tpar     = ml.tab_ml.tpar_mfe;

[ml.train.nll,ml.train.ht] = vol_nll(Data.train,ml.tpar,p,o,q,GarchType);
[ml.test.nll,ml.test.ht] = vol_nll(Data.test,ml.tpar,p,o,q,GarchType);

ml.train.LB                 = nan;
ml.test.LB                  = nan;
ml.train.mse                = mean((Data.train.^2-ml.train.ht).^2);
ml.test.mse                 = mean((Data.test.^2-ml.test.ht).^2);
ml.perf = [ml.train.LB,ml.train.nll,ml.train.mse, ml.test.LB,ml.test.nll,ml.test.mse];
end
