MOOS 0.2375
/home/toby/moos-ivp/MOOS-2375-Oct0611/NavigationAndControl/MOOSNavLib/MOOSNavVehicle.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 // MOOSNavVehicle.h: interface for the CMOOSNavVehicle class.
00032 //
00034 
00035 #if !defined(AFX_MOOSNAVVEHICLE_H__AC4BAF08_DD52_4ED9_A7B3_860B132D32BD__INCLUDED_)
00036 #define AFX_MOOSNAVVEHICLE_H__AC4BAF08_DD52_4ED9_A7B3_860B132D32BD__INCLUDED_
00037 
00038 #if _MSC_VER > 1000
00039 #pragma once
00040 #endif // _MSC_VER > 1000
00041 
00042 #include "MOOSNavEntity.h"
00043 
00044 class CMOOSNavVehicle  : public CMOOSNavEntity
00045 {
00046 public:
00047     class CPlantNoise
00048     {
00049     public:
00050         //noise terms for static model
00051         //noise is in velocity
00052         double m_dfqXv;
00053         double m_dfqYv;
00054         double m_dfqZv;
00055         double m_dfqHv;
00056 
00057         //noise terms for dynamic model
00058         //noise is in acceleration
00059         double m_dfqXa;
00060         double m_dfqYa;
00061         double m_dfqZa;
00062         double m_dfqHa;
00063 
00064     };
00065 public:
00066     bool SetDroppedState(bool bDropped);
00067     bool SetDynamics(double dfDynamicsXY,double dfDynamicsZ,double dfDynamicsYaw);
00068 
00069 
00070     CMOOSNavVehicle();
00071     virtual ~CMOOSNavVehicle();
00072 
00073 
00074     virtual bool GetFullState(Matrix &Result,Matrix * m_pXToUse=NULL,bool bUseEstimate=true);
00075     virtual bool RefreshState();
00076     virtual bool FillModelMatrices(Matrix &F,Matrix &Q,Matrix & Xhat,double dfDeltaT);
00077 
00078     virtual int GetStateSize();
00079 
00080 protected:
00081     bool FillPoseOnlyModelMatrices(Matrix & jF,Matrix & jQ,Matrix & Xhat,double dfDeltaT);
00082     bool FillPoseAndRateModelMatrices(Matrix &jF, Matrix &jQ, Matrix &Xhat, double dfDeltaT);
00083 
00084     CPlantNoise m_Noise;
00085     bool    m_bDroppedState;
00086 };
00087 
00088 #endif // !defined(AFX_MOOSNAVVEHICLE_H__AC4BAF08_DD52_4ED9_A7B3_860B132D32BD__INCLUDED_)
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines