mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-05-27 18:27:05 +08:00
Control lib update.
This commit is contained in:
@@ -299,8 +299,8 @@ int RoboClaw::update()
|
|||||||
// if new data, send to motors
|
// if new data, send to motors
|
||||||
if (_actuators.updated()) {
|
if (_actuators.updated()) {
|
||||||
_actuators.update();
|
_actuators.update();
|
||||||
setMotorDutyCycle(MOTOR_1, _actuators.control[CH_VOLTAGE_LEFT]);
|
setMotorDutyCycle(MOTOR_1, _actuators.get().control[CH_VOLTAGE_LEFT]);
|
||||||
setMotorDutyCycle(MOTOR_2, _actuators.control[CH_VOLTAGE_RIGHT]);
|
setMotorDutyCycle(MOTOR_2, _actuators.get().control[CH_VOLTAGE_RIGHT]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
@@ -58,8 +58,8 @@ static const uint16_t maxPublicationsPerBlock = 100;
|
|||||||
static const uint8_t blockNameLengthMax = 80;
|
static const uint8_t blockNameLengthMax = 80;
|
||||||
|
|
||||||
// forward declaration
|
// forward declaration
|
||||||
class SuperBlock;
|
|
||||||
class BlockParamBase;
|
class BlockParamBase;
|
||||||
|
class SuperBlock;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
@@ -81,9 +81,9 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
// accessors
|
// accessors
|
||||||
SuperBlock *getParent() { return _parent; }
|
SuperBlock *getParent() { return _parent; }
|
||||||
List<uORB::SubscriptionNode *> & getSubscriptions() { return _subscriptions; }
|
List<uORB::SubscriptionNode *> &getSubscriptions() { return _subscriptions; }
|
||||||
List<uORB::PublicationNode *> & getPublications() { return _publications; }
|
List<uORB::PublicationNode *> &getPublications() { return _publications; }
|
||||||
List<BlockParamBase *> & getParams() { return _params; }
|
List<BlockParamBase *> &getParams() { return _params; }
|
||||||
// attributes
|
// attributes
|
||||||
const char *_name;
|
const char *_name;
|
||||||
SuperBlock *_parent;
|
SuperBlock *_parent;
|
||||||
@@ -94,8 +94,8 @@ protected:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
/* this class has pointer data members and should not be copied (private constructor) */
|
/* this class has pointer data members and should not be copied (private constructor) */
|
||||||
Block(const control::Block&);
|
Block(const control::Block &);
|
||||||
Block operator=(const control::Block&);
|
Block operator=(const control::Block &);
|
||||||
};
|
};
|
||||||
|
|
||||||
class __EXPORT SuperBlock :
|
class __EXPORT SuperBlock :
|
||||||
@@ -106,28 +106,32 @@ public:
|
|||||||
// methods
|
// methods
|
||||||
SuperBlock(SuperBlock *parent, const char *name) :
|
SuperBlock(SuperBlock *parent, const char *name) :
|
||||||
Block(parent, name),
|
Block(parent, name),
|
||||||
_children() {
|
_children()
|
||||||
|
{
|
||||||
}
|
}
|
||||||
virtual ~SuperBlock() {};
|
virtual ~SuperBlock() {};
|
||||||
virtual void setDt(float dt);
|
virtual void setDt(float dt);
|
||||||
virtual void updateParams() {
|
virtual void updateParams()
|
||||||
|
{
|
||||||
Block::updateParams();
|
Block::updateParams();
|
||||||
|
|
||||||
if (getChildren().getHead() != NULL) updateChildParams();
|
if (getChildren().getHead() != NULL) { updateChildParams(); }
|
||||||
}
|
}
|
||||||
virtual void updateSubscriptions() {
|
virtual void updateSubscriptions()
|
||||||
|
{
|
||||||
Block::updateSubscriptions();
|
Block::updateSubscriptions();
|
||||||
|
|
||||||
if (getChildren().getHead() != NULL) updateChildSubscriptions();
|
if (getChildren().getHead() != NULL) { updateChildSubscriptions(); }
|
||||||
}
|
}
|
||||||
virtual void updatePublications() {
|
virtual void updatePublications()
|
||||||
|
{
|
||||||
Block::updatePublications();
|
Block::updatePublications();
|
||||||
|
|
||||||
if (getChildren().getHead() != NULL) updateChildPublications();
|
if (getChildren().getHead() != NULL) { updateChildPublications(); }
|
||||||
}
|
}
|
||||||
protected:
|
protected:
|
||||||
// methods
|
// methods
|
||||||
List<Block *> & getChildren() { return _children; }
|
List<Block *> &getChildren() { return _children; }
|
||||||
void updateChildParams();
|
void updateChildParams();
|
||||||
void updateChildSubscriptions();
|
void updateChildSubscriptions();
|
||||||
void updateChildPublications();
|
void updateChildPublications();
|
||||||
|
|||||||
@@ -65,6 +65,7 @@ BlockParamBase::BlockParamBase(Block *parent, const char *name, bool parent_pref
|
|||||||
|
|
||||||
} else if (parent_prefix) {
|
} else if (parent_prefix) {
|
||||||
snprintf(fullname, blockNameLengthMax, "%s_%s", parentName, name);
|
snprintf(fullname, blockNameLengthMax, "%s_%s", parentName, name);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
strncpy(fullname, name, blockNameLengthMax);
|
strncpy(fullname, name, blockNameLengthMax);
|
||||||
}
|
}
|
||||||
@@ -74,15 +75,17 @@ BlockParamBase::BlockParamBase(Block *parent, const char *name, bool parent_pref
|
|||||||
|
|
||||||
_handle = param_find(fullname);
|
_handle = param_find(fullname);
|
||||||
|
|
||||||
if (_handle == PARAM_INVALID)
|
if (_handle == PARAM_INVALID) {
|
||||||
printf("error finding param: %s\n", fullname);
|
printf("error finding param: %s\n", fullname);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
BlockParam<T>::BlockParam(Block *block, const char *name,
|
BlockParam<T>::BlockParam(Block *block, const char *name,
|
||||||
bool parent_prefix) :
|
bool parent_prefix) :
|
||||||
BlockParamBase(block, name, parent_prefix),
|
BlockParamBase(block, name, parent_prefix),
|
||||||
_val() {
|
_val()
|
||||||
|
{
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -93,13 +96,15 @@ template <class T>
|
|||||||
void BlockParam<T>::set(T val) { _val = val; }
|
void BlockParam<T>::set(T val) { _val = val; }
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
void BlockParam<T>::update() {
|
void BlockParam<T>::update()
|
||||||
if (_handle != PARAM_INVALID) param_get(_handle, &_val);
|
{
|
||||||
|
if (_handle != PARAM_INVALID) { param_get(_handle, &_val); }
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
void BlockParam<T>::commit() {
|
void BlockParam<T>::commit()
|
||||||
if (_handle != PARAM_INVALID) param_set(_handle, &_val);
|
{
|
||||||
|
if (_handle != PARAM_INVALID) { param_set(_handle, &_val); }
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
|
|||||||
@@ -126,6 +126,7 @@ float BlockLowPass::update(float input)
|
|||||||
if (!isfinite(getState())) {
|
if (!isfinite(getState())) {
|
||||||
setState(input);
|
setState(input);
|
||||||
}
|
}
|
||||||
|
|
||||||
float b = 2 * float(M_PI) * getFCut() * getDt();
|
float b = 2 * float(M_PI) * getFCut() * getDt();
|
||||||
float a = b / (1 + b);
|
float a = b / (1 + b);
|
||||||
setState(a * input + (1 - a)*getState());
|
setState(a * input + (1 - a)*getState());
|
||||||
@@ -209,6 +210,7 @@ float BlockLowPass2::update(float input)
|
|||||||
if (fabsf(_lp.get_cutoff_freq() - getFCutParam()) > FLT_EPSILON) {
|
if (fabsf(_lp.get_cutoff_freq() - getFCutParam()) > FLT_EPSILON) {
|
||||||
_lp.set_cutoff_frequency(_fs, getFCutParam());
|
_lp.set_cutoff_frequency(_fs, getFCutParam());
|
||||||
}
|
}
|
||||||
|
|
||||||
_state = _lp.apply(input);
|
_state = _lp.apply(input);
|
||||||
return _state;
|
return _state;
|
||||||
}
|
}
|
||||||
@@ -340,8 +342,10 @@ int blockIntegralTrapTest()
|
|||||||
float BlockDerivative::update(float input)
|
float BlockDerivative::update(float input)
|
||||||
{
|
{
|
||||||
float output;
|
float output;
|
||||||
|
|
||||||
if (_initialized) {
|
if (_initialized) {
|
||||||
output = _lowPass.update((input - getU()) / getDt());
|
output = _lowPass.update((input - getU()) / getDt());
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// if this is the first call to update
|
// if this is the first call to update
|
||||||
// we have no valid derivative
|
// we have no valid derivative
|
||||||
@@ -351,6 +355,7 @@ float BlockDerivative::update(float input)
|
|||||||
output = 0.0f;
|
output = 0.0f;
|
||||||
_initialized = true;
|
_initialized = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
setU(input);
|
setU(input);
|
||||||
return output;
|
return output;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -317,7 +317,8 @@ public:
|
|||||||
_kP(this, "") // only one param, no need to name
|
_kP(this, "") // only one param, no need to name
|
||||||
{};
|
{};
|
||||||
virtual ~BlockP() {};
|
virtual ~BlockP() {};
|
||||||
float update(float input) {
|
float update(float input)
|
||||||
|
{
|
||||||
return getKP() * input;
|
return getKP() * input;
|
||||||
}
|
}
|
||||||
// accessors
|
// accessors
|
||||||
@@ -343,7 +344,8 @@ public:
|
|||||||
_kI(this, "I")
|
_kI(this, "I")
|
||||||
{};
|
{};
|
||||||
virtual ~BlockPI() {};
|
virtual ~BlockPI() {};
|
||||||
float update(float input) {
|
float update(float input)
|
||||||
|
{
|
||||||
return getKP() * input +
|
return getKP() * input +
|
||||||
getKI() * getIntegral().update(input);
|
getKI() * getIntegral().update(input);
|
||||||
}
|
}
|
||||||
@@ -374,7 +376,8 @@ public:
|
|||||||
_kD(this, "D")
|
_kD(this, "D")
|
||||||
{};
|
{};
|
||||||
virtual ~BlockPD() {};
|
virtual ~BlockPD() {};
|
||||||
float update(float input) {
|
float update(float input)
|
||||||
|
{
|
||||||
return getKP() * input +
|
return getKP() * input +
|
||||||
getKD() * getDerivative().update(input);
|
getKD() * getDerivative().update(input);
|
||||||
}
|
}
|
||||||
@@ -407,7 +410,8 @@ public:
|
|||||||
_kD(this, "D")
|
_kD(this, "D")
|
||||||
{};
|
{};
|
||||||
virtual ~BlockPID() {};
|
virtual ~BlockPID() {};
|
||||||
float update(float input) {
|
float update(float input)
|
||||||
|
{
|
||||||
return getKP() * input +
|
return getKP() * input +
|
||||||
getKI() * getIntegral().update(input) +
|
getKI() * getIntegral().update(input) +
|
||||||
getKD() * getDerivative().update(input);
|
getKD() * getDerivative().update(input);
|
||||||
@@ -440,11 +444,13 @@ public:
|
|||||||
SuperBlock(parent, name),
|
SuperBlock(parent, name),
|
||||||
_trim(this, "TRIM"),
|
_trim(this, "TRIM"),
|
||||||
_limit(this, ""),
|
_limit(this, ""),
|
||||||
_val(0) {
|
_val(0)
|
||||||
|
{
|
||||||
update(0);
|
update(0);
|
||||||
};
|
};
|
||||||
virtual ~BlockOutput() {};
|
virtual ~BlockOutput() {};
|
||||||
void update(float input) {
|
void update(float input)
|
||||||
|
{
|
||||||
_val = _limit.update(input + getTrim());
|
_val = _limit.update(input + getTrim());
|
||||||
}
|
}
|
||||||
// accessors
|
// accessors
|
||||||
@@ -472,13 +478,15 @@ public:
|
|||||||
const char *name) :
|
const char *name) :
|
||||||
Block(parent, name),
|
Block(parent, name),
|
||||||
_min(this, "MIN"),
|
_min(this, "MIN"),
|
||||||
_max(this, "MAX") {
|
_max(this, "MAX")
|
||||||
|
{
|
||||||
// seed should be initialized somewhere
|
// seed should be initialized somewhere
|
||||||
// in main program for all calls to rand
|
// in main program for all calls to rand
|
||||||
// XXX currently in nuttx if you seed to 0, rand breaks
|
// XXX currently in nuttx if you seed to 0, rand breaks
|
||||||
};
|
};
|
||||||
virtual ~BlockRandUniform() {};
|
virtual ~BlockRandUniform() {};
|
||||||
float update() {
|
float update()
|
||||||
|
{
|
||||||
static float rand_max = MAX_RAND;
|
static float rand_max = MAX_RAND;
|
||||||
float rand_val = rand();
|
float rand_val = rand();
|
||||||
float bounds = getMax() - getMin();
|
float bounds = getMax() - getMin();
|
||||||
@@ -503,13 +511,15 @@ public:
|
|||||||
const char *name) :
|
const char *name) :
|
||||||
Block(parent, name),
|
Block(parent, name),
|
||||||
_mean(this, "MEAN"),
|
_mean(this, "MEAN"),
|
||||||
_stdDev(this, "DEV") {
|
_stdDev(this, "DEV")
|
||||||
|
{
|
||||||
// seed should be initialized somewhere
|
// seed should be initialized somewhere
|
||||||
// in main program for all calls to rand
|
// in main program for all calls to rand
|
||||||
// XXX currently in nuttx if you seed to 0, rand breaks
|
// XXX currently in nuttx if you seed to 0, rand breaks
|
||||||
};
|
};
|
||||||
virtual ~BlockRandGauss() {};
|
virtual ~BlockRandGauss() {};
|
||||||
float update() {
|
float update()
|
||||||
|
{
|
||||||
static float V1, V2, S;
|
static float V1, V2, S;
|
||||||
static int phase = 0;
|
static int phase = 0;
|
||||||
float X;
|
float X;
|
||||||
|
|||||||
@@ -53,10 +53,11 @@ BlockWaypointGuidance::BlockWaypointGuidance(SuperBlock *parent, const char *nam
|
|||||||
|
|
||||||
BlockWaypointGuidance::~BlockWaypointGuidance() {};
|
BlockWaypointGuidance::~BlockWaypointGuidance() {};
|
||||||
|
|
||||||
void BlockWaypointGuidance::update(vehicle_global_position_s &pos,
|
void BlockWaypointGuidance::update(
|
||||||
vehicle_attitude_s &att,
|
const vehicle_global_position_s &pos,
|
||||||
position_setpoint_s &missionCmd,
|
const vehicle_attitude_s &att,
|
||||||
position_setpoint_s &lastMissionCmd)
|
const position_setpoint_s &missionCmd,
|
||||||
|
const position_setpoint_s &lastMissionCmd)
|
||||||
{
|
{
|
||||||
|
|
||||||
// heading to waypoint
|
// heading to waypoint
|
||||||
@@ -83,16 +84,16 @@ void BlockWaypointGuidance::update(vehicle_global_position_s &pos,
|
|||||||
BlockUorbEnabledAutopilot::BlockUorbEnabledAutopilot(SuperBlock *parent, const char *name) :
|
BlockUorbEnabledAutopilot::BlockUorbEnabledAutopilot(SuperBlock *parent, const char *name) :
|
||||||
SuperBlock(parent, name),
|
SuperBlock(parent, name),
|
||||||
// subscriptions
|
// subscriptions
|
||||||
_att(ORB_ID(vehicle_attitude), 20, &getSubscriptions()),
|
_att(ORB_ID(vehicle_attitude), 20, 0, &getSubscriptions()),
|
||||||
_attCmd(ORB_ID(vehicle_attitude_setpoint), 20, &getSubscriptions()),
|
_attCmd(ORB_ID(vehicle_attitude_setpoint), 20, 0, &getSubscriptions()),
|
||||||
_ratesCmd(ORB_ID(vehicle_rates_setpoint), 20, &getSubscriptions()),
|
_ratesCmd(ORB_ID(vehicle_rates_setpoint), 20, 0, &getSubscriptions()),
|
||||||
_pos(ORB_ID(vehicle_global_position), 20, &getSubscriptions()),
|
_pos(ORB_ID(vehicle_global_position), 20, 0, &getSubscriptions()),
|
||||||
_missionCmd(ORB_ID(position_setpoint_triplet), 20, &getSubscriptions()),
|
_missionCmd(ORB_ID(position_setpoint_triplet), 20, 0, &getSubscriptions()),
|
||||||
_manual(ORB_ID(manual_control_setpoint), 20, &getSubscriptions()),
|
_manual(ORB_ID(manual_control_setpoint), 20, 0, &getSubscriptions()),
|
||||||
_status(ORB_ID(vehicle_status), 20, &getSubscriptions()),
|
_status(ORB_ID(vehicle_status), 20, 0, &getSubscriptions()),
|
||||||
_param_update(ORB_ID(parameter_update), 1000, &getSubscriptions()), // limit to 1 Hz
|
_param_update(ORB_ID(parameter_update), 1000, 0, &getSubscriptions()), // limit to 1 Hz
|
||||||
// publications
|
// publications
|
||||||
_actuators(ORB_ID(actuator_controls_0), &getPublications())
|
_actuators(ORB_ID(actuator_controls_0), -1, &getPublications())
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -80,10 +80,10 @@ private:
|
|||||||
public:
|
public:
|
||||||
BlockWaypointGuidance(SuperBlock *parent, const char *name);
|
BlockWaypointGuidance(SuperBlock *parent, const char *name);
|
||||||
virtual ~BlockWaypointGuidance();
|
virtual ~BlockWaypointGuidance();
|
||||||
void update(vehicle_global_position_s &pos,
|
void update(const vehicle_global_position_s &pos,
|
||||||
vehicle_attitude_s &att,
|
const vehicle_attitude_s &att,
|
||||||
position_setpoint_s &missionCmd,
|
const position_setpoint_s &missionCmd,
|
||||||
position_setpoint_s &lastMissionCmd);
|
const position_setpoint_s &lastMissionCmd);
|
||||||
float getPsiCmd() { return _psiCmd; }
|
float getPsiCmd() { return _psiCmd; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -53,7 +53,7 @@ mTecs::mTecs() :
|
|||||||
_airspeedMin(this, "FW_AIRSPD_MIN", false),
|
_airspeedMin(this, "FW_AIRSPD_MIN", false),
|
||||||
/* Publications */
|
/* Publications */
|
||||||
#if defined(__PX4_NUTTX)
|
#if defined(__PX4_NUTTX)
|
||||||
_status(ORB_ID(tecs_status), &getPublications()),
|
_status(ORB_ID(tecs_status), -1, &getPublications()),
|
||||||
#endif // defined(__PX4_NUTTX)
|
#endif // defined(__PX4_NUTTX)
|
||||||
/* control blocks */
|
/* control blocks */
|
||||||
_controlTotalEnergy(this, "THR"),
|
_controlTotalEnergy(this, "THR"),
|
||||||
@@ -111,8 +111,8 @@ int mTecs::updateAltitudeSpeed(float flightPathAngle, float altitude, float alti
|
|||||||
|
|
||||||
#if defined(__PX4_NUTTX)
|
#if defined(__PX4_NUTTX)
|
||||||
/* Write part of the status message */
|
/* Write part of the status message */
|
||||||
_status.altitudeSp = altitudeSp;
|
_status.get().altitudeSp = altitudeSp;
|
||||||
_status.altitude_filtered = altitudeFiltered;
|
_status.get().altitude_filtered = altitudeFiltered;
|
||||||
#endif // defined(__PX4_NUTTX)
|
#endif // defined(__PX4_NUTTX)
|
||||||
|
|
||||||
|
|
||||||
@@ -149,8 +149,8 @@ int mTecs::updateFlightPathAngleSpeed(float flightPathAngle, float flightPathAng
|
|||||||
|
|
||||||
#if defined(__PX4_NUTTX)
|
#if defined(__PX4_NUTTX)
|
||||||
/* Write part of the status message */
|
/* Write part of the status message */
|
||||||
_status.airspeedSp = airspeedSp;
|
_status.get().airspeedSp = airspeedSp;
|
||||||
_status.airspeed_filtered = airspeedFiltered;
|
_status.get().airspeed_filtered = airspeedFiltered;
|
||||||
#endif // defined(__PX4_NUTTX)
|
#endif // defined(__PX4_NUTTX)
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -50,37 +50,63 @@
|
|||||||
#include "topics/encoders.h"
|
#include "topics/encoders.h"
|
||||||
#include "topics/tecs_status.h"
|
#include "topics/tecs_status.h"
|
||||||
#include "topics/rc_channels.h"
|
#include "topics/rc_channels.h"
|
||||||
|
#include "topics/filtered_bottom_flow.h"
|
||||||
|
|
||||||
|
#include <px4_defines.h>
|
||||||
|
|
||||||
namespace uORB
|
namespace uORB
|
||||||
{
|
{
|
||||||
|
|
||||||
template<class T>
|
PublicationBase::PublicationBase(const struct orb_metadata *meta,
|
||||||
Publication<T>::Publication(
|
int priority) :
|
||||||
const struct orb_metadata *meta,
|
_meta(meta),
|
||||||
List<PublicationNode *> *list) :
|
_priority(priority),
|
||||||
T(), // initialize data structure to zero
|
_instance(),
|
||||||
PublicationNode(meta, list)
|
_handle(nullptr)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class T>
|
void PublicationBase::update(void *data)
|
||||||
Publication<T>::~Publication() {}
|
|
||||||
|
|
||||||
template<class T>
|
|
||||||
void *Publication<T>::getDataVoidPtr()
|
|
||||||
{
|
{
|
||||||
return (void *)(T *)(this);
|
if (_handle != nullptr) {
|
||||||
|
int ret = orb_publish(getMeta(), getHandle(), data);
|
||||||
|
|
||||||
|
if (ret != PX4_OK) { warnx("publish fail"); }
|
||||||
|
|
||||||
|
} else {
|
||||||
|
orb_advert_t handle;
|
||||||
|
|
||||||
|
if (_priority > 0) {
|
||||||
|
handle = orb_advertise_multi(
|
||||||
|
getMeta(), data,
|
||||||
|
&_instance, _priority);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
handle = orb_advertise(getMeta(), data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (int64_t(handle) != PX4_ERROR) {
|
||||||
|
setHandle(handle);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
warnx("advert fail");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PublicationBase::~PublicationBase()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
PublicationNode::PublicationNode(const struct orb_metadata *meta,
|
PublicationNode::PublicationNode(const struct orb_metadata *meta,
|
||||||
|
int priority,
|
||||||
List<PublicationNode *> *list) :
|
List<PublicationNode *> *list) :
|
||||||
PublicationBase(meta)
|
PublicationBase(meta, priority)
|
||||||
{
|
{
|
||||||
if (list != nullptr) { list->add(this); }
|
if (list != nullptr) { list->add(this); }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// explicit template instantiation
|
||||||
template class __EXPORT Publication<vehicle_attitude_s>;
|
template class __EXPORT Publication<vehicle_attitude_s>;
|
||||||
template class __EXPORT Publication<vehicle_local_position_s>;
|
template class __EXPORT Publication<vehicle_local_position_s>;
|
||||||
template class __EXPORT Publication<vehicle_global_position_s>;
|
template class __EXPORT Publication<vehicle_global_position_s>;
|
||||||
@@ -94,5 +120,6 @@ template class __EXPORT Publication<actuator_direct_s>;
|
|||||||
template class __EXPORT Publication<encoders_s>;
|
template class __EXPORT Publication<encoders_s>;
|
||||||
template class __EXPORT Publication<tecs_status_s>;
|
template class __EXPORT Publication<tecs_status_s>;
|
||||||
template class __EXPORT Publication<rc_channels_s>;
|
template class __EXPORT Publication<rc_channels_s>;
|
||||||
|
template class __EXPORT Publication<filtered_bottom_flow_s>;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -42,13 +42,13 @@
|
|||||||
|
|
||||||
#include <uORB/uORB.h>
|
#include <uORB/uORB.h>
|
||||||
#include <containers/List.hpp>
|
#include <containers/List.hpp>
|
||||||
|
#include <systemlib/err.h>
|
||||||
|
|
||||||
namespace uORB
|
namespace uORB
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Base publication warapper class, used in list traversal
|
* Base publication wrapper class, used in list traversal
|
||||||
* of various publications.
|
* of various publications.
|
||||||
*/
|
*/
|
||||||
class __EXPORT PublicationBase
|
class __EXPORT PublicationBase
|
||||||
@@ -58,50 +58,40 @@ public:
|
|||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
*
|
*
|
||||||
*
|
* @param meta The uORB metadata (usually from
|
||||||
* @param meta The uORB metadata (usually from the ORB_ID()
|
* the ORB_ID() macro) for the topic.
|
||||||
* macro) for the topic.
|
* @param priority The priority for multi pub/sub, 0-based, -1 means
|
||||||
|
* don't publish as multi
|
||||||
*/
|
*/
|
||||||
PublicationBase(const struct orb_metadata *meta) :
|
PublicationBase(const struct orb_metadata *meta,
|
||||||
_meta(meta),
|
int priority = -1);
|
||||||
_handle(nullptr)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the struct
|
* Update the struct
|
||||||
* @param data The uORB message struct we are updating.
|
* @param data The uORB message struct we are updating.
|
||||||
*/
|
*/
|
||||||
void update(void *data)
|
void update(void *data);
|
||||||
{
|
|
||||||
if (_handle != nullptr) {
|
|
||||||
orb_publish(getMeta(), getHandle(), data);
|
|
||||||
|
|
||||||
} else {
|
|
||||||
setHandle(orb_advertise(getMeta(), data));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deconstructor
|
* Deconstructor
|
||||||
*/
|
*/
|
||||||
virtual ~PublicationBase()
|
virtual ~PublicationBase();
|
||||||
{
|
|
||||||
}
|
|
||||||
// accessors
|
// accessors
|
||||||
const struct orb_metadata *getMeta() { return _meta; }
|
const struct orb_metadata *getMeta() { return _meta; }
|
||||||
orb_advert_t getHandle() { return _handle; }
|
orb_advert_t getHandle() { return _handle; }
|
||||||
protected:
|
protected:
|
||||||
|
// disallow copy
|
||||||
|
PublicationBase(const PublicationBase &other);
|
||||||
|
// disallow assignment
|
||||||
|
PublicationBase &operator=(const PublicationBase &other);
|
||||||
// accessors
|
// accessors
|
||||||
void setHandle(orb_advert_t handle) { _handle = handle; }
|
void setHandle(orb_advert_t handle) { _handle = handle; }
|
||||||
// attributes
|
// attributes
|
||||||
const struct orb_metadata *_meta;
|
const struct orb_metadata *_meta;
|
||||||
|
int _priority;
|
||||||
|
int _instance;
|
||||||
orb_advert_t _handle;
|
orb_advert_t _handle;
|
||||||
private:
|
|
||||||
// forbid copy
|
|
||||||
PublicationBase(const PublicationBase &) : _meta(), _handle() {};
|
|
||||||
// forbid assignment
|
|
||||||
PublicationBase &operator = (const PublicationBase &);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -121,13 +111,14 @@ public:
|
|||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
*
|
*
|
||||||
*
|
* @param meta The uORB metadata (usually from
|
||||||
* @param meta The uORB metadata (usually from the ORB_ID()
|
* the ORB_ID() macro) for the topic.
|
||||||
* macro) for the topic.
|
* @param priority The priority for multi pub, 0-based.
|
||||||
* @param list A pointer to a list of subscriptions
|
* @param list A list interface for adding to
|
||||||
* that this should be appended to.
|
* list during construction
|
||||||
*/
|
*/
|
||||||
PublicationNode(const struct orb_metadata *meta,
|
PublicationNode(const struct orb_metadata *meta,
|
||||||
|
int priority = -1,
|
||||||
List<PublicationNode *> *list = nullptr);
|
List<PublicationNode *> *list = nullptr);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -142,7 +133,6 @@ public:
|
|||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
class __EXPORT Publication :
|
class __EXPORT Publication :
|
||||||
public T, // this must be first!
|
|
||||||
public PublicationNode
|
public PublicationNode
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@@ -151,33 +141,37 @@ public:
|
|||||||
*
|
*
|
||||||
* @param meta The uORB metadata (usually from
|
* @param meta The uORB metadata (usually from
|
||||||
* the ORB_ID() macro) for the topic.
|
* the ORB_ID() macro) for the topic.
|
||||||
|
* @param priority The priority for multi pub, 0-based.
|
||||||
* @param list A list interface for adding to
|
* @param list A list interface for adding to
|
||||||
* list during construction
|
* list during construction
|
||||||
*/
|
*/
|
||||||
Publication(const struct orb_metadata *meta,
|
Publication(const struct orb_metadata *meta,
|
||||||
List<PublicationNode *> *list = nullptr);
|
int priority = -1,
|
||||||
|
List<PublicationNode *> *list = nullptr) :
|
||||||
|
PublicationNode(meta, priority, list),
|
||||||
|
_data()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deconstructor
|
* Deconstructor
|
||||||
**/
|
**/
|
||||||
virtual ~Publication();
|
virtual ~Publication() {};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* XXX
|
* This function gets the T struct
|
||||||
* This function gets the T struct, assuming
|
* */
|
||||||
* the struct is the first base class, this
|
T &get() { return _data; }
|
||||||
* should use dynamic cast, but doesn't
|
|
||||||
* seem to be available
|
|
||||||
*/
|
|
||||||
void *getDataVoidPtr();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create an update function that uses the embedded struct.
|
* Create an update function that uses the embedded struct.
|
||||||
*/
|
*/
|
||||||
void update()
|
void update()
|
||||||
{
|
{
|
||||||
PublicationBase::update(getDataVoidPtr());
|
PublicationBase::update((void *)(&_data));
|
||||||
}
|
}
|
||||||
|
private:
|
||||||
|
T _data;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace uORB
|
} // namespace uORB
|
||||||
|
|||||||
@@ -54,37 +54,89 @@
|
|||||||
#include "topics/vehicle_attitude_setpoint.h"
|
#include "topics/vehicle_attitude_setpoint.h"
|
||||||
#include "topics/vehicle_rates_setpoint.h"
|
#include "topics/vehicle_rates_setpoint.h"
|
||||||
#include "topics/rc_channels.h"
|
#include "topics/rc_channels.h"
|
||||||
|
#include "topics/battery_status.h"
|
||||||
|
#include "topics/optical_flow.h"
|
||||||
|
#include "topics/distance_sensor.h"
|
||||||
|
#include "topics/home_position.h"
|
||||||
#include "topics/vehicle_control_mode.h"
|
#include "topics/vehicle_control_mode.h"
|
||||||
#include "topics/actuator_armed.h"
|
#include "topics/actuator_armed.h"
|
||||||
|
#include "topics/att_pos_mocap.h"
|
||||||
|
#include "topics/vision_position_estimate.h"
|
||||||
|
|
||||||
|
#include <px4_defines.h>
|
||||||
|
|
||||||
namespace uORB
|
namespace uORB
|
||||||
{
|
{
|
||||||
|
|
||||||
template<class T>
|
SubscriptionBase::SubscriptionBase(const struct orb_metadata *meta,
|
||||||
Subscription<T>::Subscription(
|
unsigned interval, unsigned instance) :
|
||||||
const struct orb_metadata *meta,
|
_meta(meta),
|
||||||
unsigned interval,
|
_instance(instance),
|
||||||
List<SubscriptionNode *> *list) :
|
_handle()
|
||||||
T(), // initialize data structure to zero
|
{
|
||||||
SubscriptionNode(meta, interval, list)
|
if (_instance > 0) {
|
||||||
|
_handle = orb_subscribe_multi(
|
||||||
|
getMeta(), instance);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
_handle = orb_subscribe(getMeta());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_handle < 0) { warnx("sub failed"); }
|
||||||
|
|
||||||
|
orb_set_interval(getHandle(), interval);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SubscriptionBase::updated()
|
||||||
|
{
|
||||||
|
bool isUpdated = false;
|
||||||
|
int ret = orb_check(_handle, &isUpdated);
|
||||||
|
|
||||||
|
if (ret != PX4_OK) { warnx("orb check failed"); }
|
||||||
|
|
||||||
|
return isUpdated;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SubscriptionBase::update(void *data)
|
||||||
|
{
|
||||||
|
if (updated()) {
|
||||||
|
int ret = orb_copy(_meta, _handle, data);
|
||||||
|
|
||||||
|
if (ret != PX4_OK) { warnx("orb copy failed"); }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SubscriptionBase::~SubscriptionBase()
|
||||||
|
{
|
||||||
|
int ret = orb_unsubscribe(_handle);
|
||||||
|
|
||||||
|
if (ret != PX4_OK) { warnx("orb unsubscribe failed"); }
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
Subscription<T>::Subscription(const struct orb_metadata *meta,
|
||||||
|
unsigned interval,
|
||||||
|
int instance,
|
||||||
|
List<SubscriptionNode *> *list) :
|
||||||
|
SubscriptionNode(meta, interval, instance, list),
|
||||||
|
_data() // initialize data structure to zero
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class T>
|
template <class T>
|
||||||
Subscription<T>::~Subscription() {}
|
Subscription<T>::~Subscription()
|
||||||
|
|
||||||
template<class T>
|
|
||||||
void *Subscription<T>::getDataVoidPtr()
|
|
||||||
{
|
{
|
||||||
return (void *)(T *)(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
template<class T>
|
template <class T>
|
||||||
T Subscription<T>::getData()
|
void Subscription<T>::update()
|
||||||
{
|
{
|
||||||
return T(*this);
|
SubscriptionBase::update((void *)(&_data));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
const T &Subscription<T>::get() { return _data; }
|
||||||
|
|
||||||
template class __EXPORT Subscription<parameter_update_s>;
|
template class __EXPORT Subscription<parameter_update_s>;
|
||||||
template class __EXPORT Subscription<actuator_controls_s>;
|
template class __EXPORT Subscription<actuator_controls_s>;
|
||||||
template class __EXPORT Subscription<vehicle_gps_position_s>;
|
template class __EXPORT Subscription<vehicle_gps_position_s>;
|
||||||
@@ -104,5 +156,11 @@ template class __EXPORT Subscription<vehicle_rates_setpoint_s>;
|
|||||||
template class __EXPORT Subscription<rc_channels_s>;
|
template class __EXPORT Subscription<rc_channels_s>;
|
||||||
template class __EXPORT Subscription<vehicle_control_mode_s>;
|
template class __EXPORT Subscription<vehicle_control_mode_s>;
|
||||||
template class __EXPORT Subscription<actuator_armed_s>;
|
template class __EXPORT Subscription<actuator_armed_s>;
|
||||||
|
template class __EXPORT Subscription<battery_status_s>;
|
||||||
|
template class __EXPORT Subscription<home_position_s>;
|
||||||
|
template class __EXPORT Subscription<optical_flow_s>;
|
||||||
|
template class __EXPORT Subscription<distance_sensor_s>;
|
||||||
|
template class __EXPORT Subscription<att_pos_mocap_s>;
|
||||||
|
template class __EXPORT Subscription<vision_position_estimate_s>;
|
||||||
|
|
||||||
} // namespace uORB
|
} // namespace uORB
|
||||||
|
|||||||
@@ -42,6 +42,7 @@
|
|||||||
|
|
||||||
#include <uORB/uORB.h>
|
#include <uORB/uORB.h>
|
||||||
#include <containers/List.hpp>
|
#include <containers/List.hpp>
|
||||||
|
#include <systemlib/err.h>
|
||||||
|
|
||||||
namespace uORB
|
namespace uORB
|
||||||
{
|
{
|
||||||
@@ -60,47 +61,29 @@ public:
|
|||||||
*
|
*
|
||||||
* @param meta The uORB metadata (usually from the ORB_ID()
|
* @param meta The uORB metadata (usually from the ORB_ID()
|
||||||
* macro) for the topic.
|
* macro) for the topic.
|
||||||
*
|
|
||||||
* @param interval The minimum interval in milliseconds
|
* @param interval The minimum interval in milliseconds
|
||||||
* between updates
|
* between updates
|
||||||
|
* @param instance The instance for multi sub.
|
||||||
*/
|
*/
|
||||||
SubscriptionBase(const struct orb_metadata *meta,
|
SubscriptionBase(const struct orb_metadata *meta,
|
||||||
unsigned interval = 0) :
|
unsigned interval = 0, unsigned instance = 0);
|
||||||
_meta(meta),
|
|
||||||
_handle()
|
|
||||||
{
|
|
||||||
setHandle(orb_subscribe(getMeta()));
|
|
||||||
orb_set_interval(getHandle(), interval);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if there is a new update.
|
* Check if there is a new update.
|
||||||
* */
|
* */
|
||||||
bool updated()
|
bool updated();
|
||||||
{
|
|
||||||
bool isUpdated = false;
|
|
||||||
orb_check(_handle, &isUpdated);
|
|
||||||
return isUpdated;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update the struct
|
* Update the struct
|
||||||
* @param data The uORB message struct we are updating.
|
* @param data The uORB message struct we are updating.
|
||||||
*/
|
*/
|
||||||
void update(void *data)
|
void update(void *data);
|
||||||
{
|
|
||||||
if (updated()) {
|
|
||||||
orb_copy(_meta, _handle, data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deconstructor
|
* Deconstructor
|
||||||
*/
|
*/
|
||||||
virtual ~SubscriptionBase()
|
virtual ~SubscriptionBase();
|
||||||
{
|
|
||||||
orb_unsubscribe(_handle);
|
|
||||||
}
|
|
||||||
// accessors
|
// accessors
|
||||||
const struct orb_metadata *getMeta() { return _meta; }
|
const struct orb_metadata *getMeta() { return _meta; }
|
||||||
int getHandle() { return _handle; }
|
int getHandle() { return _handle; }
|
||||||
@@ -109,12 +92,13 @@ protected:
|
|||||||
void setHandle(int handle) { _handle = handle; }
|
void setHandle(int handle) { _handle = handle; }
|
||||||
// attributes
|
// attributes
|
||||||
const struct orb_metadata *_meta;
|
const struct orb_metadata *_meta;
|
||||||
|
int _instance;
|
||||||
int _handle;
|
int _handle;
|
||||||
private:
|
private:
|
||||||
// forbid copy
|
// disallow copy
|
||||||
SubscriptionBase(const SubscriptionBase &other);
|
SubscriptionBase(const SubscriptionBase &other);
|
||||||
// forbid assignment
|
// disallow assignment
|
||||||
SubscriptionBase &operator = (const SubscriptionBase &);
|
SubscriptionBase &operator=(const SubscriptionBase &other);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -123,7 +107,7 @@ private:
|
|||||||
typedef SubscriptionBase SubscriptionTiny;
|
typedef SubscriptionBase SubscriptionTiny;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The publication base class as a list node.
|
* The subscription base class as a list node.
|
||||||
*/
|
*/
|
||||||
class __EXPORT SubscriptionNode :
|
class __EXPORT SubscriptionNode :
|
||||||
|
|
||||||
@@ -134,18 +118,19 @@ public:
|
|||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
*
|
*
|
||||||
*
|
|
||||||
* @param meta The uORB metadata (usually from the ORB_ID()
|
* @param meta The uORB metadata (usually from the ORB_ID()
|
||||||
* macro) for the topic.
|
* macro) for the topic.
|
||||||
* @param interval The minimum interval in milliseconds
|
* @param interval The minimum interval in milliseconds
|
||||||
* between updates
|
* between updates
|
||||||
|
* @param instance The instance for multi sub.
|
||||||
* @param list A pointer to a list of subscriptions
|
* @param list A pointer to a list of subscriptions
|
||||||
* that this should be appended to.
|
* that this should be appended to.
|
||||||
*/
|
*/
|
||||||
SubscriptionNode(const struct orb_metadata *meta,
|
SubscriptionNode(const struct orb_metadata *meta,
|
||||||
unsigned interval = 0,
|
unsigned interval = 0,
|
||||||
|
int instance = 0,
|
||||||
List<SubscriptionNode *> *list = nullptr) :
|
List<SubscriptionNode *> *list = nullptr) :
|
||||||
SubscriptionBase(meta, interval),
|
SubscriptionBase(meta, interval, instance),
|
||||||
_interval(interval)
|
_interval(interval)
|
||||||
{
|
{
|
||||||
if (list != nullptr) { list->add(this); }
|
if (list != nullptr) { list->add(this); }
|
||||||
@@ -169,7 +154,6 @@ protected:
|
|||||||
*/
|
*/
|
||||||
template<class T>
|
template<class T>
|
||||||
class __EXPORT Subscription :
|
class __EXPORT Subscription :
|
||||||
public T, // this must be first!
|
|
||||||
public SubscriptionNode
|
public SubscriptionNode
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@@ -185,7 +169,9 @@ public:
|
|||||||
*/
|
*/
|
||||||
Subscription(const struct orb_metadata *meta,
|
Subscription(const struct orb_metadata *meta,
|
||||||
unsigned interval = 0,
|
unsigned interval = 0,
|
||||||
|
int instance = 0,
|
||||||
List<SubscriptionNode *> *list = nullptr);
|
List<SubscriptionNode *> *list = nullptr);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deconstructor
|
* Deconstructor
|
||||||
*/
|
*/
|
||||||
@@ -195,20 +181,14 @@ public:
|
|||||||
/**
|
/**
|
||||||
* Create an update function that uses the embedded struct.
|
* Create an update function that uses the embedded struct.
|
||||||
*/
|
*/
|
||||||
void update()
|
void update();
|
||||||
{
|
|
||||||
SubscriptionBase::update(getDataVoidPtr());
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* XXX
|
* This function gets the T struct data
|
||||||
* This function gets the T struct, assuming
|
* */
|
||||||
* the struct is the first base class, this
|
const T &get();
|
||||||
* should use dynamic cast, but doesn't
|
private:
|
||||||
* seem to be available
|
T _data;
|
||||||
*/
|
|
||||||
void *getDataVoidPtr();
|
|
||||||
T getData();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace uORB
|
} // namespace uORB
|
||||||
|
|||||||
Reference in New Issue
Block a user