ROSBuzz_MISTLab/buzz_scripts/main.bzz

118 lines
2.7 KiB
Plaintext
Raw Normal View History

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"
include "taskallocate/graphformGPS.bzz"
2017-12-22 17:48:39 -04:00
include "vstigenv.bzz"
include "timesync.bzz"
2017-12-22 17:48:39 -04:00
2018-02-26 14:26:33 -04:00
#State launched after takeoff
AUTO_LAUNCH_STATE = "FORMATION"
#AUTO_LAUNCH_STATE = "CUSFUN"
2018-07-04 22:17:42 -03:00
#Lowest robot id in the network
LOWEST_ROBOT_ID = 97
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}
}
2018-07-04 22:17:42 -03:00
2017-12-22 17:48:39 -04:00
# Executed once at init time.
function init() {
init_stig()
init_swarm()
init_time_sync()
2018-07-04 22:17:42 -03:00
TARGET_ALTITUDE = 5 + (id-LOWEST_ROBOT_ID)*3.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
nei_cmd_listen()
2017-12-22 17:48:39 -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() {
# step time sync algorithm
step_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()
#
# State machine
2017-12-22 17:48:39 -04:00
#
if(BVMSTATE=="TURNEDOFF")
statef=turnedoff
2018-07-04 22:17:42 -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
else if(BVMSTATE=="LAUNCH") # ends on AUTO_LAUNCH_STATE
2017-12-22 17:48:39 -04:00
statef=launch
2018-07-04 22:17:42 -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
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")
statef=DoFree
2018-03-03 23:43:12 -04:00
else if(BVMSTATE=="GRAPH_ASKING")
statef=DoAsking
2018-03-03 23:43:12 -04:00
else if(BVMSTATE=="GRAPH_JOINING")
statef=DoJoining
2018-03-03 23:43:12 -04:00
else if(BVMSTATE=="GRAPH_JOINED")
statef=DoJoined
2018-03-03 23:43:12 -04:00
else if(BVMSTATE=="GRAPH_TRANSTOLOCK")
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
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
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() {
}