MAV'RIC
/home/travis/build/lis-epfl/MAVRIC_Library/control/velocity_controller.hpp
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_ */
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Friends Defines