/**************************************************************************** * * Copyright (c) 2013 PX4 Development Team. All rights reserved. * Author: @author Thomas Gubler * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * 3. Neither the name PX4 nor the names of its contributors may be * used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * ****************************************************************************/ /** * @file mTecs.h * * @author Thomas Gubler */ #ifndef MTECS_H_ #define MTECS_H_ #include "mTecs_blocks.h" #include #include #include #include namespace fwPosctrl { /* Main class of the mTecs */ class mTecs : public control::SuperBlock { public: mTecs(); virtual ~mTecs(); /* A small class which provides helper fucntions to override control output limits which are usually set by * parameters in special cases */ class LimitOverride { public: LimitOverride() : overrideThrottleMinEnabled(false), overrideThrottleMaxEnabled(false), overridePitchMinEnabled(false), overridePitchMaxEnabled(false) {}; ~LimitOverride() {}; /* * Override the limits of the outputlimiter instances given by the arguments with the limits saved in * this class (if enabled) * @return true if the limit was applied */ bool applyOverride(BlockOutputLimiter &outputLimiterThrottle, BlockOutputLimiter &outputLimiterPitch); /* Functions to enable or disable the override */ void enableThrottleMinOverride(float value) { enable(&overrideThrottleMinEnabled, &overrideThrottleMin, value); } void disableThrottleMinOverride() { disable(&overrideThrottleMinEnabled); } void enableThrottleMaxOverride(float value) { enable(&overrideThrottleMaxEnabled, &overrideThrottleMax, value); } void disableThrottleMaxOverride() { disable(&overrideThrottleMaxEnabled); } void enablePitchMinOverride(float value) { enable(&overridePitchMinEnabled, &overridePitchMin, value); } void disablePitchMinOverride() { disable(&overridePitchMinEnabled); } void enablePitchMaxOverride(float value) { enable(&overridePitchMaxEnabled, &overridePitchMax, value); } void disablePitchMaxOverride() { disable(&overridePitchMaxEnabled); } protected: bool overrideThrottleMinEnabled; float overrideThrottleMin; bool overrideThrottleMaxEnabled; float overrideThrottleMax; bool overridePitchMinEnabled; float overridePitchMin; //in degrees (replaces param values) bool overridePitchMaxEnabled; float overridePitchMax; //in degrees (replaces param values) /* Enable a specific limit override */ void enable(bool *flag, float *limit, float value) { *flag = true; *limit = value; }; /* Disable a specific limit override */ void disable(bool *flag) { *flag = false; }; }; /* * Control in altitude setpoint and speed mode */ int updateAltitudeSpeed(float flightPathAngle, float altitude, float altitudeSp, float airspeed, float airspeedSp, tecs_mode mode, LimitOverride limitOverride); /* * Control in flightPathAngle setpoint (flollow a slope etc.) and speed mode */ int updateFlightPathAngleSpeed(float flightPathAngle, float flightPathAngleSp, float airspeed, float airspeedSp, tecs_mode mode, LimitOverride limitOverride); /* * Control in flightPathAngle setpoint (flollow a slope etc.) and acceleration mode (base case) */ int updateFlightPathAngleAcceleration(float flightPathAngle, float flightPathAngleSp, float airspeed, float accelerationLongitudinalSp, tecs_mode mode, LimitOverride limitOverride); /* * Reset all integrators */ void resetIntegrators(); /* * Reset all derivative calculations */ void resetDerivatives(float airspeed); /* Accessors */ bool getEnabled() {return _mTecsEnabled.get() > 0;} float getThrottleSetpoint() {return _throttleSp;} float getPitchSetpoint() {return _pitchSp;} protected: /* parameters */ control::BlockParamInt _mTecsEnabled; /**< 1 if mTecs is enabled */ control::BlockParamFloat _airspeedMin; /**< minimal airspeed */ /* Publications */ uORB::Publication _status; /**< publish internal values for logging */ /* control blocks */ BlockFFPILimitedCustom _controlTotalEnergy; /**< FFPI controller for total energy control: output is throttle */ BlockFFPILimitedCustom _controlEnergyDistribution; /**< FFPI controller for energy distribution control: output is pitch */ BlockPDLimited _controlAltitude; /**< P controller for altitude: output is the flight path angle setpoint */ BlockPLimited _controlAirSpeed; /**< P controller for airspeed: output is acceleration setpoint */ /* Other calculation Blocks */ control::BlockDerivative _airspeedDerivative; /* Output setpoints */ float _throttleSp; /**< Throttle Setpoint from 0 to 1 */ float _pitchSp; /**< Pitch Setpoint from -pi to pi */ /* Output Limits in special modes */ BlockOutputLimiter _BlockOutputLimiterTakeoffThrottle; /**< Throttle Limits during takeoff */ BlockOutputLimiter _BlockOutputLimiterTakeoffPitch; /**< Pitch Limit during takeoff */ BlockOutputLimiter _BlockOutputLimiterUnderspeedThrottle; /**< Throttle Limits when underspeed is detected */ BlockOutputLimiter _BlockOutputLimiterUnderspeedPitch; /**< Pitch Limit when underspeed is detected */ BlockOutputLimiter _BlockOutputLimiterLandThrottle; /**< Throttle Limits during landing (only in last phase)*/ BlockOutputLimiter _BlockOutputLimiterLandPitch; /**< Pitch Limit during landing */ /* Time measurements */ hrt_abstime timestampLastIteration; /**< Saves the result of hrt_absolute_time() of the last iteration */ bool _firstIterationAfterReset; /**< True during the first iteration after a reset */ bool _dtCalculated; /**< True if dt has been calculated in this iteration */ int _counter; bool _debug; ///< Set true to enable debug output static void debug_print(const char *fmt, va_list args); void debug(const char *fmt, ...); /* * Measure and update the time step dt if this was not already done in the current iteration */ void updateTimeMeasurement(); }; } /* namespace fwPosctrl */ #endif /* MTECS_H_ */