Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]
Messages
Services
Plugins
Recent questions tagged autoware_ekf_localizer at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 1.1.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-06-12 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takamasa Horibe
- Yamato Ando
- Takeshi Ishita
- Masahiro Sakamoto
- Kento Yabuuchi
- NGUYEN Viet Anh
- Taiki Yamada
- Shintaro Sakoda
- Ryu Yamamoto
Authors
- Takamasa Horibe
Overview
The Extend Kalman Filter Localizer estimates robust and less noisy robot pose and twist by integrating the 2D vehicle dynamics model with input ego-pose and ego-twist messages. The algorithm is designed especially for fast-moving robots such as autonomous driving systems.
Flowchart
The overall flowchart of the autoware_ekf_localizer is described below.
Features
This package includes the following features:
- Time delay compensation for input messages, which enables proper integration of input information with varying time delays. This is important especially for high-speed moving robots, such as autonomous driving vehicles. (see the following figure).
- Automatic estimation of yaw bias prevents modeling errors caused by sensor mounting angle errors, which can improve estimation accuracy.
- Mahalanobis distance gate enables probabilistic outlier detection to determine which inputs should be used or ignored.
- Smooth update, the Kalman Filter measurement update is typically performed when a measurement is obtained, but it can cause large changes in the estimated value, especially for low-frequency measurements. Since the algorithm can consider the measurement time, the measurement data can be divided into multiple pieces and integrated smoothly while maintaining consistency (see the following figure).
- Calculation of vertical correction amount from pitch mitigates localization instability on slopes. For example, when going uphill, it behaves as if it is buried in the ground (see the left side of the “Calculate delta from pitch” figure) because EKF only considers 3DoF(x,y,yaw). Therefore, EKF corrects the z-coordinate according to the formula (see the right side of the “Calculate delta from pitch” figure).
Node
Subscribed Topics
Name | Type | Description |
---|---|---|
measured_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Input pose source with the measurement covariance matrix. |
measured_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
Input twist source with the measurement covariance matrix. |
initialpose |
geometry_msgs::msg::PoseWithCovarianceStamped |
Initial pose for EKF. The estimated pose is initialized with zeros at the start. It is initialized with this message whenever published. |
Published Topics
Name | Type | Description |
---|---|---|
ekf_odom |
nav_msgs::msg::Odometry |
Estimated odometry. |
ekf_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose. |
ekf_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance. |
ekf_biased_pose |
geometry_msgs::msg::PoseStamped |
Estimated pose including the yaw bias |
ekf_biased_pose_with_covariance |
geometry_msgs::msg::PoseWithCovarianceStamped |
Estimated pose with covariance including the yaw bias |
ekf_twist |
geometry_msgs::msg::TwistStamped |
Estimated twist. |
ekf_twist_with_covariance |
geometry_msgs::msg::TwistWithCovarianceStamped |
The estimated twist with covariance. |
diagnostics |
diagnostics_msgs::msg::DiagnosticArray |
The diagnostic information. |
debug/processing_time_ms |
autoware_internal_debug_msgs::msg::Float64Stamped |
The processing time [ms]. |
Published TF
- base_link
TF from
map
coordinate to estimated pose.
Functions
Predict
The current robot state is predicted from previously estimated data using a given prediction model. This calculation is called at a constant interval (predict_frequency [Hz]
). The prediction equation is described at the end of this page.
Measurement Update
Before the update, the Mahalanobis distance is calculated between the measured input and the predicted state, the measurement update is not performed for inputs where the Mahalanobis distance exceeds the given threshold.
The predicted state is updated with the latest measured inputs, measured_pose, and measured_twist. The updates are performed with the same frequency as prediction, usually at a high frequency, in order to enable smooth state estimation.
Parameter description
The parameters are set in launch/ekf_localizer.launch
.
For Node
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/node.sub_schema.json”) }}
For pose measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/pose_measurement.sub_schema.json”) }}
For twist measurement
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/twist_measurement.sub_schema.json”) }}
For process noise
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/process_noise.sub_schema.json”) }}
note: process noise for positions x & y are calculated automatically from nonlinear dynamics.
Simple 1D Filter Parameters
{{ json_to_markdown(“localization/autoware_ekf_localizer/schema/sub/simple_1d_filter_parameters.sub_schema.json”) }}
File truncated at 100 lines see the full file
Changelog for package autoware_ekf_localizer
1.1.0 (2025-05-01)
1.0.0 (2025-03-31)
0.3.0 (2025-03-21)
- chore: fix versions in package.xml
- chore(ekf_localizer): increase z_filter_proc_dev for large gradient road (#211) increase z_filter_proc_dev Co-authored-by: SakodaShintaro <<shintaro.sakoda@tier4.jp>>
- feat(autoware_ekf_localizer)!: porting from universe to core 2nd (#180)
- Contributors: Kento Yabuuchi, Motz, mitsudome-r
Wiki Tutorials
Package Dependencies
System Dependencies
Dependant Packages
Name | Deps |
---|---|
autoware_core_localization |
Launch files
- launch/ekf_localizer.launch.xml
-
- param_file [default: $(find-pkg-share autoware_ekf_localizer)/config/ekf_localizer.param.yaml]
- input_initial_pose_name [default: initialpose3d]
- input_trigger_node_service_name [default: trigger_node]
- input_pose_with_cov_name [default: in_pose_with_covariance]
- input_twist_with_cov_name [default: in_twist_with_covariance]
- output_odom_name [default: ekf_odom]
- output_pose_name [default: ekf_pose]
- output_pose_with_covariance_name [default: ekf_pose_with_covariance]
- output_biased_pose_name [default: ekf_biased_pose]
- output_biased_pose_with_covariance_name [default: ekf_biased_pose_with_covariance]
- output_twist_name [default: ekf_twist]
- output_twist_with_covariance_name [default: ekf_twist_with_covariance]
- output_processing_time_ms [default: debug/processing_time_ms]