Skip to content

LiDAR マーカー ローカライザー#

LiDARMarkerLocalizer は、反射器を検出して位置を推定するノードです。

入出力#

lidar_marker_localizer ノード#

入力#

  • /hesai406/points (PointCloud)
    • ヘサイ406のLiDARポイントクラウド
  • /current_pose (Odometry)
    • 自車位置
  • /static_map (StaticMap)
    • 静的地図(反転させた座標系)

出力#

  • /lidar_marker_localizer/output (Odometry)
    • 検出された反射器に基づく、自車位置の推定値
  • /lidar_marker_localizer/debug (MarkerArray)
    • デバッグ用マーカー
名前 説明
~/input/lanelet2_map autoware_map_msgs::msg::HADMapBin lanelet2データ
~/input/pointcloud sensor_msgs::msg::PointCloud2 点群
~/input/ekf_pose geometry_msgs::msg::PoseWithCovarianceStamped EKFによる自車位置

出力#

はじめに

このドキュメントでは、Autoware の自動運転ソフトウェアの詳細について説明します。Autoware は、オープンソースのソフトウェアスタックであり、車が周囲環境を認識し、計画を立て、制御を行うために必要なすべてのコンポーネントが含まれています。

コンポーネント

Autoware は、以下の主要コンポーネントで構成されています。

  • Perception (認識): センサーデータから周囲環境を認識します。
  • Planning (計画): 自車の経路と操縦操作を計画します。
  • Control (制御): 計画された操縦操作を車両に送信します。
  • Localization (局所化): 自車位置と姿勢を特定します。

機能

Autoware は、以下の機能を提供します。

  • 物体検出: 車両、歩行者、自転車などの周囲の物体を検出します。
  • 障害物検出: レーンマーカー、ガードレールなどの障害物を検出します。
  • 経路計画: 目的地までの安全で効率的な経路を計画します。
  • 操縦制御: 車両の速度、操舵、ブレーキを制御します。
  • 自車位置推定: GPS、IMU、オドメトリーを使用して自車位置を推定します。

アーキテクチャ

Autoware は、モジュール式アーキテクチャに基づいています。これにより、開発者は特定のコンポーネントや機能を交換したり拡張したりできます。各コンポーネントは、他のコンポーネントとデータと情報をやり取りします。

パフォーマンス

Autoware は、以下のパフォーマンス指標を満たすように設計されています。

  • 検出範囲: 200m 以上の物体検出
  • 経路計画時間: 100ms 以内
  • 操縦制御精度: ±0.5m の横方向逸脱量、±0.2m/s の速度逸脱量、±0.2m/s² の加速度逸脱量
  • 自車位置精度: 1m 以内の絶対位置精度、0.1度以内の姿勢精度

使用例

Autoware は、以下を含むさまざまな自動運転アプリケーションに使用できます。

  • 自動運転車
  • ロボタクシー
  • 貨物配送車両

貢献

Autoware はオープンソースプロジェクトであり、コミュニティからの貢献を歓迎しています。貢献方法の詳細については、Autoware の Web サイトを参照してください。

免責事項

このドキュメントに記載されている情報は、正確で最新であることを目指していますが、Autoware Foundation はその正確性または完全性について保証しません。Autoware の使用は、ユーザー自身の責任において行われるものとします。

名前 種類 説明
~/output/pose_with_covariance geometry_msgs::msg::PoseWithCovarianceStamped 推定姿勢
~/debug/pose_with_covariance geometry_msgs::msg::PoseWithCovarianceStamped [デバッグトピック] 推定姿勢
~/debug/marker_detected geometry_msgs::msg::PoseArray [デバッグトピック] 検出されたマーカートピック
~/debug/marker_mapped visualization_msgs::msg::MarkerArray [デバッグトピック] Rvizで薄板として可視化するための読み込まれたランドマーク
~/debug/marker_pointcloud sensor_msgs::msg::PointCloud2 検出されたマーカーのPointCloud
/diagnostics diagnostic_msgs::msg::DiagnosticArray 診断結果

パラメータ#

Name Type Description Default Range
marker_name string The name of the markers listed in the HD map. reflector N/A
resolution float Grid size for marker detection algorithm. [m] 0.05 ≥0.0
intensity_pattern array A sequence of high/low intensity to perform pattern matching. 1: high intensity (positive match), 0: not consider, -1: low intensity (negative match) [-1, -1, 0, 1, 1, 1, 1, 1, 0, -1, -1] N/A
match_intensity_difference_threshold float Threshold for determining high/low. 20 ≥0
positive_match_num_threshold float Threshold for the number of required matches with the pattern. 3 ≥0
negative_match_num_threshold float Threshold for the number of required matches with the pattern. 3 ≥0
vote_threshold_for_detect_marker float Threshold for the number of rings matching the pattern needed to detect it as a marker. 20 ≥0
marker_height_from_ground float Height from the ground to the center of the marker. [m] 1.075 N/A
self_pose_timeout_sec float Timeout for self pose. [sec] 1.0 ≥0.0
self_pose_distance_tolerance_m float Tolerance for the distance between two points when performing linear interpolation. [m] 1.0 ≥0.0
limit_distance_from_self_pose_to_nearest_marker float Distance limit for the purpose of determining whether the node should detect a marker. [m] 2.0 ≥0.0
limit_distance_from_self_pose_to_marker float Distance limit for avoiding miss detection. [m] 2.0 ≥0.0
base_covariance array Output covariance in the base_link coordinate. [0.04, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.04, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.01, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 7.569e-05, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 7.569e-05, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.00030625] N/A
marker_width float Width of a marker. This param is used for visualizing the detected marker pointcloud[m] 0.8 ≥0.0
enable_save_log boolean False N/A
save_file_directory_path string $(env HOME)/detected_reflector_intensity N/A
save_file_name string detected_reflector_intensity N/A
save_frame_id string velodyne_top N/A

起動方法#

Autowareを起動する際は、pose_sourcelidar-markerを設定します。

ros2 launch autoware_launch ... \
    pose_source:=lidar-marker \
    ...

設計#

フローチャート#

uml diagram

検出アルゴリズム#

detection_algorithm

  1. LiDAR 点群を resolution サイズの間隔で base_link 座標系の x 軸に沿ってリング状に分割する。
  2. intensity_pattern に一致する強度の部分を検索する。
  3. 各リングに対して 1 と 2 の手順を実行し、一致するインデックスを蓄積し、カウントが vote_threshold_for_detect_marker を超える部分をマーカーとして検出する。

サンプルデータセット#

このデータセットは、国土交通省 土木研究所 大規模トンネル実験施設で取得されました。 反射材は 大成建設 によって設置されました。

協力者#