MOOS 0.2375
|
00001 00002 // 00003 // MOOS - Mission Oriented Operating Suite 00004 // 00005 // A suit of Applications and Libraries for Mobile Robotics Research 00006 // Copyright (C) 2001-2005 Massachusetts Institute of Technology and 00007 // Oxford University. 00008 // 00009 // This software was written by Paul Newman and others 00010 // at MIT 2001-2002 and Oxford University 2003-2005. 00011 // email: pnewman@robots.ox.ac.uk. 00012 // 00013 // This file is part of a MOOS Basic (Common) Application. 00014 // 00015 // This program is free software; you can redistribute it and/or 00016 // modify it under the terms of the GNU General Public License as 00017 // published by the Free Software Foundation; either version 2 of the 00018 // License, or (at your option) any later version. 00019 // 00020 // This program is distributed in the hope that it will be useful, 00021 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00022 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00023 // General Public License for more details. 00024 // 00025 // You should have received a copy of the GNU General Public License 00026 // along with this program; if not, write to the Free Software 00027 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 00028 // 02111-1307, USA. 00029 // 00031 // MOOSNavEKFEngine.h: interface for the CMOOSNavEKFEngine class. 00032 // 00034 00035 #if !defined(AFX_MOOSNAVEKFENGINE_H__E0A35A81_1CA8_4A96_9B2B_F301DB02E70C__INCLUDED_) 00036 #define AFX_MOOSNAVEKFENGINE_H__E0A35A81_1CA8_4A96_9B2B_F301DB02E70C__INCLUDED_ 00037 00038 #if _MSC_VER > 1000 00039 #pragma once 00040 #endif // _MSC_VER > 1000 00041 00042 #include "MOOSNavEngine.h" 00043 00044 class CMOOSNavEKFEngine : public CMOOSNavEngine 00045 { 00046 public: 00047 virtual bool Reset(); 00048 bool IsBooted(); 00049 virtual bool Iterate(double dfTimeNow); 00050 virtual bool Initialise(STRING_LIST sParams); 00051 bool AddData(const CMOOSMsg &Msg); 00052 CMOOSNavEKFEngine(); 00053 virtual ~CMOOSNavEKFEngine(); 00054 00055 protected: 00056 00057 bool LimitVelocityStates(); 00058 bool MakeSymmetric(); 00059 bool PredictForward(double dfStop,double dfTimeNow); 00060 bool PublishResults(); 00061 bool OnIterateDone(double dfTimeNow); 00062 bool PreparePredictionMatrices(); 00063 bool FillGlobalParamModelMatrices(double dfDeltaT); 00064 bool InitialiseEstimates(); 00065 bool Boot(); 00066 bool DoPredict(double dfDeltaT); 00067 00068 //fancy data rejection 00069 int HyperDimSelect(Matrix & Innov,Matrix & Cov,Matrix & InvCov); 00070 bool IsInside(Matrix &v, Matrix &Ellipse); 00071 bool ApplyHalfBakedHeuristics(double dfInnov,double dfInnovStd, int i); 00072 00073 Matrix m_jF; 00074 Matrix m_jQ; 00075 Matrix m_S; 00076 00077 Matrix m_XTmp; 00078 Matrix m_PTmp; 00079 00080 double m_dfXYDynamics; 00081 double m_dfZDynamics; 00082 double m_dfYawDynamics; 00083 00084 double m_dfPxx0; 00085 double m_dfPyy0; 00086 double m_dfPzz0; 00087 double m_dfPhh0; 00088 double m_dfPTide0; 00089 00090 double m_dfX0; 00091 double m_dfY0; 00092 double m_dfZ0; 00093 double m_dfH0; 00094 double m_dfTide0; 00095 00096 bool m_bBooted; 00097 double m_dfLastIterated; 00098 double m_dfLag; 00099 double m_dfYawBiasStd; 00100 int m_nUpdates; 00101 00102 double m_dfMaxZVel; 00103 00104 }; 00105 00106 #endif // !defined(AFX_MOOSNAVEKFENGINE_H__E0A35A81_1CA8_4A96_9B2B_F301DB02E70C__INCLUDED_)