9 #include <top/calibration/TOPModuleT0DeltaTAlgorithm.h>
10 #include <top/dbobjects/TOPCalModuleT0.h>
16 #include <TMatrixDSym.h>
17 #include <TDecompChol.h>
31 TOPModuleT0DeltaTAlgorithm::TOPModuleT0DeltaTAlgorithm():
43 auto slotPairs = getObjectPtr<TH2F>(
"slots");
45 B2ERROR(
"TOPModuleT0DeltaTAlgorithm: histogram 'slots' not found");
52 string expNo = to_string(expRun[0].first);
53 while (expNo.length() < 4) expNo.insert(0,
"0");
54 string runNo = to_string(expRun[0].second);
55 while (runNo.length() < 5) runNo.insert(0,
"0");
56 string outputFileName =
"moduleT0_rough-e" + expNo +
"-r" + runNo +
".root";
57 auto* file = TFile::Open(outputFileName.c_str(),
"recreate");
63 std::vector<double> deltaT0;
64 std::vector<double> sigma;
65 std::vector<std::vector<double> > A;
66 auto* chi2Fits =
new TH2F(
"chi2_of_fits",
"normalized chi2 of succesfull fits",
67 16, 0.5, 16.5, 16, 0.5, 16.5);
68 chi2Fits->SetXTitle(
"first slot number");
69 chi2Fits->SetYTitle(
"second slot number");
73 for (
int i = 0; i < slotPairs->GetNbinsX(); i++) {
74 for (
int k = 0; k < slotPairs->GetNbinsY(); k++) {
75 if (slotPairs->GetBinContent(i + 1, k + 1) <
m_minEntries)
continue;
76 int slot1 = slotPairs->GetXaxis()->GetBinCenter(i + 1);
77 int slot2 = slotPairs->GetYaxis()->GetBinCenter(k + 1);
78 string name =
"deltaT0_" + to_string(slot1) +
"-" + to_string(slot2);
79 auto h = getObjectPtr<TH1F>(name);
82 if (status != 0)
continue;
86 std::vector<double> a(16, 0);
90 chi2Fits->SetBinContent(i + 1, k + 1,
m_chi2 /
m_ndf);
96 A.push_back(std::vector<double>(16, 1));
98 sigma.push_back(0.001);
102 int m = deltaT0.size();
107 B2INFO(
"TOPModuleT0DeltaTAlgorithm: NDF < 0");
114 for (
int i = 0; i < 16; i++) {
115 for (
int j = 0; j < 16; j++) {
116 for (
int k = 0; k < m; k++) {
117 B[i][j] += A[k][i] * A[k][j] / (sigma[k] * sigma[k]);
125 bool ok = C.Invert(B);
129 B2INFO(
"TOPModuleT0DeltaTAlgorithm: matrix is not positive definite");
135 std::vector<double> b(16, 0);
136 for (
int i = 0; i < 16; i++) {
137 for (
int k = 0; k < m; k++) {
138 b[i] += A[k][i] * deltaT0[k] / (sigma[k] * sigma[k]);
144 std::vector<double> x(16, 0);
145 std::vector<double> e(16, 0);
146 for (
int i = 0; i < 16; i++) {
147 for (
int j = 0; j < 16; j++) {
148 x[i] += B[i][j] * b[j];
150 e[i] =
sqrt(B[i][i]);
156 for (
int k = 0; k < m; k++) {
158 for (
int i = 0; i < 16; i++) {
161 chi2 += pow((s - deltaT0[k]) / sigma[k], 2);
168 ss <<
"Module T0, chi^2/NDF = " << chi2 <<
"/" << ndf;
169 string title = ss.str();
171 auto* h_moduleT0 =
new TH1F(
"moduleT0", title.c_str(), 16, 0.5, 16.5);
172 h_moduleT0->SetXTitle(
"slot number");
173 h_moduleT0->SetYTitle(
"module T0 [ns]");
174 for (
int i = 0; i < 16; i++) {
175 h_moduleT0->SetBinContent(i + 1, x[i]);
176 h_moduleT0->SetBinError(i + 1, e[i]);
193 for (
int i = 0; i < 16; i++) {
194 moduleT0->setT0(i + 1, x[i], e[i]);
196 moduleT0->suppressAverage();
205 int numEntries = h->GetSumOfWeights();
219 double sum = h->GetSumOfWeights();
220 if (sum < 5)
return 5;
221 double maxPosition = h->GetBinCenter(h->GetMaximumBin());
222 double binWidth = h->GetBinWidth(1);
223 double xmin = h->GetXaxis()->GetXmin();
224 double xmax = h->GetXaxis()->GetXmax();
226 auto* func =
new TF1(
"func1g",
227 "[0] + [1]/sqrt(2*pi)/[3]*exp(-0.5*((x-[2])/[3])**2)",
229 func->SetParameter(0, 0);
230 func->SetParameter(1, sum * binWidth);
231 func->SetParameter(2, maxPosition);
234 int status = h->Fit(func,
"LERSQ");
236 m_delT0 = func->GetParameter(2);
237 m_error = func->GetParError(2);
238 m_chi2 = func->GetChisquare();
239 m_ndf = func->GetNDF();
247 double sum = h->GetSumOfWeights();
248 if (sum < 7)
return 7;
249 double maxPosition = h->GetBinCenter(h->GetMaximumBin());
250 double binWidth = h->GetBinWidth(1);
251 double xmin = h->GetXaxis()->GetXmin();
252 double xmax = h->GetXaxis()->GetXmax();
254 auto* func =
new TF1(
"func2g",
255 "[0] + [1]*((1-[4])/sqrt(2*pi)/[3]*exp(-0.5*((x-[2])/[3])**2)"
256 "+ [4]/sqrt(2*pi)/[5]*exp(-0.5*((x-[2])/[5])**2))",
258 func->SetParameter(0, 0);
259 func->SetParameter(1, sum * binWidth);
260 func->SetParameter(2, maxPosition);
265 int status = h->Fit(func,
"LERSQ");
267 m_delT0 = func->GetParameter(2);
268 m_error = func->GetParError(2);
269 m_chi2 = func->GetChisquare();
270 m_ndf = func->GetNDF();
Base class for calibration algorithms.
void saveCalibration(TClonesArray *data, const std::string &name)
Store DBArray payload with given name with default IOV.
void setDescription(const std::string &description)
Set algorithm description (in constructor)
EResult
The result of calibration.
@ c_OK
Finished successfuly =0 in Python.
@ c_NotEnoughData
Needs more data =2 in Python.
@ c_Failure
Failed =3 in Python.
const std::vector< Calibration::ExpRun > & getRunList() const
Get the list of runs for which calibration is called.
Module T0 calibration constants for all 16 modules.
int fitDoubleGaus(std::shared_ptr< TH1F > h)
Fit double gaus w/ same mean + constant.
int m_minEntries
minimal number of histogram entries to perform fit
double m_delT0
fitted delta T0
virtual EResult calibrate() final
algorithm implementation
int fitHistogram(std::shared_ptr< TH1F > h)
Fit histogram.
double m_chi2
chi2 of the fit
int m_cutoffEntries
cutoff entries for single/double gaussian fit
double m_sigmaTailInit
tail gaussian sigma [ns]
double m_minError
minimal moduleT0 uncertainty [ns] to declare c_OK
double m_ndf
NDF of the fit.
double m_tailFractInit
fraction of tail gaussian
double m_error
error on fitted delta T0
double m_sigmaCoreInit
core gaussian sigma [ns]
int fitSingleGaus(std::shared_ptr< TH1F > h)
Fit single gaus + constant.
double sqrt(double a)
sqrt for double
Abstract base class for different kinds of events.