Gazebo | Ignition | Community
Ask Your Question
1

What is the meaning of LOCAL and GLOBAL CoordinateTypes in SphericalCoordinates class

asked 2016-11-15 22:06:34 -0600

dejanpan gravatar image

Hi all, I am looking at the SphericalCoordinates class, in particular at the CoordinateType: https://bitbucket.org/osrf/gazebo/src....

Now what is the meaning of LOCAL and GLOBAL? Would this correspond to base_link and map respectively as defined in http://www.ros.org/reps/rep-0105.html? And would in ROS world be a localization node that would do this transform for me?

Secondly, what do GlobalFromLocal and LocalFromGlobal functions of the same class only convert velocity vectors (and not e.g. positions)?

Thx ahead, D.

edit retag flag offensive close merge delete

1 Answer

Sort by ยป oldest newest most voted
1

answered 2016-11-16 11:59:01 -0600

scpeters gravatar image

updated 2020-10-26 16:27:22 -0600

chapulina gravatar image

The GLOBAL coordinate frame is a Cartesian coordinate frame with its origin at the latitude, longitude, and height specified in the spherical_coordinates tags. It is documented as having XYZ directions mapped to East-North-Up (ENU), but there is currently a bug that causes them to be interpreted as West-South-Up (issue 2022).

The LOCAL frame is similar to the GLOBAL frame but with an additional heading offset (also specified in the sdf tags).

Update: sorry I missed the second question.

The LocalToGlobal and GlobalToLocal functions were written first (by me) but were somewhat limited. The PositionTransform and VelocityTransform functions should be more general. We could possibly deprecate the LocalToGlobal and GlobalToLocal, but we haven't gotten around to it yet.

As to the question about the reason for the order of transformations, I'm not sure of the answer.

edit flag offensive delete link more

Comments

Thx. Did you also see my other question: why do GlobalFromLocal and LocalFromGlobal functions of the same class only convert velocity vectors (and not e.g. positions)? One more follow-up question, why is the conversion exactly this way (LLA -> ECEF -> ENU)? Why people do not convert directly from LLA -> ENU? Or why don't they just convert LLA -> ECEF and work in ECEF? Is it because the ENU is more intuitive?

dejanpan gravatar imagedejanpan ( 2016-11-16 13:11:44 -0600 )edit

Question Tools

1 follower

Stats

Asked: 2016-11-15 22:06:34 -0600

Seen: 1,701 times

Last updated: Oct 26 '20