diff --git a/CHANGELOG.md b/CHANGELOG.md
index 353abc4b7..b4d824953 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -13,6 +13,7 @@ Requires `libfranka` >= 0.8.0
* `franka_gazebo`: `FrankaHWSim` only acts on joints belonging to a Franka robot. This allows to combine a Franka robot and others (like mobile platforms) in same URDF ([#313](https://github.com/frankaemika/franka_ros/issues/313))
* `franka_description`: `` macro now supports to customize the `parent` frame and its `xyz` + `rpy` offset
* `franka_hw`: Fix the bug where the previous controller is still running after switching the controller. ([#326](https://github.com/frankaemika/franka_ros/issues/326))
+ * `franka_gazebo`: remove FrankaHWSim robot namespace warning
## 0.10.1 - 2022-09-15
diff --git a/franka_gazebo/src/franka_hw_sim.cpp b/franka_gazebo/src/franka_hw_sim.cpp
index fb80907b2..8a0c1ed9b 100644
--- a/franka_gazebo/src/franka_hw_sim.cpp
+++ b/franka_gazebo/src/franka_hw_sim.cpp
@@ -35,14 +35,14 @@ bool FrankaHWSim::initSim(const std::string& robot_namespace,
gazebo::physics::ModelPtr parent,
const urdf::Model* const urdf,
std::vector transmissions) {
- model_nh.param("arm_id", this->arm_id_, robot_namespace);
- if (this->arm_id_ != robot_namespace) {
- ROS_WARN_STREAM_NAMED(
- "franka_hw_sim",
- "Caution: Robot names differ! Read 'arm_id: "
- << this->arm_id_ << "' from parameter server but URDF defines '"
- << robot_namespace << "'. Will use '" << this->arm_id_ << "'!");
+ // Try to get the arm_id from the robot_namespace otherwise use the model name.
+ if (!model_nh.hasParam("arm_id")) {
+ ROS_WARN_STREAM_NAMED("franka_hw_sim", "No 'arm_id' found on '" << model_nh.getNamespace()
+ << "' parameter namespace."
+ << " Using model name instead ("
+ << parent->GetName() << ").");
}
+ model_nh.param("arm_id", this->arm_id_, parent->GetName());
this->robot_ = parent;
this->robot_initialized_ = false;