27#include <lttng/tracepoint.h>
38using namespace std::chrono_literals;
46: schedulerThread(nullptr),
47 signalDetectorLoop(nullptr),
48 signalDetector(nullptr),
84 lastState_ = std::numeric_limits<int64_t>::quiet_NaN();
101 auto & orthogonal = pair.second;
102 auto & clients = orthogonal->getClients();
104 for (
auto & client : clients)
109 if (updatableClient !=
nullptr)
117 std::vector<std::shared_ptr<ISmaccComponent>> components;
118 client->getComponents(components);
119 for (
auto & componententry : components)
121 auto updatableComponent =
dynamic_cast<ISmaccUpdatable *
>(componententry.get());
122 if (updatableComponent !=
nullptr)
126 "Adding updatable component: " <<
demangleType(
typeid(*updatableComponent)));
147 auto & orthogonal = pair.second;
148 auto & behaviors = orthogonal->getClientBehaviors().back();
150 for (
auto & currentBehavior : behaviors)
155 if (updatableClientBehavior !=
nullptr)
159 "Adding updatable behavior: " <<
demangleType(
typeid(updatableClientBehavior)));
160 updatableElements.push_back(updatableClientBehavior);
166 if (updatableState !=
nullptr)
168 updatableElements.push_back(updatableState);
172 for (
auto & sr : statereactors)
175 if (updatableStateReactor !=
nullptr)
179 "Adding updatable stateReactorr: " <<
demangleType(
typeid(updatableStateReactor)));
180 updatableElements.push_back(updatableStateReactor);
185 for (
auto & eg : eventgenerators)
188 if (updatableEventGenerator !=
nullptr)
192 "Adding updatable eventGenerator: " <<
demangleType(
typeid(updatableEventGenerator)));
193 updatableElements.push_back(updatableEventGenerator);
210 RCLCPP_INFO(
getLogger(),
"[SignalDetector] ROS initialization complete, enabling polling loop");
257 RCLCPP_INFO(
getLogger(),
"[SignalDetector] Terminating scheduler...");
272 TRACETOOLS_TRACEPOINT(spinOnce);
287 auto updatableElementName =
demangleType(
typeid(*updatableClient)).c_str();
292 "[PollOnce] update client call: " <<
demangleType(
typeid(*updatableClient)));
298 catch (
const std::exception & e)
302 "Error in updatable elemnent " << updatableElementName <<
": " << e.what() <<
'\n');
311 this->smaccStateMachine_->stateMachineCurrentAction !=
313 this->smaccStateMachine_->stateMachineCurrentAction !=
315 this->smaccStateMachine_->stateMachineCurrentAction !=
323 for (
auto * udpatableStateElement : stateElement)
325 std::string updatableElementName =
demangleType(
typeid(*udpatableStateElement));
326 auto updatableElementNameCstr = updatableElementName.c_str();
329 getLogger(),
"pollOnce update client behavior call: "
339 catch (std::exception & ex)
341 RCLCPP_ERROR(
getLogger(),
"Exception during Signal Detector update loop. %s.", ex.what());
345 rclcpp::spin_some(nh);
357 rclcpp::Node::SharedPtr _;
369 if (!rclcpp::ok() ||
end_)
371 RCLCPP_INFO(
getLogger(),
"[SignalDetector] Shutdown requested before initialization completed");
377 if (!nh->get_parameter(
"signal_detector_loop_freq", this->loop_rate_hz))
381 "Signal Detector frequency (ros param signal_detector_loop_freq) was not set, using default "
389 getLogger(),
"Signal Detector frequency (ros param signal_detector_loop_freq): %lf",
393 nh->set_parameter(rclcpp::Parameter(
"signal_detector_loop_freq", this->
loop_rate_hz));
399 RCLCPP_INFO_STREAM(
getLogger(),
"[SignalDetector] Running in single-threaded mode.");
402 while (rclcpp::ok() && !
end_)
404 RCLCPP_INFO_STREAM_THROTTLE(
407 rclcpp::spin_some(nh);
413 RCLCPP_INFO_STREAM(
getLogger(),
"[SignalDetector] Running in multi-threaded mode.");
415 rclcpp::executors::MultiThreadedExecutor executor;
416 executor.add_node(nh);
442 RCLCPP_INFO(rclcpp::get_logger(
"SMACC"),
"SignalDetector: SIGQUIT received.");
StateMachineInternalAction stateMachineCurrentAction
rclcpp::Node::SharedPtr getNode()
const std::map< std::string, std::shared_ptr< smacc2::ISmaccOrthogonal > > & getOrthogonals() const
std::recursive_mutex m_mutex_
std::vector< std::shared_ptr< StateReactor > > & getStateReactors()
std::vector< std::shared_ptr< SmaccEventGenerator > > & getEventGenerators()
SmaccFifoScheduler * scheduler_
void terminateScheduler()
boost::thread signalDetectorThread_
void notifyStateExited(ISmaccState *currentState)
ExecutionModel executionModel_
void initialize(ISmaccStateMachine *stateMachine)
std::vector< std::vector< ISmaccUpdatable * > > updatableStateElements_
std::atomic< bool > rosInitialized_
rclcpp::Logger getLogger()
rclcpp::Node::SharedPtr getNode()
SmaccFifoScheduler::processor_handle processorHandle_
SignalDetector(SmaccFifoScheduler *scheduler, ExecutionModel executionModel=ExecutionModel::SINGLE_THREAD_SPINNER)
std::atomic< int64_t > lastState_
std::vector< ISmaccUpdatable * > updatableClients_
void notifyRosInitialized()
void setProcessorHandle(SmaccFifoScheduler::processor_handle processorHandle)
void findUpdatableStateElements(ISmaccState *currentState)
void findUpdatableClientsAndComponents()
ISmaccStateMachine * smaccStateMachine_
void notifyStateConfigured(ISmaccState *currentState)
std::atomic< bool > initialized_
static SmExecution & getInstance()
SignalDetector * signalDetector
std::string demangleType(const std::type_info *tinfo)
void onSignalShutdown(int sig)
boost::statechart::fifo_scheduler< SmaccFifoWorker, SmaccAllocator > SmaccFifoScheduler
smacc2_state_update_start