mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
AP_VisualOdom: allow VisualOdom backends to be compiled in individually
This commit is contained in:
parent
3c86167544
commit
b10c576134
@ -13,15 +13,15 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "AP_VisualOdom.h"
|
#include "AP_VisualOdom_config.h"
|
||||||
|
|
||||||
#if HAL_VISUALODOM_ENABLED
|
#if HAL_VISUALODOM_ENABLED
|
||||||
|
|
||||||
|
#include "AP_VisualOdom.h"
|
||||||
#include "AP_VisualOdom_Backend.h"
|
#include "AP_VisualOdom_Backend.h"
|
||||||
#include "AP_VisualOdom_MAV.h"
|
#include "AP_VisualOdom_MAV.h"
|
||||||
#include "AP_VisualOdom_IntelT265.h"
|
#include "AP_VisualOdom_IntelT265.h"
|
||||||
#include <AP_AHRS/AP_AHRS.h>
|
#include <AP_AHRS/AP_AHRS.h>
|
||||||
#include <AP_Logger/AP_Logger.h>
|
|
||||||
|
|
||||||
extern const AP_HAL::HAL &hal;
|
extern const AP_HAL::HAL &hal;
|
||||||
|
|
||||||
@ -128,13 +128,17 @@ void AP_VisualOdom::init()
|
|||||||
case VisualOdom_Type::None:
|
case VisualOdom_Type::None:
|
||||||
// do nothing
|
// do nothing
|
||||||
break;
|
break;
|
||||||
|
#if AP_VISUALODOM_MAV_ENABLED
|
||||||
case VisualOdom_Type::MAV:
|
case VisualOdom_Type::MAV:
|
||||||
_driver = new AP_VisualOdom_MAV(*this);
|
_driver = new AP_VisualOdom_MAV(*this);
|
||||||
break;
|
break;
|
||||||
|
#endif
|
||||||
|
#if AP_VISUALODOM_INTELT265_ENABLED
|
||||||
case VisualOdom_Type::IntelT265:
|
case VisualOdom_Type::IntelT265:
|
||||||
case VisualOdom_Type::VOXL:
|
case VisualOdom_Type::VOXL:
|
||||||
_driver = new AP_VisualOdom_IntelT265(*this);
|
_driver = new AP_VisualOdom_IntelT265(*this);
|
||||||
break;
|
break;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,9 +44,13 @@ public:
|
|||||||
// external position backend types (used by _TYPE parameter)
|
// external position backend types (used by _TYPE parameter)
|
||||||
enum class VisualOdom_Type {
|
enum class VisualOdom_Type {
|
||||||
None = 0,
|
None = 0,
|
||||||
|
#if AP_VISUALODOM_MAV_ENABLED
|
||||||
MAV = 1,
|
MAV = 1,
|
||||||
|
#endif
|
||||||
|
#if AP_VISUALODOM_INTELT265_ENABLED
|
||||||
IntelT265 = 2,
|
IntelT265 = 2,
|
||||||
VOXL = 3,
|
VOXL = 3,
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
// detect and initialise any sensors
|
// detect and initialise any sensors
|
||||||
|
@ -17,11 +17,9 @@
|
|||||||
|
|
||||||
#if HAL_VISUALODOM_ENABLED
|
#if HAL_VISUALODOM_ENABLED
|
||||||
|
|
||||||
#include <AP_Logger/AP_Logger.h>
|
#include <AP_AHRS/AP_AHRS.h>
|
||||||
#include <GCS_MAVLink/GCS.h>
|
#include <GCS_MAVLink/GCS.h>
|
||||||
|
|
||||||
extern const AP_HAL::HAL &hal;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
base class constructor.
|
base class constructor.
|
||||||
This incorporates initialisation as well.
|
This incorporates initialisation as well.
|
||||||
|
@ -68,5 +68,4 @@ protected:
|
|||||||
uint32_t _reset_timestamp_ms; // time reset counter was received
|
uint32_t _reset_timestamp_ms; // time reset counter was received
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif // HAL_VISUALODOM_ENABLED
|
||||||
|
|
||||||
|
@ -13,14 +13,15 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "AP_VisualOdom_IntelT265.h"
|
#include "AP_VisualOdom_config.h"
|
||||||
|
|
||||||
#if HAL_VISUALODOM_ENABLED
|
#if AP_VISUALODOM_INTELT265_ENABLED
|
||||||
|
|
||||||
|
#include "AP_VisualOdom_IntelT265.h"
|
||||||
|
|
||||||
#include <AP_HAL/AP_HAL.h>
|
#include <AP_HAL/AP_HAL.h>
|
||||||
#include <AP_AHRS/AP_AHRS.h>
|
#include <AP_AHRS/AP_AHRS.h>
|
||||||
#include <GCS_MAVLink/GCS.h>
|
#include <GCS_MAVLink/GCS.h>
|
||||||
#include <AP_Logger/AP_Logger.h>
|
|
||||||
|
|
||||||
#define VISUALODOM_RESET_IGNORE_DURATION_MS 1000 // sensor data is ignored for 1sec after a position reset
|
#define VISUALODOM_RESET_IGNORE_DURATION_MS 1000 // sensor data is ignored for 1sec after a position reset
|
||||||
|
|
||||||
@ -344,4 +345,4 @@ void AP_VisualOdom_IntelT265::handle_voxl_camera_reset_jump(const Vector3f &sens
|
|||||||
_voxl_reset_counter_last = reset_counter;
|
_voxl_reset_counter_last = reset_counter;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif // AP_VISUALODOM_INTELT265_ENABLED
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "AP_VisualOdom_Backend.h"
|
#include "AP_VisualOdom_config.h"
|
||||||
|
|
||||||
#if HAL_VISUALODOM_ENABLED
|
#if AP_VISUALODOM_INTELT265_ENABLED
|
||||||
|
|
||||||
|
#include "AP_VisualOdom_Backend.h"
|
||||||
|
|
||||||
class AP_VisualOdom_IntelT265 : public AP_VisualOdom_Backend
|
class AP_VisualOdom_IntelT265 : public AP_VisualOdom_Backend
|
||||||
{
|
{
|
||||||
@ -88,4 +90,4 @@ protected:
|
|||||||
Vector3f _voxl_position_last; // last recorded position (post scaling, offset and orientation corrections)
|
Vector3f _voxl_position_last; // last recorded position (post scaling, offset and orientation corrections)
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif // AP_VISUALODOM_INTELT265_ENABLED
|
||||||
|
@ -13,15 +13,14 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "AP_VisualOdom_MAV.h"
|
#include "AP_VisualOdom_config.h"
|
||||||
|
|
||||||
#if HAL_VISUALODOM_ENABLED
|
#if AP_VISUALODOM_MAV_ENABLED
|
||||||
|
|
||||||
|
#include "AP_VisualOdom_MAV.h"
|
||||||
|
|
||||||
#include <AP_HAL/AP_HAL.h>
|
#include <AP_HAL/AP_HAL.h>
|
||||||
#include <AP_AHRS/AP_AHRS.h>
|
#include <AP_AHRS/AP_AHRS.h>
|
||||||
#include <AP_Logger/AP_Logger.h>
|
|
||||||
|
|
||||||
extern const AP_HAL::HAL& hal;
|
|
||||||
|
|
||||||
// consume vision position estimate data and send to EKF. distances in meters
|
// consume vision position estimate data and send to EKF. distances in meters
|
||||||
void AP_VisualOdom_MAV::handle_vision_position_estimate(uint64_t remote_time_us, uint32_t time_ms, float x, float y, float z, const Quaternion &attitude, float posErr, float angErr, uint8_t reset_counter)
|
void AP_VisualOdom_MAV::handle_vision_position_estimate(uint64_t remote_time_us, uint32_t time_ms, float x, float y, float z, const Quaternion &attitude, float posErr, float angErr, uint8_t reset_counter)
|
||||||
@ -58,4 +57,4 @@ void AP_VisualOdom_MAV::handle_vision_speed_estimate(uint64_t remote_time_us, ui
|
|||||||
Write_VisualVelocity(remote_time_us, time_ms, vel, reset_counter, false);
|
Write_VisualVelocity(remote_time_us, time_ms, vel, reset_counter, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif // AP_VISUALODOM_MAV_ENABLED
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "AP_VisualOdom_Backend.h"
|
#include "AP_VisualOdom_config.h"
|
||||||
|
|
||||||
#if HAL_VISUALODOM_ENABLED
|
#if AP_VISUALODOM_MAV_ENABLED
|
||||||
|
|
||||||
|
#include "AP_VisualOdom_Backend.h"
|
||||||
|
|
||||||
class AP_VisualOdom_MAV : public AP_VisualOdom_Backend
|
class AP_VisualOdom_MAV : public AP_VisualOdom_Backend
|
||||||
{
|
{
|
||||||
@ -18,4 +20,4 @@ public:
|
|||||||
void handle_vision_speed_estimate(uint64_t remote_time_us, uint32_t time_ms, const Vector3f &vel, uint8_t reset_counter) override;
|
void handle_vision_speed_estimate(uint64_t remote_time_us, uint32_t time_ms, const Vector3f &vel, uint8_t reset_counter) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif // AP_VISUALODOM_MAV_ENABLED
|
||||||
|
@ -1,7 +1,20 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <AP_HAL/AP_HAL_Boards.h>
|
#include <AP_HAL/AP_HAL_Boards.h>
|
||||||
|
#include <GCS_MAVLink/GCS_config.h>
|
||||||
|
|
||||||
#ifndef HAL_VISUALODOM_ENABLED
|
#ifndef HAL_VISUALODOM_ENABLED
|
||||||
#define HAL_VISUALODOM_ENABLED BOARD_FLASH_SIZE > 1024
|
#define HAL_VISUALODOM_ENABLED BOARD_FLASH_SIZE > 1024
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef AP_VISUALODOM_BACKEND_DEFAULT_ENABLED
|
||||||
|
#define AP_VISUALODOM_BACKEND_DEFAULT_ENABLED HAL_VISUALODOM_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef AP_VISUALODOM_INTELT265_ENABLED
|
||||||
|
#define AP_VISUALODOM_INTELT265_ENABLED AP_VISUALODOM_BACKEND_DEFAULT_ENABLED && HAL_GCS_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef AP_VISUALODOM_MAV_ENABLED
|
||||||
|
#define AP_VISUALODOM_MAV_ENABLED AP_VISUALODOM_BACKEND_DEFAULT_ENABLED && HAL_GCS_ENABLED
|
||||||
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user