exampleFunctor.C: Tutorial illustrating how creating a TF1 class using functor or class member functions | Math tutorials | goftest.C: GoFTest tutorial macro |
// Example of using the TKDE class (kernel density estimator) // Author: Lorenzo Moneta, Bartolomeu Rabacal (Dec 2010) #include "TH1.h" #include "TF1.h" #include "TKDE.h" #include "TCanvas.h" //#include "TStopwatch.h" #include "TRandom.h" #ifndef __CINT__ #include "Math/DistFunc.h" #endif #include "TLegend.h" // test TKDE void exampleTKDE(int n = 1000) { // generate some gaussian points int nbin = 100; double xmin = 0; double xmax = 10; TH1D * h1 = new TH1D("h1","h1",nbin,xmin,xmax); // generate some points with bi- gaussian distribution std::vector<double> data(n); for (int i = 0; i < n; ++i) { if (i < 0.4*n) { data[i] = gRandom->Gaus(2,1); h1->Fill(data[i]); } else { data[i] = gRandom->Gaus(7,1.5); h1->Fill(data[i]); } } // scale histogram h1->Scale(1./h1->Integral(),"width" ); h1->SetStats(false); h1->SetTitle("Bi-Gaussian"); h1->Draw(); // drawn true normalized density TF1 * f1 = new TF1("f1","0.4*ROOT::Math::normal_pdf(x,1,2)+0.6*ROOT::Math::normal_pdf(x,1.5,7)",xmin,xmax); f1->SetLineColor(kGreen+2); f1->Draw("SAME"); /////////////////////////////////////////////////////////////////////////// // create TKDE class double rho = 1.0; //default value TKDE * kde = new TKDE(n, &data[0], xmin,xmax, "", rho); //kde->Draw("ConfidenceInterval@0.95 Same"); kde->Draw("SAME"); // KDE options // int nbinKDE = 0; // TKDE::EBinning bin; // TKDE::EIteration iter; // TKDE::EMirror mirror; // if (nbinKDE> 0) kde->SetNBins(nbinKDE); // if (iter != TKDE::kAdaptive) kde->SetIteration(iter); // if (mirror != TKDE::kNoMirror) kde->SetMirror(mirror); //alternative way instead of using kde->Draw() // TF1 * const hk = kde->GetFunction(1000); // hk->SetLineColor(kBlue); // hk->Draw("same"); // TF1 * fl = kde->GetLowerFunction(0.684); // TF1 * fu = kde->GetUpperFunction(0.684); // fl->Draw("SAME"); // fl->SetLineColor(kBlue-5); // fu->SetLineColor(kBlue-5); // fu->Draw("SAME"); TLegend * legend = new TLegend(0.6,0.7,0.9,0.95); legend->AddEntry(f1,"True function"); legend->AddEntry(kde->GetDrawnFunction(),"TKDE"); legend->AddEntry(kde->GetDrawnLowerFunction(),"TKDE - #sigma"); legend->AddEntry(kde->GetDrawnUpperFunction(),"TKDE + #sigma"); legend->Draw(); return; gPad->Update(); } exampleTKDE.C:1 exampleTKDE.C:2 exampleTKDE.C:3 exampleTKDE.C:4 exampleTKDE.C:5 exampleTKDE.C:6 exampleTKDE.C:7 exampleTKDE.C:8 exampleTKDE.C:9 exampleTKDE.C:10 exampleTKDE.C:11 exampleTKDE.C:12 exampleTKDE.C:13 exampleTKDE.C:14 exampleTKDE.C:15 exampleTKDE.C:16 exampleTKDE.C:17 exampleTKDE.C:18 exampleTKDE.C:19 exampleTKDE.C:20 exampleTKDE.C:21 exampleTKDE.C:22 exampleTKDE.C:23 exampleTKDE.C:24 exampleTKDE.C:25 exampleTKDE.C:26 exampleTKDE.C:27 exampleTKDE.C:28 exampleTKDE.C:29 exampleTKDE.C:30 exampleTKDE.C:31 exampleTKDE.C:32 exampleTKDE.C:33 exampleTKDE.C:34 exampleTKDE.C:35 exampleTKDE.C:36 exampleTKDE.C:37 exampleTKDE.C:38 exampleTKDE.C:39 exampleTKDE.C:40 exampleTKDE.C:41 exampleTKDE.C:42 exampleTKDE.C:43 exampleTKDE.C:44 exampleTKDE.C:45 exampleTKDE.C:46 exampleTKDE.C:47 exampleTKDE.C:48 exampleTKDE.C:49 exampleTKDE.C:50 exampleTKDE.C:51 exampleTKDE.C:52 exampleTKDE.C:53 exampleTKDE.C:54 exampleTKDE.C:55 exampleTKDE.C:56 exampleTKDE.C:57 exampleTKDE.C:58 exampleTKDE.C:59 exampleTKDE.C:60 exampleTKDE.C:61 exampleTKDE.C:62 exampleTKDE.C:63 exampleTKDE.C:64 exampleTKDE.C:65 exampleTKDE.C:66 exampleTKDE.C:67 exampleTKDE.C:68 exampleTKDE.C:69 exampleTKDE.C:70 exampleTKDE.C:71 exampleTKDE.C:72 exampleTKDE.C:73 exampleTKDE.C:74 exampleTKDE.C:75 exampleTKDE.C:76 exampleTKDE.C:77 exampleTKDE.C:78 exampleTKDE.C:79 exampleTKDE.C:80 exampleTKDE.C:81 exampleTKDE.C:82 exampleTKDE.C:83 exampleTKDE.C:84 exampleTKDE.C:85 exampleTKDE.C:86 exampleTKDE.C:87 exampleTKDE.C:88 exampleTKDE.C:89 exampleTKDE.C:90 exampleTKDE.C:91 exampleTKDE.C:92 exampleTKDE.C:93 exampleTKDE.C:94 exampleTKDE.C:95 exampleTKDE.C:96 exampleTKDE.C:97 exampleTKDE.C:98 exampleTKDE.C:99 exampleTKDE.C:100 exampleTKDE.C:101 |
|