MOOS 0.2375
/home/toby/moos-ivp/MOOS-2375-Oct0611/NavigationAndControl/MOOSNavLib/MOOSNavLSQEngine.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 // MOOSNavLSQEngine.h: interface for the CMOOSNavLSQEngine class.
00032 //
00034 
00035 #if !defined(AFX_MOOSNAVLSQENGINE_H__310A3F56_1319_4C86_95BC_9986EB653113__INCLUDED_)
00036 #define AFX_MOOSNAVLSQENGINE_H__310A3F56_1319_4C86_95BC_9986EB653113__INCLUDED_
00037 
00038 #if _MSC_VER > 1000
00039 #pragma once
00040 #endif // _MSC_VER > 1000
00041 
00042 #include "MOOSNavEngine.h"
00043 
00044 #define RANGES_FOR_PURE_LBL_FIX 3
00045 
00046 //typedef map<int,OBSLIST> CHANNEL_OBSLIST_MAP;
00047 typedef map<string,OBSLIST> SOURCE_OBSLIST_MAP;
00048 
00049 class CMOOSNavLSQEngine : public CMOOSNavEngine  
00050 {
00051 public:
00052     enum LSQStatus
00053     {
00054         LSQ_NO_SOLUTION,
00055         LSQ_IN_PROGRESS,
00056         LSQ_SOLVED,
00057         LSQ_BIG_CHANGE
00058     };
00059 
00060     CMOOSNavLSQEngine();
00061     virtual ~CMOOSNavLSQEngine();
00062     virtual bool Iterate(double dfTimeNow);
00063     virtual bool AddData(const CMOOSMsg &Msg);
00064     virtual bool Initialise(STRING_LIST  sParams);
00065 
00066 protected:
00067     bool PublishData();
00068 
00069     bool DoWStatistic();
00070     virtual bool OnSolved();
00071     bool IsReasonableMerit();
00072     void DoDebug();
00073 
00074     bool        IterateRequired(double dfTimeNow);
00075     LSQStatus    Solve();
00076 
00077     double    m_dfLSQWindow;
00078     int        m_nLSQIterations;
00079     bool    m_bTryToSolve;
00080     double  m_dfLastSolveAttempt;
00081     bool    m_bGuessed;
00082     
00083 };
00084 
00085 #endif // !defined(AFX_MOOSNAVLSQENGINE_H__310A3F56_1319_4C86_95BC_9986EB653113__INCLUDED_)
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines