-
Notifications
You must be signed in to change notification settings - Fork 789
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
fix typo in g2o file format parsing for the information matrix #1310
fix typo in g2o file format parsing for the information matrix #1310
Conversation
@mauricefallon this is a very good question. Can @mmattamala or someone else please add a test which will also verify the fix? I guess something simple would be to make a trivial graph that exposes the issue, write it to a g2o format string and parse it back, then we can check the parsed one against the original one. |
gtsam/slam/dataset.cpp
Outdated
mgtsam.block<3, 3>(3, 0) = m.block<3, 3>(3, 0); // off diagonal | ||
mgtsam.block<3, 3>(0, 0) = m.block<3, 3>(3, 3); // info rotation | ||
mgtsam.block<3, 3>(3, 3) = m.block<3, 3>(0, 0); // info translation | ||
mgtsam.block<3, 3>(3, 0) = m.block<3, 3>(0, 3); // off diagonal swap |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess there should be a comment here specifying that we need to swap to read the matrix in R,t order?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, I agree we should be more explicit on our comments to avoid future confusions
Some tests are failing on the CI related to SLAM graphs. |
I realized the tests are failing because in this PR we are just fixing the g2o-GTSAM conversions when reading Pose3 data but not when writing them. I made a PR against @mauricefallon's branch to fix it (mauricefallon#1), so we don't open more PRs here. The test that's failing is |
Fix in writeG2o when writing Pose3 measurement
Awesome stuff. If we can get a simple test to verify this (and for posterity) then we can happily merge this in. |
@varunagrawal , this bug fix is an error in file I/O - not in GTSAM itself. the test writeG2o3DNonDiagonalNoise reads in a g2o file (which is non diagonal), parses its constrants into a GTSAM graph and then writes out the constraints and compares the output constraints to the expected result. In brief:
The issue is that previously the test was just working because the input and output parsing code were BOTH wrong. "Two wrongs made a right" Which this PR, the test still passes - the output is still the same. But the parsing is correct. I dont think a test is needed. |
Fair enough. Approving. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
the g2o parser seems to have a bug when parsing the information matrix.
In brief:
IMO the correct values would be:
g2o info matrix is: (input)
00 10 20 30 40 50
10 01 21 31 41 51
20 21 02 32 42 52
30 31 32 03 43 53
40 41 42 43 04 54
50 51 52 53 54 05
the correct gtsam information matrix is: (output, with my fix)
03 43 53 30 31 32
43 04 54 40 41 42
53 54 05 50 51 52
30 40 50 00 10 20
31 41 51 10 01 21
32 42 52 20 21 02
After the reordering the offdiagonal elements (e.g. 31) should still be aligned with corresponding dimensions (1 and 3)
A test string for g2o:
EDGE_SE3:QUAT 1054 1055 0.251779 0.0571828 0.0217246 -0.0167946 -0.0087881 -0.0277189 0.999436 0 10 20 30 40 50 1 21 31 41 51 2 32 42 52 3 43 53 4 54 5
Final question:
way are there no GTSAM tests failing? Do some of them not have off diagonal terms e.g. the spheres dataset?
For reference Ceres parser:
https://github.com/ceres-solver/ceres-solver/blob/master/examples/slam/common/read_g2o.h#L94