2017-10-02 13:47:02 -03:00
|
|
|
|
|
|
|
# Write to matrix
|
2017-11-22 20:06:22 -04:00
|
|
|
robot_marker = "X"
|
|
|
|
|
2017-10-02 13:47:02 -03:00
|
|
|
# copy a full matrix row
|
|
|
|
function mat_copyrow(out,ro,in,ri){
|
2017-12-19 14:09:22 -04:00
|
|
|
out[ro] = {}
|
2017-12-19 19:36:10 -04:00
|
|
|
var icr = 1
|
|
|
|
while(icr <= size(in[ri])) {
|
2017-12-19 14:09:22 -04:00
|
|
|
out[ro][icr]=in[ri][icr]
|
2017-10-02 13:47:02 -03:00
|
|
|
icr = icr + 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function getvec(t,row){
|
2017-12-19 14:09:22 -04:00
|
|
|
return math.vec2.new(t[row][1],t[row][2])
|
2017-10-02 13:47:02 -03:00
|
|
|
}
|
|
|
|
|
2017-11-22 20:06:22 -04:00
|
|
|
function init_test_map(len){
|
2017-12-19 14:09:22 -04:00
|
|
|
map = {}
|
2017-12-19 19:36:10 -04:00
|
|
|
var indexR = 1
|
|
|
|
while(indexR <= len) {
|
2017-12-19 14:09:22 -04:00
|
|
|
map[indexR] = {}
|
2017-12-19 19:36:10 -04:00
|
|
|
var indexC = 1
|
|
|
|
while(indexC <= len) {
|
2017-12-19 14:09:22 -04:00
|
|
|
map[indexR][indexC] = 1.0
|
|
|
|
indexC = indexC + 1
|
|
|
|
}
|
|
|
|
indexR = indexR + 1
|
2017-10-02 13:47:02 -03:00
|
|
|
}
|
2017-12-19 14:09:22 -04:00
|
|
|
# DEBUG\TEST: puts an obstacle right in the middle
|
|
|
|
map[5][5] = 0.0
|
|
|
|
map[6][5] = 0.0
|
|
|
|
map[4][5] = 0.0
|
2017-10-02 13:47:02 -03:00
|
|
|
|
2017-12-19 19:36:10 -04:00
|
|
|
log("Occupancy grid initialized (",size(map),"x",size(map[1]),") with obstacles.")
|
2017-10-02 13:47:02 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
function init_map(len){
|
2017-12-19 14:09:22 -04:00
|
|
|
map = {}
|
2017-12-19 19:36:10 -04:00
|
|
|
var indexR = 1
|
|
|
|
while(indexR <= len) {
|
2017-12-19 14:09:22 -04:00
|
|
|
map[indexR] = {}
|
2017-12-19 19:36:10 -04:00
|
|
|
var indexC = 1
|
|
|
|
while(indexC <= len) {
|
2017-12-19 14:09:22 -04:00
|
|
|
map[indexR][indexC] = 1.0
|
|
|
|
indexC = indexC + 1
|
|
|
|
}
|
|
|
|
indexR = indexR + 1
|
2017-10-02 13:47:02 -03:00
|
|
|
}
|
2017-12-19 19:36:10 -04:00
|
|
|
log("Occupancy grid initialized (",size(map),"x",size(map[1]),").")
|
2017-10-02 13:47:02 -03:00
|
|
|
}
|
|
|
|
|
2017-11-22 20:06:22 -04:00
|
|
|
function add_obstacle(pos, off, inc_trust) {
|
2017-12-18 20:30:05 -04:00
|
|
|
var xi = math.round(pos.x)
|
|
|
|
var yi = math.round(pos.y)
|
2017-11-22 20:06:22 -04:00
|
|
|
|
2017-12-19 14:09:22 -04:00
|
|
|
if(xi <= size(map) and yi <= size(map[1]) and xi > 0 and yi > 0) {
|
2017-12-21 22:41:57 -04:00
|
|
|
# log("Add obstacle in cell: ", xi, " ", yi)
|
2017-12-19 19:36:10 -04:00
|
|
|
var old=map[xi][yi]
|
2017-11-22 20:06:22 -04:00
|
|
|
if(old-inc_trust > 0.0)
|
2017-12-19 14:09:22 -04:00
|
|
|
map[xi][yi] = old-inc_trust
|
2017-11-22 20:06:22 -04:00
|
|
|
else
|
2017-12-19 14:09:22 -04:00
|
|
|
map[xi][yi] = 0.0
|
2017-11-22 20:06:22 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function remove_obstacle(pos, off, dec_trust) {
|
2017-12-18 20:30:05 -04:00
|
|
|
var xi = math.round(pos.x)
|
|
|
|
var yi = math.round(pos.y)
|
2017-11-22 20:06:22 -04:00
|
|
|
|
2017-12-21 22:41:57 -04:00
|
|
|
if(xi <= size(map) and yi <= size(map[1]) and xi > 0 and yi > 0) {
|
|
|
|
# log("Remove obstacle in cell: ", xi, " ", yi)
|
2017-12-19 19:36:10 -04:00
|
|
|
var old=map[xi][yi]
|
2017-11-22 20:06:22 -04:00
|
|
|
if(old + dec_trust < 1.0) #x,y
|
2017-12-19 14:09:22 -04:00
|
|
|
map[xi][yi] = old+dec_trust
|
2017-11-22 20:06:22 -04:00
|
|
|
else
|
2017-12-19 14:09:22 -04:00
|
|
|
map[xi][yi] = 1.0
|
2017-10-02 13:47:02 -03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-19 19:36:10 -04:00
|
|
|
|
|
|
|
function get_occupied_cells(cur_cell){
|
|
|
|
var i = 1
|
|
|
|
var occupied_cells = {}
|
|
|
|
occupied_cells[0] = cur_cell
|
|
|
|
occupied_cells[1] = math.vec2.new(cur_cell.x + 1, cur_cell.y)
|
|
|
|
occupied_cells[2] = math.vec2.new(cur_cell.x - 1, cur_cell.y)
|
|
|
|
occupied_cells[3] = math.vec2.new(cur_cell.x, cur_cell.y + 1)
|
|
|
|
occupied_cells[4] = math.vec2.new(cur_cell.x, cur_cell.y - 1)
|
|
|
|
return occupied_cells
|
|
|
|
}
|
|
|
|
|
|
|
|
function is_in(dictionary, x, y){
|
|
|
|
var i = 0
|
|
|
|
while(i < size(dictionary)){
|
|
|
|
if(dictionary[i].x == x and dictionary[i].y == y){
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
i = i + 1
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2017-10-02 13:47:02 -03:00
|
|
|
function print_pos(t) {
|
2017-12-18 20:30:05 -04:00
|
|
|
var ir=1
|
2017-12-19 14:09:22 -04:00
|
|
|
while(ir <= size(t)) {
|
|
|
|
log(ir, ": ", t[ir][1], " ", t[ir][2])
|
2017-10-02 13:47:02 -03:00
|
|
|
ir = ir + 1
|
|
|
|
}
|
2017-11-22 20:06:22 -04:00
|
|
|
}
|
2017-12-19 14:09:22 -04:00
|
|
|
|
2017-11-22 20:06:22 -04:00
|
|
|
function print_map(t) {
|
2017-12-19 14:09:22 -04:00
|
|
|
var ir=size(t)
|
|
|
|
log("Printing a ", size(t), " by ", size(t[1]), " map")
|
|
|
|
while(ir > 0) {
|
2017-11-22 20:06:22 -04:00
|
|
|
logst=string.concat("\t", string.tostring(ir), "\t:")
|
2017-12-19 14:09:22 -04:00
|
|
|
ic = size(t[ir])
|
|
|
|
while(ic > 0) {
|
2017-11-22 20:06:22 -04:00
|
|
|
if(ir==cur_cell.x and ic==cur_cell.y)
|
|
|
|
logst = string.concat(logst, " XXXXXXXX")
|
|
|
|
else
|
2017-12-19 14:09:22 -04:00
|
|
|
logst = string.concat(logst, " ", string.tostring(t[ir][ic]))
|
2017-11-22 20:06:22 -04:00
|
|
|
ic = ic - 1
|
|
|
|
}
|
|
|
|
log(logst)
|
|
|
|
ir = ir - 1
|
|
|
|
}
|
2017-12-19 14:09:22 -04:00
|
|
|
export_map(map)
|
2017-11-22 20:06:22 -04:00
|
|
|
}
|