135 pmin =
gPad->PadtoX(
gPad->GetUxmin());
136 pmax =
gPad->PadtoX(
gPad->GetUxmax());
140 if (
xmax < pmin)
return;
141 if (
xmin > pmax)
return;
165 for (i=0;i<=
fNpx;i++) {
166 xbins[i] =
gPad->PadtoX(xlogmin+ i*dlogx);
177 for (i=1;i<=
fNpx;i++) {
195 char *o = (
char *) opt.
Data();
227void TSpline::Streamer(
TBuffer &R__b)
237 TNamed::Streamer(R__b);
238 TAttLine::Streamer(R__b);
239 TAttFill::Streamer(R__b);
240 TAttMarker::Streamer(R__b);
358 fValBeg(valbeg), fValEnd(valend), fBegCond(0), fEndCond(0)
368 for (
Int_t i=0; i<
n; ++i) {
387 fValBeg(valbeg), fValEnd(valend),
388 fBegCond(0), fEndCond(0)
398 for (
Int_t i=0; i<
n; ++i) {
416 fValBeg(valbeg), fValEnd(valend),
417 fBegCond(0), fEndCond(0)
427 for (
Int_t i=0; i<
n; ++i) {
443 const TF1 *func,
Int_t n,
const char *opt,
446 fValBeg(valbeg), fValEnd(valend),
447 fBegCond(0), fEndCond(0)
460 for (
Int_t i=0; i<
n; ++i) {
476 const TGraph *
g,
const char *opt,
479 fValBeg(valbeg), fValEnd(valend),
480 fBegCond(0), fEndCond(0)
492 g->GetPoint(i,xx,yy);
509 fValBeg(valbeg), fValEnd(valend),
510 fBegCond(0), fEndCond(0)
521 fPoly[i].
X()=
h->GetXaxis()->GetBinCenter(i+1);
522 fPoly[i].
Y()=
h->GetBinContent(i+1);
537 fValBeg(sp3.fValBeg),
538 fValEnd(sp3.fValEnd),
539 fBegCond(sp3.fBegCond),
540 fEndCond(sp3.fEndCond)
572 const char *b1 = strstr(opt,
"b1");
573 const char *e1 = strstr(opt,
"e1");
574 const char *b2 = strstr(opt,
"b2");
575 const char *e2 = strstr(opt,
"e2");
577 Error(
"SetCond",
"Cannot specify first and second derivative at first point");
579 Error(
"SetCond",
"Cannot specify first and second derivative at last point");
619 printf(
"1 TEST OF TSpline3 WITH NONEQUIDISTANT KNOTS\n");
634 printf(
"\n-N = %3d M =%2d\n",
n,
m);
636 for (i = 0; i <
n; ++i)
637 spline->
GetCoeff(i,hx,
a[i],
a[i+200],
a[i+400],
a[i+600]);
639 for (i = 0; i < mm1; ++i) diff[i] = com[i] = 0;
640 for (k = 0; k <
n; ++k) {
641 for (i = 0; i <
mm; ++i)
c[i] =
a[k+i*200];
642 printf(
" ---------------------------------------%3d --------------------------------------------\n",k+1);
643 printf(
"%12.8f\n",
x[k]);
645 printf(
"%16.8f\n",
c[0]);
647 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
649 for (i = 0; i < mm1; ++i)
650 if ((z=
TMath::Abs(
a[k+i*200])) > com[i]) com[i] = z;
652 for (i = 1; i <
mm; ++i)
653 for (jj = i; jj <
mm; ++jj) {
655 c[j-2] =
c[j-1]*z+
c[j-2];
657 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
659 for (i = 0; i < mm1; ++i)
660 if (!(k >=
n-2 && i != 0))
662 > diff[i]) diff[i] = z;
665 printf(
" MAXIMUM ABSOLUTE VALUES OF DIFFERENCES \n");
666 for (i = 0; i < mm1; ++i) printf(
"%18.9E",diff[i]);
668 printf(
" MAXIMUM ABSOLUTE VALUES OF COEFFICIENTS \n");
671 for (i = 0; i < mm1; ++i) printf(
"%16.8f",com[i]);
674 for (
n = 10;
n <= 100;
n += 10) {
678 for (i = 0; i < nm1; i += 2) {
688 printf(
"\n-N = %3d M =%2d\n",
n,
m);
690 for (i = 0; i <
n; ++i)
693 for (i = 0; i < mm1; ++i)
694 diff[i] = com[i] = 0;
695 for (k = 0; k <
n; ++k) {
696 for (i = 0; i <
mm; ++i)
699 printf(
" ---------------------------------------%3d --------------------------------------------\n",k+1);
700 printf(
"%12.8f\n",
x[k]);
701 if (k ==
n-1) printf(
"%16.8f\n",
c[0]);
705 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
708 for (i = 0; i < mm1; ++i)
712 for (i = 1; i <
mm; ++i)
713 for (jj = i; jj <
mm; ++jj) {
715 c[j-2] =
c[j-1]*z+
c[j-2];
718 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
721 for (i = 0; i < mm1; ++i)
722 if (!(k >=
n-2 && i != 0))
724 > diff[i]) diff[i] = z;
726 printf(
" MAXIMUM ABSOLUTE VALUES OF DIFFERENCES \n");
727 for (i = 0; i < mm1; ++i) printf(
"%18.9E",diff[i]);
729 printf(
" MAXIMUM ABSOLUTE VALUES OF COEFFICIENTS \n");
732 for (i = 0; i < mm1; ++i) printf(
"%16.8E",com[i]);
747 else if(
x>=
fXmax) klow=khig;
756 else if (klow < khig) {
757 if (
x >
fPoly[klow+1].X()) ++klow;
764 if(
x>
fPoly[khalf=(klow+khig)/2].X())
772 "Binary search failed x(%d) = %f < x= %f < x(%d) = %f\n",
785 if (klow >=
fNp-1 &&
fNp > 1) klow =
fNp-2;
795 if (klow >=
fNp-1) klow =
fNp-2;
806 std::ofstream *
f =
new std::ofstream(filename,std::ios::out);
808 Error(
"SaveAs",
"Cannot open file:%s\n",filename);
814 Int_t nch = strlen(filename);
815 snprintf(buffer,512,
"double %s",filename);
816 char *dot = strstr(buffer,
".");
818 strlcat(buffer,
"(double x) {\n",512);
819 nch = strlen(buffer);
f->write(buffer,nch);
821 nch = strlen(buffer);
f->write(buffer,nch);
823 nch = strlen(buffer);
f->write(buffer,nch);
827 snprintf(buffer,512,
" const double fX[%d] = {",
fNp);
828 nch = strlen(buffer);
f->write(buffer,nch);
832 for (i=0;i<
fNp;i++) {
835 if (i ==
fNp-1) numb[nch-1]=0;
836 strlcat(buffer,numb,512);
837 if (i%5 == 4 || i ==
fNp-1) {
838 nch = strlen(buffer);
f->write(buffer,nch);
843 nch = strlen(buffer);
f->write(buffer,nch);
845 snprintf(buffer,512,
" const double fY[%d] = {",
fNp);
846 nch = strlen(buffer);
f->write(buffer,nch);
848 for (i=0;i<
fNp;i++) {
851 if (i ==
fNp-1) numb[nch-1]=0;
852 strlcat(buffer,numb,512);
853 if (i%5 == 4 || i ==
fNp-1) {
854 nch = strlen(buffer);
f->write(buffer,nch);
859 nch = strlen(buffer);
f->write(buffer,nch);
861 snprintf(buffer,512,
" const double fB[%d] = {",
fNp);
862 nch = strlen(buffer);
f->write(buffer,nch);
864 for (i=0;i<
fNp;i++) {
867 if (i ==
fNp-1) numb[nch-1]=0;
868 strlcat(buffer,numb,512);
869 if (i%5 == 4 || i ==
fNp-1) {
870 nch = strlen(buffer);
f->write(buffer,nch);
875 nch = strlen(buffer);
f->write(buffer,nch);
877 snprintf(buffer,512,
" const double fC[%d] = {",
fNp);
878 nch = strlen(buffer);
f->write(buffer,nch);
880 for (i=0;i<
fNp;i++) {
883 if (i ==
fNp-1) numb[nch-1]=0;
884 strlcat(buffer,numb,512);
885 if (i%5 == 4 || i ==
fNp-1) {
886 nch = strlen(buffer);
f->write(buffer,nch);
891 nch = strlen(buffer);
f->write(buffer,nch);
893 snprintf(buffer,512,
" const double fD[%d] = {",
fNp);
894 nch = strlen(buffer);
f->write(buffer,nch);
896 for (i=0;i<
fNp;i++) {
899 if (i ==
fNp-1) numb[nch-1]=0;
900 strlcat(buffer,numb,512);
901 if (i%5 == 4 || i ==
fNp-1) {
902 nch = strlen(buffer);
f->write(buffer,nch);
907 nch = strlen(buffer);
f->write(buffer,nch);
910 snprintf(buffer,512,
" int klow=0;\n");
911 nch = strlen(buffer);
f->write(buffer,nch);
913 snprintf(buffer,512,
" // If out of boundaries, extrapolate. It may be badly wrong\n");
914 snprintf(buffer,512,
" if(x<=fXmin) klow=0;\n");
915 nch = strlen(buffer);
f->write(buffer,nch);
916 snprintf(buffer,512,
" else if(x>=fXmax) klow=fNp-1;\n");
917 nch = strlen(buffer);
f->write(buffer,nch);
919 nch = strlen(buffer);
f->write(buffer,nch);
920 snprintf(buffer,512,
" if(fKstep) {\n");
921 nch = strlen(buffer);
f->write(buffer,nch);
923 snprintf(buffer,512,
" // Equidistant knots, use histogramming\n");
924 nch = strlen(buffer);
f->write(buffer,nch);
925 snprintf(buffer,512,
" klow = int((x-fXmin)/fDelta);\n");
926 nch = strlen(buffer);
f->write(buffer,nch);
927 snprintf(buffer,512,
" if (klow < fNp-1) klow = fNp-1;\n");
928 nch = strlen(buffer);
f->write(buffer,nch);
930 nch = strlen(buffer);
f->write(buffer,nch);
931 snprintf(buffer,512,
" int khig=fNp-1, khalf;\n");
932 nch = strlen(buffer);
f->write(buffer,nch);
934 snprintf(buffer,512,
" // Non equidistant knots, binary search\n");
935 nch = strlen(buffer);
f->write(buffer,nch);
936 snprintf(buffer,512,
" while(khig-klow>1)\n");
937 nch = strlen(buffer);
f->write(buffer,nch);
938 snprintf(buffer,512,
" if(x>fX[khalf=(klow+khig)/2]) klow=khalf;\n");
939 nch = strlen(buffer);
f->write(buffer,nch);
940 snprintf(buffer,512,
" else khig=khalf;\n");
941 nch = strlen(buffer);
f->write(buffer,nch);
943 nch = strlen(buffer);
f->write(buffer,nch);
945 nch = strlen(buffer);
f->write(buffer,nch);
946 snprintf(buffer,512,
" // Evaluate now\n");
947 nch = strlen(buffer);
f->write(buffer,nch);
948 snprintf(buffer,512,
" double dx=x-fX[klow];\n");
949 nch = strlen(buffer);
f->write(buffer,nch);
950 snprintf(buffer,512,
" return (fY[klow]+dx*(fB[klow]+dx*(fC[klow]+dx*fD[klow])));\n");
951 nch = strlen(buffer);
f->write(buffer,nch);
956 if (
f) {
f->close();
delete f;}
971 out<<
"spline3 = new TSpline3("<<quote<<
GetTitle()<<quote<<
","
972 <<
fXmin<<
","<<
fXmax<<
",(TF1*)0,"<<
fNp<<
","<<quote<<quote<<
","
974 out<<
" spline3->SetName("<<quote<<
GetName()<<quote<<
");"<<std::endl;
979 if (
fNpx != 100) out<<
" spline3->SetNpx("<<
fNpx<<
");"<<std::endl;
982 out<<
" spline3->SetPoint("<<i<<
","<<
fPoly[i].
X()<<
","<<
fPoly[i].
Y()<<
");"<<std::endl;
983 out<<
" spline3->SetPointCoeff("<<i<<
","<<
fPoly[i].
B()<<
","<<
fPoly[i].
C()<<
","<<
fPoly[i].
D()<<
");"<<std::endl;
985 out<<
" spline3->Draw("<<quote<<option<<quote<<
");"<<std::endl;
993 if (i < 0 || i >=
fNp)
return;
1003 if (i < 0 || i >=
fNp)
return;
1088 for (
m=1;
m<
l; ++
m) {
1157 for (i=1; i<
fNp; ++i) {
1161 fPoly[i-1].
C() = (divdf1 -
fPoly[i-1].
B() - divdf3)/dtau;
1162 fPoly[i-1].
D() = (divdf3/dtau)/dtau;
1169void TSpline3::Streamer(
TBuffer &R__b)
1179 TSpline::Streamer(R__b);
1183 fPoly[i].Streamer(R__b);
1216 const char *cb1, *ce1, *cb2, *ce2;
1225 for (
Int_t i=0; i<
n; ++i) {
1250 const char *cb1, *ce1, *cb2, *ce2;
1259 for (
Int_t i=0; i<
n; ++i) {
1283 const char *cb1, *ce1, *cb2, *ce2;
1292 for (
Int_t i=0; i<
n; i++) {
1317 const char *cb1, *ce1, *cb2, *ce2;
1326 for (
Int_t i=0; i<
n; ++i) {
1329 if (func)
fPoly[i+beg].
Y() = ((
TF1*)func)->Eval(
x);
1352 const char *cb1, *ce1, *cb2, *ce2;
1363 g->GetPoint(i,xx,yy);
1386 const char *cb1, *ce1, *cb2, *ce2;
1396 fPoly[i+beg].
X()=
h->GetXaxis()->GetBinCenter(i+1);
1397 fPoly[i+beg].
Y()=
h->GetBinContent(i+1);
1443 const char *&cb1,
const char *&ce1,
1444 const char *&cb2,
const char *&ce2)
1449 cb1 = strstr(opt,
"b1");
1450 ce1 = strstr(opt,
"e1");
1451 cb2 = strstr(opt,
"b2");
1452 ce2 = strstr(opt,
"e2");
1474 const char *cb1,
const char *ce1,
const char *cb2,
1540 if(
x>
fPoly[khalf=(klow+khig)/2].X())
1549 "Binary search failed x(%d) = %f < x(%d) = %f\n",
1550 klow,
fPoly[klow].X(),klow+1,
fPoly[klow+1].X());
1580 std::ofstream *
f =
new std::ofstream(filename,std::ios::out);
1582 Error(
"SaveAs",
"Cannot open file:%s\n",filename);
1588 Int_t nch = strlen(filename);
1589 snprintf(buffer,512,
"double %s",filename);
1590 char *dot = strstr(buffer,
".");
1592 strlcat(buffer,
"(double x) {\n",512);
1593 nch = strlen(buffer);
f->write(buffer,nch);
1595 nch = strlen(buffer);
f->write(buffer,nch);
1597 nch = strlen(buffer);
f->write(buffer,nch);
1601 snprintf(buffer,512,
" const double fX[%d] = {",
fNp);
1602 nch = strlen(buffer);
f->write(buffer,nch);
1606 for (i=0;i<
fNp;i++) {
1609 if (i ==
fNp-1) numb[nch-1]=0;
1610 strlcat(buffer,numb,512);
1611 if (i%5 == 4 || i ==
fNp-1) {
1612 nch = strlen(buffer);
f->write(buffer,nch);
1617 nch = strlen(buffer);
f->write(buffer,nch);
1619 snprintf(buffer,512,
" const double fY[%d] = {",
fNp);
1620 nch = strlen(buffer);
f->write(buffer,nch);
1622 for (i=0;i<
fNp;i++) {
1625 if (i ==
fNp-1) numb[nch-1]=0;
1626 strlcat(buffer,numb,512);
1627 if (i%5 == 4 || i ==
fNp-1) {
1628 nch = strlen(buffer);
f->write(buffer,nch);
1633 nch = strlen(buffer);
f->write(buffer,nch);
1635 snprintf(buffer,512,
" const double fB[%d] = {",
fNp);
1636 nch = strlen(buffer);
f->write(buffer,nch);
1638 for (i=0;i<
fNp;i++) {
1641 if (i ==
fNp-1) numb[nch-1]=0;
1642 strlcat(buffer,numb,512);
1643 if (i%5 == 4 || i ==
fNp-1) {
1644 nch = strlen(buffer);
f->write(buffer,nch);
1649 nch = strlen(buffer);
f->write(buffer,nch);
1651 snprintf(buffer,512,
" const double fC[%d] = {",
fNp);
1652 nch = strlen(buffer);
f->write(buffer,nch);
1654 for (i=0;i<
fNp;i++) {
1657 if (i ==
fNp-1) numb[nch-1]=0;
1658 strlcat(buffer,numb,512);
1659 if (i%5 == 4 || i ==
fNp-1) {
1660 nch = strlen(buffer);
f->write(buffer,nch);
1665 nch = strlen(buffer);
f->write(buffer,nch);
1667 snprintf(buffer,512,
" const double fD[%d] = {",
fNp);
1668 nch = strlen(buffer);
f->write(buffer,nch);
1670 for (i=0;i<
fNp;i++) {
1673 if (i ==
fNp-1) numb[nch-1]=0;
1674 strlcat(buffer,numb,512);
1675 if (i%5 == 4 || i ==
fNp-1) {
1676 nch = strlen(buffer);
f->write(buffer,nch);
1681 nch = strlen(buffer);
f->write(buffer,nch);
1683 snprintf(buffer,512,
" const double fE[%d] = {",
fNp);
1684 nch = strlen(buffer);
f->write(buffer,nch);
1686 for (i=0;i<
fNp;i++) {
1689 if (i ==
fNp-1) numb[nch-1]=0;
1690 strlcat(buffer,numb,512);
1691 if (i%5 == 4 || i ==
fNp-1) {
1692 nch = strlen(buffer);
f->write(buffer,nch);
1697 nch = strlen(buffer);
f->write(buffer,nch);
1699 snprintf(buffer,512,
" const double fF[%d] = {",
fNp);
1700 nch = strlen(buffer);
f->write(buffer,nch);
1702 for (i=0;i<
fNp;i++) {
1705 if (i ==
fNp-1) numb[nch-1]=0;
1706 strlcat(buffer,numb,512);
1707 if (i%5 == 4 || i ==
fNp-1) {
1708 nch = strlen(buffer);
f->write(buffer,nch);
1713 nch = strlen(buffer);
f->write(buffer,nch);
1716 snprintf(buffer,512,
" int klow=0;\n");
1717 nch = strlen(buffer);
f->write(buffer,nch);
1719 snprintf(buffer,512,
" // If out of boundaries, extrapolate. It may be badly wrong\n");
1720 snprintf(buffer,512,
" if(x<=fXmin) klow=0;\n");
1721 nch = strlen(buffer);
f->write(buffer,nch);
1722 snprintf(buffer,512,
" else if(x>=fXmax) klow=fNp-1;\n");
1723 nch = strlen(buffer);
f->write(buffer,nch);
1725 nch = strlen(buffer);
f->write(buffer,nch);
1726 snprintf(buffer,512,
" if(fKstep) {\n");
1727 nch = strlen(buffer);
f->write(buffer,nch);
1729 snprintf(buffer,512,
" // Equidistant knots, use histogramming\n");
1730 nch = strlen(buffer);
f->write(buffer,nch);
1731 snprintf(buffer,512,
" klow = int((x-fXmin)/fDelta);\n");
1732 nch = strlen(buffer);
f->write(buffer,nch);
1733 snprintf(buffer,512,
" if (klow < fNp-1) klow = fNp-1;\n");
1734 nch = strlen(buffer);
f->write(buffer,nch);
1735 snprintf(buffer,512,
" } else {\n");
1736 nch = strlen(buffer);
f->write(buffer,nch);
1737 snprintf(buffer,512,
" int khig=fNp-1, khalf;\n");
1738 nch = strlen(buffer);
f->write(buffer,nch);
1740 snprintf(buffer,512,
" // Non equidistant knots, binary search\n");
1741 nch = strlen(buffer);
f->write(buffer,nch);
1742 snprintf(buffer,512,
" while(khig-klow>1)\n");
1743 nch = strlen(buffer);
f->write(buffer,nch);
1744 snprintf(buffer,512,
" if(x>fX[khalf=(klow+khig)/2]) klow=khalf;\n");
1745 nch = strlen(buffer);
f->write(buffer,nch);
1746 snprintf(buffer,512,
" else khig=khalf;\n");
1747 nch = strlen(buffer);
f->write(buffer,nch);
1749 nch = strlen(buffer);
f->write(buffer,nch);
1751 nch = strlen(buffer);
f->write(buffer,nch);
1752 snprintf(buffer,512,
" // Evaluate now\n");
1753 nch = strlen(buffer);
f->write(buffer,nch);
1754 snprintf(buffer,512,
" double dx=x-fX[klow];\n");
1755 nch = strlen(buffer);
f->write(buffer,nch);
1756 snprintf(buffer,512,
" return (fY[klow]+dx*(fB[klow]+dx*(fC[klow]+dx*(fD[klow]+dx*(fE[klow]+dx*fF[klow])))));\n");
1757 nch = strlen(buffer);
f->write(buffer,nch);
1762 if (
f) {
f->close();
delete f;}
1771 out<<
" "<<std::endl;
1781 out<<
"spline5 = new TSpline5("<<quote<<
GetTitle()<<quote<<
","
1782 <<
fXmin<<
","<<
fXmax<<
",(TF1*)0,"<<
fNp<<
","<<quote<<quote<<
","
1783 <<b1<<
","<<e1<<
","<<b2<<
","<<e2<<
");"<<std::endl;
1784 out<<
" spline5->SetName("<<quote<<
GetName()<<quote<<
");"<<std::endl;
1789 if (
fNpx != 100) out<<
" spline5->SetNpx("<<
fNpx<<
");"<<std::endl;
1792 out<<
" spline5->SetPoint("<<i<<
","<<
fPoly[i].
X()<<
","<<
fPoly[i].
Y()<<
");"<<std::endl;
1793 out<<
" spline5->SetPointCoeff("<<i<<
","<<
fPoly[i].
B()<<
","<<
fPoly[i].
C()<<
","<<
fPoly[i].
D()<<
","<<
fPoly[i].
E()<<
","<<
fPoly[i].
F()<<
");"<<std::endl;
1795 out<<
" spline5->Draw("<<quote<<option<<quote<<
");"<<std::endl;
1804 if (i < 0 || i >=
fNp)
return;
1815 if (i < 0 || i >=
fNp)
return;
1904 b1,
p2,
p3, q2, q3, r2, pq, pr, qr;
1919 if (
q)
fPoly[1].
D() =
q*6.*q2/(qr*qr);
1923 for (i = 1; i <
m; ++i) {
1936 fPoly[i+1].
D() = q3*6./(qr*qr);
1938 *(pr* 20.+q2*7.)+q2*
1939 ((
p2+r2)*8.+pr*21.+q2+q2))/(pqqr*pqqr);
1940 fPoly[i-1].
D() += q3*6./(pq*pq);
1941 fPoly[i].
E() = q2*(p*qr+pq*3.*(qr+
r+
r))/(pqqr*qr);
1942 fPoly[i-1].
E() += q2*(
r*pq+qr*3.*(pq+p+p))/(pqqr*pq);
1943 fPoly[i-1].
F() = q3/pqqr;
1948 if (
r)
fPoly[
m-1].
D() +=
r*6.*r2/(qr*qr);
1953 for (i = 1; i <
fNp; ++i) {
1962 for (i = 2; i <
fNp; ++i) {
1980 for (i = 2; i <
m; ++i) {
1993 for (i=
fNp-3; i > 0; --i)
2011 for (i = 1; i <
m; ++i) {
2089 printf(
"1 TEST OF TSpline5 WITH NONEQUIDISTANT KNOTS\n");
2104 printf(
"\n-N = %3d M =%2d\n",
n,
m);
2106 for (i = 0; i <
n; ++i)
2108 a[i+600],
a[i+800],
a[i+1000]);
2110 for (i = 0; i < mm1; ++i) diff[i] = com[i] = 0;
2111 for (k = 0; k <
n; ++k) {
2112 for (i = 0; i <
mm; ++i)
c[i] =
a[k+i*200];
2113 printf(
" ---------------------------------------%3d --------------------------------------------\n",k+1);
2114 printf(
"%12.8f\n",
x[k]);
2116 printf(
"%16.8f\n",
c[0]);
2118 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2120 for (i = 0; i < mm1; ++i)
2121 if ((z=
TMath::Abs(
a[k+i*200])) > com[i]) com[i] = z;
2123 for (i = 1; i <
mm; ++i)
2124 for (jj = i; jj <
mm; ++jj) {
2126 c[j-2] =
c[j-1]*z+
c[j-2];
2128 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2130 for (i = 0; i < mm1; ++i)
2131 if (!(k >=
n-2 && i != 0))
2133 > diff[i]) diff[i] = z;
2136 printf(
" MAXIMUM ABSOLUTE VALUES OF DIFFERENCES \n");
2137 for (i = 0; i < mm1; ++i) printf(
"%18.9E",diff[i]);
2139 printf(
" MAXIMUM ABSOLUTE VALUES OF COEFFICIENTS \n");
2142 for (i = 0; i < mm1; ++i) printf(
"%16.8f",com[i]);
2145 for (
n = 10;
n <= 100;
n += 10) {
2149 for (i = 0; i < nm1; i += 2) {
2159 printf(
"\n-N = %3d M =%2d\n",
n,
m);
2161 for (i = 0; i <
n; ++i)
2163 a[i+600],
a[i+800],
a[i+1000]);
2165 for (i = 0; i < mm1; ++i)
2166 diff[i] = com[i] = 0;
2167 for (k = 0; k <
n; ++k) {
2168 for (i = 0; i <
mm; ++i)
2171 printf(
" ---------------------------------------%3d --------------------------------------------\n",k+1);
2172 printf(
"%12.8f\n",
x[k]);
2173 if (k ==
n-1) printf(
"%16.8f\n",
c[0]);
2175 if (k ==
n-1)
break;
2177 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2180 for (i = 0; i < mm1; ++i)
2184 for (i = 1; i <
mm; ++i)
2185 for (jj = i; jj <
mm; ++jj) {
2187 c[j-2] =
c[j-1]*z+
c[j-2];
2190 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2193 for (i = 0; i < mm1; ++i)
2194 if (!(k >=
n-2 && i != 0))
2196 > diff[i]) diff[i] = z;
2198 printf(
" MAXIMUM ABSOLUTE VALUES OF DIFFERENCES \n");
2199 for (i = 0; i < mm1; ++i) printf(
"%18.9E",diff[i]);
2201 printf(
" MAXIMUM ABSOLUTE VALUES OF COEFFICIENTS \n");
2204 for (i = 0; i < mm1; ++i) printf(
"%16.8E",com[i]);
2209 printf(
"1 TEST OF TSpline5 WITH NONEQUIDISTANT DOUBLE KNOTS\n");
2235 printf(
"-N = %3d M =%2d\n",
n,
m);
2237 for (i = 0; i < nn; ++i)
2239 a[i+600],
a[i+800],
a[i+1000]);
2241 for (i = 0; i < mm1; ++i)
2242 diff[i] = com[i] = 0;
2243 for (k = 0; k < nn; ++k) {
2244 for (i = 0; i <
mm; ++i)
2246 printf(
" ---------------------------------------%3d --------------------------------------------\n",k+1);
2247 printf(
"%12.8f\n",
x[k]);
2249 printf(
"%16.8f\n",
c[0]);
2252 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2254 for (i = 0; i < mm1; ++i)
2255 if ((z=
TMath::Abs(
a[k+i*200])) > com[i]) com[i] = z;
2257 for (i = 1; i <
mm; ++i)
2258 for (jj = i; jj <
mm; ++jj) {
2260 c[j-2] =
c[j-1]*z+
c[j-2];
2262 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2264 for (i = 0; i < mm1; ++i)
2265 if (!(k >= nn-2 && i != 0))
2267 > diff[i]) diff[i] = z;
2269 printf(
" MAXIMUM ABSOLUTE VALUES OF DIFFERENCES \n");
2270 for (i = 1; i <= mm1; ++i) {
2271 printf(
"%18.9E",diff[i-1]);
2276 printf(
" MAXIMUM ABSOLUTE VALUES OF COEFFICIENTS \n");
2277 for (i = 0; i < mm1; ++i) printf(
"%16.8f",com[i]);
2280 for (
n = 10;
n <= 100;
n += 10) {
2285 for (i = 0; i <
n; ++i) {
2292 printf(
"-N = %3d M =%2d\n",
n,
m);
2294 for (i = 0; i < nn; ++i)
2296 a[i+600],
a[i+800],
a[i+1000]);
2298 for (i = 0; i < mm1; ++i)
2299 diff[i] = com[i] = 0;
2300 for (k = 0; k < nn; ++k) {
2301 for (i = 0; i <
mm; ++i)
2304 printf(
" ---------------------------------------%3d --------------------------------------------\n",k+1);
2305 printf(
"%12.8f\n",
x[k]);
2306 if (k == nn-1) printf(
"%16.8f\n",
c[0]);
2308 if (k == nn-1)
break;
2310 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2313 for (i = 0; i < mm1; ++i)
2314 if ((z=
TMath::Abs(
a[k+i*200])) > com[i]) com[i] = z;
2316 for (i = 1; i <
mm; ++i) {
2317 for (jj = i; jj <
mm; ++jj) {
2319 c[j-2] =
c[j-1]*z+
c[j-2];
2323 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2326 for (i = 0; i < mm1; ++i)
2327 if (!(k >= nn-2 && i != 0))
2329 > diff[i]) diff[i] = z;
2331 printf(
" MAXIMUM ABSOLUTE VALUES OF DIFFERENCES \n");
2332 for (i = 0; i < mm1; ++i) printf(
"%18.9E",diff[i]);
2334 printf(
" MAXIMUM ABSOLUTE VALUES OF COEFFICIENTS \n");
2337 for (i = 0; i < mm1; ++i) printf(
"%18.9E",com[i]);
2343 printf(
"1 TEST OF TSpline5 WITH NONEQUIDISTANT KNOTS,\n");
2344 printf(
" ONE DOUBLE, ONE TRIPLE KNOT\n");
2365 printf(
"-N = %3d M =%2d\n",
n,
m);
2367 for (i = 0; i <
n; ++i)
2369 a[i+600],
a[i+800],
a[i+1000]);
2371 for (i = 0; i < mm1; ++i)
2372 diff[i] = com[i] = 0;
2373 for (k = 0; k <
n; ++k) {
2374 for (i = 0; i <
mm; ++i)
2376 printf(
" ---------------------------------------%3d --------------------------------------------\n",k+1);
2377 printf(
"%12.8f\n",
x[k]);
2379 printf(
"%16.8f\n",
c[0]);
2382 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2384 for (i = 0; i < mm1; ++i)
2385 if ((z=
TMath::Abs(
a[k+i*200])) > com[i]) com[i] = z;
2387 for (i = 1; i <
mm; ++i)
2388 for (jj = i; jj <
mm; ++jj) {
2390 c[j-2] =
c[j-1]*z+
c[j-2];
2392 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2394 for (i = 0; i < mm1; ++i)
2395 if (!(k >=
n-2 && i != 0))
2397 > diff[i]) diff[i] = z;
2399 printf(
" MAXIMUM ABSOLUTE VALUES OF DIFFERENCES \n");
2400 for (i = 0; i < mm1; ++i) printf(
"%18.9E",diff[i]);
2402 printf(
" MAXIMUM ABSOLUTE VALUES OF COEFFICIENTS \n");
2405 for (i = 0; i < mm1; ++i) printf(
"%16.8f",com[i]);
2410 printf(
"1 TEST OF TSpline5 WITH NONEQUIDISTANT KNOTS,\n");
2411 printf(
" TWO DOUBLE, ONE TRIPLE KNOT\n");
2436 printf(
"-N = %3d M =%2d\n",
n,
m);
2438 for (i = 0; i <
n; ++i)
2440 a[i+600],
a[i+800],
a[i+1000]);
2442 for (i = 0; i < mm1; ++i)
2443 diff[i] = com[i] = 0;
2444 for (k = 0; k <
n; ++k) {
2445 for (i = 0; i <
mm; ++i)
2447 printf(
" ---------------------------------------%3d --------------------------------------------\n",k+1);
2448 printf(
"%12.8f\n",
x[k]);
2450 printf(
"%16.8f\n",
c[0]);
2453 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2455 for (i = 0; i < mm1; ++i)
2456 if ((z=
TMath::Abs(
a[k+i*200])) > com[i]) com[i] = z;
2458 for (i = 1; i <
mm; ++i)
2459 for (jj = i; jj <
mm; ++jj) {
2461 c[j-2] =
c[j-1]*z+
c[j-2];
2463 for (i = 0; i <
mm; ++i) printf(
"%16.8f",
c[i]);
2465 for (i = 0; i < mm1; ++i)
2466 if (!(k >=
n-2 && i != 0))
2468 > diff[i]) diff[i] = z;
2470 printf(
" MAXIMUM ABSOLUTE VALUES OF DIFFERENCES \n");
2471 for (i = 0; i < mm1; ++i) printf(
"%18.9E",diff[i]);
2473 printf(
" MAXIMUM ABSOLUTE VALUES OF COEFFICIENTS \n");
2476 for (i = 0; i < mm1; ++i) printf(
"%16.8f",com[i]);
2483void TSpline5::Streamer(
TBuffer &R__b)
2493 TSpline::Streamer(R__b);
2497 fPoly[i].Streamer(R__b);
static double p3(double t, double a, double b, double c, double d)
static double p2(double t, double a, double b, double c)
Binding & operator=(OUT(*fun)(void))
R__EXTERN TSystem * gSystem
Fill Area Attributes class.
virtual Color_t GetFillColor() const
Return the fill area color.
virtual Style_t GetFillStyle() const
Return the fill area style.
virtual void SetFillColor(Color_t fcolor)
Set the fill area color.
virtual void SetFillStyle(Style_t fstyle)
Set the fill area style.
virtual void SaveFillAttributes(std::ostream &out, const char *name, Int_t coldef=1, Int_t stydef=1001)
Save fill attributes as C++ statement(s) on output stream out.
virtual Color_t GetLineColor() const
Return the line color.
virtual void SetLineStyle(Style_t lstyle)
Set the line style.
virtual Width_t GetLineWidth() const
Return the line width.
virtual void SetLineWidth(Width_t lwidth)
Set the line width.
virtual void SetLineColor(Color_t lcolor)
Set the line color.
virtual Style_t GetLineStyle() const
Return the line style.
virtual void SaveLineAttributes(std::ostream &out, const char *name, Int_t coldef=1, Int_t stydef=1, Int_t widdef=1)
Save line attributes as C++ statement(s) on output stream out.
virtual void SaveMarkerAttributes(std::ostream &out, const char *name, Int_t coldef=1, Int_t stydef=1, Int_t sizdef=1)
Save line attributes as C++ statement(s) on output stream out.
virtual Style_t GetMarkerStyle() const
Return the marker style.
virtual void SetMarkerColor(Color_t mcolor=1)
Set the marker color.
virtual Color_t GetMarkerColor() const
Return the marker color.
virtual Size_t GetMarkerSize() const
Return the marker size.
virtual void SetMarkerStyle(Style_t mstyle=1)
Set the marker style.
virtual void SetMarkerSize(Size_t msize=1)
Set the marker size.
virtual void SetLimits(Double_t xmin, Double_t xmax)
Buffer base class used for serializing objects.
virtual Int_t ReadClassBuffer(const TClass *cl, void *pointer, const TClass *onfile_class=0)=0
virtual Version_t ReadVersion(UInt_t *start=0, UInt_t *bcnt=0, const TClass *cl=0)=0
virtual Int_t CheckByteCount(UInt_t startpos, UInt_t bcnt, const TClass *clss)=0
virtual Int_t WriteClassBuffer(const TClass *cl, void *pointer)=0
A Graph is a graphics object made of two arrays X and Y with npoints each.
virtual void Paint(Option_t *chopt="")
Draw this graph with its current attributes.
1-D histogram with a float per channel (see TH1 documentation)}
virtual void SetDirectory(TDirectory *dir)
By default when an histogram is created, it is added to the list of histogram objects in the current ...
virtual Double_t GetBinCenter(Int_t bin) const
Return bin center for 1D histogram.
@ kLogX
X-axis in log scale.
@ kNoStats
don't draw stats box
TAxis * GetXaxis()
Get the behaviour adopted by the object about the statoverflows. See EStatOverflows for more informat...
virtual void SetBinContent(Int_t bin, Double_t content)
Set bin content see convention for numbering bins in TH1::GetBin In case the bin number is greater th...
virtual void ExecuteEvent(Int_t event, Int_t px, Int_t py)
Execute action corresponding to one event.
virtual void Paint(Option_t *option="")
Control routine to paint any kind of histograms.
virtual Int_t DistancetoPrimitive(Int_t px, Int_t py)
Compute distance from point px,py to a line.
The TNamed class is the base class for all named ROOT classes.
virtual const char * GetTitle() const
Returns title of object.
TNamed & operator=(const TNamed &rhs)
TNamed assignment operator.
virtual const char * GetName() const
Returns name of object.
TObject & operator=(const TObject &rhs)
TObject assignment operator.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual void AppendPad(Option_t *option="")
Append graphics object to current pad.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
Class to create third splines to interpolate knots Arbitrary conditions can be introduced for first a...
virtual void SavePrimitive(std::ostream &out, Option_t *option="")
Save primitive as a C++ statement(s) on output stream out.
Int_t FindX(Double_t x) const
Find X.
static void Test()
Test method for TSpline5.
virtual void SaveAs(const char *filename, Option_t *option="") const
Write this spline as a C++ function that can be executed without ROOT the name of the function is the...
void SetCond(const char *opt)
Check the boundary conditions.
Double_t Derivative(Double_t x) const
Derivative.
TSpline3 & operator=(const TSpline3 &)
Assignment operator.
Double_t Eval(Double_t x) const
Eval this spline at x.
virtual void SetPoint(Int_t i, Double_t x, Double_t y)
Set point number i.
void BuildCoeff()
Build coefficients.
void GetCoeff(Int_t i, Double_t &x, Double_t &y, Double_t &b, Double_t &c, Double_t &d)
virtual void SetPointCoeff(Int_t i, Double_t b, Double_t c, Double_t d)
Set point coefficient number i.
Class to create quintic natural splines to interpolate knots Arbitrary conditions can be introduced f...
static void Test()
Test method for TSpline5.
void GetCoeff(Int_t i, Double_t &x, Double_t &y, Double_t &b, Double_t &c, Double_t &d, Double_t &e, Double_t &f)
virtual void SaveAs(const char *filename, Option_t *option="") const
Write this spline as a C++ function that can be executed without ROOT the name of the function is the...
virtual void SavePrimitive(std::ostream &out, Option_t *option="")
Save primitive as a C++ statement(s) on output stream out.
virtual void SetPointCoeff(Int_t i, Double_t b, Double_t c, Double_t d, Double_t e, Double_t f)
Set point coefficient number i.
Double_t Derivative(Double_t x) const
Derivative.
Double_t Eval(Double_t x) const
Eval this spline at x.
void BoundaryConditions(const char *opt, Int_t &beg, Int_t &end, const char *&cb1, const char *&ce1, const char *&cb2, const char *&ce2)
Check the boundary conditions and the amount of extra double knots needed.
void BuildCoeff()
Algorithm 600, collected algorithms from acm.
void SetBoundaries(Double_t b1, Double_t e1, Double_t b2, Double_t e2, const char *cb1, const char *ce1, const char *cb2, const char *ce2)
Set the boundary conditions at double/triple knots.
Int_t FindX(Double_t x) const
Find X.
virtual void SetPoint(Int_t i, Double_t x, Double_t y)
Set point number i.
TSpline5 & operator=(const TSpline5 &)
Assignment operator.
Double_t Derivative(Double_t x) const
Double_t Eval(Double_t x) const
void CopyPoly(TSplinePoly3 const &other)
Utility called by the copy constructors and = operator.
TSplinePoly3 & operator=(TSplinePoly3 const &other)
Assignment operator.
void CopyPoly(TSplinePoly5 const &other)
Utility called by the copy constructors and = operator.
TSplinePoly5 & operator=(TSplinePoly5 const &other)
Assignment operator.
Double_t Derivative(Double_t x) const
Double_t Eval(Double_t x) const
Base class for TSpline knot.
void CopyPoly(TSplinePoly const &other)
Utility called by the copy constructors and = operator.
TSplinePoly & operator=(TSplinePoly const &other)
Assignment operator.
Base class for spline implementation containing the Draw/Paint methods.
virtual void ExecuteEvent(Int_t event, Int_t px, Int_t py)
Execute action corresponding to one event.
virtual Double_t Eval(Double_t x) const =0
virtual void Draw(Option_t *option="")
Draw this function with its current attributes.
virtual void GetKnot(Int_t i, Double_t &x, Double_t &y) const =0
TSpline & operator=(const TSpline &)
Assignment operator.
virtual void Paint(Option_t *option="")
Paint this function with its current attributes.
virtual Int_t DistancetoPrimitive(Int_t px, Int_t py)
Compute distance from point px,py to a spline.
virtual ~TSpline()
Destructor.
void ToLower()
Change string to lower-case.
const char * Data() const
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)
Returns FALSE if one can access a file using the specified access mode.
static constexpr double s
static constexpr double mm
Short_t Max(Short_t a, Short_t b)
Int_t FloorNint(Double_t x)
constexpr Double_t E()
Base of natural log:
Short_t Min(Short_t a, Short_t b)
Double_t Log10(Double_t x)