adapted bzz files from sim.
This commit is contained in:
parent
392531e131
commit
1bfeada346
@ -7,10 +7,11 @@
|
|||||||
#
|
#
|
||||||
# Constants
|
# Constants
|
||||||
#
|
#
|
||||||
BARRIER_TIMEOUT = 1200 # in steps
|
BARRIER_TIMEOUT = 200 # in steps
|
||||||
BARRIER_VSTIG = 80
|
BARRIER_VSTIG = 80
|
||||||
timeW = 0
|
timeW = 0
|
||||||
barrier = nil
|
barrier = nil
|
||||||
|
bc = 0;
|
||||||
|
|
||||||
#
|
#
|
||||||
# Sets a barrier
|
# Sets a barrier
|
||||||
@ -22,15 +23,15 @@ function barrier_create() {
|
|||||||
#log("---> Prev. br. ", barrier, " ", BARRIER_VSTIG)
|
#log("---> Prev. br. ", barrier, " ", BARRIER_VSTIG)
|
||||||
if(barrier!=nil) {
|
if(barrier!=nil) {
|
||||||
barrier=nil
|
barrier=nil
|
||||||
BARRIER_VSTIG = BARRIER_VSTIG +1
|
# BARRIER_VSTIG = BARRIER_VSTIG +1
|
||||||
}
|
}
|
||||||
#log("---> New. br. ", barrier, " ", BARRIER_VSTIG)
|
#log("---> New. br. ", barrier, " ", BARRIER_VSTIG)
|
||||||
barrier = stigmergy.create(BARRIER_VSTIG)
|
barrier = stigmergy.create(BARRIER_VSTIG)
|
||||||
}
|
}
|
||||||
|
|
||||||
function barrier_set(threshold, transf, resumef) {
|
function barrier_set(threshold, transf, resumef, bc) {
|
||||||
statef = function() {
|
statef = function() {
|
||||||
barrier_wait(threshold, transf, resumef);
|
barrier_wait(threshold, transf, resumef, bc);
|
||||||
}
|
}
|
||||||
BVMSTATE = "BARRIERWAIT"
|
BVMSTATE = "BARRIERWAIT"
|
||||||
barrier_create()
|
barrier_create()
|
||||||
@ -39,21 +40,31 @@ function barrier_set(threshold, transf, resumef) {
|
|||||||
#
|
#
|
||||||
# Make yourself ready
|
# Make yourself ready
|
||||||
#
|
#
|
||||||
function barrier_ready() {
|
function barrier_ready(bc) {
|
||||||
#log("BARRIER READY -------")
|
#log("BARRIER READY -------")
|
||||||
barrier.put(id, 1)
|
barrier.put(id, bc)
|
||||||
barrier.put("d", 0)
|
barrier.put("d", 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
# Executes the barrier
|
# Executes the barrier
|
||||||
#
|
#
|
||||||
function barrier_wait(threshold, transf, resumef) {
|
function barrier_wait(threshold, transf, resumef, bc) {
|
||||||
barrier.put(id, 1)
|
barrier.put(id, bc)
|
||||||
|
|
||||||
barrier.get(id)
|
barrier.get(id)
|
||||||
#log("--->BS: ", barrier.size(), " (", BARRIER_VSTIG, ")")
|
var allgood = 0
|
||||||
|
log("--->BS: ", barrier.size(), " / ", threshold, " (", BARRIER_VSTIG, " - ", barrier.get("d"), ") t= ", timeW)
|
||||||
if(barrier.size() - 1 >= threshold or barrier.get("d") == 1) {
|
if(barrier.size() - 1 >= threshold or barrier.get("d") == 1) {
|
||||||
|
var bi = LOWEST_ROBOT_ID
|
||||||
|
allgood = 1
|
||||||
|
while (bi<LOWEST_ROBOT_ID+threshold) {
|
||||||
|
if(barrier.get(bi) != bc)
|
||||||
|
allgood = 0
|
||||||
|
bi = bi + 1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(allgood) {
|
||||||
barrier.put("d", 1)
|
barrier.put("d", 1)
|
||||||
timeW = 0
|
timeW = 0
|
||||||
BVMSTATE = transf
|
BVMSTATE = transf
|
||||||
@ -62,7 +73,8 @@ function barrier_wait(threshold, transf, resumef) {
|
|||||||
barrier = nil
|
barrier = nil
|
||||||
timeW = 0
|
timeW = 0
|
||||||
BVMSTATE = resumef
|
BVMSTATE = resumef
|
||||||
}
|
} else if(timeW % 10 == 0 and bc > 0)
|
||||||
|
neighbors.broadcast("cmd", bc)
|
||||||
|
|
||||||
timeW = timeW+1
|
timeW = timeW+1
|
||||||
}
|
}
|
||||||
|
@ -27,44 +27,60 @@ function idle() {
|
|||||||
BVMSTATE = "IDLE"
|
BVMSTATE = "IDLE"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Custom function for the user.
|
||||||
|
function cusfun(){
|
||||||
|
BVMSTATE="CUSFUN"
|
||||||
|
log("cusfun: yay!!!")
|
||||||
|
}
|
||||||
|
|
||||||
function launch() {
|
function launch() {
|
||||||
BVMSTATE = "LAUNCH"
|
BVMSTATE = "LAUNCH"
|
||||||
if(V_TYPE == 0 or V_TYPE == 1) { # flying vehicle so LAND
|
if(V_TYPE == 0 or V_TYPE == 1) { # flying vehicle so TAKE_OFF
|
||||||
homegps = {.lat=pose.position.latitude, .long=pose.position.longitude}
|
homegps = {.lat=pose.position.latitude, .long=pose.position.longitude}
|
||||||
if( flight.status == 2 and pose.position.altitude >= TARGET_ALTITUDE-TARGET_ALTITUDE/20.0) {
|
if( flight.status == 2 and pose.position.altitude >= TARGET_ALTITUDE-TARGET_ALTITUDE/20.0) {
|
||||||
barrier_set(ROBOTS, AUTO_LAUNCH_STATE, "LAUNCH")
|
barrier_set(ROBOTS, AUTO_LAUNCH_STATE, "STOP", 22)
|
||||||
barrier_ready()
|
barrier_ready(22)
|
||||||
} else {
|
} else {
|
||||||
log("Altitude: ", pose.position.altitude)
|
log("Altitude: ", pose.position.altitude)
|
||||||
neighbors.broadcast("cmd", 22)
|
neighbors.broadcast("cmd", 22)
|
||||||
uav_takeoff(TARGET_ALTITUDE)
|
uav_takeoff(TARGET_ALTITUDE)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
barrier_set(ROBOTS, AUTO_LAUNCH_STATE, "LAUNCH")
|
barrier_set(ROBOTS, AUTO_LAUNCH_STATE, "STOP", 22)
|
||||||
barrier_ready()
|
barrier_ready(22)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gohomeT=100
|
||||||
|
function goinghome() {
|
||||||
|
BVMSTATE = "GOHOME"
|
||||||
|
if(gohomeT > 0) { # TODO: Make a real check if home is reached
|
||||||
|
gohome()
|
||||||
|
gohomeT = gohomeT - 1
|
||||||
|
} else
|
||||||
|
BVMSTATE = AUTO_LAUNCH_STATE
|
||||||
|
}
|
||||||
|
|
||||||
function stop() {
|
function stop() {
|
||||||
BVMSTATE = "STOP"
|
BVMSTATE = "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(flight.status != 2 and flight.status != 3) {
|
if(flight.status != 2 and flight.status != 3) {
|
||||||
barrier_set(ROBOTS,"TURNEDOFF","STOP")
|
barrier_set(ROBOTS,"TURNEDOFF","STOP", 21)
|
||||||
barrier_ready()
|
barrier_ready(21)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
barrier_set(ROBOTS,"TURNEDOFF","STOP")
|
barrier_set(ROBOTS,"TURNEDOFF","STOP", 21)
|
||||||
barrier_ready()
|
barrier_ready(21)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function take_picture() {
|
function take_picture() {
|
||||||
BVMSTATE="PICTURE"
|
BVMSTATE="PICTURE"
|
||||||
uav_setgimbal(0.0, 0.0, -90.0, 20.0)
|
setgimbal(0.0, 0.0, -90.0, 20.0)
|
||||||
if(pic_time==PICTURE_WAIT/2) { # wait for the drone to stabilize
|
if(pic_time==PICTURE_WAIT/2) { # wait for the drone to stabilize
|
||||||
uav_takepicture()
|
takepicture()
|
||||||
} else if(pic_time>=PICTURE_WAIT) { # wait for the picture
|
} else if(pic_time>=PICTURE_WAIT) { # wait for the picture
|
||||||
BVMSTATE="IDLE"
|
BVMSTATE="IDLE"
|
||||||
pic_time=0
|
pic_time=0
|
||||||
@ -117,7 +133,7 @@ function aggregate() {
|
|||||||
# circle all together around centroid
|
# circle all together around centroid
|
||||||
function pursuit() {
|
function pursuit() {
|
||||||
BVMSTATE="PURSUIT"
|
BVMSTATE="PURSUIT"
|
||||||
rd = 15.0
|
rd = 20.0
|
||||||
pc = 3.2
|
pc = 3.2
|
||||||
vd = 15.0
|
vd = 15.0
|
||||||
r_vec = neighbors.reduce(function(rid, data, r_vec) {
|
r_vec = neighbors.reduce(function(rid, data, r_vec) {
|
||||||
@ -127,8 +143,7 @@ function pursuit() {
|
|||||||
if(neighbors.count() > 0)
|
if(neighbors.count() > 0)
|
||||||
r_vec = math.vec2.scale(r_vec, 1.0 / neighbors.count())
|
r_vec = math.vec2.scale(r_vec, 1.0 / neighbors.count())
|
||||||
r = math.vec2.length(r_vec)
|
r = math.vec2.length(r_vec)
|
||||||
sqr = (r-rd)*(r-rd)+pc*pc*r*r
|
gamma = vd / math.sqrt((r-rd)*(r-rd)+pc*pc*r*r)
|
||||||
gamma = vd / math.sqrt(sqr)
|
|
||||||
dr = -gamma * (r-rd)
|
dr = -gamma * (r-rd)
|
||||||
dT = gamma * pc
|
dT = gamma * pc
|
||||||
vfg = math.vec2.newp(r+dr*0.1, math.vec2.angle(r_vec)+dT*0.1)
|
vfg = math.vec2.newp(r+dr*0.1, math.vec2.angle(r_vec)+dT*0.1)
|
||||||
@ -138,9 +153,9 @@ function pursuit() {
|
|||||||
|
|
||||||
# Lennard-Jones interaction magnitude
|
# Lennard-Jones interaction magnitude
|
||||||
TARGET = 8.0
|
TARGET = 8.0
|
||||||
EPSILON = 3.0
|
EPSILON = 30.0
|
||||||
function lj_magnitude(dist, target, epsilon) {
|
function lj_magnitude(dist, target, epsilon) {
|
||||||
lj = -(epsilon / dist) * ((target / dist)^4 - 1.2 * (target / dist)^2)
|
lj = -(epsilon / dist) * ((target / dist)^4 - (target / dist)^2)
|
||||||
return lj
|
return lj
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,17 +170,17 @@ function lj_sum(rid, data, accum) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Calculates and actuates the flocking interaction
|
# Calculates and actuates the flocking interaction
|
||||||
old_lj = math.vec2.newp(0.0, 0.0) # 1-step filter, to smoothen dir. changes
|
|
||||||
function formation() {
|
function formation() {
|
||||||
BVMSTATE="FORMATION"
|
BVMSTATE="FORMATION"
|
||||||
# Calculate accumulator
|
# Calculate accumulator
|
||||||
accum_lj = neighbors.map(lj_vector).reduce(lj_sum, math.vec2.new(0.0, 0.0))
|
accum_lj = neighbors.map(lj_vector).reduce(lj_sum, math.vec2.new(0.0, 0.0))
|
||||||
if(neighbors.count() > 0)
|
if(neighbors.count() > 0)
|
||||||
accum_lj = math.vec2.scale(accum_lj, 1.0 / neighbors.count())
|
accum_lj = math.vec2.scale(accum_lj, 1.0 / neighbors.count())
|
||||||
old_lj = LimitSpeed(math.vec2.add(old_lj, accum_lj), 1.0/4.0)
|
accum_lj = LimitSpeed(accum_lj, 1.0/3.0)
|
||||||
goto_abs(old_lj.x, old_lj.y, 0.0, 0.0)
|
goto_abs(accum_lj.x, accum_lj.y, 0.0, 0.0)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# listens to commands from the remote control (web, commandline, etc)
|
||||||
function rc_cmd_listen() {
|
function rc_cmd_listen() {
|
||||||
if(flight.rc_cmd==22) {
|
if(flight.rc_cmd==22) {
|
||||||
log("cmd 22")
|
log("cmd 22")
|
||||||
@ -173,74 +188,101 @@ function rc_cmd_listen() {
|
|||||||
BVMSTATE = "LAUNCH"
|
BVMSTATE = "LAUNCH"
|
||||||
neighbors.broadcast("cmd", 22)
|
neighbors.broadcast("cmd", 22)
|
||||||
} else if(flight.rc_cmd==21) {
|
} else if(flight.rc_cmd==21) {
|
||||||
log("cmd 21")
|
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
|
AUTO_LAUNCH_STATE = "TURNEDOFF"
|
||||||
|
barrier_set(ROBOTS, "GOHOME", BVMSTATE, 21)
|
||||||
|
barrier_ready(21)
|
||||||
BVMSTATE = "STOP"
|
BVMSTATE = "STOP"
|
||||||
neighbors.broadcast("cmd", 21)
|
neighbors.broadcast("cmd", 21)
|
||||||
|
} else if(flight.rc_cmd==20) {
|
||||||
|
flight.rc_cmd=0
|
||||||
|
AUTO_LAUNCH_STATE = "IDLE"
|
||||||
|
barrier_set(ROBOTS, "GOHOME", BVMSTATE, 20)
|
||||||
|
barrier_ready(20)
|
||||||
|
neighbors.broadcast("cmd", 20)
|
||||||
} else if(flight.rc_cmd==16) {
|
} else if(flight.rc_cmd==16) {
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
BVMSTATE = "PATHPLAN"
|
BVMSTATE = "PATHPLAN"
|
||||||
} else if(flight.rc_cmd==400) {
|
} else if(flight.rc_cmd==400) {
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
uav_arm()
|
arm()
|
||||||
neighbors.broadcast("cmd", 400)
|
neighbors.broadcast("cmd", 400)
|
||||||
} else if (flight.rc_cmd==401){
|
} else if (flight.rc_cmd==401){
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
uav_disarm()
|
disarm()
|
||||||
neighbors.broadcast("cmd", 401)
|
neighbors.broadcast("cmd", 401)
|
||||||
} else if (flight.rc_cmd==666){
|
} else if (flight.rc_cmd==666){
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
stattab_send()
|
stattab_send()
|
||||||
} else if (flight.rc_cmd==900){
|
} else if (flight.rc_cmd==900){
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
BVMSTATE = "TASK_ALLOCATE"
|
barrier_set(ROBOTS, "TASK_ALLOCATE", BVMSTATE, 900)
|
||||||
|
barrier_ready(900)
|
||||||
neighbors.broadcast("cmd", 900)
|
neighbors.broadcast("cmd", 900)
|
||||||
} else if (flight.rc_cmd==901){
|
} else if (flight.rc_cmd==901){
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
destroyGraph()
|
destroyGraph()
|
||||||
BVMSTATE = "PURSUIT"
|
barrier_set(ROBOTS, "PURSUIT", BVMSTATE, 901)
|
||||||
|
barrier_ready(901)
|
||||||
neighbors.broadcast("cmd", 901)
|
neighbors.broadcast("cmd", 901)
|
||||||
} else if (flight.rc_cmd==902){
|
} else if (flight.rc_cmd==902){
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
destroyGraph()
|
destroyGraph()
|
||||||
BVMSTATE = "AGGREGATE"
|
barrier_set(ROBOTS, "AGGREGATE", BVMSTATE, 902)
|
||||||
|
barrier_ready(902)
|
||||||
neighbors.broadcast("cmd", 902)
|
neighbors.broadcast("cmd", 902)
|
||||||
} else if (flight.rc_cmd==903){
|
} else if (flight.rc_cmd==903){
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
destroyGraph()
|
destroyGraph()
|
||||||
BVMSTATE = "FORMATION"
|
barrier_set(ROBOTS, "FORMATION", BVMSTATE, 903)
|
||||||
|
barrier_ready(903)
|
||||||
neighbors.broadcast("cmd", 903)
|
neighbors.broadcast("cmd", 903)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# listens to other fleet members broadcasting commands
|
||||||
function nei_cmd_listen() {
|
function nei_cmd_listen() {
|
||||||
neighbors.listen("cmd",
|
neighbors.listen("cmd",
|
||||||
function(vid, value, rid) {
|
function(vid, value, rid) {
|
||||||
print("Got (", vid, ",", value, ") #", rid, "(", BVMSTATE, ")")
|
print("Got (", vid, ",", value, ") #", rid, "(", BVMSTATE, ")")
|
||||||
if(value==22 and BVMSTATE!="BARRIERWAIT") {
|
if(BVMSTATE!="BARRIERWAIT") {
|
||||||
|
if(value==22) {
|
||||||
BVMSTATE = "LAUNCH"
|
BVMSTATE = "LAUNCH"
|
||||||
} else if(value==21 and BVMSTATE!="BARRIERWAIT") {
|
}else if(value==20) {
|
||||||
|
AUTO_LAUNCH_STATE = "IDLE"
|
||||||
|
BVMSTATE = "GOHOME"
|
||||||
|
} else if(value==21) {
|
||||||
|
AUTO_LAUNCH_STATE = "TURNEDOFF"
|
||||||
BVMSTATE = "STOP"
|
BVMSTATE = "STOP"
|
||||||
} else if(value==400 and BVMSTATE=="TURNEDOFF") {
|
} else if(value==400 and BVMSTATE=="TURNEDOFF") {
|
||||||
uav_arm()
|
arm()
|
||||||
} else if(value==401 and BVMSTATE=="TURNEDOFF"){
|
} else if(value==401 and BVMSTATE=="TURNEDOFF"){
|
||||||
uav_disarm()
|
disarm()
|
||||||
} else if(value==900){ # Shapes
|
} else if(value==900){ # Shapes
|
||||||
BVMSTATE = "TASK_ALLOCATE"
|
barrier_set(ROBOTS, "TASK_ALLOCATE", BVMSTATE, 900)
|
||||||
|
#barrier_ready(900)
|
||||||
|
neighbors.broadcast("cmd", 900)
|
||||||
} else if(value==901){ # Pursuit
|
} else if(value==901){ # Pursuit
|
||||||
destroyGraph()
|
destroyGraph()
|
||||||
BVMSTATE = "PURSUIT"
|
barrier_set(ROBOTS, "PURSUIT", BVMSTATE, 901)
|
||||||
|
#barrier_ready(901)
|
||||||
|
neighbors.broadcast("cmd", 901)
|
||||||
} else if(value==902){ # Agreggate
|
} else if(value==902){ # Agreggate
|
||||||
destroyGraph()
|
destroyGraph()
|
||||||
BVMSTATE = "AGGREGATE"
|
barrier_set(ROBOTS, "AGGREGATE", BVMSTATE, 902)
|
||||||
|
#barrier_ready(902)
|
||||||
|
neighbors.broadcast("cmd", 902)
|
||||||
} else if(value==903){ # Formation
|
} else if(value==903){ # Formation
|
||||||
destroyGraph()
|
destroyGraph()
|
||||||
BVMSTATE = "FORMATION"
|
barrier_set(ROBOTS, "FORMATION", BVMSTATE, 903)
|
||||||
|
#barrier_ready(903)
|
||||||
|
neighbors.broadcast("cmd", 903)
|
||||||
} else if(value==16 and BVMSTATE=="IDLE"){
|
} else if(value==16 and BVMSTATE=="IDLE"){
|
||||||
# neighbors.listen("gt",function(vid, value, rid) {
|
# neighbors.listen("gt",function(vid, value, rid) {
|
||||||
# print("Got (", vid, ",", value, ") from robot #", rid)
|
# print("Got (", vid, ",", value, ") from robot #", rid)
|
||||||
# # if(gt.id == id) statef=goto
|
# # if(gt.id == id) statef=goto
|
||||||
# })
|
# })
|
||||||
}
|
}
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,7 @@ mapgoal = {}
|
|||||||
function navigate() {
|
function navigate() {
|
||||||
BVMSTATE="NAVIGATE"
|
BVMSTATE="NAVIGATE"
|
||||||
if(V_TYPE == 0) { # TODO: place these in a generic function in conversion.bzz
|
if(V_TYPE == 0) { # TODO: place these in a generic function in conversion.bzz
|
||||||
uav_storegoal(goal_list[g_it].x, goal_list[g_it].y, pose.position.altitude)
|
storegoal(goal_list[g_it].x, goal_list[g_it].y, pose.position.altitude)
|
||||||
cur_goal = vec_from_gps(rc_goto.latitude, rc_goto.longitude, 0)
|
cur_goal = vec_from_gps(rc_goto.latitude, rc_goto.longitude, 0)
|
||||||
m_pos = math.vec2.scale(vec_from_gps(homegps.lat, homegps.long, 0),-1)
|
m_pos = math.vec2.scale(vec_from_gps(homegps.lat, homegps.long, 0),-1)
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
####################################################################################################
|
####################################################################################################
|
||||||
updated="update_ack"
|
updated="update_ack"
|
||||||
update_no=0
|
update_no=0
|
||||||
function updated_neigh(){
|
updates_active = 1
|
||||||
|
function updated_no_bct(){
|
||||||
neighbors.broadcast(updated, update_no)
|
neighbors.broadcast(updated, update_no)
|
||||||
}
|
}
|
@ -7,7 +7,11 @@ include "taskallocate/graphformGPS.bzz"
|
|||||||
include "vstigenv.bzz"
|
include "vstigenv.bzz"
|
||||||
|
|
||||||
#State launched after takeoff
|
#State launched after takeoff
|
||||||
AUTO_LAUNCH_STATE = "PURSUIT"
|
AUTO_LAUNCH_STATE = "CUSFUN"
|
||||||
|
#Lowest robot id in the network
|
||||||
|
LOWEST_ROBOT_ID = 97
|
||||||
|
TARGET = 9.0
|
||||||
|
EPSILON = 30.0
|
||||||
|
|
||||||
#####
|
#####
|
||||||
# Vehicule type:
|
# Vehicule type:
|
||||||
@ -21,12 +25,13 @@ goal_list = {
|
|||||||
.0={.x = 45.5088103899, .y = -73.1540826153, .z = 2.5}
|
.0={.x = 45.5088103899, .y = -73.1540826153, .z = 2.5}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
# Executed once at init time.
|
# Executed once at init time.
|
||||||
function init() {
|
function init() {
|
||||||
init_stig()
|
init_stig()
|
||||||
init_swarm()
|
init_swarm()
|
||||||
|
|
||||||
TARGET_ALTITUDE = 10 + id*2.0 # m
|
TARGET_ALTITUDE = 5 + (id-LOWEST_ROBOT_ID)*3.0 # m
|
||||||
loop = 1
|
loop = 1
|
||||||
|
|
||||||
# start the swarm command listener
|
# start the swarm command listener
|
||||||
@ -49,10 +54,14 @@ function step() {
|
|||||||
#
|
#
|
||||||
if(BVMSTATE=="TURNEDOFF")
|
if(BVMSTATE=="TURNEDOFF")
|
||||||
statef=turnedoff
|
statef=turnedoff
|
||||||
|
else if(BVMSTATE=="CUSFUN")
|
||||||
|
statef=cusfun
|
||||||
else if(BVMSTATE=="STOP") # ends on turnedoff
|
else if(BVMSTATE=="STOP") # ends on turnedoff
|
||||||
statef=stop
|
statef=stop
|
||||||
else if(BVMSTATE=="LAUNCH") # ends on AUTO_LAUNCH_STATE
|
else if(BVMSTATE=="LAUNCH") # ends on AUTO_LAUNCH_STATE
|
||||||
statef=launch
|
statef=launch
|
||||||
|
else if(BVMSTATE=="GOHOME") # ends on AUTO_LAUNCH_STATE
|
||||||
|
statef=goinghome
|
||||||
else if(BVMSTATE=="IDLE")
|
else if(BVMSTATE=="IDLE")
|
||||||
statef=idle
|
statef=idle
|
||||||
else if(BVMSTATE=="AGGREGATE")
|
else if(BVMSTATE=="AGGREGATE")
|
||||||
|
@ -51,7 +51,6 @@ function step() {
|
|||||||
statef=action
|
statef=action
|
||||||
|
|
||||||
statef()
|
statef()
|
||||||
|
|
||||||
log("Current state: ", BVMSTATE)
|
log("Current state: ", BVMSTATE)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,11 @@
|
|||||||
|
include "act/states.bzz"
|
||||||
|
include "vstigenv.bzz"
|
||||||
|
|
||||||
updated="update_ack"
|
updated="update_ack"
|
||||||
update_no=0
|
update_no=0
|
||||||
|
BVMSTATE = "UPDATESTANDBY"
|
||||||
|
|
||||||
|
# Executed once at init time.
|
||||||
function init(){
|
function init(){
|
||||||
barrier = stigmergy.create(101)
|
barrier = stigmergy.create(101)
|
||||||
barrier.put(id,1)
|
barrier.put(id,1)
|
||||||
@ -8,28 +14,25 @@ barrier.onconflict(function (k,l,r) {
|
|||||||
if(r. data < l. data or (r. data == l. data )) return l
|
if(r. data < l. data or (r. data == l. data )) return l
|
||||||
else return r
|
else return r
|
||||||
})
|
})
|
||||||
|
init_swarm()
|
||||||
s = swarm.create(1)
|
# start the swarm command listener
|
||||||
s.join()
|
nei_cmd_listen()
|
||||||
}
|
}
|
||||||
|
|
||||||
function stand_by(){
|
function stand_by(){
|
||||||
|
|
||||||
barrier.get(id)
|
barrier.get(id)
|
||||||
barrier_val = barrier.size()
|
barrier_val = barrier.size()
|
||||||
|
|
||||||
neighbors.listen(updated,
|
neighbors.listen(updated,
|
||||||
function(vid, value, rid) {
|
function(vid, value, rid) {
|
||||||
print(" got from",vid," ", " value = ",value," ","rid"," " )
|
|
||||||
if(value==update_no) barrier.put(rid,1)
|
if(value==update_no) barrier.put(rid,1)
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Executed at each time step.
|
||||||
function step() {
|
function step() {
|
||||||
|
|
||||||
stand_by()
|
stand_by()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
72
buzz_scripts/testLJ.bzz
Executable file
72
buzz_scripts/testLJ.bzz
Executable file
@ -0,0 +1,72 @@
|
|||||||
|
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"
|
||||||
|
include "vstigenv.bzz"
|
||||||
|
|
||||||
|
V_TYPE = 0
|
||||||
|
|
||||||
|
#State launched after takeoff
|
||||||
|
AUTO_LAUNCH_STATE = "FORMATION"
|
||||||
|
|
||||||
|
|
||||||
|
TARGET = 8.0
|
||||||
|
EPSILON = 3.0
|
||||||
|
GOTO_MAXVEL = 2.5 # m/steps
|
||||||
|
|
||||||
|
# Executed once at init time.
|
||||||
|
function init() {
|
||||||
|
init_stig()
|
||||||
|
init_swarm()
|
||||||
|
|
||||||
|
# start the swarm command listener
|
||||||
|
nei_cmd_listen()
|
||||||
|
|
||||||
|
# Starting state: TURNEDOFF to wait for user input.
|
||||||
|
BVMSTATE = "TURNEDOFF"
|
||||||
|
TAKEOFF_COUNTER = 20
|
||||||
|
}
|
||||||
|
|
||||||
|
# Executed at each time step.
|
||||||
|
function step() {
|
||||||
|
rc_cmd_listen()
|
||||||
|
|
||||||
|
# update the vstig (status/net/batt/...)
|
||||||
|
# uav_updatestig()
|
||||||
|
|
||||||
|
#
|
||||||
|
# State machine
|
||||||
|
#
|
||||||
|
if(BVMSTATE=="TURNEDOFF")
|
||||||
|
statef=turnedoff
|
||||||
|
else if(BVMSTATE=="STOP") # ends on turnedoff
|
||||||
|
statef=stop
|
||||||
|
else if(BVMSTATE=="LAUNCH") # ends on AUTO_LAUNCH_STATE
|
||||||
|
statef=launch
|
||||||
|
else if(BVMSTATE=="IDLE")
|
||||||
|
statef=idle
|
||||||
|
else if(BVMSTATE=="FORMATION")
|
||||||
|
statef=formation
|
||||||
|
|
||||||
|
statef()
|
||||||
|
|
||||||
|
log("Current state: ", BVMSTATE)
|
||||||
|
|
||||||
|
# Auto-takeoff (delayed for simulator boot)
|
||||||
|
if(id == 0) {
|
||||||
|
if(TAKEOFF_COUNTER>0)
|
||||||
|
TAKEOFF_COUNTER = TAKEOFF_COUNTER - 1
|
||||||
|
else if(TAKEOFF_COUNTER == 0) {
|
||||||
|
BVMSTATE="LAUNCH"
|
||||||
|
TAKEOFF_COUNTER = -1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Executed once when the robot (or the simulator) is reset.
|
||||||
|
function reset() {
|
||||||
|
}
|
||||||
|
|
||||||
|
# Executed once at the end of experiment.
|
||||||
|
function destroy() {
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user