747      Error(
"TGaxis", 
"calling constructor with an unknown function: %s", funcname);
 
  781  fGridLength(ax.fGridLength),
 
  782  fTickSize(ax.fTickSize),
 
  783  fLabelOffset(ax.fLabelOffset),
 
  784  fLabelSize(ax.fLabelSize),
 
  785  fTitleOffset(ax.fTitleOffset),
 
  786  fTitleSize(ax.fTitleSize),
 
  788  fLabelColor(ax.fLabelColor),
 
  789  fLabelFont(ax.fLabelFont),
 
  790  fNModLabs(ax.fNModLabs),
 
  794  fTimeFormat(ax.fTimeFormat),
 
  795  fFunctionName(ax.fFunctionName),
 
  796  fFunction(ax.fFunction),
 
  798  fModLabs(ax.fModLabs)
 
  961   const char *where = 
"PaintAxis";
 
  971   Double_t phil, phi, sinphi, cosphi, asinphi, acosphi;
 
  972   Double_t binLow = 0.,  binLow2 = 0.,  binLow3 = 0.;
 
  973   Double_t binHigh = 0., binHigh2 = 0., binHigh3 = 0.;
 
  974   Double_t binWidth = 0., binWidth2 = 0., binWidth3 = 0.;
 
  985   xx0 = xx1 = yy0 = yy1 = 0;
 
  986   Double_t xxmin, xxmax, yymin, yymax;
 
  987   xxmin = xxmax = yymin = yymax = 0;
 
  991   Double_t xmnlog, x00, x11, h2, h2sav, axmul, 
y;
 
  994   Int_t nlabels, nticks, nticks0, nticks1;
 
  995   Int_t i, j, k, 
l, decade, ltick;
 
  999   Int_t iexe, if1, if2, na, nf, ih1, ih2, nbinin, nch, kmod;
 
 1000   Int_t optionLog,optionBlank,optionVert,optionPlus,optionMinus,optionUnlab,optionPara;
 
 1001   Int_t optionDown,optionRight,optionLeft,optionCent,optionEqual,optionDecimals=0,optionDot;
 
 1002   Int_t optionY,optionText,optionGrid,optionSize,optionNoopt,optionInt,optionM,optionUp,optionX;
 
 1005   Int_t xalign, yalign;
 
 1006   Int_t nn1, nn2, nn3, n1a, n2a, n3a, nb2, nb3;
 
 1007   Int_t nbins=10, n1aold, nn1old;
 
 1009   n1aold = nn1old = 0;
 
 1033   chtemp = &kchtemp[0];
 
 1034   label  = &chlabel[0];
 
 1053   if(strchr(chopt,
'G')) optionLog  = 1;  
else optionLog  = 0;
 
 1054   if(strchr(chopt,
'B')) optionBlank= 1;  
else optionBlank= 0;
 
 1055   if(strchr(chopt,
'V')) optionVert = 1;  
else optionVert = 0;
 
 1056   if(strchr(chopt,
'+')) optionPlus = 1;  
else optionPlus = 0;
 
 1057   if(strchr(chopt,
'-')) optionMinus= 1;  
else optionMinus= 0;
 
 1058   if(strchr(chopt,
'U')) optionUnlab= 1;  
else optionUnlab= 0;
 
 1059   if(strchr(chopt,
'P')) optionPara = 1;  
else optionPara = 0;
 
 1060   if(strchr(chopt,
'O')) optionDown = 1;  
else optionDown = 0;
 
 1061   if(strchr(chopt,
'R')) optionRight= 1;  
else optionRight= 0;
 
 1062   if(strchr(chopt,
'L')) optionLeft = 1;  
else optionLeft = 0;
 
 1063   if(strchr(chopt,
'C')) optionCent = 1;  
else optionCent = 0;
 
 1064   if(strchr(chopt,
'=')) optionEqual= 1;  
else optionEqual= 0;
 
 1065   if(strchr(chopt,
'Y')) optionY    = 1;  
else optionY    = 0;
 
 1066   if(strchr(chopt,
'T')) optionText = 1;  
else optionText = 0;
 
 1067   if(strchr(chopt,
'W')) optionGrid = 1;  
else optionGrid = 0;
 
 1068   if(strchr(chopt,
'S')) optionSize = 1;  
else optionSize = 0;
 
 1069   if(strchr(chopt,
'N')) optionNoopt= 1;  
else optionNoopt= 0;
 
 1070   if(strchr(chopt,
'I')) optionInt  = 1;  
else optionInt  = 0;
 
 1071   if(strchr(chopt,
'M')) optionM    = 1;  
else optionM    = 0;
 
 1072   if(strchr(chopt,
'0')) optionUp   = 1;  
else optionUp   = 0;
 
 1073   if(strchr(chopt,
'X')) optionX    = 1;  
else optionX    = 0;
 
 1074   if(strchr(chopt,
't')) optionTime = 1;  
else optionTime = 0;
 
 1075   if(strchr(chopt,
'.')) optionDot  = 1;  
else optionDot  = 0;
 
 1097      Error(where, 
"Invalid number of divisions: %d",ndiv);
 
 1104      if (gridlength == 0) gridlength = 0.8;
 
 1105      linegrid = 
new TLine();
 
 1135         Int_t year, 
mm, dd, hh, mi, ss;
 
 1136         if (sscanf(stringtimeoffset.
Data(), 
"%d-%d-%d %d:%d:%d", &year, &
mm, &dd, &hh, &mi, &ss) == 6) {
 
 1139            tp.tm_year   = year-1900;
 
 1153               TString sdp = stringtimeoffset(ids+1,lns);
 
 1154               sscanf(sdp.
Data(),
"%g",&dp);
 
 1158            Error(where, 
"Time offset has not the right format");
 
 1163      wmin += timeoffset - (int)(timeoffset);
 
 1164      wmax += timeoffset - (int)(timeoffset);
 
 1168      time_t timetp = (time_t)((
Long_t)(timeoffset));
 
 1171      if (range>60)       rangeBase = 60*20;       
 
 1172      if (range>3600)     rangeBase = 3600*20;     
 
 1173      if (range>86400)    rangeBase = 86400*20;    
 
 1174      if (range>2419200)  rangeBase = 31556736;    
 
 1176      if (range>31536000) {
 
 1177         tp0 = gmtime(&timetp);
 
 1184         rangeBase = (timetp-mktime(tp0)); 
 
 1185         rangeOffset = (
Double_t) (rangeBase);
 
 1187      wmax += rangeOffset;
 
 1188      wmin += rangeOffset;
 
 1193   n2a       = (ndiv%10000 - n1a)/100;
 
 1194   n3a       = (ndiv%1000000 - n2a -n1a)/10000;
 
 1199   maxDigits = (ndiv/1000000);
 
 1208   if (wmin == wmax || ndiv == 0 || n1a <= 1 || optionLog) {
 
 1214   if ( (wmax-wmin) < 1 && optionInt) {
 
 1215      Error(where, 
"option I not available");
 
 1218   if (!optionNoopt || optionInt ) {
 
 1226         if (binLow != 
Double_t(
int(binLow)) || binWidth != 
Double_t(
int(binWidth))) {
 
 1230      if ((wmin-binLow)  > 
epsilon) { binLow  += binWidth; nbins--; }
 
 1231      if ((binHigh-wmax) > 
epsilon) { binHigh -= binWidth; nbins--; }
 
 1236         yymin = rtyw*(binLow-wmin)  + 
ymin;
 
 1237         yymax = rtyw*(binHigh-wmin) + 
ymin;
 
 1241         xxmin = rtxw*(binLow-wmin)  + 
xmin;
 
 1242         xxmax = rtxw*(binHigh-wmin) + 
xmin;
 
 1250            yymin = alfa*xxmin + 
beta;
 
 1251            yymax = alfa*xxmax + 
beta;
 
 1266      if (!optionNoopt && n2a > 1 && binWidth > 0) {
 
 1272      if (!optionNoopt && n3a > 1 && binWidth2 > 0) {
 
 1286   ratio1 = 1/(rwxmax-rwxmin);
 
 1287   ratio2 = 1/(rwymax-rwymin);
 
 1288   x0     = ratio1*(
xmin-rwxmin);
 
 1289   x1     = ratio1*(
xmax-rwxmin);
 
 1290   y0     = ratio2*(
ymin-rwymin);
 
 1291   y1     = ratio2*(
ymax-rwymin);
 
 1292   if (!optionNoopt || optionInt ) {
 
 1293      xx0 = ratio1*(xxmin-rwxmin);
 
 1294      xx1 = ratio1*(xxmax-rwxmin);
 
 1295      yy0 = ratio2*(yymin-rwymin);
 
 1296      yy1 = ratio2*(yymax-rwymin);
 
 1299   if ((x0 == 
x1) && (y0 == y1)) {
 
 1300      Error(where, 
"length of axis is 0");
 
 1307   if (toffset==0 && 
x1 == x0) autotoff = 
kTRUE;
 
 1320   if (!
gPad->IsBatch()) {
 
 1321      gVirtualX->GetCharacterUp(chupxvsav, chupyvsav);
 
 1327   if (axis_length == 0) {
 
 1328      Error(where, 
"length of axis is 0");
 
 1331   if (!optionNoopt || optionInt) {
 
 1332      axis_lengthN = 
TMath::Sqrt((xx1-xx0)*(xx1-xx0)+(yy1-yy0)*(yy1-yy0));
 
 1333      axis_length0 = 
TMath::Sqrt((xx0-x0)*(xx0-x0)+(yy0-y0)*(yy0-y0));
 
 1344            wmin        += timeoffset - (int)(timeoffset) + rangeOffset;
 
 1345            wmax        += timeoffset - (int)(timeoffset) + rangeOffset;
 
 1351      if (y1>=y0) phi  = 0.5*
kPI;
 
 1367   if (acosphi <= 
epsilon) { acosphi = 0;  cosphi  = 0; }
 
 1368   if (asinphi <= 
epsilon) { asinphi = 0;  sinphi  = 0; }
 
 1376   if (x0 == 
x1 && y1 > y0)       mside = -1;
 
 1377   if (optionPlus)                mside = 1;
 
 1378   if (optionMinus)               mside = -1;
 
 1379   if (optionPlus && optionMinus) mside = 0;
 
 1382   if (optionEqual) lside = mside;
 
 1383   if (optionPlus && optionMinus) {
 
 1385      if (optionEqual) lside=1;
 
 1390   if(xmside >= 0) tick_side = 1;
 
 1391   else            tick_side = -1;
 
 1392   if (optionSize) atick[0] = tick_side*axis_length*
fTickSize;
 
 1393   else            atick[0] = tick_side*axis_length*0.03;
 
 1395   atick[1] = 0.5*atick[0];
 
 1396   atick[2] = 0.5*atick[1];
 
 1399   if ((x0 == 
x1) && (y1 > y0))  grid_side =-1;
 
 1424   if (ndiv == 0)
goto L210;
 
 1426      Error(where, 
"wmin (%f) == wmax (%f)", wmin, wmax);
 
 1436   if (optionText && 
GetLabelFont()%10 != 3) charheight *= 0.66666;
 
 1446   if (!optionUp && !optionDown && !optionY && !optionUnlab) {
 
 1461               if (nl > 50) angle = 90;
 
 1512   if (!
gPad->IsBatch()) {
 
 1513      if (cosphi > 0) 
gVirtualX->SetCharacterUp(-sinphi,cosphi);
 
 1514      else            gVirtualX->SetCharacterUp(sinphi,-cosphi);
 
 1516      if (optionVert) 
gVirtualX->SetCharacterUp(0,1);
 
 1517      if (optionPara) 
gVirtualX->SetCharacterUp(-sinphi,cosphi);
 
 1518      if (optionDown) 
gVirtualX->SetCharacterUp(cosphi,sinphi);
 
 1524   if (x0 == 
x1)    xalign = 3;
 
 1525   if (y0 != y1)    yalign = 2;
 
 1526   if (optionCent)  xalign = 2;
 
 1527   if (optionRight) xalign = 3;
 
 1528   if (optionLeft)  xalign = 1;
 
 1532      if (cosphi*sinphi > 0)  xalign = 1;
 
 1533      if (cosphi*sinphi < 0)  xalign = 3;
 
 1539      if (optionPlus && !optionMinus) {
 
 1544         if (lside < 0)  ylabel += atick[0];
 
 1546   } 
else if (y0 == y1) {
 
 1547      if (optionMinus && !optionPlus) {
 
 1558         if (mside <= 0) ylabel -= 
TMath::Abs(atick[0]);
 
 1560      if (optionLog)  ylabel -= 0.5*charheight;
 
 1565   if (optionText) ylabel /= 2;
 
 1571            dxtick=(binHigh-binLow)/
Double_t(nticks-1);
 
 1573            if (optionNoopt && !optionInt) dxtick=axis_length/
Double_t(nticks-1);
 
 1574            else                           dxtick=axis_lengthN/
Double_t(nticks-1);
 
 1576         for (k=0;k<nticks; k++) {
 
 1578            if (k%nn3 == 0) ltick = 1;
 
 1579            if (k%nn2 == 0) ltick = 0;
 
 1583               xtick = zz* axis_length / 
TMath::Abs(rwma-rwmi);
 
 1588            if (!mside) ytick -= atick[ltick];
 
 1589            if ( optionNoopt && !optionInt) {
 
 1590               Rotate(xtick,ytick,cosphi,sinphi,x0,y0,xpl2,ypl2);
 
 1591               Rotate(xtick,atick[ltick],cosphi,sinphi,x0,y0,xpl1,ypl1);
 
 1594               Rotate(xtick,ytick,cosphi,sinphi,xx0,yy0,xpl2,ypl2);
 
 1595               Rotate(xtick,atick[ltick],cosphi,sinphi,xx0,yy0,xpl1,ypl1);
 
 1598               if ((x0 != 
x1) && (y0 != y1)) {
 
 1601                     if (cosphi > 0) ypl1 = ypl2 + atick[ltick];
 
 1602                     else            ypl1 = ypl2 - atick[ltick];
 
 1605                     xpl1 = 0.5*(xpl1 + xpl2);
 
 1607                     ypl1 = 0.5*(ypl1 + ypl2) + atick[ltick];
 
 1608                     ypl2 = 0.5*(ypl1 + ypl2) - atick[ltick];
 
 1612            if (!drawGridOnly) 
PaintLineNDC(xpl1, ypl1, xpl2, ypl2);
 
 1616                  if (optionNoopt && !optionInt) {
 
 1617                     Rotate(xtick,0,cosphi,sinphi,x0,y0 ,xpl2,ypl2);
 
 1618                     Rotate(xtick,grid_side*gridlength ,cosphi,sinphi,x0,y0 ,xpl1,ypl1);
 
 1621                     Rotate(xtick,0,cosphi ,sinphi,xx0,yy0 ,xpl2,ypl2);
 
 1622                     Rotate(xtick,grid_side*gridlength ,cosphi,sinphi,xx0,yy0 ,xpl1,ypl1);
 
 1631         if (
fFunction) axis_length0 = binLow-wmin;
 
 1632         if ((!optionNoopt || optionInt) && axis_length0) {
 
 1633            nticks0 = 
Int_t(axis_length0/dxtick);
 
 1634            if (nticks0 > 1000) nticks0 = 1000;
 
 1635            for (k=0; k<=nticks0; k++) {
 
 1637               if (k%nn3 == 0) ltick = 1;
 
 1638               if (k%nn2 == 0) ltick = 0;
 
 1640               if (!mside) ytick0 -= atick[ltick];
 
 1645               Rotate(xtick0,ytick0,cosphi,sinphi,xx0,yy0 ,xpl2,ypl2);
 
 1646               Rotate(xtick0,atick[ltick],cosphi,sinphi,xx0,yy0 ,xpl1,ypl1);
 
 1648                  if ((x0 != 
x1) && (y0 != y1)) {
 
 1651                        if (cosphi > 0) ypl1 = ypl2 + atick[ltick];
 
 1652                        else            ypl1 = ypl2 - atick[ltick];
 
 1655                        xpl1 = 0.5*(xpl1 + xpl2);
 
 1657                        ypl1 = 0.5*(ypl1 + ypl2) + atick[ltick];
 
 1658                        ypl2 = 0.5*(ypl1 + ypl2) - atick[ltick];
 
 1662               if (!drawGridOnly) 
PaintLineNDC(xpl1, ypl1, xpl2, ypl2);
 
 1666                     Rotate(xtick0,0,cosphi,sinphi,xx0,yy0,xpl2,ypl2);
 
 1667                     Rotate(xtick0,grid_side*gridlength ,cosphi,sinphi,xx0,yy0 ,xpl1,ypl1);
 
 1675         if (
fFunction) axis_length1 = wmax-binHigh;
 
 1676         if ((!optionNoopt || optionInt) && axis_length1) {
 
 1677            nticks1 = int(axis_length1/dxtick);
 
 1678            if (nticks1 > 1000) nticks1 = 1000;
 
 1679            for (k=0; k<=nticks1; k++) {
 
 1681               if (k%nn3 == 0) ltick = 1;
 
 1682               if (k%nn2 == 0) ltick = 0;
 
 1684               if (!mside) ytick1 -= atick[ltick];
 
 1689               Rotate(xtick1,ytick1,cosphi,sinphi,xx0,yy0 ,xpl2,ypl2);
 
 1690               Rotate(xtick1,atick[ltick],cosphi,sinphi,xx0,yy0 ,xpl1,ypl1);
 
 1692                  if ((x0 != 
x1) && (y0 != y1)) {
 
 1695                        if (cosphi > 0) ypl1 = ypl2 + atick[ltick];
 
 1696                        else            ypl1 = ypl2 - atick[ltick];
 
 1699                        xpl1 = 0.5*(xpl1 + xpl2);
 
 1701                        ypl1 = 0.5*(ypl1 + ypl2) + atick[ltick];
 
 1702                        ypl2 = 0.5*(ypl1 + ypl2) - atick[ltick];
 
 1706               if (!drawGridOnly) 
PaintLineNDC(xpl1, ypl1, xpl2, ypl2);
 
 1709                     Rotate(xtick1,0,cosphi,sinphi,xx0,yy0 ,xpl2,ypl2);
 
 1710                     Rotate(xtick1,grid_side*gridlength,cosphi,sinphi,xx0,yy0,xpl1,ypl1);
 
 1721   if (!drawGridOnly && !optionUnlab) {
 
 1725            if ((wmin == wmax) || (ndiv == 0)) {
 
 1726               Error(where, 
"wmin (%f) == wmax (%f), or ndiv == 0", wmin, wmax);
 
 1730            dwlabel = (wmax-wmin)/
Double_t(n1a);
 
 1731            if (optionNoopt && !optionInt) dxlabel = axis_length/
Double_t(n1a);
 
 1732            else                           dxlabel = axis_lengthN/
Double_t(n1a);
 
 1734            if (!optionText && !optionTime) {
 
 1756                     if (iexe%3 == 1)     iexe += 2;
 
 1757                     else if(iexe%3 == 2) iexe += 1;
 
 1758                     if (nexe < 0) nexe = -iexe;
 
 1771               if (!noExponent && nf > maxDigits)  flexpo = 
kTRUE;
 
 1772               if (!noExponent && nf < -maxDigits) flexne = 
kTRUE;
 
 1783                     if (nexe%3 == 0 && ww <= 
TMath::Power(10,maxDigits-1)) 
break;
 
 1795                     if (nexe%3 == 0 && ww >= rne) 
break;
 
 1800               for (i=maxDigits-1; i>0; i--) {
 
 1806                  if (wdyn <= 0.999 && na < maxDigits-2) {
 
 1826               if (if1 > 14) if1 = 14;
 
 1827               if (if2 > 14) if2 = 14;
 
 1828               if (if1 <  0) if1 = 0;
 
 1831                  len = 
snprintf(chcoded,
sizeof(chcoded),
"%%%d.%df",if1,if2);
 
 1833                  len = 
snprintf(chcoded,
sizeof(chcoded),
"%%%d.%df",if1+1,1);
 
 1836               if ((len < 0) || (len >= (
int) 
sizeof(chcoded)))
 
 1837                  strcpy(chcoded,
"%7.3f");
 
 1843            Int_t ndecimals = 0;
 
 1844            if (optionDecimals) {
 
 1845               char *dot = strchr(chtemp,
'.');
 
 1847                  ndecimals = chtemp + strlen(chtemp) -dot;
 
 1850                  exp = strstr(chtemp,
"e-");
 
 1852                     sscanf(&
exp[2],
"%d",&ndecimals);
 
 1857            if (optionM) nlabels = n1a-1;
 
 1860            for ( k=0; k<=nlabels; k++) {
 
 1865                  xlabel = zz* axis_length / 
TMath::Abs(rwma-rwmi);
 
 1869               if (optionM)    xlabel += 0.5*dxlabel;
 
 1871               if (!optionText && !optionTime) {
 
 1872                  snprintf(label,256,chcoded,wlabel);
 
 1878                  if (label[
first] == 
'.') { 
 
 1879                     strncpy(chtemp, 
"0",256);
 
 1880                     strlcat(chtemp, &label[
first],256);
 
 1881                     strncpy(label, chtemp,256);
 
 1882                     first = 1; last = strlen(label);
 
 1884                  if (label[
first] == 
'-' && label[
first+1] == 
'.') {
 
 1885                     strncpy(chtemp, 
"-0",256);
 
 1886                     strlcat(chtemp, &label[
first+1],256);
 
 1887                     strncpy(label, chtemp, 256);
 
 1888                     first = 1; last = strlen(label);
 
 1893                     char *adot = strchr(label,
'.');
 
 1894                     if (adot) adot[ndecimals] = 0;
 
 1896                     while (label[last] == 
'0') { label[last] = 0; last--;}
 
 1900                  if (label[last] == 
'.') {
 
 1901                     if (!optionDot) { label[last] = 0; last--;}
 
 1906                                      && label[last]  == 
'0') {
 
 1907                     strncpy(label, 
"0", 256);
 
 1915                  timed = wlabel + (int)(timeoffset) - rangeOffset;
 
 1916                  timelabel = (time_t)((
Long_t)(timed));
 
 1917                  if (optionTime == 1) {
 
 1918                     utctis = localtime(&timelabel);
 
 1920                     utctis = gmtime(&timelabel);
 
 1923                  if (timeformat.
Length() < 220) timeformattmp = timeformat;
 
 1924                  else timeformattmp = 
"#splitline{Format}{too long}";
 
 1930                     snprintf(label, 256, 
"%%S%7.5f", modf(timed,&tmpdb));
 
 1931                     tmplast = strlen(label)-1;
 
 1934                     while (label[tmplast] == 
'0') {
 
 1935                        label[tmplast] = 0; tmplast--;
 
 1944                  if (utctis != 
nullptr) {
 
 1945                     strftime(label, 256, timeformattmp.
Data(), utctis);
 
 1947                     strncpy(label, 
"invalid", 256);
 
 1949                  strncpy(chtemp, &label[0], 256);
 
 1950                  first = 0; last=strlen(label)-1;
 
 1951                  wlabel = wTimeIni + (k+1)*dwlabel;
 
 1956               if (optionNoopt && !optionInt)
 
 1957                        Rotate (xlabel,ylabel,cosphi,sinphi,x0,y0,xx,yy);
 
 1958               else     Rotate (xlabel,ylabel,cosphi,sinphi,xx0,yy0,xx,yy);
 
 1959               if (y0 == y1 && !optionDown && !optionUp) {
 
 1960                  yy -= 0.80*charheight;
 
 1963                  if (x0 != 
x1 && y0 != y1) {
 
 1964                     if (optionNoopt && !optionInt)
 
 1965                           Rotate (xlabel,0,cosphi,sinphi,x0,y0,xx,yy);
 
 1966                     else  Rotate (xlabel,0,cosphi,sinphi,xx0,yy0,xx,yy);
 
 1967                     if (cosphi > 0 ) yy += ylabel;
 
 1968                     if (cosphi < 0 ) yy -= ylabel;
 
 1971               if (!optionY || (x0 == 
x1)) {
 
 1973                     if (
first > last)  strncpy(chtemp, 
" ", 256);
 
 1974                     else               strncpy(chtemp, &label[
first], 255);
 
 1977                     if (!optionTime) typolabel.
ReplaceAll(
"-", 
"#minus");
 
 2000                  if (!optionText)     lnlen = last-
first+1;
 
 2002                     if (k+1 > nhilab) lnlen = 0;
 
 2004                  for ( 
l=1; 
l<=lnlen; 
l++) {
 
 2005                     if (!optionText) *chtemp = label[
first+
l-2];
 
 2007                        if (lnlen == 0) strncpy(chtemp, 
" ", 256);
 
 2008                        else            strncpy(chtemp, 
"1", 256);
 
 2017                     yy -= charheight*1.3;
 
 2024            if (flexe && !optionText && nexe)  {
 
 2025               snprintf(label,256,
"#times10^{%d}", nexe);
 
 2026               if (x0 != 
x1) { xfactor = axis_length+0.1*charheight; yfactor = 0; }
 
 2027               else          { xfactor = y1-y0+0.1*charheight; yfactor = 0; }
 
 2028               Rotate (xfactor,yfactor,cosphi,sinphi,x0,y0,xx,yy);
 
 2054   if (optionLog && ndiv) {
 
 2055      UInt_t xi1=0,xi2=0,wi=0,yi1=0,yi2=0,
hi=0,xl=0,xh=0;
 
 2057      if ((wmin == wmax) || (ndiv == 0))  {
 
 2058         Error(where, 
"wmin (%f) == wmax (%f), or ndiv == 0", wmin, wmax);
 
 2062         Error(where, 
"negative logarithmic axis");
 
 2066         Error(where, 
"negative logarithmic axis");
 
 2070      if (xmnlog > 0) xmnlog += 1.E-6;
 
 2071      else            xmnlog -= 1.E-6;
 
 2076      if (h2 > 0) h2 += 1.E-6;
 
 2081      axmul  = (x11-x00)/(h2sav-xmnlog);
 
 2086      if ( xmnlog > 0 && (xmnlog-
Double_t(ih1) > 0) ) labelnumber++;
 
 2087      Int_t changelablogid  = 0;
 
 2088      Int_t changelablognum = 0;
 
 2089      for (j=1; j<=nbinin; j++) {
 
 2094         if (x0 == 
x1 && j == 1) ylabel += charheight*0.33;
 
 2095         if (y0 == y1 && j == 1) ylabel -= charheight*0.65;
 
 2096         xone = x00+axmul*(
Double_t(decade)-xmnlog);
 
 2098         if (j < 0) printf(
"j=%d\n",j);
 
 2099         if (x00 > xone) 
goto L160;
 
 2100         if ((xone-x11)>
epsilon) 
break;
 
 2103         if (!mside) 
y -= atick[0];
 
 2104         Rotate(xone,
y,cosphi,sinphi,x0,y0,xpl2,ypl2);
 
 2105         Rotate(xtwo,atick[0],cosphi,sinphi,x0,y0,xpl1,ypl1);
 
 2107            if ((x0 != 
x1) && (y0 != y1)) {
 
 2110                  if (cosphi > 0) ypl1 = ypl2 + atick[0];
 
 2111                  else            ypl1 = ypl2 - atick[0];
 
 2114                  xpl1 = 0.5*(xpl1 + xpl2);
 
 2116                  ypl1 = 0.5*(ypl1 + ypl2) + atick[0];
 
 2117                  ypl2 = 0.5*(ypl1 + ypl2) - atick[0];
 
 2121         if (!drawGridOnly) 
PaintLineNDC(xpl1, ypl1, xpl2, ypl2);
 
 2124            Rotate(xone,0,cosphi,sinphi,x0,y0,xpl2,ypl2);
 
 2125            Rotate(xone,grid_side*gridlength,cosphi,sinphi,x0,y0,xpl1,ypl1);
 
 2129         if (!drawGridOnly && !optionUnlab)  {
 
 2136               while (last > 
first) {
 
 2137                  if (label[last] != 
'0') 
break;
 
 2141               if (label[last] == 
'.') {label[last] = 0; last--;}
 
 2143               snprintf(label,256, 
"%d", labelnumber);
 
 2146            Rotate (xone,ylabel,cosphi,sinphi,x0,y0,xx,yy);
 
 2147            if ((x0 == 
x1) && !optionPara) {
 
 2150                     if (labelnumber == 0) nch=1;
 
 2152                     xx    += nch*charheight;
 
 2154                     xx += 0.25*charheight;
 
 2157               xx += 0.25*charheight;
 
 2159            if ((y0 == y1) && !optionDown && !optionUp) {
 
 2160               if (noExponent) yy += 0.33*charheight;
 
 2162            if (n1a == 0)
goto L210;
 
 2164            if (kmod == 0) kmod=1000000;
 
 2165            if ((nbinin <= n1a) || (j == 1) || (j == nbinin) || ((nbinin > n1a) && (j%kmod == 0))) {
 
 2166               if (labelnumber == 0) {
 
 2168               } 
else if (labelnumber == 1) {
 
 2172                     chtemp = &label[
first];
 
 2174                     snprintf(chtemp,256, 
"10^{%d}", labelnumber);
 
 2178                  if (changelablogid  == 0) changelablognum = nbinin-j;
 
 2198         for (k=2;k<10;k++) {
 
 2202            if (x00 > xone) 
continue;
 
 2203            if (xone > x11) 
goto L200;
 
 2205            if (!mside)  
y -= atick[1];
 
 2207            Rotate(xone,
y,cosphi,sinphi,x0,y0,xpl2,ypl2);
 
 2208            Rotate(xtwo,atick[1],cosphi,sinphi,x0,y0,xpl1,ypl1);
 
 2210               if ((x0 != 
x1) && (y0 != y1)) {
 
 2213                     if (cosphi > 0) ypl1 = ypl2 + atick[1];
 
 2214                     else            ypl1 = ypl2 - atick[1];
 
 2217                     xpl1 = 0.5*(xpl1+xpl2);
 
 2219                     ypl1 = 0.5*(ypl1+ypl2) + atick[1];
 
 2220                     ypl2 = 0.5*(ypl1+ypl2) - atick[1];
 
 2225            if ((nbinin <= idn) || ((nbinin > idn) && (k == 5))) {
 
 2226               if (!drawGridOnly) 
PaintLineNDC(xpl1, ypl1, xpl2, ypl2);
 
 2230               if (moreLogLabels && !optionUnlab && !drawGridOnly && !overlap) {
 
 2235                     if (labelnumber-1 == 0) {
 
 2237                     } 
else if (labelnumber-1 == 1) {
 
 2240                        snprintf(chtemp,256, 
"%d#times10^{%d}", k, labelnumber-1);
 
 2243                  Rotate (xone,ylabel,cosphi,sinphi,x0,y0,xx,yy);
 
 2244                  if ((x0 == 
x1) && !optionPara) {
 
 2247                           if (labelnumber == 0) nch=1;
 
 2249                           xx    += nch*charheight;
 
 2251                           if (labelnumber >= 0) xx    += 0.25*charheight;
 
 2252                           else                  xx    += 0.50*charheight;
 
 2255                     xx += 0.25*charheight;
 
 2257                  if ((y0 == y1) && !optionDown && !optionUp) {
 
 2258                     if (noExponent) yy += 0.33*charheight;
 
 2261                     if ((x0 != 
x1) && (y0 != y1)) {
 
 2262                        Rotate(xone,ylabel,cosphi,sinphi,x0,y0,xx,yy);
 
 2263                        if (cosphi > 0) yy += ylabel;
 
 2272                     xi1 = 
gPad->XtoAbsPixel(u);
 
 2273                     yi1 = 
gPad->YtoAbsPixel(
v);
 
 2279                     xi2 = 
gPad->XtoAbsPixel(u);
 
 2280                     yi2 = 
gPad->YtoAbsPixel(
v);
 
 2283                     if ((x0 == 
x1 && yi1-
hi <= yi2) || (y0 == y1 && xl+wi >= xh)){
 
 2297               if (optionGrid && nbinin <= 5 && ndiv > 100) {
 
 2298                  Rotate(xone,0,cosphi,sinphi,x0,y0,xpl2, ypl2);
 
 2299                  Rotate(xone,grid_side*gridlength,cosphi,sinphi,x0,y0, xpl1,ypl1);
 
 2310   if (!drawGridOnly && strlen(
GetTitle())) {
 
 2314         charheight = charheight/
gPad->GetWh();
 
 2318            if (toffset) ylabel = xlside*charheight+toffset;
 
 2319            else         ylabel = xlside*1.6*charheight;
 
 2321            ylabel = xlside*1.6*charheight*toffset;
 
 2324        ylabel = xlside*1.3*charheight*toffset;
 
 2328         ylabel = xlside*1.6*charheight*toffset;
 
 2332      else                              axispos = axis_length;
 
 2351      Rotate(axispos,ylabel,cosphi,sinphi,x0,y0,xpl1,ypl1);
 
 2362   if (optionGrid) 
delete linegrid;
 
 2381   if (binWidth <= 1) { binWidth = 1; binLow = int(A1); }
 
 2385      binLow   = int(A1/binWidth)*binWidth;
 
 2391         for (
Int_t ic=0; ic<1000; ic++) {
 
 2393            Int_t   ibl = int(binLow/binWidth);
 
 2394            if ( (rbl-ibl) == 0 || ic > 
width) { binLow -= 5; 
break;}
 
 2401   while (xb <= binHigh) {
 
 2405   binHigh = xb - binWidth;
 
 2413   last = strlen(label)-1;
 
 2414   for (
Int_t i=0; i<=last; i++) {
 
 2415      if (strchr(
"1234567890-+.", label[i]) ) { 
first = i; 
return; }
 
 2417   Error(
"LabelsLimits", 
"attempt to draw a blank label");
 
 2441   out<<
"gaxis = new TGaxis("<<
fX1<<
","<<
fY1<<
","<<
fX2<<
","<<
fY2 
 2443   out<<
"   gaxis->SetLabelOffset("<<
GetLabelOffset()<<
");"<<std::endl;
 
 2444   out<<
"   gaxis->SetLabelSize("<<
GetLabelSize()<<
");"<<std::endl;
 
 2445   out<<
"   gaxis->SetTickSize("<<
GetTickSize()<<
");"<<std::endl;
 
 2446   out<<
"   gaxis->SetGridLength("<<
GetGridLength()<<
");"<<std::endl;
 
 2447   out<<
"   gaxis->SetTitleOffset("<<
GetTitleOffset()<<
");"<<std::endl;
 
 2448   out<<
"   gaxis->SetTitleSize("<<
GetTitleSize()<<
");"<<std::endl;
 
 2449   out<<
"   gaxis->SetTitleColor("<<
GetTextColor()<<
");"<<std::endl;
 
 2450   out<<
"   gaxis->SetTitleFont("<<
GetTextFont()<<
");"<<std::endl;
 
 2453      out<<
"   gaxis->SetName("<<quote<<
GetName()<<quote<<
");"<<std::endl;
 
 2456      out<<
"   gaxis->SetTitle("<<quote<<
GetTitle()<<quote<<
");"<<std::endl;
 
 2462         out<<
"   gaxis->SetLabelColor(ci);" << std::endl;
 
 2464         out<<
"   gaxis->SetLabelColor("<<
GetLabelColor()<<
");"<<std::endl;
 
 2469         out<<
"   gaxis->SetLineColor(ci);" << std::endl;
 
 2471         out<<
"   gaxis->SetLineColor("<<
GetLineColor()<<
");"<<std::endl;
 
 2474      out<<
"   gaxis->SetLineStyle("<<
GetLineStyle()<<
");"<<std::endl;
 
 2477      out<<
"   gaxis->SetLineWidth("<<
GetLineWidth()<<
");"<<std::endl;
 
 2480      out<<
"   gaxis->SetLabelFont("<<
GetLabelFont()<<
");"<<std::endl;
 
 2483      out<<
"   gaxis->SetMoreLogLabels();"<<std::endl;
 
 2486      out<<
"   gaxis->SetNoExponent();"<<std::endl;
 
 2489   out<<
"   gaxis->Draw();"<<std::endl;
 
 2517      Error(
"SetFunction", 
"unknown function: %s", funcname);
 
 2616      if (labNum < 0) labNum = nlabels + labNum + 2;
 
 2727   if (timeformat.
Index(
"%F")>=0 || timeformat.
IsNull()) {
 
 2759   timeoff = (time_t)((
Long_t)(toffset));
 
 2763   utctis = gmtime(&timeoff);
 
 2765   if (utctis != 
nullptr) {
 
 2766      strftime(tmp, 20,
"%Y-%m-%d %H:%M:%S",utctis);
 
 2805void TGaxis::Streamer(
TBuffer &R__b)
 
 2815      TLine::Streamer(R__b);
 
 2816      TAttText::Streamer(R__b);
 
 2831      fName.Streamer(R__b);
 
static const double x2[5]
static const double x1[5]
static RooMathCoreReg dummy
include TDocParser_001 C image html pict1_TDocParser_001 png width
static Double_t SavedTextAngle
Change the label attributes of label number i.
static Int_t SavedTextFont
static Int_t SavedTextAlign
static Double_t SavedTextSize
static Int_t SavedTextColor
float type_of_call hi(const int &, const int &)
Binding & operator=(OUT(*fun)(void))
R__EXTERN TStyle * gStyle
virtual Color_t GetTitleColor() const
virtual Color_t GetLabelColor() const
virtual Color_t GetAxisColor() const
virtual Style_t GetTitleFont() const
virtual Float_t GetLabelOffset() const
virtual Style_t GetLabelFont() const
virtual Float_t GetTitleSize() const
virtual Float_t GetLabelSize() const
virtual Float_t GetTickLength() const
virtual Float_t GetTitleOffset() const
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.
Width_t fLineWidth
Line width.
virtual void SetLineColor(Color_t lcolor)
Set the line color.
virtual Style_t GetLineStyle() const
Return the line style.
Style_t fLineStyle
Line style.
Color_t fLineColor
Line color.
virtual Float_t GetTextSize() const
Return the text size.
virtual void SetTextAlign(Short_t align=11)
Set the text alignment.
virtual Short_t GetTextAlign() const
Return the text alignment.
virtual Font_t GetTextFont() const
Return the text font.
Color_t fTextColor
Text color.
Float_t fTextAngle
Text angle.
virtual Color_t GetTextColor() const
Return the text color.
virtual void SetTextAngle(Float_t tangle=0)
Set the text angle.
virtual Float_t GetTextAngle() const
Return the text angle.
virtual void SetTextColor(Color_t tcolor=1)
Set the text color.
virtual void SetTextFont(Font_t tfont=62)
Set the text font.
Font_t fTextFont
Text font.
virtual void SetTextSize(Float_t tsize=1)
Set the text size.
Short_t fTextAlign
Text alignment.
Float_t fTextSize
Text size.
TAxis helper class used to store the modified labels.
void SetColor(Int_t c=-1)
Set modified label color.
void SetSize(Double_t s=-1.)
Set modified label size.
void SetFont(Int_t f=-1)
Set modified label font.
void SetText(TString t="")
Set modified label text.
void SetAlign(Int_t a=-1)
Set modified label alignment.
void SetLabNum(Int_t n=0)
Set modified label number.
void SetAngle(Double_t a=-1.)
Set modified label angle.
Class to manage histogram axis.
virtual Double_t GetBinCenter(Int_t bin) const
Return center of bin.
const char * GetBinLabel(Int_t bin) const
Return label for bin.
Bool_t GetDecimals() const
Int_t GetLast() const
Return last bin on the axis i.e.
TList * GetModifiedLabels() const
virtual const char * GetTimeFormat() const
const char * GetTitle() const
Returns title of object.
Int_t GetFirst() const
Return first bin on the axis i.e.
THashList * GetLabels() const
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
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
static void SaveColor(std::ostream &out, Int_t ci)
Save a color with index > 228 as a C++ statement(s) on output stream out.
virtual Double_t GetXmax() const
virtual Double_t Eval(Double_t x, Double_t y=0, Double_t z=0, Double_t t=0) const
Evaluate this function.
virtual Double_t GetXmin() const
static Int_t fgMaxDigits
! Number of digits above which the 10>N notation is used
virtual void Paint(Option_t *chopt="")
Draw this axis with its current attributes.
virtual void SetNoExponent(Bool_t noExponent=kTRUE)
Set the NoExponent flag.
void SetTimeFormat(const char *tformat)
Change the format used for time plotting.
virtual void PaintAxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax, Double_t &wmin, Double_t &wmax, Int_t &ndiv, Option_t *chopt="", Double_t gridlength=0, Bool_t drawGridOnly=kFALSE)
Control function to draw an axis.
static Float_t fYAxisExpYOffset
! Exponent Y offset for the Y axis
TGaxis()
TGaxis default constructor.
void SetTitleOffset(Float_t titleoffset=1)
Float_t fTitleSize
Size of title in NDC.
Float_t GetGridLength() const
void SetLabelFont(Int_t labelfont)
void SetTitleSize(Float_t titlesize)
Float_t fTitleOffset
Offset of title wrt axis.
TString fTitle
Axis title.
Int_t fLabelFont
Font for labels.
virtual void SetTitle(const char *title="")
Change the title of the axis.
Int_t fLabelColor
Color for labels.
TAxis * fAxis
! Pointer to original TAxis axis (if any)
TString fTimeFormat
Time format, ex: 09/12/99 12:34:00.
TString fFunctionName
Name of mapping function pointed by fFunction.
void SetLabelOffset(Float_t labeloffset)
virtual void Rotate(Double_t X, Double_t Y, Double_t CFI, Double_t SFI, Double_t XT, Double_t YT, Double_t &U, Double_t &V)
Internal method to rotate axis coordinates.
virtual const char * GetTitle() const
Returns title of object.
Float_t GetLabelOffset() const
void SetTimeOffset(Double_t toffset, Option_t *option="local")
Change the time offset. If option = "gmt", set display mode to GMT.
Float_t fTickSize
Size of primary tick mark in NDC.
static Float_t fYAxisExpXOffset
! Exponent X offset for the Y axis
virtual void ImportAxisAttributes(TAxis *axis)
Internal method to import TAxis attributes to this TGaxis.
Int_t GetLabelFont() const
Float_t fLabelOffset
Offset of label wrt axis.
static Float_t fXAxisExpYOffset
! Exponent Y offset for the X axis
static void SetMaxDigits(Int_t maxd=5)
Static function to set fgMaxDigits for axis.
Float_t fLabelSize
Size of labels in NDC.
Int_t fNdiv
Number of divisions.
void ChangeLabelAttributes(Int_t i, Int_t nlabels, TLatex *t, char *c)
TString fChopt
Axis options.
TGaxis & operator=(const TGaxis &)
Assignment operator.
Float_t GetTitleOffset() const
TF1 * fFunction
! Pointer to function computing axis values
void ChangeLabel(Int_t labNum=0, Double_t labAngle=-1., Double_t labSize=-1., Int_t labAlign=-1, Int_t labColor=-1, Int_t labFont=-1, TString labText="")
Define new text attributes for the label number "labNum".
Float_t GetTitleSize() const
static Int_t GetMaxDigits()
Static function returning fgMaxDigits (See SetMaxDigits).
virtual void CenterLabels(Bool_t center=kTRUE)
If center = kTRUE axis labels are centered in the center of the bin.
void SetLabelColor(Int_t labelcolor)
virtual const char * GetName() const
Returns name of object.
virtual void AdjustBinSize(Double_t A1, Double_t A2, Int_t nold, Double_t &BinLow, Double_t &BinHigh, Int_t &nbins, Double_t &BinWidth)
Internal method for axis labels optimisation.
virtual void DrawAxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax, Double_t wmin, Double_t wmax, Int_t ndiv=510, Option_t *chopt="", Double_t gridlength=0)
Draw this axis with new attributes.
Float_t fGridLength
Length of the grid in NDC.
Int_t GetLabelColor() const
virtual void SetDecimals(Bool_t dot=kTRUE)
Set the decimals flag.
virtual void CenterTitle(Bool_t center=kTRUE)
If center = kTRUE axis title will be centered. The default is right adjusted.
virtual void SavePrimitive(std::ostream &out, Option_t *option="")
Save primitive as a C++ statement(s) on output stream out.
virtual ~TGaxis()
TGaxis default destructor.
TList * fModLabs
List of modified labels.
Double_t fWmax
Highest value on the axis.
Float_t GetTickSize() const
virtual void SetMoreLogLabels(Bool_t more=kTRUE)
Set the kMoreLogLabels bit flag.
void SetTickSize(Float_t ticksize)
Int_t fNModLabs
Number of modified labels.
Double_t fWmin
Lowest value on the axis.
void SetLabelSize(Float_t labelsize)
void SetFunction(const char *funcname="")
Specify a function to map the axis values.
static Float_t fXAxisExpXOffset
! Exponent X offset for the X axis
virtual void SetName(const char *name)
Change the name of the axis.
static void SetExponentOffset(Float_t xoff=0., Float_t yoff=0., Option_t *axis="xy")
Static function to set X and Y offset of the axis 10^n notation.
void LabelsLimits(const char *label, Int_t &first, Int_t &last)
Internal method to find first and last character of a label.
void ResetLabelAttributes(TLatex *t)
Reset the label attributes to the value they have before the last call to ChangeLabelAttributes.
Float_t GetLabelSize() const
void SetOption(Option_t *option="")
To set axis options.
static void Optimize(Double_t A1, Double_t A2, Int_t nold, Double_t &BinLow, Double_t &BinHigh, Int_t &nbins, Double_t &BWID, Option_t *option="")
Static function to compute reasonable axis limits.
To draw Mathematical Formula.
Double_t GetXsize()
Return size of the formula along X in pad coordinates.
void GetBoundingBox(UInt_t &w, UInt_t &h, Bool_t angle=kFALSE)
Return text size in pixels.
virtual void PaintLatex(Double_t x, Double_t y, Double_t angle, Double_t size, const char *text)
Main drawing function.
Double_t fY1
Y of 1st point.
Double_t fX1
X of 1st point.
Double_t fX2
X of 2nd point.
TLine & operator=(const TLine &src)
Assignment operator.
Double_t fY2
Y of 2nd point.
virtual void PaintLineNDC(Double_t u1, Double_t v1, Double_t u2, Double_t v2)
Draw this line with new coordinates in NDC.
virtual void Add(TObject *obj)
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
virtual const char * GetName() const
Returns name of object.
Mother of all ROOT objects.
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.
@ kCanDelete
if object in a list can be deleted
void ToLower()
Change string to lower-case.
const char * Data() const
TString & ReplaceAll(const TString &s1, const TString &s2)
TString & Remove(Ssiz_t pos)
TString & Append(const char *cs)
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
Double_t GetTimeOffset() const
Color_t GetGridColor() const
Style_t GetGridStyle() const
Float_t GetTitleOffset(Option_t *axis="X") const
Return title offset.
Width_t GetGridWidth() const
Int_t GetStripDecimals() const
virtual void SetText(Double_t x, Double_t y, const char *text)
static time_t MktimeFromUTC(tm_t *tmstruct)
Equivalent of standard routine "mktime" but using the assumption that tm struct is filled with UTC,...
double beta(double x, double y)
Calculates the beta function.
static constexpr double s
static constexpr double mm
Short_t Max(Short_t a, Short_t b)
Double_t ATan2(Double_t, Double_t)
Double_t Sqrt(Double_t x)
LongDouble_t Power(LongDouble_t x, LongDouble_t y)
Short_t Min(Short_t a, Short_t b)
Double_t Log10(Double_t x)