Global Nearest Neighbor Multi Object Tracker
Multi-sensor, multi-object tracker using GNN assignment

Libraries:
      Sensor Fusion and Tracking Toolbox / 
      Multi-Object Tracking Algorithms
   
Description
The Global Nearest Neighbor Multi Object Tracker block is capable of
      processing detections of many targets from multiple sensors, much like the trackerGNN
      System object™. The tracker initializes, confirms, predicts, corrects, and deletes tracks based
      on a global nearest neighbor (GNN) assignment algorithm. The tracker estimates the state
      vector and state vector covariance matrix for each track. Each detection is assigned to at
      most one track. If the detection cannot be assigned to any track, the tracker initializes a
      new track.
Any new track starts in a tentative state. If enough detections are assigned to a
      tentative track, its status changes to confirmed. If the detection already has a known
      classification (the ObjectClassID field of the returned track is nonzero),
      that track is confirmed immediately. When a track is confirmed, the tracker considers the
      track to represent a physical object. If detections are not assigned to the track within a
      specifiable number of updates, the track is deleted.
Examples
Track Closely Spaced Targets Under Ambiguity in Simulink
Track objects in Simulink® with Sensor Fusion and Tracking Toolbox™ when the association of sensor detections to tracks is ambiguous. It closely follows the Tracking Closely Spaced Targets Under Ambiguity MATLAB® example.
Track Simulated Vehicles Using GNN and JPDA Trackers in Simulink
Configure and utilize GNN and JPDA trackers in a simulated highway scenario in Simulink® with Sensor Fusion and Tracking Toolbox™. It closely follows the Sensor Fusion Using Synthetic Radar and Vision Data in Simulink (Automated Driving Toolbox). A main benefit of modeling the system in Simulink is the simplicity of performing "what-if" analysis and choosing a tracker that results in the best performance based on the requirements.
Ports
Input
Detection list, specified as a Simulink bus containing a MATLAB structure. The structure has the form:
| Field | Description | Type | 
|---|---|---|
| NumDetections | Number of detections | integer | 
| Detections | Object detections | Array of object detection structures. The first NumDetectionsof these detections are actual
                        detections. | 
The fields of Detections are:
| Field | Description | Type | 
|---|---|---|
| Time | Measurement time | singleordouble | 
| Measurement | Object measurements | singleordouble | 
| MeasurementNoise | Measurement noise covariance matrix | singleordouble | 
| SensorIndex | Unique ID of the sensor | singleordouble | 
| ObjectClassID | Object classification ID | singleordouble | 
| MeasurementParameters | Parameters used by initialization functions of tracking filters | Simulink Bus | 
| ObjectAttributes | Additional information passed to tracker | Simulink Bus | 
See objectDetection for more detailed
              explanations of these fields.
Note
The object detection structure contains a Time field. The
                  time tag of each object detection must be less than or equal to the time of the
                  current invocation of the block. The time tag must also be greater than the update
                  time specified in the previous invocation of the block.
Track update time, specified as a real scalar in seconds. The tracker updates all
              tracks to this time. The update time must always increase with each invocation of the
              block. Units are in seconds. The update time must be at least as large as the largest
                Time specified at the Detections input
              port.
If this port is not enabled, the simulation clock managed by Simulink determines the update time.
Dependencies
To enable this port, in the Port Setting tab, set
                  Prediction time source to Input
                  port.
Cost matrix, specified as a real-valued Nt-by-Nd matrix, where Nt is the number of existing tracks and Nd is the number of current detections.
The rows of the cost matrix correspond to the existing tracks. The columns correspond to the detections. Tracks are ordered as they appear in the list of tracks at the All Tracks output port on the previous invocation of the block.
In the first update to the tracker, or if the track has no previous tracks, assign
              the cost matrix a size of [0, Nd]. The cost
              must be calculated so that lower costs indicate a higher likelihood that the tracker
              assigns a detection to a track. To prevent certain detections from being assigned to
              certain tracks, use Inf. 
If this port is not enabled, the filter initialized by the Filter initialization function calculates the cost matrix using the distance method.
Dependencies
To enable this port, in the Port Setting tab, select Enable cost matrix input.
Detectable track IDs, specified as a real-valued M-by-1 vector or M-by-2 matrix. Detectable tracks are tracks that the sensors expect to detect. The first column of the matrix contains a list of track IDs that the sensors report as detectable. The second column contains the detection probability for the track. The detection probability is either reported by a sensor or, if not reported, obtained from the Probability of detection used for track score parameter.
Tracks whose identifiers are not included in Detectable TrackIDs are considered undetectable. The track deletion logic does not count the lack of detection as a "missed detection" for track deletion purposes.
If this port is not enabled, the tracker assumes all tracks to be detectable at each invocation of the block.
Dependencies
To enable this port, in the Port Setting tab, select Enable detectable track IDs Input.
Track state parameters, specified as a Simulink bus containing a MATLAB structure. The structure has the form:
| Field | Description | 
|---|---|
| NumParameters | Number of non-default state parameters, specified as a nonnegative integer | 
| Parameters | Array of state parameter structures | 
The block uses the value of the Parameters field for  the
                StateParameters field of the generated tracks. You can use
            these parameters to define the reference frame in which the track is reported or other
            desirable attributes of the generated tracks.
For example, you can use the following structure to define a rectangular reference
            frame whose origin position is at [10 10 0] meters and whose origin
            velocity is [2 -2 0] meters per second with respect to the scenario
            frame. 
| Field Name | Value | 
|---|---|
| Frame | "Rectangular" | 
| Position | [10 10 0] | 
| Velocity | [2 -2 0] | 
Dependencies
To enable this port, in the Tracker Configuration tab, select the Update track state parameters with time parameter.
Output
Confirmed tracks, returned as a Simulink bus containing a MATLAB structure. The structure has the form:
| Field | Description | 
|---|---|
| NumTracks | Number of tracks | 
| Tracks | Array of track structures of a length set by the Maximum number
                        of tracks parameter. Only the first NumTracksof these are actual tracks. | 
The fields of the track structure are shown in Track Structure.
Depending on the track logic, a track is confirmed if:
- History – A track receives at least - Mdetections in the last- Nupdates.- Mand- Nare specified in Confirmation threshold for the- Historylogic.
- Score – The track score is at least as high as the confirmation threshold specified in Confirmation threshold for the - Scorelogic.
Tentative tracks, returned as a Simulink bus containing a MATLAB structure. A track is tentative before it is confirmed.
The fields of the track structure are shown in Track Structure.
Dependencies
To enable this port, in the Port Setting tab, select Enable tentative tracks output.
Combined list of confirmed and tentative tracks, returned as a Simulink bus containing a MATLAB structure.
The fields of the track structure are shown in Track Structure.
Dependencies
To enable this port, in the Port Setting tab, select Enable all tracks output.
Additional information for analyzing track updates, returned as a Simulink bus containing a MATLAB structure.
This table shows the fields of the info structure:
| Field | Description | 
| OOSMDetectionIndices | Indices of out-of-sequence measurements at the current step of the tracker | 
| TrackIDsAtStepBeginning | Track IDs when step began | 
| CostMatrix | Cost of kinematic assignment matrix, in which the (i, j) element denotes the cost of assigning track i to detection j. | 
| Assignments | Assignments from the assignment function, returned as an integer-valued L-by-2 matrix, where L is the number of assignments. The first column of the matrix contains the track IDs and the second column contains the indices of assigned detections. The detection indices are the array-indices of the detections that you used to update the tracker. | 
| UnassignedTracks | IDs of unassigned tracks returned from the tracker | 
| UnassignedDetections | IDs of unassigned detections returned from the tracker | 
| InitiatedTrackIDs | IDs of tracks initiated during the step | 
| DeletedTrackIDs | IDs of tracks deleted during the step | 
| TrackIDsAtStepEnd | Track IDs when the step ended | 
| MaxNumDetectionsPerCluster  | The maximum number of detections in all the clusters generated during the
                      step. The structure has this field only when you set both the
                        Cluster tracks and detections for assignment and
                        Enable memory management parameters as on. | 
| MaxNumTracksPerCluster | The maximum number of tracks in all the clusters generated during the
                      step. The structure has this field only when you set both the
                        Cluster tracks and detections for assignment and
                        Enable memory management parameters as on. | 
| OOSMHandling | Analysis information for out-of-sequence measurements handling,
                        returned as a structure. The structure has this field only when the
                          Out-of-sequence measurements handling parameter of
                        the tracker is specified as  | 
The OOSMHandling structure contains these fields:
| Field | Description | 
|---|---|
| DiscardedDetections | Indices of discarded out-of-sequence detections. An OOSM is discarded if it is not covered by the saved state history specified by the Maximum number of OOSM steps parameter. | 
| CostMatrix | Cost of assignment matrix for the out-of-sequence measurements | 
| Assignments | Assignments between the out-of-sequence detections and the maintained tracks | 
| UnassignedDetections | Indices of unassigned out-of-sequence detections. The tracker creates new tracks for unassigned out-of-sequence detections. | 
Dependencies
To enable this port, in the Port Setting tab, select Enable information output.
Parameters
Tracker Management
Specify the unique tracker identifier as a nonnegative integer. This parameter is
            passed as the SourceIndex in the tracker outputs, and distinguishes
            tracks that come from different trackers in a multiple-tracker system. You must specify
            this property as a positive integer to use the track outputs as inputs to a Track-To-Track Fuser
            block.
Example: 1
Filter initialization function, specified as the name of a valid filter initialization function. The tracker uses the filter initialization function when creating new tracks.
Sensor Fusion and Tracking Toolbox™ supplies many initialization functions that you can use:
| Initialization Function | Function Definition | 
|---|---|
| initcvabf | Initialize constant-velocity alpha-beta filter | 
| initcaabf | Initialize constant-acceleration alpha-beta filter | 
| initcvekf | Initialize constant-velocity extended Kalman filter. | 
| initcackf | Initialize constant-acceleration cubature filter. | 
| initctckf | Initialize constant-turn-rate cubature filter. | 
| initcvckf | Initialize constant-velocity cubature filter. | 
| initcapf | Initialize constant-acceleration particle filter. | 
| initctpf | Initialize constant-turn-rate particle filter. | 
| initcvpf | Initialize constant-velocity particle filter. | 
| initcvkf | Initialize constant-velocity linear Kalman filter. | 
| initcvukf | Initialize constant-velocity unscented Kalman filter. | 
| initcaekf | Initialize constant-acceleration extended Kalman filter. | 
| initcakf | Initialize constant-acceleration linear Kalman filter. | 
| initcaukf  | Initialize constant-acceleration unscented Kalman filter. | 
| initctekf  | Initialize constant-turn-rate extended Kalman filter. | 
| initctukf | Initialize constant-turn-rate unscented Kalman filter. | 
| initcvmscekf | Initialize constant-velocity modified spherical coordinates extended Kalman filter. | 
| initrpekf | Initialize constant-velocity range-parametrized extended Kalman filter. | 
| initapekf | Initialize constant-velocity angle-parametrized extended Kalman filter. | 
| initekfimm | Initialize tracking IMM filter. | 
You can also write your own initialization function. The function must have this syntax:
filter = filterInitializationFcn(detection)
objectDetection. The output of this function must be a filter object:
              trackingKF, trackingEKF, trackingUKF, trackingCKF,
              trackingPF,
              trackingMSCEKF, trackingGSF,
              trackingIMM,
            or trackingABF.To guide you in writing this function, you can examine the details of the supplied functions from within MATLAB. For example:
type initcvekfMaximum number of tracks that the block can maintain, specified as a positive integer.
Maximum number of sensors that the block can process, specified as a positive
            integer. This value should be greater than or equal to the highest
              SensorIndex value input at the Detections
            input port.
Out-of-sequence measurements handling, specified as
              Terminate, Neglect, or
              Retrodiction. Each detection has an associated timestamp,
              td, and the tracker block has it own
            timestamp, tt, which is updated in each
            invocation. The tracker block considers a measurement as an OOSM if
              td <
              tt. 
When you specify the parameter as:
- Terminate— The block stops running when it encounters an out-of-sequence measurement.
- Neglect— The block neglects any out-of-sequence measurements and continues to run.
- Retrodiction— The block uses a retrodiction algorithm to update the tracker by either neglecting the OOSM, updating existing tracks, or creating new tracks using the OOSM. You must specify a filter initialization function that returns a- trackingKF,- trackingEKF, or- trackingIMMobject in the Filter initialization function parameter.
If you specify this parameter as Retrodiction,
            the tracker follows these steps to handle the OOSM:
- If the OOSM timestamp is beyond the oldest correction timestamp (specified by the Maximum number of OOSM steps parameter) maintained in the tracker, the tracker discards the OOSMs. 
- If the OOSM timestamp is within the oldest correction timestamp by the tracker, the tracker first retrodicts all the existing tracks to the time of the OOSMs. Then, the tracker applies the joint probability data association algorithm to try to associate the OOSMs to the retrodicted tracks. - If the tracker successfully associates the OOSM to at least one retrodicted track, then the tracker updates the retrodicted tracks using the OOSMs by applying the retro-correction algorithm to obtain current, corrected tracks. 
- If the tracker cannot associate an OOSM to any retrodicted track, then the tracker creates a new track based on the OOSM and predicts the track to the current time. 
 
For more details on the retrodiction and retro-correction algorithms, see
              Retrodiction and Retro-Correction. To simulate out-of-sequence detections, use objectDetectionDelay.
Note
- When you select - Retrodiction, you cannot use the Cost Matrix input.
Maximum number of out-of-sequence measurement (OOSMs) steps, specified as a positive integer.
Increasing the value of this parameter requires more memory but allows you to call
            the tracker block with OOSMs that have a larger lag relative to the last timestamp when
            the block was updated. Also, as the lag increases, the impact of the OOSM on the current
            state of the track diminishes. The recommended value of this parameter is
              3. 
Dependencies
To enable this parameter, set the Out-of-sequence measurements
                handling parameter to Retrodiction.
Specify the parameters of the track state reference frame as a
      structure or a structure array. The block passes the value of this parameter to the
        StateParameters field of the generated tracks. You can use these
      parameters to define the reference frame in which the track is reported or other desirable
      attributes of the generated tracks. 
For example, you can use the following structure to define a
                                    rectangular reference frame whose origin position is at
                                                [10 10 0] meters and whose origin
                                    velocity is [2 -2 0] meters per second with
                                    respect to the scenario frame. 
| Field Name | Value | 
|---|---|
| Frame | "Rectangular" | 
| Position | [10 10 0] | 
| Velocity | [2 -2 0] | 
You can update the track state parameters through the State Parameters input port by selecting the Update track state parameters with time parameter.
Data Types: struct
Select this parameter to enable the input port for track state parameters through the State Parameters input port.
Select this parameter to enable memory management using the Maximum number
              of detections per sensor parameter to specify the maximum number of
            detections that each sensor can pass to the tracker during one call of the tracker.
            Additionally, if the Cluster tracks and detections for assignment
            parameter is specified as on, you can use three more
            parameters to specify bounds for certain variable-sized arrays in the tracker as well as
            determine how the tracker handles cluster size violations:
- Maximum number of detections per cluster 
- Maximum number of tracks per cluster 
- Handle run-time violation of cluster size 
Specifying bounds for variable-sized arrays allows you to manage the memory footprint of the tracker in the generated C/C++ code.
Assignment algorithm, specified as 'MatchPairs',
              'Munkres', 'Jonker-Volgenant',
              'Auction', or 'Custom'. Munkres is the only
            assignment algorithm that guarantees an optimal solution, but it is also the slowest,
            especially for large numbers of detections and tracks. The other algorithms do not
            guarantee an optimal solution but can be faster for problems with 20 or more tracks and
            detections. Use'Custom' to define your own assignment function and
            specify its name in the CustomAssignmentFcn property.
Custom assignment function name, specified as a character string. An assignment function must have this syntax:
[assignment,unTrs,unDets] = f(cost,costNonAssignment)
assignmunkres.Example: 'mycustomfcn'
Dependencies
To enable this property, set the Assignment algorithm name
              name to 'Custom'.
Threshold for assigning detections to tracks (or gating threshold), specified as a
            positive scalar or a 1-by-2 vector of
              [C1,C2],
            where C1 ≤
              C2. If specified as a scalar, the specified
            value, val, will be expanded to [val,
              Inf].
Initially, the tracker executes a coarse estimation for the normalized distance between all the tracks and detections. The tracker only calculates the accurate normalized distance for the combinations whose coarse normalized distance is less than C2. Also, the tracker can only assign a detection to a track if their accurate normalized distance is less than C1. See Algorithms for an explanation of the normalized distance.
- Increase the value of C2 if there are combinations of track and detection that should be calculated for assignment but are not. Decrease it if cost calculation takes too much time. 
- Increase the value of C1 if there are detections that should be assigned to tracks but are not. Decrease it if there are detections that are assigned to tracks they should not be assigned to (too far away). 
Note
If the value of C2 is finite, the state transition function and measurement function, specified in the tracking filter used in the tracker, must be able to take an M-by-N matrix of states as input and output N predicted states and N measurements, respectively. M is the size of the state. N, the number of states, is an arbitrary nonnegative integer.
Specify cluster tracks and detections for assignment as:
- off— The tracker solves the global nearest neighbor assignment problem per sensor using a cost matrix. The number of columns in the cost matrix is equal to the number of detections by the sensor, and the number of rows is equal to the number of tracks maintained by the tracker. Forbidden assignments (assignments with a cost greater than the Threshold for assigning detections to tracks parameter) have an infinite cost of assignment.
- on— The tracker creates a cluster after separating out the forbidden assignments (assignments with a cost greater than the Threshold for assigning detections to tracks parameter) and uses the forbidden assignments to form new clusters based one the Threshold for assigning detections to tracks parameter. A cluster is a collection of detections (per sensor) and tracks considered to be assigned to each other. In this case, the tracker solves the global nearest neighbor assignment problem per cluster.- When you both specify this property as - onand select Enable memory management in the Tracker Management tab, you can use these three parameters to specify bounds for certain variable-sized arrays in the tracker as well as determine how the tracker handles cluster size violations:- Maximum number of detections per cluster 
- Maximum number of tracks per cluster 
- Handle run-time violation of cluster size 
 - Specifying bounds for variable-sized arrays enables you to manage the memory footprint of the tracker, especially in the generated C/C++ code. 
- Interpreted execution— Simulate the model using the MATLAB interpreter. This option shortens startup time. In- Interpreted executionmode, you can debug the source code of the block.
- Code generation— Simulate the model using generated C code. The first time you run a simulation, Simulink generates C code for the block. The C code is reused for subsequent simulations as long as the model does not change. This option requires additional startup time.
Track Logic
Confirmation and deletion logic type, selected as History
            or Score.
- History– Track confirmation and deletion is based on the number of times the track has been assigned to a detection in the latest tracker updates.
- Score– Track confirmation and deletion is based on a log-likelihood track score. A high score means that the track is more likely to be valid. A low score means that the track is more likely to be a false alarm.
Track confirmation threshold for history logic, specified as a real-valued 1-by-2
            vector of positive integers [M N]. A track is confirmed if it
            receives at least M detections in the last N
            updates.
Dependencies
To enable this parameter, set Type of track confirmation and deletion
                logic to History.
Track deletion threshold for history logic, specified as a real-valued 1-by-2 vector
            of positive integers [P Q]. If a confirmed track is not assigned to
            any detection P times in the last Q tracker
            updates, then the track is deleted.
Dependencies
To enable this parameter, set Type of track confirmation and deletion
                logic to History.
Track confirmation threshold for score logic, specified as a real-valued positive scalar. A track is confirmed if its score is at least as high as the confirmation threshold.
Dependencies
To enable this parameter, set Type of track confirmation and deletion
                logic to Score.
Track deletion threshold for score logic, specified as a negative scalar. A track is deleted if its score decreases by at least the threshold from the maximum track score.
Dependencies
To enable this parameter, set Type of track confirmation and deletion
                logic to Score.
Probability of detection used for track score, specified as a positive scalar in (0,1).
Example: 0.5
Dependencies
To enable this parameter, set Type of track confirmation and deletion
                logic to Score.
The probability of false alarm used for track score, specified as a scalar in (0,1).
Example: 1e-5
Dependencies
To enable this parameter, set Type of track confirmation and deletion
                logic to Score.
The volume of a sensor detection bin, specified as a positive scalar. For example, if a radar produces a 4-D measurement, which includes azimuth, elevation, range, and range rate, the 4-D volume is defined by the radar angular beam width, the range bin width, and the range-rate bin width. Volume is used in calculating the track score when initializing and updating a track.
Example: 1.5
Dependencies
To enable this parameter, set Type of track confirmation and deletion
                logic to Score.
The rate of new tracks per unit volume, specified as a positive scalar. The rate of new tracks is used in calculating the track score during track initialization.
Example: 2.5
Dependencies
To enable this parameter, set Type of track confirmation and deletion
                logic to Score.
Port Setting
Source for prediction time, specified as Input port or
              Auto. Select Input port to input
            an update time by using the Prediction Time input port. Otherwise,
            the simulation clock managed by Simulink determines the update time.
Select this check box to enable the input of a cost matrix by using the Cost Matrix input port.
Select this check box to enable the Detectable track IDs input port.
Select this check box to enable the output of tentative tracks through the Tentative Tracks output port.
Select this check box to enable the output of all the tracks through the All Tracks output port.
Select this check box to enable the output port for analysis information through the Info output port.
Source of the output track bus name, specified as:
- Auto— The block automatically creates an output track bus name.
- Property— Specify the output track bus name by using the Specify an output bus name parameter.
Source of the output info bus name, specified as one of these options:
- Auto— The block automatically creates an output info bus name.
- Property— Specify the output info bus name by using the Specify an output bus name parameter.
Memory Management
Specify the maximum number of detections per sensor as a positive integer. This parameter determines the maximum number of detections that each sensor can pass to the tracker in each call of the tracker.
Set this parameter to a finite value if you want the tracker to establish efficient
            bounds on local variables for C/C++ code generation. Set this property to
              Inf if you do not want to bound the maximum number of detections
            per sensor.
Dependencies
To enable this parameter, select Enable Memory Management in the Tracker Management tab.
Specify the maximum number of detections per cluster during the run-time of the tracker as a positive integer.
Setting this parameter to a finite value allows the tracker to bound cluster sizes
            and reduces the memory footprint of the tracker in generated C/C++ code. Set this
            property to Inf if you do not want to bound the maximum number of
            detections per cluster.
If during run-time, the number of detections in a cluster exceeds this parameter, the tracker reacts based on the Handle run-time violation of cluster size parameter.
Dependencies
To enable this parameter, specify the Cluster tracks and detections for
                assignment as on and select Enable
                Memory Management in the Tracker Management
              tab.
Specify the maximum number of tracks per cluster during the run-time of the tracker as a positive integer.
Setting this parameter to a finite value allows the tracker to bound cluster sizes
            and reduces the memory footprint of the tracker in generated C/C++ code. Set this
            property to Inf if you do not want to bound the maximum number of
            detections per cluster.
If, during run-time, the number of tracks in a cluster exceeds this parameter, the tracker reacts based on the Handle run-time violation of cluster size parameter.
Dependencies
To enable this parameter, specify the Cluster tracks and detections for
                assignment as on and select Enable
                Memory Management in the Tracker Management
              tab.
Specify the handling of run-time violation of cluster size as one of these options:
- Teminate— The tracker reports an error if, during run-time, any cluster violates the cluster bounds specified in the Maximum number of detections per cluster and Maximum number of tracks per cluster parameters.
- Split and warn— The tracker splits the size-violating cluster into smaller clusters by using a suboptimal approach. The tracker also reports a warning to indicate the violation.
- Split— The tracker splits the size-violating cluster into smaller clusters by using a suboptimal approach. The tracker does not report a warning.
In the suboptimal approach, the tracker separates out detections or tacks that have the smallest likelihoods of association to other tracks or detections until the cluster bounds are satisfied. These separated-out detections or tracks can form one or many new clusters depends on their association likelihoods with each other and the Threshold for assigning detections to tracks parameter.
Dependencies
To enable this parameter, specify the Cluster tracks and detections for
                assignment as on and select Enable
                Memory Management in the Tracker Management
              tab.
Algorithms
When a GNN tracker processes detections, track creation and management follow these steps:
- The tracker divides detections by originating sensor. 
- For each sensor: - The tracker calculates the distances from detections to existing tracks and forms a cost matrix. 
- Based on the costs, the tracker performs global nearest neighbor assignment using the algorithm specified by the Assignment algorithm name parameter. 
- The assignment algorithm divides the detections and tracks into three groups: - Assigned one-to-one detection and track pairs 
- Unassigned detections 
- Unassigned tracks 
 
 
- Unassigned detections initialize new tracks. Using the unassigned detection, the tracker initializes a new track filter specified by the Filter initialization function parameter. The track logic for the new track is initialized as well. - The tracker checks if any of the unassigned detections from other sensors can be assigned to the new track. If so, the tracker updates the new track with the assigned detections from the other sensors. As a result, these detections no longer initialize new tracks. 
- The pairs of assigned tracks and detections are used to update each track. The track filter is updated using the - correctmethod provided by the specified tracking filter. Also, the track logic is updated with a "hit". The tracker checks if the track meets the criteria for confirmation. If so, the tracker confirms the track and sets the- IsCoastedfield to- false.
- Unassigned tracks are updated with a "miss" and their - IsCoastedfield is set to- true. The tracker checks if the track meets the criteria for deletion. If so, the tracker removes the track from the maintained track list.
- All tracks are predicted to the latest time value (either the time provided by the Prediction Time input port, or the time determined by Simulink). 
The fields of the track structure are:
| Field | Definition | 
|---|---|
| TrackID | Unique track identifier used to distinguish multiple tracks. | 
| BranchID | Unique track branch identifier used to distinguish multiple track branches. | 
| SourceIndex | Unique source index used to distinguish tracking sources in a multiple tracker environment. | 
| UpdateTime | Time at which the track is updated. Units are in seconds. | 
| Age | Number of times the track survived. | 
| State | Value of the state vector at the update time. | 
| StateCovariance | Uncertainty covariance matrix. | 
| ObjectClassID | Integer value representing the object classification. The value 0represents an unknown classification. Nonzero
                    classifications apply only to confirmed tracks. | 
| TrackLogic | Confirmation and deletion logic type, returned as 'History'or'Score'. | 
| TrackLogicState | The current state of the track logic type. Based on the logic type  
 | 
| IsConfirmed | Confirmation status. This field is trueif the track is confirmed to be a real target. | 
| IsCoasted | Coasting status. This field is trueif the track is updated without a new detection. | 
| IsSelfReported | Indicate if the track is reported by the tracker. This field is used in a track fusion environment. It is returned as  | 
| ObjectAttributes | Additional information about the track. | 
Extended Capabilities
Usage notes and limitations:
- The block supports strict single-precision code generation with these restrictions: - You must specify the assignment algorithm as - 'Jonker-Volgenant'.
- You must specify the filter initialization function to return a - trackingEKF,- trackingUKF,- trackingCKF, or- trackingIMMobject configured with single-precision.
 - For details, see Generate Code with Strict Single-Precision and Non-Dynamic Memory Allocation. 
- The tracker supports non-dynamic memory allocation code generation with these restrictions: - You must specify the assignment algorithm as - 'Jonker-Volgenant'or- 'MatchPairs'.
- You must specify the filter initialization function to return a - trackingEKF,- trackingUKF,- trackingCKF, or- trackingIMMobject.
 - For details, see Generate Code with Strict Single-Precision and Non-Dynamic Memory Allocation. - After enabling non-dynamic memory allocation code generation, consider using these parameters to set bounds on the local variables in the tracker: - Enable memory management 
- Cluster tracks and detections for assignment 
- Maximum number of detections per sensor 
- Maximum number of detections per cluster 
- Maximum number of tracks per cluster 
- Handle run-time violation of cluster size 
 
- In code generation, if the detection inputs are specified in - doubleprecision, then the- NumTracksfield of the track outputs is returned as a- doublevariable. If the detection inputs are specified in- singleprecision, then the- NumTracksfield of the track outputs is returned as a- uint32variable.
Version History
Introduced in R2019bAs of R2023a, the Simulink buses created by this block no longer show in MATLAB workspace.
See Also
Blocks
Functions
- assignauction|- assignjv|- assignkbest|- assignkbestsd|- assignmunkres|- assignsd|- getTrackPositions|- getTrackVelocities|- fusecovint|- fusecovunion|- fusexcov
Objects
- objectDetection|- trackingKF|- trackingEKF|- trackingUKF|- trackingABF|- trackingCKF|- trackingGSF|- trackingIMM|- trackingMSCEKF|- trackingPF|- trackHistoryLogic|- trackScoreLogic|- objectTrack|- trackerJPDA|- trackerTOMHT|- trackerGNN
Blocks
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
웹사이트 선택
번역된 콘텐츠를 보고 지역별 이벤트와 혜택을 살펴보려면 웹사이트를 선택하십시오. 현재 계신 지역에 따라 다음 웹사이트를 권장합니다:
또한 다음 목록에서 웹사이트를 선택하실 수도 있습니다.
사이트 성능 최적화 방법
최고의 사이트 성능을 위해 중국 사이트(중국어 또는 영어)를 선택하십시오. 현재 계신 지역에서는 다른 국가의 MathWorks 사이트 방문이 최적화되지 않았습니다.
미주
- América Latina (Español)
- Canada (English)
- United States (English)
유럽
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)

