Template Class CombinatorialKalmanFilter¶
Defined in File CombinatorialKalmanFilter.hpp
Nested Relationships¶
Class Documentation¶
-
template<typename
propagator_t
, typenameupdater_t
= VoidKalmanUpdater, typenamesmoother_t
= VoidKalmanSmoother, typenamesource_link_selector_t
= CKFSourceLinkSelector, typenamebranch_stopper_t
= VoidBranchStopper, typenamecalibrator_t
= VoidMeasurementCalibrator, typenameinput_converter_t
= VoidKalmanComponents, typenameoutput_converter_t
= VoidKalmanComponents>
classActs
::
CombinatorialKalmanFilter
¶ CombinatorialKalmanFilter implementation of Acts as a plugin.
to the Propgator
The CombinatorialKalmanFilter contains an Actor and a Sequencer sub-class. The Sequencer has to be part of the Navigator of the Propagator in order to initialize and provide the measurement surfaces.
- Template Parameters
propagator_t
: Type of the propagation classupdater_t
: Type of the kalman updater classsmoother_t
: Type of the kalman smoother classsource_link_selector_t
: Type of the source link selector classbranch_stopper_t
: Type of the branch stopper classcalibrator_t
: Type of the calibrator classinput_converter_t
: Type of the input converter classoutput_converter_t
: Type of the output converter class
The Actor is part of the Propagation call and does the Kalman update and eventually the smoothing. Updater, Smoother and Calibrator are given to the Actor for further use:
The Updater is the implemented kalman updater formalism, it runs via a visitor pattern through the measurements.
The Smoother is called at the end of the forward track finding by the Actor.
The Sourcelink selector is called during the filtering by the Actor.
The Calibrator is a dedicated calibration algorithm that allows to calibrate measurements using track information, this could be e.g. sagging for wires, module deformations, etc.
Measurements are not required to be ordered for the CombinatorialKalmanFilter, measurement ordering needs to be figured out by the navigation of the propagator.
The Input converter is a converter that transforms the input measurement/track/segments into a set of FittableMeasurements
The Output converter is a converter that transforms the set of track states into a given track/track particle class
The void components are provided mainly for unit testing.
Public Types
The navigator type.
Public Functions
-
CombinatorialKalmanFilter
() = delete¶ Default constructor is deleted.
-
CombinatorialKalmanFilter
(propagator_t pPropagator, std::unique_ptr<const Logger> logger = getDefaultLogger("CombinatorialKalmanFilter", Logging::INFO), input_converter_t pInputCnv = input_converter_t(), output_converter_t pOutputCnv = output_converter_t())¶ Constructor from arguments.
-
template<typename
source_link_container_t
, typenamestart_parameters_t
, typenamecomb_kalman_filter_options_t
, typenameparameters_t
= BoundParameters>
Result<CombinatorialKalmanFilterResult<typename source_link_container_t::value_type>>findTracks
(const source_link_container_t &sourcelinks, const start_parameters_t &sParameters, const comb_kalman_filter_options_t &tfOptions) const¶ Fit implementation of the foward filter, calls the the forward filter and backward smoother.
- Note
The input measurements are given in the form of
SourceLinks
. It’scalibrator_t's
job to turn them into calibrated measurements used in the track finding.- Return
the output as an output track
- Template Parameters
source_link_container_t
: Source link container typestart_parameters_t
: Type of the initial parameterscomb_kalman_filter_options_t
: Type of the CombinatorialKalmanFilter optionsparameters_t
: Type of parameters used for local parameters
- Parameters
sourcelinks
: The fittable uncalibrated measurementssParameters
: The initial track parameterstfOptions
: CombinatorialKalmanFilterOptions steering the track finding