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

Property use_now_instead_of_sim_time has no effect #31

Open
dmronga opened this issue Apr 20, 2018 · 7 comments
Open

Property use_now_instead_of_sim_time has no effect #31

dmronga opened this issue Apr 20, 2018 · 7 comments

Comments

@dmronga
Copy link
Contributor

dmronga commented Apr 20, 2018

Hi,

I am using mars under Rock (Ubuntu16.04, Rock branch master, Mars branch master). It seems that the property use_now_instead_of_sim_time does not have any effect.

My use case is the following: I have multiple Rock components attached to a Mars simulation and some of them are using the transformer. When I reset the simulation (through the GUI or via the control_action input port), the timestamps of the Mars sensor readings are reset to the time when the simulation was started. This makes the transformer start dropping transforms because of old data. When I change use_now_instead_of_sim_time to true, the same problem occurs, the timestamps still seem to show the Mars time instead of the current wall time.

I already checked:

However, the value of cfgUseNow.bValue is always false, even if I set use_now_instead_of_sim_time to true.
Any ideas how to solve this?

Best,
Dennis

@malter
Copy link
Member

malter commented Apr 23, 2018

Hey, I just fixed the getTime function and the cfgUseNow property handling. Without the property the simulation will return the real time of the last simulation reset + the processed simulated time. With the use_now... time option set, it should always return the current real time.

@planthaber
Copy link
Member

Then, that option HAS to make sure, that realtime_calc is enabled.

@malter
Copy link
Member

malter commented Apr 27, 2018

Why and where?

@planthaber
Copy link
Member

The simulation in general may run faster or slower than realtime. So using Time::now is misleading, as in 1s simulation time may be e.g. 0.1s or 2s in real time. this will definately lead to different results in the higher level. realtime_calc at least makes sure, simulation time is not faster than the system time.

This is why the system time is normally not used by the simulation.

Also the higher processing levels should use the timestamp of data aquisition and not the current time, as transmission times may vary between the receival of samples.

As Time::now should normally only be used by sensor drivers, not higher level tasks. using the simulation time is normally not an issue. This might also be the reason why use_now_instead_of_sim_time does not work.

Afaik the transformer also works on the timestamps, not Time::now.

I think the better option would be to restart also the transformer, or create a mars option not to reset the simulation time when resetting.

@malter
Copy link
Member

malter commented May 3, 2018

I have no Idea how the "high" level deals with data which is in the future. ;-)
If the simulation should run in real time but is computational to slow some control task also can't deal with that setup.
To my knowledge the simulation should always run (and manage to run) in real time for usage with ROCK.
Concerning Time::now, for me the simulation is simulating the sensor drivers and it should be okay to it.

@planthaber
Copy link
Member

"high" level means all except the drivers. If those components are all using timestamps instead of Time::now() (system time), there is no issue with different simulation speeds at all.

That was more a general remark, because the availability of that option could confuse devs and make them to rely on system time and not timestamps. So i think it is a bad idea to have that option at all. Also because it makes the user think, it solved the issue but actually it is not. The simulation still can become slower than the system time.

The simulation does not have to run in a similar speed to actual time, even with rock. But only if the components are consistently using the timestamps and not the system time.

I'd rather change the reset to optionally start from system time

@malter
Copy link
Member

malter commented May 3, 2018

OK, then we may remove the option. By the way I did a fix that the simulation time is reset to Time::now() and then incrementing the time with the simulated time. This should also solve the reset issue. If it does, we can remove the Time::now().

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

No branches or pull requests

3 participants