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 altitude_estimation.hpp 00034 * 00035 * \author MAV'RIC Team 00036 * \author Julien Lecoeur 00037 * 00038 * \brief Altitude estimation 00039 * 00040 ******************************************************************************/ 00041 00042 00043 #ifndef ALTITUDE_ESTIMATION_HPP_ 00044 #define ALTITUDE_ESTIMATION_HPP_ 00045 00046 00047 #include "drivers/sonar.hpp" 00048 #include "drivers/barometer.hpp" 00049 #include "sensing/ahrs.hpp" 00050 #include "util/kalman.hpp" 00051 00052 extern "C" 00053 { 00054 #include "sensing/altitude.h" 00055 } 00056 00057 00061 typedef struct 00062 { 00063 } altitude_estimation_conf_t; 00064 00065 00071 static inline altitude_estimation_conf_t altitude_estimation_default_config(void); 00072 00073 00077 class Altitude_estimation: public Kalman<3,1,1> 00078 { 00079 public: 00080 Altitude_estimation(Sonar& sonar, 00081 Barometer& barometer, 00082 AHRS& ahrs, 00083 altitude_t& altitude, 00084 altitude_estimation_conf_t config = altitude_estimation_default_config() ); 00085 00091 bool init(void); 00092 00093 00099 bool update(void); 00100 00101 00102 private: 00103 const Sonar& sonar_; 00104 const Barometer& barometer_; 00105 const AHRS& ahrs_; 00106 altitude_t& altitude_; 00107 00108 altitude_estimation_conf_t config_; 00109 00110 float last_sonar_update_us_; 00111 }; 00112 00113 00114 static inline altitude_estimation_conf_t altitude_estimation_default_config(void) 00115 { 00116 altitude_estimation_conf_t conf = {}; 00117 00118 return conf; 00119 } 00120 00121 #endif /* ALTITUDE_ESTIMATION_HPP_ */