Merge commit 'e5e7500b20770df29d594a7d07d1cd8e9f6ee6f9' into sim

This commit is contained in:
dave 2018-10-03 21:25:36 -04:00
commit a20f70950b
4 changed files with 36 additions and 15 deletions

View File

@ -12,7 +12,7 @@ TARGET_ALTITUDE = 15.0 # m.
BVMSTATE = "TURNEDOFF" BVMSTATE = "TURNEDOFF"
PICTURE_WAIT = 20 # steps PICTURE_WAIT = 20 # steps
GOTO_MAXVEL = 0.85 # m/steps GOTO_MAXVEL = 1.5 # m/steps
GOTO_MAXDIST = 150 # m. GOTO_MAXDIST = 150 # m.
GOTODIST_TOL = 0.4 # m. GOTODIST_TOL = 0.4 # m.
GOTOANG_TOL = 0.1 # rad. GOTOANG_TOL = 0.1 # rad.
@ -35,7 +35,7 @@ function cusfun(){
log("cusfun: yay!!!") log("cusfun: yay!!!")
LOCAL_TARGET = math.vec2.new(5 ,0 ) LOCAL_TARGET = math.vec2.new(5 ,0 )
local_set_point = math.vec2.new(LOCAL_TARGET.x - pose.position.x ,LOCAL_TARGET.y - pose.position.y ) # has to move 5 meters in x from the home location local_set_point = math.vec2.new(LOCAL_TARGET.x - pose.position.x ,LOCAL_TARGET.y - pose.position.y ) # has to move 5 meters in x from the home location
if(math.vec2.length(local_set_point) > GOTODIST_TOL){ if(math.vec2.length(local_set_point) > GOTODIST_TOL){
local_set_point = LimitSpeed(local_set_point, 1.0) local_set_point = LimitSpeed(local_set_point, 1.0)
goto_abs(local_set_point.x, local_set_point.y, 0.0, 0.0) goto_abs(local_set_point.x, local_set_point.y, 0.0, 0.0)
} }
@ -77,7 +77,7 @@ function stop() {
if(V_TYPE == 0 or V_TYPE == 1) { # flying vehicle so LAND if(V_TYPE == 0 or V_TYPE == 1) { # flying vehicle so LAND
neighbors.broadcast("cmd", 21) neighbors.broadcast("cmd", 21)
uav_land() uav_land()
if(pose.position.altitude <= 0.3) { if(pose.position.altitude <= 0.2) {
BVMSTATE = "TURNEDOFF" BVMSTATE = "TURNEDOFF"
#barrier_set(ROBOTS,"TURNEDOFF","STOP", 21) #barrier_set(ROBOTS,"TURNEDOFF","STOP", 21)
#barrier_ready(21) #barrier_ready(21)
@ -105,7 +105,7 @@ function goto_gps(transf) {
m_navigation = vec_from_gps(rc_goto.latitude, rc_goto.longitude, 0) m_navigation = vec_from_gps(rc_goto.latitude, rc_goto.longitude, 0)
#print(" has to move ", math.vec2.length(m_navigation), math.vec2.angle(m_navigation)) #print(" has to move ", math.vec2.length(m_navigation), math.vec2.angle(m_navigation))
if(math.vec2.length(m_navigation)>GOTO_MAXDIST) if(math.vec2.length(m_navigation)>GOTO_MAXDIST)
log("Sorry this is too far.") log("Sorry this is too far (", math.vec2.length(m_navigation), " / ", GOTO_MAXDIST, " )")
else if(math.vec2.length(m_navigation) < GOTODIST_TOL and math.vec2.angle(m_navigation) < GOTOANG_TOL) # reached destination else if(math.vec2.length(m_navigation) < GOTODIST_TOL and math.vec2.angle(m_navigation) < GOTOANG_TOL) # reached destination
transf() transf()
else { else {

View File

@ -9,6 +9,7 @@ include "vstigenv.bzz"
include "utils/takeoff_heights.bzz" include "utils/takeoff_heights.bzz"
#State launched after takeoff #State launched after takeoff
AUTO_LAUNCH_STATE = "TASK_ALLOCATE" AUTO_LAUNCH_STATE = "TASK_ALLOCATE"
TARGET = 9.0 TARGET = 9.0
EPSILON = 30.0 EPSILON = 30.0
@ -32,11 +33,11 @@ goal_list = {
function init() { function init() {
init_stig() init_stig()
init_swarm() init_swarm()
# initGraph() # initGraph()
TARGET_ALTITUDE = takeoff_heights[id] TARGET_ALTITUDE = takeoff_heights[id]
# start the swarm command listener # start the swarm command listener
nei_cmd_listen() nei_cmd_listen()

View File

@ -98,6 +98,7 @@ private:
typedef struct POSE ros_pose; typedef struct POSE ros_pose;
ros_pose target, home, cur_pos; ros_pose target, home, cur_pos;
double* goto_pos;
struct MsgData struct MsgData
{ {
@ -141,6 +142,7 @@ private:
uint8_t old_val = 0; uint8_t old_val = 0;
bool debug = false; bool debug = false;
bool setmode = false; bool setmode = false;
bool BClpose = false;
std::string bzzfile_name; std::string bzzfile_name;
std::string bcfname, dbgfname; std::string bcfname, dbgfname;
std::string stand_by; std::string stand_by;

View File

@ -39,6 +39,7 @@ logical_clock(ros::Time()), previous_step_time(ros::Time())
cur_pos.longitude = 0; cur_pos.longitude = 0;
cur_pos.latitude = 0; cur_pos.latitude = 0;
cur_pos.altitude = 0; cur_pos.altitude = 0;
goto_pos = buzzuav_closures::getgoto();
// set stream rate - wait for the FC to be started // set stream rate - wait for the FC to be started
SetStreamRate(0, 10, 1); SetStreamRate(0, 10, 1);
@ -162,6 +163,9 @@ void roscontroller::RosControllerRun()
prepare_msg_and_publish(); prepare_msg_and_publish();
// Call the flight controler service // Call the flight controler service
flight_controller_service_call(); flight_controller_service_call();
// Broadcast local position to FCU
if(BClpose)
SetLocalPosition(goto_pos[0], goto_pos[1], goto_pos[2], goto_pos[3]);
// Set ROBOTS variable (swarm size) // Set ROBOTS variable (swarm size)
get_number_of_robots(); get_number_of_robots();
buzz_utility::set_robot_var(no_of_robots); buzz_utility::set_robot_var(no_of_robots);
@ -737,34 +741,40 @@ script
/-------------------------------------------------------------------------------*/ /-------------------------------------------------------------------------------*/
{ {
// flight controller client call if requested from Buzz // flight controller client call if requested from Buzz
double* goto_pos;
float* gimbal; float* gimbal;
switch (buzzuav_closures::bzz_cmd()) switch (buzzuav_closures::bzz_cmd())
{ {
case NAV_TAKEOFF: case NAV_TAKEOFF:
goto_pos = buzzuav_closures::getgoto(); goto_pos = buzzuav_closures::getgoto();
goto_pos[0] = 0.0;
goto_pos[1] = 0.0;
cmd_srv.request.param5 = cur_pos.latitude; cmd_srv.request.param5 = cur_pos.latitude;
cmd_srv.request.param6 = cur_pos.longitude; cmd_srv.request.param6 = cur_pos.longitude;
cmd_srv.request.param7 = goto_pos[2]; cmd_srv.request.param7 = goto_pos[2];
cmd_srv.request.command = buzzuav_closures::getcmd(); cmd_srv.request.command = buzzuav_closures::getcmd();
if (!armstate) if (!armstate)
{ {
if(setmode) if(setmode){
SetMode("LOITER", 0); SetMode("LOITER", 0);
ros::Duration(0.5).sleep();
}
armstate = 1; armstate = 1;
Arm(); Arm();
ros::Duration(0.5).sleep();
// Registering HOME POINT. // Registering HOME POINT.
home = cur_pos; home = cur_pos;
BClpose = true;
} }
if (current_mode != "GUIDED" && setmode) if (current_mode != "GUIDED" && setmode)
SetMode("GUIDED", 2000); // added for compatibility with 3DR Solo SetMode("GUIDED", 2000); // added for compatibility with 3DR Solo
if (mav_client.call(cmd_srv)) if(setmode)
{ {
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");
break; break;
case NAV_LAND: case NAV_LAND:
@ -778,10 +788,11 @@ script
armstate = 0; armstate = 0;
Arm(); Arm();
} }
else if(cur_pos.altitude < 0.3) //disarm only when close to ground else if(cur_pos.altitude < 0.4) //disarm only when close to ground
{ {
armstate = 0; armstate = 0;
Arm(); Arm();
BClpose = false;
} }
if (mav_client.call(cmd_srv)) if (mav_client.call(cmd_srv))
{ {
@ -829,7 +840,6 @@ script
case NAV_SPLINE_WAYPOINT: case NAV_SPLINE_WAYPOINT:
goto_pos = buzzuav_closures::getgoto(); goto_pos = buzzuav_closures::getgoto();
roscontroller::SetLocalPosition(goto_pos[0], goto_pos[1], goto_pos[2], goto_pos[3]);
break; break;
case DO_MOUNT_CONTROL: case DO_MOUNT_CONTROL:
@ -1005,6 +1015,14 @@ void roscontroller::local_pos_callback(const geometry_msgs::PoseStamped::ConstPt
cur_pos.x = msg->pose.position.x; cur_pos.x = msg->pose.position.x;
cur_pos.y = msg->pose.position.y; cur_pos.y = msg->pose.position.y;
if(!BClpose)
{
goto_pos[0]=cur_pos.x;
goto_pos[1]=cur_pos.y;
goto_pos[2]=0.0;
BClpose = true;
}
buzzuav_closures::set_currentNEDpos(msg->pose.position.y,msg->pose.position.x); buzzuav_closures::set_currentNEDpos(msg->pose.position.y,msg->pose.position.x);
// cur_pos.z = pose->pose.position.z; // Using relative altitude topic instead // cur_pos.z = pose->pose.position.z; // Using relative altitude topic instead
tf::Quaternion q( tf::Quaternion q(