Home | Tutorials | Wiki | Issues
Ask Your Question

How to administrate (spawning and deleting) models synchronously and deterministically for testrun automation?

asked 2018-12-09 17:58:16 -0600

Illuminatur gravatar image

updated 2018-12-16 02:15:31 -0600


i've got some questions regarding the simulation loop inside of Gazebo:

  • (Q1) We want to use multiple plugins, with have different times for loading up (since we are instantiating different amount of models). We want to wait until all plugins are ready. Is there any function, which is executed before any callback connected to OnWorldUpdateBegin(), which can be blocked or take arbitrary times before being finished?

  • (Q2) If we want to spawn a set of models at the beginning of every single scenario, is there a possibility to get a direct response or feedback about the success/failure of its "birth"? This is insofar important, since we need to spawn our models in order to provide reproducibility of the distinct scenarios?

  • (Q3) Init(), Reset() and Load(): If we want to realize testrun automation within Gazebo, we have the necessity of adding and removing models for scenario variation between successive testruns. In order to be able to create or remove models between those runs, we might get in conflict with the different threads accessing those models. This, for example, is the case with Reset() and OnUpdate(), which has been registered to the WorldUpdateBegin() event, e.g.. So, we might need to disconnect the callback for example right BEFORE the deletion of the model in in the Reset() method to avoid any threading issues, right?

  • (Q4) My next question then continues the right usage of those functions: How are Load() and Init() (or Reset()) are in general thought to be used? Which data structures should be instantiated in which function (gazebo transport node, …)?

I think it might get clearer, if i outline and detail our application and sketch it in the context of question (Q1) and (Q2):

We are using Gazebo as a co-simulation master for controlling two connected simulations and combining the specific agents in one, common environment model for a co-simulation plattform: Two dedicated plugins, both of type WorldPlugin, establish their connection to a microscopic vehicle and a pedestrian crowd simulation. Both plugins build up the connection in their specific Load() function, receive the number of expected vehicles and pedestrians from both simulations and then requests Gazebo to instantiate the number of necessary models via InsertModelAsSDF() on the world ptrs of the plugins. Since the Load() function shall be non-blocking, a OnUpdate() function, which has been previously connected to the OnWorldUpdateBegin() event of the simulation loop, then checks at the very beginning if the available amount of models corresponds to the number of recently requested models. If so, the plugins and the simulation models are synchronized. This approach has two big disadvantages:

  • We completely miss reproducability, since it is not predictable in which stimulation step Gazebo is synchronized with one of the coupled simulations, especially considering the synchronization with both simulations.
  • This also prevents us from implementing a simple Reset(). We are able to reset the connected simulations, but... we (1) have to remove our EventConnection on OnWorldUpdateBegin()-Event, (2) remove the agents safely by deleting the models ...
edit retag flag offensive close merge delete

2 Answers

Sort by » oldest newest most voted

answered 2018-12-11 16:42:54 -0600

nkoenig gravatar image
  1. Your first question is difficult to understand. Are you looking for a function to block simulation update at a particular time? Are you experiencing a situation where gazebo hangs? Are you trying to block simulation based on an event?

  2. One approach is to send out a "birth" message on your own topic. You can also monitor the /pose/info topic, which will contain pose info on your model after the model is spawned.

  3. Since I can reproduce your test scenario the best answer I can give is maybe. What have you tried, where did it fail, and what steps can I follow to reproduce your problem?

  4. After construction of an entity, you should call Load to configure the entity. Init should follow Load. You will likely get unexpected results if you call Reset followed by Init. While there was intention to eventually support this use-case, we have never implemented the Init --> Reset --> Init pattern.

edit flag offensive delete link more


Hi, i just added my explanations to the original post. Are there any ideas how we could solve our issue?

Illuminatur gravatar imageIlluminatur ( 2018-12-12 13:34:00 -0600 )edit

answered 2018-12-15 02:44:07 -0600

Illuminatur gravatar image


are there any ideas? Any help is appreciated.

Best regards and thx!

edit flag offensive delete link more
Login/Signup to Answer

Question Tools



Asked: 2018-12-09 17:58:16 -0600

Seen: 108 times

Last updated: Dec 16 '18