mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-26 10:38:28 -04:00
236 lines
7.9 KiB
C++
236 lines
7.9 KiB
C++
/*
|
|
* AP_ControllerBlock.h
|
|
* Copyright (C) James Goppert 2010 <james.goppert@gmail.com>
|
|
*
|
|
* This file 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 file 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 <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef AP_ControllerBlock_H
|
|
#define AP_ControllerBlock_H
|
|
|
|
// inclusions
|
|
#include "../AP_Common/AP_Common.h"
|
|
#include "../AP_Common/AP_Var.h"
|
|
|
|
// ArduPilotOne namespace
|
|
namespace apo {
|
|
|
|
///
|
|
// The abstract class defining a controller block.
|
|
class AP_ControllerBlock {
|
|
public:
|
|
///
|
|
// Controller block constructor.
|
|
// This creates a controller block.
|
|
// @group The group containing the class parameters.
|
|
// @groupStart The start of the group. Used for chaining parameters.
|
|
// @groupEnd The end of the group.
|
|
AP_ControllerBlock(AP_Var_group * group, uint8_t groupStart,
|
|
uint8_t groupLength);
|
|
|
|
///
|
|
// Get the end of the AP_Var group.
|
|
// This is used for chaining multiple AP_Var groups into one.
|
|
uint8_t getGroupEnd() {
|
|
return _groupEnd;
|
|
}
|
|
protected:
|
|
AP_Var_group * _group; /// Contains all the parameters of the class.
|
|
uint8_t _groupStart; /// The start of the AP_Var group. Used for chaining parameters.
|
|
uint8_t _groupEnd; /// The end of the AP_Var group.
|
|
};
|
|
|
|
///
|
|
// A low pass filter block.
|
|
// This takes a signal and smooths it out. It
|
|
// cuts all frequencies higher than the frequency provided.
|
|
class BlockLowPass: public AP_ControllerBlock {
|
|
public:
|
|
///
|
|
// The constructor.
|
|
// @group The group containing the class parameters.
|
|
// @groupStart The start of the group. Used for chaining parameters.
|
|
// @fCut The cut-off frequency in Hz for smoothing.
|
|
BlockLowPass(AP_Var_group * group, uint8_t groupStart, float fCut,
|
|
const prog_char_t * fCutLabel = NULL);
|
|
|
|
///
|
|
// The update function.
|
|
// @input The input signal.
|
|
// @dt The timer interval.
|
|
// @return The output (smoothed) signal.
|
|
float update(const float & input, const float & dt);
|
|
protected:
|
|
AP_Float _fCut; /// The cut-off frequency in Hz.
|
|
float _y; /// The internal state of the low pass filter.
|
|
};
|
|
|
|
///
|
|
// This block saturates a signal.
|
|
// If the signal is above max it is set to max.
|
|
// If it is below -max it is set to -max.
|
|
class BlockSaturation: public AP_ControllerBlock {
|
|
public:
|
|
///
|
|
// Controller block constructor.
|
|
// This creates a controller block.
|
|
// @group The group containing the class parameters.
|
|
// @groupStart The start of the group. Used for chaining parameters.
|
|
// @yMax The maximum threshold.
|
|
BlockSaturation(AP_Var_group * group, uint8_t groupStart, float yMax,
|
|
const prog_char_t * yMaxLabel = NULL);
|
|
///
|
|
// The update function.
|
|
// @input The input signal.
|
|
// @return The output (saturated) signal.
|
|
float update(const float & input);
|
|
protected:
|
|
AP_Float _yMax; /// output saturation
|
|
};
|
|
|
|
///
|
|
// This block calculates a derivative.
|
|
class BlockDerivative {
|
|
public:
|
|
/// The constructor.
|
|
BlockDerivative();
|
|
|
|
///
|
|
// The update function.
|
|
// @input The input signal.
|
|
// @return The derivative.
|
|
float update(const float & input, const float & dt);
|
|
protected:
|
|
float _lastInput; /// The last input to the block.
|
|
bool firstRun; /// Keeps track of first run inorder to decide if _lastInput should be used.
|
|
};
|
|
|
|
/// This block calculates an integral.
|
|
class BlockIntegral {
|
|
public:
|
|
/// The constructor.
|
|
BlockIntegral();
|
|
///
|
|
// The update function.
|
|
// @input The input signal.
|
|
// @dt The timer interval.
|
|
// @return The output (integrated) signal.
|
|
float update(const float & input, const float & dt);
|
|
protected:
|
|
float _i; /// integral
|
|
};
|
|
|
|
///
|
|
// This is a proportional block with built-in gain.
|
|
class BlockP: public AP_ControllerBlock {
|
|
public:
|
|
BlockP(AP_Var_group * group, uint8_t groupStart, float kP,
|
|
const prog_char_t * kPLabel = NULL);
|
|
///
|
|
// The update function.
|
|
// @input The input signal.
|
|
// @return The output signal (kP*input).
|
|
float update(const float & input);
|
|
protected:
|
|
AP_Float _kP; /// proportional gain
|
|
};
|
|
|
|
///
|
|
// This is a integral block with built-in gain.
|
|
class BlockI: public AP_ControllerBlock {
|
|
public:
|
|
BlockI(AP_Var_group * group, uint8_t groupStart, float kI, float iMax,
|
|
const prog_char_t * kILabel = NULL,
|
|
const prog_char_t * iMaxLabel = NULL);
|
|
float update(const float & input, const float & dt);
|
|
protected:
|
|
AP_Float _kI; /// integral gain
|
|
BlockSaturation _blockSaturation; /// integrator saturation
|
|
float _eI; /// internal integrator state
|
|
};
|
|
|
|
///
|
|
// This is a derivative block with built-in gain.
|
|
class BlockD: public AP_ControllerBlock {
|
|
public:
|
|
BlockD(AP_Var_group * group, uint8_t groupStart, float kD, uint8_t dFCut,
|
|
const prog_char_t * kDLabel = NULL,
|
|
const prog_char_t * dFCutLabel = NULL);
|
|
float update(const float & input, const float & dt);
|
|
protected:
|
|
BlockLowPass _blockLowPass; /// The low-pass filter block
|
|
AP_Float _kD; /// The derivative gain
|
|
float _eP; /// The previous state
|
|
};
|
|
|
|
///
|
|
// This is a proportional, integral, derivative block with built-in gains.
|
|
class BlockPID: public AP_ControllerBlock {
|
|
public:
|
|
BlockPID(AP_Var_group * group, uint8_t groupStart, float kP, float kI,
|
|
float kD, float iMax, float yMax, uint8_t dFcut);
|
|
float update(const float & input, const float & dt);
|
|
protected:
|
|
BlockP _blockP; /// The proportional block.
|
|
BlockI _blockI; /// The integral block.
|
|
BlockD _blockD; /// The derivative block.
|
|
BlockSaturation _blockSaturation; /// The saturation block.
|
|
};
|
|
|
|
///
|
|
// This is a proportional, integral block with built-in gains.
|
|
class BlockPI: public AP_ControllerBlock {
|
|
public:
|
|
BlockPI(AP_Var_group * group, uint8_t groupStart, float kP, float kI,
|
|
float iMax, float yMax);
|
|
float update(const float & input, const float & dt);
|
|
protected:
|
|
BlockP _blockP; /// The proportional block.
|
|
BlockI _blockI; /// The derivative block.
|
|
BlockSaturation _blockSaturation; /// The saturation block.
|
|
};
|
|
|
|
///
|
|
// This is a proportional, derivative block with built-in gains.
|
|
class BlockPD: public AP_ControllerBlock {
|
|
public:
|
|
BlockPD(AP_Var_group * group, uint8_t groupStart, float kP, float kI,
|
|
float kD, float iMax, float yMax, uint8_t dFcut);
|
|
float update(const float & input, const float & dt);
|
|
protected:
|
|
BlockP _blockP; /// The proportional block.
|
|
BlockD _blockD; /// The derivative block.
|
|
BlockSaturation _blockSaturation; /// The saturation block.
|
|
};
|
|
|
|
/// PID with derivative feedback (ignores reference derivative)
|
|
class BlockPIDDfb: public AP_ControllerBlock {
|
|
public:
|
|
BlockPIDDfb(AP_Var_group * group, uint8_t groupStart, float kP, float kI,
|
|
float kD, float iMax, float yMax,
|
|
const prog_char_t * dLabel = NULL);
|
|
float update(const float & input, const float & derivative,
|
|
const float & dt);
|
|
protected:
|
|
BlockP _blockP; /// The proportional block.
|
|
BlockI _blockI; /// The integral block.
|
|
BlockSaturation _blockSaturation; /// The saturation block.
|
|
AP_Float _kD; /// derivative gain
|
|
};
|
|
|
|
} // apo
|
|
|
|
#endif // AP_ControllerBlock_H
|
|
// vim:ts=4:sw=4:expandtab
|