2015-06-19 21:06:14 +02:00
|
|
|
//
|
|
|
|
// FILE: DistanceTable.cpp
|
|
|
|
// AUTHOR: Rob Tillaart
|
2017-07-27 16:24:22 +02:00
|
|
|
// VERSION: 0.1.3
|
2015-06-19 21:06:14 +02:00
|
|
|
// PURPOSE: library for a memory efficient DistanceTable for Arduino
|
|
|
|
// URL:
|
|
|
|
//
|
|
|
|
// Released to the public domain
|
|
|
|
//
|
2017-07-27 16:24:22 +02:00
|
|
|
// 0.1.3 2017-07-27 Fix issue #33
|
|
|
|
// 0.1.2 - fix overflow; add some error detection; revert float to float to memory
|
2015-06-19 21:06:14 +02:00
|
|
|
// 0.1.01 - refactor
|
2017-07-15 17:58:10 +02:00
|
|
|
// 0.1.00 - initial version
|
2015-06-19 21:06:14 +02:00
|
|
|
|
|
|
|
#include "DistanceTable.h"
|
|
|
|
|
|
|
|
DistanceTable::DistanceTable(uint8_t size)
|
|
|
|
{
|
2017-07-15 17:58:10 +02:00
|
|
|
// MUST: size > 1
|
2017-07-27 16:24:22 +02:00
|
|
|
// ATMEL 328 has 2000 bytes mem,
|
2017-07-15 17:58:10 +02:00
|
|
|
// so roughly 30X30 = 900 floats(4Bytes) => 1740 bytes is max feasible
|
2015-06-19 21:06:14 +02:00
|
|
|
_size = size;
|
2017-07-15 17:58:10 +02:00
|
|
|
_store = _size;
|
|
|
|
_store *= (_size-1)/2;
|
2017-07-27 16:24:22 +02:00
|
|
|
_distanceTable = (float *) malloc(_store * sizeof(float));
|
2015-06-19 21:06:14 +02:00
|
|
|
if (_distanceTable == NULL) _size = 0;
|
2017-07-15 17:58:10 +02:00
|
|
|
clear();
|
2015-06-19 21:06:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
DistanceTable::~DistanceTable()
|
|
|
|
{
|
|
|
|
if (_distanceTable != NULL) free(_distanceTable);
|
|
|
|
}
|
|
|
|
|
|
|
|
void DistanceTable::clear()
|
|
|
|
{
|
2017-07-15 17:58:10 +02:00
|
|
|
for (uint16_t index = 0; index <_store; index++) _distanceTable[index] = 0;
|
2015-06-19 21:06:14 +02:00
|
|
|
};
|
|
|
|
|
2017-07-27 16:24:22 +02:00
|
|
|
void DistanceTable::set(uint8_t x, uint8_t y, float value )
|
2015-06-19 21:06:14 +02:00
|
|
|
{
|
|
|
|
if ( x == y ) return;
|
2017-07-27 16:24:22 +02:00
|
|
|
// comment next line to skip rangecheck (squeeze performance)
|
2017-07-15 17:58:10 +02:00
|
|
|
if ( x >= _size || y >= _size) return;
|
2017-07-27 16:24:22 +02:00
|
|
|
|
|
|
|
// uint16_t index = getIndex(uint8_t x, uint8_t y);
|
|
|
|
if ( x < y )
|
2015-06-19 21:06:14 +02:00
|
|
|
{
|
|
|
|
uint8_t t = x; x = y; y = t;
|
|
|
|
}
|
2017-07-15 17:58:10 +02:00
|
|
|
// prevent overflow by moving to 16 bit
|
2015-06-19 21:06:14 +02:00
|
|
|
uint16_t index = x;
|
2017-07-27 16:24:22 +02:00
|
|
|
index = (index * (index-1))/2 + y;
|
2015-06-19 21:06:14 +02:00
|
|
|
_distanceTable[index] = value;
|
|
|
|
};
|
|
|
|
|
2017-07-27 16:24:22 +02:00
|
|
|
float DistanceTable::get (uint8_t x, uint8_t y)
|
2015-06-19 21:06:14 +02:00
|
|
|
{
|
2017-07-27 16:24:22 +02:00
|
|
|
if ( x == y ) return 0.0;
|
|
|
|
// comment next line to skip rangecheck (squeeze performance)
|
2017-07-15 17:58:10 +02:00
|
|
|
if ( x >= _size || y >= _size) return -1;
|
2017-07-27 16:24:22 +02:00
|
|
|
|
|
|
|
// uint16_t index = getIndex(uint8_t x, uint8_t y);
|
|
|
|
if ( x < y )
|
2015-06-19 21:06:14 +02:00
|
|
|
{
|
|
|
|
uint8_t t = x; x = y; y = t;
|
|
|
|
}
|
|
|
|
uint16_t index = x;
|
2017-07-27 16:24:22 +02:00
|
|
|
index = (index * (index-1))/2 + y;
|
2015-06-19 21:06:14 +02:00
|
|
|
return _distanceTable[index];
|
|
|
|
};
|
|
|
|
|
2017-07-27 16:24:22 +02:00
|
|
|
// TODO remove identical code
|
|
|
|
// int DistanceTable::getIndex(uint8_t x, uint8_t y)
|
|
|
|
// {
|
|
|
|
// if ( x < y )
|
|
|
|
// {
|
|
|
|
// uint8_t t = x; x = y; y = t;
|
|
|
|
// }
|
|
|
|
// uint16_t index = x;
|
|
|
|
// index = (index * (index-1))/2 + y;
|
|
|
|
// return index;
|
|
|
|
// }
|
|
|
|
|
|
|
|
// triangular dump
|
2015-06-19 21:06:14 +02:00
|
|
|
void DistanceTable::dump()
|
|
|
|
{
|
|
|
|
uint16_t index = 0;
|
2017-07-15 17:58:10 +02:00
|
|
|
for (uint8_t i = 0; i < _size-1; i++)
|
2015-06-19 21:06:14 +02:00
|
|
|
{
|
2017-07-15 17:58:10 +02:00
|
|
|
for (uint8_t j = 0; j <= i; j++)
|
2015-06-19 21:06:14 +02:00
|
|
|
{
|
|
|
|
Serial.print(_distanceTable[index++]);
|
|
|
|
Serial.print("\t");
|
|
|
|
}
|
|
|
|
Serial.println();
|
2017-07-27 16:24:22 +02:00
|
|
|
}
|
2015-06-19 21:06:14 +02:00
|
|
|
Serial.println();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// --- END OF FILE ---
|