/*
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
*/
#pragma once
#include
#include
#include
#include
class AP_VisualOdom_Backend;
#define AP_VISUALODOM_TIMEOUT_MS 300
class AP_VisualOdom
{
public:
friend class AP_VisualOdom_Backend;
AP_VisualOdom();
// get singleton instance
static AP_VisualOdom *get_singleton() {
return _singleton;
}
// external position backend types (used by _TYPE parameter)
enum AP_VisualOdom_Type {
AP_VisualOdom_Type_None = 0,
AP_VisualOdom_Type_MAV = 1
};
// The VisualOdomState structure is filled in by the backend driver
struct VisualOdomState {
Vector3f angle_delta; // attitude delta (in radians) of most recent update
Vector3f position_delta; // position delta (in meters) of most recent update
uint64_t time_delta_usec; // time delta (in usec) between previous and most recent update
float confidence; // confidence expressed as a value from 0 (no confidence) to 100 (very confident)
uint32_t last_sensor_update_ms; // system time (in milliseconds) of last update from sensor
uint32_t last_processed_sensor_update_ms; // timestamp of last sensor update that was processed
};
// detect and initialise any sensors
void init();
// should be called really, really often. The faster you call
// this the lower the latency of the data fed to the estimator.
void update();
// return true if sensor is enabled
bool enabled() const;
// return true if sensor is basically healthy (we are receiving data)
bool healthy() const;
// return a 3D vector defining the position offset of the camera in meters relative to the body frame origin
const Vector3f &get_pos_offset(void) const { return _pos_offset; }
// consume data from MAVLink messages
void handle_msg(const mavlink_message_t &msg);
static const struct AP_Param::GroupInfo var_info[];
private:
static AP_VisualOdom *_singleton;
// state accessors
const Vector3f &get_angle_delta() const { return _state.angle_delta; }
const Vector3f &get_position_delta() const { return _state.position_delta; }
uint64_t get_time_delta_usec() const { return _state.time_delta_usec; }
float get_confidence() const { return _state.confidence; }
uint32_t get_last_update_ms() const { return _state.last_sensor_update_ms; }
// parameters
AP_Int8 _type;
AP_Vector3f _pos_offset; // position offset of the camera in the body frame
AP_Int8 _orientation; // camera orientation on vehicle frame
// reference to backends
AP_VisualOdom_Backend *_driver;
// state of backend
VisualOdomState _state;
};
namespace AP {
AP_VisualOdom *visualodom();
};