Jpp 19.3.0-rc.2
the software that should make you happy
Loading...
Searching...
No Matches
JOmega2D.cc
Go to the documentation of this file.
1
2#include <string>
3#include <iostream>
4#include <iomanip>
5#include <cmath>
6
7#include "TROOT.h"
8#include "TFile.h"
9#include "TH1D.h"
10#include "TRandom3.h"
11
12#include "JMath/JConstants.hh"
13#include "JTools/JQuantile.hh"
14#include "JTools/JRange.hh"
15#include "JROOT/JRootToolkit.hh"
16
18
19#include "Jeep/JParser.hh"
20#include "Jeep/JMessage.hh"
21
22
23/**
24 * \file
25 *
26 * Example program to test JGEOMETRY2D::JOmega2D class.
27 * \author mdejong
28 */
29int main(int argc, char**argv)
30{
31 using namespace std;
32 using namespace JPP;
33
34 string outputFile;
35 int numberOfEvents;
36 JRange<double> range_Deg;
37 int debug;
38
39 try {
40
41 JParser<> zap("Example program to test JOmega2D class.");
42
43 zap['o'] = make_field(outputFile) = "";
44 zap['n'] = make_field(numberOfEvents) = 1000;
45 zap['G'] = make_field(range_Deg) = JRange<double>(0.5, 10.5);
46 zap['d'] = make_field(debug) = 3;
47
48 zap(argc, argv);
49 }
50 catch(const exception &error) {
51 FATAL(error.what() << endl);
52 }
53
54
55 const int N = 10;
56
57 TH1D h0("h0[grid", NULL, N, range_Deg.getLowerLimit(), range_Deg.getUpperLimit());
58 TH1D h1("h1[RMS]", NULL, N, range_Deg.getLowerLimit(), range_Deg.getUpperLimit());
59 TH1D h2("h2[deviation]", NULL, N, range_Deg.getLowerLimit(), range_Deg.getUpperLimit());
60
61
62 vector<JOmega2D> omega;
63 vector<JQuantile> quantile;
64
65 for (int i = 1; i <= h0.GetNbinsX(); ++i) {
66
67 const Double_t x = h0.GetBinCenter(i);
68
69 omega .push_back(JOmega2D(x * PI/180.0));
70 quantile.push_back(JQuantile());
71 }
72
73
74 for (int i = 0; i != numberOfEvents; ++i) {
75
76 STATUS("event: " << setw(10) << i << '\r'); DEBUG(endl);
77
78 const double phi = gRandom->Uniform(0.0, 2*PI);
79
80 const JAngle2D angle(phi);
81
82 for (size_t j = 0; j != omega.size(); ++j) {
83
84 const int pos = omega[j].find(angle);
85 const double dot = angle.getDot(omega[j][pos]);
86
87 quantile[j].put(acos(dot) * 180.0/PI);
88 }
89 }
90 STATUS(endl);
91
92
93 for (int i = 1; i <= h0.GetNbinsX(); ++i) {
94 h0.SetBinContent(i, omega [i-1].size());
95 h1.SetBinContent(i, quantile[i-1].getSTDev());
96 h2.SetBinContent(i, quantile[i-1].getDeviation());
97 }
98
99 if (outputFile != "") {
100
101 TFile out(outputFile.c_str(), "recreate");
102
103 out << h0 << h1 << h2;
104
105 out.Write();
106 out.Close();
107 }
108
109 for (int i = 1; i <= h2.GetNbinsX(); ++i) {
110
111 const Double_t x = h2.GetBinCenter (i);
112 const Double_t y = h2.GetBinContent(i);
113
114 NOTICE("Grid test " << x << " [deg]: " << y << " [deg]." << endl);
115 ASSERT(y < x / 2.0);
116 }
117
118 return 0;
119}
string outputFile
Mathematical constants.
General purpose messaging.
#define DEBUG(A)
Message macros.
Definition JMessage.hh:62
#define STATUS(A)
Definition JMessage.hh:63
#define ASSERT(A,...)
Assert macro.
Definition JMessage.hh:90
#define NOTICE(A)
Definition JMessage.hh:64
#define FATAL(A)
Definition JMessage.hh:67
int debug
debug level
Definition JSirene.cc:72
int main(int argc, char **argv)
Definition JOmega2D.cc:29
Utility class to parse command line options.
#define make_field(A,...)
macro to convert parameter to JParserTemplateElement object
Definition JParser.hh:2142
Auxiliary class to define a range between two values.
Data structure for angle in two dimensions.
Definition JAngle2D.hh:35
double getDot(const JAngle2D &angle) const
Get dot product.
Definition JAngle2D.hh:189
Direction set covering (part of) circle.
Definition JOmega2D.hh:62
Utility class to parse command line options.
Definition JParser.hh:1698
Range of values.
Definition JRange.hh:42
T getLowerLimit() const
Get lower limit.
Definition JRange.hh:202
T getUpperLimit() const
Get upper limit.
Definition JRange.hh:213
This name space includes all other name spaces (except KM3NETDAQ, KM3NET and ANTARES).
Auxiliary data structure for running average, standard deviation and quantiles.
Definition JQuantile.hh:46