10#include <analysis/modules/ParticleVertexFitter/ParticleVertexFitterModule.h>
13#include <framework/gearbox/Unit.h>
14#include <framework/gearbox/Const.h>
15#include <framework/geometry/B2Vector3.h>
16#include <framework/logging/Logger.h>
17#include <framework/particledb/EvtGenDatabasePDG.h>
20#include <analysis/dataobjects/Particle.h>
21#include <analysis/dataobjects/Btube.h>
22#include <mdst/dataobjects/V0.h>
25#include <analysis/utility/CLHEPToROOT.h>
26#include <analysis/utility/PCmsLabTransform.h>
27#include <analysis/utility/ParticleCopy.h>
28#include <analysis/utility/ROOTToCLHEP.h>
31#include <framework/geometry/BFieldManager.h>
34#include <analysis/VertexFitting/KFit/KFitConst.h>
64 "Confidence level to accept the fit. Particle candidates with "
65 "p-value less than confidenceLevel are removed from the particle "
66 "list. If set to -1, all candidates are kept; if set to 0, "
67 "the candidates failing the fit are removed.",
70 addParam(
"fitType",
m_fitType,
"type of the kinematic fit (vertex, massvertex, mass)",
string(
"vertex"));
72 "additional constraint on vertex: ipprofile, iptube, mother, iptubecut, pointing, btube",
74 addParam(
"decayString",
m_decayString,
"specifies which daughter particles are included in the kinematic fit",
string(
""));
79 "Type::[int]. List of daughter particles to mass constrain with int = pdg code. (only for MassFourCKFit)", {});
94 B2DEBUG(1,
"ParticleVertexFitterModule : magnetic field = " <<
m_Bfield);
102 B2INFO(
"ParticleVertexFitter: Using specified decay string: " <<
m_decayString);
104 B2INFO(
"ParticleVertexFitter: Additional " <<
m_withConstraint <<
" will be applied");
122 TMatrixDSym beamSpotCov(3);
139 std::vector<unsigned int> toRemove;
140 unsigned int nParticles =
m_plist->getListSize();
142 for (
unsigned iPart = 0; iPart < nParticles; iPart++) {
148 else B2ERROR(
"Daughters update works only when all daughters are selected. Daughters will not be updated");
156 TMatrixFSym mother_errMatrix(7);
157 mother_errMatrix = particle->getMomentumVertexErrorMatrix();
158 for (
int k = 0; k < 7; k++) {
159 for (
int j = 0; j < 7; j++) {
160 if (mother_errMatrix[k][j] > 0) {
171 toRemove.push_back(particle->getArrayIndex());
182 particle->setPValue(-1);
184 toRemove.push_back(particle->getArrayIndex());
187 m_plist->removeParticles(toRemove);
199 B2FATAL(
"ParticleVertexFitter: No magnetic field");
209 B2FATAL(
"ParticleVertexFitter: " <<
m_withConstraint <<
" ***invalid Constraint ");
216 B2FATAL(
"ParticleVertexFitter: KFit does not support yet selection of daughters via decay string except for vertex fit!");
232 B2FATAL(
"ParticleVertexFitter: Invalid options - mass-constrained fit using KFit does not work with iptube or ipprofile constraint.");
243 B2FATAL(
"ParticleVertexFitter: Invalid options - mass fit using KFit does not work with iptube or ipprofile constraint.");
252 B2FATAL(
"ParticleVertexFitter: Invalid options - four C fit using KFit does not work with iptube or ipprofile constraint.");
261 B2FATAL(
"ParticleVertexFitter: Invalid options - four C fit using KFit does not work with iptube or ipprofile constraint.");
270 B2FATAL(
"ParticleVertexFitter: Invalid options - recoil mass fit using KFit does not work with iptube or ipprofile constraint.");
283 B2FATAL(
"ParticleVertexFitter: " <<
m_fitType <<
" ***invalid fit type for the vertex fitter ");
290 }
catch (
const rave::CheckedFloatException&) {
291 B2ERROR(
"Invalid inputs (nan/inf)?");
298 B2FATAL(
"ParticleVertexFitter: " <<
m_vertexFitter <<
" ***invalid vertex fitter ");
300 if (!ok)
return false;
310 std::vector<const Particle*>& twoPhotonChildren)
314 for (
unsigned ichild = 0; ichild < mother->
getNDaughters(); ichild++) {
321 fitChildren.push_back(child);
327 auto itr = fitChildren.begin();
328 while (itr != fitChildren.end()) {
331 if (child->getPValue() < 0) {
332 B2WARNING(
"Daughter with PDG code " << child->getPDGCode() <<
" does not have a valid error matrix.");
335 bool isTwoPhotonParticle =
false;
338 if (child->getNDaughters() == 2) {
341 isTwoPhotonParticle =
true;
346 if (isTwoPhotonParticle) {
348 twoPhotonChildren.push_back(child);
349 itr = fitChildren.erase(itr);
359 const std::vector<const Particle*>& fitChildren)
361 if (fitChildren.empty())
362 B2WARNING(
"[ParticleVertexFitterModule::fillNotFitParticles] fitChildren is empty! Please call fillFitParticles firstly");
363 if (!notFitChildren.empty())
364 B2WARNING(
"[ParticleVertexFitterModule::fillNotFitParticles] notFitChildren is NOT empty!"
365 <<
" The function should be called only once");
371 std::function<bool(
const Particle*)> funcCheckInFit =
372 [&funcCheckInFit, ¬FitChildren, fitChildren](
const Particle * part) {
376 if (std::find(fitChildren.begin(), fitChildren.end(), part) != fitChildren.end())
380 if (part->getNDaughters() == 0)
385 bool isAnyChildrenInFit =
false;
386 vector<const Particle*> notFitChildren_tmp;
387 for (
unsigned ichild = 0; ichild < part->getNDaughters(); ichild++) {
389 const Particle* child = part->getDaughter(ichild);
390 bool isChildrenInFit = funcCheckInFit(child);
391 isAnyChildrenInFit = isChildrenInFit or isAnyChildrenInFit;
394 if (!isChildrenInFit)
395 notFitChildren_tmp.push_back(child);
399 if (isAnyChildrenInFit)
400 notFitChildren.insert(notFitChildren.end(), notFitChildren_tmp.begin(), notFitChildren_tmp.end());
404 return isAnyChildrenInFit;
409 for (
unsigned ichild = 0; ichild < mother->
getNDaughters(); ichild++) {
411 bool isGivenParticleOrAnyChildrenInFit = funcCheckInFit(child);
412 if (!isGivenParticleOrAnyChildrenInFit)
413 notFitChildren.push_back(child);
436 TMatrixFSym errMatrix(3);
437 for (
int i = 0; i < 3; i++)
438 for (
int j = 0; j < 3; j++)
439 errMatrix(i, j) = posErrorMatrix[i][j];
441 g1ErrMatrix.SetSub(4, errMatrix);
442 g2ErrMatrix.SetSub(4, errMatrix);
458 int err = km.
doFit();
476 std::vector<const Particle*> fitChildren;
477 std::vector<const Particle*> twoPhotonChildren;
478 bool validChildren =
fillFitParticles(mother, fitChildren, twoPhotonChildren);
483 std::vector<const Particle*> notFitChildren;
487 if (twoPhotonChildren.size() > 1) {
488 B2FATAL(
"[ParticleVertexFitterModule::doKVertexFit] Vertex fit using KFit does not support fit with multiple particles decaying to two photons like pi0 (yet).");
491 if ((fitChildren.size() < 2 && !ipTubeConstraint) || fitChildren.size() < 1) {
492 B2WARNING(
"[ParticleVertexFitterModule::doKVertexFit] Number of particles with valid error matrix entering the vertex fit using KFit is too low.");
500 if (mother->
getV0()) {
507 for (
auto& child : fitChildren)
510 if (ipProfileConstraint)
513 if (ipTubeConstraint)
517 int err = kv.
doFit();
527 if (twoPhotonChildren.size() == 0)
530 else if (twoPhotonChildren.size() == 1) {
536 const Particle* twoPhotonDaughter = twoPhotonChildren[0];
546 for (
auto& child : fitChildren)
551 if (ipProfileConstraint)
563 ROOT::Math::PxPyPzEVector total4Vector(mother->
get4Vector());
564 for (
auto& child : notFitChildren)
565 total4Vector += child->get4Vector();
575 std::vector<const Particle*> fitChildren;
576 std::vector<const Particle*> twoPhotonChildren;
577 bool validChildren =
fillFitParticles(mother, fitChildren, twoPhotonChildren);
582 if (twoPhotonChildren.size() > 1) {
583 B2FATAL(
"[ParticleVertexFitterModule::doKVertexFit] MassVertex fit using KFit does not support fit with multiple particles decaying to two photons like pi0 (yet).");
586 if (fitChildren.size() < 2) {
587 B2WARNING(
"[ParticleVertexFitterModule::doKVertexFit] Number of particles with valid error matrix entering the vertex fit using KFit is less than 2.");
592 if (twoPhotonChildren.size() == 0) {
597 if (mother->
getV0()) {
604 for (
auto child : fitChildren)
608 int err = kmv.
doFit();
614 }
else if (twoPhotonChildren.size() == 1) {
623 for (
auto child : fitChildren)
627 int err = kv.
doFit();
631 const Particle* twoPhotonDaughter = twoPhotonChildren[0];
641 for (
auto child : fitChildren)
666 std::vector<const Particle*> fitChildren;
667 std::vector<const Particle*> twoPhotonChildren;
668 bool validChildren =
fillFitParticles(mother, fitChildren, twoPhotonChildren);
673 if (twoPhotonChildren.size() > 0) {
674 B2FATAL(
"[ParticleVertexFitterModule::doKMassPointingVertexFit] MassPointingVertex fit using KFit does not support fit with two-photon daughters (yet).");
677 if (fitChildren.size() < 2) {
678 B2WARNING(
"[ParticleVertexFitterModule::doKMassPointingVertexFit] Number of particles with valid error matrix entering the vertex fit using KFit is less than 2.");
687 for (
auto child : fitChildren)
695 int err = kmpv.
doFit();
696 if (err != 0)
return false;
710 for (
unsigned ichild = 0; ichild < mother->
getNDaughters(); ichild++) {
713 if (child->getPValue() < 0)
return false;
721 int err = km.
doFit();
723 if (err != 0)
return false;
737 for (
unsigned ichild = 0; ichild < mother->
getNDaughters(); ichild++) {
740 if (child->getNDaughters() > 0) {
742 if (!err)
return false;
744 if (child->getPValue() < 0)
return false;
754 int err = kf.
doFit();
756 if (err != 0)
return false;
770 for (
unsigned ichild = 0; ichild < mother->
getNDaughters(); ichild++) {
773 if (child->getNDaughters() > 0) {
776 std::vector<unsigned> childId;
779 if (!err)
return false;
781 if (child->getPValue() < 0)
return false;
790 int err = kf.
doFit();
792 if (err != 0)
return false;
804 for (
unsigned ichild = 0; ichild < mother->
getNDaughters(); ichild++) {
807 if (child->getPValue() < 0)
return false;
819 int err = kf.
doFit();
821 if (err != 0)
return false;
839 std::vector<Particle*> daughters = mother->
getDaughters();
842 if (daughters.size() != track_count)
845 for (
unsigned iChild = 0; iChild < track_count; iChild++) {
850 ROOT::Math::PxPyPzEVector i4Vector(kv.
getTrackMomentum(iChild).x() - a * dy,
854 daughters[iChild]->set4VectorDividingByMomentumScaling(i4Vector);
856 daughters[iChild]->setVertex(
858 daughters[iChild]->setMomentumVertexErrorMatrix(
867 if (fitChildren.size() != track_count)
870 for (
unsigned iChild = 0; iChild < track_count; iChild++) {
871 auto daughter =
const_cast<Particle*
>(fitChildren[iChild]);
877 ROOT::Math::PxPyPzEVector i4Vector(kv.
getTrackMomentum(iChild).x() - a * dy,
881 daughter->set4VectorDividingByMomentumScaling(i4Vector);
883 daughter->setVertex(CLHEPToROOT::getXYZVector(kv.
getTrackPosition(iChild)));
884 daughter->setMomentumVertexErrorMatrix(CLHEPToROOT::getTMatrixFSym(kv.
getTrackError(iChild)));
888 std::function<bool(
Particle*)> funcUpdateMomentum =
889 [&funcUpdateMomentum, fitChildren](
Particle * part) {
891 if (part->getNDaughters() == 0) {
893 if (std::find(fitChildren.begin(), fitChildren.end(), part) != fitChildren.end())
899 bool includeFitChildren =
false;
902 for (
auto daughter : part->getDaughters())
903 includeFitChildren = funcUpdateMomentum(daughter) || includeFitChildren;
905 if (includeFitChildren) {
907 ROOT::Math::PxPyPzEVector sum4Vector;
908 for (
auto daughter : part->getDaughters())
909 sum4Vector += daughter->get4Vector();
911 part->set4VectorDividingByMomentumScaling(sum4Vector);
914 return includeFitChildren;
919 funcUpdateMomentum(daughter);
938 std::vector<Particle*> daughters = mother->
getDaughters();
941 if (daughters.size() != track_count)
944 for (
unsigned iChild = 0; iChild < track_count; iChild++) {
949 ROOT::Math::PxPyPzEVector i4Vector(kmv.
getTrackMomentum(iChild).x() - a * dy,
953 daughters[iChild]->set4VectorDividingByMomentumScaling(i4Vector);
955 daughters[iChild]->setVertex(
957 daughters[iChild]->setMomentumVertexErrorMatrix(
978 std::vector<Particle*> daughters = mother->
getDaughters();
981 if (daughters.size() != track_count)
984 for (
unsigned iChild = 0; iChild < track_count; iChild++) {
989 ROOT::Math::PxPyPzEVector i4Vector(kmpv.
getTrackMomentum(iChild).x() - a * dy,
993 daughters[iChild]->set4VectorDividingByMomentumScaling(i4Vector);
995 daughters[iChild]->setVertex(
997 daughters[iChild]->setMomentumVertexErrorMatrix(
1017 std::vector<Particle*> daughters = mother->
getDaughters();
1020 if (daughters.size() != track_count)
1023 for (
unsigned iChild = 0; iChild < track_count; iChild++) {
1028 ROOT::Math::PxPyPzEVector i4Vector(km.
getTrackMomentum(iChild).x() - a * dy,
1032 daughters[iChild]->set4VectorDividingByMomentumScaling(i4Vector);
1034 daughters[iChild]->setVertex(
1036 daughters[iChild]->setMomentumVertexErrorMatrix(
1058 std::vector<Particle*> daughters = mother->
getDaughters();
1060 const unsigned nd = daughters.size();
1062 std::vector<std::vector<unsigned>> pars;
1063 std::vector<Particle*> allparticles;
1064 for (
unsigned ichild = 0; ichild < nd; ichild++) {
1066 std::vector<unsigned> pard;
1067 if (daughter->getNDaughters() > 0) {
1069 pars.push_back(pard);
1070 allparticles.push_back(daughters[ichild]);
1073 pars.push_back(pard);
1074 allparticles.push_back(daughters[ichild]);
1080 if (l != track_count)
1083 for (
unsigned iDaug = 0; iDaug < allparticles.size(); iDaug++) {
1084 ROOT::Math::PxPyPzEVector childMoms;
1085 ROOT::Math::XYZVector childPoss;
1086 TMatrixFSym childErrMatrixs(7);
1087 for (
unsigned int iChild : pars[iDaug]) {
1088 childMoms = childMoms +
1089 CLHEPToROOT::getLorentzVector(
1091 childPoss = childPoss +
1092 CLHEPToROOT::getXYZVector(
1094 TMatrixFSym childErrMatrix =
1096 childErrMatrixs = childErrMatrixs + childErrMatrix;
1098 allparticles[iDaug]->set4Vector(childMoms);
1099 allparticles[iDaug]->setVertex(childPoss);
1100 allparticles[iDaug]->setMomentumVertexErrorMatrix(childErrMatrixs);
1120 std::vector<Particle*> daughters = mother->
getDaughters();
1122 const unsigned nd = daughters.size();
1124 std::vector<std::vector<unsigned>> pars;
1125 std::vector<Particle*> allparticles;
1126 for (
unsigned ichild = 0; ichild < nd; ichild++) {
1128 std::vector<unsigned> pard;
1129 if (daughter->getNDaughters() > 0) {
1131 pars.push_back(pard);
1132 allparticles.push_back(daughters[ichild]);
1135 pars.push_back(pard);
1136 allparticles.push_back(daughters[ichild]);
1142 if (l != track_count)
1145 for (
unsigned iDaug = 0; iDaug < allparticles.size(); iDaug++) {
1146 ROOT::Math::PxPyPzEVector childMoms;
1147 ROOT::Math::XYZVector childPoss;
1148 TMatrixFSym childErrMatrixs(7);
1149 for (
unsigned int iChild : pars[iDaug]) {
1150 childMoms = childMoms +
1151 CLHEPToROOT::getLorentzVector(
1153 childPoss = childPoss +
1154 CLHEPToROOT::getXYZVector(
1156 TMatrixFSym childErrMatrix =
1158 childErrMatrixs = childErrMatrixs + childErrMatrix;
1160 allparticles[iDaug]->set4Vector(childMoms);
1161 allparticles[iDaug]->setVertex(childPoss);
1162 allparticles[iDaug]->setMomentumVertexErrorMatrix(childErrMatrixs);
1182 std::vector<Particle*> daughters = mother->
getDaughters();
1185 if (daughters.size() != track_count)
1188 for (
unsigned iChild = 0; iChild < track_count; iChild++) {
1193 ROOT::Math::PxPyPzEVector i4Vector(kf.
getTrackMomentum(iChild).x() - a * dy,
1197 daughters[iChild]->set4VectorDividingByMomentumScaling(i4Vector);
1199 daughters[iChild]->setVertex(
1201 daughters[iChild]->setMomentumVertexErrorMatrix(
1211 std::vector<unsigned>& parm, std::vector<Particle*>& allparticles,
const Particle* daughter)
1213 std::vector <Belle2::Particle*> daughters = daughter->getDaughters();
1214 for (
unsigned ichild = 0; ichild < daughter->getNDaughters(); ichild++) {
1215 const Particle* child = daughter->getDaughter(ichild);
1216 std::vector<unsigned> pard;
1217 if (child->getNDaughters() > 0) {
1219 parm.insert(parm.end(), pard.begin(), pard.end());
1220 pars.push_back(pard);
1221 allparticles.push_back(daughters[ichild]);
1225 pars.push_back(pard);
1226 allparticles.push_back(daughters[ichild]);
1252 for (
auto& itrack : tracksVertex) {
1253 if (itrack != mother) rf.
addTrack(itrack);
1259 bool mothSel =
false;
1261 for (
unsigned itrack = 0; itrack < tracksVertex.size(); itrack++) {
1262 if (tracksVertex[itrack] != mother) {
1263 rsf.
addTrack(tracksVertex[itrack]);
1264 B2DEBUG(1,
"ParticleVertexFitterModule: Adding particle " << tracksName[itrack] <<
" to vertex fit ");
1267 if (tracksVertex[itrack] == mother) mothSel =
true;
1272 bool mothIPfit =
false;
1273 if (tracksVertex.size() == 1 && mothSel ==
true &&
m_withConstraint !=
"" && nTrk == 0) {
1275 if (tracksVertex[0] != mother)
1276 B2FATAL(
"ParticleVertexFitterModule: FATAL Error in IP constrained mother fit");
1282 ROOT::Math::XYZVector pos;
1283 TMatrixDSym RerrMatrix(3);
1289 for (
auto& itrack : tracksVertex) {
1291 nvert = rsg.
fit(
"kalman");
1294 RerrMatrix = rsg.
getCov(0);
1296 ROOT::Math::PxPyPzEVector mom(mother->
get4Vector());
1297 TMatrixDSym errMatrix(7);
1298 for (
int i = 0; i < 7; i++) {
1299 for (
int j = 0; j < 7; j++) {
1300 if (i > 3 && j > 3) {errMatrix[i][j] = RerrMatrix[i - 4][j - 4];}
1301 else {errMatrix[i][j] = 0;}
1321 }
else {
return false;}
1331 ROOT::Math::PxPyPzEVector mom(mother->
get4Vector());
1332 TMatrixDSym errMatrix(7);
1333 for (
int i = 0; i < 7; i++) {
1334 for (
int j = 0; j < 7; j++) {
1335 if (i > 3 && j > 3) {errMatrix[i][j] = RerrMatrix[i - 4][j - 4];}
1336 else {errMatrix[i][j] = 0;}
1340 }
else {
return false;}
1343 if (mothSel && nTrk > 1) {
1346 int nKfit = rf.
fit();
1350 if (nKfit > 0) {
return true;}
1359 int nVert = rf.
fit();
1362 if (nVert != 1)
return false;
1369 int nVert = rf.
fit();
1371 if (nVert != 1)
return false;
1376 int nVert = rf.
fit();
1379 if (nVert != 1)
return false;
1382 B2FATAL(
"fitType : " <<
m_fitType <<
" ***invalid fit type ");
1389 const std::vector<const Particle*>& tracksVertex)
1398 for (
auto& vi : tracksVertex) {
1400 nNotIncluded = nNotIncluded - 1;
1408 if (nNotIncluded == 0) isAll =
true;
1414 for (
unsigned ichild = 0; ichild < particle->getNDaughters(); ichild++) {
1415 const Particle* child = particle->getDaughter(ichild);
1418 if (child->getPValue() < 0)
return false;
1427 std::vector<unsigned>& particleId)
1429 for (
unsigned ichild = 0; ichild < particle->getNDaughters(); ichild++) {
1430 const Particle* child = particle->getDaughter(ichild);
1431 if (child->getNDaughters() > 0) {
1434 std::vector<unsigned> childId;
1437 particleId.insert(particleId.end(), childId.begin(), childId.end());
1439 if (child->getPValue() < 0)
return false;
1450 CLHEP::HepSymMatrix covMatrix(3, 0);
1452 for (
int i = 0; i < 3; i++) {
1454 for (
int j = 0; j < 3; j++) {
1464 CLHEP::HepSymMatrix err(7, 0);
1466 for (
int i = 0; i < 3; i++) {
1467 for (
int j = 0; j < 3; j++) {
1476 ROOTToCLHEP::getHepLorentzVector(iptube_mom),
1489 TMatrixDSym beamSpotCov =
m_beamSpotDB->getCovVertex();
1490 beamSpotCov(2, 2) = cut * cut;
1491 double thetab = boostDir.
Theta();
1492 double phib = boostDir.
Phi();
1494 double stb = TMath::Sin(thetab);
1495 double ctb = TMath::Cos(thetab);
1496 double spb = TMath::Sin(phib);
1497 double cpb = TMath::Cos(phib);
1500 TMatrix rz(3, 3); rz(2, 2) = 1;
1501 rz(0, 0) = cpb; rz(0, 1) = spb;
1502 rz(1, 0) = -1 * spb; rz(1, 1) = cpb;
1504 TMatrix ry(3, 3); ry(1, 1) = 1;
1505 ry(0, 0) = ctb; ry(0, 2) = -1 * stb;
1506 ry(2, 0) = stb; ry(2, 2) = ctb;
1508 TMatrix r(3, 3); r.Mult(rz, ry);
1509 TMatrix rt(3, 3); rt.Transpose(r);
1511 TMatrix TubePart(3, 3); TubePart.Mult(rt, beamSpotCov);
1512 TMatrix Tube(3, 3); Tube.Mult(TubePart, r);
1521 TMatrixDSym beamSpotCov =
m_beamSpotDB->getCovVertex();
1522 for (
int i = 0; i < 3; i++)
1523 beamSpotCov(i, i) += width * width;
1530 double chi2TrackL = 0;
1532 for (
int iTrack = 0; iTrack < kv.
getTrackCount(); iTrack++) {
1544 TVectorD boostD(0, 6, 0., 0., 0., 0., boost3.
X(), boost3.
Y(), boost3.
Z(),
"END");
1546 double dLBoost = dPos.
Dot(boost3);
1548 chi2TrackL += TMath::Power(dLBoost, 2) / err.Similarity(boostD);
DataType Phi() const
The azimuth angle.
DataType Z() const
access variable Z (= .at(2) without boundary check)
DataType Theta() const
The polar angle.
DataType X() const
access variable X (= .at(0) without boundary check)
DataType Y() const
access variable Y (= .at(1) without boundary check)
DataType Dot(const B2Vector3< DataType > &p) const
Scalar product.
B2Vector3< DataType > Unit() const
Unit vector parallel to this.
void SetXYZ(DataType x, DataType y, DataType z)
set all coordinates using data type
static ROOT::Math::XYZVector getFieldInTesla(const ROOT::Math::XYZVector &pos)
return the magnetic field at a given position in Tesla.
For each MCParticle with hits in the CDC, this class stores some summarising information on those hit...
TMatrixFSym getTubeMatrix() const
Returns Btube matrix.
Eigen::Matrix< double, 3, 1 > getTubeCenter() const
Returns Btube center.
int getPDGCode() const
PDG code.
static const ParticleType pi0
neutral pion particle
static const double speedOfLight
[cm/ns]
static const ParticleType photon
photon particle
bool init(const std::string &str)
Initialise the DecayDescriptor from given string.
std::vector< std::string > getSelectionNames()
Return list of human readable names of selected particles.
std::vector< const Particle * > getSelectionParticles(const Particle *particle)
Get a vector of pointers with selected daughters in the decay tree.
void setDescription(const std::string &description)
Sets the description of the module.
void setPropertyFlags(unsigned int propertyFlags)
Sets the flags for the module properties.
@ c_ParallelProcessingCertified
This module can be run in parallel processing mode safely (All I/O must be done through the data stor...
TMatrixDSym m_beamSpotCov
Beam spot covariance matrix.
bool makeKMassMother(analysis::MassFitKFit &kv, Particle *p)
Update mother particle after mass fit using KFit.
std::string m_withConstraint
additional constraint on vertex
bool doKMassPointingVertexFit(Particle *p)
Mass-constrained vertex fit with additional pointing constraint using KFit.
void smearBeamSpot(double width)
smear beam spot covariance
bool makeMassKFourCMother(analysis::MassFourCFitKFit &kv, Particle *p)
Update mother particle after MassFourC fit using KFit.
void updateMapOfTrackAndDaughter(unsigned &l, std::vector< std::vector< unsigned > > &pars, std::vector< unsigned > &pard, std::vector< Particle * > &allparticles, const Particle *daughter)
update the map of daughter and tracks, find out which tracks belong to each daughter.
bool doKVertexFit(Particle *p, bool ipProfileConstraint, bool ipTubeConstraint)
Unconstrained vertex fit using KFit.
bool doKMassVertexFit(Particle *p)
Mass-constrained vertex fit using KFit.
virtual void initialize() override
Initialize the Module.
void addIPTubeToKFit(analysis::VertexFitKFit &kv)
Adds IPTube constraint to the vertex fit using KFit.
bool addChildofParticletoMassKFit(analysis::MassFourCFitKFit &kf, const Particle *particle, std::vector< unsigned > &particleId)
Adds given particle's child to the MassFourCFitKFit.
virtual void event() override
Event processor.
bool makeKMassPointingVertexMother(analysis::MassPointingVertexFitKFit &kv, Particle *p)
Update mother particle after mass-constrained vertex fit with additional pointing constraint using KF...
bool m_updateDaughters
flag for daughters update
ParticleVertexFitterModule()
Constructor.
std::string m_decayString
daughter particles selection
std::string m_listName
particle list name
std::vector< int > m_massConstraintList
PDG codes of the particles to be mass constraint (massfourC)
bool m_hasCovMatrix
flag for mother covariance matrix (PseudoFitter)
bool makeKVertexMother(analysis::VertexFitKFit &kv, Particle *p)
Update mother particle after unconstrained vertex fit using KFit.
bool redoTwoPhotonDaughterMassFit(Particle *postFit, const Particle *preFit, const analysis::VertexFitKFit &kv)
Combines preFit particle and vertex information from vertex fit kv to create new postFit particle.
bool makeKMassVertexMother(analysis::MassVertexFitKFit &kv, Particle *p)
Update mother particle after mass-constrained vertex fit using KFit.
bool makeKFourCMother(analysis::FourCFitKFit &kv, Particle *p)
Update mother particle after FourC fit using KFit.
bool fillFitParticles(const Particle *mother, std::vector< const Particle * > &fitChildren, std::vector< const Particle * > &twoPhotonChildren)
Fills valid particle's children (with valid error matrix) in the vector of Particles that will enter ...
bool doKFourCFit(Particle *p)
FourC fit using KFit.
B2Vector3D m_BeamSpotCenter
Beam spot position.
virtual void beginRun() override
Called when entering a new run.
bool doKRecoilMassFit(Particle *p)
RecoilMass fit using KFit.
DBObjPtr< BeamSpot > m_beamSpotDB
Beam spot database object.
bool doVertexFit(Particle *p)
Main steering routine.
std::string m_vertexFitter
Vertex Fitter name.
bool doRaveFit(Particle *mother)
Fit using Rave.
bool makeKRecoilMassMother(analysis::RecoilMassKFit &kf, Particle *p)
Update mother particle after RecoilMass fit using KFit.
bool doKMassFit(Particle *p)
Mass fit using KFit.
double m_recoilMass
recoil mass for constraint
double m_confidenceLevel
required fit confidence level
bool doKMassFourCFit(Particle *p)
MassFourC fit using KFit.
DecayDescriptor m_decaydescriptor
Decay descriptor of decays to look for.
bool fillNotFitParticles(const Particle *mother, std::vector< const Particle * > ¬FitChildren, const std::vector< const Particle * > &fitChildren)
Fills valid particle's children (with valid error matrix) in the vector of Particles that will not en...
void findConstraintBoost(double cut)
calculate iptube constraint (quasi cylinder along boost direction) for RAVE fit
double m_Bfield
magnetic field from data base
bool addChildofParticletoKFit(analysis::FourCFitKFit &kv, const Particle *particle)
Adds given particle's child to the FourCFitKFit.
double getChi2TracksLBoost(const analysis::VertexFitKFit &kv)
calculate the chi2 using only lboost information of tracks
double m_smearing
smearing width applied to IP tube
std::string m_fitType
type of the kinematic fit
void addIPProfileToKFit(analysis::VertexFitKFit &kv)
Adds IPProfile constraint to the vertex fit using KFit.
StoreObjPtr< ParticleList > m_plist
particle list
bool allSelectedDaughters(const Particle *mother, const std::vector< const Particle * > &tracksVertex)
check if all the Daughters (o grand-daughters) are selected for the vertex fit
Class to store reconstructed particles.
void writeExtraInfo(const std::string &name, const double value)
Sets the user defined extraInfo.
bool hasExtraInfo(const std::string &name) const
Return whether the extra info with the given name is set.
const V0 * getV0() const
Returns the pointer to the V0 object that was used to create this Particle (if ParticleType == c_V0).
int getPDGCode(void) const
Returns PDG code.
int getProperty() const
Returns particle property as a bit pattern The values are defined in the PropertyFlags enum and descr...
unsigned getNDaughters(void) const
Returns number of daughter particles.
std::vector< Belle2::Particle * > getDaughters() const
Returns a vector of pointers to daughter particles.
double getPDGMass(void) const
Returns uncertainty on the invariant mass (requires valid momentum error matrix)
ROOT::Math::PxPyPzEVector get4Vector() const
Returns Lorentz vector.
void addExtraInfo(const std::string &name, double value)
Sets the user-defined data of given name to the given value.
void set4Vector(const ROOT::Math::PxPyPzEVector &p4)
Sets Lorentz vector.
void updateMomentum(const ROOT::Math::PxPyPzEVector &p4, const ROOT::Math::XYZVector &vertex, const TMatrixFSym &errMatrix, double pValue)
Sets Lorentz vector, position, 7x7 error matrix and p-value.
TMatrixFSym getMomentumVertexErrorMatrix() const
Returns 7x7 error matrix.
@ c_IsUnspecified
Ordinary particles.
const Particle * getDaughter(unsigned i) const
Returns a pointer to the i-th daughter particle.
double getExtraInfo(const std::string &name) const
Return given value if set.
double getFittedVertexX() const
Get the X coordinate of the fitted vertex.
double getFittedVertexY() const
Get the Y coordinate of the fitted vertex.
double getFittedVertexZ() const
Get the Z coordinate of the fitted vertex.
FourCFitKFit is a derived class from KFitBase to perform 4 momentum-constraint kinematical fit.
enum KFitError::ECode setFourMomentum(const ROOT::Math::PxPyPzEVector &m)
Set an 4 Momentum for the FourC-constraint fit.
double getCHIsq(void) const override
Get a chi-square of the fit.
enum KFitError::ECode updateMother(Particle *mother)
Update mother particle.
enum KFitError::ECode doFit(void)
Perform a four momentum-constraint fit.
const CLHEP::HepSymMatrix getTrackError(const int id) const
Get an error matrix of the track.
const CLHEP::HepLorentzVector getTrackMomentum(const int id) const
Get a Lorentz vector of the track.
const HepPoint3D getTrackPosition(const int id) const
Get a position of the track.
virtual int getNDF(void) const
Get an NDF of the fit.
enum KFitError::ECode setMagneticField(const double mf)
Change a magnetic field from the default value KFitConst::kDefaultMagneticField.
const KFitTrack getTrack(const int id) const
Get a specified track object.
enum KFitError::ECode addParticle(const Particle *particle)
Add a particle to the fitter.
int getTrackCount(void) const
Get the number of added tracks.
ECode
ECode is a error code enumerate.
KFitTrack is a container of the track information (Lorentz vector, position, and error matrix),...
const CLHEP::HepSymMatrix getError(const int flag=KFitConst::kAfterFit) const
Get an error matrix of the track.
const HepPoint3D getPosition(const int flag=KFitConst::kAfterFit) const
Get a position of the track.
MassFitKFit is a derived class from KFitBase to perform mass-constraint kinematical fit.
enum KFitError::ECode setVertex(const HepPoint3D &v)
Set an initial vertex position for the mass-constraint fit.
enum KFitError::ECode updateMother(Particle *mother)
Update mother particle.
enum KFitError::ECode doFit(void)
Perform a mass-constraint fit.
enum KFitError::ECode setInvariantMass(const double m)
Set an invariant mass for the mass-constraint fit.
enum KFitError::ECode setVertexError(const CLHEP::HepSymMatrix &e)
Set an initial vertex error matrix for the mass-constraint fit.
const HepPoint3D getVertex(const int flag=KFitConst::kAfterFit) const
Get a vertex position.
MassFourCFitKFit is a derived class from KFitBase to perform mass and 4 momentum-constraint kinematic...
enum KFitError::ECode setFourMomentum(const ROOT::Math::PxPyPzEVector &m)
Set an 4 Momentum for the mass-four-constraint fit.
enum KFitError::ECode addMassConstraint(const double m, std::vector< unsigned > &childTrackId)
Set an invariant mass of daughter particle for the mass-four-momentum-constraint fit.
double getCHIsq(void) const override
Get a chi-square of the fit.
enum KFitError::ECode updateMother(Particle *mother)
Update mother particle.
enum KFitError::ECode doFit(void)
Perform a mass-four-momentum-constraint fit.
MassPointingVertexFitKFit is a derived class from KFitBase It performs a kinematical fit with three c...
enum KFitError::ECode updateMother(Particle *mother)
Update mother particle.
enum KFitError::ECode doFit(void)
Perform a mass-vertex-pointing constraint fit.
enum KFitError::ECode setInvariantMass(const double m)
Set an invariant mass for the mass-vertex-pointing constraint fit.
enum KFitError::ECode setProductionVertex(const HepPoint3D &v)
Set the production vertex of the particle.
const HepPoint3D getVertex(const int flag=KFitConst::kAfterFit) const
Get a vertex position.
MassVertexFitKFit is a derived class from KFitBase to perform mass-vertex-constraint kinematical fit.
enum KFitError::ECode setInitialVertex(const HepPoint3D &v)
Set an initial vertex point for the mass-vertex constraint fit.
enum KFitError::ECode updateMother(Particle *mother)
Update mother particle.
enum KFitError::ECode doFit(void)
Perform a mass-vertex-constraint fit.
enum KFitError::ECode setInvariantMass(const double m)
Set an invariant mass for the mass-vertex constraint fit.
const HepPoint3D getVertex(const int flag=KFitConst::kAfterFit) const
Get a vertex position.
The RaveKinematicVertexFitter class is part of the RaveInterface together with RaveSetup.
void updateMother()
update the mother particle
void addMother(const Particle *aMotherParticlePtr)
All daughters of the argument of this function will be used as input for the vertex fit.
ROOT::Math::XYZVector getPos()
get the position of the fitted vertex.
void addTrack(const Particle *aParticlePtr)
add a track (in the format of a Belle2::Particle) to set of tracks that should be fitted to a vertex
void setMother(const Particle *aMotherParticlePtr)
Set Mother particle for Vertex/momentum update.
int fit()
do the kinematic vertex fit with all tracks previously added with the addTrack or addMother function.
void setVertFit(bool isVertFit=true)
Set vertex fit: set false in case of mass fit only.
void setMassConstFit(bool isConstFit=true)
Set mass constrained fit
double getPValue()
get the p value of the fitted vertex.
TMatrixDSym getVertexErrorMatrix()
get the covariance matrix (3x3) of the of the fitted vertex position.
void updateDaughters()
update the Daughters particles
void unsetBeamSpot()
unset beam spot constraint
static void initialize(int verbosity=1, double MagneticField=1.5)
Set everything up so everything needed for vertex fitting is there.
static RaveSetup * getInstance()
get the pointer to the instance to get/set any of options stored in RaveSetup
void setBeamSpot(const B2Vector3D &beamSpot, const TMatrixDSym &beamSpotCov)
The beam spot position and covariance is known you can set it here so that and a vertex in the beam s...
void reset()
frees memory allocated by initialize().
The RaveVertexFitter class is part of the RaveInterface together with RaveSetup.
TMatrixDSym getCov(VecSize vertexId=0) const
get the covariance matrix (3x3) of the of the fitted vertex position.
int fit(std::string options="default")
do the vertex fit with all tracks previously added with the addTrack or addMother function.
void addTrack(const Particle *const aParticlePtr)
add a track (in the format of a Belle2::Particle) to set of tracks that should be fitted to a vertex
B2Vector3D getPos(VecSize vertexId=0) const
get the position of the fitted vertex.
double getPValue(VecSize vertexId=0) const
get the p value of the fitted vertex.
RecoilMassKFit is a derived class from KFitBase to perform a kinematical fit with a recoil mass const...
enum KFitError::ECode setFourMomentum(const ROOT::Math::PxPyPzEVector &m)
Set a recoil mass .
double getCHIsq(void) const override
Get a chi-square of the fit.
enum KFitError::ECode updateMother(Particle *mother)
Update mother particle.
enum KFitError::ECode setRecoilMass(const double m)
Set an invariant mass for the four momentum-constraint fit.
enum KFitError::ECode doFit(void)
Perform a recoil-mass constraint fit.
const HepPoint3D getVertex(const int flag=KFitConst::kAfterFit) const
Get a vertex position.
VertexFitKFit is a derived class from KFitBase to perform vertex-constraint kinematical fit.
enum KFitError::ECode setIpTubeProfile(const CLHEP::HepLorentzVector &p, const HepPoint3D &x, const CLHEP::HepSymMatrix &e, const double q)
Set a virtual IP-tube track for the vertex constraint fit.
enum KFitError::ECode setInitialVertex(const HepPoint3D &v)
Set an initial vertex point for the vertex-vertex constraint fit.
enum KFitError::ECode updateMother(Particle *mother)
Update mother particle.
const CLHEP::HepSymMatrix getVertexError(void) const
Get a fitted vertex error matrix.
enum KFitError::ECode doFit(void)
Perform a vertex-constraint fit.
enum KFitError::ECode setIpProfile(const HepPoint3D &ip, const CLHEP::HepSymMatrix &ipe)
Set an IP-ellipsoid shape for the vertex constraint fit.
const HepPoint3D getVertex(const int flag=KFitConst::kAfterFit) const
Get a vertex position.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
#define REG_MODULE(moduleName)
Register the given module (without 'Module' suffix) with the framework.
B2Vector3< double > B2Vector3D
typedef for common usage with double
void copyDaughters(Particle *mother)
Function copies all (grand-)^n-daughter particles of the argument mother Particle.
Abstract base class for different kinds of events.
static const int kBeforeFit
Input parameter to specify before-fit when setting/getting a track attribute.