Belle II Software  release-08-01-10
GblFitter Class Reference

Generic GBL implementation. More...

#include <GblFitter.h>

Inheritance diagram for GblFitter:
Collaboration diagram for GblFitter:

Public Member Functions

 GblFitter ()
 Default (and only) constructor.
 
virtual ~GblFitter ()
 Destructor.
 
void setOptions (const std::string &internalIterations="", bool enableScatterers=true, bool enableIntermediateScatterer=true, unsigned int externalIterations=1, unsigned int recalcJacobians=1)
 Set options of the fitter/GBL. More...
 
void setMSOptions (bool enableScatterers=true, bool enableIntermediateScatterer=true)
 Set multiple scattering options of the fitter/GBL. More...
 
void getScattererFromMatList (double &length, double &theta, double &s, double &ds, const double p, const double mass, const double charge, const std::vector< genfit::MatStep > &steps) const
 Evaluates moments of radiation length distribution from list of material steps and computes parameters describing a corresponding thick scatterer. More...
 
void processTrackWithRep (Track *trk, const AbsTrackRep *rep, bool resortHits=false) override
 Performs fit on a Track. More...
 
double constructGblInfo (Track *trk, const AbsTrackRep *rep)
 Propagate seed, populate track with scatterers and GblFitterInfos with reference state set. More...
 
void updateGblInfo (gbl::GblTrajectory &traj, genfit::Track *trk, const genfit::AbsTrackRep *rep)
 Populate all fitter infos in track for rep with results of trajectory fit. More...
 
std::vector< gbl::GblPointcollectGblPoints (genfit::Track *trk, const genfit::AbsTrackRep *rep)
 Constructs all GBL points and returns them in vector for trajectory construction. More...
 
void cleanGblInfo (Track *trk, const AbsTrackRep *rep) const
 Remove all previous gbl fitter data from track Also removes trackpoints without measurement. More...
 
void sortHits (Track *trk, const AbsTrackRep *rep) const
 Sort hits in track by arc-len using extrapolation. More...
 
void setTrackSegmentController (GblTrackSegmentController *controler)
 
void processTrack (Track *, bool resortHits=false)
 Process all reps. More...
 
virtual void setDebugLvl (unsigned int lvl=1)
 

Protected Attributes

unsigned int debugLvl_
 

Private Member Functions

 GblFitter (const GblFitter &)
 
GblFitteroperator= (GblFitter const &)
 

Private Attributes

std::string m_gblInternalIterations
 
bool m_enableScatterers
 
bool m_enableIntermediateScatterer
 
unsigned int m_externalIterations
 
unsigned int m_recalcJacobians
 
double scatEpsilon
 
GblTrackSegmentControllerm_segmentController
 

Detailed Description

Generic GBL implementation.

The interface class to GBL track fit

Definition at line 53 of file GblFitter.h.

Member Function Documentation

◆ cleanGblInfo()

void cleanGblInfo ( Track trk,
const AbsTrackRep rep 
) const

Remove all previous gbl fitter data from track Also removes trackpoints without measurement.

Parameters
trkThe track
repRepresentation for which to clean data
Returns
void

Definition at line 233 of file GblFitter.cc.

233  {
234 
235  for (int ip = trk->getNumPoints() - 1; ip >=0; ip--) {
236  trk->getPoint(ip)->setScatterer(nullptr);
237  trk->getPoint(ip)->deleteFitterInfo(rep);
238  //TODO
239  if (!trk->getPoint(ip)->hasRawMeasurements())
240  trk->deletePoint(ip);
241  }
242 }

◆ collectGblPoints()

std::vector< gbl::GblPoint > collectGblPoints ( genfit::Track trk,
const genfit::AbsTrackRep rep 
)

Constructs all GBL points and returns them in vector for trajectory construction.

Returns
const std::vector< gbl::GblPoint, std::allocator >&

Definition at line 274 of file GblFitter.cc.

◆ constructGblInfo()

double constructGblInfo ( Track trk,
const AbsTrackRep rep 
)

Propagate seed, populate track with scatterers and GblFitterInfos with reference state set.

Parameters
trkTrack to attach with infos at given rep
repTrackRep to which fitter info shall be attached
Returns
Length of track from extrapolations

Definition at line 376 of file GblFitter.cc.

◆ getScattererFromMatList()

void getScattererFromMatList ( double &  length,
double &  theta,
double &  s,
double &  ds,
const double  p,
const double  mass,
const double  charge,
const std::vector< genfit::MatStep > &  steps 
) const

Evaluates moments of radiation length distribution from list of material steps and computes parameters describing a corresponding thick scatterer.

Based on input from Claus Kleinwort (DESY), adapted for continuous material distribution represented by a sum of step functions. Returned thick scatterer can be represented by two GBL scattering points. Calculates variance of theta from total sum of radiation lengths instead of summimg squares of individual deflection angle variances.

Parameters
lengthreturned: Length of the track
thetareturned: Variation of distribution of deflection angle
sreturned: First moment of material scattering distribution
dsreturned: Second moment (variance) of material scattering distribution
pParticle momentum magnitude (GeV/c)
massMass of particle (GeV/c/c)
stepsVector of material steps from (RKTrackRep) extrapolation
Returns
void

Definition at line 315 of file GblFitter.cc.

◆ processTrack()

void processTrack ( Track tr,
bool  resortHits = false 
)
inherited

Process all reps.

Start with the cardinalRep and resort the hits if necessary (and supported by the fitter)

Definition at line 25 of file AbsFitter.cc.

◆ processTrackWithRep()

void processTrackWithRep ( Track trk,
const AbsTrackRep rep,
bool  resortHits = false 
)
overridevirtual

Performs fit on a Track.

Hit resorting currently supported (use only if necessary /wire chamber/ ... will extrapolate along whole track to sort the hits).

Implements AbsFitter.

Definition at line 106 of file GblFitter.cc.

◆ setMSOptions()

void setMSOptions ( bool  enableScatterers = true,
bool  enableIntermediateScatterer = true 
)
inline

Set multiple scattering options of the fitter/GBL.

Returns
void
Parameters
enableScatterersIf false, no scatterers will be added to GBL trajectory
enableIntermediateScattererTrue to simulate thick sctatterers by two thin scatterers 1st at detector plane and intermediate between each two planes

Definition at line 119 of file GblFitter.h.

119  {
120  if (!enableScatterers)
121  enableIntermediateScatterer = false;
122  m_enableScatterers = enableScatterers;
123  m_enableIntermediateScatterer = enableIntermediateScatterer;
124  }

◆ setOptions()

void setOptions ( const std::string &  internalIterations = "",
bool  enableScatterers = true,
bool  enableIntermediateScatterer = true,
unsigned int  externalIterations = 1,
unsigned int  recalcJacobians = 1 
)
inline

Set options of the fitter/GBL.

Returns
void
Parameters
internalIterationsGBL down-weighting in iterations. One letter (T,H,C) per iteration. Seems "HH" is resonable for outliers. Default "" is OK. Separate by comma for each external iteration (usually last), e.g., for 3 iterations: ",,HH" to down-weight at last one
enableScatterersIf false, no scatterers will be added to GBL trajectory
enableIntermediateScattererTrue to simulate thick sctatterers by two thin scatterers 1st at detector plane and intermediate between each two planes
externalIterationsSets number of times GblTrajectory.fit(...) will be called in processTrackWithRep(...). Called external iterations. State is updated each time with GBL results. If =0, GblFitterInfos will filled by reference states and GblFitStatus in track able to construct simple GBL trajectory (for fit by GBL of output to Mille binary) / get list of points 1st at detector plane and intermediate between each two planes
recalcJacobiansNumber of iteration up to which Jacobians should be recalculated / planes/meas updated after the fit. 0 = do not recalculate Jacobians. 1 = recalculate after first GBL fit. 2 = after 1st and 2nd GBL fit etc.

Definition at line 100 of file GblFitter.h.

◆ sortHits()

void sortHits ( Track trk,
const AbsTrackRep rep 
) const

Sort hits in track by arc-len using extrapolation.

Parameters
trkThe track
repThe track representation
Returns
void

Definition at line 244 of file GblFitter.cc.

◆ updateGblInfo()

void updateGblInfo ( gbl::GblTrajectory traj,
genfit::Track trk,
const genfit::AbsTrackRep rep 
)

Populate all fitter infos in track for rep with results of trajectory fit.

Updates also seed state in track (from forward prediction at first point)

(The trajectory can only be cut before track end, cannot have missing points in between (if valid))

TODO ?? Re-construct all points in GblFitterInfos (updated) and collect them in fit status

Parameters
trajThe fitted GblTrajectory
trkThe track with fitter infos from whose points traj was created
repThe representation to which this fit status belong

Definition at line 289 of file GblFitter.cc.


The documentation for this class was generated from the following files: