2017-01-28 04:15:52 -04:00
|
|
|
|
2017-01-25 15:08:15 -04:00
|
|
|
# We need this for 2D vectors
|
|
|
|
# Make sure you pass the correct include path to "bzzc -I <path1:path2> ..."
|
2017-02-17 21:03:09 -04:00
|
|
|
include "/home/ubuntu/buzz/src/include/vec2.bzz"
|
2017-01-27 09:10:27 -04:00
|
|
|
####################################################################################################
|
|
|
|
# Updater related
|
|
|
|
# This should be here for the updater to work, changing position of code will crash the updater
|
|
|
|
####################################################################################################
|
|
|
|
updated="update_ack"
|
2017-01-27 13:21:09 -04:00
|
|
|
update_no=0
|
2017-01-27 09:10:27 -04:00
|
|
|
function updated_neigh(){
|
|
|
|
neighbors.broadcast(updated, update_no)
|
|
|
|
}
|
2017-01-25 22:10:07 -04:00
|
|
|
|
2017-02-19 19:06:01 -04:00
|
|
|
TARGET_ALTITUDE = 2.0
|
2017-01-25 15:08:15 -04:00
|
|
|
|
|
|
|
# Lennard-Jones parameters
|
2017-02-19 19:15:57 -04:00
|
|
|
TARGET = 10.0 #0.000001001
|
|
|
|
EPSILON = 0.05 #0.001
|
2017-01-25 15:08:15 -04:00
|
|
|
|
|
|
|
# Lennard-Jones interaction magnitude
|
|
|
|
function lj_magnitude(dist, target, epsilon) {
|
|
|
|
return -(epsilon / dist) * ((target / dist)^4 - (target / dist)^2)
|
|
|
|
}
|
|
|
|
|
|
|
|
# Neighbor data to LJ interaction vector
|
|
|
|
function lj_vector(rid, data) {
|
|
|
|
return math.vec2.newp(lj_magnitude(data.distance, TARGET, EPSILON), data.azimuth)
|
|
|
|
}
|
|
|
|
|
|
|
|
# Accumulator of neighbor LJ interactions
|
|
|
|
function lj_sum(rid, data, accum) {
|
|
|
|
return math.vec2.add(data, accum)
|
|
|
|
}
|
|
|
|
|
|
|
|
# Calculates and actuates the flocking interaction
|
|
|
|
function hexagon() {
|
|
|
|
statef=hexagon
|
|
|
|
# Calculate accumulator
|
|
|
|
var accum = neighbors.map(lj_vector).reduce(lj_sum, math.vec2.new(0.0, 0.0))
|
|
|
|
if(neighbors.count() > 0)
|
|
|
|
math.vec2.scale(accum, 1.0 / neighbors.count())
|
|
|
|
# Move according to vector
|
2017-02-19 19:06:01 -04:00
|
|
|
print("Robot ", id, "must push ",accum.length, "; ", accum.angle)
|
|
|
|
uav_moveto(accum.x, accum.y)
|
2017-01-25 15:08:15 -04:00
|
|
|
}
|
|
|
|
|
2016-12-23 15:21:52 -04:00
|
|
|
########################################
|
|
|
|
#
|
|
|
|
# BARRIER-RELATED FUNCTIONS
|
|
|
|
#
|
|
|
|
########################################
|
|
|
|
|
|
|
|
#
|
|
|
|
# Constants
|
|
|
|
#
|
|
|
|
BARRIER_VSTIG = 1
|
2017-02-19 19:06:01 -04:00
|
|
|
ROBOTS = 2 # number of robots in the swarm
|
2016-12-23 15:21:52 -04:00
|
|
|
|
|
|
|
#
|
|
|
|
# Sets a barrier
|
|
|
|
#
|
|
|
|
function barrier_set(threshold, transf) {
|
|
|
|
statef = function() {
|
|
|
|
barrier_wait(threshold, transf);
|
|
|
|
}
|
|
|
|
barrier = stigmergy.create(BARRIER_VSTIG)
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# Make yourself ready
|
|
|
|
#
|
|
|
|
function barrier_ready() {
|
|
|
|
barrier.put(id, 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# Executes the barrier
|
|
|
|
#
|
|
|
|
function barrier_wait(threshold, transf) {
|
|
|
|
barrier.get(id)
|
|
|
|
if(barrier.size() >= threshold) {
|
|
|
|
barrier = nil
|
|
|
|
transf()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# flight status
|
|
|
|
|
|
|
|
function idle() {
|
2016-12-23 18:48:01 -04:00
|
|
|
statef=idle
|
2016-12-23 17:36:31 -04:00
|
|
|
neighbors.listen("cmd",
|
|
|
|
function(vid, value, rid) {
|
|
|
|
print("Got (", vid, ",", value, ") from robot #", rid)
|
|
|
|
if(value==22) {
|
|
|
|
statef=takeoff
|
|
|
|
} else if(value==21) {
|
|
|
|
statef=land
|
|
|
|
}
|
|
|
|
}
|
2017-01-31 04:57:03 -04:00
|
|
|
|
2017-01-31 04:15:22 -04:00
|
|
|
|
2016-12-23 17:36:31 -04:00
|
|
|
)
|
2016-12-23 15:21:52 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function takeoff() {
|
2017-02-19 19:41:45 -04:00
|
|
|
log("TakeOff: ", flight.status)
|
2017-02-19 19:06:01 -04:00
|
|
|
if( flight.status == 2 and position.altitude >= TARGET_ALTITUDE-TARGET_ALTITUDE/20.0) {
|
|
|
|
barrier_set(ROBOTS,hexagon)
|
|
|
|
barrier_ready()
|
|
|
|
}
|
2017-02-17 17:35:08 -04:00
|
|
|
if( flight.status !=3){
|
|
|
|
log("Altitude: ", TARGET_ALTITUDE)
|
2017-01-30 18:36:05 -04:00
|
|
|
neighbors.broadcast("cmd", 22)
|
2017-01-25 22:10:07 -04:00
|
|
|
uav_takeoff(TARGET_ALTITUDE)
|
2017-01-30 18:36:05 -04:00
|
|
|
}
|
2016-12-23 15:21:52 -04:00
|
|
|
}
|
|
|
|
function land() {
|
2017-02-19 19:41:45 -04:00
|
|
|
log("Land: ", flight.status)
|
2017-02-19 19:31:20 -04:00
|
|
|
if(flight.status == 2 or flight.status == 3){
|
2017-02-19 19:06:01 -04:00
|
|
|
neighbors.broadcast("cmd", 21)
|
|
|
|
uav_land()
|
|
|
|
}
|
2017-02-19 19:31:20 -04:00
|
|
|
else
|
|
|
|
statef=idle
|
2016-12-23 15:21:52 -04:00
|
|
|
}
|
|
|
|
|
2016-11-28 21:35:33 -04:00
|
|
|
# Executed once at init time.
|
|
|
|
function init() {
|
2017-01-09 18:15:33 -04:00
|
|
|
statef=idle
|
2016-11-28 21:35:33 -04:00
|
|
|
}
|
2017-01-09 18:15:33 -04:00
|
|
|
|
2016-11-28 21:35:33 -04:00
|
|
|
# Executed at each time step.
|
|
|
|
function step() {
|
|
|
|
|
2017-02-17 17:35:08 -04:00
|
|
|
if(flight.rc_cmd==22) {
|
|
|
|
log("cmd 22")
|
2016-12-23 18:48:01 -04:00
|
|
|
flight.rc_cmd=0
|
2017-02-17 17:35:08 -04:00
|
|
|
statef = takeoff
|
2016-12-06 13:02:39 -04:00
|
|
|
neighbors.broadcast("cmd", 22)
|
2017-02-17 17:35:08 -04:00
|
|
|
} else if(flight.rc_cmd==21) {
|
|
|
|
log("cmd 21")
|
|
|
|
log("To land")
|
2016-12-23 18:48:01 -04:00
|
|
|
flight.rc_cmd=0
|
2017-02-17 17:35:08 -04:00
|
|
|
statef = land
|
2016-12-06 13:02:39 -04:00
|
|
|
neighbors.broadcast("cmd", 21)
|
2017-02-17 18:29:42 -04:00
|
|
|
} else if(flight.rc_cmd==16) {
|
2017-02-08 12:23:12 -04:00
|
|
|
flight.rc_cmd=0
|
|
|
|
uav_goto()
|
2017-02-17 17:35:08 -04:00
|
|
|
}
|
|
|
|
statef()
|
2016-11-28 21:35:33 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
# Executed once when the robot (or the simulator) is reset.
|
|
|
|
function reset() {
|
|
|
|
}
|
|
|
|
|
|
|
|
# Executed once at the end of experiment.
|
|
|
|
function destroy() {
|
|
|
|
}
|