-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPlot.dox
executable file
·534 lines (381 loc) · 22 KB
/
Plot.dox
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
/*! \mainpage
\tableofcontents
PlottI - Plotting Interface for easy plotting of your data.
\section Canvasses Canvasses
For your perfect plot you first need a Canvas, that will display your beautiful data.
The (virtual) base class Plot includes most basic plotting functionalities. It provides a canvas and a default main pad, as well as basic set up variables such as canvas dimensions.
For your very own plot you should one of the provided derived classes that implement one type of plot, e.g. a simple SquarePlot or a SingleRatioPlot, or derive your own class. The basic dimensions and offsets are already predefined but can be changed manually with the corresponding methods.
You create a canvas by calling the corresponding constructor with one or more TObjArrays containing the objects you want to plot and the corresponding axis titles. After the construction you can adjust your canvas or histogram settings (cf. section \ref cSettings) and plot everything with the Draw method (this will automatically save the canvas with the given name).
\section cSettings Settings for Canvasses
The following options are available for Canvasses:
- Setting canvas dimension, offsets and Margin
- Setting a Mode that will determine text size* and style*
- Setting the draw options*
- Setting color-, marker-, or size arrays* used for Histogram customization (cf. section \ref hSettings)
- Setting the Ranges of the different axis
Settings marked with * are static and will be used for all following canvasses (in your macro) as well until they are manually changed.
\subsection opt Draw Options
The draw options for your plottable objects can be set in various ways via the SetOptions function:
- using only one single option (provided as a std::string) that will be used for all objects
- using a std::vector of std::strings to provide a different option for every object, similar to colors and markers (cf. section \ref hSettings)
- using one std::strings containing options (divided by spaces) and one std::strings containing the positions for which the options will be applied (also divided by spaces). Optionally you can also provide an offset that will be added to each given position.
If you only want to manipulate one option at a time, you can do so via the SetOption function:
- using one std::string containing one option and one std::string containing the position where this option should be applied.
If you don't manually set any options the default option "SAME" will be used.
\section hSettings Settings for Histograms
You can choose the style and colors of the plotted objects by either calling the Set<Object>Properties method on each histogram beforehand or set arrays containing these settings that will be used for all plots (until they are changed) by calling SetStyle.
You can set an offset for the ratio markers, meaning for offset = 2 the first ratio marker will have the properties defined by the third array entry. The default offset is one, assuming that the ratio is to the first histogram in the array then the colors will correspond to those used in the main plot.
In the case that some of your style arrays are empty or don't contain enough elements, default settings for the markers and lines will be used: marker size and line width 2., line style 1 (straight line), marker style kFullCircle and marker color kBlack.
It is also possible to automatically pick colors from a color palette. To do this, use the SetPalette function to choose a palette and draw then set the histogram draw options to "PMC PLC PFC".
\section draw The Draw() Function
Once the canvas is created with the corresponding constructor and you applied all your settings
you can finalise your plot by calling the Draw() function of the class you are using. \n
This function will save the final plot, but it will also delete the canvas from the program
so it is not possible to access it after the Draw() option has been called.
\section legends Legends
The Legend class can be used to automatically create a legend from data or text.
You have the following options
- Generate Legend from
+ a TObjArray with your plottable objects
+ a string containing the entry names like "entry number 1\n entry number 2\n"
+ and a string containing the display options like "lp lp"
- Create an informative Legend containing just text without symbols from
+ a string containing the information to be displayed (entries) like "entry number 1\n entry number 2\n"
+ the number of entries
- Create a legend with dummy markers from
+ a string containing the marker options like "23 23 23\n 24 24 24\n"
+ a string containing the entry names like "entry number 1\n entry number 2\n"
+ a string containing the options like "lp p"
+ the number of entries
- Copy an already existing legend
\remark Unfortunately it is not possible for the second option to use the corresponding enumerators like kBlack for the colors and such, but the actual number has to be used. It is however possible to use functions like Format to print the value of kBlack into a string and then use this string.
\section cols Colors
This interface provides two functionalities for using personalised colors in your plots:
-# The structure \ref color can be used to define colors from RGB values. It includes
an automatically generated ROOT color index.
-# The class \ref ColorGradient can be used to generate a palette (color gradient) from
\ref color endpoints, defined using the above mentioned structure.
For more information on colors and predefined colors and palettes see page \ref colorpage.
\section Additional Functionality
The following additional functionalities are currently available (in the file functionality.h):
- GetXfirstFilledBin: Finds the first bin from the left with content > 0, if all bins (except last) are empty 0 is returned
- GetXlastFilledBin: Finds the first bin from the right with content > 0, if all bins (except first) are empty last bin is returned
- CleanUpHistogram: Sets bin contents of bins with too large uncertainties to zero, for specifics please see documentation.
*/
-----------------------------------------------------------------------------
/**
\image html Square.png "Example of a SquarePlot" width=5cm
Default measures:
- Canvas \c dimensions: \b width = 1000, \b height = 1000
- Canvas \c margins: \b left = 0.15, \b right = 0.07, \b top = 0.07, \b bottom = 0.15
- Canvas \c offsets: \b x-Axis = 1.3, \b y-Axis = 1.5
\class SquarePlot PlotDerived.h
*/
/**
\image html just_ratio.png "Example of a RatioPlot" width=5cm
Default measures:
- Canvas \c dimensions: \b width = 1000, \b height = 600
- Canvas \c margins: \b left = 0.15, \b right = 0.07, \b top = 0.07, \b bottom = 0.25
- Canvas \c offsets: \b x-Axis = 1.0, \b y-Axis = 0.8
\class RatioPlot PlotDerived.h
*/
/**
\image html Ratio.png "Example of a SingleRatioPlot" width=5cm
Default measures:
- Canvas \c dimensions: \b width = 1000, \b height = 1200
- Canvas \c margins: \b left = 0.15, \b right = 0.07, \b top = 0.07, \b bottom = 0.4
- Canvas \c offsets: \b x-Axis = 4.5, \b y-Axis = 1.7
\class SingleRatioPlot PlotDerived.h
*/
/**
\image html heat.png "Example of a HeatMapPlot" width=5cm
Default measures:
- Canvas \c dimensions: \b width = 1000, \b height = 850
- Canvas \c margins: \b left = 0.15, \b right = 0.2, \b top = 0.07, \b bottom = 0.15
- Canvas \c offsets: \b x-Axis = 1.3, \b y-Axis = 1.5, \b z-Axis = 1.5
\class HeatMapPlot PlotDerived.h
*/
/**
This class contains all functions necessary for basic plotting functionality. This way
very little additional programming is necessary for derived classes.
This class is meant to be purely a base for implementing the derived classes and
should not be instanced itself.
\class Plot PlotBase.h
*/
/**
The constructor takes two mandatory arguments:
+ One Int_t that specifies the number of colors the color gradient will have and
+ a vector of RGB colors defined using the \ref color structure.
Optionally you can specify:
+ A vector containing the spacing of the colors and
+ the transparency of the colors
The color gradient can be accessed by calling the methods GetPalette() or GetGradient()
that will return a vector of type Int_t or Color_t respectively. If you are using the
SetPalette() option that PlottI provides you can use the ColorGradient instance directly.
For a full list and preview of PlottI color gradients see \ref prePal
\class ColorGradient Color.h
*/
/**
The Constructor takes 3 Float_t numbers between 0. and 1. corresponding to RGB values.
The values are given in relation to the maximum value of 255. E.g a blue value of 51
would correspond to a relative value of 51/255 = 0.2.\n
The structure \ref color will automatically add the new color to the ROOT colors using
<a href="https://root.cern/doc/master/classTColor.html#a3c5219ffdafddfcd4b020fb9365533af">TColor::GetColor(r, g, b)</a>.
The corresponding ROOT color index can then be accessed via the index parameter of the
structure. \n
For a full list and preview of the PlottI colors see \ref preCols.
\class color Color.h
*/
-----------------------------------------------------------------------
/**
* \page example Examples
\brief Collection of examples for different features of the interface.
\tableofcontents
\section base Basic Layout of Plotting Code
The following example will demonstrate the basic syntax of the interface.
Assume you have two histograms called black and white and a ratio called grey.
~~~~~~~~~~~~~~~{.c}
TH1D* black = new TH1D("black", "", 100, -3, 3);
black->Sumw2();
black->FillRandom("gaus", 10000);
TH1D* white = new TH1D("white", "", 100, -3, 3);
white->Sumw2();
white->FillRandom("gaus", 10000);
TH1D* grey = (TH1D*)black->Clone("grey");
grey->Divide(white);
~~~~~~~~~~~~~~~
First create two object arrays for the main plot and the ratio.
~~~~~~~~~~~~~~~{.c}
TObjArray* main = new TObjArray();
main->Add(black);
main->Add(white);
TObjArray* ratio = new TObjArray();
ratio->Add(grey);
~~~~~~~~~~~~~~~
Now we generate legends for this plot:
~~~~~~~~~~~~~~~{.c}
Legend* l = new Legend(main, "Black Histo\n White Histo\n", "lp lp", "", "l");
Legend* ll = new Legend(l, "ll"); //Copy first legend so that we can place it seperately
TString info = TString("Black and White Histogram\n");
info.Append("Example\n");
TLegend* lInfo = new Legend(info.Data(), 2);
main->Add(lInfo);
~~~~~~~~~~~~~~~
Then we define marker colors and styles.
The ones for the ratios will be added after the ones for the main pad.
~~~~~~~~~~~~~~~{.c}
vector<Color_t> colors = {kBlack, kBlack, kBlack+3};
vector<Style_t> markers = {kFullCircle, kOpenCircle, kFullCircle};
vector<Size_t> sizes = {2., 2., 2.};
~~~~~~~~~~~~~~~
Adjusting the legend position:
~~~~~~~~~~~~~~~{.c}
Legend::SetPosition(lInfo, 0.2, 0.3, 0.85, 0.75); // static function
Legend::SetPosition(l, 0.43, 0.6, 0.2, 0.32);
ll->SetPosition(0.43, 0.6, 0.05, 0.22); // non-static function
~~~~~~~~~~~~~~~
And finally create the Canvasses:
~~~~~~~~~~~~~~~{.c}
SquarePlot square = SquarePlot(main, "x", "count");
square.SetStyle(colors, markers, sizes);
square.SetMode(Plot::Presentation);
square.SetRanges(3, -3, 400, 0);
square.Draw(TString("Square.pdf"));
main->AddBefore(lInfo, ll); // replace l in main with ll
SingleRatioPlot rat = SingleRatioPlot(main, ratio, "x", "count", "ratio");
rat.SetOffset(2); // determines where the ratio entries start in the style arrays
rat.SetRanges(3, -3, 400, -10, 3.2, 0.5);
rat.Draw(TString("Ratio.pdf"));
~~~~~~~~~~~~~~~
Results:
\image html Square.png "Square Plot" width=5cm
\image html Ratio.png "Ratio Plot" width=5cm
\subsection ratioExample RatioPlot
The syntax for a \ref RatioPlot is very similar to that of a SquarePlot:
~~~~~~~~~~~~~~~{.c}
RatioPlot just_the_ratio = RatioPlot(ratio, "x", "ratio");
just_the_ratio.SetOffset(2);
just_the_ratio.SetRanges(-3, 3, 0.5, 3.2);
just_the_ratio.Draw("just_ratio.png");
~~~~~~~~~~~~~~~
\image html just_ratio.png "Example of Ratio Plot using the grey array from above" width=5cm
\subsection heat HeatMapPlot
The syntax for a HeatMapPlot is also quite similar to that of a SquarePlot. The
main difference to a SquarePlot is that the first entry of the array that is to
be plotted must be a TH2.
~~~~~~~~~~~~~~~{.c}
TH2I* heat = new TH2I("heat", "", 20, 1, 20, 20, 1, 20);
for (Int_t binx = 1; binx < 20; binx++){
for (Int_t biny = 1; biny < 20; biny++){
heat->SetBinContent(binx, biny, binx + biny + binx*biny);
}
}
Legend* legend = new Legend("This is a heatmap!\n", 1);
legend->SetPosition(0.2, 0.75, 0.8, 0.87);
TObjArray* heatArray = new TObjArray();
heatArray->Add(heat);
heatArray->Add(legend);
HeatMapPlot heatMap = HeatMapPlot(heatArray, "X", "Y", "Z");
heatMap.SetRanges(0, 20, 0, 20, 1, 1E3);
heatMap.SetPalette(kPastel, kTRUE);
heatMap.SetLog(kFALSE, kFALSE, kTRUE);
heatMap.Draw("heat.png");
~~~~~~~~~~~~~~~
\image html heat.png "Example of a HeatMapPlot" width=5cm
\section colorExample Defining Colors and Color Gradients
Before defining the colors, we define some histograms we can use for testing:
~~~~~~~~~~~~~~~{.c}
TObjArray* pal = new TObjArray();
TObjArray* indices = new TObjArray();
palette[0] = new TH1I("palette", "", 20, 1, 20);
pal->Add(palette[0]);
for (Int_t bin = 1; bin < palette[0]->GetNbinsX(); bin++){
palette[0]->SetBinContent(bin, 1);
palette[0]->SetBinError(bin, 0.00001);
}
for (Int_t hist = 1; hist < 20; hist++){
palette[hist] = (TH1I*)palette[0]->Clone(Form("palette_%d", hist));
palette[hist]->Scale(hist+1);
pal->Add(palette[hist]);
}
indices->Add(palette[0]);
indices->Add(palette[1]);
indices->Add(palette[2]);
~~~~~~~~~~~~~~~
Colors can then be defined as follows:
~~~~~~~~~~~~~~~{.c}
color blue {0.00, 0.00, 1.00};
color green {0.00, 1.00, 0.00};
color red {1.00, 0.00, 0.00};
~~~~~~~~~~~~~~~
The ROOT color index of these colors can then be accessed by the index attribute of color:
~~~~~~~~~~~~~~~{.c}
Color_t index_of_color_blue = blue.index;
Color_t index_of_color_red = red.index;
Color_t index_of_color_green = green.index;
~~~~~~~~~~~~~~~
This color index can then be used like any other ROOT color index:
~~~~~~~~~~~~~~~{.c}
vector<Style_t> markersPal (20, kFullCircle);
vector<Size_t> sizesPal (20, 3.);
TMarker* marker = new TMarker();
Plot::SetMarkerProperties(marker, blue.index, kFullSquare, 3.);
std::vector<Color_t> RGB_Colors = {blue.index, red.index, green.index};
SquarePlot indices_usage = SquarePlot(indices, "", "");
indices_usage.SetStyle(RGB_Colors, markersPal, sizesPal);
indices_usage.SetRanges(0, 20, 0, 4);
indices_usage.Draw("indices.png");
~~~~~~~~~~~~~~~
\image html indices.png "Example: Usage of user defined colors with color indices" width=5cm
Color gradients can be defined from \ref color points via the ColorGradient class as follows:
~~~~~~~~~~~~~~~{.c}
vector<color> rgbRainbow = {blue, green, red};
ColorGradient rainbow = ColorGradient(20, rgbRainbow);
vector<Double_t> spacing = {0., 0.8, 1.};
ColorGradient blue_green_somered = ColorGradient(20, rgbRainbow, spacing);
~~~~~~~~~~~~~~~
They can be used either directly as the color array or set as the current palette:
~~~~~~~~~~~~~~~{.c}
vector<Color_t> colors_rainbow = rgb_rainbow.GetGradient();
SquarePlot direct_usage = SquarePlot(pal, "", "");
direct_usage.SetMode(Plot::Presentation);
direct_usage.SetStyle(colors_rainbow, markersPal, sizesPal);
direct_usage.SetRanges(0, 20, 0, 21);
direct_usage.SetOptions("SAME");
direct_usage.Draw("direct.png");
SquarePlot palette_usage = SquarePlot(pal, "", "");
palette_usage.SetRanges(0, 20, 0, 21);
palette_usage.SetPalette(blue_green_somered, kFALSE);
palette_usage.SetOptions("SAME PMC PLC PFC");
palette_usage.Draw("palette.png");
~~~~~~~~~~~~~~~
\image html direct.png "Example: Usage of user defined palette \c colors_rainbow via color vector" width=5cm
\image html palette.png "Example: Usage of user defined palette \c blue_green_somered via ColorGradient" width=5cm
\section legendExample Legend Usage
Generate a legend from a TObjArray:
~~~~~~~~~~~~~~~{.c}
TLegend* lIndices = new Legend(indices, "First Histogram\n Second\n and Third", "lp lp lp", "", 3,"indices");
indices->Add(lIndices);
~~~~~~~~~~~~~~~
Or with dummy markers from a string with marker specifications:
~~~~~~~~~~~~~~~{.c}
std::string marker_information = Form("%d %d %f \n %d %d %f \n %d %d %f", kBlack, kFullCircle, 3., kBlue+2, kFullSquare, 3., kMagenta+2, kFullDiamond, 4.);
TLegend* lDummyMarkers = new Legend(marker_information.data(), "Black Full Circle\n Blue Full Square\n Magenta Full Diamond", "lp p lp", 3, "lDummyMarkers");
indices->Add(lDummyMarkers);
~~~~~~~~~~~~~~~
Or a legend containing information about your plot:
~~~~~~~~~~~~~~~{.c}
TLegend* lInformation = new Legend("Some information \n about your histograms \n or your data", 3, "lInformation");
indices->Add(lInformation);
~~~~~~~~~~~~~~~
Each legend can be placed individually:
~~~~~~~~~~~~~~~{.c}
Legend::SetPosition(lIndices, 0.45, 0.8, 0.4, 0.55);
Legend::SetPosition(lDummyMarkers, 0.45, 0.8, 0.6, 0.75);
Legend::SetPosition(lInformation, 0.2, 0.21, 0.77, 0.87);
~~~~~~~~~~~~~~~
And plotted by adding them to the array:
~~~~~~~~~~~~~~~{.c}
SquarePlot legends = SquarePlot(indices, "", "");
legends.SetRanges(0, 20, 0, 21);
legends.SetPalette(kAvocado);
legends.SetOptions("SAME PMC PLC PFC");
legends.Draw("legends.png");
~~~~~~~~~~~~~~~
\image html legends.png "Example: Different Methods for defining a legend" width=5cm
*/
/**
* \page colorpage Colors
\brief Predefined colors and palettes included in PlottI.
\tableofcontents
\section colsinroot Predefined Colors in ROOT
In ROOT every seperately usable color (namely when you aren't using the palette option) is collected in the
<a href="https://root.cern/doc/master/classTColorWheel.html">TColorWheel</a>. Since the colors are grouped
by hue and each segment vary only in their brightness and intensity, I feel that you are supposed to (or at least try)
to only use colors with the same modifier in one plot. I therefore rearranged the colors in a way, that you can
see all the colors with the same modifier in a palette like way.
\image html mix.png "Mixed Colors" width=5cm
\image html bas.png "Base Colors" width=5cm
There are also a number of predefined Palettes in ROOT listed in the
<a href="https://root.cern/doc/master/classTColor.html#C06">TColor class documentation</a>.
The <a href="https://root.cern/doc/master/classTHistPainter.html#HP061">THistPainter class documentation</a>
explains in detail how to automatically pick colors from a palette. It also lists all
the different draw options that can be used for Histograms and functions.
\section preCols Colors in PlottI
Personalised colors can be defined using the \ref color structure. The Constructor takes
3 Float_t numbers between 0. and 1. corresponding to RGB values. The values are given
in relation to the maximum value of 255. E.g a blue value of 51 would correspond to a
relative value of 51/255 = 0.2.\n
The structure \ref color will automatically add the new color to the ROOT colors using
<a href="https://root.cern/doc/master/classTColor.html#a3c5219ffdafddfcd4b020fb9365533af">TColor::GetColor(r, g, b)</a>.
The corresponding ROOT color index can then be accessed via the index parameter of the
structure. \n
\subsection preColsList Predefined Colors
The following colors are already defined in PlottI and can be used individually or in
the definition of a color gradient:
\image html basic_colors.png "Some basic colors." width=15cm
\n
\image html alice_logo_colors.png "Colors extracted from the ALICE logo" width=15cm
\n
\image html citrus_colors.png "Colors close to citrus fruit" width = 15cm
\n
\image html ocean_colors.png "Colors resembling different oceans" width = 15cm
\section prePal Color Gradients in PlottI
Personalised color gradients can be defined using the \ref ColorGradient class. The
constructor takes two mandatory arguments:
+ One Int_t that specifies the number of colors the color gradient will have and
+ a vector of RGB colors defined using the \ref color structure.
Optionally you can specify:
+ A vector containing the spacing of the colors and
+ the transparency of the colors
The color gradient can be accessed by calling the methods GetPalette() or GetGradient()
that will return a vector of type Int_t or Color_t respectively. If you are using the
SetPalette() option that PlottI provides you can use the ColorGradient instance directly.
\subsection prePalList Predefined Color Gradients
The following color gradients are already included in PlottI:
\image html alice_logo.png "Palette: alice_logo -- Modeled after the colors used in the ALICE logo -- 100 colors" width=15cm
\image html rainbow.png "Palette: rainbow -- Simple rainbow palette -- 20 colors" width=15cm
\image html purple_to_yellow.png "Palette: purple_to_yellow -- Color gradient from purple to yellow -- 100 colors" width=15cm
\image html citrus.png "Palette: citrus -- Citrus colors -- 100 colors" width = 15cm
\image html ocean.png "Palette: ocean -- Gradient from deep arctic ocean to warm caribbean ocean -- 100 colors" width = 15cm
*/