Made rc command available in .bzz script and removed continuous call of flight controller

This commit is contained in:
vivek 2016-12-02 19:11:36 -05:00
parent 4b2f02facb
commit 9e9eb964b1
7 changed files with 72 additions and 29 deletions

View File

@ -9,7 +9,7 @@ endif()
find_package(catkin REQUIRED COMPONENTS find_package(catkin REQUIRED COMPONENTS
roscpp roscpp
std_msgs std_msgs
mavros_msgs #mavros_msgs
sensor_msgs sensor_msgs
) )

View File

@ -22,8 +22,10 @@ int buzzros_print(buzzvm_t vm);
int buzzuav_goto(buzzvm_t vm); int buzzuav_goto(buzzvm_t vm);
/* Returns the current command from local variable*/ /* Returns the current command from local variable*/
int getcmd(); int getcmd();
/*Sets goto position could be used for bypassing*/ /*Sets goto position */
void set_goto(double pos[]); void set_goto(double pos[]);
/*Sets goto position from rc client*/
void rc_set_goto(double pos[]);
/*sets rc requested command */ /*sets rc requested command */
void rc_call(int rc_cmd); void rc_call(int rc_cmd);
/* sets the battery state */ /* sets the battery state */
@ -57,7 +59,9 @@ int buzzuav_update_battery(buzzvm_t vm);
*/ */
int buzzuav_update_currentpos(buzzvm_t vm); int buzzuav_update_currentpos(buzzvm_t vm);
/* /*
* Updates flight status in Buzz * Updates flight status and rc command in Buzz, put it in a tabel to acess it
* use flight.status for flight status
* use flight.rc_cmd for current rc cmd
*/ */
int buzzuav_update_flight_status(buzzvm_t vm); int buzzuav_update_flight_status(buzzvm_t vm);

View File

@ -42,6 +42,7 @@ private:
int robot_id=0; int robot_id=0;
int oldcmdID=0; int oldcmdID=0;
int rc_cmd; int rc_cmd;
int bzz_old_cmd=0;
std::string bzzfile_name, fcclient_name, rcservice_name,bcfname,dbgfname,out_payload,in_payload; //, rcclient; std::string bzzfile_name, fcclient_name, rcservice_name,bcfname,dbgfname,out_payload,in_payload; //, rcclient;
bool rcclient; bool rcclient;
ros::ServiceClient mav_client; ros::ServiceClient mav_client;

View File

@ -2,13 +2,13 @@
<launch> <launch>
<node name="rosbuzz_node" pkg="rosbuzz" type="rosbuzz_node" respawn="false" output="screen" > <node name="rosbuzz_node" pkg="rosbuzz" type="rosbuzz_node" respawn="false" output="screen" >
<param name="bzzfile_name" value="../ROS_WS/src/ROSBuzz/src/test.bzz" /> <param name="bzzfile_name" value="/home/vivek/catkin_ws/src/rosbuzz/src/test.bzz" />
<param name="rcclient" value="true" /> <param name="rcclient" value="true" />
<param name="rcservice_name" value="rc_cmd" /> <param name="rcservice_name" value="rc_cmd" />
<param name="fcclient_name" value="/djicmd" /> <param name="fcclient_name" value="/djicmd" />
<param name="in_payload" value="outMavlink"/> <param name="in_payload" value="/inMavlink"/>
<param name="out_payload" value="outMavlink"/> <param name="out_payload" value="/outMavlink"/>
<param name="robot_id" value="1"/> <param name="robot_id" value="2"/>
</node> </node>

View File

@ -9,10 +9,11 @@
#include "buzzuav_closures.h" #include "buzzuav_closures.h"
namespace buzzuav_closures{ namespace buzzuav_closures{
static double goto_pos[3]; static double goto_pos[3];
static double rc_goto_pos[3];
static float batt[3]; static float batt[3];
static double cur_pos[3]; static double cur_pos[3];
static uint8_t status; static uint8_t status;
static int cur_cmd; static int cur_cmd = 0;
static int rc_cmd=0; static int rc_cmd=0;
/****************************************/ /****************************************/
/****************************************/ /****************************************/
@ -83,13 +84,8 @@ return goto_pos;
} }
/******************************/ /******************************/
int getcmd(){ int getcmd(){
if(rc_cmd==0) return cur_cmd;
else {
cur_cmd=rc_cmd;
rc_cmd=0;
return cur_cmd; return cur_cmd;
} }
}
void set_goto(double pos[]){ void set_goto(double pos[]){
goto_pos[0]=pos[0]; goto_pos[0]=pos[0];
@ -98,6 +94,12 @@ goto_pos[2]=pos[2];
} }
void rc_set_goto(double pos[]){
rc_goto_pos[0]=pos[0];
rc_goto_pos[1]=pos[1];
rc_goto_pos[2]=pos[2];
}
void rc_call(int rc_cmd_in){ void rc_call(int rc_cmd_in){
rc_cmd=rc_cmd_in; rc_cmd=rc_cmd_in;
} }
@ -188,14 +190,35 @@ int buzzuav_update_flight_status(buzzvm_t vm) {
buzzvm_pushs(vm, buzzvm_string_register(vm, "flight", 1)); buzzvm_pushs(vm, buzzvm_string_register(vm, "flight", 1));
buzzvm_pusht(vm); buzzvm_pusht(vm);
buzzvm_dup(vm); buzzvm_dup(vm);
buzzvm_pushs(vm, buzzvm_string_register(vm, "rc_cmd", 1));
buzzvm_pushi(vm, rc_cmd);
buzzvm_tput(vm);
buzzvm_dup(vm);
buzzvm_pushs(vm, buzzvm_string_register(vm, "status", 1)); buzzvm_pushs(vm, buzzvm_string_register(vm, "status", 1));
buzzvm_pushf(vm, status); buzzvm_pushi(vm, status);
buzzvm_tput(vm);
buzzvm_gstore(vm);
//also set rc_controllers goto
buzzvm_pushs(vm, buzzvm_string_register(vm, "rc_goto", 1));
buzzvm_pusht(vm);
buzzvm_dup(vm);
buzzvm_pushs(vm, buzzvm_string_register(vm, "latitude", 1));
buzzvm_pushf(vm, rc_goto_pos[0]);
buzzvm_tput(vm);
buzzvm_dup(vm);
buzzvm_pushs(vm, buzzvm_string_register(vm, "longitude", 1));
buzzvm_pushf(vm, rc_goto_pos[1]);
buzzvm_tput(vm);
buzzvm_dup(vm);
buzzvm_pushs(vm, buzzvm_string_register(vm, "altitude", 1));
buzzvm_pushf(vm, rc_goto_pos[2]);
buzzvm_tput(vm); buzzvm_tput(vm);
buzzvm_gstore(vm); buzzvm_gstore(vm);
return vm->state; return vm->state;
} }
/****************************************/ /****************************************/
/*To do !!!!!*/ /*To do !!!!!*/
/****************************************/ /****************************************/

View File

@ -92,6 +92,7 @@ namespace rosbzz_node{
flight_status_sub =n_c.subscribe("/mav/flight_status",100, &roscontroller::flight_status_update,this); flight_status_sub =n_c.subscribe("/mav/flight_status",100, &roscontroller::flight_status_update,this);
/*publishers*/ /*publishers*/
payload_pub = n_c.advertise<mavros_msgs::Mavlink>(out_payload, 1000); payload_pub = n_c.advertise<mavros_msgs::Mavlink>(out_payload, 1000);
cout<<out_payload<<endl;
/* Clients*/ /* Clients*/
mav_client = n_c.serviceClient<mavros_msgs::CommandInt>(fcclient_name); mav_client = n_c.serviceClient<mavros_msgs::CommandInt>(fcclient_name);
@ -122,15 +123,19 @@ namespace rosbzz_node{
} }
void roscontroller::prepare_msg_and_publish(){ void roscontroller::prepare_msg_and_publish(){
/* flight controller client call*/
if (bzz_old_cmd != buzzuav_closures::getcmd()) {
/*prepare the goto publish message */ /*prepare the goto publish message */
double* goto_pos = buzzuav_closures::getgoto(); double* goto_pos = buzzuav_closures::getgoto();
cmd_srv.request.param1 = goto_pos[0]; cmd_srv.request.param1 = goto_pos[0];
cmd_srv.request.param2 = goto_pos[1]; cmd_srv.request.param2 = goto_pos[1];
cmd_srv.request.param3 = goto_pos[2]; cmd_srv.request.param3 = goto_pos[2];
cmd_srv.request.command = buzzuav_closures::getcmd(); cmd_srv.request.command = buzzuav_closures::getcmd();
/* flight controller client call*/ if (mav_client.call(cmd_srv)){ROS_INFO("Reply: %ld", (long int)cmd_srv.response.success); }
if (mav_client.call(cmd_srv));//{ROS_INFO("Reply: %ld", (long int)cmd_srv.response.success); }
else ROS_ERROR("Failed to call service from flight controller"); else ROS_ERROR("Failed to call service from flight controller");
bzz_old_cmd = cmd_srv.request.command;
}
/*obtain Pay load to be sent*/ /*obtain Pay load to be sent*/
uint64_t* payload_out_ptr= buzz_utility::out_msg_process(); uint64_t* payload_out_ptr= buzz_utility::out_msg_process();
uint64_t position[3]; uint64_t position[3];
@ -276,12 +281,12 @@ namespace rosbzz_node{
res.success = true; res.success = true;
break; break;
case mavros_msgs::CommandCode::NAV_WAYPOINT: case mavros_msgs::CommandCode::NAV_WAYPOINT:
ROS_INFO("RC_Call: GO TO!!!! x = %f , y = %f , Z = %f",req.param1,req.param2,req.param3); ROS_INFO("RC_Call: GO TO!!!! ");
double rc_goto[3]; double rc_goto[3];
rc_goto[0]=req.param1; rc_goto[0]=req.x;
rc_goto[1]=req.param2; rc_goto[1]=req.y;
rc_goto[2]=req.param3; rc_goto[2]=req.z;
buzzuav_closures::set_goto(rc_goto); buzzuav_closures::rc_set_goto(rc_goto);
rc_cmd=mavros_msgs::CommandCode::NAV_WAYPOINT; rc_cmd=mavros_msgs::CommandCode::NAV_WAYPOINT;
buzzuav_closures::rc_call(rc_cmd); buzzuav_closures::rc_call(rc_cmd);
res.success = true; res.success = true;

View File

@ -1,6 +1,8 @@
# Executed once at init time. # Executed once at init time.
function init() { function init() {
i = 1 i = 1
a = 0
val = 0
} }
# Executed at each time step. # Executed at each time step.
@ -15,11 +17,19 @@ neighbors.listen("Take",
neighbors.listen("key", neighbors.listen("key",
function(vid, value, rid) { function(vid, value, rid) {
print("Got (", vid, ",", value, ") from robot #", rid) print("Got (", vid, ",", value, ") from robot #", rid)
val = value
} }
) )
print(val)
if ((val == 23) and (a == 0)) {
uav_takeoff()
a=1
}
if (a == 10) uav_land()
if (a != 0) a = a+1
} }
else{ else{
neighbors.broadcast("key", "yes") neighbors.broadcast("key", 23)
neighbors.broadcast("Take", "no") neighbors.broadcast("Take", "no")
} }