26 #include "nav2_amcl/map/map.hpp"
37 unsigned int src_i_, src_j_;
51 : distances_(NULL), scale_(scale), max_dist_(max_dist)
53 cell_radius_ = max_dist / scale;
54 distances_ =
new double *[cell_radius_ + 2];
55 for (
int i = 0; i <= cell_radius_ + 1; i++) {
56 distances_[i] =
new double[cell_radius_ + 2];
57 for (
int j = 0; j <= cell_radius_ + 1; j++) {
58 distances_[i][j] = sqrt(i * i + j * j);
69 for (
int i = 0; i <= cell_radius_ + 1; i++) {
70 delete[] distances_[i];
86 return a.map_->cells[MAP_INDEX(
88 a.j_)].occ_dist > a.map_->cells[MAP_INDEX(b.map_, b.i_, b.j_)].occ_dist;
98 get_distance_map(
double scale,
double max_dist)
102 if (!cdm || (cdm->scale_ != scale) || (cdm->max_dist_ != max_dist)) {
116 map_t * map,
int i,
int j,
117 int src_i,
int src_j,
118 std::priority_queue<CellData> & Q,
120 unsigned char * marked)
122 if (marked[MAP_INDEX(map, i, j)]) {
126 int di = abs(i - src_i);
127 int dj = abs(j - src_j);
128 double distance = cdm->distances_[di][dj];
130 if (distance > cdm->cell_radius_) {
134 map->cells[MAP_INDEX(map, i, j)].occ_dist = distance * map->scale;
145 marked[MAP_INDEX(map, i, j)] = 1;
153 void map_update_cspace(
map_t * map,
double max_occ_dist)
155 unsigned char * marked;
156 std::priority_queue<CellData> Q;
158 marked =
new unsigned char[map->size_x * map->size_y];
159 memset(marked, 0,
sizeof(
unsigned char) * map->size_x * map->size_y);
161 map->max_occ_dist = max_occ_dist;
168 for (
int i = 0; i < map->size_x; i++) {
169 cell.src_i_ = cell.i_ = i;
170 for (
int j = 0; j < map->size_y; j++) {
171 if (map->cells[MAP_INDEX(map, i, j)].occ_state == +1) {
172 map->cells[MAP_INDEX(map, i, j)].occ_dist = 0.0;
173 cell.src_j_ = cell.j_ = j;
174 marked[MAP_INDEX(map, i, j)] = 1;
177 map->cells[MAP_INDEX(map, i, j)].occ_dist = max_occ_dist;
184 if (current_cell.i_ > 0) {
186 map, current_cell.i_ - 1, current_cell.j_,
187 current_cell.src_i_, current_cell.src_j_,
190 if (current_cell.j_ > 0) {
192 map, current_cell.i_, current_cell.j_ - 1,
193 current_cell.src_i_, current_cell.src_j_,
196 if (
static_cast<int>(current_cell.i_) < map->size_x - 1) {
198 map, current_cell.i_ + 1, current_cell.j_,
199 current_cell.src_i_, current_cell.src_j_,
202 if (
static_cast<int>(current_cell.j_) < map->size_y - 1) {
204 map, current_cell.i_, current_cell.j_ + 1,
205 current_cell.src_i_, current_cell.src_j_,