MOOS 0.2375
/home/toby/moos-ivp/MOOS-2375-Oct0611/NavigationAndControl/MOOSNavLib/MOOSNavEKFEngine.h
Go to the documentation of this file.
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_)
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines