MAV'RIC
|
00001 /******************************************************************************* 00002 * Copyright (c) 2009-2016, MAV'RIC Development Team 00003 * All rights reserved. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions are met: 00007 * 00008 * 1. Redistributions of source code must retain the above copyright notice, 00009 * this list of conditions and the following disclaimer. 00010 * 00011 * 2. Redistributions in binary form must reproduce the above copyright notice, 00012 * this list of conditions and the following disclaimer in the documentation 00013 * and/or other materials provided with the distribution. 00014 * 00015 * 3. Neither the name of the copyright holder nor the names of its contributors 00016 * may be used to endorse or promote products derived from this software without 00017 * specific prior written permission. 00018 * 00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 00023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00029 * POSSIBILITY OF SUCH DAMAGE. 00030 ******************************************************************************/ 00031 00032 /******************************************************************************* 00033 * \file velocity_controller.hpp 00034 * 00035 * \author MAV'RIC Team 00036 * \author Julien Lecoeur 00037 * 00038 * \brief Velocity controller base class 00039 * 00040 ******************************************************************************/ 00041 00042 00043 #ifndef VELOCITY_CONTROLLER_HPP_ 00044 #define VELOCITY_CONTROLLER_HPP_ 00045 00046 #include "control/controller.hpp" 00047 #include "control/pid_controller.hpp" 00048 #include "sensing/ahrs.hpp" 00049 #include "sensing/ins.hpp" 00050 00054 class Velocity_controller : public Controller_1_to_2<velocity_command_t, attitude_command_t, thrust_command_t> 00055 { 00056 public: 00057 00061 enum control_frame_t 00062 { 00063 LOCAL_FRAME = 0, 00064 SEMILOCAL_FRAME = 1, 00065 BODY_FRAME = 2 00066 }; 00067 00068 00072 struct conf_t 00073 { 00074 control_frame_t control_frame; 00075 pid_controller_conf_t pid_config[3]; 00076 }; 00077 00078 00082 struct args_t 00083 { 00084 const AHRS& ahrs; 00085 const INS& ins; 00086 velocity_command_t& velocity_command; 00087 attitude_command_t& attitude_command; 00088 thrust_command_t& thrust_command; 00089 }; 00090 00091 00098 Velocity_controller(const args_t& args, const conf_t& config); 00099 00100 00106 bool update(void); 00107 00108 00116 bool set_command(const velocity_command_t& vel); 00117 00118 00126 bool get_command(velocity_command_t& vel) const; 00127 00128 00136 bool get_output(attitude_command_t& att) const; 00137 00138 00146 bool get_output(thrust_command_t& thrust) const; 00147 00148 00154 pid_controller_t& get_pid_X(void); 00155 pid_controller_t& get_pid_Y(void); 00156 pid_controller_t& get_pid_Z(void); 00157 00158 protected: 00159 00169 virtual bool compute_attitude_and_thrust_from_desired_accel(const std::array<float,3>& accel_vector, 00170 attitude_command_t& attitude_command, 00171 thrust_command_t& thrust_command ) = 0; 00172 00173 const AHRS& ahrs_; 00174 const INS& ins_; 00175 velocity_command_t& velocity_command_; 00176 attitude_command_t& attitude_command_; 00177 thrust_command_t& thrust_command_; 00178 00179 control_frame_t control_frame_; 00180 pid_controller_t pid_[3]; 00181 }; 00182 00183 #endif /* VELOCITY_CONTROLLER_HPP_ */