31 using Deleter = std::function<void(
void)>;
41 : state_interface_(state_interface), deleter_(std::forward<Deleter>(deleter))
51 : state_interface_(*state_interface), deleter_(std::forward<Deleter>(deleter))
61 auto logger = rclcpp::get_logger(state_interface_.get_name());
62 RCLCPP_WARN_EXPRESSION(
64 (get_value_statistics_.failed_counter > 0 || get_value_statistics_.timeout_counter > 0),
65 "LoanedStateInterface %s has %u (%.4f %%) timeouts and %u (%.4f %%) missed calls out of %u "
67 state_interface_.get_name().c_str(), get_value_statistics_.timeout_counter,
68 (get_value_statistics_.timeout_counter * 100.0) / get_value_statistics_.total_counter,
69 get_value_statistics_.failed_counter,
70 (get_value_statistics_.failed_counter * 10.0) / get_value_statistics_.total_counter,
71 get_value_statistics_.total_counter);
78 const std::string & get_name()
const {
return state_interface_.get_name(); }
80 const std::string & get_interface_name()
const {
return state_interface_.get_interface_name(); }
82 const std::string & get_prefix_name()
const {
return state_interface_.get_prefix_name(); }
85 "Use std::optional<T> get_optional() instead to retrieve the value. This method will be "
86 "removed by the ROS 2 Kilted Kaiju release.")]]
87 double get_value()
const
90 if (opt_value.has_value())
92 return opt_value.value();
96 return std::numeric_limits<double>::quiet_NaN();
114 template <
typename T =
double>
115 [[nodiscard]] std::optional<T>
get_optional(
unsigned int max_tries = 10)
const
117 unsigned int nr_tries = 0;
120 ++get_value_statistics_.total_counter;
121 const std::optional<T> data = state_interface_.
get_optional<T>();
122 if (data.has_value())
126 ++get_value_statistics_.failed_counter;
128 std::this_thread::yield();
129 }
while (nr_tries < max_tries);
131 ++get_value_statistics_.timeout_counter;
152 struct HandleRTStatistics
154 unsigned int total_counter = 0;
155 unsigned int failed_counter = 0;
156 unsigned int timeout_counter = 0;
158 mutable HandleRTStatistics get_value_statistics_;