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

How to configure device timestamping? #333

Closed
stephen-cpr opened this issue May 23, 2024 · 9 comments
Closed

How to configure device timestamping? #333

stephen-cpr opened this issue May 23, 2024 · 9 comments
Labels
bug Something isn't working New This issue is new, and should not be marked as stale

Comments

@stephen-cpr
Copy link

I'm using a GQ7 and would like the driver to output IMU data based on the internal (presumably GPS time sync'd) clock, not the ROS time when the packet was received. It looks like in the past there was a 'use_device_timestamp' parameter you could configure, but this has since been removed. Is there still a way to do this?

@stephen-cpr stephen-cpr added the bug Something isn't working label May 23, 2024
@github-actions github-actions bot added the New This issue is new, and should not be marked as stale label May 23, 2024
@Aposhian
Copy link

It seems like we should be able to add that parameter back, and just have that option be read in the updateHeaderTime method. The GPS timestamp is already being passed into that method, but just isn't being used.

@hofbauerc
Copy link

Are there any methods on how to use the "use_device_timestamp" parameter with the current version? It seems weird that this functionality has been removed.

@robbiefish
Copy link

I am working on re implementing this for the driver. This was removed when releasing 4.0.0 in order to update and improve the timestamping feature, but due to some other priorities never got added back. I will link to the PR once it is open

@robbiefish robbiefish reopened this Oct 3, 2024
@hofbauerc
Copy link

Ok thanks for the reply.

So currently the timestamp is based on the system time of the PC am I right?

@hofbauerc
Copy link

@robbiefish any news on when we can expect that feature to be added back?

When we ordered our GQ7 we thought this would be the default way in terms of timestamping and now we basically wait for this feature to be added back to properly continue our projects with it.

@robbiefish
Copy link

This has been readded in 4.5.0, please see the timestamp_source parameter for more information.

If you want to go back to using the exact device timestamp, you can set timestamp_source to 1, but keep in mind that when the GQ7 gets a GPS fix, the timestamp will jump considerably. If you want a mostly consistent timestamp that should track ROS time, but with a dt similar to the device timestamp, you can set timestamp_source to 2

@lincob
Copy link

lincob commented Nov 18, 2024

Hi,

I've built from source 4.5.0 using the option :

  • /microstrain_inertial_driver/timestamp_source: 1

However my packets are still stamped with ros time (I manually set back the time of the computer to create a gap and disabled time server)

header:
seq: 121
stamp:
secs: 1730420953
nsecs: 412555065
frame_id: "gnss_1_antenna_link"
time_ref:
secs: 1731943260
nsecs: 0
source: ''”

Am I missing something here ?

Thanks.

@robbiefish
Copy link

Hi @lincob, the gnss_x/time topic you subscribed to is a special case. That message will always contain the device timestamp in the time_ref field, and be stamped with ROS time.

The purpose of that message is to show the relationship between the device GNSS time and ROS time. All other messages should be stamped with the requested timestamp

@lincob
Copy link

lincob commented Dec 19, 2024

Thanks @robbiefish that actually makes sense.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working New This issue is new, and should not be marked as stale
Projects
None yet
Development

No branches or pull requests

5 participants