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

Get updated GUI ECM info when a user presses 'play' #1109

Merged
merged 18 commits into from
Nov 6, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ set(IGN_FUEL_TOOLS_VER ${ignition-fuel_tools7_VERSION_MAJOR})

#--------------------------------------
# Find ignition-gui
ign_find_package(ignition-gui6 REQUIRED)
ign_find_package(ignition-gui6 REQUIRED VERSION 6.1)
set(IGN_GUI_VER ${ignition-gui6_VERSION_MAJOR})
ign_find_package (Qt5
COMPONENTS
Expand Down
1 change: 1 addition & 0 deletions examples/plugin/rendering_plugins/rendering_plugins.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,7 @@
<start_paused>true</start_paused>
<service>/world/default/control</service>
<stats_topic>/world/default/stats</stats_topic>
<use_event>true</use_event>
</plugin>
<plugin filename='WorldStats' name='World stats'>
<ignition-gui>
Expand Down
1 change: 1 addition & 0 deletions examples/worlds/camera_sensor.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/fuel_textured_mesh.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/grid.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/minimal_scene.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,7 @@ Features:
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/optical_tactile_sensor_plugin.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/plot_3d.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/segmentation_camera.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/sensors_demo.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/sky.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,7 @@ Currently only supported using ogre2 rendering engine plugin.
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/thermal_camera.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/tunnel.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/video_record_dbl_pendulum.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -180,6 +180,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/visibility.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/visualize_contacts.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,7 @@ Contacts will be visualized as blue spheres and green cylinders.
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
1 change: 1 addition & 0 deletions examples/worlds/visualize_lidar.sdf
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,7 @@
<play_pause>true</play_pause>
<step>true</step>
<start_paused>true</start_paused>
<use_event>true</use_event>

</plugin>

Expand Down
69 changes: 56 additions & 13 deletions src/SimulationRunner.cc
Original file line number Diff line number Diff line change
Expand Up @@ -195,12 +195,14 @@ SimulationRunner::SimulationRunner(const sdf::World *_world,

// TODO(louise) Combine both messages into one.
this->node->Advertise("control", &SimulationRunner::OnWorldControl, this);
this->node->Advertise("control/state", &SimulationRunner::OnWorldControlState,
this);
this->node->Advertise("playback/control",
&SimulationRunner::OnPlaybackControl, this);

ignmsg << "Serving world controls on [" << opts.NameSpace()
<< "/control] and [" << opts.NameSpace() << "/playback/control]"
<< std::endl;
<< "/control], [" << opts.NameSpace() << "/control/state] and ["
<< opts.NameSpace() << "/playback/control]" << std::endl;

// Publish empty GUI messages for worlds that have no GUI in the beginning.
// In the future, support modifying GUI from the server at runtime.
Expand Down Expand Up @@ -410,6 +412,12 @@ void SimulationRunner::PublishStats()

msg.set_paused(this->currentInfo.paused);

if (this->Stepping())
{
auto headerData = msg.mutable_header()->add_data();
headerData->set_key("step");
}

// Publish the stats message. The stats message is throttled.
this->statsPub.Publish(msg);

Expand Down Expand Up @@ -1079,6 +1087,18 @@ void SimulationRunner::SetPaused(const bool _paused)
this->currentInfo.paused = _paused;
}

/////////////////////////////////////////////////
void SimulationRunner::SetStepping(bool _stepping)
{
this->stepping = _stepping;
}

/////////////////////////////////////////////////
bool SimulationRunner::Stepping() const
{
return this->stepping;
}

/////////////////////////////////////////////////
void SimulationRunner::SetRunToSimTime(
const std::chrono::steady_clock::duration &_time)
Expand All @@ -1097,36 +1117,54 @@ void SimulationRunner::SetRunToSimTime(
/////////////////////////////////////////////////
bool SimulationRunner::OnWorldControl(const msgs::WorldControl &_req,
msgs::Boolean &_res)
{
msgs::WorldControlState req;
req.mutable_world_control()->CopyFrom(_req);

return this->OnWorldControlState(req, _res);
}

/////////////////////////////////////////////////
bool SimulationRunner::OnWorldControlState(const msgs::WorldControlState &_req,
msgs::Boolean &_res)
{
std::lock_guard<std::mutex> lock(this->msgBufferMutex);

// update the server ECM if the request contains SerializedState information
if (_req.has_state())
this->entityCompMgr.SetState(_req.state());
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry to join the party late, but is this thread-safe? It's dangerous to update the ECM in a transport callback. I think we should define a clear moment in the update loop when the ECM is updated with the new state; maybe before PreUpdate?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for pointing thread safety out - I totally missed this the first time around 🤦 @nkoenig is going to open another PR with a fix.

// TODO(anyone) notify server systems of changes made to the ECM, if there
// were any?

WorldControl control;
control.pause = _req.pause();
control.pause = _req.world_control().pause();

if (_req.multi_step() != 0)
control.multiStep = _req.multi_step();
else if (_req.step())
if (_req.world_control().multi_step() != 0)
control.multiStep = _req.world_control().multi_step();
else if (_req.world_control().step())
control.multiStep = 1;

if (_req.has_reset())
if (_req.world_control().has_reset())
{
control.rewind = _req.reset().all() || _req.reset().time_only();
control.rewind = _req.world_control().reset().all() ||
_req.world_control().reset().time_only();

if (_req.reset().model_only())
if (_req.world_control().reset().model_only())
{
ignwarn << "Model only reset is not supported." << std::endl;
}
}

if (_req.seed() != 0)
if (_req.world_control().seed() != 0)
{
ignwarn << "Changing seed is not supported." << std::endl;
}

if (_req.has_run_to_sim_time())
if (_req.world_control().has_run_to_sim_time())
{
control.runToSimTime = std::chrono::seconds(_req.run_to_sim_time().sec()) +
std::chrono::nanoseconds(_req.run_to_sim_time().nsec());
control.runToSimTime = std::chrono::seconds(
_req.world_control().run_to_sim_time().sec()) +
std::chrono::nanoseconds(_req.world_control().run_to_sim_time().nsec());
}

this->worldControls.push_back(control);
Expand Down Expand Up @@ -1175,6 +1213,10 @@ void SimulationRunner::ProcessMessages()
void SimulationRunner::ProcessWorldControl()
{
IGN_PROFILE("SimulationRunner::ProcessWorldControl");

// assume no stepping unless WorldControl msgs say otherwise
this->SetStepping(false);

for (const auto &control : this->worldControls)
{
// Play / pause
Expand All @@ -1186,6 +1228,7 @@ void SimulationRunner::ProcessWorldControl()
this->pendingSimIterations += control.multiStep;
// Unpause so that stepping can occur.
this->SetPaused(false);
this->SetStepping(true);
}

// Rewind / reset
Expand Down
26 changes: 26 additions & 0 deletions src/SimulationRunner.hh
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@
#include <ignition/common/Event.hh>
#include <ignition/common/WorkerPool.hh>
#include <ignition/math/Stopwatch.hh>
#include <ignition/msgs.hh>
#include <ignition/transport/Node.hh>

#include "ignition/gazebo/config.hh"
Expand Down Expand Up @@ -291,6 +292,17 @@ namespace ignition
/// \return True if the simulation runner is paused, false otherwise.
public: bool Paused() const;

/// \brief Set if the simulation runner is stepping based on WorldControl
/// info
/// \param[in] _step True if stepping based on WorldControl info, false
/// otherwise
public: void SetStepping(bool _step);

/// \brief Get if the simulation runner is stepping based on WorldControl
/// info
/// \return True if stepping based on WorldControl info, false otherwise
public: bool Stepping() const;

/// \brief Set the run to simulation time.
/// \param[in] _time A simulation time in the future to run to and then
/// pause. A negative number or a time less than the current simulation
Expand Down Expand Up @@ -370,6 +382,16 @@ namespace ignition
private: bool OnWorldControl(const msgs::WorldControl &_req,
msgs::Boolean &_res);

/// \brief World control state service callback. This function stores the
/// the request which will then be processed by the ProcessMessages
/// function.
/// \param[in] _req Request from client, currently handling play / pause
/// and multistep. This also may contain SerializedState information.
/// \param[out] _res Response to client, true if successful.
/// \return True for success
private: bool OnWorldControlState(const msgs::WorldControlState &_req,
msgs::Boolean &_res);

/// \brief World control service callback. This function stores the
/// the request which will then be processed by the ProcessMessages
/// function.
Expand Down Expand Up @@ -601,6 +623,10 @@ namespace ignition
/// \brief True if Server::RunOnce triggered a blocking paused step
private: bool blockingPausedStepPending{false};

/// \brief Whether the simulation runner is currently stepping based on
/// WorldControl info (true) or not (false)
private: bool stepping{false};

friend class LevelManager;
};
}
Expand Down
Loading