2017-12-22 17:48:39 -04:00
|
|
|
include "update.bzz"
|
|
|
|
# don't use a stigmergy id=11 with this header, for barrier
|
|
|
|
# it requires an 'action' function to be defined here.
|
|
|
|
include "act/states.bzz"
|
2018-02-26 14:26:33 -04:00
|
|
|
include "plan/rrtstar.bzz"
|
2018-03-02 16:35:06 -04:00
|
|
|
include "taskallocate/graphformGPS.bzz"
|
2017-12-22 17:48:39 -04:00
|
|
|
include "vstigenv.bzz"
|
2018-09-06 13:47:38 -03:00
|
|
|
include "timesync.bzz"
|
2017-12-22 17:48:39 -04:00
|
|
|
|
2018-02-26 14:26:33 -04:00
|
|
|
#State launched after takeoff
|
2018-09-06 13:47:38 -03:00
|
|
|
AUTO_LAUNCH_STATE = "TASK_ALLOCATE"
|
|
|
|
#AUTO_LAUNCH_STATE = "CUSFUN"
|
|
|
|
#Lowest robot id in the network
|
|
|
|
LOWEST_ROBOT_ID = 1
|
|
|
|
TARGET = 9.0
|
|
|
|
EPSILON = 30.0
|
2018-02-26 14:26:33 -04:00
|
|
|
|
2017-12-22 17:48:39 -04:00
|
|
|
#####
|
|
|
|
# Vehicule type:
|
|
|
|
# 0 -> outdoor flying vehicle
|
|
|
|
# 1 -> indoor flying vehicle
|
|
|
|
# 2 -> outdoor wheeled vehicle
|
|
|
|
# 3 -> indoor wheeled vehicle
|
|
|
|
V_TYPE = 0
|
|
|
|
|
|
|
|
goal_list = {
|
|
|
|
.0={.x = 45.5088103899, .y = -73.1540826153, .z = 2.5}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Executed once at init time.
|
|
|
|
function init() {
|
|
|
|
init_stig()
|
|
|
|
init_swarm()
|
|
|
|
|
2018-09-06 13:47:38 -03:00
|
|
|
# initGraph()
|
|
|
|
|
|
|
|
TARGET_ALTITUDE = 5 + (id-LOWEST_ROBOT_ID)*4.0 # m
|
|
|
|
|
2018-03-03 23:43:12 -04:00
|
|
|
loop = 1
|
2017-12-22 17:48:39 -04:00
|
|
|
|
|
|
|
# start the swarm command listener
|
2018-03-02 16:35:06 -04:00
|
|
|
nei_cmd_listen()
|
2017-12-22 17:48:39 -04:00
|
|
|
|
2018-03-02 16:35:06 -04:00
|
|
|
# Starting state: TURNEDOFF to wait for user input.
|
|
|
|
BVMSTATE = "TURNEDOFF"
|
2017-12-22 17:48:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
# Executed at each time step.
|
|
|
|
function step() {
|
2018-09-06 13:47:38 -03:00
|
|
|
|
|
|
|
# check time sync algorithm state
|
|
|
|
check_time_sync()
|
|
|
|
|
2017-12-22 17:48:39 -04:00
|
|
|
# listen to Remote Controller
|
|
|
|
rc_cmd_listen()
|
|
|
|
|
|
|
|
# update the vstig (status/net/batt/...)
|
|
|
|
# uav_updatestig()
|
|
|
|
|
|
|
|
#
|
2018-03-02 16:35:06 -04:00
|
|
|
# State machine
|
2017-12-22 17:48:39 -04:00
|
|
|
#
|
|
|
|
if(BVMSTATE=="TURNEDOFF")
|
|
|
|
statef=turnedoff
|
2018-09-06 13:47:38 -03:00
|
|
|
else if(BVMSTATE=="CUSFUN")
|
|
|
|
statef=cusfun
|
2017-12-22 17:48:39 -04:00
|
|
|
else if(BVMSTATE=="STOP") # ends on turnedoff
|
|
|
|
statef=stop
|
2018-03-02 16:35:06 -04:00
|
|
|
else if(BVMSTATE=="LAUNCH") # ends on AUTO_LAUNCH_STATE
|
2017-12-22 17:48:39 -04:00
|
|
|
statef=launch
|
2018-09-06 13:47:38 -03:00
|
|
|
else if(BVMSTATE=="GOHOME") # ends on AUTO_LAUNCH_STATE
|
|
|
|
statef=goinghome
|
2017-12-22 17:48:39 -04:00
|
|
|
else if(BVMSTATE=="IDLE")
|
|
|
|
statef=idle
|
2018-03-03 20:41:54 -04:00
|
|
|
else if(BVMSTATE=="AGGREGATE")
|
|
|
|
statef=aggregate
|
|
|
|
else if(BVMSTATE=="FORMATION")
|
|
|
|
statef=formation
|
|
|
|
else if(BVMSTATE=="PURSUIT")
|
|
|
|
statef=pursuit
|
2018-03-03 23:43:12 -04:00
|
|
|
else if(BVMSTATE=="TASK_ALLOCATE") # or bidding ?
|
|
|
|
statef=resetGraph
|
|
|
|
else if(BVMSTATE=="GRAPH_FREE")
|
2018-03-02 16:35:06 -04:00
|
|
|
statef=DoFree
|
2018-03-03 23:43:12 -04:00
|
|
|
else if(BVMSTATE=="GRAPH_ASKING")
|
2018-03-02 16:35:06 -04:00
|
|
|
statef=DoAsking
|
2018-03-03 23:43:12 -04:00
|
|
|
else if(BVMSTATE=="GRAPH_JOINING")
|
2018-03-02 16:35:06 -04:00
|
|
|
statef=DoJoining
|
2018-03-03 23:43:12 -04:00
|
|
|
else if(BVMSTATE=="GRAPH_JOINED")
|
2018-03-02 16:35:06 -04:00
|
|
|
statef=DoJoined
|
2018-03-03 23:43:12 -04:00
|
|
|
else if(BVMSTATE=="GRAPH_TRANSTOLOCK")
|
2018-03-02 16:35:06 -04:00
|
|
|
statef=TransitionToLock
|
2018-03-03 23:43:12 -04:00
|
|
|
else if(BVMSTATE=="GRAPH_LOCK") # move all together (TODO: not tested), but auto-loop in graph list
|
2018-03-02 16:35:06 -04:00
|
|
|
statef=DoLock
|
2018-02-26 14:26:33 -04:00
|
|
|
else if(BVMSTATE=="PATHPLAN") # ends on navigate, defined in rrtstar
|
2017-12-22 17:48:39 -04:00
|
|
|
statef=rrtstar
|
2018-02-26 14:26:33 -04:00
|
|
|
else if(BVMSTATE=="NAVIGATE") # ends on idle, defined in rrtstar
|
2017-12-22 17:48:39 -04:00
|
|
|
statef=navigate
|
|
|
|
else if(BVMSTATE == "FOLLOW") #TODO: not tested in new structure
|
|
|
|
statef=follow
|
|
|
|
else if(BVMSTATE == "PICTURE") #TODO: not tested in new structure
|
|
|
|
statef=take_picture
|
2018-03-02 16:35:06 -04:00
|
|
|
|
2017-12-22 17:48:39 -04:00
|
|
|
|
|
|
|
statef()
|
|
|
|
|
|
|
|
log("Current state: ", BVMSTATE)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
# Executed once when the robot (or the simulator) is reset.
|
|
|
|
function reset() {
|
|
|
|
}
|
|
|
|
|
|
|
|
# Executed once at the end of experiment.
|
|
|
|
function destroy() {
|
|
|
|
}
|