Prima implementazione messaggio startup dei moduli
This commit is contained in:
@@ -40,6 +40,7 @@
|
|||||||
<!-- Message Relay to/from MQTT -->
|
<!-- Message Relay to/from MQTT -->
|
||||||
<node name="roboglue_ros_relay" pkg="roboglue_ros" type="roboglue_ros_relay" output="screen" required="true">
|
<node name="roboglue_ros_relay" pkg="roboglue_ros" type="roboglue_ros_relay" output="screen" required="true">
|
||||||
<param name="parameter_ns" type="string" value="/roboglue_ros_common/" />
|
<param name="parameter_ns" type="string" value="/roboglue_ros_common/" />
|
||||||
|
<param name="startup_msg" type="string" value='{"STARTUP":"RELAY"}'>
|
||||||
<param name="mqtt_host" type="string" value="tcp://localhost:1883" />
|
<param name="mqtt_host" type="string" value="tcp://localhost:1883" />
|
||||||
<param name="mqtt_qos" type="int" value="0" />
|
<param name="mqtt_qos" type="int" value="0" />
|
||||||
<param name="mqtt_INstate" type="string" value="roboglue_com/com2ros/state" />
|
<param name="mqtt_INstate" type="string" value="roboglue_com/com2ros/state" />
|
||||||
@@ -53,12 +54,14 @@
|
|||||||
<!-- Real Time Tracking -->
|
<!-- Real Time Tracking -->
|
||||||
<node name="roboglue_ros_follower" pkg="roboglue_ros" type="roboglue_ros_follower" output="screen" required="true">
|
<node name="roboglue_ros_follower" pkg="roboglue_ros" type="roboglue_ros_follower" output="screen" required="true">
|
||||||
<param name="parameter_ns" type="string" value="roboglue_ros_common" />
|
<param name="parameter_ns" type="string" value="roboglue_ros_common" />
|
||||||
|
<param name="startup_msg" type="string" value='{"STARTUP":"FOLLOWER"}'>
|
||||||
<param name="jog_pub_rate" type="int" value="5" />
|
<param name="jog_pub_rate" type="int" value="5" />
|
||||||
</node>
|
</node>
|
||||||
|
|
||||||
<!-- Tracking data Recorder/Player -->
|
<!-- Tracking data Recorder/Player -->
|
||||||
<node name="roboglue_ros_recorder" pkg="roboglue_ros" type="roboglue_ros_recorder" output="screen" required="true">
|
<node name="roboglue_ros_recorder" pkg="roboglue_ros" type="roboglue_ros_recorder" output="screen" required="true">
|
||||||
<param name="parameter_ns" type="string" value="/roboglue_ros_common/" />
|
<param name="parameter_ns" type="string" value="/roboglue_ros_common/" />
|
||||||
|
<param name="startup_msg" type="string" value='{"STARTUP":"RECORDER"}'>
|
||||||
<param name="point_group_mode" type="string" value="dist" />
|
<param name="point_group_mode" type="string" value="dist" />
|
||||||
<param name="planning_mode" type="string" value="path" />
|
<param name="planning_mode" type="string" value="path" />
|
||||||
<param name="meta_dir" type="string" value="/home/emanuele/Documents/GestioneMacchine/Robot_Incollaggio/Software/roboglue_ros_ws/src/roboglue_ros/config/meta/" />
|
<param name="meta_dir" type="string" value="/home/emanuele/Documents/GestioneMacchine/Robot_Incollaggio/Software/roboglue_ros_ws/src/roboglue_ros/config/meta/" />
|
||||||
@@ -69,7 +72,4 @@
|
|||||||
<param name="data_template" type="string" value="@data_template.data" />
|
<param name="data_template" type="string" value="@data_template.data" />
|
||||||
</node>
|
</node>
|
||||||
|
|
||||||
<!-- <param name="planning_mode" type="string" value="joint" /> -->
|
|
||||||
<!-- <param name="point_group_mode" type="string" value="time" /> -->
|
|
||||||
|
|
||||||
</launch>
|
</launch>
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
20190308 - Inserita una funzione che si occupa di effettuare il blocco delle variaili.
|
20190308 - Inserita una funzione che si occupa di effettuare il blocco delle variaili.
|
||||||
20190325 - Implementato uso del ros parameter server per la configurazione del nodo.
|
20190325 - Implementato uso del ros parameter server per la configurazione del nodo.
|
||||||
Contiene i nomi delle code ros.
|
Contiene i nomi delle code ros.
|
||||||
20191023 - Passaggio dei commenti a GIT
|
20191023 - Spostata Documentazione su GIT
|
||||||
*/
|
*/
|
||||||
////////// ROS INCLUDES /////////////
|
////////// ROS INCLUDES /////////////
|
||||||
#include "ros/ros.h"
|
#include "ros/ros.h"
|
||||||
@@ -64,8 +64,8 @@ void commandCallback(const std_msgs::String::ConstPtr& msg, internalState* is, p
|
|||||||
} else {
|
} else {
|
||||||
ROS_WARN("Unknown command: %s", command.c_str());
|
ROS_WARN("Unknown command: %s", command.c_str());
|
||||||
}
|
}
|
||||||
} catch (nlohmann::json::exception){
|
} catch (nlohmann::json::exception &e){
|
||||||
ROS_ERROR("Failed to parse command!");
|
ROS_ERROR("Failed to parse COMMAND: [%s]", e.what());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -178,6 +178,7 @@ int main(int argc, char **argv) {
|
|||||||
/// node variables ///
|
/// node variables ///
|
||||||
int loopRate, msgBufferSize, jogPubRate;
|
int loopRate, msgBufferSize, jogPubRate;
|
||||||
std::string param_ns;
|
std::string param_ns;
|
||||||
|
std_msgs::String startup_msg;
|
||||||
ROS_topics ros_topics;
|
ROS_topics ros_topics;
|
||||||
/// internal state struct ////
|
/// internal state struct ////
|
||||||
internalState is;
|
internalState is;
|
||||||
@@ -191,6 +192,7 @@ int main(int argc, char **argv) {
|
|||||||
ros::NodeHandle nh;
|
ros::NodeHandle nh;
|
||||||
///read parameters from server ///
|
///read parameters from server ///
|
||||||
nh.getParam("/roboglue_ros_relay/parameter_ns", param_ns);
|
nh.getParam("/roboglue_ros_relay/parameter_ns", param_ns);
|
||||||
|
nh.getParam(param_ns+"startup_msg", startup_msg.data);
|
||||||
nh.getParam(param_ns+"loop_rate", loopRate);
|
nh.getParam(param_ns+"loop_rate", loopRate);
|
||||||
nh.getParam(param_ns+"msg_buffer", msgBufferSize);
|
nh.getParam(param_ns+"msg_buffer", msgBufferSize);
|
||||||
nh.getParam(param_ns+"INstate", ros_topics.stateSub);
|
nh.getParam(param_ns+"INstate", ros_topics.stateSub);
|
||||||
@@ -210,7 +212,7 @@ int main(int argc, char **argv) {
|
|||||||
/// set spinner rate ///
|
/// set spinner rate ///
|
||||||
ros::Rate loop_rate(loopRate);
|
ros::Rate loop_rate(loopRate);
|
||||||
/// set console log level ///
|
/// set console log level ///
|
||||||
ros::console::set_logger_level(ROSCONSOLE_DEFAULT_NAME, ros::console::levels::Debug);
|
ros::console::set_logger_level(ROSCONSOLE_DEFAULT_NAME, ros::console::levels::Info);
|
||||||
ROS_INFO("Follower Node Started");
|
ROS_INFO("Follower Node Started");
|
||||||
|
|
||||||
/// advertise publish topics ///
|
/// advertise publish topics ///
|
||||||
@@ -221,10 +223,22 @@ int main(int argc, char **argv) {
|
|||||||
static_cast<uint32_t>(msgBufferSize));
|
static_cast<uint32_t>(msgBufferSize));
|
||||||
ros::Publisher trj_pub = nh.advertise<trajectory_msgs::JointTrajectory>(ros_topics.traj_jog,
|
ros::Publisher trj_pub = nh.advertise<trajectory_msgs::JointTrajectory>(ros_topics.traj_jog,
|
||||||
static_cast<uint32_t>(msgBufferSize));
|
static_cast<uint32_t>(msgBufferSize));
|
||||||
|
ros::Publisher command_pub = nh.advertise<std_msgs::String>(ros_topics.commandPub,
|
||||||
|
static_cast<uint32_t>(msgBufferSize));
|
||||||
|
ros::Publisher coord_pub = nh.advertise<std_msgs::String>(ros_topics.coordPub,
|
||||||
|
static_cast<uint32_t>(msgBufferSize));
|
||||||
|
ros::Publisher state_pub = nh.advertise<std_msgs::String>(ros_topics.statePub,
|
||||||
|
static_cast<uint32_t>(msgBufferSize));
|
||||||
|
|
||||||
/// build a list of publisher to pass to mqtt callback ///
|
/// build a list of publisher to pass to mqtt callback ///
|
||||||
|
publishers[command_pub.getTopic()] = &command_pub;
|
||||||
|
publishers[coord_pub.getTopic()] = &coord_pub;
|
||||||
|
publishers[state_pub.getTopic()] = &state_pub;
|
||||||
|
/// publishers to jog command interfaces
|
||||||
publishers["jog_pub"] = &jog_pub;
|
publishers["jog_pub"] = &jog_pub;
|
||||||
publishers["jog_joint_pub"] = &jog_joint_pub;
|
publishers["jog_joint_pub"] = &jog_joint_pub;
|
||||||
publishers["trj_pub"] = &trj_pub;
|
publishers["trj_pub"] = &trj_pub;
|
||||||
|
|
||||||
/// subscribe to incoming topics ///
|
/// subscribe to incoming topics ///
|
||||||
ros::Subscriber command_sub = nh.subscribe<std_msgs::String>(ros_topics.commandSub, static_cast<uint32_t>(msgBufferSize),
|
ros::Subscriber command_sub = nh.subscribe<std_msgs::String>(ros_topics.commandSub, static_cast<uint32_t>(msgBufferSize),
|
||||||
boost::bind(commandCallback, _1, &is, &publishers, &pos_data, &robot_data));
|
boost::bind(commandCallback, _1, &is, &publishers, &pos_data, &robot_data));
|
||||||
@@ -247,13 +261,18 @@ int main(int argc, char **argv) {
|
|||||||
boost::bind(timedPublishCallback, _1, &is, &publishers, &pos_data, &robot_data));
|
boost::bind(timedPublishCallback, _1, &is, &publishers, &pos_data, &robot_data));
|
||||||
// now we can get inverse kinematics from kinematic state using the joint model
|
// now we can get inverse kinematics from kinematic state using the joint model
|
||||||
|
|
||||||
|
///////////////////// MAIN LOOP //////////////////////
|
||||||
|
bool startCycle = true;
|
||||||
while (ros::ok() && is.isRunning) {
|
while (ros::ok() && is.isRunning) {
|
||||||
|
if (startCycle){
|
||||||
|
startCycle = false;
|
||||||
|
publishers[command_pub.getTopic()]->publish(startup_msg);
|
||||||
|
}
|
||||||
ROS_DEBUG_ONCE("Follower Node Looping");
|
ROS_DEBUG_ONCE("Follower Node Looping");
|
||||||
//testFunction(&trj_pub);
|
|
||||||
ros::spinOnce();
|
ros::spinOnce();
|
||||||
//if (is.isRealtime)
|
|
||||||
loop_rate.sleep();
|
loop_rate.sleep();
|
||||||
}
|
}
|
||||||
|
//////////////////////////////////////////////////////
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
////////////////////////////////////////
|
////////////////////////////////////////
|
||||||
|
|||||||
@@ -33,7 +33,7 @@
|
|||||||
che non si incappi in configurazioni instabili.
|
che non si incappi in configurazioni instabili.
|
||||||
20190708 - Implementazione funzioni di visualizzazione del percorso e pulizia dello schermo prima
|
20190708 - Implementazione funzioni di visualizzazione del percorso e pulizia dello schermo prima
|
||||||
dell'esecuzione del file.
|
dell'esecuzione del file.
|
||||||
20191029 - Spostata la documentazione si Git
|
20191029 - Spostata la documentazione suG GIT
|
||||||
*/
|
*/
|
||||||
////////// ROS INCLUDES /////////////
|
////////// ROS INCLUDES /////////////
|
||||||
#include "ros/ros.h"
|
#include "ros/ros.h"
|
||||||
@@ -125,7 +125,7 @@ void commandCallback(const std_msgs::String::ConstPtr& msg, internalState* is, p
|
|||||||
ROS_WARN("Unknown command: %s", command.c_str());
|
ROS_WARN("Unknown command: %s", command.c_str());
|
||||||
}
|
}
|
||||||
} catch (nlohmann::json::exception &e) {
|
} catch (nlohmann::json::exception &e) {
|
||||||
ROS_ERROR("Failed to parse command: [%s]", e.what());
|
ROS_ERROR("Failed to parse COMMAND: [%s]", e.what());
|
||||||
is->isPlaying = false;
|
is->isPlaying = false;
|
||||||
is->isRealtime = false;
|
is->isRealtime = false;
|
||||||
is->isRecording = false;
|
is->isRecording = false;
|
||||||
@@ -181,22 +181,26 @@ void coordinateCallback(const std_msgs::String::ConstPtr& msg, internalState* is
|
|||||||
|
|
||||||
void stateCallback(const std_msgs::String::ConstPtr& msg, internalState*is, auxData* aux){
|
void stateCallback(const std_msgs::String::ConstPtr& msg, internalState*is, auxData* aux){
|
||||||
ROS_DEBUG("Received aux I/O State Update: [%s]", msg->data.c_str());
|
ROS_DEBUG("Received aux I/O State Update: [%s]", msg->data.c_str());
|
||||||
nlohmann::json auxParsed = nlohmann::json::parse(msg->data);
|
try {
|
||||||
nlohmann::json digitalParsed = auxParsed["digital"];
|
nlohmann::json auxParsed = nlohmann::json::parse(msg->data);
|
||||||
nlohmann::json analogParsed = auxParsed["analog"];
|
nlohmann::json digitalParsed = auxParsed["digital"];
|
||||||
std::vector<std::pair<std::string,bool>> tempDigital;
|
nlohmann::json analogParsed = auxParsed["analog"];
|
||||||
std::vector<std::pair<std::string,uint16_t>> tempAnalog;
|
std::vector<std::pair<std::string,bool>> tempDigital;
|
||||||
if (is->isRecording || is->isRealtime){
|
std::vector<std::pair<std::string,uint16_t>> tempAnalog;
|
||||||
for (auto di : digitalParsed.items()){
|
if (is->isRecording || is->isRealtime){
|
||||||
tempDigital.push_back(std::pair<std::string,bool>(di.key(),di.value().get<bool>()));
|
for (auto di : digitalParsed.items()){
|
||||||
|
tempDigital.push_back(std::pair<std::string,bool>(di.key(),di.value().get<bool>()));
|
||||||
|
}
|
||||||
|
for (auto ai : analogParsed.items()){
|
||||||
|
tempAnalog.push_back(std::pair<std::string,uint16_t>(ai.key(),ai.value().get<uint16_t>()));
|
||||||
|
}
|
||||||
|
aux->digital.clear();
|
||||||
|
aux->analog.clear();
|
||||||
|
aux->digital.assign(tempDigital.begin(), tempDigital.end());
|
||||||
|
aux->analog.assign(tempAnalog.begin(), tempAnalog.end());
|
||||||
}
|
}
|
||||||
for (auto ai : analogParsed.items()){
|
} catch (nlohmann::json::exception &e) {
|
||||||
tempAnalog.push_back(std::pair<std::string,uint16_t>(ai.key(),ai.value().get<uint16_t>()));
|
ROS_ERROR("Failed to parse STATE: [%s]", e.what());
|
||||||
}
|
|
||||||
aux->digital.clear();
|
|
||||||
aux->analog.clear();
|
|
||||||
aux->digital.assign(tempDigital.begin(), tempDigital.end());
|
|
||||||
aux->analog.assign(tempAnalog.begin(), tempAnalog.end());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -224,6 +228,8 @@ int main(int argc, char **argv) {
|
|||||||
file_data.playVect = &playVector;
|
file_data.playVect = &playVector;
|
||||||
|
|
||||||
/// player variables ///
|
/// player variables ///
|
||||||
|
|
||||||
|
std_msgs::String startup_msg;
|
||||||
double dsCounter, dtCounter;
|
double dsCounter, dtCounter;
|
||||||
std::vector<pointRecord> tempPlayVector;
|
std::vector<pointRecord> tempPlayVector;
|
||||||
std::vector<geometry_msgs::PoseStamped> tempPlanningVector;
|
std::vector<geometry_msgs::PoseStamped> tempPlanningVector;
|
||||||
@@ -235,6 +241,7 @@ int main(int argc, char **argv) {
|
|||||||
/// read parameters from server ///
|
/// read parameters from server ///
|
||||||
//load common parameters
|
//load common parameters
|
||||||
nh.getParam("/roboglue_ros_recorder/parameter_ns", param_ns);
|
nh.getParam("/roboglue_ros_recorder/parameter_ns", param_ns);
|
||||||
|
nh.getParam(param_ns+"startup_msg", startup_msg.data);
|
||||||
nh.getParam(param_ns+"loop_rate", loopRate);
|
nh.getParam(param_ns+"loop_rate", loopRate);
|
||||||
nh.getParam(param_ns+"msg_buffer", msgBufferSize);
|
nh.getParam(param_ns+"msg_buffer", msgBufferSize);
|
||||||
nh.getParam(param_ns+"min_nonzero_move", nonzero_move);
|
nh.getParam(param_ns+"min_nonzero_move", nonzero_move);
|
||||||
@@ -311,7 +318,9 @@ int main(int argc, char **argv) {
|
|||||||
rviz_data.vtools->loadRemoteControl();
|
rviz_data.vtools->loadRemoteControl();
|
||||||
rviz_data.vtools->deleteAllMarkers();
|
rviz_data.vtools->deleteAllMarkers();
|
||||||
rviz_data.vtools->trigger();
|
rviz_data.vtools->trigger();
|
||||||
|
publishers[command_pub.getTopic()]->publish(startup_msg);
|
||||||
}
|
}
|
||||||
|
ROS_DEBUG_ONCE("Recorder Node Looping");
|
||||||
ros::spinOnce();
|
ros::spinOnce();
|
||||||
/////////////////////////////////////////
|
/////////////////////////////////////////
|
||||||
/////////// PLAY FILE ///////////////////
|
/////////// PLAY FILE ///////////////////
|
||||||
|
|||||||
@@ -6,6 +6,7 @@
|
|||||||
modi che li devono interpretare. qui viene trattato tutto come stringa.
|
modi che li devono interpretare. qui viene trattato tutto come stringa.
|
||||||
20190325 - Implementato uso del ros parameter server per la configurazione del nodo.
|
20190325 - Implementato uso del ros parameter server per la configurazione del nodo.
|
||||||
Contiene i nomi delle code sia ros che mqtt.
|
Contiene i nomi delle code sia ros che mqtt.
|
||||||
|
20191028 - Documentazione Spostata su GIT
|
||||||
*/
|
*/
|
||||||
|
|
||||||
////////// ROS INCLUDES /////////////
|
////////// ROS INCLUDES /////////////
|
||||||
@@ -83,11 +84,13 @@ int main(int argc, char **argv) {
|
|||||||
std::string param_ns;
|
std::string param_ns;
|
||||||
MQTT_topics mqtt_topics;
|
MQTT_topics mqtt_topics;
|
||||||
ROS_topics ros_topics;
|
ROS_topics ros_topics;
|
||||||
|
std_msgs::String startup_msg;
|
||||||
/// setup node parameters ///
|
/// setup node parameters ///
|
||||||
ros::init(argc, argv, "roboglue_relay");
|
ros::init(argc, argv, "roboglue_relay");
|
||||||
ros::NodeHandle nh;
|
ros::NodeHandle nh;
|
||||||
///read parameters from server ///
|
///read parameters from server ///
|
||||||
nh.getParam("/roboglue_ros_relay/parameter_ns", param_ns);
|
nh.getParam("/roboglue_ros_relay/parameter_ns", param_ns);
|
||||||
|
nh.getParam(param_ns+"startup_msg", startup_msg.data);
|
||||||
nh.getParam(param_ns+"loop_rate", loopRate);
|
nh.getParam(param_ns+"loop_rate", loopRate);
|
||||||
nh.getParam(param_ns+"msg_buffer", msgBufferSize);
|
nh.getParam(param_ns+"msg_buffer", msgBufferSize);
|
||||||
nh.getParam(param_ns+"INstate", ros_topics.stateSub);
|
nh.getParam(param_ns+"INstate", ros_topics.stateSub);
|
||||||
@@ -146,13 +149,18 @@ int main(int argc, char **argv) {
|
|||||||
ROS_ERROR("Failed to Connect to MQTT: [%s]", e.what());
|
ROS_ERROR("Failed to Connect to MQTT: [%s]", e.what());
|
||||||
ros::shutdown();
|
ros::shutdown();
|
||||||
}
|
}
|
||||||
|
////////////// MAIN LOOP /////////////
|
||||||
|
bool startCycle = true;
|
||||||
while (ros::ok()) {
|
while (ros::ok()) {
|
||||||
|
if (startCycle){
|
||||||
|
startCycle = false;
|
||||||
|
publishers[command_pub.getTopic()]->publish(startup_msg);
|
||||||
|
}
|
||||||
ROS_DEBUG_ONCE("Relay Node Looping");
|
ROS_DEBUG_ONCE("Relay Node Looping");
|
||||||
ros::spinOnce();
|
ros::spinOnce();
|
||||||
loop_rate.sleep();
|
loop_rate.sleep();
|
||||||
}
|
}
|
||||||
|
///////////////////////////////////////
|
||||||
try {
|
try {
|
||||||
client.stop_consuming();
|
client.stop_consuming();
|
||||||
client.disable_callbacks();
|
client.disable_callbacks();
|
||||||
|
|||||||
Reference in New Issue
Block a user