123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- #include <AP_HAL/AP_HAL.h>
- #include <AP_Common/AP_Common.h>
- #include <AP_Math/AP_Math.h>
- #include <GCS_MAVLink/GCS_MAVLink.h>
- #include <GCS_MAVLink/GCS.h>
- #include "AP_Terrain.h"
- #if AP_TERRAIN_AVAILABLE
- #include <AP_Filesystem/AP_Filesystem.h>
- extern const AP_HAL::HAL& hal;
- uint8_t AP_Terrain::grid_bitnum(uint8_t idx_x, uint8_t idx_y)
- {
- ASSERT_RANGE(idx_x,0,27);
- ASSERT_RANGE(idx_y,0,31);
- uint8_t subgrid_x = idx_x / TERRAIN_GRID_MAVLINK_SIZE;
- uint8_t subgrid_y = idx_y / TERRAIN_GRID_MAVLINK_SIZE;
- ASSERT_RANGE(subgrid_x,0,TERRAIN_GRID_BLOCK_MUL_X-1);
- ASSERT_RANGE(subgrid_y,0,TERRAIN_GRID_BLOCK_MUL_Y-1);
- return subgrid_y + TERRAIN_GRID_BLOCK_MUL_Y*subgrid_x;
- }
- bool AP_Terrain::check_bitmap(const struct grid_block &grid, uint8_t idx_x, uint8_t idx_y)
- {
- uint8_t bitnum = grid_bitnum(idx_x, idx_y);
- return (grid.bitmap & (((uint64_t)1U)<<bitnum)) != 0;
- }
- void AP_Terrain::calculate_grid_info(const Location &loc, struct grid_info &info) const
- {
-
-
- info.lat_degrees = (loc.lat<0?(loc.lat-9999999L):loc.lat) / (10*1000*1000L);
- info.lon_degrees = (loc.lng<0?(loc.lng-9999999L):loc.lng) / (10*1000*1000L);
-
- Location ref;
- ref.lat = info.lat_degrees*10*1000*1000L;
- ref.lng = info.lon_degrees*10*1000*1000L;
-
- const Vector2f offset = ref.get_distance_NE(loc);
-
- uint32_t idx_x = offset.x / grid_spacing;
- uint32_t idx_y = offset.y / grid_spacing;
-
-
-
- info.grid_idx_x = idx_x / TERRAIN_GRID_BLOCK_SPACING_X;
- info.grid_idx_y = idx_y / TERRAIN_GRID_BLOCK_SPACING_Y;
-
- info.idx_x = idx_x % TERRAIN_GRID_BLOCK_SPACING_X;
- info.idx_y = idx_y % TERRAIN_GRID_BLOCK_SPACING_Y;
-
- info.frac_x = (offset.x - idx_x * grid_spacing) / grid_spacing;
- info.frac_y = (offset.y - idx_y * grid_spacing) / grid_spacing;
-
- ref.offset(info.grid_idx_x * TERRAIN_GRID_BLOCK_SPACING_X * (float)grid_spacing,
- info.grid_idx_y * TERRAIN_GRID_BLOCK_SPACING_Y * (float)grid_spacing);
- info.grid_lat = ref.lat;
- info.grid_lon = ref.lng;
- ASSERT_RANGE(info.idx_x,0,TERRAIN_GRID_BLOCK_SPACING_X-1);
- ASSERT_RANGE(info.idx_y,0,TERRAIN_GRID_BLOCK_SPACING_Y-1);
- ASSERT_RANGE(info.frac_x,0,1);
- ASSERT_RANGE(info.frac_y,0,1);
- }
- AP_Terrain::grid_cache &AP_Terrain::find_grid_cache(const struct grid_info &info)
- {
- uint16_t oldest_i = 0;
-
- for (uint16_t i=0; i<cache_size; i++) {
- if (cache[i].grid.lat == info.grid_lat &&
- cache[i].grid.lon == info.grid_lon &&
- cache[i].grid.spacing == grid_spacing) {
- cache[i].last_access_ms = AP_HAL::millis();
- return cache[i];
- }
- if (cache[i].last_access_ms < cache[oldest_i].last_access_ms) {
- oldest_i = i;
- }
- }
-
-
- struct grid_cache &grid = cache[oldest_i];
- memset(&grid, 0, sizeof(grid));
- grid.grid.lat = info.grid_lat;
- grid.grid.lon = info.grid_lon;
- grid.grid.spacing = grid_spacing;
- grid.grid.grid_idx_x = info.grid_idx_x;
- grid.grid.grid_idx_y = info.grid_idx_y;
- grid.grid.lat_degrees = info.lat_degrees;
- grid.grid.lon_degrees = info.lon_degrees;
- grid.grid.version = TERRAIN_GRID_FORMAT_VERSION;
- grid.last_access_ms = AP_HAL::millis();
-
- grid.state = GRID_CACHE_DISKWAIT;
- return grid;
- }
- int16_t AP_Terrain::find_io_idx(enum GridCacheState state)
- {
-
- for (uint16_t i=0; i<cache_size; i++) {
- if (disk_block.block.lat == cache[i].grid.lat &&
- disk_block.block.lon == cache[i].grid.lon &&
- cache[i].state == state) {
- return i;
- }
- }
-
- for (uint16_t i=0; i<cache_size; i++) {
- if (disk_block.block.lat == cache[i].grid.lat &&
- disk_block.block.lon == cache[i].grid.lon) {
- return i;
- }
- }
- return -1;
- }
- uint16_t AP_Terrain::get_block_crc(struct grid_block &block)
- {
- uint16_t saved_crc = block.crc;
- block.crc = 0;
- uint16_t ret = crc16_ccitt((const uint8_t *)&block, sizeof(block), 0);
- block.crc = saved_crc;
- return ret;
- }
- #endif
|