30 #include <TRotation.h>
32 #include <TObjString.h>
40 #include <Eigen/Dense>
45 #include <tracking/calibration/BeamSpotStandAlone.h>
46 #include <tracking/calibration/Splitter.h>
47 #include <tracking/calibration/tools.h>
49 #include <BeamSpotStandAlone.h>
54 using Eigen::VectorXd;
55 using Eigen::Vector3d;
56 using Eigen::MatrixXd;
57 using Eigen::Matrix3d;
60 namespace Belle2::BeamSpotCalib {
63 inline double sqrS(
double x) {
return x >= 0 ? x * x : -x * x; }
64 inline double sqrtS(
double x) {
return x >= 0 ?
sqrt(x) : -
sqrt(-x); }
66 MatrixXd getRotatedSizeMatrix(std::vector<double> xySize,
double zzSize,
double kX,
double kY);
98 SpotParam(
const std::vector<double>& vals,
const std::vector<double>& errs,
const std::vector<std::vector<double>>& spls,
101 auto getSize = [order](
const std::vector<double>& sp) {
106 B2ASSERT(
"There must be least one node at this place", sp.size() >= 1);
107 return int(sp.size() + 1);
108 }
else if (order == 1) {
109 B2ASSERT(
"Must be at least two nodes in lin. spline", sp.size() >= 2);
110 return int(sp.size());
112 B2FATAL(
"Unknown order");
117 int nx = getSize(spls[0]);
118 int ny = getSize(spls[1]);
126 if (spls.size() >= 4) {
127 int nkx = getSize(spls[2]);
128 int nky = getSize(spls[3]);
137 if (spls.size() >= 5) {
138 int nz = getSize(spls[4]);
140 z.
vals =
slice(vals, nx + ny + nkx + nky, nz);
141 z.
errs =
slice(errs, nx + ny + nkx + nky, nz);
160 int nNd =
spls[0].vals.size();
161 for (
int k = 0; k < nNd; ++k) {
162 double s = 0, ss = 0;
163 for (
unsigned i = 0; i <
spls.size(); ++i) {
164 s +=
spls[i].vals[k];
168 for (
unsigned i = 0; i <
spls.size(); ++i) {
169 ss += pow(
spls[i].vals[k] - s, 2);
190 double indx = (
spls.size() - 1) * v;
191 int nNd =
spls[0].vals.size();
192 for (
int k = 0; k < nNd; ++k) {
193 std::vector<double> vals;
194 for (
unsigned i = 0; i <
spls.size(); ++i) {
195 vals.push_back(
spls[i].vals[k]);
197 sort(vals.begin(), vals.end());
201 sLim.
vals[k] = vals[I] * (1 - r) + vals[I + 1] * r;
220 B2ASSERT(
"Must be at least one replica",
vars.size() >= 1);
221 return accumulate(
vars.begin(),
vars.end(), 0.) /
vars.size();
227 B2ASSERT(
"Must be at least one replica",
vars.size() >= 1);
241 B2ASSERT(
"Must be at least one replica",
vars.size() >= 1);
242 double indx = (
vars.size() - 1) * v;
246 return vars[I] * (1 - r) +
vars[I + 1] * r;
252 B2ASSERT(
"Must be at least one replica",
vars.size() >= 1);
271 double getAngle(
double SizeX,
double SizeY,
double SizeXY)
273 double C = sqrS(SizeXY);
276 double angle = 1. / 2 * atan2(2 * C, (pow(SizeX, 2) - pow(SizeY, 2)));
287 std::pair<double, double> getSizeMinMax(
double SizeX,
double SizeY,
double SizeXY)
289 double A = pow(SizeX, 2) + pow(SizeY, 2);
290 double B = pow(SizeX, 2) * pow(SizeY, 2) - pow(SizeXY, 4);
291 double D = pow(A, 2) - 4 * B;
294 B2FATAL(
"Problem with D value : " << D);
297 double Size2Min = 2 * B / (A +
sqrt(D));
298 if (abs(Size2Min) < 1e-7) Size2Min = 0;
300 B2FATAL(
"Negative BS eigen size : " << Size2Min);
302 double Size2Max = (A +
sqrt(D)) / 2;
303 return {sqrtS(Size2Min), sqrtS(Size2Max)};
313 double getSize2MinMat(
double SizeXX,
double SizeYY,
double SizeXY)
315 double A = SizeXX + SizeYY;
316 double B = SizeXX * SizeYY - pow(SizeXY, 2);
317 double D = pow(A, 2) - 4 * B;
320 B2FATAL(
"Problem with D value : " << D);
323 double Size2Min = 2 * B / (A +
sqrt(D));
359 void add(
SpotParam sPar,
double SizeX,
double SizeY,
double SizeXY,
double SizeZ)
375 double SizeMin, SizeMax;
376 std::tie(SizeMin, SizeMax) = getSizeMinMax(SizeX, SizeY, SizeXY);
382 double angle = 1e3 * getAngle(SizeX, SizeY, SizeXY);
388 MatrixXd matSize = getRotatedSizeMatrix({sqrS(SizeX), sqrS(SizeY), sqrS(SizeXY)}, sqrS(SizeZ), sPar.
kX.
val(sPar.
kX.
center()),
402 double crossAngleVal = 1e3 * 2 * sqrtS(matSize(0, 0)) / sqrtS(matSize(2, 2));
436 void getOutput(std::vector<VectorXd>& vtxPos, std::vector<MatrixXd>& vtxErr, MatrixXd& sizeMat)
439 int nVals =
x.
spls[0].vals.size();
444 const double toCm = 1e-4;
446 for (
int i = 0; i < nVals; ++i) {
448 Vector3d vtx(
x.
spls[0].vals[i]*toCm,
y.
spls[0].vals[i]*toCm,
z.
spls[0].vals[i]*toCm);
451 Matrix3d mS = Matrix3d::Zero();
452 mS(0, 0) = sqrS(
x.
spls[0].errs[i] * toCm);
453 mS(1, 1) = sqrS(
y.
spls[0].errs[i] * toCm);
454 mS(2, 2) = sqrS(
z.
spls[0].errs[i] * toCm);
456 vtxPos.push_back(vtx);
457 vtxErr.push_back(mS);
462 sizeMat.resize(3, 3);
463 sizeMat(0, 0) = sqrS(
matXX.
vars[0] * toCm);
464 sizeMat(1, 1) = sqrS(
matYY.
vars[0] * toCm);
465 sizeMat(2, 2) = sqrS(
matZZ.
vars[0] * toCm);
467 sizeMat(0, 1) = sqrS(
matXY.
vars[0] * toCm);
468 sizeMat(0, 2) = sqrS(
matXZ.
vars[0] * toCm);
469 sizeMat(1, 2) = sqrS(
matYZ.
vars[0] * toCm);
471 sizeMat(1, 0) = sizeMat(0, 1);
472 sizeMat(2, 0) = sizeMat(0, 2);
473 sizeMat(2, 1) = sizeMat(1, 2);
480 T->Branch(n, &vec->at(0), n +
"/D");
481 T->Branch(n +
"_low", &vec->at(1), n +
"_low/D");
482 T->Branch(n +
"_high", &vec->at(2), n +
"_high/D");
488 T->Branch(n +
"_nodes", &spl->
nodes);
489 T->Branch(n +
"_vals", &spl->
vals);
490 T->Branch(n +
"_errs", &spl->
errs);
499 TTree* T =
new TTree(
"runs",
"beam conditions of runs");
502 T->Branch(
"run", &run,
"run/I");
567 double getZIPest(
const Track& tr,
double t,
const SpotParam& spotPar,
int nestMax = 5,
int nest = 0)
570 if (nest < nestMax) {
571 double zIP = getZIPest(tr, t, spotPar, nestMax, nest + 1);
573 x0 = spotPar.x.val(t) + spotPar.kX.val(t) * (zIP - spotPar.z.val(t));
574 y0 = spotPar.y.val(t) + spotPar.kY.val(t) * (zIP - spotPar.z.val(t));
576 x0 = spotPar.x.val(t);
577 y0 = spotPar.y.val(t);
580 double f0 = tr.tanlambda * (x0 * cos(tr.phi0) + y0 * sin(tr.phi0));
592 double getCorrD(
const Track& tr,
double t,
const SpotParam& spotPar)
594 double zIP = getZIPest(tr, t, spotPar);
596 double x0 = spotPar.x.val(t) + spotPar.kX.val(t) * (zIP - spotPar.z.val(t));
597 double y0 = spotPar.y.val(t) + spotPar.kY.val(t) * (zIP - spotPar.z.val(t));
599 double f0 = x0 * sin(tr.phi0) - y0 * cos(tr.phi0);
605 double getDtimeConst(
const Track& tr,
double t,
const SpotParam& spotPar)
607 double zIP = getZIPest(tr, t, spotPar);
608 double zIPM = getZIPest(tr, spotPar.z.center(), spotPar);
610 double x0 = spotPar.x.val(t) + spotPar.kX.val(t) * (zIP - spotPar.z.val(t));
611 double y0 = spotPar.y.val(t) + spotPar.kY.val(t) * (zIP - spotPar.z.val(t));
613 double xM = spotPar.x.val(spotPar.x.center()) + spotPar.kX.val(spotPar.kX.center()) * (zIPM - spotPar.z.val(spotPar.z.center()));
614 double yM = spotPar.y.val(spotPar.y.center()) + spotPar.kY.val(spotPar.kY.center()) * (zIPM - spotPar.z.val(spotPar.z.center()));
617 double f0 = (x0 - xM) * sin(tr.phi0) - (y0 - yM) * cos(tr.phi0);
629 double getCorrZ(
const Track& tr,
double t,
const SpotParam& spotPar)
631 double zIP = getZIPest(tr, t, spotPar);
633 double x0 = spotPar.x.val(t) + spotPar.kX.val(t) * (zIP - spotPar.z.val(t));
634 double y0 = spotPar.y.val(t) + spotPar.kY.val(t) * (zIP - spotPar.z.val(t));
635 double z0 = spotPar.z.val(t);
637 double f0 = z0 - tr.tanlambda * (x0 * cos(tr.phi0) + y0 * sin(tr.phi0));
650 std::pair<double, double> getStartStop(
const std::vector<Event>& evts)
652 double minT = 1e20, maxT = -1e20;
653 for (
auto ev : evts) {
654 minT = std::min(minT, ev.t);
655 maxT = std::max(maxT, ev.t);
661 std::vector<TString> extractFileNames(TString str)
663 std::vector<TString> files;
664 auto tempVec = str.Tokenize(
",");
665 for (
int i = 0; i < tempVec->GetEntries(); ++i) {
666 TString s = ((TObjString*)tempVec->At(i))->GetString();
667 files.push_back(s.Strip());
673 std::vector<Event> getEvents(TTree* tr)
676 std::vector<Event> events;
677 events.reserve(tr->GetEntries());
681 tr->SetBranchAddress(
"run", &evt.run);
682 tr->SetBranchAddress(
"exp", &evt.exp);
683 tr->SetBranchAddress(
"event", &evt.evtNo);
684 tr->SetBranchAddress(
"mu0_d0", &evt.mu0.d0);
685 tr->SetBranchAddress(
"mu1_d0", &evt.mu1.d0);
686 tr->SetBranchAddress(
"mu0_z0", &evt.mu0.z0);
687 tr->SetBranchAddress(
"mu1_z0", &evt.mu1.z0);
689 tr->SetBranchAddress(
"mu0_tanlambda", &evt.mu0.tanlambda);
690 tr->SetBranchAddress(
"mu1_tanlambda", &evt.mu1.tanlambda);
693 tr->SetBranchAddress(
"mu0_phi0", &evt.mu0.phi0);
694 tr->SetBranchAddress(
"mu1_phi0", &evt.mu1.phi0);
696 tr->SetBranchAddress(
"time", &evt.t);
699 for (
int i = 0; i < tr->GetEntries(); ++i) {
705 events.push_back(evt);
709 sort(events.begin(), events.end(), [](Event e1, Event e2) {return e1.t < e2.t;});
716 void bootStrap(std::vector<Event>& evts)
719 e.nBootStrap = gRandom->Poisson(1);
730 VectorXd linearFit(MatrixXd mat, VectorXd r)
732 MatrixXd matT = mat.transpose();
733 MatrixXd A = matT * mat;
735 VectorXd v = matT * r;
736 MatrixXd Ainv = A.inverse();
749 std::pair<std::vector<double>, std::vector<double>> linearFitErr(MatrixXd m, VectorXd r,
double& err2Mean,
double& err2press,
750 double& err2pressErr)
752 MatrixXd mT = m.transpose();
753 MatrixXd mat = mT * m;
756 MatrixXd A = mat * mT;
757 VectorXd res = A * r;
758 VectorXd dataH = m * res;
762 double err2 = (dataH - r).squaredNorm() / (r.rows() - res.rows());
770 for (
int i = 0; i < r.rows(); ++i) {
772 for (
int k = 0; k < m.cols(); ++k)
773 Ahat += m(i, k) * A(k, i);
775 double v = pow((r(i) - dataH(i)) / (1 - Ahat), 2);
780 press2 /= (r.rows() - 1);
783 err2pressErr =
sqrt((press2 - press * press) / r.rows()) /
sqrt(r.rows());
788 MatrixXd AT = A.transpose();
789 MatrixXd errMat = err2 * A * AT;
790 VectorXd errs2(errMat.rows());
791 for (
int i = 0; i < errs2.rows(); ++i)
792 errs2(i) = errMat(i, i);
808 VectorXd linearFitPos(MatrixXd mat, VectorXd r)
810 const double s2MinLimit = pow(0.05, 2);
811 B2ASSERT(
"Matrix size for size fit should be 3", mat.cols() == 3);
812 MatrixXd matT = mat.transpose();
813 MatrixXd A = matT * mat;
814 VectorXd v = matT * r;
815 MatrixXd Ainv = A.inverse();
817 VectorXd pars = Ainv * v;
820 double s2Min = getSize2MinMat(pars[0], pars[1], pars[2]);
821 if (pars[0] >= 0 && pars[1] >= 0 && s2Min >= s2MinLimit)
828 int nDf = r.rows() - 3;
830 double err2 = (mat * pars - r).squaredNorm() / nDf;
832 MatrixXd wMat = Ainv * matT;
833 MatrixXd wMatT = wMat.transpose();
835 MatrixXd covMat = err2 * wMat * wMatT;
836 MatrixXd covMatI = covMat.inverse();
843 TF2 fEig(
rn(), [covMatI, pars, s2MinLimit](
const double * x,
const double*) {
845 double eig2 = s2MinLimit;
851 xVec[0] = eig1 * c * c + eig2 * s * s;
852 xVec[1] = eig1 * s * s + eig2 * c * c;
853 xVec[2] = s * c * (eig1 - eig2);
856 double res = (xVec - pars).transpose() * covMatI * (xVec - pars);
858 }, s2MinLimit, 400, 0, 2 * M_PI, 0);
861 fEig.GetMinimumXY(eigHigh, phi);
863 pars[0] = eigHigh * pow(cos(phi), 2) + s2MinLimit * pow(sin(phi), 2);
864 pars[1] = eigHigh * pow(sin(phi), 2) + s2MinLimit * pow(cos(phi), 2);
865 pars[2] = sin(phi) * cos(phi) * (eigHigh - s2MinLimit);
876 TH1D* getResolution(TH2D* hRes)
878 TH1D* hSigmaAll =
new TH1D(
rn(),
"", 50, -M_PI, M_PI);
879 for (
int i = 1; i <= hRes->GetNbinsX(); ++i) {
880 TH1D* hProj = hRes->ProjectionY(
rn(), i, i);
881 double rms = hProj->GetRMS();
882 double rmsErr = hProj->GetRMSError();
883 hSigmaAll->SetBinContent(i, rms * rms);
884 hSigmaAll->SetBinError(i, 2 * abs(rms)*rmsErr);
890 TH1D* getMean(
const TH2D* hRes)
892 TH1D* hMean =
new TH1D(
rn(),
"", 50, -M_PI, M_PI);
893 for (
int i = 1; i <= hRes->GetNbinsX(); ++i) {
894 TH1D* hProj = hRes->ProjectionY(
rn(), i, i);
895 double mean = hProj->GetMean();
896 double meanErr = hProj->GetMeanError();
897 hMean->SetBinContent(i, mean);
898 hMean->SetBinError(i, meanErr);
904 double getD12th(Event e, std::vector<double> sizesXY)
906 double sxx = sizesXY[0];
907 double syy = sizesXY[1];
908 double sxy = sizesXY[2];
910 double cc = cos(e.mu0.phi0) * cos(e.mu1.phi0);
911 double ss = sin(e.mu0.phi0) * sin(e.mu1.phi0);
912 double sc = -(sin(e.mu0.phi0) * cos(e.mu1.phi0) + sin(e.mu1.phi0) * cos(e.mu0.phi0));
914 return ss * sxx + cc * syy + sc * sxy;
918 double getZ12th(Event e, std::vector<double> sizesXY)
920 double sxx = sizesXY[0];
921 double syy = sizesXY[1];
923 double corr = e.mu0.tanlambda * e.mu1.tanlambda * (sxx * cos(e.mu0.phi0) * cos(e.mu1.phi0) + syy * sin(e.mu0.phi0) * sin(
925 + (sin(e.mu0.phi0) * cos(e.mu1.phi0) + cos(e.mu0.phi0) * sin(e.mu1.phi0)));
935 void plotSpotPositionFit(
const std::vector<Event>& evts, SpotParam par, TString fName)
937 TGraph* gr =
new TGraph();
938 TProfile* dProf =
new TProfile(
rn(),
"dProf", 100, -M_PI, M_PI,
"S");
939 TProfile* dProfRes =
new TProfile(
rn(),
"dProfRes", 100, -M_PI, M_PI,
"S");
941 for (
auto e : evts) {
942 if (!e.isSig)
continue;
944 double d1 = getDtimeConst(e.mu0, e.t, par);
945 double d2 = getDtimeConst(e.mu1, e.t, par);
947 gr->SetPoint(gr->GetN(), e.mu0.phi0, d1);
948 gr->SetPoint(gr->GetN(), e.mu1.phi0, d2);
950 dProf->Fill(e.mu0.phi0, d1);
951 dProf->Fill(e.mu1.phi0, d2);
954 double d1c = getCorrD(e.mu0, e.t, par);
955 double d2c = getCorrD(e.mu1, e.t, par);
957 dProfRes->Fill(e.mu0.phi0, d1c);
958 dProfRes->Fill(e.mu1.phi0, d2c);
960 TF1* f =
new TF1(
rn(),
"[0]*sin(x) - [1]*cos(x)", -M_PI, M_PI);
961 f->SetParameters(par.x.val(par.x.center()), par.y.val(par.y.center()));
963 TCanvas* c =
new TCanvas(
rn(),
"");
965 gr->GetXaxis()->SetRangeUser(-M_PI, M_PI);
966 gr->SetMaximum(+1.3 * f->GetMaximum());
967 gr->SetMinimum(-1.3 * f->GetMaximum());
969 gr->GetXaxis()->SetTitle(
"#phi_{0} [rad]");
970 gr->GetYaxis()->SetTitle(
"d_{0} [#mum]");
973 c->SaveAs(fName +
"_dots.pdf");
976 TCanvas* d =
new TCanvas(
rn(),
"");
977 gStyle->SetOptStat(0);
979 dProf->GetXaxis()->SetRangeUser(-M_PI, M_PI);
980 dProf->SetMaximum(+1.3 * f->GetMaximum());
981 dProf->SetMinimum(-1.3 * f->GetMaximum());
983 dProf->GetXaxis()->SetTitle(
"#phi_{0} [rad]");
984 dProf->GetYaxis()->SetTitle(
"d_{0} [#mum]");
988 B2INFO(
"Saving " << fName <<
" prof ");
989 d->SaveAs(fName +
"_prof.pdf");
992 TCanvas* e =
new TCanvas(
rn(),
"");
993 gStyle->SetOptStat(0);
995 dProfRes->GetXaxis()->SetRangeUser(-M_PI, M_PI);
997 dProfRes->GetXaxis()->SetTitle(
"#phi_{0} [rad]");
998 dProfRes->GetYaxis()->SetTitle(
"d_{0} res [#mum]");
1000 TH1D* errP =
new TH1D(
rn(),
"dErrP", 100, -M_PI, M_PI);
1001 TH1D* errM =
new TH1D(
rn(),
"dErrM", 100, -M_PI, M_PI);
1002 for (
int i = 1; i <= errP->GetNbinsX(); ++i) {
1003 errP->SetBinContent(i, dProfRes->GetBinError(i));
1004 errM->SetBinContent(i, -dProfRes->GetBinError(i));
1007 errP->Draw(
"hist same");
1008 errM->Draw(
"hist same");
1010 f->SetParameters(0, 0);
1013 B2INFO(
"Saving " << fName <<
" profRes ");
1014 e->SaveAs(fName +
"_profRes.pdf");
1020 void plotSpotZPositionFit(
const std::vector<Event>& evts, SpotParam par, TString fName)
1022 TProfile* zProf =
new TProfile(
rn(),
"dProf", 100, -M_PI, M_PI,
"S");
1023 TGraph* gr =
new TGraph();
1024 for (
auto e : evts) {
1025 if (!e.isSig)
continue;
1028 double z1ip = getZIPest(e.mu0, e.t, par);
1029 double z2ip = getZIPest(e.mu1, e.t, par);
1031 double zipT = par.z.val(e.t);
1032 double zipM = par.z.val(par.z.center());
1034 double val1 = z1ip - (zipT - zipM);
1035 double val2 = z2ip - (zipT - zipM);
1037 gr->SetPoint(gr->GetN(), e.mu0.phi0, val1);
1038 gr->SetPoint(gr->GetN(), e.mu1.phi0, val2);
1040 zProf->Fill(e.mu0.phi0, val1);
1041 zProf->Fill(e.mu1.phi0, val2);
1043 TF1* f =
new TF1(
rn(),
"[0]", -M_PI, M_PI);
1044 f->SetParameter(0, par.z.val(par.z.center()));
1046 TCanvas* c =
new TCanvas(
rn(),
"");
1047 c->SetLeftMargin(0.12);
1049 gr->GetXaxis()->SetRangeUser(-M_PI, M_PI);
1050 gr->SetMaximum(1000);
1051 gr->SetMinimum(-1000);
1053 gr->GetXaxis()->SetTitle(
"#phi_{0} [rad]");
1054 gr->GetYaxis()->SetTitle(
"z_{IP} estimate [#mum]");
1057 c->SaveAs(fName +
"_dots.pdf");
1060 TCanvas* d =
new TCanvas(
rn(),
"");
1061 gStyle->SetOptStat(0);
1062 d->SetLeftMargin(0.12);
1064 zProf->GetXaxis()->SetRangeUser(-M_PI, M_PI);
1065 zProf->SetMaximum(1000);
1066 zProf->SetMinimum(-1000);
1068 zProf->GetXaxis()->SetTitle(
"#phi_{0} [rad]");
1069 zProf->GetYaxis()->SetTitle(
"z_{IP} estimate [#mum]");
1072 d->SaveAs(fName + +
"_prof.pdf");
1081 void plotSpotPositionPull(
const std::vector<Event>& evts,
const SpotParam& par, TString fName,
double cut = 70)
1083 TH1D* hPull =
new TH1D(
rn(),
"", 200, -200, 200);
1085 for (
auto& e : evts) {
1086 if (!e.isSig)
continue;
1088 double d0 = getCorrD(e.mu0, e.t, par);
1089 double d1 = getCorrD(e.mu1, e.t, par);
1095 TCanvas* c =
new TCanvas(
rn(),
"");
1096 gStyle->SetOptStat(2210);
1099 hPull->GetXaxis()->SetTitle(
"pull [#mum]");
1100 hPull->GetYaxis()->SetTitle(
"#tracks");
1102 TLine* l =
new TLine;
1103 l->SetLineColor(kRed);
1104 l->DrawLine(-cut, 0, -cut, 500);
1105 l->DrawLine(+cut, 0, +cut, 500);
1107 c->SaveAs(fName +
".pdf");
1112 void plotKxKyFit(
const std::vector<Event>& evts, SpotParam par, TString fName)
1114 TProfile* profRes =
new TProfile(
rn(),
"dProf", 100, -800, 800,
"S");
1115 TProfile* profResKx =
new TProfile(
rn(),
"dProfKx", 100, -800, 800,
"S");
1116 TProfile* profResKy =
new TProfile(
rn(),
"dProfKy", 100, -800, 800,
"S");
1118 SpotParam parNoKx = par;
1119 SpotParam parNoKy = par;
1120 parNoKx.kX.vals = {0};
1121 parNoKy.kY.vals = {0};
1122 parNoKx.kX.nodes = {};
1123 parNoKy.kY.nodes = {};
1125 for (
auto& e : evts) {
1126 if (!e.isSig)
continue;
1128 double zDiff1 = getZIPest(e.mu0, e.t, par) - par.z.val(e.t);
1129 double zDiff2 = getZIPest(e.mu1, e.t, par) - par.z.val(e.t);
1132 double d1 = getCorrD(e.mu0, e.t, par);
1133 double d2 = getCorrD(e.mu1, e.t, par);
1135 double d1KX = getCorrD(e.mu0, e.t, parNoKx);
1136 double d2KX = getCorrD(e.mu1, e.t, parNoKx);
1139 profResKx->Fill(zDiff1 * sin(e.mu0.phi0), d1KX);
1140 profResKx->Fill(zDiff2 * sin(e.mu1.phi0), d2KX);
1142 double d1KY = getCorrD(e.mu0, e.t, parNoKy);
1143 double d2KY = getCorrD(e.mu1, e.t, parNoKy);
1144 profResKy->Fill(-zDiff1 * cos(e.mu0.phi0), d1KY);
1145 profResKy->Fill(-zDiff2 * cos(e.mu1.phi0), d2KY);
1147 profRes->Fill(zDiff1, d1);
1148 profRes->Fill(zDiff2, d2);
1153 TCanvas* cX =
new TCanvas(
rn(),
"");
1154 gStyle->SetOptStat(0);
1157 profResKx->GetXaxis()->SetTitle(
"(z_{IP} - z_{IP}^{0}) sin #phi_{0} [#mum]");
1158 profResKx->GetYaxis()->SetTitle(
"d_{0} res [#mum]");
1160 TF1* f =
new TF1(
rn(),
"[0]*x", -800, 800);
1161 f->SetParameter(0, par.kX.val(par.kX.center()));
1164 cX->SaveAs(fName +
"_kX.pdf");
1166 TCanvas* cY =
new TCanvas(
rn(),
"");
1167 gStyle->SetOptStat(0);
1170 profResKy->GetXaxis()->SetTitle(
"-(z_{IP} - z_{IP}^{0}) cos #phi_{0} [#mum]");
1171 profResKy->GetYaxis()->SetTitle(
"d_{0} res [#mum]");
1173 f->SetParameter(0, par.kY.val(par.kY.center()));
1176 cY->SaveAs(fName +
"_kY.pdf");
1182 void plotXYtimeDep(
const std::vector<Event>& evts, SpotParam par, TString fName)
1184 TProfile* profRes =
new TProfile(
rn(),
"dProf", 50, -0.5, 0.5);
1185 TProfile* profResTx =
new TProfile(
rn(),
"dProfTx", 50, -0.5, 0.5);
1186 TProfile* profResTy =
new TProfile(
rn(),
"dProfTy", 50, -0.5, 0.5);
1188 SpotParam parNoTx = par;
1189 SpotParam parNoTy = par;
1190 parNoTx.x.nodes = {};
1191 parNoTx.x.vals = {par.x.val(par.x.center())};
1192 parNoTy.y.nodes = {};
1193 parNoTy.y.vals = {par.y.val(par.y.center())};
1195 for (
auto& e : evts) {
1196 if (!e.isSig)
continue;
1198 double tDiff = (e.t - par.x.val(par.x.center()));
1202 double d1 = getCorrD(e.mu0, e.t, par);
1203 double d2 = getCorrD(e.mu1, e.t, par);
1205 double d1TX = getCorrD(e.mu0, e.t, parNoTx);
1206 double d2TX = getCorrD(e.mu1, e.t, parNoTx);
1208 profResTx->Fill(tDiff * sin(e.mu0.phi0), d1TX);
1209 profResTx->Fill(tDiff * sin(e.mu1.phi0), d2TX);
1211 double d1TY = getCorrD(e.mu0, e.t, parNoTy);
1212 double d2TY = getCorrD(e.mu1, e.t, parNoTy);
1214 profResTy->Fill(-tDiff * cos(e.mu0.phi0), d1TY);
1215 profResTy->Fill(-tDiff * cos(e.mu1.phi0), d2TY);
1218 profRes->Fill(tDiff * sin(e.mu0.phi0), d1);
1219 profRes->Fill(tDiff * sin(e.mu1.phi0), d2);
1224 TCanvas* cX =
new TCanvas(
rn(),
"");
1225 gStyle->SetOptStat(0);
1229 TF1* f =
new TF1(
rn(),
"[0]*x", -1, 1);
1230 f->SetParameter(0, (par.x.val(1) - par.x.val(0)));
1232 B2INFO(
"Table value " << par.x.val(1) - par.x.val(0));
1234 cX->SaveAs(fName +
"_tX.pdf");
1244 void plotSpotZpositionPull(
const std::vector<Event>& evts,
const SpotParam& par, TString fName,
double cut = 1000)
1246 TH1D* hPull =
new TH1D(
rn(),
"", 200, -2000, 2000);
1248 for (
auto& e : evts) {
1249 if (!e.isSig)
continue;
1251 double z0 = getCorrZ(e.mu0, e.t, par);
1252 double z1 = getCorrZ(e.mu1, e.t, par);
1258 gStyle->SetOptStat(2210);
1259 TCanvas* c =
new TCanvas(
rn(),
"");
1262 hPull->GetXaxis()->SetTitle(
"pull [#mum]");
1263 hPull->GetYaxis()->SetTitle(
"#tracks");
1265 TLine* l =
new TLine;
1266 l->SetLineColor(kRed);
1267 l->DrawLine(-cut, 0, -cut, 500);
1268 l->DrawLine(+cut, 0, +cut, 500);
1270 c->SaveAs(fName +
".pdf");
1275 void removeSpotPositionOutliers(std::vector<Event>& evts,
const SpotParam& par,
double cut = 70)
1279 for (
auto& e : evts) {
1280 if (!e.isSig)
continue;
1282 double d0 = getCorrD(e.mu0, e.t, par);
1283 double d1 = getCorrD(e.mu1, e.t, par);
1285 e.isSig = abs(d0) < cut && abs(d1) < cut;
1289 B2INFO(
"Removed fraction Position " << nRem / (nAll + 0.));
1294 void removeSpotZpositionOutliers(std::vector<Event>& evts,
const SpotParam& par,
double cut = 1000)
1298 for (
auto& e : evts) {
1299 if (!e.isSig)
continue;
1301 double z0 = getCorrZ(e.mu0, e.t, par);
1302 double z1 = getCorrZ(e.mu1, e.t, par);
1304 e.isSig = abs(z0) < cut && abs(z1) < cut;
1308 B2INFO(
"Removed fraction Position " << nRem / (nAll + 0.));
1314 std::vector<std::vector<double>> fillSplineBasesLinear(
const std::vector<Event>& evts, std::vector<double> spl,
1315 std::function<
double(Track,
double)> fun)
1318 if (n == 0 || (n == 2 && spl[0] > spl[1]))
1321 std::vector<std::vector<double>> vecs(n);
1324 for (
const auto& e : evts) {
1325 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1326 vecs[0].push_back(1 * fun(e.mu0, e.t));
1327 vecs[0].push_back(1 * fun(e.mu1, e.t));
1331 for (
int k = 0; k < n; ++k) {
1332 double xCnt = spl[k];
1333 double xLow = (k == 0) ? spl[0] : spl[k - 1];
1334 double xHigh = (k == n - 1) ? spl[n - 1] : spl[k + 1];
1336 for (
const auto& e : evts) {
1339 if (xLow <= x && x < xCnt)
1340 v = (x - xLow) / (xCnt - xLow);
1341 else if (xCnt < x && x <= xHigh)
1342 v = (xHigh - x) / (xHigh - xCnt);
1345 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1346 vecs[k].push_back(v * fun(e.mu0, e.t));
1347 vecs[k].push_back(v * fun(e.mu1, e.t));
1358 std::vector<std::vector<double>> fillSplineBasesZero(
const std::vector<Event>& evts, std::vector<double> spl,
1359 std::function<
double(Track,
double)> fun)
1361 int n = spl.size() + 1;
1363 std::vector<std::vector<double>> vecs(n);
1366 for (
const auto& e : evts) {
1367 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1368 vecs[0].push_back(1 * fun(e.mu0, e.t));
1369 vecs[0].push_back(1 * fun(e.mu1, e.t));
1373 for (
int k = 0; k < n; ++k) {
1374 double xLow = -1e30;
1375 double xHigh = +1e30;
1379 }
else if (k == n - 1) {
1386 for (
const auto& e : evts) {
1389 if (xLow <= x && x < xHigh)
1392 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1393 vecs[k].push_back(v * fun(e.mu0, e.t));
1394 vecs[k].push_back(v * fun(e.mu1, e.t));
1409 double compareSplines(
const Spline& spl1,
const Spline& spl2)
1413 double step = 0.001;
1414 for (
double x = 0; x <= 1 + step / 2; x += step) {
1415 double v1 = spl1.val(x);
1416 double e1 = spl1.err(x);
1417 double v2 = spl2.val(x);
1418 double e2 = spl2.err(x);
1420 double d = pow(v2 - v1, 2) / pow(std::max(e1, e2), 2);
1427 double fitSpotZwidth(
const std::vector<Event>& evts,
const SpotParam& spotPar,
const std::vector<double>& sizesXY)
1430 std::vector<double> dataVec;
1431 std::vector<double> zzVec;
1434 for (
auto e : evts) {
1435 double z0 = getCorrZ(e.mu0, e.t, spotPar);
1436 double z1 = getCorrZ(e.mu1, e.t, spotPar);
1438 double corr = getZ12th(e, sizesXY);
1439 double z0z1Corr = z0 * z1 - corr;
1442 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1443 dataVec.push_back(z0z1Corr);
1450 std::vector<double> pars, err2;
1451 double err2Mean, err2press, err2pressErr;
1452 std::tie(pars, err2) = linearFitErr(mat,
vec2vec(dataVec), err2Mean, err2press, err2pressErr);
1462 SpotParam fitSpotPositionSplines(
const std::vector<Event>& evts,
const std::vector<double>& splX,
const std::vector<double>& splY,
1463 const std::vector<double>& splKX,
const std::vector<double>& splKY)
1465 std::vector<std::vector<double>> basesX = fillSplineBasesZero(evts, splX, [](Track tr,
double) {
return sin(tr.phi0);});
1466 std::vector<std::vector<double>> basesY = fillSplineBasesZero(evts, splY, [](Track tr,
double) {
return -cos(tr.phi0);});
1468 std::vector<std::vector<double>> basesKX = fillSplineBasesZero(evts, splKX, [](Track tr,
double) {
return sin(tr.phi0) * tr.z0;});
1469 std::vector<std::vector<double>> basesKY = fillSplineBasesZero(evts, splKY, [](Track tr,
double) {
return -cos(tr.phi0) * tr.z0;});
1472 std::vector<double> dataVec;
1473 for (
auto e : evts) {
1474 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1475 dataVec.push_back(e.mu0.d0);
1476 dataVec.push_back(e.mu1.d0);
1480 std::vector<std::vector<double>> allVecs =
merge({basesX, basesY, basesKX, basesKY});
1485 VectorXd vData =
vec2vec(dataVec);
1487 std::vector<double> pars(A.cols()), err2(A.cols());
1488 double err2Mean, err2press, err2pressErr;
1489 std::tie(pars, err2) = linearFitErr(A, vData, err2Mean, err2press, err2pressErr);
1491 for (
auto& e : err2) e =
sqrt(e);
1492 return SpotParam(pars, err2, {splX, splY, splKX, splKY});
1496 SpotParam fitSpotPositionSplines(
const std::vector<Event>& evts,
const std::vector<double>& splX,
const std::vector<double>& splY,
1497 const std::vector<double>& splKX,
const std::vector<double>& splKY,
const SpotParam& spotPars)
1499 std::vector<std::vector<double>> basesX = fillSplineBasesZero(evts, splX, [](Track tr,
double) {
return sin(tr.phi0);});
1500 std::vector<std::vector<double>> basesY = fillSplineBasesZero(evts, splY, [](Track tr,
double) {
return -cos(tr.phi0);});
1502 std::vector<std::vector<double>> basesKX = fillSplineBasesZero(evts, splKX, [ = ](Track tr,
double t) {
return sin(tr.phi0) * (getZIPest(tr, t, spotPars) - spotPars.z.val(t));});
1503 std::vector<std::vector<double>> basesKY = fillSplineBasesZero(evts, splKY, [ = ](Track tr,
double t) {
return -cos(tr.phi0) * (getZIPest(tr, t, spotPars) - spotPars.z.val(t));});
1506 std::vector<double> dataVec;
1507 for (
auto e : evts) {
1508 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1509 dataVec.push_back(e.mu0.d0);
1510 dataVec.push_back(e.mu1.d0);
1514 std::vector<std::vector<double>> allVecs =
merge({basesX, basesY, basesKX, basesKY});
1519 VectorXd vData =
vec2vec(dataVec);
1521 std::vector<double> pars(A.cols()), err2(A.cols());
1522 double err2Mean, err2press, err2pressErr;
1523 std::tie(pars, err2) = linearFitErr(A, vData, err2Mean, err2press, err2pressErr);
1525 for (
auto& e : err2) e =
sqrt(e);
1526 auto res = SpotParam(pars, err2, {splX, splY, splKX, splKY});
1536 SpotParam fitSpotPositionSplines(
const std::vector<Event>& evts,
const std::vector<double>& splX,
const std::vector<double>& splY)
1538 std::vector<std::vector<double>> basesX = fillSplineBasesZero(evts, splX, [](Track tr,
double) {
return sin(tr.phi0);});
1539 std::vector<std::vector<double>> basesY = fillSplineBasesZero(evts, splY, [](Track tr,
double) {
return -cos(tr.phi0);});
1541 std::vector<double> dataVec;
1542 for (
auto e : evts) {
1543 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1544 dataVec.push_back(e.mu0.d0);
1545 dataVec.push_back(e.mu1.d0);
1549 std::vector<std::vector<double>> allVecs =
merge({basesX, basesY});
1553 VectorXd vData =
vec2vec(dataVec);
1555 std::vector<double> pars(A.cols()), err2(A.cols());
1556 double err2Mean, err2press, err2pressErr;
1557 std::tie(pars, err2) = linearFitErr(A, vData, err2Mean, err2press, err2pressErr);
1559 for (
auto& e : err2) e =
sqrt(e);
1560 return SpotParam(pars, err2, {splX, splY});
1569 SpotParam fitZpositionSplines(
const std::vector<Event>& evts,
const std::vector<double>& splX,
const std::vector<double>& splY,
1570 const std::vector<double>& splKX,
const std::vector<double>& splKY,
1571 const std::vector<double>& splZ)
1573 std::vector<std::vector<double>> basesX = fillSplineBasesZero(evts, splX, [](Track tr,
double) {
return -tr.tanlambda * cos(tr.phi0);});
1574 std::vector<std::vector<double>> basesY = fillSplineBasesZero(evts, splY, [](Track tr,
double) {
return -tr.tanlambda * sin(tr.phi0);});
1576 std::vector<std::vector<double>> basesKX = fillSplineBasesZero(evts, splKX, [](Track tr,
double) {
return -tr.z0 * tr.tanlambda * cos(tr.phi0);});
1577 std::vector<std::vector<double>> basesKY = fillSplineBasesZero(evts, splKY, [](Track tr,
double) {
return -tr.z0 * tr.tanlambda * sin(tr.phi0);});
1579 std::vector<std::vector<double>> basesZ = fillSplineBasesZero(evts, splZ, [](Track,
double) {
return 1;});
1582 std::vector<double> dataVec;
1583 for (
auto e : evts) {
1584 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1585 dataVec.push_back(e.mu0.z0);
1586 dataVec.push_back(e.mu1.z0);
1590 std::vector<std::vector<double>> allVecs =
merge({basesX, basesY, basesKX, basesKY, basesZ});
1594 VectorXd vData =
vec2vec(dataVec);
1596 std::vector<double> pars(A.cols()), err2(A.cols());
1597 double err2Mean, err2press, err2pressErr;
1598 std::tie(pars, err2) = linearFitErr(A, vData, err2Mean, err2press, err2pressErr);
1600 for (
auto& e : err2) e =
sqrt(e);
1601 return SpotParam(pars, err2, {splX, splY, splKX, splKY, splZ});
1607 SpotParam fitZpositionSplinesSimple(
const std::vector<Event>& evts,
const std::vector<double>& splZ,
const SpotParam& spotPars)
1609 std::vector<std::vector<double>> basesZ = fillSplineBasesZero(evts, splZ, [](Track,
double) {
return 1;});
1611 std::vector<double> dataVec;
1612 for (
auto e : evts) {
1613 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1614 double z1 = getZIPest(e.mu0, e.t, spotPars);
1615 double z2 = getZIPest(e.mu1, e.t, spotPars);
1616 dataVec.push_back(z1);
1617 dataVec.push_back(z2);
1623 VectorXd vData =
vec2vec(dataVec);
1625 std::vector<double> pars(A.cols()), err2(A.cols());
1626 double err2Mean, err2press, err2pressErr;
1627 std::tie(pars, err2) = linearFitErr(A, vData, err2Mean, err2press, err2pressErr);
1629 for (
auto& e : err2) e =
sqrt(e);
1631 SpotParam parsUpd = spotPars;
1632 parsUpd.z.vals = pars;
1633 parsUpd.z.errs = err2;
1634 parsUpd.z.nodes = splZ;
1642 std::vector<double> fitSpotWidthCMS(
const std::vector<Event>& evts,
const SpotParam& spotPar)
1645 std::vector<double> dataVec, ccVec, ssVec, scVec;
1648 for (
auto e : evts) {
1649 double d0 = getCorrD(e.mu0, e.t, spotPar);
1650 double d1 = getCorrD(e.mu1, e.t, spotPar);
1652 for (
int i = 0; i < e.nBootStrap * e.isSig; ++i) {
1653 dataVec.push_back(d0 * d1);
1655 ccVec.push_back(cos(e.mu0.phi0)*cos(e.mu1.phi0));
1656 ssVec.push_back(sin(e.mu0.phi0)*sin(e.mu1.phi0));
1657 scVec.push_back(-(sin(e.mu0.phi0)*cos(e.mu1.phi0) + sin(e.mu1.phi0)*cos(e.mu0.phi0)));
1662 MatrixXd mat =
vecs2mat({ssVec, ccVec, scVec});
1665 VectorXd resPhys = linearFitPos(mat,
vec2vec(dataVec));
1667 return {resPhys(0), resPhys(1), resPhys(2)};
1672 void plotSpotSizePull(
const std::vector<Event>& evts,
const SpotParam& spotPar,
const std::vector<double>& sizesXY)
1674 TH1D* hPull =
new TH1D(
rn(),
"", 100, -2000, 2000);
1675 for (
auto& e : evts) {
1676 if (!e.isSig)
continue;
1678 double d0 = getCorrD(e.mu0, e.t, spotPar);
1679 double d1 = getCorrD(e.mu1, e.t, spotPar);
1681 double d12Th = getD12th(e, sizesXY);
1683 hPull->Fill(d0 * d1 - d12Th);
1685 TCanvas* c =
new TCanvas(
rn(),
"");
1687 c->SaveAs(
"pullsSize.pdf");
1692 void plotSpotSizeZPull(
const std::vector<Event>& evts,
const SpotParam& spotPar,
const std::vector<double>& sizesXY,
double sizeZZ)
1694 TH1D* hPull =
new TH1D(
rn(),
"", 100, -300e3, 600e3);
1695 for (
auto& e : evts) {
1696 if (!e.isSig)
continue;
1698 double z0 = getCorrZ(e.mu0, e.t, spotPar);
1699 double z1 = getCorrZ(e.mu1, e.t, spotPar);
1701 double corr = getZ12th(e, sizesXY);
1702 double res = z0 * z1 - corr - sizeZZ;
1707 gStyle->SetOptStat(2210);
1708 TCanvas* c =
new TCanvas(
rn(),
"");
1710 B2INFO(
"zSizeFit mean " << hPull->GetMean());
1711 B2INFO(
"zSizeFit rms " << hPull->GetRMS());
1713 c->SaveAs(
"pullsZSize.pdf");
1720 void plotSpotSizeFit(
const std::vector<Event>& evts,
const SpotParam& par,
const std::vector<double>& sizeXY)
1722 double sxx = sizeXY[0];
1723 double syy = sizeXY[1];
1724 double sxy = sizeXY[2];
1726 gStyle->SetOptStat(0);
1728 TProfile* profSxx =
new TProfile(
rn(),
"", 50, -1, 1);
1729 TProfile* profSyy =
new TProfile(
rn(),
"", 50, -1, 1);
1730 TProfile* profSxy =
new TProfile(
rn(),
"", 50, -1, 1);
1731 for (
auto e : evts) {
1732 if (!e.isSig)
continue;
1734 double cc = cos(e.mu0.phi0) * cos(e.mu1.phi0);
1735 double ss = sin(e.mu0.phi0) * sin(e.mu1.phi0);
1736 double sc = - (sin(e.mu0.phi0) * cos(e.mu1.phi0) + sin(e.mu1.phi0) * cos(e.mu0.phi0));
1738 double d0 = getCorrD(e.mu0, e.t, par);
1739 double d1 = getCorrD(e.mu1, e.t, par);
1741 double data = d0 * d1;
1743 profSxx->Fill(ss, data - syy * cc - sxy * sc);
1744 profSyy->Fill(cc, data - sxx * ss - sxy * sc);
1745 profSxy->Fill(sc, data - syy * cc - sxx * ss);
1748 TCanvas* c =
new TCanvas(
rn(),
"", 1200, 500);
1752 profSxx->GetXaxis()->SetTitle(
"sin #phi_{1} sin #phi_{2}");
1753 profSxx->GetYaxis()->SetTitle(
"#LTd_{1} d_{2}#GT - corr_{xx} [#mum^{2}]");
1754 TF1* fxx =
new TF1(
rn(),
"[0]*x", -1, 1);
1755 fxx->SetParameter(0, sxx);
1760 profSyy->GetXaxis()->SetTitle(
"cos #phi_{1} cos #phi_{2}");
1761 profSyy->GetYaxis()->SetTitle(
"#LTd_{1} d_{2}#GT - corr_{yy} [#mum^{2}]");
1762 TF1* fyy =
new TF1(
rn(),
"[0]*x", -1, 1);
1763 fyy->SetParameter(0, syy);
1768 profSxy->GetXaxis()->SetTitle(
"-(sin #phi_{1} cos #phi_{2} + sin #phi_{2} cos #phi_{1})");
1769 profSxy->GetYaxis()->SetTitle(
"#LTd_{1} d_{2}#GT - corr_{xy} [#mum^{2}]");
1770 TF1* fxy =
new TF1(
rn(),
"[0]*x", -1, 1);
1771 fxy->SetParameter(0, sxy);
1774 c->SaveAs(
"SizeFit.pdf");
1779 void plotSpotZSizeFit(
const std::vector<Event>& evts,
const SpotParam& par,
const std::vector<double>& sizesXY,
double sizeZZ)
1782 gStyle->SetOptStat(0);
1785 TProfile* zzProfPhi =
new TProfile(
rn(),
"", 100, -M_PI, M_PI);
1786 TProfile* zzProfXX =
new TProfile(
rn(),
"", 100, -M_PI / 4, 2 * M_PI);
1787 TProfile* zzProfYY =
new TProfile(
rn(),
"", 100, -M_PI / 4, 2 * M_PI);
1788 TProfile* zzProfXY =
new TProfile(
rn(),
"", 100, -2 * M_PI, 2 * M_PI);
1789 TProfile* zzProfXZ =
new TProfile(
rn(),
"", 100, -2 * M_PI, 2 * M_PI);
1790 TProfile* zzProfYZ =
new TProfile(
rn(),
"", 100, -2 * M_PI, 2 * M_PI);
1793 for (
auto e : evts) {
1794 double z0 = getCorrZ(e.mu0, e.t, par);
1795 double z1 = getCorrZ(e.mu1, e.t, par);
1797 double corr = getZ12th(e, sizesXY);
1798 double z0z1Corr = z0 * z1 - corr;
1802 double xx = e.mu0.tanlambda * e.mu1.tanlambda * cos(e.mu0.phi0) * cos(e.mu1.phi0);
1803 double yy = e.mu0.tanlambda * e.mu1.tanlambda * sin(e.mu0.phi0) * sin(e.mu1.phi0);
1804 double xy = e.mu0.tanlambda * e.mu1.tanlambda * (sin(e.mu0.phi0) * cos(e.mu1.phi0) + cos(e.mu0.phi0) * sin(e.mu1.phi0));
1805 double xz = - (e.mu0.tanlambda * cos(e.mu0.phi0) + e.mu1.tanlambda * cos(e.mu1.phi0));
1806 double yz = - (e.mu0.tanlambda * sin(e.mu0.phi0) + e.mu1.tanlambda * sin(e.mu1.phi0));
1809 zzProfPhi->Fill(e.mu0.phi0, z0z1Corr);
1810 zzProfPhi->Fill(e.mu1.phi0, z0z1Corr);
1811 zzProfXX->Fill(xx, z0z1Corr);
1812 zzProfYY->Fill(yy, z0z1Corr);
1813 zzProfXY->Fill(xy, z0z1Corr);
1814 zzProfXZ->Fill(xz, z0z1Corr);
1815 zzProfYZ->Fill(yz, z0z1Corr);
1819 TF1* f =
new TF1(
rn(),
"[0]", -2 * M_PI, 2 * M_PI);
1820 f->SetParameter(0, sizeZZ);
1822 TCanvas* c =
new TCanvas(
rn(),
"", 1200, 500);
1826 zzProfPhi->GetXaxis()->SetTitle(
"#phi_{0} [rad]");
1827 zzProfPhi->GetYaxis()->SetTitle(
"#LTz_{1} z_{2}#GT - corr [#mum^{2}]");
1832 zzProfXX->GetXaxis()->SetTitle(
"xx sensitive");
1833 zzProfXX->GetYaxis()->SetTitle(
"#LTz_{1} z_{2}#GT - corr [#mum^{2}]");
1838 zzProfYY->GetXaxis()->SetTitle(
"yy sensitive");
1839 zzProfYY->GetYaxis()->SetTitle(
"#LTz_{1} z_{2}#GT - corr [#mum^{2}]");
1844 zzProfXY->GetXaxis()->SetTitle(
"xy sensitive");
1845 zzProfXY->GetYaxis()->SetTitle(
"#LTz_{1} z_{2}#GT - corr [#mum^{2}]");
1850 zzProfXZ->GetXaxis()->SetTitle(
"xz sensitive");
1851 zzProfXZ->GetYaxis()->SetTitle(
"#LTz_{1} z_{2}#GT - corr [#mum^{2}]");
1856 zzProfYZ->GetXaxis()->SetTitle(
"yz sensitive");
1857 zzProfYZ->GetYaxis()->SetTitle(
"#LTz_{1} z_{2}#GT - corr [#mum^{2}]");
1860 c->SaveAs(
"SizeZFit.pdf");
1866 void removeSpotSizeOutliers(std::vector<Event>& evts,
const SpotParam& spotPar,
const std::vector<double>& sizesXY,
1872 for (
auto& e : evts) {
1873 if (!e.isSig)
continue;
1875 double d0 = getCorrD(e.mu0, e.t, spotPar);
1876 double d1 = getCorrD(e.mu1, e.t, spotPar);
1877 double d12Th = getD12th(e, sizesXY);
1879 e.isSig = abs(d0 * d1 - d12Th) < cut;
1883 B2INFO(
"Removed fraction Size " << nRem / (nAll + 0.));
1888 void removeSpotSizeZOutliers(std::vector<Event>& evts,
const SpotParam& spotPar,
const std::vector<double>& sizesXY,
double sizeZZ,
1889 double cut = 150000)
1894 for (
auto& e : evts) {
1895 if (!e.isSig)
continue;
1897 double z0 = getCorrZ(e.mu0, e.t, spotPar);
1898 double z1 = getCorrZ(e.mu1, e.t, spotPar);
1900 double corr = getZ12th(e, sizesXY);
1901 double res = z0 * z1 - corr - sizeZZ;
1904 e.isSig = abs(res) < cut;
1908 B2INFO(
"Removed fraction Size " << nRem / (nAll + 0.));
1913 MatrixXd toMat(TRotation rot)
1915 MatrixXd rotM(3, 3);
1916 rotM(0, 0) = rot.XX();
1917 rotM(0, 1) = rot.XY();
1918 rotM(0, 2) = rot.XZ();
1919 rotM(1, 0) = rot.YX();
1920 rotM(1, 1) = rot.YY();
1921 rotM(1, 2) = rot.YZ();
1922 rotM(2, 0) = rot.ZX();
1923 rotM(2, 1) = rot.ZY();
1924 rotM(2, 2) = rot.ZZ();
1937 MatrixXd getRotatedSizeMatrix(std::vector<double> xySize,
double zzSize,
double kX,
double kY)
1943 MatrixXd rotM = toMat(rot);
1944 MatrixXd rotMT = rotM.transpose();
1946 Matrix3d eigenMat = Matrix3d::Zero();
1947 eigenMat(0, 0) = xySize[0];
1948 eigenMat(1, 1) = xySize[1];
1949 eigenMat(0, 1) = xySize[2];
1950 eigenMat(1, 0) = xySize[2];
1951 eigenMat(2, 2) = zzSize;
1953 return (rotM * eigenMat * rotMT);
1963 std::tuple<std::vector<VectorXd>, std::vector<MatrixXd>, MatrixXd> runBeamSpotAnalysis(std::vector<Event> evts,
1964 const std::vector<double>& splitPoints)
1966 const double xyPosLimit = 70;
1967 const double xySize2Limit = pow(40, 2);
1968 const double zPosLimit = 1200;
1971 std::vector<double> indX = splitPoints;
1972 std::vector<double> indY = splitPoints;
1973 std::vector<double> indZ = splitPoints;
1976 std::vector<double> indKX = {};
1977 std::vector<double> indKY = {};
1979 UnknownPars allPars;
1980 for (
int k = 0; k < 1; ++k) {
1981 for (
auto& e : evts) e.isSig =
true;
1982 if (k != 0) bootStrap(evts);
1986 auto resTemp = fitSpotPositionSplines(evts, indX, indY);
1988 const int kPlot = -1;
1991 plotSpotPositionFit(evts, resTemp,
"positionFitSimpe");
1992 plotSpotPositionPull(evts, resTemp,
"pullsPositionSimple", xyPosLimit);
1994 removeSpotPositionOutliers(evts, resTemp, xyPosLimit);
1997 auto resFin = fitSpotPositionSplines(evts, indX, indY);
1999 plotSpotPositionFit(evts, resFin,
"positionFitSimpleC");
2000 plotSpotPositionPull(evts, resFin,
"pullsPositionSimpleC", xyPosLimit);
2001 plotXYtimeDep(evts, resFin,
"simplePosTimeDep");
2005 auto resZmy = fitZpositionSplinesSimple(evts, indZ, resFin);
2007 plotSpotZPositionFit(evts, resZmy,
"positionFitSimpleZ");
2008 plotSpotZpositionPull(evts, resZmy,
"zPositionPull", zPosLimit);
2011 removeSpotZpositionOutliers(evts, resZmy, zPosLimit);
2014 resZmy = fitZpositionSplinesSimple(evts, indZ, resZmy);
2018 auto resNew = fitSpotPositionSplines(evts, indX, indY, indKX, indKY, resZmy);
2020 plotSpotPositionFit(evts, resNew,
"positionFitFull");
2021 plotKxKyFit(evts, resNew,
"slopes");
2025 resZmy = fitZpositionSplinesSimple(evts, indZ, resNew);
2026 if (k == kPlot) plotSpotZPositionFit(evts, resZmy,
"positionFitSimpleZLast");
2030 resNew = fitSpotPositionSplines(evts, indX, indY, indKX, indKY, resZmy);
2033 resZmy = fitZpositionSplinesSimple(evts, indZ, resNew);
2034 resNew = fitSpotPositionSplines(evts, indX, indY, indKX, indKY, resZmy);
2038 auto vecXY = fitSpotWidthCMS(evts, resNew);
2039 if (k == kPlot) plotSpotSizePull(evts, resNew, vecXY);
2040 removeSpotSizeOutliers(evts, resNew, vecXY, xySize2Limit);
2041 vecXY = fitSpotWidthCMS(evts, resNew);
2042 if (k == kPlot) plotSpotSizeFit(evts, resNew, vecXY);
2046 double sizeZZ = fitSpotZwidth(evts, resNew, vecXY);
2049 plotSpotZSizeFit(evts, resNew, vecXY, sizeZZ);
2050 plotSpotSizeZPull(evts, resNew, vecXY, sizeZZ);
2056 allPars.add(resNew, sqrtS(vecXY[0]), sqrtS(vecXY[1]), sqrtS(vecXY[2]), sqrtS(sizeZZ));
2062 std::vector<VectorXd> vtxPos;
2063 std::vector<MatrixXd> vtxErr;
2066 allPars.getOutput(vtxPos, vtxErr, sizeMat);
2068 return std::make_tuple(vtxPos, vtxErr, sizeMat);
Class that bundles various TrackFitResults.
double sqrt(double a)
sqrt for double
TString rn()
Get random string.
std::vector< Atom > slice(std::vector< Atom > vec, int s, int e)
Slice the vector to contain only elements with indexes s .. e (included)
std::vector< std::vector< double > > merge(std::vector< std::vector< std::vector< double >>> toMerge)
merge { vector<double> a, vector<double> b} into {a, b}
Eigen::MatrixXd vecs2mat(std::vector< std::vector< double >> vecs)
merge columns (from std::vectors) into ROOT matrix
Eigen::VectorXd vec2vec(std::vector< double > vec)
std vector -> ROOT vector
const std::vector< double > v2
MATLAB generated random vector.
const std::vector< double > v1
MATLAB generated random vector.
structure containing most of the beam spot parameters
SpotParam(const std::vector< double > &vals, const std::vector< double > &errs, const std::vector< std::vector< double >> &spls, int order=0)
Constructor based output of the linear regression, assuming zero-order splines vals,...
void print()
Print BeamSpot parameters.
Spline z
spline for BS center position as a function of time (z coordinate)
Spline x
spline for BS center position as a function of time (x coordinate)
Spline kX
spline for BS angle in the xz plane as a function of time
Spline kY
spline for BS angle in the yz plane as a function of time
Spline y
spline for BS center position as a function of time (y coordinate)
Spline with uncertainty obtained from the boot-strap replicas.
void add(Spline spl)
add boot-strap replica
std::vector< Spline > spls
vector with replicas
Spline getMeanSigma()
Get mean and 1-sigma errors of the spline values.
Spline getLimit(double v)
quantile of all points in spline, v=0.5 : median, v=0.16: lower 68% bound, v=0.84 : upper 68% bound
variable with uncertainty from boot-strap replicas
std::vector< double > vars
vector of variable values for all replicas
double getMean()
Get mean value.
double getLimit(double v)
Get quantile (v=0.5 -> median, v=0.16,v=0.84 68% confidence interval)
void add(double x)
add value to the replicas
std::vector< double > getStats()
Get basic stats.
double getSigma()
Get standard deviation.
void printStat(TString n)
Print variable of name n with stat-info.
structure including all variables of interest with uncertainties from boot-strap
UnknowSpline kY
BS angle in yz plane.
UnknowVar crossAngle
derived value of the crossing angle of the HER & LER beams
UnknowVar matZZ
ZZ element of BS size cov matrix.
UnknowVar sizeMin
smallest eigenvalue of the BS size cov matrix (similar to sizeY)
void printStat()
Print interesting statistics from boot-strap.
UnknowVar matYY
YY element of BS size cov matrix.
UnknowVar sizeZ
BS size in z direction.
UnknowSpline z
BS position (z coordinate)
void add(SpotParam sPar, double SizeX, double SizeY, double SizeXY, double SizeZ)
add next boot-strap replica of the BS parameters
UnknowVar sizeY
BS size in y direction.
UnknowVar matXZ
XZ element of BS size cov matrix.
void getOutput(std::vector< VectorXd > &vtxPos, std::vector< MatrixXd > &vtxErr, MatrixXd &sizeMat)
get output in Belle2-like format
UnknowVar matXY
XY element of BS size cov matrix.
UnknowSpline y
BS position (y coordinate)
UnknowVar sizeX
BS size in x direction.
UnknowVar matXX
XX element of BS size cov matrix.
void save2tree(TString fName)
save everything to TTree
UnknowVar sizeMax
middle eigenvalue of the BS size cov matrix (similar to sizeX)
void setBranchSpline(TTree *T, Spline *spl, TString n)
save bootstrap spline to TTree
UnknowVar sizeXY
off-diagonal component of BS size cov matrix in frame where z' is aligned with z
void setBranchVal(TTree *T, std::vector< double > *vec, TString n)
save bootstrap variable to TTree
UnknowSpline x
BS position (x coordinate)
UnknowVar xyAngle
angle of the BS in xy plane when z' is aligned with z
UnknowVar matYZ
YZ element of BS size cov matrix.
UnknowSpline kX
BS angle in xz plane.
Spline structure for zero-order & linear splines.
double val(double x) const
get value of spline at point x
std::vector< double > nodes
vector of spline nodes
std::vector< double > errs
vector of spline errors
std::vector< double > vals
vector of spline values
void print(TString tag="")
print the spline
double center() const
Get center of the spline domain.