448 latex.TLatex::Copy(*
this);
458 TAttLine::operator=(
lt);
555 const char *
tab[] = {
"alpha",
"beta",
"chi",
"delta",
"varepsilon",
"phi",
"gamma",
"eta",
"iota",
"varphi",
"kappa",
"lambda",
556 "mu",
"nu",
"omicron",
"pi",
"theta",
"rho",
"sigma",
"tau",
"upsilon",
"varomega",
"omega",
"xi",
"psi",
"zeta",
557 "Alpha",
"Beta",
"Chi",
"Delta",
"Epsilon",
"Phi",
"Gamma",
"Eta",
"Iota",
"vartheta",
558 "Kappa",
"Lambda",
"Mu",
"Nu",
"Omicron",
"Pi",
"Theta",
"Rho",
"Sigma",
"Tau",
559 "Upsilon",
"varsigma",
"Omega",
"Xi",
"Psi",
"Zeta",
"varUpsilon",
"epsilon"};
561 const char *
tab2[] = {
"leq",
"/",
"infty",
"voidb",
"club",
"diamond",
"heart",
562 "spade",
"leftrightarrow",
"leftarrow",
"uparrow",
"rightarrow",
563 "downarrow",
"circ",
"pm",
"doublequote",
"geq",
"times",
"propto",
564 "partial",
"bullet",
"divide",
"neq",
"equiv",
"approx",
"3dots",
565 "cbar",
"topbar",
"downleftarrow",
"aleph",
"Jgothic",
"Rgothic",
"voidn",
566 "otimes",
"oplus",
"oslash",
"cap",
"cup",
"supset",
"supseteq",
567 "notsubset",
"subset",
"subseteq",
"in",
"notin",
"angle",
"nabla",
568 "oright",
"ocopyright",
"trademark",
"prod",
"surd",
"upoint",
"corner",
"wedge",
569 "vee",
"Leftrightarrow",
"Leftarrow",
"Uparrow",
"Rightarrow",
570 "Downarrow",
"diamond",
"LT",
"void1",
"copyright",
"void3",
"sum",
571 "arctop",
"lbar",
"arcbottom",
"topbar",
"void8",
"bottombar",
"arcbar",
572 "ltbar",
"AA",
"aa",
"void06",
"GT",
"int",
"forall",
"exists" };
574 const char *
tab3[] = {
"bar",
"vec",
"dot",
"hat",
"ddot",
"acute",
"grave",
"check",
"tilde",
"slash"};
580 Int_t min = 0, max = 0;
598 if (t[i] ==
'{' && !(i>0 && t[i-1] ==
'@'))
nBrackets++;
599 if (t[i] ==
'}' && t[i-1]!=
'@')
nBrackets--;
624 Error(
"Analyse",
"It seems there is a syntax error in the TLatex string");
697 if (
text[i+1]!=
'{' && !(
text[i+2]==
'{' && (
text[i+1]==
'^' ||
text[i+1]==
'_'))
766 if (
strncmp(buf,
"splitline{",10)==0) {
812 if (
strncmp(buf,
"frac{",5)==0) {
876 if (
strncmp(buf,
"{}{",3)==0 ) {
1018 pos = (
m-
fs1.Width())/2;
1035 if (min >= 2 &&
strncmp(&
text[min-2],
"{}",2)==0) {
1095 if (
fs2.Width()>
fs1.Width())
1142 if (
fs2.Width()>
fs1.Width())
1201 hbar.SetTextFont(12);
1205 hbar.SetTextAlign(11);
1220 minus.SetTextFont(122);
1224 minus.SetTextAlign(11);
1238 plus.SetTextFont(122);
1242 plus.SetTextAlign(11);
1256 mp.SetTextFont(122);
1257 mp.SetTextColor(
spec.fColor);
1258 mp.SetTextSize(
spec.fSize);
1260 mp.SetTextAlign(11);
1263 mp.PaintText(
xx,
yy,
"\261");
1291 bs.SetTextColor(
spec.fColor);
1292 bs.SetTextSize(
spec.fSize);
1294 bs.SetTextAlign(11);
1297 bs.PaintText(
xx,
yy,
"\\");
1343 if (
gVirtualX->InheritsFrom(
"TGCocoa")) {
1394 yy[0] =
yy[1] =
y - sub -
fs1.Over();
1421 xx[1] =
x +
fs1.Width()/2;
1422 xx[0] =
xx[1] -
fs1.Width()/3;
1423 xx[2] =
xx[1] +
fs1.Width()/3;
1424 yy[0] =
y - sub -
fs1.Over();
1425 yy[1] =
yy[0] - 2*sub;
1432 midx =
x +
fs1.Width()/2 - 1.5*sub,
1437 midx =
x +
fs1.Width()/2 + 1.5*sub;
1445 xx[0] =
x +
fs1.Width()/2;
xx[1] =
xx[0] + 3*sub;
1446 yy[0] =
y - sub -
fs1.Over();
1447 yy[1] =
yy[0] - 2.5*sub;
1453 xx[0] =
x +
fs1.Width()/2 + sub;
xx[1] =
xx[0] - 2*sub;
1454 yy[0] =
y - sub -
fs1.Over();
1455 yy[1] =
yy[0] - 2*sub;
1461 xx[1] =
x+
fs1.Width()/2;
xx[0] =
xx[1] - 2*sub;
xx[2] =
xx[1] + 2*sub;
1462 yy[1] =
y - sub -
fs1.Over();
1463 yy[0] =
yy[2] =
yy[1] - 2*sub;
1474 if (
gVirtualX->InheritsFrom(
"TGCocoa"))
y2 -= 4.7*sub;
1481 tilde.SetTextAlign(22);
1495 xx[0] =
x + 0.8*
fs1.Width();
1496 yy[0] =
y -
fs1.Over() - sub;
1497 xx[1] =
x + 0.3*
fs1.Width();
1498 yy[1] =
yy[0] +
fs1.Height() + 2*sub;
1572 l8 =
fs1.Height()/8 ;
1579 l8 =
fs1.Height()/8 ;
1610 fError =
"Missing denominator for #frac";
1624 if (
fs1.Width()<
fs2.Width()) {
1643 fError =
"Missing second line for #splitline";
1719 fError =
"Missing color number. Syntax is #color[(Int_t)nb]{ ... }";
1730 fError =
"Invalid color number. Syntax is #color[(Int_t)nb]{ ... }";
1744 fError =
"Missing font number. Syntax is #font[nb]{ ... }";
1755 fError =
"Invalid font number. Syntax is #font[(Int_t)nb]{ ... }";
1769 fError =
"Missing horizontal shift number. Syntax is #kern[dx]{ ... }";
1780 fError =
"Invalid horizontal shift number. Syntax is #kern[(Float_t)dx]{ ... }";
1799 fError =
"Missing vertical shift number. Syntax is #lower[dy]{ ... }";
1810 fError =
"Invalid vertical shift number. Syntax is #lower[(Float_t)dy]{ ... }";
1829 fError =
"Missing scale factor. Syntax is #scale[(Double_t)nb]{ ... }";
1840 fError =
"Invalid scale factor. Syntax is #factor[(Double_t)nb]{ ... }";
1854 Int_t lut[] = {3, 13, 1, 6, 7, 4, 5, 10, 11, 8, 9, 12, 2, 14, 15};
1880 Int_t lut[] = {13, 3, 2, 5, 4, 7, 6, 9, 8, 11, 10, 15, 1, 14, 12};
1908 for (i=0 ; i<
leng ; i++) {
1914 if (
text[i] ==
'@') {
1916 if ( *(
p+1) ==
'{' || *(
p+1) ==
'}' || *(
p+1) ==
'[' || *(
p+1) ==
']') {
2038 for (
Int_t i = 0; i <=
np; i++) {
2068 for (
Int_t i = 0; i <=
np; i++) {
2172 t.
ReplaceAll(
"#splitline",
"\\genfrac{}{}{0pt}{}");
2204 newText.ReplaceAll(
"#hbox",
"#mbox");
2208 std::cout<<
"\n*ERROR<TLatex>: "<<
fError<<std::endl;
2209 std::cout<<
"==> "<<
text1<<std::endl;
2277 std::cout<<
"*ERROR<TLatex>: "<<
fError<<std::endl;
2278 std::cout<<
"==> "<<
text<<std::endl;
2284 case 0:
y -=
fs.Under();
break;
2286 case 2:
y +=
fs.Height()*0.5-
fs.Under() + 1.;
break;
2287 case 3:
y +=
fs.Over();
break;
2290 case 2:
x -=
fs.Width()/2;
break;
2291 case 3:
x -=
fs.Width();
break;
2315 const Char_t *
kWord1[] = {
"{}^{",
"{}_{",
"^{",
"_{",
"#scale{",
"#color{",
"#font{",
"#sqrt{",
"#[]{",
"#{}{",
"#||{",
2316 "#bar{",
"#vec{",
"#dot{",
"#hat{",
"#ddot{",
"#acute{",
"#grave{",
"#check{",
"#tilde{",
"#slash{",
"#bf{",
"#it{",
"#mbox{",
2317 "\\scale{",
"\\color{",
"\\font{",
"\\sqrt{",
"\\[]{",
"\\{}{",
"\\||{",
"#(){",
"\\(){",
2318 "\\bar{",
"\\vec{",
"\\dot{",
"\\hat{",
"\\ddot{",
"\\acute{",
"\\grave{",
"\\check{",
"\\bf{",
"\\it{",
"\\mbox{"};
2319 const Char_t *
kWord2[] = {
"#scale[",
"#color[",
"#font[",
"#sqrt[",
"#kern[",
"#lower[",
"\\scale[",
"\\color[",
"\\font[",
"\\sqrt[",
"\\kern[",
"\\lower["};
2320 const Char_t *
kWord3[] = {
"#frac{",
"\\frac{",
"#splitline{",
"\\splitline{"};
2321 const Char_t *
kLeft1[] = {
"#left[",
"\\left[",
"#left{",
"\\left{",
"#left|",
"\\left|",
"#left(",
"\\left("};
2322 const Char_t *
kLeft2[] = {
"#[]{",
"#[]{",
"#{}{",
"#{}{",
"#||{",
"#||{",
"#(){",
"#(){"};
2323 const Char_t *kRight[] = {
"#right]",
"\\right]",
"#right}",
"\\right}",
"#right|",
"\\right|",
"#right)",
"\\right)"};
2324 const Int_t lkWord1[] = {4,4,2,2,7,7,6,6,4,4,4,5,5,5,5,6,7,7,7,7,7,4,4,6,7,7,6,6,4,4,4,4,4,5,5,5,5,6,7,7,7,4,4,6};
2325 const Int_t lkWord2[] = {7,7,6,6,6,7,7,7,6,6,6,7} ;
2336 Char_t buf[11] ;
for (i=0;i<11;i++) buf[i]=0;
2354 for (k = 0 ; k <
nLeft1 ; k++) {
2377 fError =
"Operators \"#left\" and \"#right\" don't match !" ;
2381 for (k = 0 ; k <
nLeft1 ; k++) {
2384 for (k = 0 ; k <
nRight ; k++) {
2450 else if (
text[i] ==
']' ) {
2451 text.Insert(i,
"@") ;
2455 else if (
text[i] ==
'[' ) {
2456 text.Insert(i,
"@") ;
2460 else if (
text[i] ==
'{' ) {
2461 text.Insert(i,
"@") ;
2465 else if (
text[i] ==
'}' ) {
2470 text.Insert(i,
"@") ;
2482 fError =
"Invalid number of \"]{\"" ;
2486 fError =
"Error in syntax of \"#frac\"" ;
2490 fError =
"Missing \"{\"" ;
2494 fError =
"Missing \"}\"" ;
2498 fError =
"Missing \"[\"" ;
2502 fError =
"Missing \"]\"" ;
2547 if (!
gPad)
return 0.;
2562 if (!
gPad)
return 0.;
2564 if(
newText.Length() == 0)
return 0;
2567 if (
newText.Contains(
"\\") ) {
2569 return tm.GetXsize();
2574 std::cout<<
"\n*ERROR<TLatex>: "<<
fError<<std::endl;
2575 std::cout<<
"==> "<<
GetTitle()<<std::endl;
2585 return std::abs(
gPad->AbsPixeltoX(
fs.Width()) -
gPad->AbsPixeltoX(0));
2595 if(
newText.Length() == 0)
return;
2598 if (
newText.Contains(
"\\") ) {
2600 tm.GetBoundingBox(
w,
h);
2606 std::cout<<
"\n*ERROR<TLatex>: "<<
fError<<std::endl;
2607 std::cout<<
"==> "<<
GetTitle()<<std::endl;
2627 for (
Int_t i=1; i<4; i++) {
2650 if (!
gPad)
return 0.;
2652 if(
newText.Length() == 0)
return 0;
2655 if (
newText.Contains(
"\\") ) {
2657 return tm.GetYsize();
2662 std::cout<<
"\n*ERROR<TLatex>: "<<
fError<<std::endl;
2663 std::cout<<
"==> "<<
GetTitle()<<std::endl;
2673 return std::abs(
gPad->AbsPixeltoY(
fs.Height()) -
gPad->AbsPixeltoY(0));
2682 Error(
"Readfs",
"No data in fTabSize stack");
2705 out,
Class(),
"tex",
2712 out <<
" tex->SetNDC();\n";
size_t size(const MatrixT &matrix)
retrieve the size of a square matrix
int Int_t
Signed integer 4 bytes (int)
char Char_t
Character 1 byte (char)
unsigned int UInt_t
Unsigned integer 4 bytes (unsigned int)
float Float_t
Float 4 bytes (float)
short Short_t
Signed Short integer 2 bytes (short)
double Double_t
Double 8 bytes.
const char Option_t
Option string (const char)
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t SetLineWidth
Option_t Option_t SetTextSize
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t np
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h prop
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t result
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h length
Option_t Option_t SetLineColor
Option_t Option_t TPoint TPoint const char x2
Option_t Option_t TPoint TPoint const char x1
Option_t Option_t SetTextFont
Option_t Option_t TPoint TPoint angle
Option_t Option_t TPoint TPoint const char y2
Option_t Option_t TPoint TPoint const char DrawLine
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize fs
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t height
Option_t Option_t TPoint TPoint const char text
Option_t Option_t TPoint TPoint const char y1
R__EXTERN TVirtualPS * gVirtualPS
Fill Area Attributes class.
virtual Color_t GetLineColor() const
Return the line color.
virtual Width_t GetLineWidth() const
Return the line width.
virtual void Modify()
Change current line attributes if necessary.
void Copy(TAttLine &attline) const
Copy this line attributes to a new TAttLine.
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 Float_t GetTextSize() const
Return the text size.
virtual void Modify()
Change current text attributes if necessary.
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.
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.
Font_t fTextFont
Text font.
virtual void SaveTextAttributes(std::ostream &out, const char *name, Int_t alidef=12, Float_t angdef=0, Int_t coldef=1, Int_t fondef=61, Float_t sizdef=1)
Save text attributes as C++ statement(s) on output stream out.
virtual Float_t GetTextSizePercent(Float_t size)
Return the text in percent of the pad size.
Short_t fTextAlign
Text alignment.
void Copy(TAttText &atttext) const
Copy this text attributes to a new TAttText.
To draw Mathematical Formula.
virtual void SetLimitIndiceSize(Int_t limitFactorSize)
Set limit for text resizing of subscripts and superscripts.
Double_t GetXsize()
Return size of the formula along X in pad coordinates when the text precision is smaller than 3.
void Rotate(TVirtualPad *pad, Double_t angle, Int_t np, Double_t *x, Double_t *y)
Rotate array of points around fX, fY coordinate by specified angle.
Double_t GetHeight() const
Return height of current pad in pixels.
void Copy(TObject &text) const override
Copy this TLatex object to another TLatex.
Double_t fFactorPos
! Relative position of subscripts and superscripts
Int_t fLimitFactorSize
lower bound for subscripts/superscripts size
void DrawLine(Double_t x1, Double_t y1, Double_t x2, Double_t y2, const TextSpec_t &spec)
Draw a line in a Latex formula.
TLatexFormSize Anal1(const TextSpec_t &spec, const Char_t *t, Int_t length)
Analyse function.
void DrawParenthesis(Double_t x1, Double_t y1, Double_t r1, Double_t r2, Double_t phimin, Double_t phimax, const TextSpec_t &spec)
Draw an arc of ellipse in a Latex formula (right or left parenthesis)
virtual void SetIndiceSize(Double_t factorSize)
Set relative size of subscripts and superscripts.
std::vector< TLatexFormSize > fTabSize
! array of values for the different zones
Int_t PaintLatex1(Double_t x, Double_t y, Double_t angle, Double_t size, const char *text)
Drawing function.
Double_t fOriginSize
Font size of the starting font.
Double_t GetYsize()
Return size of the formula along Y in pad coordinates when the text precision is smaller than 3.
TLatexFormSize FirstParse(Double_t angle, Double_t size, const Char_t *text)
First parsing of the analyse sequence.
TLatexFormSize Readfs()
Read fs in fTabSize.
void GetBoundingBox(UInt_t &w, UInt_t &h, Bool_t angle=kFALSE) override
Return text size in pixels.
@ kTextNDC
The text position is in NDC coordinates.
TLatex * DrawLatexNDC(Double_t x, Double_t y, const char *text)
Draw this TLatex with new coordinates in NDC.
void DrawCircle(Double_t x1, Double_t y1, Double_t r, const TextSpec_t &spec)
Draw an arc of ellipse in a Latex formula (right or left parenthesis)
virtual void PaintLatex(Double_t x, Double_t y, Double_t angle, Double_t size, const char *text)
Main drawing function.
TLatex()
Default constructor.
Bool_t fShow
! is true during the second pass (Painting)
~TLatex() override
Destructor.
void SavePrimitive(std::ostream &out, Option_t *option="") override
Save primitive as a C++ statement(s) on output stream out.
TLatex & operator=(const TLatex &)
assignment operator
void DrawPolyLine(Int_t npoints, Double_t *xx, Double_t *yy, const TextSpec_t &spec, Double_t scale_width=0.)
Draw a poly line in a Latex formula Is scale_width parameter >=1, fill area will be drawn Otherwise l...
TLatex * DrawLatex(Double_t x, Double_t y, const char *text)
Make a copy of this object with the new parameters And copy object attributes.
Double_t fFactorSize
! Relative size of subscripts and superscripts
const Char_t * fError
! error code
Bool_t fItalic
! Currently inside italic operator
void Paint(Option_t *option="") override
Paint.
TLatexFormSize Analyse(Double_t x, Double_t y, const TextSpec_t &spec, const Char_t *t, Int_t length)
Analyse and paint the TLatex formula.
Int_t CheckLatexSyntax(TString &text)
Check if the Latex syntax is correct.
void Savefs(TLatexFormSize *fs)
Save fs values in array fTabSize.
To draw TeX Mathematical Formula.
const char * GetTitle() const override
Returns title of object.
Mother of all ROOT objects.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
static void SavePrimitiveDraw(std::ostream &out, const char *variable_name, Option_t *option=nullptr)
Save invocation of primitive Draw() method Skipped if option contains "nodraw" string.
static void SavePrimitiveConstructor(std::ostream &out, TClass *cl, const char *variable_name, const char *constructor_agrs="", Bool_t empty_line=kTRUE)
Save object constructor in the output stream "out".
@ kCanDelete
if object in a list can be deleted
const char * Data() const
TString & ReplaceAll(const TString &s1, const TString &s2)
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
Base class for several text objects.
Double_t fY
Y position of text (left,center,etc..)
void Copy(TObject &text) const override
Copy this text to text.
TText & operator=(const TText &src)
Assignment operator.
Double_t fX
X position of text (left,center,etc..)
virtual void GetTextExtent(UInt_t &w, UInt_t &h, const char *text) const
Return text extent for string text.
virtual void GetTextAscentDescent(UInt_t &a, UInt_t &d, const char *text) const
Return text ascent and descent for string text.
virtual void GetControlBox(Int_t x, Int_t y, Double_t theta, Int_t cBoxX[4], Int_t cBoxY[4])
Return the text control box.
TVirtualPS is an abstract interface to Postscript, PDF, SVG.
virtual void Text(Double_t x, Double_t y, const char *string)=0
TVirtualPad is an abstract base class for the Pad and Canvas classes.
Int_t Nint(T x)
Round to nearest integer. Rounds half integers to the nearest even integer.
Double_t Exp(Double_t x)
Returns the base-e exponential function of x, which is e raised to the power x.
Double_t Log(Double_t x)
Returns the natural logarithm of x.
Short_t Min(Short_t a, Short_t b)
Returns the smallest of a and b.
Double_t Cos(Double_t)
Returns the cosine of an angle of x radians.
Double_t Sin(Double_t)
Returns the sine of an angle of x radians.
TLatex helper struct holding the attributes of a piece of text.