void splines (Int_t np=23, Double_t a=-0.5, Double_t b=31) { // examples of use of the spline classes //Author: Federico Carminati // array of points Double_t *xx=0, *yy=0; TSpline3 *spline3=0; TSpline5 *spline5=0; TLine *line5, *line3; TText *text5, *text3, *textn; char text[20]; const Double_t power=0.75; // Define the original function TF1 *f=new TF1("f","sin(x)*sin(x/10)", a-0.05*(b-a),b+0.05*(b-a)); // Draw function f->Draw("lc"); // Create text and legend Float_t xx1, yy1, xx2, yy2, dx, dy; gPad->Update(); gPad->GetRangeAxis(xx1,yy1,xx2,yy2); dx = xx2-xx1; dy = yy2-yy1; line5=new TLine(xx1+dx*0.3,yy1+dy*1.02, xx1+dx*0.38,yy1+dy*1.02); line5->SetLineColor(kRed); line5->SetLineWidth(2); text5 = new TText(xx1+dx*0.4, yy1+dy*1.03,"quintic spline"); text5->SetTextAlign(12); text5->SetTextSize(0.04); line3=new TLine(xx1+dx*0.67,yy1+dy*1.02, xx1+dx*0.75,yy1+dy*1.02); line3->SetLineColor(kGreen); line3->SetLineWidth(2); text3 = new TText(xx1+dx*0.77, yy1+dy*1.03,"third spline"); text3->SetTextAlign(12); text3->SetTextSize(0.04); textn = new TText(xx1+dx*0.8,yy1+dy*0.91," "); textn->SetTextAlign(12); textn->SetTextSize(0.04); textn->Draw(); // Draw legenda line5->Draw(); text5->Draw(); line3->Draw(); text3->Draw(); for(Int_t nnp=2; nnp<=np; ++nnp) { // Calculate the knots if(xx) delete xx; xx = new Double_t[nnp]; if(yy) delete yy; yy = new Double_t[nnp]; for (Int_t i=0; i<nnp; ++i) { xx[i]=a+(b-a)*TMath::Power(i/Double_t (nnp-1),power); yy[i]=f->Eval(xx[i]); } // Evaluate fifth spline coefficients Double_t eps=(b-a)*1.e-5; if(spline5) delete spline5; spline5 = new TSpline5("Test",xx,f,nnp,"b1e1b2e2", f->Derivative(a),f->Derivative(b), (f->Derivative(a+eps)-f->Derivative(a))/eps, (f->Derivative(b)-f->Derivative(b-eps))/eps); spline5->SetLineColor(kRed); spline5->SetLineWidth(3); // Draw the quintic spline spline5->Draw("lcsame"); // Evaluate third spline coefficients if(spline3) delete spline3; spline3 = new TSpline3("Test",xx,yy,nnp,"b1e1", f->Derivative(a),f->Derivative(b)); spline3->SetLineColor(kGreen); spline3->SetLineWidth(3); spline3->SetMarkerColor(kBlue); spline3->SetMarkerStyle(20); spline3->SetMarkerSize(1.5); // Draw the third spline spline3->Draw("lcpsame"); sprintf(text,"%3d knots",nnp); textn->SetTitle(text); gPad->Update(); // gSystem->Sleep(500); } } splines.C:1 splines.C:2 splines.C:3 splines.C:4 splines.C:5 splines.C:6 splines.C:7 splines.C:8 splines.C:9 splines.C:10 splines.C:11 splines.C:12 splines.C:13 splines.C:14 splines.C:15 splines.C:16 splines.C:17 splines.C:18 splines.C:19 splines.C:20 splines.C:21 splines.C:22 splines.C:23 splines.C:24 splines.C:25 splines.C:26 splines.C:27 splines.C:28 splines.C:29 splines.C:30 splines.C:31 splines.C:32 splines.C:33 splines.C:34 splines.C:35 splines.C:36 splines.C:37 splines.C:38 splines.C:39 splines.C:40 splines.C:41 splines.C:42 splines.C:43 splines.C:44 splines.C:45 splines.C:46 splines.C:47 splines.C:48 splines.C:49 splines.C:50 splines.C:51 splines.C:52 splines.C:53 splines.C:54 splines.C:55 splines.C:56 splines.C:57 splines.C:58 splines.C:59 splines.C:60 splines.C:61 splines.C:62 splines.C:63 splines.C:64 splines.C:65 splines.C:66 splines.C:67 splines.C:68 splines.C:69 splines.C:70 splines.C:71 splines.C:72 splines.C:73 splines.C:74 splines.C:75 splines.C:76 splines.C:77 splines.C:78 splines.C:79 splines.C:80 splines.C:81 splines.C:82 splines.C:83 splines.C:84 splines.C:85 splines.C:86 splines.C:87 splines.C:88 splines.C:89 splines.C:90 splines.C:91 splines.C:92 splines.C:93 splines.C:94 splines.C:95 splines.C:96 splines.C:97 splines.C:98 splines.C:99 splines.C:100 splines.C:101 splines.C:102 |
|