본문 바로가기

자율주행 관련 번역 방

map odometry

Odometry란 단어 그대로 주행기록계라는 의미로서 엔코더를 통한 회전수와 IMU(관성 측정 장비)로 기울기 등을 측정함으로서 움직이고 있는 사물의 위치를 측정하는 방법을 의미합니다.

 Odometry는 ROS에서 odom frame으로 구현되며 위에서 설명한 엔코더 혹은 IMU를 사용하여 위치를 추정할 수 있습니다. 부득이하게 Visual SLAM을 사용하여 위의 센서를 사용하지 못할 경우 카메라를 통해 관측한 값을 토대로 Odom을 추정하는 방법을 사용할 수도 있습니다.

 Odom frame을 설계함에 있에 일반적으로 위와 같은 구조로 Frame을 설계합니다. map 은 여러 개의 odom을 가질 수 있으나 odom은 단 하나의 map을 가질 수 있습니다. 즉 1 개의 map 위에 다수의 로봇이 존재할 경우 odom은 로봇의 개수 만큼 존재한다고 할 수 있겠습니다.

 

earth

 earth frame은 여러 대의 로봇들이 서로 다른 map 위에서 존재할 수 있도록 해줍니다. 로봇들이 한 빌딩의 각 층에 위치하여 서로 다른 map을 가지고 있을 경우 earth frame은 모든 map frame을 통해 각 층의 정보를 가질 수 있게 해줍니다.

 

map

 map frame은 world fixed frame으로서 earth frame에 고정된 프레임이라 할 수 있습니다.  odom frame이 움직일 때 drift가 발생하여 로봇의 위치가 미세하게 바뀌는 경우가 발생합니다. map frame은 연속적이지 않기 때문에 시뮬레이션을 돌릴 때 마치 로봇이 갑자기 순간이동 한 듯 움직이는 경우를 볼 수 있습니다. 이러한 단점이 있지만 map frame은 장기간 global reference에는 매우 유용한 frame입니다.

 

odom

 odom frame은 world fixed frame으로서 또한 earth frame에 고정된 프레임이라 할 수 있습니다. 로봇의 위치가 drift로 인해 odom frame이 장기간 global reference에서는 사용에 있어 의미가 없을 수 있으나 odom frame은 로봇의 위치를 연속적으로 나타낼 수 있어 로봇이 갑자기 순간이동을 하는 듯한 모습을 보이지 않고 부드럽게 움직일 수 있도록 해줍니다.

 즉 odom frame은 단기간 local reference에서 로봇의 위치를 정확하게 파악하는데는 매우 유용한 frame이라 할 수 있겠습니다.

 

base_link

 base_link frame은 로봇 자체의 위치를 나타내는 frame이라 할 수 있습니다. base_link frame의 위치를 odom 혹은 map frame을 사용하여 위치를 추정하는 방법으로 로봇의 위치를 파악할 수 있습니다.


출처: https://elecs.tistory.com/296

 

 

 

Publishing Odometry Information Over ROS

이 학습서는 탐색 스택에 대한 측량 정보를 공개하는 예제를 제공합니다. 여기에는 ROS를 통한 nav_msgs / Odometry 메시지 게시와 tf를 통한 "odom"좌표 프레임에서 "base_link"좌표 프레임으로의 변환이 모두 포함됩니다.

http://wiki.ros.org/navigation/Tutorials/RobotSetup/Odom

1. Publishing Odometry Information Over ROS


navigation  스택은 tf를 사용하여 세계에서 로봇의 location 를 결정하고 센서 데이터를 정적 맵과 관련시킵니다. 그러나 tf는 로봇의 속도에 대한 정보를 제공하지 않습니다. 이로 인해 navigation  스택을 사용하려면 모든 odometry 소스가 속도 정보가 포함 된 ROS를 통해 변환 및 nav_msgs / Odometry 메시지를 모두 게시해야합니다. 이 학습서는 nav_msgs / Odometry 메시지를 설명하고 메시지를 공개하고 ROS 및 tf를 통해 각각 변환하는 예제 코드를 제공합니다.

 

차례

  1. Publishing Odometry Information Over ROS
  2. The nav_msgs/Odometry Message
  3. Using tf to Publish an Odometry transform
  4. Writing the Code

2. The nav_msgs/Odometry Message


nav_msgs / Odometry 메시지는  free space에서 로봇의 위치 및 속도 추정값을 저장합니다.

# This represents an estimate of a position and velocity in free space.  
# The pose in this message should be specified in the coordinate frame given by header.frame_id.
# The twist in this message should be specified in the coordinate frame given by the child_frame_id
Header header
string child_frame_id
geometry_msgs/PoseWithCovariance pose
geometry_msgs/TwistWithCovariance twist

이 메시지의 포즈는 해당 포즈 추정의 확실성에 대한 선택적 공분산과 함께 odometric 프레임에서 로봇의 예상 위치에 해당합니다. 이 메시지의 비틀림은 하위 프레임에서 로봇의 속도, 일반적으로 모바일베이스의 좌표 프레임과 해당 속도 추정의 확실성에 대한 선택적 공분산에 해당합니다.

3. Using tf to Publish an Odometry transform

Transform Configuration 학습서에서 설명한대로 "tf"소프트웨어 라이브러리는 transform  트리에서 로봇과 관련된 좌표 프레임 간의 관계를 관리합니다. 따라서 모든 odometry 소스는 관리하는 좌표 프레임에 대한 정보를 게시해야합니다. 아래 코드는 tf에 대한 기본 지식을 전제로하며, Transform Configuration 학습서를 읽으면 충분합니다.

4. Writing the Code

이 섹션에서는 ROS를 통해 nav_msgs / Odometry 메시지를 게시하기위한 예제 코드와 원으로 만 구동되는 가짜 로봇에 tf를 사용한 변환을 작성합니다. 먼저 코드 전체를 아래에 단계별로 설명합니다.
패키지의 manifest.xml에 의존성을 추가하십시오.

<depend package="tf"/>

<depend package="nav_msgs"/>

#include <ros/ros.h>
#include <tf/transform_broadcaster.h>
#include <nav_msgs/Odometry.h>

int main(int argc, char** argv){
  ros::init(argc, argv, "odometry_publisher");

  ros::NodeHandle n;
  ros::Publisher odom_pub = n.advertise("odom", 50);
  tf::TransformBroadcaster odom_broadcaster;

  double x = 0.0;
  double y = 0.0;
  double th = 0.0;

  double vx = 0.1;
  double vy = -0.1;
  double vth = 0.1;

  ros::Time current_time, last_time;
  current_time = ros::Time::now();
  last_time = ros::Time::now();

  ros::Rate r(1.0);
  while(n.ok()){

    ros::spinOnce();               // check for incoming messages
    current_time = ros::Time::now();

    //compute odometry in a typical way given the velocities of the robot
    double dt = (current_time - last_time).toSec();
    double delta_x = (vx * cos(th) - vy * sin(th)) * dt;
    double delta_y = (vx * sin(th) + vy * cos(th)) * dt;
    double delta_th = vth * dt;

    x += delta_x;
    y += delta_y;
    th += delta_th;

    //since all odometry is 6DOF we'll need a quaternion created from yaw
    geometry_msgs::Quaternion odom_quat = tf::createQuaternionMsgFromYaw(th);

    //first, we'll publish the transform over tf
    geometry_msgs::TransformStamped odom_trans;
    odom_trans.header.stamp = current_time;
    odom_trans.header.frame_id = "odom";
    odom_trans.child_frame_id = "base_link";

    odom_trans.transform.translation.x = x;
    odom_trans.transform.translation.y = y;
    odom_trans.transform.translation.z = 0.0;
    odom_trans.transform.rotation = odom_quat;

    //send the transform
    odom_broadcaster.sendTransform(odom_trans);

    //next, we'll publish the odometry message over ROS
    nav_msgs::Odometry odom;
    odom.header.stamp = current_time;
    odom.header.frame_id = "odom";

    //set the position
    odom.pose.pose.position.x = x;
    odom.pose.pose.position.y = y;
    odom.pose.pose.position.z = 0.0;
    odom.pose.pose.orientation = odom_quat;

    //set the velocity
    odom.child_frame_id = "base_link";
    odom.twist.twist.linear.x = vx;
    odom.twist.twist.linear.y = vy;
    odom.twist.twist.angular.z = vth;

    //publish the message
    odom_pub.publish(odom);

    last_time = current_time;
    r.sleep();
  }
}

 

 

 

 

'자율주행 관련 번역 방' 카테고리의 다른 글

Navigation Stack  (0) 2020.02.28
Transform Configuration  (0) 2020.02.25
칼만 필터 [일부 번역]  (0) 2020.02.09
인공지능과 자율주행 [번역]  (0) 2020.02.09
오토파일럿 홈페이지 [번역]  (0) 2020.02.07