Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Inertial (measurement unit) data published by ServerInertial and IOrientationSensor is not fully defined #802

Open
traversaro opened this issue Jun 16, 2016 · 7 comments

Comments

@traversaro
Copy link
Member

The data published by the inertial device (ServerInertial class, documented in http://www.yarp.it/classyarp_1_1dev_1_1ServerInertial.html ) is not completely defined.
In particular:

  • The convention used for the RPY angles is undocumented.
  • The location of the "inertial" world frame with respect to which the sensor frame is expressed is not documented.

The first point is not critical (the convention is not documented but well understood among the users, see iDynTree::Rotation documentation for a documentation we can copy) while the second one is more subtle.

Considering that the XSens MTx was the device for which the inertial was firstly implemented, we can take its definition of the "inertial" world frame, i.e. :
X : NORTH
Y : WEST
Z : UP
See http://wiki.icub.org/images/8/82/XsensMtx.pdf , page 6 , section 2.3.2 .

However we should make sure that existing device follow this convention, see for example this issue in Gazebo : https://bitbucket.org/osrf/gazebo/issues/1959/add-ability-to-set-imu-initial-orientation .

Note that under the proposed convention, we are assuming that the IMU sensors are used near the earth surface, however considering that this kind of sensor only works near the earth surface it seems to be a reasonable assumption.

@traversaro
Copy link
Member Author

Apparently also in Gazebo we are (implicitly) using the NWU frame by default, see https://bitbucket.org/osrf/gazebo/pull-requests/2316/issue-1959-imu-fixes/diff#Lgazebo/sensors/ImuSensor.ccT238 .

@drdanz drdanz changed the title Inertial (measurement unit) data published by ServerInertial is not fully defined Inertial (measurement unit) data published by ServerInertial is not fully defined Aug 4, 2016
@traversaro
Copy link
Member Author

Just noticed that in http://www.yarp.it/classyarp_1_1dev_1_1ServerInertial.html we also need to document the unit of measurement.

@randaz81
Copy link
Member

randaz81 commented Dec 14, 2016

I dislike the inheritance of server inertial from IGenericSensor (or from generic IAnalogSensor et similia). Generally speaking, I think we should go for more detailed interfaces (for example: IInertialSensor) and use more the client interfaces in our modules. For example, the interface could have a non-ambiguous, well documented getRPYangles(), getGyros() etc..

@traversaro traversaro changed the title Inertial (measurement unit) data published by ServerInertial is not fully defined Inertial (measurement unit) data published by ServerInertial and IOrientationSensor is not fully defined Nov 5, 2019
@traversaro
Copy link
Member Author

traversaro commented Nov 5, 2019

The same problems actually still applies to IOrientationSensors interfaces (see

class YARP_dev_API yarp::dev::IOrientationSensors
).

Fortunately, since 2016 a few standards emerged that fortunately should match what we always did in the IMU, so in the documentation we should just reference that standards.

The convention used for the RPY angles is undocumented.

Fortunatly, the convention that we use is consistent with the one adopted in the section 12.29 3DOrientation of the OPC 10001-11 - Amendment 11: Spatial Types OPC UA standard https://opcfoundation.org/developer-tools/specifications-unified-architecture/errata-and-amendments/ . In particular, the Appendix G is quite useful (if you pretend that the Wikipedia reference is not there O_o ):
opc-ua-angles

I think it make sense to mention this standard in the documentation to explain the RPY convention used in YARP.

The location of the "inertial" world frame with respect to which the sensor frame is expressed is not documented.

Not sure if it is relevant, but this https://www.w3.org/TR/orientation-sensor/ could be useful.

cc @CarlottaSartore @fjandrad @nunoguedelha

@fjandrad
Copy link

fjandrad commented Nov 5, 2019

I see that the reference you posted

https://www.w3.org/TR/orientation-sensor/

Has the convention for absolute orientation with Y pointing to North instead of X as we were discussing previously. Which in the end is a choice. I am biased towards using X since it is more comfortable to explain when using the right hand rule xD

@fjandrad
Copy link

I'm not sure an action was decided or will be implemented. Should we close this issue @traversaro ?

@traversaro
Copy link
Member Author

I'm not sure an action was decided or will be implemented. Should we close this issue @traversaro ?

The two main points of the issue are:

The convention used for the RPY angles is undocumented.

This has actually been fixed for MAP interfaces in http://www.yarp.it/classyarp_1_1dev_1_1IOrientationSensors.html#adb2a40d03c747aa9c8b7fc542f193fd9 . For ServerInertial, we should just point at this docs.

The location of the "inertial" world frame with respect to which the sensor frame is expressed is not documented.

This still is not solved, and I think it is quite important to clarify it especially checking the existing implementations and see if the comply with it, as otherwise user will not know how to use the measure. For example, can we at least assume that the inertial frame will have the Z direction opposite to gravity? If not, this will affect a lot of user code. I think that for example @MiladShafiee @prashanthr05 had exactly problem of this kind. In this case, the action is clear, and even if no one is currently working on it, I do not think it makes a lot of sense to close the issue.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants